### MCF51JF128 Reference Manual

Supports the MCF51JF32, MCF51JF64, and MCF51JF128

Document Number: MCF51JF128RM

Rev. 2, 03/2011



2

#### **Contents**

| Section Number |         |              | Title                              | Page |
|----------------|---------|--------------|------------------------------------|------|
|                |         |              | Chapter 1 About This Document      |      |
| 1.1            | Overvi  | ew           |                                    | 63   |
|                | 1.1.1   | Purpose      |                                    | 63   |
|                | 1.1.2   | Audience     | 2                                  | 63   |
| 1.2            | Conve   | ntions       |                                    | 63   |
|                | 1.2.1   | Numberii     | ng systems                         | 63   |
|                | 1.2.2   | Typograp     | phic notation                      | 64   |
|                | 1.2.3   | Special te   | erms                               | 64   |
|                | 1.2.4   | Register     | reset                              | 65   |
|                |         |              | Chapter 2<br>Introduction          |      |
| 2.1            | ColdFi  | re+ Portfoli | io Introduction                    | 67   |
| 2.2            | MCF5    | IJF128 Bloo  | ck Diagram                         | 68   |
| 2.3            | MCF5    | 1JF Feature  | Summary                            | 69   |
| 2.4            | MCF5    | 1JF Feature  | s by Package                       |      |
|                |         |              | Chapter 3 Chip Configuration       |      |
| 3.1            | Introdu | iction       |                                    | 77   |
| 3.2            | Modul   | e to Module  | e Interaction Summary              | 77   |
| 3.3            | Core m  | nodules      |                                    | 79   |
|                | 3.3.1   | Version 1    | 1 (V1) ColdFire Core Configuration | 79   |
|                | 3.3.2   | Debug Co     | onfiguration                       |      |
| 3.4            | System  | modules      |                                    | 80   |
|                | 3.4.1   | Crossbar     | Switch Configuration.              | 80   |
|                |         | 3.4.1.1      | Crossbar Switch Master Assignments | 81   |
|                |         | 3.4.1.2      | Crossbar Switch Slave Assignments  | 82   |
|                |         |              |                                    |      |

| Sec | tion N | umber       | Title                                                      | Page |
|-----|--------|-------------|------------------------------------------------------------|------|
|     | 3.4.2  | Periphera   | al Bridge Configuration                                    | 82   |
|     |        | 3.4.2.1     | Peripheral bridge interfaces.                              | 82   |
|     |        | 3.4.2.2     | Memory map and module register access                      | 83   |
|     | 3.4.3  | DMA Co      | ontroller Configuration                                    | 83   |
|     |        | 3.4.3.1     | DMA Request Sources                                        | 83   |
|     | 3.4.4  | Interrupt   | Controller (INTC) Configuration                            | 84   |
|     |        | 3.4.4.1     | Interrupt priority levels                                  | 85   |
|     |        | 3.4.4.2     | Interrupt channel assignments                              | 85   |
|     | 3.4.5  | Low-Lea     | kage Wakeup Unit (LLWU) Configuration                      | 88   |
|     |        | 3.4.5.1     | LLWU wakeup sources                                        | 89   |
|     |        | 3.4.5.2     | LLWU register reset                                        | 90   |
|     | 3.4.6  | Compute     | r Operating Properly (COP) Watchdog Configuration          | 90   |
|     |        | 3.4.6.1     | COP clocks                                                 | 90   |
|     |        | 3.4.6.2     | COP watchdog operation                                     | 90   |
|     | 3.4.7  | System M    | Mode Controller (SMC) Configuration                        | 92   |
|     |        | 3.4.7.1     | SMC register reset                                         | 93   |
|     | 3.4.8  | Power M     | anagement Controller (PMC) Configuration                   | 93   |
|     |        | 3.4.8.1     | PMC register reset                                         | 93   |
|     | 3.4.9  | System In   | ntegration Module (SIM) Configuration                      | 94   |
|     |        | 3.4.9.1     | SIM register reset                                         | 94   |
| 3.5 | Clock  | Modules     |                                                            | 94   |
|     | 3.5.1  | Multipur    | pose Clock Generator (MCG) Configuration                   | 94   |
|     |        | 3.5.1.1     | MCG oscillator-frequency trim settings: factory and custom | 95   |
|     | 3.5.2  | Oscillator  | r (OSC) Configuration                                      | 96   |
| 3.6 | Memor  | ries and Me | mory Interfaces                                            | 97   |
|     | 3.6.1  | RAM Co      | nfiguration                                                | 97   |
|     |        | 3.6.1.1     | RAM overview                                               | 97   |
|     |        | 3.6.1.2     | RAM sizes                                                  | 97   |
|     |        | 3.6.1.3     | RAM retention in low power modes                           | 98   |

| Section Number |          | umber     | Title                                               | Page |
|----------------|----------|-----------|-----------------------------------------------------|------|
|                |          | 3.6.1.4   | RAM accesses                                        | 98   |
|                | 3.6.2    | Flash Me  | emory Controller (FMC) Configuration                | 98   |
|                | 3.6.3    | Flash Me  | emory Module (FTFL) Configuration                   | 99   |
|                |          | 3.6.3.1   | Flash Memory Types                                  | 100  |
|                |          | 3.6.3.2   | Flash Memory Sizes                                  | 100  |
|                |          | 3.6.3.3   | Flash Memory Map                                    | 101  |
|                |          | 3.6.3.4   | Flash Security                                      | 102  |
|                |          | 3.6.3.5   | Flash Modes                                         | 102  |
|                |          | 3.6.3.6   | Erase All Flash Contents                            | 102  |
|                |          | 3.6.3.7   | FTFL_FOPT Register                                  | 102  |
|                | 3.6.4    | System R  | Register File Configuration                         | 102  |
|                |          | 3.6.4.1   | Register file details                               | 103  |
|                | 3.6.5    | EzPort Co | onfiguration                                        | 103  |
|                |          | 3.6.5.1   | EzPort and BDM                                      | 104  |
|                |          | 3.6.5.2   | Flash Option Register (FOPT)                        | 104  |
|                |          | 3.6.5.3   | EzPort Clocking                                     | 104  |
|                | 3.6.6    | Mini-Flex | xBus Configuration                                  | 105  |
|                |          | 3.6.6.1   | Mini-FlexBus instantiation information              | 105  |
|                |          | 3.6.6.2   | Mini-FlexBus security                               | 106  |
| 3.7            | Security |           |                                                     | 106  |
|                | 3.7.1    | Cryptogra | aphic Acceleration Unit (CAU) Configuration         | 106  |
|                | 3.7.2    | Random 1  | Number Generator (RNG) Configuration                | 107  |
|                |          | 3.7.2.1   | Module register width and serialization of accesses | 107  |
|                | 3.7.3    | Cyclic Re | edundancy Check (CRC) Configuration                 | 107  |
|                |          | 3.7.3.1   | Module register width and serialization of accesses | 108  |
| 3.8            | Analog   | ţ         |                                                     | 108  |
|                | 3.8.1    | 12-bit An | nalog-to-Digital Converter (ADC) Configuration      | 108  |
|                |          | 3.8.1.1   | Module register width and serialization of accesses | 109  |
|                |          | 3.8.1.2   | ADC instantiation information                       | 109  |
|                |          |           | MCF51JF128 Reference Manual, Rev. 2, 03/2011        |      |

| Section N | lumber    | Title                                               | Page |
|-----------|-----------|-----------------------------------------------------|------|
|           | 3.8.1.3   | DMA support on ADC                                  | 109  |
|           | 3.8.1.4   | ADC0 Channel Assignments                            | 110  |
|           | 3.8.1.5   | ADC Reference, Triggers, and Alternate Clock        | 111  |
|           | 3.8.1.6   | Clock Gating                                        | 111  |
| 3.8.2     | Compara   | ator (CMP) Configuration                            | 112  |
|           | 3.8.2.1   | CMP instantiation information                       | 112  |
|           | 3.8.2.2   | External window/sample input                        | 113  |
| 3.8.3     | 12-bit Di | igital-to-Analog Converter (DAC) Configuration      | 114  |
|           | 3.8.3.1   | 12-bit DAC Overview                                 | 114  |
|           | 3.8.3.2   | 12-bit DAC Instantiation                            | 114  |
|           | 3.8.3.3   | 12-bit DAC External Reference                       | 114  |
|           | 3.8.3.4   | DAC DMA request                                     | 115  |
| 3.8.4     | Voltage l | Reference (VREF) Configuration                      | 115  |
|           | 3.8.4.1   | VREF Overview                                       | 115  |
| 3.9 Timer | 'S        |                                                     | 116  |
| 3.9.1     | Programi  | mable Delay Block (PDB) Configuration               | 116  |
|           | 3.9.1.1   | Module register width and serialization of accesses | 116  |
|           | 3.9.1.2   | PDB Overview                                        | 117  |
|           | 3.9.1.3   | PDB instantiation                                   | 117  |
|           | 3.9.1.4   | PDB Module Interconnections                         | 117  |
| 3.9.2     | FlexTime  | er (FTM) Configuration                              | 118  |
|           | 3.9.2.1   | FTM overview                                        | 118  |
|           | 3.9.2.2   | FTM instantiation information                       | 118  |
|           | 3.9.2.3   | FTM external clock options                          | 119  |
| 3.9.3     | Modulo    | Timer (MTIM) Configuration                          | 120  |
|           | 3.9.3.1   | MTIM overview                                       | 120  |
| 3.9.4     | Low Pow   | ver Timer (LPTMR) Configuration                     | 121  |
|           | 3.9.4.1   | LPTMR overview                                      | 121  |
|           | 3.9.4.2   | LPTMR pin connections                               | 121  |

| Section Number |        | ımber                                                                   | Title                                                                 | Page |
|----------------|--------|-------------------------------------------------------------------------|-----------------------------------------------------------------------|------|
|                |        | 3.9.4.3                                                                 | LPTMR clock options                                                   | 122  |
|                |        | 3.9.4.4                                                                 | LPTMR register reset                                                  | 122  |
|                | 3.9.5  | Carrier M                                                               | odulator Transmitter (CMT) Configuration                              | 122  |
|                |        | 3.9.5.1                                                                 | CMT instantiation information                                         | 123  |
|                |        | 3.9.5.2                                                                 | CMT IRO drive strength                                                | 123  |
| 3.10           | Commu  | inication int                                                           | erfaces                                                               | 123  |
|                | 3.10.1 | Universal                                                               | Serial Bus (USB) Subsystem                                            | 123  |
|                |        | 3.10.1.1                                                                | USB Wakeup                                                            | 124  |
|                |        | 3.10.1.2                                                                | USB Power Distribution                                                | 124  |
|                |        | 3.10.1.3                                                                | USB power management                                                  | 126  |
|                |        | 3.10.1.4                                                                | USB Controller Configuration                                          | 126  |
|                |        | 3.10.1.5                                                                | USB Device Charger Detection (USBDCD) Configuration                   | 127  |
|                |        | 3.10.1.6                                                                | USB Voltage Regulator (VREG) Configuration                            | 128  |
|                | 3.10.2 | Serial Per                                                              | ipheral Interface (SPI) Configuration                                 | 128  |
|                |        | 3.10.2.1                                                                | Number and instantiation of SPI modules                               | 129  |
|                |        | 3.10.2.2                                                                | SPI baud rate                                                         | 129  |
|                | 3.10.3 | Inter-Integ                                                             | grated Circuit (I2C) Configuration                                    | 130  |
|                |        | 3.10.3.1                                                                | Number of I2C modules                                                 | 130  |
|                | 3.10.4 | 3.10.4 Universal Asynchronous Receiver/Transmitter (UART) Configuration |                                                                       |      |
|                |        | 3.10.4.1                                                                | Number of UART modules                                                | 131  |
|                |        | 3.10.4.2                                                                | UART wakeup                                                           | 131  |
|                |        | 3.10.4.3                                                                | UART support for opto-isolated interface                              | 131  |
|                | 3.10.5 | Integrated                                                              | Interchip Sound (I2S)/Synchronous Audio Interface (SAI) Configuration | 132  |
|                |        | 3.10.5.1                                                                | Instantiation Information.                                            | 132  |
|                |        | 3.10.5.2                                                                | Module register width and serialization of accesses                   | 132  |
|                |        | 3.10.5.3                                                                | I2S/SAI Clocking                                                      | 132  |
| 3.11           | Human  | -machine in                                                             | terfaces (HMI)                                                        | 133  |
|                | 3.11.1 | Rapid GP                                                                | IO (RGPIO) Configuration                                              | 133  |
|                |        | 3.11.1.1                                                                | Number of available RGPIO pins                                        | 134  |

| tion N  | umber                                                                      | Title                                                                                                                          | Page                        |
|---------|----------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------|-----------------------------|
|         | 3.11.1.2                                                                   | RGPIO clock gating                                                                                                             | 134                         |
| 3.11.2  | Enhanced                                                                   | GPIO (EGPIO) Configuration                                                                                                     | 134                         |
|         | 3.11.2.1                                                                   | Instantiation Information.                                                                                                     | 135                         |
|         | 3.11.2.2                                                                   | EGPIO registers                                                                                                                | 135                         |
| 3.11.3  | Touch Ser                                                                  | nse Input (TSI) Configuration                                                                                                  | 136                         |
|         | 3.11.3.1                                                                   | Module register width and serialization of accesses                                                                            | 136                         |
|         | 3.11.3.2                                                                   | Number and instantiation of inputs                                                                                             | 136                         |
|         | 3.11.3.3                                                                   | TSI Interrupts                                                                                                                 | 136                         |
| 3.11.4  | External I                                                                 | Interrupt (IRQ) Module Configuration                                                                                           | 137                         |
| System  | Memory M                                                                   | Memory Map  Iap  Chapter 5                                                                                                     | 139                         |
| Introdu | ction                                                                      |                                                                                                                                | 145                         |
| Clock   | listribution                                                               |                                                                                                                                | 145                         |
| 5.2.1   | High-Leve                                                                  | el device clocking diagram                                                                                                     | 145                         |
| 5.2.2   | Device Cl                                                                  | lock Summary                                                                                                                   | 146                         |
| 5.2.3   | Architectu                                                                 | ure                                                                                                                            | 148                         |
| 5.2.4   | Clock div                                                                  | ider requirements                                                                                                              | 148                         |
| 5.2.5   | Clock gati                                                                 | ing                                                                                                                            | 149                         |
| 5.2.6   | Module cl                                                                  | locks                                                                                                                          | 149                         |
|         | 5.2.6.1                                                                    | VLPR Mode Clocking                                                                                                             | 151                         |
|         | 5.2.6.2                                                                    | I2S/SAI Clocking                                                                                                               | 151                         |
|         | 5.2.6.3                                                                    | USB Controller Clocking                                                                                                        | 151                         |
|         | 5.2.6.4                                                                    | UART Clocking                                                                                                                  | 151                         |
|         | 5.2.6.5                                                                    | PMC's 1 kHz Clock                                                                                                              | 152                         |
|         | 3.11.2  3.11.3  3.11.4  System  Clock of 5.2.1  5.2.2  5.2.3  5.2.4  5.2.5 | 3.11.2 Enhanced 3.11.2.1 3.11.2.2 3.11.3 Touch Se 3.11.3.1 3.11.3.2 3.11.3.3 3.11.4 External I  System Memory M.  Introduction | 3.11.1.2 RGPIO clock gating |

# Chapter 6 Reset and Boot

| 6.1 | Reset   |                                           |                                                  |     |
|-----|---------|-------------------------------------------|--------------------------------------------------|-----|
|     | 6.1.1   | MCU rese                                  | et sources                                       | 153 |
|     |         | 6.1.1.1                                   | Power-on reset (POR)                             | 154 |
|     |         | 6.1.1.2                                   | External RESET pin (PIN)                         | 154 |
|     |         | 6.1.1.3                                   | COP watchdog (WDOG) timer                        | 155 |
|     |         | 6.1.1.4                                   | Illegal opcode detect (ILOP)                     | 155 |
|     |         | 6.1.1.5                                   | Illegal address detect (ILAD)                    | 155 |
|     |         | 6.1.1.6                                   | Multipurpose Clock Generator loss of clock (LOC) | 155 |
|     |         | 6.1.1.7                                   | Low voltage detect (LVD)                         | 156 |
|     |         | 6.1.1.8                                   | Low leakage wakeup (WAKEUP)                      | 156 |
|     |         | 6.1.1.9                                   | Stop mode acknowledge error (SACKERR)            | 157 |
|     |         | 6.1.1.10                                  | Background debug forced reset (BDFR)             | 157 |
|     | 6.1.2   | Reset Pin                                 |                                                  | 157 |
|     | 6.1.3   | MCU Res                                   | sets                                             | 157 |
|     |         | 6.1.3.1                                   | POR Only                                         | 157 |
|     |         | 6.1.3.2                                   | Chip POR not VLLS                                | 158 |
|     |         | 6.1.3.3                                   | Chip POR                                         | 158 |
|     |         | 6.1.3.4                                   | Chip Reset not VLLS                              | 158 |
|     |         | 6.1.3.5                                   | Early Chip Reset                                 | 158 |
|     |         | 6.1.3.6                                   | Chip Reset                                       | 158 |
| 6.2 | Reset r | nemory map                                | and register descriptions                        | 159 |
|     | 6.2.1   | System Reset Status Register 0 (RCM_SRS0) |                                                  |     |
|     | 6.2.2   | System R                                  | eset Status Register 1 (RCM_SRS1)                | 161 |
|     | 6.2.3   | Reset Pin                                 | Filter Control Register (RCM_RPFC)               | 162 |
|     | 6.2.4   | Reset Pin                                 | Filter Width Register (RCM_RPFW)                 | 163 |
|     | 6.2.5   | Mode Reg                                  | gister (RCM_MR)                                  | 164 |

| Sec | tion N  | lumber Title                                        | Page   |
|-----|---------|-----------------------------------------------------|--------|
| 6.3 | Boot    |                                                     | 165    |
|     | 6.3.1   | Boot sources                                        | 165    |
|     | 6.3.2   | Boot options                                        | 165    |
|     | 6.3.3   | FOPT boot options                                   | 166    |
|     | 6.3.4   | Boot sequence                                       | 167    |
|     |         | Chapter 7<br>Power Management                       |        |
| 7.1 | Introdu | uction                                              | 169    |
| 7.2 | Power   | modes                                               | 169    |
| 7.3 | Modul   | le Operation in Low Power Modes                     | 170    |
|     |         | Chapter 8<br>Security                               |        |
| 8.1 | Introdu | uction                                              | 175    |
| 8.2 | Flash S | 175                                                 |        |
| 8.3 | Flash S | 176                                                 |        |
|     | 8.3.1   | Backdoor Key Access                                 | 176    |
|     | 8.3.2   | Freescale Factory Access                            | 176    |
|     | 8.3.3   | Mass Erase Disable                                  | 176    |
| 8.4 | Enabli  | ing Flash Security                                  | 177    |
| 8.5 | Unsec   | ruring the MCU using Backdoor Key Access            | 177    |
| 8.6 | Unsec   | turing the MCU using the Erase All Blocks command   | 179    |
| 8.7 | Securi  | ity Interactions with other Modules                 | 179    |
|     | 8.7.1   | Security interactions with Mini-FlexBus             | 179    |
|     | 8.7.2   | Security interactions with EzPort                   | 179    |
|     | 8.7.3   | Security interactions with Debug                    | 180    |
|     |         | Chapter 9<br>Signal Multiplexing and Signal Descrip | otions |
| 9.1 | Introdu | uction                                              | 181    |
| 9.2 | Signal  | Multiplexing Integration                            | 181    |
| 9.3 | Port M  | Mux Control Features                                |        |

| Sec  | tion Nu  | mber Title                                  | Page |
|------|----------|---------------------------------------------|------|
| 9.4  | Signal M | Multiplexing and Pin Assignments            | 183  |
| 9.5  | Pinout d | iagrams                                     | 186  |
| 9.6  | Module-  | -by-module signals                          | 190  |
| 9.7  | Module   | Signal Description Tables                   | 201  |
|      | 9.7.1    | Core Modules                                | 201  |
|      | 9.7.2    | System Modules                              | 201  |
|      | 9.7.3    | Clock Modules.                              | 201  |
|      | 9.7.4    | Memories and Memory Interfaces              | 202  |
|      | 9.7.5    | Analog                                      |      |
|      | 9.7.6    | Timer Modules.                              | 203  |
|      | 9.7.7    | Communication Interfaces                    |      |
|      | 9.7.8    | Human-Machine Interfaces (HMI)              | 207  |
|      |          | Chapter 10<br>Port Mux Control              |      |
| 10.1 | Port Mu  | x Control                                   |      |
| 10.2 | Memory   | Map and Registers                           | 209  |
|      | 10.2.1   | Port A Pin Function 1 Register (MXC_PTAPF1) | 211  |
|      | 10.2.2   | Port A Pin Function 2 Register (MXC_PTAPF2) | 211  |
|      | 10.2.3   | Port A Pin Function 3 Register (MXC_PTAPF3) | 212  |
|      | 10.2.4   | Port A Pin Function 4 Register (MXC_PTAPF4) | 213  |
|      | 10.2.5   | Port B Pin Function 1 Register (MXC_PTBPF1) | 214  |
|      | 10.2.6   | Port B Pin Function 2 Register (MXC_PTBPF2) | 215  |
|      | 10.2.7   | Port B Pin Function 3 Register (MXC_PTBPF3) | 215  |
|      | 10.2.8   | Port B Pin Function 4 Register (MXC_PTBPF4) | 216  |
|      | 10.2.9   | Port C Pin Function 1 Register (MXC_PTCPF1) | 217  |
|      | 10.2.10  | Port C Pin Function 2 Register (MXC_PTCPF2) | 218  |
|      | 10.2.11  | Port C Pin Function 3 Register (MXC_PTCPF3) | 219  |
|      | 10.2.12  | Port C Pin Function 4 Register (MXC_PTCPF4) | 219  |
|      | 10.2.13  | Port D Pin Function 1 Register (MXC_PTDPF1) | 220  |
|      |          |                                             |      |

| Sect | ion Nu   | mber          | Title                                            | Page |
|------|----------|---------------|--------------------------------------------------|------|
|      | 10.2.14  | Port D Pin    | Function 2 Register (MXC_PTDPF2)                 | 221  |
|      | 10.2.15  | Port D Pin    | Function 3 Register (MXC_PTDPF3)                 | 222  |
|      | 10.2.16  | Port D Pin    | Function 4 Register (MXC_PTDPF4)                 | 223  |
|      | 10.2.17  | Port E Pin    | Function 1 Register (MXC_PTEPF1)                 |      |
|      | 10.2.18  | Port E Pin    | Function 2 Register (MXC_PTEPF2)                 |      |
|      | 10.2.19  | Port E Pin    | Function 3 Register (MXC_PTEPF3)                 |      |
|      | 10.2.20  | Port E Pin    | Function 4 Register (MXC_PTEPF4)                 |      |
|      | 10.2.21  | Port F Pin    | Function 1 Register (MXC_PTFPF1)                 |      |
|      | 10.2.22  | Port F Pin    | Function 2 Register (MXC_PTFPF2)                 |      |
|      | 10.2.23  | Port F Pin    | Function 3 Register (MXC_PTFPF3)                 |      |
|      | 10.2.24  | Port F Pin    | Function 4 Register (MXC_PTFPF4)                 |      |
|      |          |               | Chapter 11<br>Core                               |      |
| 11.1 | Introduc | ction         |                                                  | 231  |
|      | 11.1.1   | Overview      |                                                  | 231  |
| 11.2 | Memory   | Map/Regis     | ster Description                                 | 233  |
|      | 11.2.1   | Data regist   | ters (D0–D7)                                     | 235  |
|      | 11.2.2   | Address re    | egisters (A0–A6)                                 | 236  |
|      | 11.2.3   | Supervisor    | r/user stack pointers (A7 and OTHER_A7)          | 237  |
|      | 11.2.4   | Condition     | code register (CCR)                              | 238  |
|      | 11.2.5   | Program co    | ounter (PC)                                      | 239  |
|      | 11.2.6   | Vector base   | se register (VBR)                                | 239  |
|      | 11.2.7   | CPU config    | guration register (CPUCR)                        | 240  |
|      | 11.2.8   | Status regis  | ster (SR)                                        | 243  |
| 11.3 | Function | nal Descripti | ion                                              | 244  |
|      | 11.3.1   | Instruction   | Set Architecture                                 | 244  |
|      | 11.3.2   | Exception     | Processing Overview                              | 245  |
|      |          | 11.3.2.1      | Exception Stack Frame Definition                 | 248  |
|      |          | 11.3.2.2      | S08 and ColdFire Exception Processing Comparison | 249  |
|      |          |               |                                                  |      |

| Sec  | Section Number |             | Title                                               | Page |
|------|----------------|-------------|-----------------------------------------------------|------|
|      | 11.3.3         | Processor 1 | Exceptions                                          | 251  |
|      |                | 11.3.3.1    | Access Error Exception.                             | 251  |
|      |                | 11.3.3.2    | Address Error Exception.                            | 252  |
|      |                | 11.3.3.3    | Illegal Instruction Exception.                      | 252  |
|      |                | 11.3.3.4    | Divide-By-Zero                                      | 254  |
|      |                | 11.3.3.5    | Privilege Violation.                                | 254  |
|      |                | 11.3.3.6    | Trace Exception.                                    | 254  |
|      |                | 11.3.3.7    | Unimplemented Line-A Opcode                         | 255  |
|      |                | 11.3.3.8    | Unimplemented Line-F Opcode                         | 255  |
|      |                | 11.3.3.9    | Debug Interrupt                                     | 255  |
|      |                | 11.3.3.10   | RTE and Format Error Exception                      | 256  |
|      |                | 11.3.3.11   | TRAP Instruction Exception.                         | 256  |
|      |                | 11.3.3.12   | Unsupported Instruction Exception.                  | 257  |
|      |                | 11.3.3.13   | Interrupt Exception                                 | 257  |
|      |                | 11.3.3.14   | Fault-on-Fault Halt.                                | 257  |
|      |                | 11.3.3.15   | Reset Exception.                                    | 257  |
|      | 11.3.4         | Instruction | Execution Timing                                    | 260  |
|      |                | 11.3.4.1    | Timing Assumptions                                  | 261  |
|      |                | 11.3.4.2    | MOVE Instruction Execution Times                    | 262  |
|      |                | 11.3.4.3    | Standard One Operand Instruction Execution Times    | 263  |
|      |                | 11.3.4.4    | Standard Two Operand Instruction Execution Times    | 264  |
|      |                | 11.3.4.5    | Miscellaneous Instruction Execution Times           | 265  |
|      |                | 11.3.4.6    | EMAC Instruction Execution Times                    | 266  |
|      |                | 11.3.4.7    | Branch Instruction Execution Times                  | 268  |
|      |                |             | Chapter 12 Enhanced Multiply-Accumulate Unit (EMAC) |      |
| 12.1 | Introdu        | ction       |                                                     | 271  |
|      | 12.1.1         | Overview.   |                                                     | 271  |
|      |                | 12.1.1.1    | Introduction to the MAC                             | 272  |

| Sect | tion Nu  | mber Title                                               | Page |
|------|----------|----------------------------------------------------------|------|
| 12.2 | Memory   | Map/Register Definition                                  | 273  |
|      | 12.2.1   | MAC Status Register (MACSR)                              | 274  |
|      | 12.2.2   | Mask Register (MASK)                                     | 276  |
|      | 12.2.3   | Accumulator Registers (ACC0-3)                           | 278  |
|      | 12.2.4   | Accumulator Extension Registers (ACCext01, ACCext23)     | 278  |
| 12.3 | Function | nal Description                                          | 280  |
|      | 12.3.1   | Fractional Operation Mode.                               | 282  |
|      |          | 12.3.1.1 Rounding                                        | 282  |
|      |          | 12.3.1.2 Saving and Restoring the EMAC Programming Model | 284  |
|      |          | 12.3.1.3 MULS/MULU                                       | 285  |
|      |          | 12.3.1.4 Scale Factor in MAC or MSAC Instructions        | 285  |
|      | 12.3.2   | EMAC Instruction Set Summary                             | 285  |
|      | 12.3.3   | EMAC Instruction Execution Times.                        | 286  |
|      | 12.3.4   | Data Representation                                      | 287  |
|      | 12.3.5   | MAC Opcodes                                              | 287  |
|      |          | Chapter 13 System Integration Module (SIM)               |      |
| 13.1 | Introduc | tion                                                     | 293  |
| 13.2 | Memory   | Map and Registers                                        | 293  |
|      | 13.2.1   | System Options Register 1 (SIM_SOPT1)                    | 296  |
|      | 13.2.2   | System Options Register 2 (SIM_SOPT2)                    | 297  |
|      | 13.2.3   | System Options Register 3 (SIM_SOPT3)                    | 298  |
|      | 13.2.4   | System Options Register 4 (SIM_SOPT4)                    | 298  |
|      | 13.2.5   | System Options Register 5 (SIM_SOPT5)                    | 299  |
|      | 13.2.6   | System Options Register 6 (SIM_SOPT6)                    | 300  |
|      | 13.2.7   | System Options Register 7 (SIM_SOPT7)                    | 301  |
|      | 13.2.8   | COP Control Register (SIM_COPC)                          | 302  |
|      | 13.2.9   | Service COP Register (SIM_SRVCOP)                        | 303  |
|      | 13.2.10  | Oscillator 1 Control Register (SIM_OSC1)                 | 303  |
|      |          |                                                          |      |

| Section Nu | mber Title                                      | Page |
|------------|-------------------------------------------------|------|
| 13.2.11    | Device Identification High Register (SIM_SDIDH) | 304  |
| 13.2.12    | Device Identification Low Register (SIM_SDIDL)  | 305  |
| 13.2.13    | Clock Gate Control Register 1 (SIM_SCGC1)       | 306  |
| 13.2.14    | Clock Gate Control Register 2 (SIM_SCGC2)       | 307  |
| 13.2.15    | Clock Gate Control Register 3 (SIM_SCGC3)       | 308  |
| 13.2.16    | Clock Gate Control Register 4 (SIM_SCGC4)       | 310  |
| 13.2.17    | Clock Gate Control Register 5 (SIM_SCGC5)       | 311  |
| 13.2.18    | Clock Gate Control Register 6 (SIM_SCGC6)       | 312  |
| 13.2.19    | Clockout Register (SIM_CLKOUT)                  | 313  |
| 13.2.20    | Clock Divider 0 Register (SIM_CLKDIV0)          | 314  |
| 13.2.21    | Clock Divider 1 Register (SIM_CLKDIV1)          | 315  |
| 13.2.22    | Flash Configuration Register (SIM_SPCR)         | 316  |
| 13.2.23    | Unique Identification Register (SIM_UIDH3)      | 317  |
| 13.2.24    | Unique Identification Register (SIM_UIDH2)      | 317  |
| 13.2.25    | Unique Identification Register (SIM_UIDH1)      | 318  |
| 13.2.26    | Unique Identification Register (SIM_UIDH0)      | 318  |
| 13.2.27    | Unique Identification Register (SIM_UIDMH3)     | 319  |
| 13.2.28    | Unique Identification Register (SIM_UIDMH2)     | 319  |
| 13.2.29    | Unique Identification Register (SIM_UIDMH1)     | 320  |
| 13.2.30    | Unique Identification Register (SIM_UIDMH0)     | 320  |
| 13.2.31    | Unique Identification Register (SIM_UIDML3)     | 321  |
| 13.2.32    | Unique Identification Register (SIM_UIDML2)     | 321  |
| 13.2.33    | Unique Identification Register (SIM_UIDML1)     | 322  |
| 13.2.34    | Unique Identification Register (SIM_UIDML0)     | 322  |
| 13.2.35    | Unique Identification Register (SIM_UIDL3)      | 323  |
| 13.2.36    | Unique Identification Register (SIM_UIDL2)      | 323  |
| 13.2.37    | Unique Identification Register (SIM_UIDL1)      | 324  |
| 13.2.38    | Unique Identification Register (SIM_UIDL0)      | 324  |

| Sec  | tion Nu   | mber              | Title                                        | Page |
|------|-----------|-------------------|----------------------------------------------|------|
|      | 15.4.7    | Clear Interrupt M | Mask Register (INTC_CIMR)                    | 349  |
|      | 15.4.8    | INTC Set Interru  | pt Force Register (INTC_SFRC)                | 349  |
|      | 15.4.9    | INTC Clear Inter  | rupt Force Register (INTC_CFRC)              | 350  |
|      | 15.4.10   | INTC Software I   | ACK Register (INTC_SWIACK)                   | 351  |
|      | 15.4.11   | INTC Level-n IA   | ACK Registers (INTC_LVLnIACK)                | 352  |
| 15.5 | Functio   | nal Description   |                                              | 353  |
|      | 15.5.1    | Handling of Non-  | -Maskable Level 7 Interrupt Requests         | 353  |
| 15.6 | Initializ | ation Information |                                              | 354  |
| 15.7 | Applica   | tion Information  |                                              | 354  |
|      | 15.7.1    | Emulation of the  | HCS08's 1-Level IRQ Handling                 | 354  |
|      | 15.7.2    | Using INTC_PLO    | 6P{7,6} Registers                            | 355  |
|      | 15.7.3    | More on Softwar   | e IACKs                                      | 356  |
|      |           |                   | Chapter 16<br>Low Leakage Wakeup Unit (LLWU) | 250  |
| 16.1 |           |                   |                                              |      |
|      | 16.1.1    |                   |                                              |      |
|      | 16.1.2    | •                 | on                                           |      |
|      |           |                   | mode                                         |      |
|      |           |                   | -low leakage modes.                          |      |
|      |           |                   | · ·                                          |      |
|      | 16.1.3    |                   | ug mode                                      |      |
| 16.2 |           | _                 | IS                                           |      |
| 16.3 |           |                   | nition                                       |      |
| 10.5 | 16.3.1    | 1 0               | le 1 Register (LLWU_PE1)                     |      |
|      | 16.3.2    |                   | le 2 Register (LLWU_PE2)                     |      |
|      | 16.3.3    |                   | le 3 Register (LLWU_PE3)                     |      |
|      | 16.3.4    |                   | le 4 Register (LLWU_PE4)                     |      |
|      | 16.3.5    |                   | Enable Register (LLWU_ME)                    |      |
|      | 10.3.3    | DL 11 O MOdule I  | Sauce region (DD 11 O_111D)                  |      |

| Sect | tion Nu                       | ımber        | Title                                    | Page |
|------|-------------------------------|--------------|------------------------------------------|------|
|      | 16.3.6                        | LLWU Fla     | ag 1 Register (LLWU_F1)                  | 370  |
|      | 16.3.7                        | LLWU Fla     | ag 2 Register (LLWU_F2)                  | 372  |
|      | 16.3.8                        | LLWU Fla     | ag 3 Register (LLWU_F3)                  | 373  |
|      | 16.3.9                        | LLWU Pin     | n Filter 1 Register (LLWU_FILT1)         | 375  |
|      | 16.3.10                       | LLWU Pin     | n Filter 2 Register (LLWU_FILT2)         | 376  |
|      | 16.3.11                       | LLWU Re      | eset Enable Register (LLWU_RST)          | 377  |
| 16.4 | Functio                       | nal descript | ion                                      | 378  |
|      | 16.4.1                        | LLS mode     | 2                                        | 378  |
|      | 16.4.2                        | VLLS mo      | des                                      | 379  |
|      | 16.4.3                        | Initializati | ion                                      | 379  |
|      |                               |              | Chapter 17 System Mode Controller (SMC)  |      |
| 17.1 | Introduc                      | ction        |                                          | 381  |
| 17.2 | Modes                         | of Operation | n                                        | 381  |
| 17.3 | Memory                        | 383          |                                          |      |
|      | 17.3.1                        | Power Mo     | ode Protection Register (SMC_PMPROT)     | 383  |
|      | 17.3.2                        | Power Mo     | ode Control Register (SMC_PMCTRL)        | 384  |
|      | 17.3.3                        | VLLS Cor     | ntrol Register (SMC_VLLSCTRL)            | 386  |
|      | 17.3.4                        | Power Mo     | ode Status Register (SMC_PMSTAT)         | 387  |
| 17.4 | Functio                       | nal Descript | tion                                     | 388  |
|      | 17.4.1 Power Mode Transitions |              |                                          | 388  |
|      | 17.4.2                        | Power Mo     | ode Entry/Exit Sequencing                | 391  |
|      |                               | 17.4.2.1     | Stop Mode Entry Sequence                 | 392  |
|      |                               | 17.4.2.2     | Stop Mode Exit Sequence                  | 393  |
|      |                               | 17.4.2.3     | Aborted Stop Mode Entry                  | 393  |
|      |                               | 17.4.2.4     | Transition to Wait Modes                 | 393  |
|      |                               | 17.4.2.5     | Transition from Stop Modes to Debug Mode | 393  |
|      | 17.4.3                        | Run Mode     | es                                       | 394  |
|      |                               | 17.4.3.1     | RUN Mode                                 | 394  |

18

| Sec  | tion Nu | ımber        | Title                                                 | Page |
|------|---------|--------------|-------------------------------------------------------|------|
|      |         | 17.4.3.2     | Very Low Power Run (VLPR) Mode                        | 394  |
|      |         | 17.4.3.3     | BDM in Run and VLPR Mode                              | 395  |
|      | 17.4.4  | Wait Mod     | les                                                   | 395  |
|      |         | 17.4.4.1     | WAIT Mode                                             | 395  |
|      |         | 17.4.4.2     | Very Low Power Wait (VLPW) Mode                       | 396  |
|      |         | 17.4.4.3     | BDM in Wait and VLPW Mode                             | 396  |
|      | 17.4.5  | Stop Mod     | es                                                    | 397  |
|      |         | 17.4.5.1     | STOP Mode                                             | 397  |
|      |         | 17.4.5.2     | Very Low Power Stop (VLPS) Mode                       | 398  |
|      |         | 17.4.5.3     | BDM in Stop and VLPS Modes                            | 399  |
|      |         | 17.4.5.4     | Low-Leakage Stop (LLS) Mode                           | 399  |
|      |         | 17.4.5.5     | Very Low-Leakage Stop (VLLS3,2,1) Modes               | 400  |
|      |         | 17.4.5.6     | BDM in LLS and VLLSx Modes                            | 400  |
|      |         |              | Chapter 18 Power Management Controller (PMC)          |      |
| 18.1 | Introdu | ction        |                                                       | 403  |
| 18.2 | Feature | s            |                                                       | 403  |
| 18.3 | Low-V   | oltage Detec | ct (LVD) System                                       | 403  |
|      | 18.3.1  | LVD Rese     | et Operation                                          | 404  |
|      | 18.3.2  | LVD Inter    | rrupt Operation                                       | 404  |
|      | 18.3.3  | Low-Volt     | age Warning (LVW) Interrupt Operation                 | 404  |
| 18.4 | I/O Ret | ention       |                                                       | 405  |
| 18.5 | Memor   | y Map and l  | Register Descriptions                                 | 405  |
|      | 18.5.1  | Low Volta    | age Detect Status and Control 1 Register (PMC_LVDSC1) | 406  |
|      | 18.5.2  | Low Volta    | age Detect Status and Control 2 Register (PMC_LVDSC2) | 407  |
|      | 18.5.3  | Regulator    | Status and Control Register (PMC_REGSC)               | 408  |

| Sect | tion Nu   | ımber        | Title                                                                                       | Page |
|------|-----------|--------------|---------------------------------------------------------------------------------------------|------|
|      | 20.3.3    | MCG Con      | ntrol 3 Register (MCG_C3)                                                                   | 438  |
|      | 20.3.4    | MCG Con      | ntrol 4 Register (MCG_C4)                                                                   | 439  |
|      | 20.3.5    | MCG Con      | ntrol 5 Register (MCG_C5)                                                                   | 440  |
|      | 20.3.6    | MCG Con      | ntrol 6 Register (MCG_C6)                                                                   | 441  |
|      | 20.3.7    | MCG Stat     | rus Register (MCG_S)                                                                        | 443  |
|      | 20.3.8    | MCG Aut      | o Trim Control Register (MCG_ATC)                                                           | 444  |
|      | 20.3.9    | MCG Aut      | o Trim Compare Value High Register (MCG_ATCVH)                                              | 445  |
|      | 20.3.10   | MCG Aut      | o Trim Compare Value Low Register (MCG_ATCVL)                                               | 445  |
| 20.4 | Function  | nal Descript | tion                                                                                        | 446  |
|      | 20.4.1    | MCG Mod      | de State Diagram                                                                            | 446  |
|      |           | 20.4.1.1     | MCG Modes of Operation                                                                      | 447  |
|      |           | 20.4.1.2     | MCG Mode Switching.                                                                         | 450  |
|      | 20.4.2    | Low Powe     | er Bit Usage                                                                                | 451  |
|      | 20.4.3    | MCG Inte     | rnal Reference Clocks                                                                       | 451  |
|      |           | 20.4.3.1     | MCG Internal Reference Clock                                                                | 451  |
|      | 20.4.4    | External R   | Reference Clock                                                                             | 452  |
|      | 20.4.5    | MCG Fixe     | ed Frequency Clock                                                                          | 452  |
|      | 20.4.6    | MCG Bac      | kground Debug Controller Clock                                                              | 452  |
|      | 20.4.7    | MCG PLI      | _ Clock                                                                                     | 453  |
|      | 20.4.8    | MCG Aut      | o TRIM (ATM)                                                                                | 453  |
| 20.5 | Initializ | ation / Appl | lication Information                                                                        | 454  |
|      | 20.5.1    | MCG Mod      | dule Initialization Sequence                                                                | 454  |
|      |           | 20.5.1.1     | Initializing the MCG                                                                        | 454  |
|      | 20.5.2    | Using a 32   | 2.768 kHz Reference                                                                         | 456  |
|      | 20.5.3    | MCG Mod      | de Switching                                                                                | 457  |
|      |           | 20.5.3.1     | Example 1: Moving from FEI to PEE Mode: External Crystal = 4 MHz, MCGOUT Frequency = 48 MHz | 458  |
|      |           | 20.5.3.2     | Example 2: Moving from PEE to BLPI Mode: MCGOUT Frequency =32 kHz                           | 462  |
|      |           | 20.5.3.3     | Example 3: Moving from BLPI to FEE Mode                                                     | 464  |

#### Chapter 21 Oscillator (OSC)

| 21.1  | Introduction |                                 |                                |     |  |  |  |
|-------|--------------|---------------------------------|--------------------------------|-----|--|--|--|
| 21.2  | Feature      | s and Modes                     | S                              | 467 |  |  |  |
| 21.3  | Block I      | Diagram                         |                                | 468 |  |  |  |
| 21.4  | OSC Si       | gnal Descrip                    | otions                         | 468 |  |  |  |
| 21.5  | Externa      | l Crystal / R                   | esonator Connections.          | 469 |  |  |  |
| 21.6  | Externa      | l Clock Con                     | nections                       | 471 |  |  |  |
| 21.7  | Memor        | Memory Map/Register Definitions |                                |     |  |  |  |
|       | 21.7.1       | OSC Contr                       | rol Register (OSCx_CR)         | 472 |  |  |  |
| 21.8  | Functio      | nal Descript                    | ion                            | 473 |  |  |  |
|       | 21.8.1       | OSC Modu                        | ule States                     | 473 |  |  |  |
|       |              | 21.8.1.1                        | Off                            | 474 |  |  |  |
|       |              | 21.8.1.2                        | Oscillator Start-Up            | 474 |  |  |  |
|       |              | 21.8.1.3                        | Oscillator Stable              | 475 |  |  |  |
|       |              | 21.8.1.4                        | External Clock Mode            | 475 |  |  |  |
|       | 21.8.2       | OSC Modu                        | ule Modes                      | 475 |  |  |  |
|       |              | 21.8.2.1                        | Low-Frequency, High-Gain Mode  | 476 |  |  |  |
|       |              | 21.8.2.2                        | Low-Frequency, Low-Power Mode  | 476 |  |  |  |
|       |              | 21.8.2.3                        | High-Frequency, High-Gain Mode | 476 |  |  |  |
|       |              | 21.8.2.4                        | High-Frequency, Low-Power Mode | 477 |  |  |  |
|       | 21.8.3       | Counter                         |                                | 477 |  |  |  |
|       | 21.8.4       | Reference                       | Clock Pin Requirements         | 477 |  |  |  |
| 21.9  | Reset        |                                 |                                | 477 |  |  |  |
| 21.10 | Low Po       | wer Modes                       | Operation                      | 478 |  |  |  |
| 21.11 | Interrup     | ots                             |                                | 478 |  |  |  |

| Sec  | tion Nu  | mber        | Title                                               | Page |
|------|----------|-------------|-----------------------------------------------------|------|
|      |          | 23.34.2     | Flash Security Register (FTFL_FSEC)                 | 494  |
|      |          | 23.34.3     | Flash Configuration Register (FTFL_FCNFG)           | 496  |
|      |          | 23.34.4     | Flash Status Register (FTFL_FSTAT)                  | 497  |
|      |          | 23.34.5     | Flash Common Command Object Registers (FTFL_FCCOBn) | 499  |
|      |          | 23.34.6     | Program Flash Protection Registers (FTFL_FPROTn)    | 500  |
|      |          | 23.34.7     | Data Flash Protection Register (FTFL_FDPROT)        | 502  |
|      |          | 23.34.8     | EEPROM Protection Register (FTFL_FEPROT)            | 503  |
| 23.4 | Function | nal Descrip | tion                                                | 504  |
|      | 23.4.1   | Flash Prot  | tection                                             | 504  |
|      | 23.4.2   | FlexNVM     | I Description                                       | 506  |
|      |          | 23.4.2.1    | FlexNVM Block Partitioning for FlexRAM              | 506  |
|      |          | 23.4.2.2    | EEPROM User Perspective                             | 507  |
|      |          | 23.4.2.3    | EEPROM Implementation Overview                      | 508  |
|      |          | 23.4.2.4    | Write endurance to FlexRAM for EEPROM               | 509  |
|      | 23.4.3   | Interrupts  |                                                     | 510  |
|      | 23.4.4   | Flash Ope   | eration in Low-Power Modes                          | 511  |
|      |          | 23.4.4.1    | Wait Mode                                           | 511  |
|      |          | 23.4.4.2    | Stop Mode                                           | 511  |
|      | 23.4.5   | Functiona   | l Modes of Operation                                | 511  |
|      | 23.4.6   | Flash Rea   | ds and Ignored Writes                               | 511  |
|      | 23.4.7   | Read Whi    | ile Write (RWW)                                     | 512  |
|      | 23.4.8   | Flash Prog  | gram and Erase                                      | 512  |
|      | 23.4.9   | FTFL Cor    | mmand Operations                                    | 512  |
|      |          | 23.4.9.1    | Command Write Sequence                              | 512  |
|      |          | 23.4.9.2    | FTFL Commands                                       | 514  |
|      |          | 23.4.9.3    | FTFL Commands by Mode                               | 517  |
|      |          | 23.4.9.4    | Allowed Simultaneous Flash Operations               | 518  |
|      | 23.4.10  | Margin Re   | ead Commands                                        | 518  |

| Section Number |          | mber        | Title                                               | Page |
|----------------|----------|-------------|-----------------------------------------------------|------|
|                | 23.4.11  | FTFL Com    | mand Description                                    | 520  |
|                |          | 23.4.11.1   | Read 1s Block Command                               | 520  |
|                |          | 23.4.11.2   | Read 1s Section Command                             | 521  |
|                |          | 23.4.11.3   | Program Check Command                               | 522  |
|                |          | 23.4.11.4   | Read Resource Command                               | 524  |
|                |          | 23.4.11.5   | Program Longword Command                            | 525  |
|                |          | 23.4.11.6   | Erase Flash Block Command                           | 526  |
|                |          | 23.4.11.7   | Erase Flash Sector Command.                         | 527  |
|                |          | 23.4.11.8   | Program Section Command                             | 530  |
|                |          | 23.4.11.9   | Read 1s All Blocks Command                          | 532  |
|                |          | 23.4.11.10  | Read Once Command                                   | 533  |
|                |          | 23.4.11.11  | Program Once Command                                | 534  |
|                |          | 23.4.11.12  | Erase All Blocks Command                            | 535  |
|                |          | 23.4.11.13  | Verify Backdoor Access Key Command                  | 536  |
|                |          | 23.4.11.14  | Program Partition Command                           | 537  |
|                |          | 23.4.11.15  | Set FlexRAM Function Command                        | 540  |
|                | 23.4.12  | Security    |                                                     | 541  |
|                |          | 23.4.12.1   | FTFL Access by Mode and Security                    | 541  |
|                |          | 23.4.12.2   | Changing the Security State                         | 542  |
|                | 23.4.13  | Reset Seque | ence                                                | 543  |
|                |          |             | Chapter 24<br>External Bus Interface (Mini-FlexBus) |      |
| 24.1           | Introduc | tion        |                                                     | 545  |
|                | 24.1.1   | Overview    |                                                     | 545  |
|                | 24.1.2   | Features    |                                                     | 545  |
|                | 24.1.3   | Modes of C  | Operation                                           | 546  |
| 24.2           | Signal D | escriptions |                                                     | 546  |
|                | 24.2.1   | Address and | d Data Buses (FB_An, FB_Dn, FB_ADn)                 | 547  |
|                | 24.2.2   | Chip Select | s (FB_CS[ 1:0])                                     | 547  |

| Section Nu |           | lumber Title  |                                          | Page |
|------------|-----------|---------------|------------------------------------------|------|
|            | 24.2.3    | Output Ena    | able (FB_OE)                             | 547  |
|            | 24.2.4    | Read/Write    | e (FB_R/W)                               | 548  |
|            | 24.2.5    | Transfer St   | tart/Address Latch Enable (FB_TS/FB_ALE) | 548  |
| 24.3       | Memor     | y Map/Regis   | ter Definition                           | 548  |
|            | 24.3.1    | Chip select   | t address register (FB_CSARn)            | 549  |
|            | 24.3.2    | Chip select   | t mask register (FB_CSMRn)               | 550  |
|            | 24.3.3    | Chip select   | t control register (FB_CSCRn)            | 551  |
| 24.4       | Functio   | nal Descripti | ion                                      | 553  |
|            | 24.4.1    | Chip-Selec    | et Operation                             | 553  |
|            |           | 24.4.1.1      | General Chip-Select Operation            | 553  |
|            |           | 24.4.1.2      | 8- and 16-Bit Port Sizing                | 554  |
|            | 24.4.2    | Data Trans    | fer Operation                            | 554  |
|            | 24.4.3    | Data Byte     | Alignment and Physical Connections       | 555  |
|            | 24.4.4    | Address/D     | ata Bus Multiplexing                     | 556  |
|            | 24.4.5    | Bus Cycle     | Execution                                | 556  |
|            |           | 24.4.5.1      | Data Transfer Cycle States               | 557  |
|            | 24.4.6    | Mini-FlexI    | Bus Timing Examples                      | 558  |
|            |           | 24.4.6.1      | Basic Read Bus Cycle                     | 558  |
|            |           | 24.4.6.2      | Basic Write Bus Cycle                    | 560  |
|            |           | 24.4.6.3      | Bus Cycle Sizing                         | 561  |
|            |           | 24.4.6.4      | Timing Variations.                       | 565  |
|            | 24.4.7    | Extended 7    | Γransfer Start/Address Latch Enable      | 574  |
|            | 24.4.8    | Bus Errors    |                                          | 575  |
| 24.5       | Initializ | ation/Applic  | ration Information                       | 576  |
|            | 24.5.1    | Initializing  | a Chip Select                            | 576  |
|            | 24.5.2    | Reconfigu     | ring a Chip Select                       | 576  |

#### Chapter 25 EzPort

| 25.1 | Overvie | ew           |                                    | 577 |
|------|---------|--------------|------------------------------------|-----|
|      | 25.1.1  | Introduction | on                                 | 577 |
|      | 25.1.2  | Features     |                                    | 578 |
|      | 25.1.3  | Modes of 0   | Operation                          | 578 |
| 25.2 | Externa | l Signal Des | scription                          | 579 |
|      | 25.2.1  | EzPort Clo   | ock (EZP_CK)                       | 579 |
|      | 25.2.2  | EzPort Chi   | ip Select (EZP_CS)                 | 579 |
|      | 25.2.3  | EzPort Ser   | rial Data In (EZP_D)               | 580 |
|      | 25.2.4  | EzPort Ser   | rial Data Out (EZP_Q)              | 580 |
| 25.3 | Comma   | nd Definitio | on                                 | 580 |
|      | 25.3.1  | Command      | Descriptions                       | 581 |
|      |         | 25.3.1.1     | Write Enable                       | 581 |
|      |         | 25.3.1.2     | Write Disable                      | 581 |
|      |         | 25.3.1.3     | Read Status Register               | 581 |
|      |         | 25.3.1.4     | Read Data                          | 583 |
|      |         | 25.3.1.5     | Read Data at High Speed            | 583 |
|      |         | 25.3.1.6     | Section Program                    | 584 |
|      |         | 25.3.1.7     | Sector Erase                       | 584 |
|      |         | 25.3.1.8     | Bulk Erase                         | 584 |
|      |         | 25.3.1.9     | EzPort Reset Chip.                 | 585 |
|      |         | 25.3.1.10    | Write FCCOB Registers              | 585 |
|      |         | 25.3.1.11    | Read FCCOB Registers at High Speed | 585 |
|      |         | 25.3.1.12    | Write FlexRAM                      | 586 |
|      |         | 25.3.1.13    | Read FlexRAM                       | 586 |
|      |         | 25.3.1.14    | Read FlexRAM at High Speed         | 587 |
| 25.4 | Flash M | lemory Map   | o for EzPort Access                | 587 |
|      |         |              |                                    |     |

# Chapter 26 Cryptographic Acceleration Unit (CAU)

| 26.1 | Introduction |               |                                      |     |  |  |
|------|--------------|---------------|--------------------------------------|-----|--|--|
| 26.2 | Block I      | Diagram       |                                      | 589 |  |  |
| 26.3 | Overvie      | ew            |                                      | 590 |  |  |
| 26.4 | Feature      | S             |                                      | 590 |  |  |
| 26.5 | Registe      | r Definition. |                                      | 590 |  |  |
|      | 26.5.1       | Status Reg    | gister (CAU_CASR)                    | 592 |  |  |
|      | 26.5.2       | Accumulat     | tor (CAU_CAA)                        | 593 |  |  |
|      | 26.5.3       | General Pu    | urpose Register (CAU_CAn)            | 594 |  |  |
| 26.6 | Functio      | nal Descripti | tion                                 | 594 |  |  |
|      | 26.6.1       | Programm      | ning Model                           | 594 |  |  |
|      | 26.6.2       | Coprocesso    | sor Instructions                     | 594 |  |  |
|      | 26.6.3       | CAU Com       | nmands                               | 595 |  |  |
|      |              | 26.6.3.1      | Coprocessor No Operation (CNOP)      | 597 |  |  |
|      |              | 26.6.3.2      | Load Register (LDR)                  | 597 |  |  |
|      |              | 26.6.3.3      | Store Register (STR)                 | 597 |  |  |
|      |              | 26.6.3.4      | Add to Register (ADR)                | 597 |  |  |
|      |              | 26.6.3.5      | Reverse and Add to Register (RADR)   | 597 |  |  |
|      |              | 26.6.3.6      | Add Register to Accumulator (ADRA)   | 598 |  |  |
|      |              | 26.6.3.7      | Exclusive Or (XOR)                   | 598 |  |  |
|      |              | 26.6.3.8      | Rotate Left (ROTL)                   | 598 |  |  |
|      |              | 26.6.3.9      | Move Register to Accumulator (MVRA)  | 598 |  |  |
|      |              | 26.6.3.10     | Move Accumulator to Register (MVAR)  | 598 |  |  |
|      |              | 26.6.3.11     | AES Substitution (AESS)              | 599 |  |  |
|      |              | 26.6.3.12     | AES Inverse Substitution (AESIS)     | 599 |  |  |
|      |              | 26.6.3.13     | AES Column Operation (AESC)          | 599 |  |  |
|      |              | 26.6.3.14     | AES Inverse Column Operation (AESIC) | 599 |  |  |
|      |              | 26.6.3.15     | AES Shift Rows (AESR)                | 599 |  |  |
|      |              |               |                                      |     |  |  |

MCF51JF128 Reference Manual, Rev. 2, 03/2011

| Sec  | tion Nu      | ımber           | Title                                        | Page |
|------|--------------|-----------------|----------------------------------------------|------|
|      |              | 26.6.3.16       | AES Inverse Shift Rows (AESIR)               | 600  |
|      |              | 26.6.3.17       | DES Round (DESR)                             | 600  |
|      |              | 26.6.3.18       | DES Key Setup (DESK)                         | 601  |
|      |              | 26.6.3.19       | Hash Function (HASH)                         | 601  |
|      |              | 26.6.3.20       | Secure Hash Shift (SHS)                      | 602  |
|      |              | 26.6.3.21       | Message Digest Shift (MDS)                   |      |
|      |              | 26.6.3.22       | Secure Hash Shift 2 (SHS2)                   | 603  |
|      |              | 26.6.3.23       | Illegal Command (ILL)                        | 603  |
| 26.7 | Applica      | ntion/Initializ | zation Information                           | 603  |
|      | 26.7.1       | Code Exar       | mple                                         | 603  |
|      | 26.7.2       | Assembler       | Equate Values                                | 604  |
|      |              |                 | Chapter 27<br>Random Number Generator (RNGB) |      |
| 27.1 | Introduction |                 |                                              |      |
|      | 27.1.1       | Block Diag      | gram                                         | 607  |
|      | 27.1.2       | Features        |                                              | 607  |
| 27.2 | Modes        | of Operation    | 1                                            | 608  |
|      | 27.2.1       | Self Test N     | Mode                                         | 608  |
|      | 27.2.2       | Seed Gene       | eration Mode                                 | 608  |
|      | 27.2.3       | Random N        | Jumber Generation Mode                       | 609  |
| 27.3 | Memor        | y Map/Regis     | ster Definition                              | 609  |
|      | 27.3.1       | RNGB Ve         | rsion ID Register (RNG_VER)                  | 610  |
|      | 27.3.2       | RNGB Co         | mmand Register (RNG_CMD)                     | 610  |
|      | 27.3.3       | RNGB Co         | ntrol Register (RNG_CR)                      | 612  |
|      | 27.3.4       | RNGB Sta        | ttus Register (RNG_SR)                       | 613  |
|      | 27.3.5       | RNGB Err        | or Status Register (RNG_ESR)                 | 615  |
|      | 27.3.6       | RNGB Ou         | tput FIFO (RNG_OUT)                          | 617  |
| 27.4 | Functio      | nal Descript    | ion                                          | 617  |
|      | 27.4.1       | Pseudoran       | dom Number Generator (PRNG)                  | 617  |

| Section Number |           | ımber Title                             | Page      |
|----------------|-----------|-----------------------------------------|-----------|
|                | 27.4.2    | True Random Number Generator (TRNG)     | 618       |
|                | 27.4.3    | Resets                                  | 618       |
|                |           | 27.4.3.1 Power-on/Hardware Reset        | 618       |
|                |           | 27.4.3.2 Software Reset                 | 618       |
|                | 27.4.4    | RNG Interrupts                          | 618       |
| 27.5           | Initializ | 619                                     |           |
|                | 27.5.1    | Manual Seeding.                         | 619       |
|                | 27.5.2    | Automatic Seeding                       |           |
|                |           | Chapter 28<br>Cyclic Redundancy Ch      | eck (CRC) |
| 28.1           | Introdu   | ction                                   |           |
|                | 28.1.1    | Features                                | 621       |
|                | 28.1.2    | Block diagram                           |           |
|                | 28.1.3    | Modes of operation                      |           |
|                |           | 28.1.3.1 Run mode                       |           |
|                |           | 28.1.3.2 Low power modes (wait or stop) |           |
| 28.2           | Memor     |                                         |           |
|                | 28.2.1    | CRC Data Register (CRC_CRC)             | 623       |
|                | 28.2.2    | CRC Polynomial Register (CRC_GPOLY)     |           |
|                | 28.2.3    | CRC Control Register (CRC_CTRL)         |           |
| 28.3           | Functio   |                                         |           |
|                | 28.3.1    | CRC initialization/re-initialization.   |           |
|                | 28.3.2    | CRC calculations                        |           |
|                |           | 28.3.2.1 16-bit CRC                     |           |
|                |           | 28.3.2.2 32-bit CRC                     |           |
|                | 28.3.3    | Transpose feature                       |           |
|                |           | 28.3.3.1 Types of transpose             |           |
|                | 28.3.4    | CRC result complement                   |           |

## Chapter 29 Analog-to-Digital Converter (ADC)

| 29.1 | Introduction |                                                              |     |  |
|------|--------------|--------------------------------------------------------------|-----|--|
|      | 29.1.1       | Features                                                     | 631 |  |
|      | 29.1.2       | Block diagram                                                | 632 |  |
| 29.2 | ADC Si       | gnal Descriptions                                            | 633 |  |
|      | 29.2.1       | Analog power (VDDA)                                          | 634 |  |
|      | 29.2.2       | Analog ground (VSSA)                                         | 634 |  |
|      | 29.2.3       | Voltage reference select                                     | 634 |  |
|      | 29.2.4       | Analog channel inputs (ADx)                                  | 635 |  |
| 29.3 | Register     | Definition.                                                  | 635 |  |
|      | 29.3.1       | ADC status and control registers 1 (ADCx_SC1n)               | 637 |  |
|      | 29.3.2       | ADC configuration register 1 (ADCx_CFG1)                     | 639 |  |
|      | 29.3.3       | Configuration register 2 (ADCx_CFG2)                         | 641 |  |
|      | 29.3.4       | ADC data result register (ADCx_Rn)                           | 642 |  |
|      | 29.3.5       | Compare value registers (ADCx_CVn)                           | 643 |  |
|      | 29.3.6       | Status and control register 2 (ADCx_SC2)                     | 644 |  |
|      | 29.3.7       | Status and control register 3 (ADCx_SC3)                     | 646 |  |
|      | 29.3.8       | ADC offset correction register (ADCx_OFS)                    | 647 |  |
|      | 29.3.9       | ADC plus-side gain register (ADCx_PG)                        | 648 |  |
|      | 29.3.10      | ADC plus-side general calibration value register (ADCx_CLPD) | 648 |  |
|      | 29.3.11      | ADC plus-side general calibration value register (ADCx_CLPS) | 649 |  |
|      | 29.3.12      | ADC plus-side general calibration value register (ADCx_CLP4) | 649 |  |
|      | 29.3.13      | ADC plus-side general calibration value register (ADCx_CLP3) | 650 |  |
|      | 29.3.14      | ADC plus-side general calibration value register (ADCx_CLP2) | 650 |  |
|      | 29.3.15      | ADC plus-side general calibration value register (ADCx_CLP1) | 651 |  |
|      | 29.3.16      | ADC plus-side general calibration value register (ADCx_CLP0) | 651 |  |
| 29.4 | Function     | nal description                                              | 652 |  |
|      | 29.4.1       | Clock select and divide control.                             | 652 |  |
|      |              |                                                              |     |  |

MCF51JF128 Reference Manual, Rev. 2, 03/2011

| Section Number |                             | mber                  | Title                                 | Page |
|----------------|-----------------------------|-----------------------|---------------------------------------|------|
|                | 29.4.2                      | Voltage re            | ference selection                     | 653  |
|                | 29.4.3                      | Hardware              | trigger and channel selects           | 654  |
|                | 29.4.4                      | Conversion            | n control                             | 654  |
|                |                             | 29.4.4.1              | Initiating conversions                | 655  |
|                |                             | 29.4.4.2              | Completing conversions.               | 656  |
|                |                             | 29.4.4.3              | Aborting conversions                  | 656  |
|                |                             | 29.4.4.4              | Power control                         | 657  |
|                |                             | 29.4.4.5              | Sample time and total conversion time | 657  |
|                |                             | 29.4.4.6              | Conversion time examples              | 659  |
|                |                             | 29.4.4.7              | Hardware average function             | 661  |
|                | 29.4.5                      | Automatic             | compare function                      | 661  |
|                | 29.4.6                      | Calibration function. |                                       |      |
|                | 29.4.7                      | User define           | 664                                   |      |
|                | 29.4.8                      | Temperatu             | 665                                   |      |
|                | 29.4.9                      | MCU wait              | mode operation                        | 666  |
| 29.4.10        |                             | MCU Nor               | mal Stop mode operation               | 666  |
|                |                             | 29.4.10.1             | Normal Stop mode with ADACK disabled  | 666  |
|                |                             | 29.4.10.2             | Normal Stop mode with ADACK enabled   | 667  |
|                | 29.4.11                     | MCU Low               | Power Stop mode operation             | 667  |
| 29.5           | Initialization information. |                       |                                       | 668  |
|                | 29.5.1                      | ADC mod               | ule initialization example            | 668  |
|                |                             | 29.5.1.1              | Initialization sequence               | 668  |
|                |                             | 29.5.1.2              | Pseudo-code example                   | 668  |
| 29.6           | Applica                     | tion informa          | 670                                   |      |
|                | 29.6.1                      | External p            | 670                                   |      |
|                |                             | 29.6.1.1              | Analog supply pins                    | 670  |
|                |                             | 29.6.1.2              | Analog voltage reference pins         | 671  |
|                |                             | 29.6.1.3              | Analog input pins                     | 672  |
|                |                             |                       |                                       |      |

| Sec  | tion Nu                       | ımber       | Title                                            | Page |
|------|-------------------------------|-------------|--------------------------------------------------|------|
|      | 29.6.2 Sources of             |             | f error                                          | 672  |
|      |                               | 29.6.2.1    | Sampling error                                   | 672  |
|      |                               | 29.6.2.2    | Pin leakage error.                               | 673  |
|      |                               | 29.6.2.3    | Noise-induced errors                             | 673  |
|      |                               | 29.6.2.4    | Code width and quantization error                | 674  |
|      |                               | 29.6.2.5    | Linearity errors.                                | 675  |
|      |                               | 29.6.2.6    | Code jitter, non-monotonicity, and missing codes | 675  |
|      |                               |             | Chapter 30<br>Comparator (CMP)                   |      |
| 30.1 | Introdu                       | ction       |                                                  | 677  |
| 30.2 | CMP F                         | eatures     |                                                  | 677  |
| 30.3 | 6-bit D                       | AC Key Fea  | atures                                           | 678  |
| 30.4 | ANMU                          | X Key Feat  | tures                                            | 678  |
| 30.5 | 5 CMP, DAC, and ANMUX Diagram |             |                                                  | 679  |
| 30.6 | CMP B                         | lock Diagra | ım                                               | 680  |
| 30.7 | Memor                         | y Map/Regi  | ister Definitions                                | 681  |
|      | 30.7.1                        | CMP Con     | ntrol Register 0 (CMPx_CR0)                      | 682  |
|      | 30.7.2                        | CMP Con     | ntrol Register 1 (CMPx_CR1)                      | 683  |
|      | 30.7.3                        | CMP Filte   | er Period Register (CMPx_FPR)                    | 684  |
|      | 30.7.4                        | CMP State   | tus and Control Register (CMPx_SCR)              | 684  |
|      | 30.7.5                        | DAC Con     | ntrol Register (CMPx_DACCR)                      | 686  |
|      | 30.7.6                        | MUX Cor     | ntrol Register (CMPx_MUXCR)                      | 687  |
| 30.8 | CMP F                         | unctional D | escription                                       | 688  |
|      | 30.8.1                        | CMP Fun     | actional Modes                                   | 688  |
|      |                               | 30.8.1.1    | Disabled Mode (# 1)                              | 690  |
|      |                               | 30.8.1.2    | Continuous Mode (#s 2A & 2B)                     | 690  |
|      |                               | 30.8.1.3    | Sampled, Non-Filtered Mode (#s 3A & 3B)          | 691  |
|      |                               | 30.8.1.4    | Sampled, Filtered Mode (#s 4A & 4B)              | 693  |
|      |                               | 30.8.1.5    | Windowed Mode (#s 5A & 5B)                       | 695  |
|      |                               |             |                                                  |      |

| Sect  | Section Number |             | Title                                                  | Page |
|-------|----------------|-------------|--------------------------------------------------------|------|
|       |                | 30.8.1.6    | Windowed/Resampled Mode (# 6)                          | 697  |
|       |                | 30.8.1.7    | Windowed/Filtered Mode (#7)                            | 697  |
|       | 30.8.2         | Power Mo    | odes                                                   | 698  |
|       |                | 30.8.2.1    | Wait Mode Operation                                    | 698  |
|       |                | 30.8.2.2    | Stop Mode Operation                                    | 698  |
|       |                | 30.8.2.3    | Low-Leakage Mode Operation                             | 699  |
|       |                | 30.8.2.4    | Background Debug Mode Operation                        | 699  |
|       | 30.8.3         | Startup an  | nd Operation                                           | 699  |
|       | 30.8.4         | Low Pass    | Filter                                                 | 700  |
|       |                | 30.8.4.1    | Enabling Filter Modes                                  | 700  |
|       |                | 30.8.4.2    | Latency Issues.                                        | 701  |
| 30.9  | CMP In         | nterrupts   |                                                        |      |
| 30.10 | CMP D          | MA Suppor   | rt                                                     | 702  |
| 30.11 | Digital        | to Analog C | Converter Block Diagram                                | 703  |
| 30.12 | DAC F          | unctional D | escription                                             | 703  |
|       | 30.12.1        | Voltage R   | Reference Source Select                                | 703  |
| 30.13 | DAC R          | esets       |                                                        | 704  |
| 30.14 | DAC Clocks     |             |                                                        | 704  |
| 30.15 | DAC In         | nterrupts   |                                                        | 704  |
|       |                |             | Chapter 31<br>12-bit Digital-to-Analog Converter (DAC) | 1    |
| 31.1  | Introdu        | ction       |                                                        | 705  |
| 31.2  | Feature        | S           |                                                        | 705  |
| 31.3  | Block I        | Diagram     |                                                        | 705  |
| 31.4  | Memor          | y Map/Regi  | ster Definition                                        | 706  |
|       | 31.4.1         | DAC Data    | a Low Register (DACx_DATnL)                            | 709  |
|       | 31.4.2         | DAC Data    | a High Register (DACx_DATnH)                           |      |
|       | 31.4.3         | DAC Stat    | us Register (DACx_SR)                                  | 709  |
|       | 31.4.4         | DAC Con     | atrol Register (DACx_C0)                               | 710  |

| Sect | tion Nu | ımber                                          | Title                                  | Page |
|------|---------|------------------------------------------------|----------------------------------------|------|
|      | 31.4.5  | DAC Cont                                       | rol Register 1 (DACx_C1)               | 711  |
|      | 31.4.6  | DAC Cont                                       | rol Register 2 (DACx_C2)               | 712  |
| 31.5 | Functio | nal Descripti                                  | ion                                    | 713  |
|      | 31.5.1  | DAC Data                                       | Buffer Operation                       | 713  |
|      |         | 31.5.1.1                                       | DAC Data Buffer Interrupts             | 713  |
|      |         | 31.5.1.2                                       | Buffer Normal Mode                     | 713  |
|      |         | 31.5.1.3                                       | Buffer Swing Mode                      | 714  |
|      |         | 31.5.1.4                                       | Buffer One-time Scan Mode              | 714  |
|      | 31.5.2  | DMA Open                                       | ration                                 | 714  |
|      | 31.5.3  | Resets                                         |                                        | 714  |
|      | 31.5.4  | Low Powe                                       | r Mode Operation                       | 714  |
|      |         | 31.5.4.1                                       | Wait Mode Operation                    | 715  |
|      |         | 31.5.4.2                                       | Stop Mode Operation                    | 715  |
|      | 31.5.5  | Backgroun                                      | d Mode Operation                       | 715  |
|      |         |                                                | Chapter 32<br>Voltage Reference (VREF) |      |
| 32.1 | Introdu | ction                                          |                                        | 717  |
|      | 32.1.1  | Overview                                       |                                        | 718  |
|      | 32.1.2  | Features                                       |                                        | 718  |
|      | 32.1.3  | Modes of 0                                     | Operation                              | 718  |
|      | 32.1.4  | VREF Sign                                      | nal Descriptions                       | 719  |
| 32.2 | Memor   | y Map and R                                    | Register Definition                    | 719  |
|      | 32.2.1  | VREF Trin                                      | n Register (VREF_TRM)                  | 720  |
|      | 32.2.2  | VREF Stat                                      | rus and Control Register (VREF_SC)     | 720  |
| 32.3 | Functio | nal Descripti                                  | ion                                    | 721  |
|      | 32.3.1  | 3.1 Voltage Reference Disabled, SC[VREFEN] = 0 |                                        |      |
|      | 32.3.2  | Voltage Re                                     | eference Enabled, SC[VREFEN] = 1       | 722  |
|      |         | 32.3.2.1                                       | SC[MODE_LV]=00                         | 722  |
|      |         | 32.3.2.2                                       | SC[MODE_LV] = 01                       | 722  |
|      |         |                                                |                                        |      |

| Sec  | Section Number          |              | Title                                           | Page |
|------|-------------------------|--------------|-------------------------------------------------|------|
|      |                         | 32.3.2.3     | SC[MODE_LV] = 10                                | 723  |
|      |                         | 32.3.2.4     | SC[MODE_LV] = 11                                | 723  |
| 32.4 | Initializa              | ation Inforn | nation                                          | 723  |
|      |                         |              | Chapter 33<br>Programmable Delay Block (PDB)    |      |
| 33.1 | Introduc                | ction        |                                                 | 725  |
|      | 33.1.1                  | Features     |                                                 | 725  |
|      | 33.1.2                  | Implemen     | tation                                          | 726  |
|      | 33.1.3                  | Back-to-ba   | ack Acknowledgement Connections                 | 727  |
|      | 33.1.4                  | DAC Exte     | ernal Trigger Input Connections                 | 727  |
|      | 33.1.5                  | Block Dia    | gram                                            | 727  |
|      | 33.1.6                  | Modes of     | Operation                                       | 729  |
| 33.2 | PDB Sig                 | gnal Descrip | ptions                                          | 729  |
| 33.3 | Memory                  | 729          |                                                 |      |
|      | 33.3.1                  | Status and   | Control Register (PDBx_SC)                      | 731  |
|      | 33.3.2                  | Modulus I    | Register (PDBx_MOD)                             | 733  |
|      | 33.3.3                  | Counter R    | tegister (PDBx_CNT)                             | 734  |
|      | 33.3.4                  | Interrupt I  | Delay Register (PDBx_IDLY)                      | 734  |
|      | 33.3.5                  | Channel n    | Control Register 1 (PDBx_CHnC1)                 | 735  |
|      | 33.3.6                  | Channel n    | Status Register (PDBx_CHnS)                     | 736  |
|      | 33.3.7                  | Channel n    | Delay 0 Register (PDBx_CHnDLY0)                 | 737  |
|      | 33.3.8                  | Channel n    | Delay 1 Register (PDBx_CHnDLY1)                 | 737  |
|      | 33.3.9                  | DAC Inter    | rval Trigger n Control Register (PDBx_DACINTCn) | 738  |
|      | 33.3.10                 | DAC Inter    | rval n Register (PDBx_DACINTn)                  | 738  |
|      | 33.3.11                 | Pulse-Out    | n Enable Register (PDBx_POnEN)                  | 739  |
|      | 33.3.12                 | Pulse-Out    | n Delay Register (PDBx_POnDLY)                  | 739  |
| 33.4 | Functional Description. |              |                                                 | 740  |
|      | 33.4.1                  | PDB Pre-t    | trigger and Trigger Outputs                     | 740  |
|      | 33.4.2                  | PDB Trigg    | ger Input Source Selection                      | 742  |

| Sec  | tion Nu | umber Title                                                                  | Page |
|------|---------|------------------------------------------------------------------------------|------|
|      | 33.4.3  | DAC Interval Trigger Outputs                                                 | 742  |
|      | 33.4.4  | Pulse-Out's                                                                  | 743  |
|      | 33.4.5  | Updating the Delay Registers                                                 | 743  |
|      | 33.4.6  | Interrupts                                                                   | 745  |
|      | 33.4.7  | DMA                                                                          | 745  |
| 33.5 | Applica | ation Information                                                            | 745  |
|      | 33.5.1  | Impact of Using the Prescaler and Multiplication Factor on Timing Resolution | 745  |
|      |         | Chapter 34<br>Modulo Timer (MTIM)                                            |      |
| 34.1 | Introdu | ction                                                                        | 747  |
| 34.2 | Feature | s                                                                            | 747  |
|      | 34.2.1  | Block Diagram                                                                | 748  |
|      | 34.2.2  | Modes of Operation                                                           | 748  |
|      |         | 34.2.2.1 MTIM16 in Wait Mode                                                 | 748  |
|      |         | 34.2.2.2 MTIM16 in Stop Modes                                                | 748  |
|      |         | 34.2.2.3 MTIM16 in Active Background Mode                                    | 749  |
| 34.3 | Externa | al Signal Description                                                        | 749  |
|      | 34.3.1  | TCLK — External Clock Source Input into MTIM16                               | 749  |
| 34.4 | Memor   | y Map and Register Descriptions.                                             | 750  |
|      | 34.4.1  | MTIM16 status and control register (MTIMx_SC)                                | 750  |
|      | 34.4.2  | MTIM16 clock configuration register (MTIMx_CLK)                              | 751  |
|      | 34.4.3  | MTIM16 counter register high (MTIMx_CNTH)                                    | 752  |
|      | 34.4.4  | MTIM16 counter register low (MTIMx_CNTL)                                     | 753  |
|      | 34.4.5  | MTIM16 modulo register high (MTIMx_MODH)                                     | 754  |
|      | 34.4.6  | MTIM16 modulo register low (MTIMx_MODL)                                      | 755  |
| 34.5 | Functio | onal Description                                                             | 755  |
|      | 34.5.1  | MTIM16 Operation Example                                                     | 756  |

### Chapter 35 Low Power Timer (LPTMR)

| 35.1 | Introduction           |                                                          |     |  |  |
|------|------------------------|----------------------------------------------------------|-----|--|--|
|      | 35.1.1                 | Features                                                 |     |  |  |
|      | 35.1.2                 | Modes of operation                                       | 759 |  |  |
|      |                        | 35.1.2.1 Run mode                                        |     |  |  |
|      |                        | 35.1.2.2 Wait mode                                       | 759 |  |  |
|      |                        | 35.1.2.3 Stop mode                                       | 760 |  |  |
|      |                        | 35.1.2.4 Low leakage modes                               | 760 |  |  |
|      |                        | 35.1.2.5 Debug modes                                     | 760 |  |  |
| 35.2 | LPTMF                  | R signal descriptions                                    | 760 |  |  |
|      | 35.2.1                 | Detailed signal descriptions.                            | 760 |  |  |
| 35.3 | Memor                  | y map and register definition                            | 761 |  |  |
|      | 35.3.1                 | 3.1 Low Power Timer Control Status Register (LPTMRx_CSR) |     |  |  |
|      | 35.3.2                 | Low Power Timer Prescale Register (LPTMRx_PSR)           | 764 |  |  |
|      | 35.3.3                 | Low Power Timer Compare Register (LPTMRx_CMR)            | 765 |  |  |
|      | 35.3.4                 | Low Power Timer Counter Register (LPTMRx_CNR)            | 766 |  |  |
| 35.4 | Functional description |                                                          |     |  |  |
|      | 35.4.1                 | LPTMR power and reset                                    | 766 |  |  |
|      | 35.4.2                 | LPTMR clocking                                           | 766 |  |  |
|      | 35.4.3                 | LPTMR prescaler/glitch filter                            | 767 |  |  |
|      |                        | 35.4.3.1 Prescaler enabled                               | 767 |  |  |
|      |                        | 35.4.3.2 Prescaler bypassed                              | 767 |  |  |
|      |                        | 35.4.3.3 Glitch filter                                   | 767 |  |  |
|      |                        | 35.4.3.4 Glitch filter bypassed                          | 768 |  |  |
|      | 35.4.4                 | LPTMR compare                                            | 768 |  |  |
|      | 35.4.5                 | LPTMR counter                                            | 768 |  |  |
|      | 35.4.6                 | LPTMR hardware trigger                                   | 769 |  |  |
|      | 35.4.7                 | 4.7 LPTMR interrupt                                      |     |  |  |
|      |                        |                                                          |     |  |  |

## Chapter 36 Carrier Modulator Transmitter (CMT)

| 36.1 | Introduction                   |                                                       |     |  |  |
|------|--------------------------------|-------------------------------------------------------|-----|--|--|
| 36.2 | Features                       |                                                       |     |  |  |
| 36.3 | Block D                        | Diagram                                               | 772 |  |  |
| 36.4 | Modes of Operation             |                                                       |     |  |  |
|      | 36.4.1                         | Wait Mode Operation                                   | 774 |  |  |
|      | 36.4.2                         | Stop Mode Operation                                   | 774 |  |  |
|      |                                | 36.4.2.1 Normal Stop Mode Operation                   | 774 |  |  |
|      |                                | 36.4.2.2 Low Power Stop Mode Operation                | 774 |  |  |
|      | 36.4.3                         | Background Debug Mode Operation.                      | 774 |  |  |
| 36.5 | CMT E                          | xternal Signal Descriptions                           | 775 |  |  |
|      | 36.5.1                         | CMT_IRO — Infrared Output                             | 775 |  |  |
| 36.6 | Memory Map/Register Definition |                                                       |     |  |  |
|      | 36.6.1                         | CMT Carrier Generator High Data Register 1 (CMT_CGH1) | 776 |  |  |
|      | 36.6.2                         | CMT Carrier Generator Low Data Register 1 (CMT_CGL1)  | 777 |  |  |
|      | 36.6.3                         | CMT Carrier Generator High Data Register 2 (CMT_CGH2) | 777 |  |  |
|      | 36.6.4                         | CMT Carrier Generator Low Data Register 2 (CMT_CGL2)  | 778 |  |  |
|      | 36.6.5                         | CMT Output Control Register (CMT_OC)                  | 778 |  |  |
|      | 36.6.6                         | CMT Modulator Status and Control Register (CMT_MSC)   | 779 |  |  |
|      | 36.6.7                         | CMT Modulator Data Register Mark High (CMT_CMD1)      | 781 |  |  |
|      | 36.6.8                         | CMT Modulator Data Register Mark Low (CMT_CMD2)       | 781 |  |  |
|      | 36.6.9                         | CMT Modulator Data Register Space High (CMT_CMD3)     | 782 |  |  |
|      | 36.6.10                        | CMT Modulator Data Register Space Low (CMT_CMD4)      | 782 |  |  |
|      | 36.6.11                        | CMT Primary Prescaler Register (CMT_PPS)              | 783 |  |  |
|      | 36.6.12                        | CMT Direct Memory Access (CMT_DMA)                    | 784 |  |  |
| 36.7 | Functional Description.        |                                                       |     |  |  |
|      | 36.7.1                         | Clock Divider                                         | 784 |  |  |
|      | 36.7.2                         | Carrier Generator                                     | 785 |  |  |
|      |                                |                                                       |     |  |  |

| tion Nu  | mber                                                                                                                                                         | Title                                                                                                                                                                                      | Page               |
|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|
| 36.7.3   | Modulator                                                                                                                                                    |                                                                                                                                                                                            | 787                |
|          | 36.7.3.1 Time Mo                                                                                                                                             | ode                                                                                                                                                                                        |                    |
|          | 36.7.3.2 Baseband                                                                                                                                            | d Mode                                                                                                                                                                                     | 790                |
|          | 36.7.3.3 FSK Mo                                                                                                                                              | de                                                                                                                                                                                         | 790                |
| 36.7.4   | Extended Space Oper                                                                                                                                          | ration                                                                                                                                                                                     | 791                |
|          | 36.7.4.1 EXSPC                                                                                                                                               | Operation in Time Mode                                                                                                                                                                     | 792                |
|          | 36.7.4.2 EXSPC                                                                                                                                               | Operation in FSK Mode                                                                                                                                                                      | 792                |
| CMT Ir   | terrupts and DMA                                                                                                                                             |                                                                                                                                                                                            | 793                |
|          |                                                                                                                                                              | Chapter 37 FlexTimer (FTM)                                                                                                                                                                 |                    |
| Introdu  | tion                                                                                                                                                         |                                                                                                                                                                                            | 795                |
| 37.1.1   | FlexTimer Philosoph                                                                                                                                          | у                                                                                                                                                                                          | 795                |
| 37.1.2   | Features                                                                                                                                                     |                                                                                                                                                                                            | 796                |
| 37.1.3   | Modes of Operation                                                                                                                                           |                                                                                                                                                                                            | 797                |
| 37.1.4   | Block Diagram                                                                                                                                                |                                                                                                                                                                                            | 798                |
| Signal I | Description                                                                                                                                                  |                                                                                                                                                                                            | 800                |
| 37.2.1   | EXTCLK — FTM E                                                                                                                                               | 800                                                                                                                                                                                        |                    |
| 37.2.2   | CHn — FTM Channe                                                                                                                                             | el (n) I/O Pin                                                                                                                                                                             | 800                |
| 37.2.3   | FAULTj — FTM Fau                                                                                                                                             | ılt Input                                                                                                                                                                                  | 800                |
| 37.2.4   | PHA — FTM Quadra                                                                                                                                             | ature Decoder Phase A Input                                                                                                                                                                | 801                |
| 37.2.5   | PHB — FTM Quadra                                                                                                                                             | ture Decoder Phase B Input                                                                                                                                                                 | 801                |
| Memor    | Map and Register De                                                                                                                                          | finition                                                                                                                                                                                   | 801                |
| 37.3.1   | Module Memory Map                                                                                                                                            | p                                                                                                                                                                                          | 801                |
| 37.3.2   | Register Descriptions                                                                                                                                        | J                                                                                                                                                                                          | 802                |
| 37.3.3   | Status and Control (F                                                                                                                                        | TM <i>x</i> _SC)                                                                                                                                                                           | 806                |
| 37.3.4   | Counter High (FTMx                                                                                                                                           | _CNTH)                                                                                                                                                                                     | 807                |
| 37.3.5   | Counter Low (FTMx                                                                                                                                            | _CNTL)                                                                                                                                                                                     | 808                |
| 37.3.6   | Modulo High (FTMx)                                                                                                                                           | _MODH)                                                                                                                                                                                     | 809                |
| 37.3.7   | Modulo Low (FTMx                                                                                                                                             | _MODL)                                                                                                                                                                                     | 810                |
|          | 36.7.3  36.7.4  CMT In  Introduce 37.1.1 37.1.2 37.1.3 37.1.4  Signal E 37.2.1 37.2.2 37.2.3 37.2.4 37.2.5  Memory 37.3.1 37.3.2 37.3.3 37.3.4 37.3.5 37.3.6 | 36.7.3.1 Time Mo 36.7.3.2 Baseband 36.7.3.3 FSK Mod 36.7.4.1 EXSPC O 36.7.4.1 EXSPC O 36.7.4.2 EXSPC O 36.7.4.2 EXSPC O CMT Interrupts and DMA  37.1.1 FlexTimer Philosoph 37.1.2 Features | 36.7.3.1 Time Mode |

| Sec  | tion Nu                 | umber Title  |                                            | Page |
|------|-------------------------|--------------|--------------------------------------------|------|
|      | 37.3.8                  | Channel S    | tatus and Control (FTMx_CnSC)              | 810  |
|      | 37.3.9                  | Channel V    | Value High (FTMx_CnVH)                     | 813  |
|      | 37.3.10                 | Channel V    | Value Low (FTMx_CnVL)                      | 814  |
|      | 37.3.11                 | Counter In   | nitial Value High (FTMx_CNTINH)            | 815  |
|      | 37.3.12                 | Counter In   | nitial Value Low (FTMx_CNTINL)             | 816  |
|      | 37.3.13                 | Capture an   | nd Compare Status (FTMx_STATUS)            | 816  |
|      | 37.3.14                 | Features N   | Mode Selection (FTMx_MODE)                 | 818  |
|      | 37.3.15                 | Synchronia   | zation (FTMx_SYNC)                         | 819  |
|      | 37.3.16                 | Initial Stat | te for Channel Output (FTMx_OUTINIT)       | 822  |
|      | 37.3.17                 | Output Ma    | ask (FTMx_OUTMASK)                         | 823  |
|      | 37.3.18                 | Function f   | for Linked Channels (FTMx_COMBINEn)        | 825  |
|      | 37.3.19                 | Deadtime     | Insertion Control (FTMx_DEADTIME)          | 827  |
|      | 37.3.20                 | External T   | Trigger (FTMx_EXTTRIG)                     | 827  |
|      | 37.3.21                 | Channels I   | Polarity (FTMx_POL)                        | 829  |
|      | 37.3.22                 | Fault Mod    | le Status (FTMx_FMS)                       | 831  |
|      | 37.3.23                 | Input Capt   | ture Filter Control (FTMx_FILTERn)         | 833  |
|      | 37.3.24                 | Fault Inpu   | t Filter Control (FTMx_FLTFILTER)          | 834  |
|      | 37.3.25                 | Fault Inpu   | t Control (FTMx_FLTCTRL)                   | 834  |
|      | 37.3.26                 | Quadrature   | e Decoder Control and Status (FTMx_QDCTRL) | 836  |
| 37.4 | Functional Description. |              |                                            | 837  |
|      | 37.4.1                  | Clock Sou    | irce                                       | 838  |
|      |                         | 37.4.1.1     | Counter Clock Source                       | 838  |
|      | 37.4.2                  | Prescaler    |                                            | 839  |
|      | 37.4.3                  | Counter      |                                            | 839  |
|      |                         | 37.4.3.1     | Up Counting                                | 839  |
|      |                         | 37.4.3.2     | Up-Down Counting                           | 842  |
|      |                         | 37.4.3.3     | Free Running Counter                       | 843  |
|      |                         | 37.4.3.4     | Counter Reset                              | 844  |

| Section Number |                | Title                            | Page |
|----------------|----------------|----------------------------------|------|
| 37.4.4         | Input Capt     | ture Mode                        | 844  |
|                | 37.4.4.1       | Filter for Input Capture Mode    | 845  |
| 37.4.5         | Output Cor     | mpare Mode                       | 846  |
| 37.4.6         | Edge-Align     | ned PWM (EPWM) Mode              | 848  |
| 37.4.7         | Center-Ali     | gned PWM (CPWM) Mode             | 850  |
| 37.4.8         | Combine N      | Mode                             | 852  |
|                | 37.4.8.1       | Asymmetrical PWM                 | 859  |
| 37.4.9         | Compleme       | entary Mode                      | 859  |
| 37.4.10        | Update of      | the Registers With Write Buffers | 860  |
|                | 37.4.10.1      | CNTINH:L Registers               | 860  |
|                | 37.4.10.2      | MODH:L Registers                 | 860  |
|                | 37.4.10.3      | CnVH:L Registers                 | 861  |
| 37.4.11        | PWM Syn        | chronization                     | 862  |
|                | 37.4.11.1      | Hardware Trigger                 | 862  |
|                | 37.4.11.2      | Software Trigger                 | 863  |
|                | 37.4.11.3      | Boundary Cycle                   | 864  |
|                | 37.4.11.4      | MODH:L Registers Synchronization | 865  |
|                | 37.4.11.5      | CnVH:L Registers Synchronization | 867  |
|                | 37.4.11.6      | OUTMASK Register Synchronization | 867  |
|                | 37.4.11.7      | FTM Counter Synchronization      | 869  |
|                | 37.4.11.8      | Summary of PWM Synchronization   | 871  |
| 37.4.12        | Deadtime l     | Insertion                        | 873  |
|                | 37.4.12.1      | Deadtime Insertion Corner Cases  | 874  |
| 37.4.13        | Output Ma      | nsk                              | 876  |
| 37.4.14        | Fault Cont     | rol                              | 877  |
|                | 37.4.14.1      | Automatic Fault Clearing         | 879  |
|                | 37.4.14.2      | Manual Fault Clearing            | 880  |
| 37.4.15        | Polarity Co    | ontrol                           | 880  |
| 37.4.16        | Initialization | on                               |      |
|                |                |                                  |      |

| Sect | ion Nu   | mber Title                                       | Page |
|------|----------|--------------------------------------------------|------|
|      | 37.4.17  | Features Priority                                | 881  |
|      | 37.4.18  | Channel Trigger Output                           | 881  |
|      | 37.4.19  | Initialization Trigger                           | 882  |
|      | 37.4.20  | Capture Test Mode                                | 884  |
|      | 37.4.21  | DMA                                              | 885  |
|      | 37.4.22  | Dual Edge Capture Mode                           | 886  |
|      |          | 37.4.22.1 One-Shot Capture Mode                  | 887  |
|      |          | 37.4.22.2 Continuous Capture Mode                | 888  |
|      |          | 37.4.22.3 Pulse Width Measurement                | 888  |
|      |          | 37.4.22.4 Period Measurement                     | 890  |
|      |          | 37.4.22.5 Read Coherency Mechanism               | 892  |
|      | 37.4.23  | Quadrature Decoder Mode                          | 893  |
|      |          | 37.4.23.1 Quadrature Decoder Boundary Conditions | 897  |
|      | 37.4.24  | TPM Emulation.                                   | 898  |
|      |          | 37.4.24.1 MODH:L and CnVH:L Synchronization      | 898  |
|      |          | 37.4.24.2 Free Running Counter                   | 898  |
|      |          | 37.4.24.3 Write to SC                            | 899  |
|      |          | 37.4.24.4 Write to CnSC                          | 899  |
|      | 37.4.25  | BDM Mode                                         | 899  |
| 37.5 | Reset O  | verview                                          | 900  |
| 37.6 | FTM Int  | terrupts                                         | 902  |
|      | 37.6.1   | Timer Overflow Interrupt                         | 902  |
|      | 37.6.2   | Channel (n) Interrupt                            | 902  |
|      | 37.6.3   | Fault Interrupt                                  | 902  |
|      |          | Chapter 38<br>Serial Peripheral Interface (SPI)  |      |
| 38.1 | Introduc | ction                                            | 903  |
|      | 38.1.1   | Features                                         | 903  |
|      | 38.1.2   | Modes of Operation                               | 904  |

| Sec  | tion Nu                 | imber Title                            | Page |
|------|-------------------------|----------------------------------------|------|
|      | 38.1.3                  | Block Diagrams                         | 905  |
|      |                         | 38.1.3.1 SPI System Block Diagram      | 905  |
|      |                         | 38.1.3.2 SPI Module Block Diagram      | 905  |
| 38.2 | Externa                 | l Signal Description.                  | 908  |
|      | 38.2.1                  | SPSCK — SPI Serial Clock               | 909  |
|      | 38.2.2                  | MOSI — Master Data Out, Slave Data In  | 909  |
|      | 38.2.3                  | MISO — Master Data In, Slave Data Out  | 909  |
|      | 38.2.4                  | SS — Slave Select                      | 909  |
| 38.3 | Register                | Definition                             | 910  |
|      | 38.3.1                  | SPI control register 1 (SPIx_C1)       | 911  |
|      | 38.3.2                  | SPI control register 2 (SPIx_C2)       | 913  |
|      | 38.3.3                  | SPI baud rate register (SPIx_BR)       | 914  |
|      | 38.3.4                  | SPI status register (SPIx_S)           | 915  |
|      | 38.3.5                  | SPI data register high (SPIx_DH)       | 919  |
|      | 38.3.6                  | SPI data register low (SPIx_DL)        | 919  |
|      | 38.3.7                  | SPI match register high (SPIx_MH)      | 920  |
|      | 38.3.8                  | SPI match register low (SPIx_ML)       | 920  |
|      | 38.3.9                  | SPI control register 3 (SPIx_C3)       | 921  |
|      | 38.3.10                 | SPI clear interrupt register (SPIx_CI) | 923  |
| 38.4 | Functional Description. |                                        | 924  |
|      | 38.4.1                  | General                                | 924  |
|      | 38.4.2                  | Master Mode                            | 925  |
|      | 38.4.3                  | Slave Mode                             | 926  |
|      | 38.4.4                  | SPI FIFO Mode                          | 928  |
|      | 38.4.5                  | SPI Transmission by DMA                | 929  |
|      |                         | 38.4.5.1 Transmit by DMA               | 929  |
|      |                         | 38.4.5.2 Receive by DMA                | 931  |
|      | 38.4.6                  | Data Transmission Length               | 932  |
|      | 38.4.7                  | SPI Clock Formats.                     | 932  |
|      |                         |                                        |      |

| Sect | tion Nu    | mber          | Title                                               | Page |
|------|------------|---------------|-----------------------------------------------------|------|
|      | 38.4.8     | SPI Baud R    | Rate Generation                                     | 935  |
|      | 38.4.9     | Special Fea   | itures                                              | 936  |
|      |            | 38.4.9.1      | SS Output                                           | 936  |
|      |            | 38.4.9.2      | Bidirectional Mode (MOMI or SISO)                   | 937  |
|      | 38.4.10    | Error Cond    | itions                                              | 938  |
|      |            | 38.4.10.1     | Mode Fault Error                                    | 938  |
|      | 38.4.11    | Low Power     | Mode Options                                        | 938  |
|      |            | 38.4.11.1     | SPI in Run Mode                                     | 938  |
|      |            | 38.4.11.2     | SPI in Wait Mode                                    | 939  |
|      |            | 38.4.11.3     | SPI in Stop Mode                                    | 940  |
|      | 38.4.12    | Reset         |                                                     | 940  |
|      | 38.4.13    | Interrupts    |                                                     | 940  |
|      |            | 38.4.13.1     | MODF                                                | 941  |
|      |            | 38.4.13.2     | SPRF                                                | 941  |
|      |            | 38.4.13.3     | SPTEF                                               | 941  |
|      |            | 38.4.13.4     | SPMF                                                | 942  |
|      |            | 38.4.13.5     | TNEAREF                                             | 942  |
|      |            | 38.4.13.6     | RNFULLF                                             | 942  |
| 38.5 | Initializa | ation/Applica | ation Information                                   | 942  |
|      | 38.5.1     | Initializatio | on Sequence                                         | 942  |
|      | 38.5.2     | Pseudo-Coo    | de Example                                          | 943  |
|      |            |               | Chapter 39<br>Universal Serial Bus (USB) Controller |      |
| 39.1 | Introduc   | tion          |                                                     | 947  |
|      | 39.1.1     | USB           |                                                     | 947  |
|      | 39.1.2     | USB On-Th     | he-Go                                               | 948  |
|      | 39.1.3     | USB-FS Fe     | eatures                                             | 949  |
| 39.2 | Function   | nal Descripti | on                                                  | 949  |
|      | 39.2.1     | Data Struct   | ures                                                | 949  |

| Section Number |         | mber Title                                         | Page |
|----------------|---------|----------------------------------------------------|------|
| 39.3           | Program | nmers Interface                                    | 950  |
|                | 39.3.1  | Buffer Descriptor Table                            | 950  |
|                | 39.3.2  | Rx vs. Tx as a USB Target Device or USB Host       | 951  |
|                | 39.3.3  | Addressing Buffer Descriptor Table Entries         | 952  |
|                | 39.3.4  | Buffer Descriptor Formats.                         | 952  |
|                | 39.3.5  | USB Transaction.                                   | 955  |
| 39.4           | Memory  | Map/Register Definitions.                          | 957  |
|                | 39.4.1  | Peripheral ID Register (USBx_PERID)                | 960  |
|                | 39.4.2  | Peripheral ID Complement Register (USBx_IDCOMP)    | 960  |
|                | 39.4.3  | Peripheral Revision Register (USBx_REV)            | 961  |
|                | 39.4.4  | Peripheral Additional Info Register (USBx_ADDINFO) | 961  |
|                | 39.4.5  | OTG Interrupt Status Register (USBx_OTGISTAT)      | 962  |
|                | 39.4.6  | OTG Interrupt Control Register (USBx_OTGICR)       | 963  |
|                | 39.4.7  | OTG Status Register (USBx_OTGSTAT)                 | 964  |
|                | 39.4.8  | OTG Control Register (USBx_OTGCTL)                 | 965  |
|                | 39.4.9  | Interrupt Status Register (USBx_ISTAT)             | 966  |
|                | 39.4.10 | Interrupt Enable Register (USBx_INTEN)             | 967  |
|                | 39.4.11 | Error Interrupt Status Register (USBx_ERRSTAT)     | 968  |
|                | 39.4.12 | Error Interrupt Enable Register (USBx_ERREN)       | 969  |
|                | 39.4.13 | Status Register (USBx_STAT)                        | 970  |
|                | 39.4.14 | Control Register (USBx_CTL)                        | 971  |
|                | 39.4.15 | Address Register (USBx_ADDR)                       | 972  |
|                | 39.4.16 | BDT Page Register 1 (USBx_BDTPAGE1)                | 973  |
|                | 39.4.17 | Frame Number Register Low (USBx_FRMNUML)           | 973  |
|                | 39.4.18 | Frame Number Register High (USBx_FRMNUMH)          | 974  |
|                | 39.4.19 | Token Register (USBx_TOKEN)                        | 975  |
|                | 39.4.20 | SOF Threshold Register (USBx_SOFTHLD)              | 976  |
|                | 39.4.21 | BDT Page Register 2 (USBx_BDTPAGE2)                | 976  |
|                | 39.4.22 | BDT Page Register 3 (USBx_BDTPAGE3)                | 977  |
|                |         |                                                    |      |

| Sec  | tion Nu  | ımber Title                                             | Page |
|------|----------|---------------------------------------------------------|------|
|      | 39.4.23  | Endpoint Control Register (USBx_ENDPTn)                 | 977  |
|      | 39.4.24  | USB Control Register (USBx_USBCTRL)                     | 978  |
|      | 39.4.25  | USB OTG Observe Register (USBx_OBSERVE)                 | 979  |
|      | 39.4.26  | USB OTG Control Register (USBx_CONTROL)                 | 980  |
|      | 39.4.27  | USB Transceiver Control Register 0 (USBx_USBTRC0)       | 980  |
|      | 39.4.28  | Frame Adjust Register (USBx_USBFRMADJUST)               | 981  |
| 39.5 | OTG an   | d Host Mode Operation.                                  | 982  |
| 39.6 | Host M   | ode Operation Examples                                  | 982  |
| 39.7 | On-The   | -Go Operation                                           | 986  |
|      | 39.7.1   | OTG Dual Role A Device Operation.                       | 986  |
|      | 39.7.2   | OTG Dual Role B Device Operation.                       | 987  |
|      |          | Chapter 40 USB Device Charger Detection Module (USBDCD) |      |
| 40.1 | Preface  |                                                         | 989  |
|      | 40.1.1   | References                                              | 989  |
|      | 40.1.2   | Acronyms and Abbreviations                              | 989  |
|      | 40.1.3   | Glossary                                                | 990  |
| 40.2 | Introduc | ction                                                   | 990  |
|      | 40.2.1   | Block Diagram                                           | 990  |
|      | 40.2.2   | Features.                                               | 991  |
|      | 40.2.3   | Modes of Operation                                      | 991  |
| 40.3 | Module   | Signal Description.                                     | 992  |
|      | 40.3.1   | USB Signal Descriptions                                 | 992  |
| 40.4 | Memor    | y Map/Register Definition                               | 993  |
|      | 40.4.1   | Control Register (USBDCD_CONTROL)                       | 994  |
|      | 40.4.2   | Clock Register (USBDCD_CLOCK)                           | 996  |
|      | 40.4.3   | Status Register (USBDCD_STATUS)                         | 997  |
|      | 40.4.4   | TIMER0 Register (USBDCD_TIMER0)                         | 998  |
|      | 40.4.5   | USBDCD_TIMER1                                           | 999  |
|      |          |                                                         |      |

| Sect | Section Number           |                                              | Title                                      | Page |
|------|--------------------------|----------------------------------------------|--------------------------------------------|------|
|      | 40.4.6                   | USBDCD                                       | D_TIMER2                                   | 1000 |
| 40.5 | Functio                  | nal Descrip                                  | otion                                      | 1001 |
|      | 40.5.1                   | The Charg                                    | ger Detection Sequence                     | 1002 |
|      |                          | 40.5.1.1                                     | Initial System Conditions                  | 1004 |
|      |                          | 40.5.1.2                                     | VBUS Contact Detection                     | 1005 |
|      |                          | 40.5.1.3                                     | Data Pin Contact Detection                 | 1005 |
|      |                          | 40.5.1.4                                     | Charging Port Detection                    | 1007 |
|      |                          | 40.5.1.5                                     | Charger Type Detection                     | 1009 |
|      |                          | 40.5.1.6                                     | Charger Detection Sequence Timeout         | 1011 |
|      | 40.5.2                   | Interrupts                                   | and Events                                 | 1012 |
|      |                          | 40.5.2.1                                     | Interrupt Handling                         | 1012 |
|      | 40.5.3                   | Resets                                       |                                            | 1013 |
|      |                          | 40.5.3.1                                     | Hardware Resets.                           | 1013 |
|      |                          | 40.5.3.2                                     | Software Reset                             | 1013 |
| 40.6 | Initializ                | ation Inforr                                 | mation                                     | 1014 |
| 40.7 | Application Information. |                                              |                                            | 1014 |
|      | 40.7.1 External Pullups  |                                              | 1014                                       |      |
|      | 40.7.2                   | Dead or V                                    | Weak Battery                               | 1014 |
|      | 40.7.3                   | Handling                                     | Unplug Events                              | 1015 |
|      |                          |                                              | Chapter 41<br>USB Voltage Regulator (VREG) |      |
| 41.1 | Introduc                 | ction                                        |                                            | 1017 |
|      | 41.1.1                   | Overview                                     | 7                                          | 1017 |
|      | 41.1.2                   | Features                                     |                                            | 1018 |
|      | 41.1.3                   | Modes of                                     | Operation                                  | 1019 |
| 41.2 | USB V                    | Voltage Regulator Module Signal Descriptions |                                            |      |

## Chapter 42 Inter-Integrated Circuit (I2C)

| 42.1 | Introduction |                                                          |                                          | 1021 |  |  |
|------|--------------|----------------------------------------------------------|------------------------------------------|------|--|--|
|      | 42.1.1       | Features                                                 |                                          | 1021 |  |  |
|      | 42.1.2       | Modes of C                                               | Operation                                | 1022 |  |  |
|      | 42.1.3       | Block Diag                                               | ram                                      | 1022 |  |  |
| 42.2 | I2C Sign     | nal Descripti                                            | ons                                      | 1023 |  |  |
| 42.3 | Memory       | Map and Re                                               | egisters                                 | 1023 |  |  |
|      | 42.3.1       | I2C Address Register 1 (I2Cx_A1)                         |                                          |      |  |  |
|      | 42.3.2       | I2C Freque                                               | ncy Divider register (I2Cx_F)            | 1027 |  |  |
|      | 42.3.3       | I2C Contro                                               | l Register 1 (I2Cx_C1)                   | 1028 |  |  |
|      | 42.3.4       | I2C Status                                               | Register (I2Cx_S)                        | 1029 |  |  |
|      | 42.3.5       | I2C Data I/                                              | O register (I2Cx_D)                      | 1031 |  |  |
|      | 42.3.6       | I2C Control Register 2 (I2Cx_C2)                         |                                          |      |  |  |
|      | 42.3.7       | I2C Programmable Input Glitch Filter register (I2Cx_FLT) |                                          |      |  |  |
|      | 42.3.8       | I2C Range                                                | Address register (I2Cx_RA)               | 1034 |  |  |
|      | 42.3.9       | I2C SMBus                                                | s Control and Status register (I2Cx_SMB) | 1034 |  |  |
|      | 42.3.10      | I2C Addres                                               | ss Register 2 (I2Cx_A2)                  | 1036 |  |  |
|      | 42.3.11      | I2C SCL Lo                                               | ow Timeout Register High (I2Cx_SLTH)     | 1037 |  |  |
|      | 42.3.12      | 3.12 I2C SCL Low Timeout Register Low (I2Cx_SLTL)        |                                          |      |  |  |
| 42.4 | Function     | on                                                       | 1037                                     |      |  |  |
|      | 42.4.1       | I2C Protoco                                              | ol                                       | 1038 |  |  |
|      |              | 42.4.1.1                                                 | START Signal                             | 1038 |  |  |
|      |              | 42.4.1.2                                                 | Slave Address Transmission               | 1039 |  |  |
|      |              | 42.4.1.3                                                 | Data Transfers                           | 1039 |  |  |
|      |              | 42.4.1.4                                                 | STOP Signal                              | 1040 |  |  |
|      |              | 42.4.1.5                                                 | Repeated START Signal                    | 1040 |  |  |
|      |              | 42.4.1.6                                                 | Arbitration Procedure                    | 1040 |  |  |
|      |              | 42.4.1.7                                                 | Clock Synchronization                    | 1041 |  |  |
|      |              |                                                          |                                          |      |  |  |

| Sect | tion Nu   | ımber        | Title                                                           | Page |
|------|-----------|--------------|-----------------------------------------------------------------|------|
|      |           | 42.4.1.8     | Handshaking                                                     | 1041 |
|      |           | 42.4.1.9     | Clock Stretching.                                               | 1041 |
|      |           | 42.4.1.10    | I2C Divider and Hold Values                                     | 1042 |
|      | 42.4.2    | 10-bit Add   | iress                                                           | 1043 |
|      |           | 42.4.2.1     | Master-Transmitter Addresses a Slave-Receiver                   | 1043 |
|      |           | 42.4.2.2     | Master-Receiver Addresses a Slave-Transmitter                   | 1044 |
|      | 42.4.3    | Address M    | Tatching                                                        | 1044 |
|      | 42.4.4    | System Ma    | anagement Bus Specification                                     | 1045 |
|      |           | 42.4.4.1     | Timeouts                                                        | 1045 |
|      |           | 42.4.4.2     | FAST ACK and NACK                                               | 1047 |
|      | 42.4.5    | Resets       |                                                                 | 1048 |
|      | 42.4.6    | Interrupts   |                                                                 | 1048 |
|      |           | 42.4.6.1     | Byte Transfer Interrupt                                         | 1048 |
|      |           | 42.4.6.2     | Address Detect Interrupt                                        | 1049 |
|      |           | 42.4.6.3     | Exit from Low-Power/Stop Modes                                  | 1049 |
|      |           | 42.4.6.4     | Arbitration Lost Interrupt                                      | 1049 |
|      |           | 42.4.6.5     | Timeout Interrupt in SMBus                                      | 1050 |
|      | 42.4.7    | Programma    | able Input Glitch Filter                                        | 1050 |
|      | 42.4.8    | Address M    | fatching Wakeup                                                 | 1050 |
|      | 42.4.9    | DMA Supp     | port                                                            | 1051 |
| 42.5 | Initializ | ation/Applic | eation Information                                              | 1051 |
|      |           | Ur           | Chapter 43<br>niversal Asynchronous Receiver/Transmitter (UART) |      |
| 43.1 | Introdu   | ction        |                                                                 | 1055 |
|      | 43.1.1    | Features     |                                                                 | 1055 |
|      | 43.1.2    | Modes of o   | operation                                                       | 1057 |
|      |           | 43.1.2.1     | Run mode                                                        | 1057 |
|      |           | 43.1.2.2     | Wait mode                                                       | 1057 |
|      |           | 43.1.2.3     | Stop mode                                                       | 1058 |

| Sect | ion Nu  | imber Title                                        | Page |
|------|---------|----------------------------------------------------|------|
| 43.2 | UART s  | signal descriptions                                | 1058 |
|      | 43.2.1  | Detailed signal descriptions.                      | 1058 |
| 43.3 | Module  | Memory Map                                         | 1059 |
|      | 43.3.1  | UART Baud Rate Registers:High (UARTx_BDH)          | 1063 |
|      | 43.3.2  | UART Baud Rate Registers: Low (UARTx_BDL)          | 1064 |
|      | 43.3.3  | UART Control Register 1 (UARTx_C1)                 | 1064 |
|      | 43.3.4  | UART Control Register 2 (UARTx_C2)                 | 1066 |
|      | 43.3.5  | UART Status Register 1 (UARTx_S1)                  | 1068 |
|      | 43.3.6  | UART Status Register 2 (UARTx_S2)                  | 1071 |
|      | 43.3.7  | UART Control Register 3 (UARTx_C3)                 | 1073 |
|      | 43.3.8  | UART Data Register (UARTx_D)                       | 1074 |
|      | 43.3.9  | UART Match Address Registers 1 (UARTx_MA1)         | 1076 |
|      | 43.3.10 | UART Match Address Registers 2 (UARTx_MA2)         | 1076 |
|      | 43.3.11 | UART Control Register 4 (UARTx_C4)                 | 1077 |
|      | 43.3.12 | UART Control Register 5 (UARTx_C5)                 | 1078 |
|      | 43.3.13 | UART Extended Data Register (UARTx_ED)             | 1079 |
|      | 43.3.14 | UART Modem Register (UARTx_MODEM)                  | 1079 |
|      | 43.3.15 | UART FIFO Parameters (UARTx_PFIFO)                 | 1081 |
|      | 43.3.16 | UART FIFO Control Register (UARTx_CFIFO)           | 1082 |
|      | 43.3.17 | UART FIFO Status Register (UARTx_SFIFO)            | 1083 |
|      | 43.3.18 | UART FIFO Transmit Watermark (UARTx_TWFIFO)        | 1084 |
|      | 43.3.19 | UART FIFO Transmit Count (UARTx_TCFIFO)            | 1085 |
|      | 43.3.20 | UART FIFO Receive Watermark (UARTx_RWFIFO)         | 1086 |
|      | 43.3.21 | UART FIFO Receive Count (UARTx_RCFIFO)             | 1086 |
|      | 43.3.22 | UART 7816 Control Register (UARTx_C7816)           | 1087 |
|      | 43.3.23 | UART 7816 Interrupt Enable Register (UARTx_IE7816) | 1089 |
|      | 43.3.24 | UART 7816 Interrupt Status Register (UARTx_IS7816) | 1090 |
|      | 43.3.25 | UART 7816 Wait Parameter Register (UARTx_WP7816T0) | 1092 |
|      | 43.3.26 | UART 7816 Wait Parameter Register (UARTx_WP7816T1) | 1092 |

| Sect | tion Nu | ımber         | Title                                      | Page |
|------|---------|---------------|--------------------------------------------|------|
|      | 43.3.27 | UART 78       | 16 Wait N Register (UARTx_WN7816)          | 1093 |
|      | 43.3.28 | UART 78       | 16 Wait FD Register (UARTx_WF7816)         | 1093 |
|      | 43.3.29 | UART 78       | 16 Error Threshold Register (UARTx_ET7816) | 1094 |
|      | 43.3.30 | UART 78       | 16 Transmit Length Register (UARTx_TL7816) | 1095 |
| 43.4 | Functio | nal descripti | ion                                        | 1095 |
|      | 43.4.1  | Transmitte    | er                                         | 1095 |
|      |         | 43.4.1.1      | Transmitter character length               | 1096 |
|      |         | 43.4.1.2      | Transmission bit order                     | 1096 |
|      |         | 43.4.1.3      | Character transmission                     | 1097 |
|      |         | 43.4.1.4      | Transmitting break characters              | 1098 |
|      |         | 43.4.1.5      | Idle characters                            | 1099 |
|      |         | 43.4.1.6      | Hardware flow control                      | 1099 |
|      |         | 43.4.1.7      | Transceiver driver enable                  | 1100 |
|      | 43.4.2  | Receiver      |                                            | 1101 |
|      |         | 43.4.2.1      | Receiver character length                  | 1102 |
|      |         | 43.4.2.2      | Receiver bit ordering                      | 1102 |
|      |         | 43.4.2.3      | Character reception                        | 1103 |
|      |         | 43.4.2.4      | Data sampling                              | 1103 |
|      |         | 43.4.2.5      | Framing errors                             | 1108 |
|      |         | 43.4.2.6      | Receiving break characters                 | 1109 |
|      |         | 43.4.2.7      | Hardware flow control                      | 1109 |
|      |         | 43.4.2.8      | Baud rate tolerance                        | 1110 |
|      |         | 43.4.2.9      | Receiver wakeup                            | 1112 |
|      | 43.4.3  | Baud rate     | generation                                 | 1114 |
|      | 43.4.4  | Data form     | nat (non ISO-7816)                         | 1116 |
|      |         | 43.4.4.1      | Eight-bit configuration                    | 1116 |
|      |         | 43.4.4.2      | Nine-bit configuration                     | 1117 |
|      |         | 43.4.4.3      | Timing examples                            | 1118 |
|      | 43.4.5  | Single-wir    | re operation                               | 1119 |
|      |         |               |                                            |      |

| Section Number |         | ımber         | Title                                         | Page |
|----------------|---------|---------------|-----------------------------------------------|------|
|                | 43.4.6  | Loop oper     | ration                                        | 1120 |
|                | 43.4.7  | ISO-7816      | / smartcard support                           | 1120 |
|                |         | 43.4.7.1      | Initial characters                            | 1121 |
|                |         | 43.4.7.2      | Protocol T = 0                                | 1122 |
|                |         | 43.4.7.3      | Protocol T = 1                                | 1122 |
|                |         | 43.4.7.4      | Wait time and guard time parameters           | 1123 |
|                |         | 43.4.7.5      | Baud rate generation                          | 1124 |
|                |         | 43.4.7.6      | UART restrictions in ISO-7816 operation       | 1125 |
| 43.5           | Reset   |               |                                               | 1125 |
| 43.6           | System  | level interru | upt sources                                   | 1125 |
|                | 43.6.1  | RXEDGII       | F description                                 | 1126 |
|                |         | 43.6.1.1      | RxD edge detect sensitivity                   | 1126 |
|                |         | 43.6.1.2      | Clearing RXEDGIF interrupt request            | 1126 |
|                |         | 43.6.1.3      | Exit from low-power modes                     | 1126 |
| 43.7           | DMA o   | peration      |                                               | 1127 |
| 43.8           | Applica | 1127          |                                               |      |
|                | 43.8.1  | Transmit/     | receive data buffer operation                 | 1127 |
|                | 43.8.2  | ISO-7816      | initialization sequence                       | 1128 |
|                |         | 43.8.2.1      | Transmission procedure for (C7816[TTYPE] = 0) | 1129 |
|                |         | 43.8.2.2      | Transmission procedure for (C7816[TTYPE] = 1) | 1129 |
|                | 43.8.3  | Initializati  | ion sequence (non ISO-7816)                   | 1130 |
|                | 43.8.4  | Overrun (     | OR) flag implications                         | 1131 |
|                |         | 43.8.4.1      | Overrun operation                             | 1131 |
|                | 43.8.5  | Overrun N     | NACK considerations                           | 1132 |
|                | 43.8.6  | Match add     | dress registers                               | 1133 |
|                | 43.8.7  | Modem fe      | eature                                        | 1133 |
|                |         | 43.8.7.1      | Ready-to-receive using RTS                    | 1133 |
|                |         | 43.8.7.2      | Transceiver driver enable using RTS           | 1134 |
|                | 43.8.8  | Clearing 7    | 7816 wait timer (WT, BWT, CWT) interrupts     | 1134 |
|                |         |               | MCF51JF128 Reference Manual, Rev. 2, 03/2011  |      |

| Section Number |          | umber Title                                                                        | Page |
|----------------|----------|------------------------------------------------------------------------------------|------|
|                | 43.8.9   | Legacy and reverse compatibility considerations                                    | 1135 |
|                | lı       | Chapter 44<br>Integrated Interchip Sound (I2S) / Synchronous Audio Interface (SAI) |      |
| 44.1           | Introduc | ction                                                                              | 1137 |
|                | 44.1.1   | Features                                                                           | 1137 |
|                | 44.1.2   | Modes of Operation                                                                 | 1137 |
|                |          | 44.1.2.1 Run Mode                                                                  | 1137 |
|                |          | 44.1.2.2 Stop Modes                                                                | 1137 |
|                |          | 44.1.2.3 Low-Leakage Modes                                                         | 1138 |
|                |          | 44.1.2.4 Debug Mode                                                                | 1138 |
| 44.2           | External | al signals                                                                         | 1138 |
| 44.3           | Memory   | y Map and Registers                                                                | 1139 |
|                | 44.3.1   | SAI Transmit Control Register (I2Sx_TCSR)                                          | 1140 |
|                | 44.3.2   | SAI Transmit Configuration 1 Register (I2Sx_TCR1)                                  | 1143 |
|                | 44.3.3   | SAI Transmit Configuration 2 Register (I2Sx_TCR2)                                  | 1144 |
|                | 44.3.4   | SAI Transmit Configuration 3 Register (I2Sx_TCR3)                                  | 1145 |
|                | 44.3.5   | SAI Transmit Configuration 4 Register (I2Sx_TCR4)                                  | 1146 |
|                | 44.3.6   | SAI Transmit Configuration 5 Register (I2Sx_TCR5)                                  | 1147 |
|                | 44.3.7   | SAI Transmit Data Register (I2Sx_TDR)                                              | 1148 |
|                | 44.3.8   | SAI Transmit FIFO Register (I2Sx_TFR)                                              | 1148 |
|                | 44.3.9   | SAI Transmit Mask Register (I2Sx_TMR)                                              | 1149 |
|                | 44.3.10  | SAI Receive Control Register (I2Sx_RCSR)                                           | 1150 |
|                | 44.3.11  | SAI Receive Configuration 1 Register (I2Sx_RCR1)                                   | 1153 |
|                | 44.3.12  | SAI Receive Configuration 2 Register (I2Sx_RCR2)                                   | 1153 |
|                | 44.3.13  | SAI Receive Configuration 3 Register (I2Sx_RCR3)                                   | 1154 |
|                | 44.3.14  | SAI Receive Configuration 4 Register (I2Sx_RCR4)                                   | 1155 |
|                | 44.3.15  | SAI Receive Configuration 5 Register (I2Sx_RCR5)                                   | 1156 |
|                | 44.3.16  | SAI Receive Data Register (I2Sx_RDR)                                               | 1157 |
|                | 44.3.17  | SAI Receive FIFO Register (I2Sx_RFR)                                               | 1158 |
|                |          |                                                                                    |      |

| tion Nu | ımber        | Title                            | Page |
|---------|--------------|----------------------------------|------|
| 44.3.18 | SAI Recei    | ive Mask Register (I2Sx_RMR)     | 1158 |
| 44.3.19 | SAI MCL      | K Control Register (I2Sx_MCR)    | 1159 |
| 44.3.20 | MCLK Di      | ivide Register (I2Sx_MDR)        | 1160 |
| Functio | nal descript | tion                             | 1161 |
| 44.4.1  | SAI clock    | cing                             | 1161 |
|         | 44.4.1.1     | Audio Master Clock               | 1161 |
|         | 44.4.1.2     | Bit Clock                        | 1161 |
|         | 44.4.1.3     | Bus Clock                        | 1162 |
| 44.4.2  | SAI resets   | S                                | 1162 |
|         | 44.4.2.1     | Software reset                   | 1162 |
|         | 44.4.2.2     | FIFO reset.                      | 1162 |
| 44.4.3  | Synchrono    | ous Modes                        | 1163 |
|         | 44.4.3.1     | Synchronous Mode                 | 1163 |
|         | 44.4.3.2     | Multiple SAI Synchronous Mode    | 1163 |
| 44.4.4  | Frame syn    | nc configuration                 | 1164 |
| 44.4.5  | Data FIFO    | D                                | 1164 |
|         | 44.4.5.1     | Data alignment                   | 1164 |
|         | 44.4.5.2     | FIFO pointers                    | 1165 |
| 44.4.6  | Word mas     | sk register                      | 1166 |
| 44.4.7  | Interrupts   | and DMA requests                 | 1166 |
|         | 44.4.7.1     | FIFO data ready flag             | 1166 |
|         | 44.4.7.2     | FIFO warning flag                | 1167 |
|         | 44.4.7.3     | FIFO error flag                  | 1167 |
|         | 44.4.7.4     | Sync error flag                  | 1167 |
|         | 44.4.7.5     | Word start flag                  | 1168 |
|         |              | Chapter 45<br>Rapid GPIO (RGPIO) |      |
| Introdu | ction        | - F                              | 1169 |
| 45.1.1  | Overview     |                                  | 1169 |

| Sect | tion Nu    | imber Title                                                   | Page |  |
|------|------------|---------------------------------------------------------------|------|--|
|      | 45.1.2     | Features                                                      | 1171 |  |
|      | 45.1.3     | Modes of Operation                                            | 1172 |  |
| 45.2 | External   | l Signal Description                                          | 1172 |  |
|      | 45.2.1     | Overview                                                      | 1172 |  |
|      | 45.2.2     | Detailed Signal Descriptions.                                 | 1173 |  |
| 45.3 | Memory     | Map and Registers                                             | 1173 |  |
|      | 45.3.1     | RGPIO Data Direction Register (RGPIO_DIR)                     | 1174 |  |
|      | 45.3.2     | RGPIO Data Direction Register (RGPIO_DIR)                     | 1177 |  |
|      | 45.3.3     | RGPIO Data Register (RGPIO_DATA)                              | 1175 |  |
|      | 45.3.4     | RGPIO Pin Enable Register (RGPIO_ENB)                         | 1175 |  |
|      | 45.3.5     | RGPIO Clear Data Register (RGPIO_CLR)                         | 1176 |  |
|      | 45.3.6     | RGPIO Set Data Register (RGPIO_SET)                           | 1177 |  |
|      | 45.3.7     | RGPIO Toggle Data Register (RGPIO_TOG)                        | 1178 |  |
|      | 45.3.8     | RGPIO Data Direction Register (RGPIO_DIR)                     | 1178 |  |
| 45.4 | Function   | nal Description                                               | 1179 |  |
| 45.5 | Initializa | ation Information                                             | 1179 |  |
| 45.6 | Applicat   | tion Information                                              | 1179 |  |
|      | 45.6.1     | Application 1: Simple Square-Wave Generation                  | 1179 |  |
|      | 45.6.2     | Application 2: 16-bit Message Transmission using SPI Protocol | 1180 |  |
|      |            | Chapter 46<br>Enhanced GPIO (EGPIO)                           |      |  |
| 46.1 | Introduc   | ction                                                         | 1183 |  |
| 46.2 | Overvie    | W                                                             | 1184 |  |
|      | 46.2.1     | Features                                                      | 1184 |  |
|      | 46.2.2     | Modes of operation                                            | 1185 |  |
|      |            | 46.2.2.1 Operation in wait mode                               | 1185 |  |
|      |            | 46.2.2.2 Operation in stop mode                               | 1186 |  |
|      |            | 46.2.2.3 Operation in active background mode                  | 1186 |  |

| Sect | ection Number |                     | Title                                              | Page |
|------|---------------|---------------------|----------------------------------------------------|------|
| 46.3 | Memory        | / Map and Registers |                                                    |      |
|      | 46.3.1        | Port Pullin         | ng Enable Register (PCTLx_PUE)                     | 1190 |
|      | 46.3.2        | Port Pullu          | p/Pulldown Select Register (PCTLx_PUS)             | 1191 |
|      | 46.3.3        | Port Drive          | e Strength Enable Register (PCTLx_DS)              | 1191 |
|      | 46.3.4        | Port Slew           | Rate Enable Register (PCTLx_SRE)                   | 1192 |
|      | 46.3.5        | Port Passi          | ive Filter Enable Register (PCTLx_PFE)             | 1192 |
|      | 46.3.6        | Port Intern         | rupt Control Register (PCTLx_IC)                   | 1193 |
|      | 46.3.7        | Port Intern         | rupt Pin Enable Register (PCTLx_IPE)               | 1194 |
|      | 46.3.8        | Port Intern         | rupt Flag Register (PCTLx_IF)                      | 1195 |
|      | 46.3.9        | Interrupt l         | Edge Select Register (PCTLx_IES)                   | 1196 |
|      | 46.3.10       | Port Digit          | tal Filter Enable Register (PCTLx_DFE)             | 1196 |
|      | 46.3.11       | Port Digit          | tal Filter Control Register (PCTLx_DFC)            | 1197 |
| 46.4 | Function      | 1198                |                                                    |      |
|      | 46.4.1        | Port data           | logic                                              | 1198 |
|      |               | 46.4.1.1            | Operation when EGPIO controls pin                  | 1199 |
|      |               | 46.4.1.2            | Operation when another on-chip module controls pin | 1200 |
|      |               | 46.4.1.3            | Pin value register                                 | 1200 |
|      | 46.4.2        | Port contr          | rol                                                | 1200 |
|      | 46.4.3        | Pin interru         | upt                                                | 1201 |
|      |               | 46.4.3.1            | Edge only sensitivity                              | 1202 |
|      |               | 46.4.3.2            | Edge and level sensitivity                         | 1203 |
|      |               | 46.4.3.3            | Control of pullup/pulldown resistors               | 1203 |
|      |               | 46.4.3.4            | Asynchronous interrupt in stop mode                | 1204 |
|      |               | 46.4.3.5            | Pin interrupt initialization.                      | 1204 |
|      | 46.4.4        | Digital fil         | ters                                               | 1204 |
|      |               | 46.4.4.1            | Initialization of digital filters                  | 1205 |
| 46.5 | Reset         |                     |                                                    | 1206 |

| Section Number |          |                          | Title                                    | Page |
|----------------|----------|--------------------------|------------------------------------------|------|
| 48.7           | Functio  | Functional descriptions. |                                          |      |
|                | 48.7.1   | Capacitan                | ice measurement                          | 1231 |
|                |          | 48.7.1.1                 | TSI electrode oscillator                 | 1232 |
|                |          | 48.7.1.2                 | Electrode oscillator and counter control | 1233 |
|                |          | 48.7.1.3                 | TSI reference oscillator                 |      |
|                | 48.7.2   | TSI measi                | urement result                           | 1234 |
|                | 48.7.3   | Electrode                | scan unit                                | 1235 |
|                |          | 48.7.3.1                 | Active electrodes.                       | 1235 |
|                |          | 48.7.3.2                 | Scan trigger                             | 1236 |
|                |          | 48.7.3.3                 | Software trigger mode                    | 1236 |
|                |          | 48.7.3.4                 | Periodic scan control                    | 1236 |
|                | 48.7.4   | Touch det                | tection unit                             | 1238 |
|                |          | 48.7.4.1                 | Capacitance change threshold             | 1239 |
|                |          | 48.7.4.2                 | Error interrupt                          | 1239 |
| 48.8           | Applica  | ation inform             | nation                                   | 1240 |
|                | 48.8.1   | TSI modu                 | ile sensitivity                          | 1240 |
|                |          |                          | Chapter 49<br>External Interrupt (IRQ)   |      |
| 49.1           | Introdu  | ction                    |                                          | 1241 |
|                | 49.1.1   | Features                 |                                          | 1241 |
|                | 49.1.2   | Modes of                 | Operation                                | 1241 |
|                | 49.1.3   | Block Dia                | agram                                    |      |
| 49.2           | Signal l | Description.             |                                          |      |
|                | 49.2.1   | Detailed S               | Signal Descriptions                      |      |
| 49.3           | Memor    | y Map and l              | Register Description                     |      |
|                | 49.3.1   | Interrupt s              | status and control register (IRQ_SC)     | 1243 |
| 49.4           | Functio  | onal Descrip             | tion                                     | 1244 |
|                | 49.4.1   | External I               | Interrupt Pin                            | 1244 |
|                | 49.4.2   | IRQ Edge                 | e Select                                 | 1244 |
|                |          |                          |                                          |      |

| Sect | ion Nu   | mber Title                                                       | Page |
|------|----------|------------------------------------------------------------------|------|
|      | 49.4.3   | IRQ Sensitivity                                                  | 1244 |
|      | 49.4.4   | IRQ Interrupts                                                   | 1245 |
|      | 49.4.5   | 1245                                                             |      |
|      | 49.4.6   | Exit from Low-Power Modes.                                       | 1246 |
|      |          | 49.4.6.1 Wait                                                    | 1246 |
|      |          | 49.4.6.2 Stop                                                    | 1246 |
| 49.5 | Resets   |                                                                  | 1246 |
| 49.6 | Interrup | ts                                                               | 1246 |
|      |          | Chapter 50<br>Debug                                              |      |
| 50.1 | Introduc | tion                                                             | 1249 |
|      | 50.1.1   | Overview                                                         | 1250 |
|      | 50.1.2   | Features                                                         | 1251 |
|      | 50.1.3   | Modes of Operation                                               | 1252 |
| 50.2 | External | Signal Descriptions                                              | 1254 |
| 50.3 | Memory   | Map and Register Descriptions                                    | 1255 |
|      | 50.3.1   | Configuration/Status Register (CSR)                              | 1257 |
|      | 50.3.2   | Extended Configuration/Status Register (XCSR)                    | 1260 |
|      | 50.3.3   | Configuration/Status Register 2 (CSR2)                           | 1263 |
|      | 50.3.4   | Configuration/Status Register 3 (CSR3)                           | 1267 |
|      | 50.3.5   | Debug Control Register (DBGCR) and Debug Status Register (DBGSR) | 1269 |
|      | 50.3.6   | BDM Address Attribute Register (BAAR)                            | 1271 |
|      | 50.3.7   | Address Attribute Trigger Register (AATR)                        | 1272 |
|      | 50.3.8   | Trigger Definition Register (TDR)                                | 1273 |
|      | 50.3.9   | Program Counter Breakpoint/Mask Registers (PBR0-3, PBMR)         | 1277 |
|      | 50.3.10  | Address Breakpoint Registers (ABLR, ABHR)                        | 1279 |
|      | 50.3.11  | Data Breakpoint and Mask Registers (DBR, DBMR)                   | 1281 |
|      | 50.3.12  | Resulting Set of Possible Trigger Combinations                   | 1282 |
|      | 50.3.13  | PST Buffer (PSTB)                                                | 1282 |

| Sec  | Section Number         |            | Title                                              | Page |
|------|------------------------|------------|----------------------------------------------------|------|
| 50.4 | Functional Description |            | otion                                              | 1284 |
|      | 50.4.1                 | Backgroun  | nd Debug Mode (BDM)                                | 1284 |
|      |                        | 50.4.1.1   | CPU Halt                                           | 1285 |
|      |                        | 50.4.1.2   | Background Debug Serial Interface Controller (BDC) | 1287 |
|      |                        | 50.4.1.3   | BDM Communication Details                          | 1288 |
|      |                        | 50.4.1.4   | BDM Command Set Descriptions                       | 1291 |
|      |                        | 50.4.1.5   | BDM Command Set Summary                            | 1293 |
|      |                        | 50.4.1.6   | Serial Interface Hardware Handshake Protocol       | 1310 |
|      |                        | 50.4.1.7   | Hardware Handshake Abort Procedure                 | 1313 |
|      | 50.4.2                 | Real-Time  | e Debug Support                                    | 1316 |
|      | 50.4.3                 | Trace Sup  | pport                                              | 1316 |
|      |                        | 50.4.3.1   | Begin Execution of Taken Branch (PST = 0x05)       | 1319 |
|      |                        | 50.4.3.2   | PST Trace Buffer (PSTB) Entry Format               | 1320 |
|      |                        | 50.4.3.3   | PST/DDATA Example                                  | 1321 |
|      |                        | 50.4.3.4   | Processor Status, Debug Data Definition            | 1322 |
|      | 50.4.4                 | Freescale- | -Recommended BDM Pinout                            | 1328 |

62

# Chapter 1 About This Document

#### 1.1 Overview

## 1.1.1 Purpose

This document describes the features, architecture, and programming model of Freescale's MCF51JF32, MCF51JF64, and MCF51JF128 microcontrollers.

#### 1.1.2 Audience

This document is primarily for system architects and software application developers who are using or considering using these microcontrollers in a system.

#### 1.2 Conventions

### 1.2.1 Numbering systems

The following suffixes identify different numbering systems:

| This suffix | Identifies a                                                                                                                                                       |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| b           | Binary number. For example, the binary equivalent of the number 5 is written 101b. (In some cases, binary numbers are shown with the prefix 0b.)                   |
| d           | Decimal number. Decimal numbers are followed by this suffix only when the possibility of confusion exists. In general, decimal numbers are shown without a suffix. |
| h           | Hexadecimal number. For example, the hexadecimal equivalent of the number 60 is written 3Ch. (In some cases, hexadecimal numbers are shown with the prefix 0x.)    |

## 1.2.2 Typographic notation

The following typographic notation is used throughout this document:

| Example              | Description                                                                                                                                                                                                                                                                                                               |
|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| placeholder, x       | Items in italics are placeholders for information that you provide. Italicized text is also used for the titles of publications and for emphasis. Plain lowercase letters are also used as placeholders for single letters and numbers.                                                                                   |
| code                 | Fixed-width type indicates text that must be typed exactly as shown. It is used for instruction mnemonics, directives, symbols, subcommands, parameters, and operators. Fixed-width type is also used for example code. Instruction mnemonics and directives in text and tables are shown in all caps (for example, BSR). |
| SR[SCM]              | A mnemonic in brackets represents a named field in a register. This example refers to the Scaling Mode (SCM) field in the Status Register (SR).                                                                                                                                                                           |
| REVNO[6:4], XAD[7:0] | Numbers in brackets and separated by a colon represent either:  • A subset of a register's named field                                                                                                                                                                                                                    |
|                      | For example, REVNO[6:4] refers to bits 6–4 that are part of the COREREV field that occupies bits 6–0 of the REVNO register.                                                                                                                                                                                               |
|                      | A continuous range of individual signals of a bus                                                                                                                                                                                                                                                                         |
|                      | For example, XAD[7:0] refers to signals 7–0 of the XAD bus.                                                                                                                                                                                                                                                               |

## 1.2.3 Special terms

The following terms have special meanings:

| Term       | Meaning                                                                                                                                                                                                                                     |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| asserted   | Refers to the state of a signal as follows:  • An active-high signal is asserted when high (1).  • An active-low signal is asserted when low (0).                                                                                           |
| deasserted | Refers to the state of a signal as follows:  • An active-high signal is deasserted when low (0).  • An active-low signal is deasserted when high (1).  In some cases, deasserted signals are described as negated.                          |
| reserved   | Refers to a memory space or programming setting.     Do not modify the default value of a reserved programming setting, such as the reset value of a reserved register bitfield.     Consider undefined locations in memory to be reserved. |

## 1.2.4 Register reset

Information provided about every register includes each bit's value upon a reset event. The documented devices support multiple types of reset. The specific reset type that effects particular reset values can vary by module, by register within a module's programming model, and even by bit within a register.

For details about the reset type(s) affecting a module's registers, refer to the module's Chip Configuration information and register descriptions. When a register's details specify a reset type, in some cases other reset types do not affect the register.

For information about the various reset types, refer to the Reset details.

When a register's description does not specify a reset type, the reset type is Chip Reset (including Early Chip Reset).

Conventions

# Chapter 2 Introduction

#### 2.1 ColdFire+ Portfolio Introduction

Freescale's ColdFire+ 32-bit microcontrollers are built on the Version 1 (V1) ColdFire® core and enabled by innovative 90 nm thin film storage (TFS) flash process technology with FlexMemory. The ColdFire+ portfolio consists of six families featuring ultra-low power capabilities in small footprint solutions with embedded flash memory that scales from 32 KB to 128 KB. The families offer a rich combination of additive peripherals including USB, high performance mixed signal capabilities, hardware encryption, an innovative touch sensing interface (TSI), and more. These key features make ColdFire+ microcontrollers ideal for portable handheld devices, wireless nodes, peripherals that require device authentication, building control security pads, and advanced remote control devices.

The feature superset of all six pin- and software-compatible families includes:

- Innovative FlexMemory enabling up to 2 KB of enhanced EEPROM or additional 32 KB of flash
- 10 flexible low power modes, ideal for extending battery life
- 16-bit or 12-bit ADC and 12-bit DAC to provide flexible and powerful mixed signal capabilities
- Cryptographic Acceleration Unit (CAU) and Random Number Generator (RNGB) for secure communications
- Integrated capacitive touch sensing support: low power touch sensing interface (TSI)
- Integrated USB 2.0 Full-Speed Device/Host/OTG Controller supporting connection via USB and battery charging
- Serial audio interface (SAI) providing a direct interface to codecs and to Inter-IC Sound (I2S) audio devices
- Wide operating voltage range from 1.71 V to 3.6 V with flash programmability and full analog functionality over entire range
- Various timers that support general purpose, PWM, and motor control functions
- GPIO with pin interrupt functionality

#### MCF51JF128 Block Diagram

- Small footprint packages designed for space-constrained applications
- Rich suite of complimentary runtime software including Freescale's MQX RTOS, a full set of USB class drivers, a cryptographic library, a motor control library, and much more

The ColdFire+ device families are the MCF51QU, MCF51QH, MCF51QF, MCF51QM, MCF51JU, and MCF51JF.



Figure 2-1. ColdFire+ Portfolio

## 2.2 MCF51JF128 Block Diagram

The block diagram shows the feature categories of all ColdFire+ device families. Within each category, the diagram shows the superset of modules and number of module instances on the 64-pin members of the MCF51JF family.

68



Figure 2-2. MCF51JF128 (64-pin) Block Diagram

## 2.3 MCF51JF Feature Summary

The following table summarizes the features integrated on all MCF51JF devices. For MCF51JF device features that vary by package, refer to MCF51JF Features by Package.

**Table 2-1. Feature Summary** 

| Feature                  | Details         |
|--------------------------|-----------------|
| Hardware Characteristics |                 |
| Voltage range            | 1.71 V to 3.6 V |

Table continues on the next page...

#### MCF51JF Feature Summary

Table 2-1. Feature Summary (continued)

| Feature                                       | Details                                                                                                                                                                                |  |
|-----------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Flash write voltage                           | Down to 1.71 V                                                                                                                                                                         |  |
| Packages                                      | 32-pin QFN (5 x 5 mm <sup>2</sup> )                                                                                                                                                    |  |
|                                               | 44-pin Laminate QFN (5 x 5 mm <sup>2</sup> )                                                                                                                                           |  |
|                                               | 48-pin LQFP (7 x 7 mm <sup>2</sup> )                                                                                                                                                   |  |
|                                               | 64-pin Laminate QFN (9 x 9 mm <sup>2</sup> )                                                                                                                                           |  |
|                                               | 64-pin LQFP (10 x 10 mm <sup>2</sup> )                                                                                                                                                 |  |
| Temperature range, ambient (T <sub>A</sub> )  | -40°C to 105°C (V temperature)                                                                                                                                                         |  |
| Temperature range, junction (T <sub>J</sub> ) | -40°C to 125°C                                                                                                                                                                         |  |
|                                               | Core and System                                                                                                                                                                        |  |
| Central processing unit (CPU)                 | High-performance Version 1 (V1) ColdFire core with EMAC and DIV hardware acceleration                                                                                                  |  |
|                                               | Implements instruction set revision C (ISA_C)                                                                                                                                          |  |
| Maximum CPU frequency                         | 50 MHz                                                                                                                                                                                 |  |
| Dhrystone 2.1 performance                     | 1.10 DMIPS per MHz performance when executing from internal RAM                                                                                                                        |  |
|                                               | 0.99 DMIPS per MHz when executing from flash                                                                                                                                           |  |
| Interrupt controller (INTC)                   | Supports 7 priority levels and software interrupt acknowledges                                                                                                                         |  |
| Direct memory access (DMA) controller         | Four independently programmable channels provide the means to transfer data directly between system memory and I/O peripherals                                                         |  |
| Low-leakage wakeup unit (LLWU)                | 16 external wakeup pins with digital glitch filter                                                                                                                                     |  |
|                                               | 4 internal wakeup sources                                                                                                                                                              |  |
|                                               | RESET pin can be treated as reset wakeup in low leakage (LLS and VLLS) modes                                                                                                           |  |
| Debug                                         | Integrated ColdFire DEBUG_Rev_B+ interface with single wire BDM                                                                                                                        |  |
|                                               | Real-time debug support, with six hardware breakpoints that can be configured to halt the processor or generate debug interrupt                                                        |  |
|                                               | Capture of compressed processor status and debug data into trace buffer                                                                                                                |  |
|                                               | On-chip trace buffer that provides programmable start/stop recording conditions                                                                                                        |  |
| Power Management                              |                                                                                                                                                                                        |  |
| Power management controller (PMC)             | Various stop, wait, and run modes to enable low power applications:  • Run and stop regulation modes to enable low power MCU operation  • Several low power and low leakage stop modes |  |
|                                               | Peripheral clock enable register can disable clocks to unused modules, further reducing current consumption                                                                            |  |
|                                               | Low voltage warning and detect with selectable trip points                                                                                                                             |  |
| 3.3 V voltage regulator (VREG)                | 5 V input, 3.3 V output, up to 120 mA                                                                                                                                                  |  |
| Memory and Memory Interfaces                  |                                                                                                                                                                                        |  |
| Total flash memory                            | Up to 160 KB (128 KB + 32 KB)                                                                                                                                                          |  |
| Program flash                                 | Up to 128 KB                                                                                                                                                                           |  |
| L                                             |                                                                                                                                                                                        |  |

Table continues on the next page...

**Table 2-1. Feature Summary (continued)** 

| Feature                                                               | Details                                                                                                                      |
|-----------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|
| FlexNVM                                                               | Up to 32 KB                                                                                                                  |
| FlexRAM                                                               | Up to 2 KB                                                                                                                   |
| RAM                                                                   | Up to 32 KB                                                                                                                  |
| Total random access memory (RAM)                                      | Up to 34 KB (32 KB + 2 KB)                                                                                                   |
| FlexMemory (FlexNVM plus FlexRAM) configuration examples <sup>1</sup> | Example 1: 32 KB additional program flash, no data flash or EEPROM, 2 KB additional RAM                                      |
|                                                                       | Example 2: 32 KB data flash memory, 2 KB additional RAM                                                                      |
|                                                                       | Example 3: Up to 2 KB high-endurance, nonvolatile, enhanced EEPROM                                                           |
|                                                                       | Example 4: Partial data flash and EEPROM                                                                                     |
| Low-leakage standby memory                                            | Full RAM in LLS and VLLS3 power modes, 1 KB RAM or 8KB RAM in VLLS2 mode                                                     |
|                                                                       | 32-byte register file in all power modes, including VLLS1 mode                                                               |
| External bus interface (Mini-FlexBus)                                 | Supports glueless connections to external memories and peripherals                                                           |
|                                                                       | Up to 20 address and 8 data lines (non-muxed mode)                                                                           |
|                                                                       | Up to 20 address lines and 16 data lines (muxed mode)                                                                        |
|                                                                       | 2 chip selects                                                                                                               |
| Serial programming interface (EzPort)                                 | Supports flash in-system programming                                                                                         |
|                                                                       | Clocks                                                                                                                       |
| External crystal oscillator or resonator                              | Low range, low power, or full-swing: 32 kHz to 40 kHz                                                                        |
|                                                                       | Medium range, low power, or full-swing: 2 MHz to 8 MHz                                                                       |
|                                                                       | High range, low power, or full-swing: 8 MHz to 32 MHz                                                                        |
| External clock                                                        | DC to 50 MHz                                                                                                                 |
| Internal clock references                                             | Two internal trimmable reference clocks  • 32 kHz  • 2 MHz                                                                   |
|                                                                       | Internal 1 kHz low power oscillator                                                                                          |
| Phase-locked loop (PLL)                                               | Up to 100 MHz VCO                                                                                                            |
| Frequency-locked loop (FLL)                                           | 1                                                                                                                            |
|                                                                       | System Security and Integrity                                                                                                |
| Random number generator (RNGB)                                        | Supports both true (TRNG) and pseudo-random number (PRNG) generators                                                         |
| Cryptographic Acceleration Unit (CAU)                                 | Provides hardware encryption for:  • DES  • AES-128, AES-192, AES-256  • SHA-1 and SHA-256  • MD5                            |
|                                                                       | Enables more complex algorithms such as 3DES with software encryption libraries that use the preceding basic security blocks |

Table continues on the next page...

#### MCF51JF Feature Summary

Table 2-1. Feature Summary (continued)

| Feature                                                               | Details                                                                                                        |  |
|-----------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------|--|
| Cyclic redundancy check (CRC) module                                  | User configurable 16/32-bit hardware CRC generator circuit with programmable generator polynomial              |  |
|                                                                       | Supports checksumming of any memory image                                                                      |  |
| COP watchdog module                                                   | 1                                                                                                              |  |
| Memory                                                                | Flash security features and block protection                                                                   |  |
| Unique chip identification (ID) number                                | 128 bits wide                                                                                                  |  |
| Analog                                                                |                                                                                                                |  |
| Analog-to-digital converter (ADC): 12-bit                             | 1 successive approximation (SAR) ADC                                                                           |  |
|                                                                       | Up to 17 single-ended channels                                                                                 |  |
| 12-bit digital-to-analog converter (DAC)                              | 1                                                                                                              |  |
| High-speed comparator (CMP)                                           | 1 with 6-bit DAC                                                                                               |  |
| Programmable voltage reference (VREF)                                 | 1                                                                                                              |  |
| Timers                                                                |                                                                                                                |  |
| Programmable delay block (PDB)                                        | 1 ADC channel (with 2 triggers), 1 DAC channel, and 1 pulse-out to CMP                                         |  |
| 16-bit flexible timer (FTM0)                                          | Up to 2 channels, with quadrature decoder                                                                      |  |
| 16-bit flexible timer (FTM1)                                          | 6 channels                                                                                                     |  |
| 16-bit modulo timer (MTIM)                                            | 1                                                                                                              |  |
| Carrier modulator transmitter (CMT)                                   | 1                                                                                                              |  |
| Low-power timers (LPTMR0 and LPTMR1)                                  | Support Time of Day function with an external 32.768 kHz low power crystal oscillator                          |  |
|                                                                       | 1-channel, 16-bit pulse counter or periodic interrupt                                                          |  |
|                                                                       | Communication Interfaces                                                                                       |  |
| Universal Serial Bus (USB) 2.0 On-the-Go                              | Low-speed, full-speed                                                                                          |  |
| (OTG) controller <sup>2</sup>                                         | Host, device, and OTG support                                                                                  |  |
| USB device charger detect (DCD)                                       | Compliant with USB Battery Charging Specification, Revision 1.1, and supporting programmable timing parameters |  |
| 16-bit serial peripheral interface (SPI0)                             | 1 with independent 8-byte transmit and receive FIFOs                                                           |  |
| 16-bit serial peripheral interface (SPI1)                             | 1 (without FIFO)                                                                                               |  |
| Inter-Integrated Circuit (I <sup>2</sup> C)                           | Up to 4                                                                                                        |  |
| Universal asynchronous receivers/                                     | Serial communications interface (SCI)                                                                          |  |
| transmitters (UART0 and UART1)                                        | Support for ISO 7816 protocol for interfacing with smart cards                                                 |  |
|                                                                       | Hardware flow control                                                                                          |  |
|                                                                       | Higher baud rates (CPU clock)                                                                                  |  |
|                                                                       | Independent data FIFO for transmit and receive                                                                 |  |
| Inter-IC Sound (I <sup>2</sup> S) / Synchronous Audio Interface (SAI) | 1                                                                                                              |  |
|                                                                       | Human-Machine Interface (HMI)                                                                                  |  |

Table continues on the next page...

Table 2-1. Feature Summary (continued)

| Feature                                                 | Details                                                                                                                                       |
|---------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| Rapid general-purpose input/output (RGPIO) <sup>3</sup> | Up to 16 bits of high-speed GPIO functionality connected to the processor's local 32-bit bus with faster set, clear, and toggle functionality |
| Enhanced general-purpose input/output                   | Up to 48                                                                                                                                      |
| (EGPIO)                                                 | Pin interrupt / DMA request capability                                                                                                        |
|                                                         | Up to 16 EGPIOs (PORTB and PORTC) with digital glitch filter                                                                                  |
|                                                         | Hysteresis and configurable pullup/pulldown device on all input pins                                                                          |
|                                                         | Configurable slew rate and drive strength on all output pins                                                                                  |
| Touch sensing inputs (TSI)                              | Up to 16                                                                                                                                      |
| Interrupt Request Pin (IRQ)                             | Rising or falling edge selection                                                                                                              |
|                                                         | Level sensitivity option                                                                                                                      |
|                                                         | Configurable internal pullup/pulldown                                                                                                         |
|                                                         | Defined as a nonmaskable interrupt request                                                                                                    |

- 1. FlexNVM can be used as program flash, as data flash, or, in conjunction with FlexRAM, as high-endurance EEPROM or a combination of data flash and EEPROM.
- 2. The 3.3 V voltage regulator on all ColdFire+ devices powers the on-chip USB transceiver. The regulator input supports the 5 V supply typically provided by USB VBUS power.
- 3. Shared with EGPIO pins

## 2.4 MCF51JF Features by Package

The following summary identifies aspects of MCF51JF features that vary by package.

Table 2-2. Feature Summary by Package

| Device                                | JF32       | JF32                    | JF64        | JF64    | JF128            | JF128                           |
|---------------------------------------|------------|-------------------------|-------------|---------|------------------|---------------------------------|
| Package type and number of pins       | 32-pin QFN | 44-pin QFN <sup>1</sup> | 48-pin LQFP | 44-pir  | qFN <sup>1</sup> | 64-pin<br>LQFP/QFN <sup>1</sup> |
| Package dimensions (mm x mm)          | 5x5        | 5x5                     | 7x7         | 5x5 10x |                  | 10x10/9x9                       |
|                                       | (          | Core Processo           | r           |         |                  |                                 |
| V1 ColdFire core with EMAC and DIV    |            |                         | Yes         |         |                  |                                 |
| Maximum CPU frequency (MHz)           |            |                         | 50          |         |                  |                                 |
|                                       | Memory     | and Memory II           | nterfaces   |         |                  |                                 |
| Total flash memory (KB)               | Up to 48   |                         | Up to       | 96      | Up               | to 160                          |
| Flash (KB)                            | 32         |                         | 64          |         |                  | 128                             |
| FlexNVM (KB)                          | 16         |                         |             | 3       | 2                |                                 |
| FlexRAM (KB)                          | Up to 1    |                         |             | Up      | to 2             |                                 |
| RAM (KB)                              | 8          |                         | 16          |         |                  | 32                              |
| External bus interface (Mini-FlexBus) | None       |                         | 8 data / 2  | CS      | 1                | 20 address /<br>8 data / 2 CS   |

Table continues on the next page...

#### MCF51JF Features by Package

Table 2-2. Feature Summary by Package (continued)

| Device                                                       | JF32                          | JF32                    | JF64               | JF64        | JF128            | JF128                           |
|--------------------------------------------------------------|-------------------------------|-------------------------|--------------------|-------------|------------------|---------------------------------|
| Package type and number of pins                              | 32-pin QFN                    | 44-pin QFN <sup>1</sup> | 48-pin LQFP        | 44-pir      | QFN <sup>1</sup> | 64-pin<br>LQFP/QFN <sup>1</sup> |
| Package dimensions (mm x mm)                                 | 5x5                           | 5x5                     | 7x7                | 5           | x5               | 10x10/9x9                       |
| Serial programming interface (EzPort)                        |                               |                         | Yes                |             |                  |                                 |
|                                                              |                               | Clocks                  |                    |             |                  |                                 |
| Multipurpose clock generator (MCG)                           |                               | FLL + PLL -             | ⊦ internal oscilla | tor (32 kHz | or 2 MHz)        |                                 |
|                                                              | System                        | Security and I          | ntegrity           |             |                  |                                 |
| Random number generator (RNGB)                               |                               |                         | 1                  |             |                  |                                 |
| Cryptographic acceleration unit (CAU)                        |                               |                         | 1                  |             |                  |                                 |
| Cyclic redundancy check (CRC)                                |                               |                         | 1                  |             |                  |                                 |
| COP watchdog module                                          |                               |                         | 1                  |             |                  |                                 |
|                                                              |                               | Analog                  |                    |             |                  |                                 |
| 12-bit ADC single ended                                      | 6 ch                          | 9 ch                    | 11 ch              | 9           | ch               | 17 ch                           |
| 12-bit DAC                                                   |                               | ı                       | 1                  |             |                  | 1                               |
| CMP (with 6-bit DAC) external inputs                         | 1                             |                         | 2                  |             |                  | 4                               |
| VREF                                                         | No                            |                         |                    | Yes         |                  |                                 |
|                                                              |                               | Timers                  |                    |             |                  |                                 |
| FlexTimer (FTM0 with quad decoder) channel pins <sup>2</sup> | None                          |                         | 1 ch               |             |                  | 2 ch                            |
| FlexTimer (FTM1) channel pins                                | 6 ch                          |                         |                    |             |                  |                                 |
| Carrier modulator transmitter (CMT)                          |                               | 1                       |                    |             |                  |                                 |
| Programmable delay block (PDB)                               |                               | 1                       |                    |             |                  |                                 |
| 16-bit modulo timer (MTIM)                                   |                               | 1                       |                    |             |                  |                                 |
| Low power timer (LPTMR)                                      | 2                             |                         |                    |             |                  |                                 |
|                                                              | Comm                          | nunication Inte         | rfaces             |             |                  |                                 |
| UART                                                         |                               |                         | 2                  |             |                  |                                 |
| I <sup>2</sup> S/SAI                                         |                               |                         | 1                  |             |                  |                                 |
| SPI (16-bit)                                                 |                               |                         | 2 (1 with F        | IFO)        |                  |                                 |
| I <sup>2</sup> C                                             | 3 4                           |                         |                    | 4           |                  |                                 |
| USB 2.0 OTG LS/FS <sup>3</sup>                               |                               |                         | 1                  |             |                  |                                 |
| USB DCD                                                      | 1                             |                         |                    |             |                  |                                 |
|                                                              | Human-Machine Interface (HMI) |                         |                    |             |                  |                                 |
| Touch sensing inputs (TSI)                                   | 5                             | 7                       | 8                  |             | 7                | 16                              |
| Total GPIO pins <sup>4</sup>                                 | 22                            | 31                      | 35                 | 3           | 1                | 48                              |
| Pin interrupts                                               | 22                            | 31                      | 35                 | 3           | 1                | 48                              |
| RGPIO                                                        | 5                             | 8                       | 10                 |             | 3                | 16                              |

#### 1. Laminate QFN

74

#### **Chapter 2 Introduction**

- 2. When an FTM channel pin is not present in a package, the channel's internal functionality remains available. In packages where FTM0 channel 0 is not available, the comparator can be used to connect an external input to FTM channel 0.
- 3. The 3.3 V voltage regulator on all ColdFire+ devices powers the on-chip USB transceiver. The regulator input supports the 5 V supply typically provided by USB VBUS power.
- 4. GPIO numbers include RGPIO



# **Chapter 3 Chip Configuration**

#### 3.1 Introduction

This chip configuration information consists of details about the individual modules that are specific to the chip. The information includes:

- module block diagrams showing immediate connections within the device,
- specific module-to-module interactions not necessarily discussed in the individual module chapters, and
- links for more information.

#### **NOTE**

For clock gating information that applies to modules generally, refer to Clock gating. Any additional clock gating info that is specific to a module appears in the module's dedicated chip configuration details.

## 3.2 Module to Module Interaction Summary

This device contains internal connections between peripherals to support a number of different target applications. The following table summarizes these connections.

#### **Module to Module Interaction Summary**

**Table 3-1. Module to Module Interactions Summary** 

| Use Case                       | Function                                                                                                   | Peripherals                                                                                   | Description                                                                                                                                                                   | Control                                                                                                                                                                                                                          |
|--------------------------------|------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Motor<br>control               | Speed<br>detection /<br>tachometer pulse<br>counting                                                       | CMP, FTM0,<br>LPTMR1,<br>LPTMR0                                                               | FTM input capture or an LPTMR input is connected to CMP_OUT.                                                                                                                  | The ACFTM bit in the SIM's SOPT7 register enables CMP_OUT to the FTM0 channel 0 input. The LPTMR's CSR[TPS] bits can be set to 00 to select the CMP_OUT.                                                                         |
|                                | FTM synchronization                                                                                        | CMP, FTM0,<br>FTM1,<br>FTMxSYNC bits                                                          | The CMP_OUT signal can be used to synchronize the count of FTM0 and FTM1.                                                                                                     | Make the selection with the CHxTRIG bits in the FTMs' EXTTRIG register.                                                                                                                                                          |
|                                | Programmable fault detection                                                                               | CMP, FTM0,<br>FTM1                                                                            | The CMP_OUT signal is connected to the FTM0 and FTM1 fault inputs.                                                                                                            | Make the selection with the FAULTxEN bits in the FTMs' FLTCTRL register.                                                                                                                                                         |
| Analog /<br>signal<br>analysis | Low power adjustable pulse counting                                                                        | CMP, LPTMR1,<br>FTM0                                                                          | CMP_OUT is connected to<br>the LPTMR1 input for pulse<br>counting or to FTM0 channel<br>0 for pulse width<br>measurement.                                                     | The ACFTM bit in the SIM's SOPT7 register enables CMP_OUT to the FTM0 channel 0 input. The LPTMR's CSR[TPS] bits can be set to 00 to select the CMP_OUT.                                                                         |
|                                | Low power ADC conversion                                                                                   | LPTMR0, ADC                                                                                   | An LPTMR overflow generates an ADC conversion trigger.                                                                                                                        | The ADTRGS bit in the SIM's SOPT7 register selects ADC trigger source. Then the LPTMR should generate a trigger for the ADC's SC1A register only.                                                                                |
|                                | PDB triggering of DAC                                                                                      | DAC, PDB                                                                                      | A PDB interval trigger is used to generate DAC triggers.                                                                                                                      | Set up using the PDB.                                                                                                                                                                                                            |
|                                | PDB triggering of<br>ADC conversion<br>triggering                                                          | PDB with<br>LPTMR0,<br>LPTMR1, CMP,<br>PDB EXTRG,<br>FTM0, FTM1,<br>MTIM                      | Using the PDB, various modules can be used to initiate an ADC conversion.                                                                                                     | Combine PDB configuration and initialization of the desired peripheral.                                                                                                                                                          |
|                                | Internal voltage<br>reference signals                                                                      | DAC, VREF,<br>ADC, CMP                                                                        | DAC and VREF outputs are available as ADC channels and CMP inputs.                                                                                                            | DAC and VREF outputs must be enabled: use the ADC's SC1n register to select the DAC or VREF. The CMP can also be used to select the DAC or VREF.                                                                                 |
|                                | Accurate reference for analog peripherals                                                                  | VREF, ADC,<br>DAC                                                                             | The VREF output is connected to the ADC reference or DAC reference.                                                                                                           | The VREF is enabled by VREF control registers. The ADC or DAC chooses VREF as the reference (REFSEL bits in the ADC's SC2 register).                                                                                             |
| Communic ations                | UART optical isolation                                                                                     | UART1, FTMx,<br>MTIM, CMP                                                                     | The UART1_Rx input can be connected to CMP_OUT, and the TX output can be modulated with the output of one of the timers (FTM0, FTM1, MTIM) before being transmitted off chip. | Configure the CMP so its external input pin is used as the source of the RX signal with the SIM's SOPT6[RX1IN] bit. The FTMx or MTIM modulation is selected by the MTBASE[0:1] bits. The MODTX1 bit enables the UART modulation. |
|                                | I <sup>2</sup> C dual role<br>functionality<br>(separate slave<br>and master<br>control and<br>interrupts) | (I <sup>2</sup> C0 and I <sup>2</sup> C1)<br>and (I <sup>2</sup> C2 and<br>I <sup>2</sup> C3) | I <sup>2</sup> C0 and I <sup>2</sup> C1 or I <sup>2</sup> C2 and I <sup>2</sup> C3 are connected to allow separate status/control and interrupts for I <sup>2</sup> C.        | Use the I2CDR0 or I2CDR2 bit in the SIM's SOPT7 register to connect I <sup>2</sup> C0 and I <sup>2</sup> C1 or I <sup>2</sup> C2 and I <sup>2</sup> C3, respectively.                                                            |

#### 3.3 Core modules

#### 3.3.1 Version 1 (V1) ColdFire Core Configuration

This section summarizes how the module has been configured in the chip. For a comprehensive description of the module itself, see the module's dedicated chapter.



Figure 3-1. Core configuration

Table 3-2. Reference links to related information

| Topic                              | Related module                           | Reference          |
|------------------------------------|------------------------------------------|--------------------|
| Full description                   | V1 ColdFire core                         | Core               |
| System memory map                  |                                          | System memory map  |
| Clocking                           |                                          | Clock distribution |
| Power management                   |                                          | Power management   |
| Debug                              | Background debug controller (BDC)        | Debug              |
| Interrupts                         | Interrupt controller (INTC)              | INTC               |
| System/instruction/data bus module | Crossbar switch                          | Crossbar switch    |
| System/instruction module          | Enhanced multiply-accumulate (EMAC) unit | EMAC               |
| ColdFire core coprocessor          | Cryptographic acceleration unit (CAU)    | CAU                |

## 3.3.2 Debug Configuration

This section summarizes how the module has been configured in the chip. For a comprehensive description of the module itself, see the module's dedicated chapter.

#### System modules



Figure 3-2. Debug configuration

Table 3-3. Reference links to related information

| Topic               | Related module                                                                                                             | Reference           |
|---------------------|----------------------------------------------------------------------------------------------------------------------------|---------------------|
| Full description    | <ul> <li>V1 ColdFire core debug</li> <li>Background debug mode (BDM)</li> <li>Background debug controller (BDC)</li> </ul> | Debug               |
| Signal multiplexing | Port mux control                                                                                                           | Signal multiplexing |

## 3.4 System modules

## 3.4.1 Crossbar Switch Configuration



Figure 3-3. Crossbar switch integration

Table 3-4. Reference links to related information

| Topic                  | Related module          | Reference               |
|------------------------|-------------------------|-------------------------|
| Full description       | Crossbar switch         | Crossbar Switch         |
| System memory map      |                         | System memory map       |
| Clocking               |                         | Clock Distribution      |
| Crossbar switch master | V1 ColdFire core CPU    | Core                    |
| Crossbar switch master | DMA controller          | DMA controller          |
| Crossbar switch master | EzPort                  | EzPort                  |
| Crossbar switch master | USB                     | USB                     |
| Crossbar switch slave  | Flash memory controller | Flash memory controller |
| Crossbar switch slave  | Mini-FlexBus            | Mini-FlexBus            |
| Crossbar switch slave  | Peripheral bridge       | Peripheral bridge       |
| Crossbar switch slave  | RAM                     | RAM                     |
| Crossbar switch slave  | RGPIO                   | RGPIO                   |

## 3.4.1.1 Crossbar Switch Master Assignments

This device contains three master connections to the crossbar switch.

#### System modules

| Master module                      | Master port number |
|------------------------------------|--------------------|
| CPU                                | 0                  |
| DMA controller and EzPort (shared) | 1                  |
| USB device                         | 2                  |

#### NOTE

The DMA controller and EzPort module share a master port. Because these modules never operate at the same time, no configuration or arbitration explanations are necessary.

#### 3.4.1.2 Crossbar Switch Slave Assignments

This device contains three slave connections to the crossbar switch.

| Slave module                                | Slave port number |
|---------------------------------------------|-------------------|
| Flash memory controller                     | 0                 |
| Mini-FlexBus and peripheral bridge (shared) | 1                 |
| RAM and RGPIO (shared)                      | 3                 |

## 3.4.2 Peripheral Bridge Configuration



Figure 3-4. Peripheral bridge configuration

Table 3-5. Reference links to related information

| Topic             | Related module  | Reference          |
|-------------------|-----------------|--------------------|
| System memory map |                 | System memory map  |
| Clocking          |                 | Clock distribution |
| Crossbar switch   | Crossbar switch | Crossbar switch    |

#### 3.4.2.1 Peripheral bridge interfaces

The peripheral bridge has two interfaces for transfers to and from modules.

Table 3-6. Peripheral bridge interfaces

| Interface size | Connected modules                                                        |
|----------------|--------------------------------------------------------------------------|
| 32-bit         | DMA controller and Mini-FlexBus                                          |
| 8-bit          | All other modules with an assigned slot in the peripheral bus memory map |

#### 3.4.2.2 Memory map and module register access

The peripheral bridge enables access to the registers of most of the modules on this device. See the memory map tables for the memory slot assignment for each module.

## 3.4.3 DMA Controller Configuration

This section summarizes how the module has been configured in the chip. For a comprehensive description of the module itself, see the module's dedicated chapter.



Figure 3-5. DMA Controller configuration

Table 3-7. Reference links to related information

| Topic             | Related module | Reference           |
|-------------------|----------------|---------------------|
| Full description  | DMA controller | DMA controller      |
| System memory map |                | System memory map   |
| Clocking          |                | Clock distribution  |
| Power management  |                | Power management    |
| Requests          |                | DMA request sources |

## 3.4.3.1 DMA Request Sources

The following table identifies the DMA request sources.

#### System modules

Table 3-8. DMA request sources

| Request ID | Assignment to DMA Channel 0  Channel 1 |                           | Assignment to DMA<br>Channel 2 | Assignment to DMA<br>Channel 3 |
|------------|----------------------------------------|---------------------------|--------------------------------|--------------------------------|
| 0          | SPI0 Transmit                          | SPI0 Transmit             | SPI1 Transmit                  | SPI1 Transmit                  |
| 1          | SPI0 Receive                           | SPI0 Receive              | SPI1 Receive                   | SPI1 Receive                   |
| 2          | UART0 Transmit                         | UART1 Transmit            | UART1 Transmit                 | UART0 Transmit                 |
| 3          | UART0 Receive                          | UART1 Receive             | UART1 Receive                  | UART0 Receive                  |
| 4          | I <sup>2</sup> C0                      | I <sup>2</sup> C1         | I <sup>2</sup> C2              | I <sup>2</sup> C3              |
| 5          | I <sup>2</sup> C1                      | I <sup>2</sup> C2         | I <sup>2</sup> C3              | I <sup>2</sup> C0              |
| 6          | I <sup>2</sup> S Transmit              | I <sup>2</sup> S Transmit | I <sup>2</sup> S Transmit      | I <sup>2</sup> S Transmit      |
| 7          | I <sup>2</sup> S Receive               | I <sup>2</sup> S Receive  | I <sup>2</sup> S Receive       | I <sup>2</sup> S Receive       |
| 8          | 12-bit DAC                             | CMP                       | CMP                            | 12-bit DAC                     |
| 9          | FTM0 Channel 0                         | FTM0 Channel 0            | FTM1 Channel 0                 | FTM1 Channel 0                 |
| 10         | FTM0 Channel 1                         | FTM0 Channel 1            | FTM1 Channel 1                 | FTM1 Channel 1                 |
| 11         | FTM1 Channel 2                         | FTM1 Channel 3            | FTM1 Channel 4                 | FTM1 Channel 5                 |
| 12         | FTM1 Channel 3                         | FTM1 Channel 4            | FTM1 Channel 5                 | FTM1 Channel 2                 |
| 13         | PDB                                    | СМТ                       | ADC                            | CMT                            |
| 14         | ADC                                    | PTC   PTD                 | PTF   PTE                      | PTA   PTB                      |
| 15         | РТА                                    | PTE                       | PTC                            | PTD                            |

## 3.4.4 Interrupt Controller (INTC) Configuration



Figure 3-6. INTC configuration

Table 3-9. Reference links to related information

| Topic             | Related module                 | Reference          |
|-------------------|--------------------------------|--------------------|
| Full description  | Interrupt Controller<br>(INTC) | INTC               |
| System memory map |                                | System memory map  |
| Clocking          |                                | Clock distribution |
| Power management  |                                | Power management   |

#### 3.4.4.1 Interrupt priority levels

The CF1\_INTC module implements a sparsely populated  $7 \times 9$  matrix of levels (7) and priorities within each level (9).

#### 3.4.4.2 Interrupt channel assignments

The exception vector assignments include interrupt assignments.

#### **NOTE**

Level 7 interrupt requests are nonmaskable. For more information, refer to the detailed description of the Interrupt Controller module.

Table 3-10. Exception vector assignments

| Address offset | Vector number | Level (Priority) <sup>1</sup> | Assignment                           |
|----------------|---------------|-------------------------------|--------------------------------------|
| 0x000          | 0             |                               | Initial supervisor stack pointer     |
| 0x004          | 1             |                               | Initial program counter              |
| 0x008 - 0x0FC  | 2-63          |                               | Assigned for internal CPU exceptions |
| 0x100          | 64            | 7(mid)                        | IRQ                                  |

Table continues on the next page...

#### System modules

Table 3-10. Exception vector assignments (continued)

| Address offset | Vector number | Level (Priority) <sup>1</sup> | Assignment                                  |
|----------------|---------------|-------------------------------|---------------------------------------------|
| 0x104          | 65            | 7(3)                          | LVD                                         |
| 0x108          | 66            | 7(2)                          | Low Leakage Wakeup <sup>2</sup>             |
| 0x10C          | 67            | 7(1)                          | MCG Loss of Clock                           |
| 0x10E          |               | 6(7)                          | Reserved for remapped vector #1             |
| 0x10F          |               | 6(6)                          | Reserved for remapped vector #2             |
| 0x110          | 68            | 6(5)                          | Flash                                       |
| 0x114          | 69            | 6(4)                          | DMA Channel 0                               |
| 0x118          | 70            | 6(3)                          | DMA Channel 1                               |
| 0x11C          | 71            | 6(2)                          | DMA Channel 2                               |
| 0x120          | 72            | 6(1)                          | DMA Channel 3                               |
| 0x124          | 73            | 5(7)                          | USB Status                                  |
| 0x128          | 74            | 5(6)                          | RNGB                                        |
| 0x12C          | 75            | 5(5)                          | FTM1 Fault+Overflow                         |
| 0x130          | 76            | 5(4)                          | FTM1 Channel 0                              |
| 0x134          | 77            | 5(3)                          | FTM1 Channel 1                              |
| 0x138          | 78            | 5(2)                          | FTM1 Channel 2                              |
| 0x13C          | 79            | 5(1)                          | FTM1 Channel 3                              |
| 0x140          | 80            | 4(7)                          | FTM1 Channel 4                              |
| 0x144          | 81            | 4(6)                          | FTM1 Channel 5                              |
| 0x148          | 82            | 4(5)                          | СМР                                         |
| 0x14C          | 83            | 4(4)                          | FTM0 Fault+Overflow                         |
| 0x150          | 84            | 4(3)                          | FTM0 Channel 0                              |
| 0x154          | 85            | 4(2)                          | FTM0 Channel 1                              |
| 0x158          | 86            | 4(1)                          | SPI0                                        |
| 0x15C          | 87            | 3(7)                          | UART0 (Err, Transmit, Receive) <sup>3</sup> |
| 0x160          | 88            | 3(6)                          | I <sup>2</sup> S Receive                    |
| 0x164          | 89            | 3(5)                          | I <sup>2</sup> S Transmit                   |
| 0x168          | 90            | 3(4)                          | I <sup>2</sup> C0                           |
| 0x16C          | 91            | 3(3)                          | I <sup>2</sup> C2                           |
| 0x170          | 92            | 3(2)                          | SPI1                                        |
| 0x174          | 93            | 3(1)                          | UART1 (Err, Transmit, Receive) <sup>4</sup> |
| 0x178          | 94            | 2(7)                          | I <sup>2</sup> C1                           |
| 0x17C          | 95            | 2(6)                          | I <sup>2</sup> C3                           |
| 0x180          | 96            | 2(5)                          | ADC                                         |
| 0x184          | 97            | 2(4)                          | TSI                                         |
| L              | 1             |                               |                                             |

Table continues on the next page...

Table 3-10. Exception vector assignments (continued)

| Address offset | Vector number | Level (Priority) <sup>1</sup> | Assignment                                  |  |  |
|----------------|---------------|-------------------------------|---------------------------------------------|--|--|
| 0x188          | 98            | 2(3)                          | DAC                                         |  |  |
| 0x18C          | 99            | 2(2)                          | СМТ                                         |  |  |
| 0x190          | 100           | 2(1)                          | PDB                                         |  |  |
| 0x194          | 101           | 1(7)                          | LPTMR0                                      |  |  |
| 0x198          | 102           | 1(6)                          | LPTMR1                                      |  |  |
| 0x19C          | 103           | 7(0)                          | Level 7 Software Interrupt                  |  |  |
| 0x1A0          | 104           | 6(0)                          | Level 6 Software Interrupt                  |  |  |
| 0x1A4          | 105           | 5(0)                          | Level 5 Software Interrupt                  |  |  |
| 0x1A8          | 106           | 4(0)                          | Level 4 Software Interrupt                  |  |  |
| 0x1AC          | 107           | 3(0)                          | Level 3 Software Interrupt                  |  |  |
| 0x1B0          | 108           | 2(0)                          | Level 2 Software Interrupt                  |  |  |
| 0x1B4          | 109           | 1(0)                          | Level 1 Software Interrupt                  |  |  |
| 0x1B8          | 110           | 1(5)                          | МТІМ                                        |  |  |
| 0x1BC          | 111           | 1(4)                          | USBDCD                                      |  |  |
| 0x1C0          | 112           | 1(3)                          | EGPIO PORT A I EGPIO PORT B                 |  |  |
| 0x1C4          | 113           | 1(2)                          | EGPIO PORT D   EGPIO PORT C                 |  |  |
| 0x1C8          | 114           | 1(1)                          | EGPIO PORT F I EGPIO PORT E                 |  |  |
| 0x1CC-0x3FC    | 115-255       | -                             | RESERVED - Unused for ColdFire core devices |  |  |

- 1. In the format x(y): x is the interrupt level and y is the priority within the level.
- 2. Upon exiting LLS mode, core instruction execution goes directly to the low leakage wakeup interrupt. For wakeup from VLLSx modes:
  - One or two pending interrupts are serviced. One is serviced if the wakeup is from the LLWU wakeup pins, or two are serviced if the wakeup is from a TSI, CMP, or LPTMR module.
  - Then instruction execution resumes via the reset vectors.
- 3. All of the UART0 interrupt sources are joined in this single vector.
- 4. All of the UART1 interrupt sources are joined in this single vector.

Table 3-11. ColdFire Level, Priority within Level Matrix Interrupt Assignments

| Priority | Level | Priority within Level <sup>1</sup> |   |   |   |          |     |                          |                         |                |
|----------|-------|------------------------------------|---|---|---|----------|-----|--------------------------|-------------------------|----------------|
|          |       | 7                                  | 6 | 5 | 4 | Midpoint | 3   | 2                        | 1                       | 0              |
| Highest  | 7     |                                    |   |   |   | IRQ      | LVD | Low<br>Leakage<br>Wakeup | MCG<br>Loss of<br>Clock | Level 7<br>SWI |

Table continues on the next page...

Table 3-11. ColdFire Level, Priority within Level Matrix Interrupt Assignments (continued)

| Priority | Level | Priority within Level <sup>1</sup> |                             |                                |                                |          |                      |                      |                      |                |
|----------|-------|------------------------------------|-----------------------------|--------------------------------|--------------------------------|----------|----------------------|----------------------|----------------------|----------------|
|          |       |                                    | 6                           | 5                              | 4                              | Midpoint | 3                    | 2                    | 1                    | 0              |
|          | 6     | INTC_PL<br>6P7                     | INTC_PL<br>6P6              | Flash                          | DMA<br>Channel<br>0            | х        | DMA<br>Channel<br>1  | DMA<br>Channel<br>2  | DMA<br>Channel<br>3  | Level 6<br>SWI |
|          | 5     | USB<br>Status                      | RNGB                        | FTM1<br>Fault<br>+Overflo<br>w | FTM1<br>Channel<br>0           | х        | FTM1<br>Channel<br>1 | FTM1<br>Channel<br>2 | FTM1<br>Channel<br>3 | Level 5<br>SWI |
|          | 4     | FTM1<br>Channel<br>4               | FTM1<br>Channel<br>5        | СМР                            | FTM0<br>Fault<br>+Overflo<br>w | х        | FTM0<br>Channel<br>0 | FTM0<br>Channel<br>1 | SPI0                 | Level 4<br>SWI |
|          | 3     | UART0                              | I <sup>2</sup> S<br>Receive | I <sup>2</sup> S<br>Transmit   | I <sup>2</sup> C0              | х        | I <sup>2</sup> C2    | SPI1                 | UART1                | Level 3<br>SWI |
|          | 2     | I <sup>2</sup> C1                  | I <sup>2</sup> C3           | ADC                            | TSI                            | х        | DAC                  | CMT                  | PDB                  | Level 2<br>SWI |
| Lowest   | 1     | LPTMR0                             | LPTMR1                      | МТІМ                           | USBDCD                         | х        | PORT A I<br>PORT B   | PORT D I<br>PORT C   | PORT F I<br>PORT E   | Level 1<br>SWI |

<sup>1.</sup> Within a level, priorities are evaluated numerically: that is, the higher the number, the higher the priority.

## 3.4.5 Low-Leakage Wakeup Unit (LLWU) Configuration

This section summarizes how the module has been configured in the chip. For a comprehensive description of the module itself, see the module's dedicated chapter.



Figure 3-7. Low-Leakage Wakeup Unit configuration

Table 3-12. Reference links to related information

| Topic             | Related module                    | Reference         |
|-------------------|-----------------------------------|-------------------|
| Full description  | Low-Leakage Wakeup<br>Unit (LLWU) | LLWU              |
| System memory map |                                   | System memory map |

Table continues on the next page...

Table 3-12. Reference links to related information (continued)

| Topic            | Related module                       | Reference           |
|------------------|--------------------------------------|---------------------|
| Clocking         |                                      | Clock distribution  |
| Power management |                                      | Power management    |
|                  | Power Management<br>Controller (PMC) | PMC configuration   |
| Wakeup requests  |                                      | LLWU wakeup sources |

#### 3.4.5.1 LLWU wakeup sources

The LLWU module has the following internal and external inputs. WUP0-WUP15 are external pin inputs, and module interrupt flags (M0IF-M3IF) are internal peripheral connections.

#### **NOTE**

The RESET pin is also a wakeup source when the LLWU's RST[LLRSTE] bit is 1 and the pin is enabled as RESET or GPIO via port mux control.

Table 3-13. LLWU Inputs

| Wakeup<br>Pin | Source                                                                    | Wakeup Pin | Source                                                                        |
|---------------|---------------------------------------------------------------------------|------------|-------------------------------------------------------------------------------|
| LLWU_P0       | PTC7/UART0_RX/I2C0_SDA/RGPIO7/<br>SPI1_MISO/FBa_AD12                      | LLWU_P10   | PTF2/SPI0_MISO/FBa_AD7                                                        |
| LLWU_P1       | PTD1/UART0_RTS/I2C1_SCL/RGPIO9/<br>SPI1_SS/FBa_AD14/I2S0_RX_BC            | LLWU_P11   | PTF3/SPI0_MOSI/RGPIO1/FBa_AD8/<br>I2S0_TXD                                    |
| LLWU_P2       | PTA5/UART1_RTS/I2C2_SDA/<br>FTM1_CH5/SPI1_MOSI/CLKOUT/<br>I2S0_TXD        | LLWU_P12   | PTC2/UART1_RTS/SPI1_SS/RGPIO2/<br>FBa_AD18/I2S0_TX_FS                         |
| LLWU_P3       | PTA7/UART0_TX/FTM0_QD_PHA/<br>FBa_D5                                      | LLWU_P13   | PTF5/UART1_RX/SPI1_MISO/FBa_D2/<br>FBa_RW/I2S0_RXD                            |
| LLWU_P4       | PTD7/UART0_CTS/I2C3_SCL/RGPIO15/<br>FBa_D3                                | LLWU_P14   | PTC3/UART0_CTS/RGPIO3/SPI0_SCLK/<br>CLKOUT/USB_CLKIN/I2S0_MCLK/<br>I2S0_CLKIN |
| LLWU_P5       | PTB0/I2C0_SCL/IRQ                                                         | LLWU_P15   | PTC4/UART0_RX/RGPIO4/SPI0_MISO/<br>PDB0_EXTRG/USB_SOF_PULSE                   |
| LLWU_P6       | PTB1/SPI0_SCLK/I2C0_SDA/FTM_FLT2/<br>LPTMR_ALT2/FTM0_QD_PHB/<br>FB_CLKOUT | LLWU_M0IF  | LPTMR0 <sup>1</sup>                                                           |
| LLWU_P7       | PTB2/SPI0_MISO/FBa_CS0                                                    | LLWU_M1IF  | LPTMR1 <sup>1</sup>                                                           |
| LLWU_P8       | PTE7/UART0_TX/PDB0_EXTRG/<br>SPI1_MOSI/FBa_RW/FBa_AD4                     | LLWU_M2IF  | CMP0 <sup>1</sup>                                                             |
| LLWU_P9       | PTB4/BKGD/MS                                                              | LLWU_M3IF  | TSI <sup>1</sup>                                                              |

#### System modules

1. Requires the peripheral and the peripheral interrupt to be enabled. The internal module's WUME bit enables the internal module flag as a wakeup input. After wakeup, the flags are cleared based on the peripheral clearing mechanism.

#### 3.4.5.2 LLWU register reset

All LLWU registers are reset by Chip Reset not VLLS and by other reset types that trigger Chip Reset not VLLS. LLWU registers are unaffected by reset types that do not trigger Chip Reset not VLLS. For more information about the types of reset available on this chip, refer to the Reset details.

## 3.4.6 Computer Operating Properly (COP) Watchdog Configuration

This section summarizes how the module has been configured in the chip.

Topic Related module Reference

Clocking Clock distribution

Power management Programming model System Integration Module (SIM)

SIM

Table 3-14. Reference links to related information

#### **3.4.6.1 COP clocks**

The two clock inputs for the COP are the 1 kHz clock and the bus clock.

#### 3.4.6.2 COP watchdog operation

The COP watchdog is intended to force a system reset when the application software fails to execute as expected. To prevent a system reset from the COP timer (when it is enabled), application software must reset the COP counter periodically. If the application program gets lost and fails to reset the COP counter before it times out, a system reset is generated to force the system back to a known starting point.

After any reset, the COP watchdog is enabled. If the COP watchdog is not used in an application, it can be disabled by clearing COPC[COPT] in the SIM.

The COP counter is reset by writing 0x55 and 0xAA (in that order) to the address of the SIM's Service COP (SRVCOP) register during the selected timeout period. Writes do not affect the data in the SRVCOP register. As soon as the write sequence is complete, the COP timeout period is restarted. If the program fails to perform this restart during the timeout period, the microcontroller resets. Also, if any value other than 0x55 or 0xAA is written to the SRVCOP register, the microcontroller immediately resets.

The SIM's COPC[COPCLKS] field selects the clock source used for the COP timer. The clock source options are either the bus clock or an internal 1 kHz clock source. With each clock source, there are three associated timeouts controlled by COPC[COPT]. The following table summarizes the control functions of the COPCLKS and COPT bits. The COP watchdog defaults to operation from the 1 kHz clock source and the longest timeout for that clock source (2<sup>10</sup> cycles).

| Contr         | ol Bits    | Clock Source | COP Window Opens | COP Overflow Count                              |
|---------------|------------|--------------|------------------|-------------------------------------------------|
| COPC[COPCLKS] | COPC[COPT] | Clock Source | (COPC[COPW] = 1) | COF OVERHOW COUNT                               |
| N/A           | 00         | N/A          | N/A              | COP is disabled                                 |
| 0             | 01         | 1 kHz        | N/A              | 2 <sup>5</sup> cycles (32 ms <sup>-</sup> )     |
| 0             | 10         | 1 kHz        | N/A              | 28 cycles (256 ms.)                             |
| 0             | 11         | 1 kHz        | N/A              | 2 <sup>10</sup> cycles (1,024 ms <sup>-</sup> ) |
| 1             | 01         | Bus          | 6,144 cycles     | 2 <sup>13</sup> cycles                          |
| 1             | 10         | Bus          | 49,152 cycles    | 2 <sup>16</sup> cycles                          |
| 1             | 11         | Bus          | 196,608 cycles   | 2 <sup>18</sup> cycles                          |

After the bus clock source is selected, windowed COP operation is available by setting COPC[COPW] in the SIM. In this mode, writes to the SRS register to clear the COP timer must occur in the last 25% of the selected timeout period. A premature write immediately resets the chip. When the 1 kHz clock source is selected, windowed COP operation is not available.

The COP counter is initialized by the first writes to the SIM's COPC register and after any system reset. Subsequent writes to the SIM's COPC register have no effect on COP operation. Even if an application uses the reset default settings of the COPT, COPCLKS, and COPW bits, the user should write to the write-once COPC register during reset initialization to lock in the settings. This approach prevents accidental changes if the application program becomes lost.

The write to the SRVCOP register that services (clears) the COP counter should not be placed in an interrupt service routine (ISR) because the ISR could continue to be executed periodically even if the main application program fails.

#### System modules

If the bus clock source is selected, the COP counter does not increment while the microcontroller is in background debug mode or while the system is in stop (including VLPS or LLS) mode. The COP counter resumes when the microcontroller exits background debug mode or stop mode.

If the 1 kHz clock source is selected, the COP counter is re-initialized to zero upon entry to either background debug mode or stop (including VLPS or LLS) mode. The counter begins from zero upon exit from background debug mode or stop mode.

Regardless of the bus selected, the COP is disabled when the chip enters a VLLSx mode. Upon a reset that wakes the chip from the VLLSx mode, the COP is re-initialized and enabled as for any reset.

## 3.4.7 System Mode Controller (SMC) Configuration

This section summarizes how the module has been configured in the chip. For a comprehensive description of the module itself, see the module's dedicated chapter.



Figure 3-8. System Mode Controller configuration

| Table 2 45 D   | ) - f - u - u - a - l | limbra ta wa |       |     | <u> </u>  |
|----------------|-----------------------|--------------|-------|-----|-----------|
| 1 able 3-15. H | leterence             | links to re  | uareo | ını | formation |

| Topic             | Related module                    | Reference         |
|-------------------|-----------------------------------|-------------------|
| Full description  | System Mode<br>Controller (SMC)   | SMC               |
| System memory map |                                   | System memory map |
| Power management  |                                   | Power management  |
|                   | Power management controller (PMC) | PMC               |
|                   | Low-Leakage Wakeup<br>Unit (LLWU) | LLWU              |
|                   | Reset Control Module (RCM)        | Reset             |

92

#### 3.4.7.1 SMC register reset

Different SMC registers reset on different MCU reset types. Refer to the detailed register descriptions. For information about the various reset types on this chip, refer to the Reset details.

## 3.4.8 Power Management Controller (PMC) Configuration

This section summarizes how the module has been configured in the chip. For a comprehensive description of the module itself, see the module's dedicated chapter.



Figure 3-9. PMC configuration

Table 3-16. Reference links to related information

| Topic             | Related module                       | Reference         |
|-------------------|--------------------------------------|-------------------|
| Full description  | Power Management<br>Controller (PMC) | PMC               |
| System memory map |                                      | System memory map |
| Power management  |                                      | Power management  |
|                   | System Mode<br>Controller (SMC)      | SMC               |
|                   | Low-Leakage Wakeup<br>Unit (LLWU)    | LLWU              |
|                   | Reset Control Module (RCM)           | Reset             |

## 3.4.8.1 PMC register reset

Different portions of PMC registers reset on different MCU reset types. Refer to the detailed register descriptions. For information about the various reset types on this chip, refer to the Reset details.

## 3.4.9 System Integration Module (SIM) Configuration

This section summarizes how the module has been configured in the chip. For a comprehensive description of the module itself, see the module's dedicated chapter.



Figure 3-10. SIM configuration

Table 3-17. Reference links to related information

| Topic             | Related module                     | Reference          |
|-------------------|------------------------------------|--------------------|
| Full description  | System Integration<br>Module (SIM) | SIM                |
| System memory map |                                    | System memory map  |
| Clocking          |                                    | Clock distribution |
| Power management  |                                    | Power management   |

#### 3.4.9.1 SIM register reset

Different SIM registers reset on different MCU reset types. Refer to the detailed register descriptions. For information about the various reset types on this chip, refer to the Reset details.

#### 3.5 Clock Modules

## 3.5.1 Multipurpose Clock Generator (MCG) Configuration

This section summarizes how the module has been configured in the chip. For a comprehensive description of the module itself, see the module's dedicated chapter.



Figure 3-11. MCG configuration

Table 3-18. Reference links to related information

| Topic             | Related module | Reference          |
|-------------------|----------------|--------------------|
| Full description  | MCG            | MCG                |
| System memory map |                | System memory map  |
| Clocking          |                | Clock distribution |
| Power management  |                | Power management   |

#### 3.5.1.1 MCG oscillator-frequency trim settings: factory and custom

Factory-programmed values for trimming oscillator frequency are stored in the nonvolatile information register (IFR) and are automatically loaded into the MCG's C3 and C4 registers after any reset.

A portion of the chip's program flash memory can be used to store other, custom settings for frequency trimming. These locations appear as FTRIM and TRIM in the following table.

Table 3-19. Flash memory addresses for custom oscillator-frequency trim settings

| Address       | Register                         | 7 | 6 | 5 | 4  | 3  | 2 | 1 | 0     |
|---------------|----------------------------------|---|---|---|----|----|---|---|-------|
| 0x(00)00_03FD | Storage of other custom settings |   | _ | _ | _  | _  | _ | _ | _     |
| 0x(00)00_03FE | Storage of FTRIM                 | 0 | 0 | 0 | 0  | 0  | 0 | 0 | FTRIM |
| 0x(00)00_03FF | Storage of TRIM                  |   |   |   | TR | IM |   |   |       |

To override the factory-programmed settings with custom settings:

- 1. Using Freescale's BDM tools, users and third parties can reprogram the TRIM and FTRIM values stored in the reserved flash memory addresses.
- 2. User code must copy the value of FTRIM to the MCG's C4[SCFTRIM] bit and the value of TRIM to the MCG's C3[SCTRIM] field.

## 3.5.2 Oscillator (OSC) Configuration



Figure 3-12. OSC1 configuration



Figure 3-13. OSC2 configuration

Table 3-20. Reference links to related information

| Topic              | Related module                         | Reference          |
|--------------------|----------------------------------------|--------------------|
| Full description   | OSC                                    | OSC                |
| System memory map  |                                        | System memory map  |
| Clocking           |                                        | Clock distribution |
| Power management   |                                        | Power management   |
| OSC1 configuration | System Integration<br>Module (SIM)     | SIM                |
| OSC2 configuration | Multipurpose Clock<br>Generation (MCG) | MCG                |

## 3.6 Memories and Memory Interfaces

#### 3.6.1 RAM Configuration

This section summarizes how the module has been configured in the chip.



Figure 3-14. RAM configuration

Table 3-21. Reference links to related information

| Topic             | Related module | Reference          |
|-------------------|----------------|--------------------|
| Description       | RAM            | RAM overview       |
| System memory map |                | System memory map  |
| Clocking          |                | Clock distribution |
| Power management  |                | Power management   |

#### 3.6.1.1 RAM overview

The microcontroller includes up to 32 KB of static RAM. RAM is most efficiently accessed using the A5-relative addressing mode (address register indirect with displacement mode). Any single bit in this area can be accessed with the bit manipulation instructions (BCLR, BSET, and so on).

At power-on, the contents of RAM are uninitialized. RAM data is unaffected by any reset provided that the supply voltage does not drop below the minimum value for RAM retention  $(V_{RAM})$ .

#### 3.6.1.2 RAM sizes

The embedded RAM is tightly coupled with the V1 ColdFire core. The following table describes the amount of RAM (not counting FlexRAM) for the chips covered by this document.

#### **Memories and Memory Interfaces**

| Chip       | RAM (KB) |
|------------|----------|
| MCF51JF32  | 8        |
| MCF51JF64  | 16       |
| MCF51JF128 | 32       |

For all chips, the RAM has partitions that operate as a single unit:

- RAM1: 1 KB partition
- RAM2: 7 KB partition
- RAM3: 0 KB, 8 KB, or 24 KB partition (according to the total sizes in the preceding table)

For example, for the MCF51JF128, RAM3 is a 24 KB partition.

#### 3.6.1.3 RAM retention in low power modes

The RAM1, RAM2, and RAM3 partitions are retained in low power modes down to VLLS3 mode.

In VLLS2 mode: The RAM1 partition is powered, the RAM2 partition is optionally powered using the RAM2PO bit, and the RAM3 partition is not powered.

In VLLS1 mode: The RAM1, RAM2, and RAM3 partitions are not powered. However, the 32-byte register file remains available in VLLS1 mode.

#### 3.6.1.4 RAM accesses

The RAM's interface with the crossbar switch is 32 bits wide.

#### 3.6.2 Flash Memory Controller (FMC) Configuration

This section summarizes how the module has been configured in the chip. For a comprehensive description of the module itself, see the module's dedicated chapter.

98



Figure 3-15. Flash memory controller configuration

Table 3-22. Reference links to related information

| Topic             | Related module                                              | Reference               |
|-------------------|-------------------------------------------------------------|-------------------------|
| Full description  | Flash memory controller                                     | Flash memory controller |
| System memory map |                                                             | System memory map       |
| Clocking          |                                                             | Clock distribution      |
| Transfers         | Flash memory                                                | Flash memory            |
| Transfers         | Crossbar switch                                             | Crossbar switch         |
| Control inputs    | V1 ColdFire core's<br>CPU configuration<br>register (CPUCR) | CPUCR                   |

## 3.6.3 Flash Memory Module (FTFL) Configuration



Figure 3-16. Flash memory configuration

Table 3-23. Reference links to related information

| Topic             | Related module          | Reference               |
|-------------------|-------------------------|-------------------------|
| Full description  | Flash memory            | Flash memory            |
| System memory map |                         | System memory map       |
| Clocking          |                         | Clock distribution      |
| Transfers         | Flash memory controller | Flash memory controller |
| Register access   | Peripheral bridge       | Peripheral bridge       |

#### 3.6.3.1 Flash Memory Types

This device contains multiple types of flash memory as defined below:

- Program flash: nonvolatile flash memory that can execute program code
- FlexMemory: memory block that can be configured as additional program flash, data flash, and/or EEPROM. It allows user configuration of the EEPROM and data flash sizes, as well as EEPROM endurance, to fulfill application requirements.
  - FlexNVM: nonvolatile flash memory that can execute program code, store data, or back up EEPROM data
  - FlexRAM: RAM memory that can be used as traditional RAM or as high-endurance EEPROM storage

#### 3.6.3.2 Flash Memory Sizes

The devices covered in this document contain:

- 1 block of program flash
- 1 block of FlexNVM
- 1 block of FlexRAM

The following table describes the amounts of memory for the devices covered in this document.

| Device     | Program flash (KB) | FlexNVM (KB) | FlexRAM (KB) |
|------------|--------------------|--------------|--------------|
| MCF51JF32  | 32                 | 16           | 1            |
| MCF51JF64  | 64                 | 32           | 2            |
| MCF51JF128 | 128                | 32           | 2            |

#### 3.6.3.3 Flash Memory Map

The various flash memories and the flash registers are located at different base addresses as shown in the following figure. The base address for each is specified in System Memory Map.



Figure 3-17. Flash memory map

The following table identifies subdivisions within the chip's program flash memory space. It also indicates where to find additional information about each area.

Table 3-24. High Level Program Flash Memory Map

| Address range                  | Purpose                                                                            | Reference                                                  |
|--------------------------------|------------------------------------------------------------------------------------|------------------------------------------------------------|
| 0x(00)00_0000 to 0x(00)00_03FC | Standard program flash memory, interrupt vector table                              | Interrupt channel assignments                              |
| 0x(00)00_03FD to 0x(00)00_03FF | Standard program flash memory, space for custom oscillator-frequency trim settings | MCG oscillator-frequency trim settings: factory and custom |
| 0x(00)00_0400 to 0x(00)00_040F | Flash Configuration Field                                                          | Flash Configuration Field<br>Description                   |
| 0x(00)00_0410 to upper limit   | Standard program flash memory                                                      |                                                            |

#### 3.6.3.4 Flash Security

How flash security is implemented on the device is described in Chip Security.

#### **3.6.3.5** Flash Modes

The flash memory operates in NVM normal and NVM special modes. The flash memory enters NVM special mode when the EzPort is enabled (EZP\_CS asserted during reset). Otherwise, flash memory operates in NVM normal mode.

#### 3.6.3.6 Erase All Flash Contents

In addition to software, the entire flash memory may be erased external to the flash memory in two ways:

- 1. Via the EzPort by issuing a bulk erase (BE) command.
- 2. Via background debug by using DBGCR[0] and DBGSR[0]. Refer to Debug Control Register (DBGCR) and Debug Status Register (DBGSR) for details.

#### 3.6.3.7 FTFL\_FOPT Register

The flash memory's FTFL\_FOPT register allows the user to customize the operation of the MCU at boot time. See FOPT boot options for details of its definition.

## 3.6.4 System Register File Configuration

This section summarizes how the module has been configured in the chip.



Figure 3-18. System Register file configuration

Table 3-25. Reference links to related information

| Topic             | Related module | Reference          |
|-------------------|----------------|--------------------|
| Full description  | Register file  | Register file      |
| System memory map |                | System memory map  |
| Clocking          |                | Clock Distribution |
| Power management  |                | Power management   |

#### 3.6.4.1 Register file details

The chip includes a 32-byte register file, consisting of eight 32-bit registers, that is accessible in all power modes and retains contents during low-voltage detect (LVD) events.

The register file can be accessed via 8-bit, 16-bit, and 32-bit accesses. The 16-bit and 32-bit accesses are serialized on the 8-bit peripheral bus.

The register file is reset exclusively by the POR Only reset type. It is unaffected by other reset types. For information about the various reset types on this chip, refer to the Reset details.

## 3.6.5 EzPort Configuration

#### **Memories and Memory Interfaces**



Figure 3-19. EzPort configuration

Table 3-26. Reference links to related information

| Topic               | Related module   | Reference           |
|---------------------|------------------|---------------------|
| Full description    | EzPort           | EzPort              |
| System memory map   |                  | System memory map   |
| Clocking            |                  | Clock distribution  |
| Transfers           | Crossbar switch  | Crossbar switch     |
| Signal multiplexing | Port mux control | Signal multiplexing |

#### 3.6.5.1 EzPort and BDM

EzPort mode and active background debug mode (BDM) cannot be used at the same time. Attempts to use both simultaneously can lead to unexpected behavior.

BDM has priority over EzPort mode. For more information, refer to the detailed Boot description.

#### Flash Option Register (FOPT) 3.6.5.2

The FOPT[EZPORT\_DIS] bit can be used to prevent entry into EzPort mode during reset. If the FOPT[EZPORT DIS] bit is cleared, then the state of the chip select signal (EZP\_CS) is ignored and the MCU always boots in normal mode.

This option is useful for systems that use the EZP\_CS/IRQ signal configured for its IRQ function. Disabling EzPort mode prevents possible unwanted entry into EzPort mode if the external circuit that drives the NMI signal asserts it during reset.

The FOPT register is loaded from the flash option byte. If the flash option byte is modified, the new value takes effect for any subsequent resets, until the value is changed again. For more information about the FOPT register, refer to FOPT boot options.

Downloaded from **Elcodis.com** electronic components distributor

#### 3.6.5.3 EzPort Clocking

The EzPort module is enabled only when the device is operating in EzPort mode. The module clocks are active only in this mode. When the device is operating in normal mode, the EzPort clock is disabled.

No register bits control the ezPort module clock because the clocking is determined by operating mode.

## 3.6.6 Mini-FlexBus Configuration

This section summarizes how the module has been configured in the chip. For a comprehensive description of the module itself, see the module's dedicated chapter.



Figure 3-20. Mini-FlexBus configuration

 Topic
 Related module
 Reference

 Full description
 Mini-FlexBus
 Mini-FlexBus

 System memory map
 System memory map

 Clocking
 Clock distribution

 Power management
 Power management

 Signal multiplexing
 Port mux control

 Signal multiplexing

Table 3-27. Reference links to related information

#### 3.6.6.1 Mini-FlexBus instantiation information

The chip instantiates the Mini-FlexBus module with 20 address lines, 2 control signals, 8 data lines and 2 chip selects. The full functionality of the Mini-FlexBus is available only on the 64-pin versions of the chip. The 44-pin and 48-pin versions offer the limited functionality of the DATA bus for interfacing with peripherals such as graphical displays. The 32-pin version does not support Mini-FlexBus functionality.

#### Security

To use DATA bus functionality, set the pin muxing controls to make available the necessary functions. The DATA bus portion of Module-by-module signals identifies the pins needed to support an 8-bit data bus.

The Mini-FlexBus modes of operation for 64-pin devices are:

- Up to a 20-bit address (non-multiplexed) with 8-bit data
- Up to a 20-bit address (multiplexed) with 16-bit data (write masking of upper/lower bytes not supported)
- Up to a 20-bit address (multiplexed) with 8-bit data

#### 3.6.6.2 Mini-FlexBus security

When security is enabled on the device, Mini-FlexBus accesses may be restricted by configuring the MBSL field in the SIM's SOPT6 register. See System Integration Module (SIM) for details.

## 3.7 Security

## 3.7.1 Cryptographic Acceleration Unit (CAU) Configuration



Figure 3-21. CAU configuration

Table 3-28. Reference links to related information

| Topic             | Related module       | Reference          |
|-------------------|----------------------|--------------------|
| Full description  | CAU                  | CAU                |
| System memory map |                      | System memory map  |
| Clocking          |                      | Clock distribution |
| Power management  |                      | Power management   |
| Transfers         | V1 ColdFire core CPU | Core               |

#### 3.7.2 Random Number Generator (RNG) Configuration

This section summarizes how the module has been configured in the chip. For a comprehensive description of the module itself, see the module's dedicated chapter.



Figure 3-22. RNG configuration

Table 3-29. Reference links to related information

| Topic             | Related module | Reference          |
|-------------------|----------------|--------------------|
| Full description  | RNG            | RNG                |
| System memory map |                | System memory map  |
| Clocking          |                | Clock distribution |
| Power management  |                | Power management   |

## 3.7.2.1 Module register width and serialization of accesses

This module's registers are 32 bits wide. Accesses via the 8-bit peripheral bus are serialized: 32-bit accesses are serialized into four 8-bit accesses.

## 3.7.3 Cyclic Redundancy Check (CRC) Configuration

#### **Analog**



Figure 3-23. CRC configuration

Table 3-30. Reference links to related information

| Topic             | Related module | Reference         |
|-------------------|----------------|-------------------|
| Full description  | CRC            | CRC               |
| System memory map |                | System memory map |
| Power management  |                | Power management  |

#### 3.7.3.1 Module register width and serialization of accesses

This module's registers are 32 bits wide. Accesses via the 8-bit peripheral bus are serialized: 32-bit accesses are serialized into four 8-bit accesses.

## 3.8 Analog

## 3.8.1 12-bit Analog-to-Digital Converter (ADC) Configuration



Figure 3-24. 12-bit SAR ADC configuration

Table 3-31. Reference links to related information

| Topic               | Related module   | Reference           |  |
|---------------------|------------------|---------------------|--|
| Full description    | 12-bit SAR ADC   | 12-bit SAR ADC      |  |
| System memory map   |                  | System memory map   |  |
| Clocking            |                  | Clock distribution  |  |
| Power management    |                  | Power management    |  |
| Signal multiplexing | Port mux control | Signal multiplexing |  |

# 3.8.1.1 Module register width and serialization of accesses

This module's registers are 32 bits wide. Accesses via the 8-bit peripheral bus are serialized: 32-bit accesses are serialized into four 8-bit accesses.

### 3.8.1.2 ADC instantiation information

This device contains one ADC. The ADC has an option for the ADC clock altclk. For this chip, altclk is connected to the XOSC2 ERCLK.

The number of ADC channels present on the device is determined by the pinout of the specific device package. For details, refer to Signal Multiplexing.

The 32-pin version of the chip does not bond out VREFL and VREFH to package pins. For this reason, this package cannot achieve the same level of ADC performance as the packages with larger numbers of pins.

# 3.8.1.3 DMA support on ADC

Applications may require continuous sampling of the ADC (4K samples/second) that may impose considerable load on the CPU. Though using PDB to trigger ADC may reduce some CPU load, the ADC supports DMA request functionality for higher performance when the ADC is sampled at a very high rate or for cases where the PDB is bypassed. The ADC can trigger the DMA (via DMA req) on conversion completion.

## 3.8.1.4 ADC0 Channel Assignments

| ADC Channel (ADCH) | Channel | Input              |
|--------------------|---------|--------------------|
| 00000              | AD0     | Reserved           |
| 00001              | AD1     | Reserved           |
| 00010              | AD2     | ADC0_SE2           |
| 00011              | AD3     | ADC0_SE3           |
| 00100              | AD4     | 12-bit DAC         |
| 00101              | AD5     | -                  |
| 00110              | AD6     | -                  |
| 00111              | AD7     | -                  |
| 01000              | AD8     | ADC0_SE8           |
| 01001              | AD9     | ADC0_SE9           |
| 01010              | AD10    | ADC0_SE10          |
| 01011              | AD11    | ADC0_SE11          |
| 01100              | AD12    | ADC0_SE12          |
| 01101              | AD13    | ADC0_SE13          |
| 01110              | AD14    | ADC0_SE14          |
| 01111              | AD15    | ADC0_SE15          |
| 10000              | AD16    | ADC0_SE16          |
| 10001              | AD17    | ADC0_SE17          |
| 10010              | AD18    | ADC0_SE18          |
| 10011              | AD19    | ADC0_SE19          |
| 10100              | AD20    | ADC0_SE20          |
| 10101              | AD21    | ADC0_SE21          |
| 10110              | AD22    | ADC0_SE22          |
| 10111              | AD23    | 6-bit DAC output   |
| 11000              | AD24    | Reserved           |
| 11001              | AD25    | Reserved           |
| 11010              | AD26    | Temperature Sensor |
| 11011              | AD27    | Bandgap            |
| 11100              | AD28    | Reserved           |
| 11101              | AD29    | VREFH              |

Table continues on the next page...

| ADC Channel (ADCH) | Channel | Input           |
|--------------------|---------|-----------------|
| 11110              | AD30    | VREFL           |
| 11111              | AD31    | Module disabled |

### 3.8.1.5 ADC Reference, Triggers, and Alternate Clock

### **ADC Reference**

Select the reference on the ADC using the ADC's SC2[REFSEL] field. The available options are:

- VREFH/VREFL connected as the primary reference option
- 1.2 V VREFO connected as the V<sub>ALT</sub> reference option

### **ADC Triggers**

In addition to the PDB, the LPTMR0 module is connected to the ADC as a trigger source. LPTMR0 can trigger the ADC in low power modes where the PDB does not work. Triggering by the LPTMR0 module allows the ADC to perform conversion in a low power mode and store the output in the result register. When the data is ready in the result register, the ADC generates an interrupt that will wake the system from low power mode.

Select the trigger source for the ADC using the SIM's SOPT7[ADTRGS] bit.

- PDB trigger (run mode)
- LPTMR0 overflow (can work in stop mode)

### **Alternate Clock**

The ADC's alternate clock is connected to the XOSC2's ERCLK.

# 3.8.1.6 Clock Gating

The clock to the ADC module can be gated on and off using the SIM's SCGCx[ADC] bit. This bit is cleared after any reset, which disables the clock to the module to conserve power. Before initializing the ADC, set the SCGCx[ADC] bit to enable the clock.

#### NOTE

The clock to the ADC cannot be gated during an active conversion.

MCF51JF128 Reference Manual, Rev. 2, 03/2011

#### **Analog**

During a low power mode of operation, where the external clock to the ADC is gated, the ADC can also operate on an internally generated clock. In this case, after the conversion is complete, an asynchronous interrupt can wake the system, enabling the clocks (including the clock to the ADC) so the conversion results can be read.

# 3.8.2 Comparator (CMP) Configuration

This section summarizes how the module has been configured in the chip. For a comprehensive description of the module itself, see the module's dedicated chapter.



Figure 3-25. CMP configuration

Table 3-32. Reference links to related information

| Topic               | Related module   | Reference           |
|---------------------|------------------|---------------------|
| Full description    | Comparator (CMP) | Comparator          |
| System memory map   |                  | System memory map   |
| Clocking            |                  | Clock distribution  |
| Power management    |                  | Power management    |
| Signal multiplexing | Port mux control | Signal multiplexing |

### 3.8.2.1 CMP instantiation information

This chip has one high speed comparator module with an integrated 6-bit DAC and analog mux. The CMP's 6-bit DAC sub-block supports selection of two voltage references. For this chip, the references implemented are:

1. VDD: connected to the V<sub>in1</sub> input

### 2. VREFO: connected to the $V_{in2}$ input

Table 3-33. CMP instantiation

| CMP0 feature            | Details |
|-------------------------|---------|
| Number of 6-bit DACs    | 1       |
| Analog mux size         | 8 input |
| Number of CMP OUT pins  | 1       |
| External inputs on CMP0 | 4       |

The following table and list show the fixed internal connections to and output connections of the CMP, respectively. For information about the specific pins to which the input and output signals are assigned on a particular package, refer to the CMP portion of the Module-by-module signals.

Table 3-34. CMP Input connections

| CMP inputs | СМР                  | Pin name |
|------------|----------------------|----------|
| CMP Input1 | External input       | CMP0_IN0 |
| CMP Input2 | External input       | CMP0_IN1 |
| CMP Input3 | External input       | CMP0_IN2 |
| CMP Input4 | External input       | CMP0_IN3 |
| CMP Input5 | 12-bit DAC reference |          |
| CMP Input6 | VREF output          |          |
| CMP Input7 | Reserved             |          |
| CMP Input8 | 6-bit DAC reference  |          |

### CMP output connections are:

- CMP output pin
- FTM0 channel 0 (set this connection using the SIM's SOPT7[ACFTM] bit)
- LPTMR1 clock input (pulse count)
- FTM0 fault input
- FTM1 fault input
- FTM0 trigger
- FTM 1 trigger
- UART1 Rx input

# 3.8.2.2 External window/sample input

The analog comparator's external window/sample input is connected to the PDB channel 2's pulse-out.

# 3.8.3 12-bit Digital-to-Analog Converter (DAC) Configuration

This section summarizes how the module has been configured in the chip. For a comprehensive description of the module itself, see the module's dedicated chapter.



Figure 3-26. 12-bit DAC configuration

Table 3-35. Reference links to related information

| Topic               | Related module   | Reference           |  |
|---------------------|------------------|---------------------|--|
| Full description    | 12-bit DAC       | 12-bit DAC          |  |
| System memory map   |                  | System memory map   |  |
| Clocking            |                  | Clock distribution  |  |
| Power management    |                  | Power management    |  |
| Signal multiplexing | Port mux control | Signal multiplexing |  |

### 3.8.3.1 12-bit DAC Overview

The chip includes one 12-bit DAC with a 16 x 12 FIFO for DMA support.

### 3.8.3.2 12-bit DAC Instantiation

The output of this DAC can be placed on an external pin or set as one of the inputs to the CMP or ADC.

114

### 3.8.3.3 12-bit DAC External Reference

For this chip, VREFH and VDDA are available as the DAC reference. When the DAC uses VREFH as its reference, the ADC uses VREFO, which limits the inputs to 1.2 V for highest accuracy. However, when the DAC is not used or when the DAC uses VDDA as its reference, ADC inputs support the full voltage range with no degradation of ADC accuracy.

### 3.8.3.4 DAC DMA request

The DAC can generate a DMA request. The DAC generates requests in order to be updated at the maximum speed. As soon as the DAC is ready to receive new data, it generates a DMA request, triggering the next DAC data update.

# 3.8.4 Voltage Reference (VREF) Configuration

This section summarizes how the module has been configured in the chip. For a comprehensive description of the module itself, see the module's dedicated chapter.



Figure 3-27. VREF configuration

Table 3-36. Reference links to related information

| Topic               | Related module   | Reference           |
|---------------------|------------------|---------------------|
| Full description    | VREF             | VREF                |
| System memory map   |                  | System memory map   |
| Clocking            |                  | Clock distribution  |
| Power management    |                  | Power management    |
| Signal multiplexing | Port mux control | Signal multiplexing |

**Timers** 

### 3.8.4.1 VREF Overview

The chip includes a voltage reference (VREF) intended to supply an accurate voltage output that can be trimmed using the module's TRM[TRIM] field.

The VREF can provide a reference voltage to external peripherals or a reference to analog peripherals, such as the ADC or CMP.

The VREF is not available on the 32-pin package.

### 3.9 Timers

# 3.9.1 Programmable Delay Block (PDB) Configuration

This section summarizes how the module has been configured in the chip. For a comprehensive description of the module itself, see the module's dedicated chapter.



Figure 3-28. PDB configuration

Table 3-37. Reference links to related information

| Topic               | Related module   | Reference           |
|---------------------|------------------|---------------------|
| Full description    | PDB              | PDB                 |
| System memory map   |                  | System memory map   |
| Clocking            |                  | Clock distribution  |
| Power management    |                  | Power management    |
| Signal multiplexing | Port mux control | Signal multiplexing |

# 3.9.1.1 Module register width and serialization of accesses

This module's registers are 32 bits wide. Accesses via the 8-bit peripheral bus are serialized: 32-bit accesses are serialized into four 8-bit accesses.

116

### 3.9.1.2 PDB Overview

Many applications need to synchronize the time that multiple ADC samples are taken with respect to an external trigger or event. The programmable delay block provides controllable delays from an external trigger or a programmable interval tick to the sample trigger input of the ADCs and DACs.

### 3.9.1.3 PDB instantiation

Table 3-38. PDB output channels

| PDB feature                        | Details |
|------------------------------------|---------|
| Number of channels for ADC         | 1       |
| Number of triggers per ADC channel | 2       |
| Number of channels for DAC         | 1       |
| Number of DAC triggers             | 1       |
| Additional channel for PulseOut    | 1       |

The following table identifies PDB input trigger options.

| PDB trigger | Trigger configuration | PDB input        |
|-------------|-----------------------|------------------|
| Trigger 0   | 0b0000                | PDB_EXTRG        |
| Trigger 1   | 0b0001                | CMP Output       |
| Trigger 2   | 0b0010                | reserved         |
| Trigger 3   | 0b0011                | reserved         |
| Trigger 4   | 0b0100                | reserved         |
| Trigger 5   | 0b0101                | reserved         |
| Trigger 6   | 0b0110                | reserved         |
| Trigger 7   | 0b0111                | reserved         |
| Trigger 8   | 0b1000                | FTM0             |
| Trigger 9   | 0b1001                | FTM1             |
| Trigger 10  | 0b1010                | reserved         |
| Trigger 11  | 0b1011                | MTIM output      |
| Trigger 12  | 0b1100                | LPTMR0           |
| Trigger 13  | 0b1101                | reserved         |
| Trigger 14  | 0b1110                | LPTMR1           |
| Trigger 15  | 0b1111                | Software trigger |

**Timers** 

### 3.9.1.4 PDB Module Interconnections

- PDB channel 0 is dedicated to the ADC.
- PDB channel 1 is dedicated to the DAC.
- PDB channel 2 is dedicated to the CMP.

# 3.9.2 FlexTimer (FTM) Configuration

This section summarizes how the module has been configured in the chip. For a comprehensive description of the module itself, see the module's dedicated chapter.



Figure 3-29. FlexTimer configuration

Table 3-39. Reference links to related information

| Topic               | Related module   | Reference           |  |
|---------------------|------------------|---------------------|--|
| Full description    | FlexTimer        | FlexTimer           |  |
| System memory map   |                  | System memory map   |  |
| Clocking            |                  | Clock distribution  |  |
| Power management    |                  | Power management    |  |
| Signal multiplexing | Port mux control | Signal multiplexing |  |

### 3.9.2.1 FTM overview

The FlexTimer (FTM) module supports input capture, output compare, and the generation of PWM signals to control electric motor and power management applications. The FTM's time reference is a 16-bit counter that can be used as an unsigned or signed counter.

### 3.9.2.2 FTM instantiation information

The chip contains two FlexTimer modules. The following table shows how these modules are configured.

Table 3-40. FTM Instantiations

| FTM instance | Number of channels | Target application                | Additional features supported |
|--------------|--------------------|-----------------------------------|-------------------------------|
| FTM0         | 2 (channels 0-1)   | General purpose                   | Quadrature decoder            |
| FTM1         | 6 (channels 0-5)   | 3-phase motor and general purpose |                               |

FTM0 and FTM1 have four fault inputs. The output of the CMP is connected to the fault input 3 of both FTM0 and FTM1.

Table 3-41. FTM fault input sources

| FTMx fault input | FTM0 fault source | FTM1 fault source |
|------------------|-------------------|-------------------|
| Fault 0          | FTM_FLT0          | FTM_FLT0          |
| Fault 1          | FTM_FLT1          | FTM_FLT1          |
| Fault 2          | FTM_FLT2          | FTM_FLT2          |
| Fault 3          | CMP_OUT           | CMP_OUT           |

Table 3-42. FTM trigger sources

| Trigger source         | FTMx synchronization   |
|------------------------|------------------------|
| FTMxSYNC bits (in SIM) | FTM0 and FTM1 Trigger0 |
| CMP COUT               | FTM0 and FTM1 Trigger1 |
| FTM0_CH0               | FTM1 Trigger 2         |
| FTM1_CH0               | FTM0 Trigger 2         |

The 2-channel FTM0 pins are available only on the 64-pin packages of the chip. Although 1 channel is available on 44-pin and 48-pin packages and neither of the FTM0 pins is available on 32-pin packages, they remain available for software timer functions and internal connections from the CMP OUT.

The CMP OUT is connected to FTM0 Channel 0 to facilitate motor control applications.

Several FTM signals are and can be routed to multiple pins. For details about these pins and about programming port mux control registers to assign an FTM function to those pins, refer to signal multiplexing.

**Timers** 

### 3.9.2.3 FTM external clock options

By default, each FTM is clocked by the chip's system clock (the FTM itself also refers to it as the system clock). Each module has a register setting that allows the module to be clocked from an external clock instead. There are two external TMR\_CLKINx pins that can be selected by either FTM module via the SOPT5 register in the SIM module.

# 3.9.3 Modulo Timer (MTIM) Configuration

This section summarizes how the module has been configured in the chip. For a comprehensive description of the module itself, see the module's dedicated chapter.



Figure 3-30. MTIM configuration

Table 3-43. Reference links to related information

| Topic               | Related module   | Reference           |
|---------------------|------------------|---------------------|
| Full description    | Modulo Timer     | MTIM                |
| System memory map   |                  | System memory map   |
| Clocking            |                  | Clock distribution  |
| Power management    |                  | Power management    |
| Signal multiplexing | Port mux control | Signal multiplexing |

### 3.9.3.1 MTIM overview

The MTIM is a simple 16-bit modulo timer with several software selectable clock sources and a programmable interrupt. The chip has one MTIM module.

The MTIM shares the TMR\_CLKINx pins with the FlexTimer modules.

# 3.9.4 Low Power Timer (LPTMR) Configuration

This section summarizes how the module has been configured in the chip. For a comprehensive description of the module itself, see the module's dedicated chapter.



Figure 3-31. LPTMR configuration

Table 3-44. Reference links to related information

| Topic               | Related module   | Reference           |
|---------------------|------------------|---------------------|
| Full description    | Low power timer  | LPTMR               |
| System memory map   |                  | System memory map   |
| Clocking            |                  | Clock distribution  |
| Power management    |                  | Power management    |
| Signal multiplexing | Port mux control | Signal multiplexing |

### 3.9.4.1 LPTMR overview

The chip contains two 16-bit low power timer (LPTMR) modules that operate in all of the chip's power modes (including LLS and VLLSx). The LPTMRs can operate as either a real time interrupt or as a pulse accumulator. They include a 5-bit prescaler (real time interrupt mode) or glitch filter (pulse accumulator mode) and can be clocked from the internal reference clock, external reference clock, or internal 1 kHz LPO. An interrupt is generated (and the counter can reset) when the counter equals the value in the 16-bit compare register.

### NOTE

The internal reference clock (IRC) is generated by the MCG module and can be set to be in the 30 kHz range or to 2 MHz.

**Timers** 

### 3.9.4.2 LPTMR pin connections

Each LPTMR module has one 16-bit channel.

There are three LPTMR pins: LPTMR\_ALT1, LPTMR\_ALT2, and LPTMR\_ALT3. Each of these are connected to both LPTMR0 and LPTMR1 and can be selected by each module's CSR[TPS] field with the settings 01, 10, and 11, respectively.

The CMP output pin can also be connected to both LPTMR0 and LPTMR1 by setting each module's CSR[TPS] field to 00. This configuration allows pulse counting of the CMP output.

### 3.9.4.3 LPTMR clock options

Each module's PSR[PCS] field controls the selection of external clock options. For both LPTMR0 and LPTMR1:

- Setting PSR[PCS] to 00 selects the MCGIRCLK internal reference clock (not available in low leakage power modes).
- Setting PSR[PCS] to 01 selects the internal 1 kHz LPO clock.
- Setting PSR[PCS] to 10 selects ERCLK1 (low), the 32.768 kHz clock from OSC1. This connection is optimized for minimal power consumption in stop modes.

The effect of setting PSR[PCS] to 11 differs for the two LPTMRs:

- For LPTMR0, this setting selects the bus clock.
- For LPTMR1, this setting selects ERCLK2.

### 3.9.4.4 LPTMR register reset

All LPTMR registers are reset by Chip POR not VLLS and by POR Only, which triggers Chip POR not VLLS. LPTMR registers are unaffected by other reset types. For information about the various reset types on this chip, refer to the Reset details.

# 3.9.5 Carrier Modulator Transmitter (CMT) Configuration

This section summarizes how the module has been configured in the chip. For a comprehensive description of the module itself, see the module's dedicated chapter.



Figure 3-32. CMT configuration

Table 3-45. Reference links to related information

| Topic               | Related module                      | Reference           |
|---------------------|-------------------------------------|---------------------|
| Full description    | Carrier modulator transmitter (CMT) | СМТ                 |
| System memory map   |                                     | System memory map   |
| Clocking            |                                     | Clock distribution  |
| Power management    |                                     | Power management    |
| Signal multiplexing | Port mux control                    | Signal multiplexing |

### 3.9.5.1 CMT instantiation information

The chip contains one CMT module, which supports DMA.

# 3.9.5.2 CMT IRO drive strength

The IRO pad requires higher current drive than can be obtained from a single pad. For this chip, the pin associated with the CMT\_IRO signal is doubled bonded to two pads.

The SIM's SOPT6[PTC5PAD] bit can be used to configure the pin associated with the CMT\_IRO signal as a higher current output port pin.

# 3.10 Communication interfaces

# 3.10.1 Universal Serial Bus (USB) Subsystem

The USB subsystem includes these components:

MCF51JF128 Reference Manual, Rev. 2, 03/2011

#### **Communication interfaces**

- Dual-role USB OTG-capable (On-The-Go) controller that supports a full-speed (FS) device or FS/LS host. The module complies with the USB 2.0 specification.
- USB transceiver that includes internal 15 k $\Omega$  pulldowns on the D+ and D- lines for host mode functionality.
- A 3.3 V regulator.
- USB device charger detection module.
- VBUS detect signal: To detect a valid VBUS in device mode, use a GPIO signal that can wake the chip in all power modes.



Figure 3-33. USB Subsystem Overview

#### **USB Wakeup** 3.10.1.1

When the USB controller detects no activity on the USB bus for more than 3 ms, the INT\_STAT[SLEEP] bit is set. This bit can cause an interrupt and software determines the appropriate action.

Waking from a low power mode (except LLS and VLLSx modes) occurs through an asynchronous interrupt triggered by activity on the USB bus. Setting the USBTRC0[USBRESMEN] bit to 1 enables this function.

#### USB Power Distribution 3.10.1.2

This chip includes an internal 5 V to 3.3 V USB regulator that powers the USB transceiver or the MCU (depending on the application).

The chip can be powered by two AA/AAA cells. In this case, the MCU is powered through VDD, which is within the 1.8 V to 3.0 V range. After USB cable insertion is detected, the USB regulator is enabled to power the USB transceiver.



Figure 3-34. USB regulator AA cell use case

The chip can also be powered by a single Li-ion battery. In this case, VOUT33 is connected to VDD. The USB regulator must be enabled by default to power the MCU. When connected to a USB host, the input source of this regulator is switched to the USB bus supply from the Li-ion battery. To charge the battery, the MCU can configure the battery charger according to the charger detection description.



Figure 3-35. USB regulator Li-ion use case

MCF51JF128 Reference Manual, Rev. 2, 03/2011

#### **Communication interfaces**

The chip can also be powered by the USB bus directly. In this case, VOUT33 is connected to VDD. The USB regulator must be enabled by default to power the MCU and then to power the USB transceiver or external sensor.



Figure 3-36. USB regulator bus supply

### 3.10.1.3 USB power management

Whenever the chip is in stop mode, put the regulator into STANDBY mode by setting the SIM's SOPT1[SSTB] bit.

### 3.10.1.4 USB Controller Configuration

This section summarizes how the module has been configured in the chip. For a comprehensive description of the module itself, see the module's dedicated chapter.



Figure 3-37. USB controller configuration

Table 3-46. Reference links to related information

| Topic               | Related module   | Reference           |
|---------------------|------------------|---------------------|
| Full description    | USB controller   | USB controller      |
| System memory map   |                  | System memory map   |
| Clocking            |                  | Clock distribution  |
| Transfers           | Crossbar switch  | Crossbar switch     |
| Signal multiplexing | Port mux control | Signal multiplexing |

# 3.10.1.5 USB Device Charger Detection (USBDCD) Configuration

This section summarizes how the module has been configured in the chip. For a comprehensive description of the module itself, see the module's dedicated chapter.



Figure 3-38. USBDCD configuration

Table 3-47. Reference links to related information

| Topic             | Related module | Reference          |
|-------------------|----------------|--------------------|
| Full description  | USBDCD         | USBDCD             |
| System memory map |                | System memory map  |
| Clocking          |                | Clock distribution |

Table continues on the next page...

MCF51JF128 Reference Manual, Rev. 2, 03/2011

#### **Communication interfaces**

Table 3-47. Reference links to related information (continued)

| Topic | Related module | Reference |
|-------|----------------|-----------|
|       | USB controller | USB       |

### 3.10.1.5.1 Module register width and serialization of accesses

This module's registers are 32 bits wide. Accesses via the 8-bit peripheral bus are serialized: 32-bit accesses are serialized into four 8-bit accesses.

# 3.10.1.6 USB Voltage Regulator (VREG) Configuration

This section summarizes how the module has been configured in the chip. For a comprehensive description of the module itself, see the module's dedicated chapter.



Figure 3-39. USB Voltage Regulator configuration

Table 3-48. Reference links to related information

| Topic               | Related module        | Reference             |
|---------------------|-----------------------|-----------------------|
| Full description    | USB Voltage Regulator | USB Voltage Regulator |
| System memory map   |                       | System memory map     |
| Clocking            |                       | Clock distribution    |
|                     | USB controller        | USB                   |
| Signal multiplexing | Port mux control      | Signal multiplexing   |

# 3.10.2 Serial Peripheral Interface (SPI) Configuration

This section summarizes how the module has been configured in the chip. For a comprehensive description of the module itself, see the module's dedicated chapter.



Figure 3-40. SPI configuration

Table 3-49. Reference links to related information

| Topic               | Related module   | Reference           |
|---------------------|------------------|---------------------|
| Full description    | SPI              | SPI                 |
| System memory map   |                  | System memory map   |
| Clocking            |                  | Clock distribution  |
| Power management    |                  | Power management    |
| Signal multiplexing | Port mux control | Signal multiplexing |

### 3.10.2.1 Number and instantiation of SPI modules

The device contains two SPI modules. SPI0 has a 64-bit FIFO; SPI1 does not have a FIFO. In other regards, the two modules are identical.

### 3.10.2.2 SPI baud rate

The SPI is designed to run at a baud rate up to the bus clock divided by two when the module is in master mode and up to the bus clock divided by four when the module is in slave mode.

The device's maximum CPU frequency is 50 MHz with a maximum bus clock of 25 MHz. As a result, the SPI design supports a master baud rate up to 12.5 Mbps and a slave baud rate up to 6.25 Mbps.

### NOTE

For the actual maximum SPI baud rate in master and slave modes, refer to the device's Data Sheet.

# 3.10.3 Inter-Integrated Circuit (I2C) Configuration

This section summarizes how the module has been configured in the chip. For a comprehensive description of the module itself, see the module's dedicated chapter.



Figure 3-41. I2C configuration

Table 3-50. Reference links to related information

| Topic               | Related module   | Reference           |
|---------------------|------------------|---------------------|
| Full description    | I <sup>2</sup> C | I2C                 |
| System memory map   |                  | System memory map   |
| Clocking            |                  | Clock distribution  |
| Power management    |                  | Power management    |
| Signal multiplexing | Port mux control | Signal multiplexing |

### 3.10.3.1 Number of I2C modules

The device's 64-pin packages have four identical I<sup>2</sup>C modules.

Each of the device's other packages has three identical I<sup>2</sup>C modules.

# 3.10.4 Universal Asynchronous Receiver/Transmitter (UART) Configuration

This section summarizes how the module has been configured in the chip. For a comprehensive description of the module itself, see the module's dedicated chapter.

MCF51JF128 Reference Manual, Rev. 2, 03/2011



Figure 3-42. UART configuration

Table 3-51. Reference links to related information

| Topic               | Related module   | Reference           |  |  |  |
|---------------------|------------------|---------------------|--|--|--|
| Full description    | UART             | UART                |  |  |  |
| System memory map   |                  | System memory map   |  |  |  |
| Clocking            |                  | Clock distribution  |  |  |  |
| Power management    |                  | Power management    |  |  |  |
| Signal multiplexing | Port mux control | Signal multiplexing |  |  |  |

### 3.10.4.1 Number of UART modules

This device contains two identical UART modules.

# 3.10.4.2 **UART** wakeup

The UART can be configured to generate an interrupt/wakeup on the first active edge that it receives.

### 3.10.4.3 UART support for opto-isolated interface

The PTC5 pin, to which the UART0\_TX signal can be muxed, supports high drive strength to provide an opto-isolated interface. To enable this feature, use the PTC5PAD bit in the SIM.

Similarly: The PTF6 pin, to which the UART1\_TX signal can be muxed, supports high drive strength to provide an opto-isolated interface. To enable this feature, use the PTF6PAD bit in the SIM.

# 3.10.5 Integrated Interchip Sound (I2S)/Synchronous Audio Interface (SAI) Configuration

This section summarizes how the module has been configured in the chip. For a comprehensive description of the module itself, see the module's dedicated chapter.



Figure 3-43. I<sup>2</sup>S configuration

Table 3-52. Reference links to related information

| Topic               | Related module   | Reference           |  |  |  |
|---------------------|------------------|---------------------|--|--|--|
| Full description    | l <sup>2</sup> S | I2S                 |  |  |  |
| System memory map   |                  | System memory map   |  |  |  |
| Clocking            |                  | Clock distribution  |  |  |  |
| Power management    |                  | Power management    |  |  |  |
| Signal multiplexing | Port mux control | Signal multiplexing |  |  |  |

### 3.10.5.1 Instantiation Information

Since there is only one  $I^2S/SAI$  module, the multiple SAI synchronous mode is not supported.

# 3.10.5.2 Module register width and serialization of accesses

This module's registers are 32 bits wide. Accesses via the 8-bit peripheral bus are serialized: 32-bit accesses are serialized into four 8-bit accesses.

# 3.10.5.3 I<sup>2</sup>S/SAI Clocking

The I<sup>2</sup>S/SAI only supports one audio master clock in master mode for both transmit and receive. The following table shows the TCR2[CLKMODE] settings for SAI in this MCU.

Table 3-53. I<sup>2</sup>S/SAI master clock setting

| TCR2[CLKMODE] | Master Clock  |
|---------------|---------------|
| 00            | Bus Clock     |
| 01            | SAI_MCLK      |
| 10            | Not supported |
| 11            | Not supported |

MCLK Input Clock Select bit of MCLK Control Register (MCR[MICS]) selects the clock input to the MCLK Divider. The following table shows the options for the input clock to the I2S/SAI module's MCLK divider.

Table 3-54. MCLK input clock selection

| MCR[MICS] | Clock Selection |
|-----------|-----------------|
| 00        | System Clock    |
| 01        | ERCLK1          |
| 10        | ERCLK2          |
| 11        | MCGPLLOUT       |

# 3.11 Human-machine interfaces (HMI)

# 3.11.1 Rapid GPIO (RGPIO) Configuration

This section summarizes how the module has been configured in the chip. For a comprehensive description of the module itself, see the module's dedicated chapter.

#### **Human-machine interfaces (HMI)**



Figure 3-44. RGPIO configuration

Table 3-55. Reference links to related information

| Topic               | Related module   | Reference           |
|---------------------|------------------|---------------------|
| Full description    | RGPIO            | RGPIO               |
| System memory map   |                  | System memory map   |
| Clocking            |                  | Clock distribution  |
| Power management    |                  | Power management    |
| Transfers           | Crossbar switch  | Crossbar switch     |
| Signal multiplexing | Port mux control | Signal multiplexing |

#### Number of available RGPIO pins 3.11.1.1

The maximum number of 16 RGPIO pins is available in the 64-pin packages. Smaller packages have fewer available RGPIO pins. For details, refer to package pinout information in Signal Multiplexing.

#### RGPIO clock gating 3.11.1.2

Clock gating is not available for RGPIO.

#### **Enhanced GPIO (EGPIO) Configuration** 3.11.2

This section summarizes how the module has been configured in the chip. For a comprehensive description of the module itself, see the module's dedicated chapter.

Downloaded from **Elcodis.com** electronic components distributor



Figure 3-45. EGPIO configuration

Table 3-56. Reference links to related information

| Topic               | Related module   | Reference                     |  |  |  |
|---------------------|------------------|-------------------------------|--|--|--|
| Full description    | EGPIO            | Parallel Input/Output Control |  |  |  |
| System memory map   |                  | System memory map             |  |  |  |
| Clocking            |                  | Clock distribution            |  |  |  |
| Power management    |                  | Power management              |  |  |  |
| Signal multiplexing | Port mux control | Signal multiplexing           |  |  |  |

### 3.11.2.1 Instantiation Information

The maximum total number of GPIO pins for general purpose is 48 in the 64-pin packages. Smaller packages have fewer available GPIO pins. For details, refer to package pinout information in Signal Multiplexing.

GPIO pins are configured in 8-pin ports. The peripheral bus interface for the EGPIO operates at the bus clock.

Only two EGPIO ports have the digital filter feature: Port B and Port C. The other ports do not have this feature.

# 3.11.2.2 EGPIO registers

Every EGPIO port has two banks of registers. Each bank has a separate base address shared by all ports' registers in that bank.

- 1. One bank consists of registers for general port control. For details about these registers, refer to Port Control.
- 2. The other bank's registers control functions such as configurable slew rate, drive strength, pullups/pulldowns, and passive input filters. For details about these registers, refer to Parallel Input/Output Control.

MCF51JF128 Reference Manual, Rev. 2, 03/2011

# 3.11.3 Touch Sense Input (TSI) Configuration

This section summarizes how the module has been configured in the chip. For a comprehensive description of the module itself, see the module's dedicated chapter.



Figure 3-46. TSI configuration

Table 3-57. Reference links to related information

| Topic               | Related module   | Reference           |  |  |  |
|---------------------|------------------|---------------------|--|--|--|
| Full description    | TSI              | TSI                 |  |  |  |
| System memory map   |                  | System memory map   |  |  |  |
| Clocking            |                  | Clock distribution  |  |  |  |
| Power management    |                  | Power management    |  |  |  |
| Signal multiplexing | Port mux control | Signal multiplexing |  |  |  |

### 3.11.3.1 Module register width and serialization of accesses

This module's registers are 32 bits wide. Accesses via the 8-bit peripheral bus are serialized: 32-bit accesses are serialized into four 8-bit accesses.

## 3.11.3.2 Number and instantiation of inputs

This device includes one TSI module containing 16 inputs. The maximum number of 16 inputs is available in the 64-pin packages. Smaller packages have fewer available TSI inputs. For details, refer to package pinout information in Signal Multiplexing.

In low power modes, one selectable pin is active and able to wake the MCU.

### 3.11.3.3 TSI Interrupts

The TSI has multiple sources of interrupt requests. However, these sources are ORed together to generate a single interrupt request. When a TSI interrupt occurs, read the TSI status register to determine the exact interrupt source.

# 3.11.4 External Interrupt (IRQ) Module Configuration

This section summarizes how the module has been configured in the chip. For a comprehensive description of the module itself, see the module's dedicated chapter.



Figure 3-47. IRQ module configuration

Table 3-58. Reference links to related information

| Topic               | Related module           | Reference           |
|---------------------|--------------------------|---------------------|
| Full description    | External Interrupt (IRQ) | IRQ                 |
| System memory map   |                          | System memory map   |
| Clocking            |                          | Clock distribution  |
| Power management    |                          | Power management    |
| Signal multiplexing | Port mux control         | Signal multiplexing |

**Human-machine interfaces (HMI)** 

# Chapter 4 Memory Map

# 4.1 System Memory Map

Depending on the device variant and package, the chip supports up to 128 KB of program flash and 32 KB of FlexNVM. This configuration provides up to 160 KB of program flash, up to 2 KB of high-endurance EEPROM, or other partitioning options.

64-pin versions of the device allow flash and memory to be supplemented with off-chip storage via the Mini-FlexBus. The off-chip memory storage space is marked as available for off-chip expansion.

| Address Range | V1 ColdFire Memory Usage         |  |
|---------------|----------------------------------|--|
| 0x(00)00_0000 | Allocated to on-chip flash       |  |
| 0x(00)3F_FFFF | memory                           |  |
| 0x(00)40_0000 | Available for eff abin expansion |  |
| 0x(00)7F_FFFF | Available for off-chip expansion |  |
| 0x(00)80_0000 | Allocated to an abia DAM         |  |
| 0x(00)9F_FFFF | Allocated to on-chip RAM         |  |
| 0x(00)A0_0000 |                                  |  |
| 0x(00)BF_FFFF | Available for off-chip expansion |  |
| 0x(00)C0_0000 |                                  |  |
|               | ColdFire Rapid GPIO              |  |
| 0x(00)C0_000F |                                  |  |
| 0x(00)C0_0010 | Unimplemented                    |  |
| 0x(FF)FF_7FFF |                                  |  |
| 0x(FF)FF_8000 | 2 2                              |  |
| 0x(FF)FF_FFFF | Slave Peripherals                |  |

Figure 4-1. Generic V1 ColdFire Memory Map

Regions within the memory map are subject to restrictions with regard to the types of CPU accesses allowed. The following table outlines these restrictions. Unsupported access types terminate the bus cycle with an error. In response to a bus error termination, the chip can be configured to generate a system reset, such as by ensuring the CPUCR[ARD] bit is 0.

Table 4-1. CPU Access Type Allowed by Region

| Base Address  | Region                     | Read <sup>1</sup> |      |      | Write <sup>1</sup> |      |      |
|---------------|----------------------------|-------------------|------|------|--------------------|------|------|
| Base Address  |                            | Byte              | Word | Long | Byte               | Word | Long |
| 0x(00)00_0000 | Program flash <sup>2</sup> | х                 | х    | х    | _                  | _    | _    |
| 0x(00)20_0000 | FlexNVM <sup>2</sup>       | х                 | х    | х    | _                  | _    | _    |
| 0x(00)28_0000 | FlexRAM                    | х                 | х    | х    | х                  | х    | х    |
| 0x(00)40_0000 | Mini-FlexBus               | х                 | х    | х    | х                  | х    | х    |

Table continues on the next page...

Table 4-1. CPU Access Type Allowed by Region (continued)

| Base Address  | Region                                           | Read <sup>1</sup> |      |      | Write <sup>1</sup> |      |      |
|---------------|--------------------------------------------------|-------------------|------|------|--------------------|------|------|
|               |                                                  | Byte              | Word | Long | Byte               | Word | Long |
| 0x(00)80_0000 | RAM                                              | х                 | х    | х    | х                  | х    | х    |
| 0x(00)A0_0000 | Mini-FlexBus                                     | х                 | х    | х    | х                  | х    | х    |
| 0x(00)C0_0000 | Rapid GPIO                                       | х                 | х    | х    | х                  | х    | х    |
| 0x(FF)FF_8000 | Peripherals on 8-bit peripheral bus <sup>3</sup> | x                 | x    | x    | x                  | х    | х    |

- 1. Byte is 8-bit, Word is 16-bit, and Long is 32-bit.
- 2. Flash writes occur via a programming algorithm described in the flash memory details.
- 3. Allowed access types are peripheral specific. The peripheral bus bridge serializes 16-bit and 32-bit accesses into multiple 8-bit accesses. When using 8-bit peripherals, ensure that all accesses are properly aligned and only desired 8-bit locations are accessed.

The slave peripherals section of the memory map is further subdivided as the following table shows.

Table 4-2. High Level System Memory Map

| Memory                        | Description                                                   | Comment                                                                                              |
|-------------------------------|---------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| 0x(00)00_0000 - 0x(00)01_FFFF | Program flash space                                           | Smaller areas for 32 KB and 64 KB derivatives                                                        |
| 0x(00)02_0000 - 0x(00)1F_FFFF | Unimplemented                                                 | Bus error - illegal address                                                                          |
| 0x(00)20_0000 - 0x(00)20_7FFF | FlexNVM space                                                 | Shared memory with EEPROM that can<br>be used as program flash if no data<br>flash or EEPROM is used |
| 0x(00)20_8000 - 0x(00)27_FFFF | Unimplemented                                                 | Bus error - illegal address                                                                          |
| 0x(00)28_0000 - 0x(00)28_07FF | FlexRAM space                                                 | Up to 2 KB RAM available <sup>1</sup> if no EEPROM is used                                           |
| 0x(00)28_8000 - 0x(00)3F_FFFF | Unimplemented                                                 | Bus error - illegal address                                                                          |
| 0x(00)40_0000 - 0x(00)7F_FFFF | Mini-FlexBus                                                  |                                                                                                      |
| 0x(00)80_0000 - 0x(00)9F_FFFF | RAM mirrored in intervals of the chip's RAM size <sup>2</sup> | Mirrored all across this space                                                                       |
| 0x(00)A0_0000 - 0x(00)BF_FFFF | Mini-FlexBus                                                  | Memory expansion                                                                                     |
| 0x(00)C0_0000 - 0x(00)C0_000F | RGPIO                                                         | 16 RGPIO pins                                                                                        |
| 0x(00)C0_000F - 0x(FF)FF_7FFF | Unimplemented                                                 | Bus error - illegal address                                                                          |
| 0x(FF)FF_8000 - 0x(FF)FF_FFFF | Peripheral Bus                                                | See Table 4-4                                                                                        |

- 1. Refer to Feature Summary by Package for information about FlexRAM size for your specific chip.
- 2. RAM size is 8 KB, 16 KB, or 32 KB. See RAM sizes for your specific chip's RAM size.

Table 4-3. High Level Program Flash Memory Map

| Address range                  | Purpose                                               | Reference                     |
|--------------------------------|-------------------------------------------------------|-------------------------------|
| 0x(00)00_0000 to 0x(00)00_03FC | Standard program flash memory, interrupt vector table | Interrupt channel assignments |

Table continues on the next page...

### MCF51JF128 Reference Manual, Rev. 2, 03/2011

### **System Memory Map**

**Table 4-3. High Level Program Flash Memory Map (continued)** 

| Address range                  | Purpose                                                                            | Reference                                                  |
|--------------------------------|------------------------------------------------------------------------------------|------------------------------------------------------------|
| 0x(00)00_03FD to 0x(00)00_03FF | Standard program flash memory, space for custom oscillator-frequency trim settings | MCG oscillator-frequency trim settings: factory and custom |
| 0x(00)00_0400 to 0x(00)00_040F | Flash Configuration Field                                                          | Flash Configuration Field<br>Description                   |
| 0x(00)00_0410 to upper limit   | Standard program flash memory                                                      |                                                            |

Table 4-4. High Level Peripheral Memory Map

| Peripheral           | Description                                             | Instance Name | Base Address  |
|----------------------|---------------------------------------------------------|---------------|---------------|
| RGPIO                | Rapid General Purpose I/O                               | RGPIO         | 0x(00)C0_0000 |
| Port I/O Module      | Enhanced General Purpose I/O                            | РТА           | 0x(FF)FF_8000 |
| Port I/O Module      | Enhanced General Purpose I/O                            | РТВ           | 0x(FF)FF_8010 |
| Port I/O Module      | Enhanced General Purpose I/O                            | PTC           | 0x(FF)FF_8020 |
| Port I/O Module      | Enhanced General Purpose I/O                            | PTD           | 0x(FF)FF_8030 |
| Port I/O Module      | Enhanced General Purpose I/O                            | PTE           | 0x(FF)FF_8040 |
| Port I/O Module      | Enhanced General Purpose I/O                            | PTF           | 0x(FF)FF_8050 |
| Register File        | Register File                                           | RF            | 0x(FF)FF_8060 |
| Port Mux<br>Controls | Port Mux Controls                                       | MXC           | 0x(FF)FF_8080 |
| IRQ                  | External Interrupt Module                               | IRQ           | 0x(FF)FF_80A0 |
| LLWU                 | Low Leakage Wakeup Unit                                 | LLWU          | 0x(FF)FF_80B0 |
| SIM                  | System Integration Module                               | SIM           | 0x(FF)FF_80C0 |
| PMC                  | Power Management Controller                             | PMC           | 0x(FF)FF_8100 |
| RCM                  | Reset Control Module                                    | RCM           | 0x(FF)FF_8110 |
| SMC                  | System Mode Controller                                  | SMC           | 0x(FF)FF_8118 |
| OSC                  | OSC Control Register                                    | OSC1          | 0x(FF)FF_8120 |
| OSC                  | OSC Control Register                                    | OSC2          | 0x(FF)FF_8130 |
| UART                 | Universal Asynchronous Receiver/Transmitter (with FIFO) | UART0         | 0x(FF)FF_8140 |
| UART                 | Universal Asynchronous Receiver/Transmitter (with FIFO) | UART1         | 0x(FF)FF_8160 |
| SPI                  | Serial Peripheral Interface (with FIFO)                 | SPI0          | 0x(FF)FF_81A0 |
| SPI                  | Serial Peripheral Interface (without FIFO)              | SPI1          | 0x(FF)FF_81B0 |
| I2C                  | Inter-Integrated IC                                     | I2C0          | 0x(FF)FF_81C0 |
| I2C                  | Inter-Integrated IC                                     | I2C1          | 0x(FF)FF_81D0 |
| I2C                  | Inter-Integrated IC                                     | I2C2          | 0x(FF)FF_81E0 |
| I2C                  | Inter-Integrated IC                                     | I2C3          | 0x(FF)FF_81F0 |
| I2S/SAI              | Inter-IC Sound / Synchronous Audio Interface            | 1280          | 0x(FF)FF_8200 |
| MCG                  | Multipurpose Clock Generator                            | MCG           | 0x(FF)FF_8400 |

Table continues on the next page...

Downloaded from Elcodis.com electronic components distributor

Table 4-4. High Level Peripheral Memory Map (continued)

| Peripheral    | Description                                                               | Instance Name | Base Address  |
|---------------|---------------------------------------------------------------------------|---------------|---------------|
| MTIM16        | 16-Bit Modulo Timer                                                       | MTIM          | 0x(FF)FF_8410 |
| CMT           | Carrier Modulator Transmitter                                             | CMT           | 0x(FF)FF_8420 |
| 2-channel FTM | 2-channel Flex Timer / PWM Module                                         | FTM0          | 0x(FF)FF_8440 |
| 6-channel FTM | 6-channel Flex Timer / PWM Module                                         | FTM1          | 0x(FF)FF_8480 |
| LPTMR         | Low Power Timer                                                           | LPTMR0        | 0x(FF)FF_84C0 |
| LPTMR         | Low Power Timer                                                           | LPTMR1        | 0x(FF)FF_84D0 |
| Flash         | Flash Controller                                                          | FTFL          | 0x(FF)FF_84E0 |
| DAC           | 12-bit Digital-to-Analog Converter                                        | DAC0          | 0x(FF)FF_8500 |
| СМР           | High Speed Analog Comparator (includes mux control and 6-bit DAC control) | CMP0          | 0x(FF)FF_8530 |
| PDB           | Programmable Delay Block                                                  | PDB0          | 0x(FF)FF_8540 |
| CRC           | Cyclic Redundancy Check Generator                                         | CRC           | 0x(FF)FF_8570 |
| ADC           | Successive Approximation Analog-to-Digital Converter (12-bit)             | ADC0          | 0x(FF)FF_8600 |
| VREF          | Voltage Reference                                                         | VREF          | 0x(FF)FF_8670 |
| USBDCD        | USB Charger Detect                                                        | USBDCD        | 0x(FF)FF_8680 |
| USB           | USB Dual Role Controller                                                  | USB0          | 0x(FF)FF_9000 |
| Port Control  | Port I/O Control Module                                                   | PCTLA         | 0x(FF)FF_9200 |
| Port Control  | Port I/O Control Module                                                   | PCTLB         | 0x(FF)FF_9210 |
| Port Control  | Port I/O Control Module                                                   | PCTLC         | 0x(FF)FF_9220 |
| Port Control  | Port I/O Control Module                                                   | PCTLD         | 0x(FF)FF_9230 |
| Port Control  | Port I/O Control Module                                                   | PCTLE         | 0x(FF)FF_9240 |
| Port Control  | Port I/O Control Module                                                   | PCTLF         | 0x(FF)FF_9250 |
|               | Reserved                                                                  |               | 0x(FF)FF_9340 |
| TSI           | Touch Sensing Input                                                       | TSI0          | 0x(FF)FF_9400 |
| RNGB          | Random Number Generator Block                                             | RNGB          | 0x(FF)FF_98C0 |
| DMA           | Direct Memory Access Controller                                           | DMA           | 0x(FF)FF_E400 |
| Mini-FlexBus  | External Memory Interface                                                 | МВ            | 0x(FF)FF_E800 |
| INTC          | V1 ColdFire Interrupt Controller                                          | INTC          | 0x(FF)FF_FFC0 |

All Version 1 ColdFire+ microcontroller devices use an 8-bit peripheral bus. The bus bridge from the ColdFire system bus to the peripheral bus is capable of serializing 16-bit accesses into two 8-bit accesses and 32-bit access into four 8-bit accesses. This approach can speed access to properly aligned peripheral registers. However, not all peripheral registers are aligned to take advantage of this feature.

#### **System Memory Map**

CPU accesses to the parts of the memory map that are marked as unimplemented result in an illegal address reset if CPUCR[ARD] is 0 or result in an address error exception if CPUCR[ARD] is 1. Similarly, in the memory maps for the DMA controller and Mini-FlexBus modules, CPU accesses to unimplemented spaces result in an illegal address reset if CPUCR[ARD] is 0 or result in an address error exception if CPUCR[ARD] is 1. For other slave peripherals with addresses from 0x(FF)FF\_8000 to 0x(FF)FF\_FFFF, CPU accesses do not generate an illegal address reset or exception regardless of the CPUCR[ARD] bit's state.

The lower 32 KB of flash memory and the slave peripherals section of the memory map are most efficiently accessed using the ColdFire absolute short addressing mode. RAM is most efficiently accessed using the A5-relative addressing mode (address register indirect with displacement mode).

# Chapter 5 Clock Distribution

## 5.1 Introduction

The multipurpose clock generator (MCG) module controls which clock source is used to derive the system clocks. The clock generation logic divides the selected clock source into a variety of clock domains, including the clocks for the system bus masters, system bus slaves, and flash memory. The clock generation logic also implements module-specific clock gating to allow granular shutoff of modules.

## 5.2 Clock distribution

The primary clocks for the system are generated from the MCGOUTCLK clock. The clock generation circuitry provides several clock dividers that allow different portions of the device to be clocked at different frequencies. This allows for tradeoffs between performance and power dissipation.

Various modules have module-specific clocks that can be generated from the MCGPLLCLK clock. In addition, there are various other module-specific clocks that have other alternate sources. Clock selection for most modules is controlled by the SOPT registers in the SIM module.

# 5.2.1 High-Level device clocking diagram

The high-level clock diagram is shown below.

#### **Clock distribution**



Figure 5-1. Clocking diagram

# 5.2.2 Device Clock Summary

The following table summarizes the on-chip clocks.

## Table 5-1. Input clocks for the MCG

| MCG External Input clock options | Description                            |
|----------------------------------|----------------------------------------|
| ERCLK2                           | OSC2 Output, Crystal or External Clock |
| IRC (fast and slow)              | Internal reference of the MCG          |

## **Table 5-2. Device Clock Summary**

| Clock name                                          | Run mode                          | VLPR mode                            | Clock source            | Clock is disabled                     |
|-----------------------------------------------------|-----------------------------------|--------------------------------------|-------------------------|---------------------------------------|
|                                                     | clock frequency                   | clock frequency                      |                         | when                                  |
| MCGOUTCLK                                           | Up to 50 MHz                      | Up to 2 MHz                          | MCG                     | In all stop modes                     |
| Core clock (CPUCLK)                                 | Up to 50 MHz                      | Up to 2 MHz                          | System clock            | In wait and all stop modes            |
| System clock<br>(SYSCLK)                            | Up to 50 MHz                      | Up to 2 MHz                          | MCGOUTCLK clock divider | In all stop modes                     |
| Bus clock (BUSCLK)                                  | Up to 25 MHz                      | Up to 1 MHz                          | MCGOUTCLK clock divider | In all stop modes                     |
| Fixed frequency clock (MCGFFCLK)                    | Up to 39.0625 kHz                 | N/A                                  | MCGIRCCLK or<br>ERCLK2  | In all stop modes                     |
| FLL Output clock<br>(MCGFLLCLK)                     | Up to 50 MHz                      | N/A                                  | MCG                     | In all stop modes                     |
| PLL output clock<br>(MCGPLLCLK)                     | Up to 50 MHz                      | N/A                                  | MCG                     | In all stop modes                     |
| Background Debug<br>Controller clock<br>(MCGBDCCLK) | Up to 50 MHz                      | N/A                                  | MCG                     | In all stop modes                     |
| Internal reference<br>(MCGIRCLK)                    | 30-40kHz or 2 MHz                 | 2 MHz only                           | Internal Source         | MCG IRCLKEN disabled,                 |
|                                                     |                                   |                                      |                         | Stop mode and MCG IRSTEN disabled, or |
|                                                     |                                   |                                      |                         | VLPS/LLS/VLLS mode                    |
| External reference                                  | Up to 50 MHz                      | Up to 4 MHz (bypass),                | OSC1                    | OSC1 ERCLKEN1 is                      |
| (ERCLK1)                                            | (bypass),                         | 30-40 kHz (low-range                 |                         | disabled                              |
|                                                     | 30-40 kHz (low-range crystal), or | crystal) or Up to 4 MHz (high-       |                         |                                       |
|                                                     | 4-32 MHz (high-rangecrystal)      | range crystal)                       |                         |                                       |
| External reference                                  | Up to 50 MHz                      | Up to 4 MHz (bypass),                | OSC2                    | OSC2 ERCLKEN2 is                      |
| (ERCLK2)                                            | (bypass),                         | 30-40 kHz (low-range                 |                         | disabled                              |
|                                                     | 30-40 kHz (low-range crystal), or | crystal) or                          |                         |                                       |
|                                                     | 4-32 MHz (high-rangecrystal)      | Up to 4 MHz (high-<br>range crystal) |                         |                                       |
| LPO                                                 | 1 kHz                             | 1 kHz                                | PMC                     | Never                                 |

Table continues on the next page...

#### **Clock distribution**

Table 5-2. Device Clock Summary (continued)

| Clock name                                     | Run mode clock frequency | VLPR mode clock frequency | Clock source                                                                                  | Clock is disabled when           |
|------------------------------------------------|--------------------------|---------------------------|-----------------------------------------------------------------------------------------------|----------------------------------|
| USB clock (USB_CLK)                            | 48 MHz                   | N/A                       | MCGPLLCLK or<br>MCGFLLCLK with<br>fractional clock divider,<br>or<br>USB_CLKIN                | USB OTG is disabled              |
| SAI/I <sup>2</sup> S master clock<br>(SAI_CLK) | Up to 50 MHz             | Up to 2 MHz               | System clock,<br>MCGPLLCLK, with<br>fractional clock divider,<br>ERCLK1 or ERCLK2<br>I2S_MCLK | SAI/I <sup>2</sup> S is disabled |

## 5.2.3 Architecture

Various clocks are generated by dividing the MCGOUTCLK clock:

- Core clock Clocks the ColdFire V1 core
- System clock Clocks the crossbar switch and bus masters directly connected to the crossbar. In addition, this clock is used for UART0 and UART1.
- Bus clock Clocks the bus slaves and peripheral (excluding memories)

In addition to the MCGOUTCLK clock dividers, there are other clock dividers to generate:

- an accurate 48 MHz clock source for the USB OTG Controller
- the SAI/ I<sup>2</sup>S master clock

## 5.2.4 Clock divider requirements

The flash memory's LPBOOT bit of the option byte loaded to the FTFL\_FOPT register controls the reset value of the core clock, system clock, and bus clock dividers. For a definition of LPBOOT and other bits of the option byte, refer to FOPT boot options.

Table 5-3. LPBOOT's effect on clock dividers

| LPBOOT | SIM_CLKDIV0[OUTDI<br>V] | Core/system clock | Bus clock    | Description     |
|--------|-------------------------|-------------------|--------------|-----------------|
| 0      | 0xF                     | Divide by 16      | Divide by 32 | Low power boot  |
| 1      | 0x0                     | Divide by 1       | Divide by 2  | Fast clock boot |

The LPBOOT bit provides the flexibility to select a lower frequency, low power boot option. The flash erased state defaults to fast clocking mode, because where the low power boot (LPBOOT) bit resides in flash is logic 1 in the flash erased state.

To enable the low power boot option, program LPBOOT (in the option byte of the FTFL module's flash configuration field) to 0. During the reset sequence, if LPBOOT is 0, the system is in a slow clock configuration. Upon any system reset, the clock dividers return to this configurable reset state.

# 5.2.5 Clock gating

The clock to each module can be individually gated on and off using the SIM's SCGCx registers. These bits are cleared after any reset, which disables the clock to the corresponding module to conserve power. Prior to initializing a module, set the corresponding bit in SCGCx register to enable the clock. Before turning off the clock, disable the module or place the module in its default configuration.

Turning off the clock for an enabled, working module can produce unexpected behavior.

Any bus access to a peripheral that has its clock disabled generates a bus error.

## 5.2.6 Module clocks

The following table summarizes the clocks associated with each module.

Bus interface clock Module Internal clocks I/O interface clocks Core and system peripherals CPU **CPUCLK CPUCLK** CAU SYSCLK **RNG BUSCLK** DBG **SYSCLK BDM** SYSCLK **MCGBDCCLK EzPort SYSCLK** EZP\_CLK DMA SYSCLK **RAM** SYSCLK Flash (and FlexMemory) **BUSCLK External memory interface** 

Table 5-4. Module clock options

Table continues on the next page...

#### **Clock distribution**

Table 5-4. Module clock options (continued)

| Module                                                                     | Bus interface clock | Internal clocks                       | I/O interface clocks              |
|----------------------------------------------------------------------------|---------------------|---------------------------------------|-----------------------------------|
| Mini-FlexBus                                                               | SYSCLK              |                                       | FB_CLKOUT                         |
| CRC                                                                        | BUSCLK              |                                       |                                   |
|                                                                            | Ti                  | mers                                  |                                   |
| MTIM                                                                       | BUSCLK              | MCGFFCLK, FTM0_CH1, FTM1_CH1          | TMR_CLKIN0 pin,<br>TMR_CLKIN1 pin |
| LPTMR1                                                                     | BUSCLK              | LPO, ERCLK2, ERCLK1 (low), MCGIRCLK   |                                   |
| LPTMR0                                                                     | BUSCLK              | MCGIRCLK, ERCLK1 (low),<br>LPO        |                                   |
| COP                                                                        | BUSCLK              | LPO                                   |                                   |
| FTM0, FTM1                                                                 | SYSCLK              | MCGFFCLK                              | TMR_CLKIN0 pin,<br>TMR_CLKIN1 pin |
| PDB                                                                        | BUSCLK              |                                       |                                   |
| СМТ                                                                        | BUSCLK              |                                       |                                   |
|                                                                            | Ar                  | nalog                                 |                                   |
| ADC                                                                        | BUSCLK              | ERCLK2, ADC asynchronous clock        |                                   |
| VREF                                                                       | BUSCLK              |                                       |                                   |
| CMP                                                                        | BUSCLK              |                                       |                                   |
| DAC                                                                        | BUSCLK              |                                       |                                   |
|                                                                            | Commi               | ınications                            |                                   |
| SPI0, SPI1                                                                 | BUSCLK              |                                       | SPIx_SCLK                         |
| UART0, UART1                                                               | SYSCLK              |                                       |                                   |
| USB                                                                        | SYSCLK              | USB_CLK <sup>1</sup>                  |                                   |
| USB_DCD                                                                    | BUSCLK              |                                       |                                   |
| I <sup>2</sup> C0, I <sup>2</sup> C1, I <sup>2</sup> C2, I <sup>2</sup> C3 | BUSCLK              |                                       |                                   |
| I <sup>2</sup> S/SAI                                                       | BUSCLK              | SAI_MCLK <sup>1</sup>                 | SAI_TX_BCLK,<br>SAI_RX_BCLK       |
| Human-machine interface                                                    |                     |                                       |                                   |
| TSI                                                                        | BUSCLK              | LPO, ERCLK1 (low)<br>ERCLK2, MCGIRCLK |                                   |
| EGPIO                                                                      | BUSCLK              |                                       |                                   |
| RGPIO                                                                      | SYSCLK              |                                       |                                   |
| IRQ                                                                        | BUSCLK              |                                       |                                   |

<sup>1.</sup> See Device Clock Summary.

Internally generated module clocks include:

• ADC asynchronous clock: Internally generated ADC conversion clock

# 5.2.6.1 VLPR Mode Clocking

The clock dividers cannot be changed while in VLPR mode. They must be programmed prior to entering VLPR mode to guarantee the core/system clocks are less than or equal to 2 MHz.

# 5.2.6.2 I<sup>2</sup>S/SAI Clocking

In addition to the bus clock, the I<sup>2</sup>S/SAI module has different clock sources for master clock generation. The maximum frequency of this clock is 50 MHz. The master clock source can be derived from several sources. The options are external crystals OSC1 or OSC2, external pin input, the PLL out clock with a fractional divider, or the SYSCLK with a fractional divider. See the I<sup>2</sup>S module's MCR and MDR register descriptions for details.

## 5.2.6.3 USB Controller Clocking

The USB controller is a bus master attached to the crossbar switch. As such, the USB interface clock is connected to SYSCLK.

#### NOTE

For the USB controller to operate, the minimum interface clock frequency is 16 MHz.

The USB controller also requires a 48 MHz clock. The clock source options appear below.



Figure 5-2. USB 48 MHz Clock Source

**Clock distribution** 

# 5.2.6.4 UART Clocking

UART0 and UART1 modules operate from the core clock, which provides higher performance level for these modules.

## 5.2.6.5 PMC's 1 kHz Clock

The PMC generates a 1 kHz clock that is alive in all modes of operation, including all low power modes (whenever the PMC is powered). This 1 kHz source is commonly called the LPO clock or 1 kHz LPO clock.

This clock feeds the following destinations:

- LPTMR0/LPTMR1
- EGPIO filter
- Touch Sensing Interface
- COP watchdog

# Chapter 6 Reset and Boot

## 6.1 Reset

This section discusses the Reset Control Module (RCM), basic reset mechanisms, and the various sources of reset on the chip. Some modules that cause resets can be configured to cause interrupts instead. Consult the individual peripherals' chapters for more information.

### 6.1.1 MCU reset sources

Resetting the MCU provides a way to start processing from a known set of initial conditions.

When the ColdFire processor exits reset, it fetches initial 32-bit values for the supervisor stack pointer and program counter from locations  $0x(00)00\_0000$  and  $0x(00)00\_0004$ , respectively.

The on-chip peripheral modules are disabled and the non-analog I/O pins are initially configured as disabled. The pins with analog functions assigned to them default to their analog function after reset.

During and following a reset, the input pin associated with the BKGD pin is configured with pullup enabled.

This series of devices has the following sources for reset:

- Power-on reset (POR)
- External RESET pin (PIN)
- COP watchdog (WDOG) timer
- Illegal opcode detect (ILOP)
- Illegal address detect (ILAD)
- Multipurpose Clock Generator loss of clock (LOC)
- Low-voltage detect (LVD)

#### Reset

- Low leakage wakeup (WAKEUP)
- Stop mode acknowledge error (SACKERR)
- EzPort RESET command (EZPT)
- Background debug forced reset (BDFR)

Each of these sources has an associated bit in the system reset status (SRS) registers.

## 6.1.1.1 Power-on reset (POR)

When power is initially applied to the MCU, or when the supply voltage drops below the power-on reset re-arm voltage level (VPOR), the POR circuit causes a POR reset condition.

As the supply voltage rises, the LVD circuit holds the MCU in reset until the supply rises above the LVD low threshold (VLVDL). The RCM's SRS0[POR] and SRS0[LVD] bits are both set following a POR.

# 6.1.1.2 External RESET pin (PIN)

On this series of devices, the  $\overline{RESET}$  pin is multiplexed with GPIO. By default, the  $\overline{RESET}$  function on this pin is enabled. This pin is open drain and has an internal pullup device and an optional digital filter. Asserting  $\overline{RESET}$  low can wake the device from any mode.

#### 6.1.1.2.1 Reset Pin Filter

The RESET pin filter supports filtering from both the 1 kHz LPO clock and the bus clock. A separate filter is implemented for each clock source. In stop and VLPS mode operation, this logic either switches to bypass operation or has continued filtering operation depending on the filtering mode selected.

The RPFC[RSTFLTSS], RPFC[RSTFLTSRW], and RPFW[RSTFLTSEL] fields in the reset control (RCM) register set control this functionality. The filters are asynchronously reset by Chip POR. The reset value for each filter assumes the RESET pin is negated.

The two clock options for the RESET pin filter when the chip is not in low leakage modes are the LPO (1 kHz) and bus clock. For low leakage modes, the LLWU provides control of an optional fixed digital filter running the LPO.

The 1 kHz filter has a fixed filter value of 3. Due to a synchronizer on the input data, there is also some associated latency (2 cycles). As a result, 5 cycles are required to complete a transition from low to high or high to low.

The bus filter should synchronously prime to off (logic 1) when the bus filter is not enabled. The bus clock is used when the filter selects bus clock, and the number of counts is controlled by the RPFW[RSTFLTSEL] field.

# 6.1.1.3 COP watchdog (WDOG) timer

The computer operating properly (COP) watchdog timer monitors the operation of the system by expecting periodic communication from the software. This communication is generally known as servicing (or refreshing) the COP watchdog. If this periodic refreshing does not occur, the watchdog issues a system reset. The COP reset causes the RCM's SRS0[WDOG] bit to set.

# 6.1.1.4 Illegal opcode detect (ILOP)

By default, the V1 ColdFire core generates a MCU reset when attempting to execute an illegal instruction (except for the ILLEGAL opcode), illegal line-A instruction, illegal line-F instruction, or a supervisor instruction while in user mode (privilege violation). You may set the core's CPUCR[IRD] bit to generate the appropriate exception instead of forcing a reset.

#### NOTE

The attempted execution of the STOP instruction is treated as an illegal instruction if entry to stop or wait mode is disabled because the STOPE or WAITE bit is cleared in the SIM's SOPT4 register.

#### NOTE

The attempted execution of the HALT instruction is treated as an illegal instruction if the core's XCSR[ENBDM] bit is cleared.

# 6.1.1.5 Illegal address detect (ILAD)

By default, the V1 ColdFire core generates an MCU reset when detecting an address error, bus error termination, RTE format error, or fault-on-fault condition. If the core's CPUCR[ARD] bit is set, the processor generates the appropriate exception instead of forcing a reset, or simply halts the processor in response to the fault-on-fault condition.

Reset

# 6.1.1.6 Multipurpose Clock Generator loss of clock (LOC)

The MCG module supports an external reference clock.

If the C6[CME] bit in the MCG module is set, the clock monitor is enabled. If the external reference falls below  $f_{loc\_low}$  or  $f_{loc\_high}$ , as controlled by the C2[RANGE] field in the MCG module, the MCU resets. The RCM's SRS0[LOC] bit is set to indicate this reset source.

#### NOTE

This reset source does not cause a reset if the chip is in any stop mode.

# 6.1.1.7 Low voltage detect (LVD)

The chip includes a system for managing low voltage conditions to protect memory contents and control MCU system states during supply voltage variations. The system consists of a power-on reset (POR) circuit and an LVD circuit with a user-selectable trip voltage. The LVD system is always enabled in normal run, wait, or stop mode. The LVD system is disabled when entering VLPx, LLS, or VLLSx modes.

The LVD can be configured to generate a reset upon detection of a low voltage condition by setting the PMC's LVDSC1[LVDRE] bit to 1. The low voltage detection threshold is determined by the PMC's LVDSC1[LVDV] field. After an LVD reset has occurred, the LVD system holds the MCU in reset until the supply voltage has risen above the low voltage detection threshold. The RCM's SRS0[LVD] bit is set following either an LVD reset or POR.

# 6.1.1.8 Low leakage wakeup (WAKEUP)

The LLWU module provides the means for a number of external pins, the RESET pin, and a number of internal peripherals to wake the MCU from low leakage power modes. The LLWU module is functional only in low leakage power modes.

- In LLS mode, only the  $\overline{RESET}$  pin via the LLWU can generate a system reset.
- In VLLSx modes, all enabled inputs to the LLWU can generate a system reset.

After a system reset, the LLWU retains the flags indicating the input source of the last wakeup until the user clears them.

#### NOTE

Some flags are cleared in the LLWU and some flags are required to be cleared in the peripheral module. Refer to the individual peripheral specifications for more information.

# 6.1.1.9 Stop mode acknowledge error (SACKERR)

This reset is generated if the core attempts to enter stop mode, but not all modules acknowledge stop mode within 1025 cycles of the 1 kHz LPO clock.

A module might not acknowledge the entry to stop mode if an error condition occurs. The error can be caused by a failure of an external clock input to a module.

# 6.1.1.10 Background debug forced reset (BDFR)

A host debug system, when connected to the MCU via the BKGD pin, can force a background debug reset by setting the CSR2[BDFR] bit in the ColdFire debug register set. To show that this event was the source of a reset, the RCM's SRS1[BDFR] bit is 1 after the reset.

## 6.1.2 Reset Pin

For all reset sources except a VLLS Wakeup that does not occur via the RESET pin, the RESET pin is driven low by the MCU for at least 128 bus clock cycles and until flash initialization has completed.

After flash initialization has completed, the  $\overline{RESET}$  pin is released, and the internal Chip Reset negates after the  $\overline{RESET}$  pin is pulled high. Keeping the  $\overline{RESET}$  pin asserted externally delays the negation of the internal Chip Reset.

## 6.1.3 MCU Resets

A variety of resets are generated by the MCU to reset different modules.

# 6.1.3.1 POR Only

The POR Only reset asserts on the POR reset source only. It resets the PMC and Register File.

#### Reset

The POR Only reset also causes all other reset types to occur.

# 6.1.3.2 Chip POR not VLLS

The Chip POR not VLLS reset asserts on POR and LVD reset sources. It resets parts of the SMC and SIM. It also resets the LPTMR.

The Chip POR not VLLS reset also causes these resets to occur: Chip POR, Chip Reset not VLLS, and Chip Reset (including Early Chip Reset).

# 6.1.3.3 Chip POR

The Chip POR asserts on POR, LVD, and VLLS Wakeup reset sources. It does not assert on LLS Wakeup via the RESET pin. It resets the Reset Pin Filter registers and parts of the SIM and MCG.

The Chip POR also causes the Chip Reset (including Early Chip Reset) to occur.

## 6.1.3.4 Chip Reset not VLLS

The Chip Reset not VLLS reset asserts on all reset sources except a VLLS Wakeup that does not occur via the RESET pin. It resets parts of the SMC, LLWU, and other modules that remain powered during VLLS mode.

The Chip Reset not VLLS reset also causes the Chip Reset (including Early Chip Reset) to occur.

## 6.1.3.5 Early Chip Reset

The Early Chip Reset asserts on all reset sources. It resets only the flash memory module. It negates before flash memory initialization begins ("earlier" than when the Chip Reset negates).

# 6.1.3.6 Chip Reset

Chip Reset asserts on all reset sources and only negates after flash initialization has completed and the  $\overline{RESET}$  pin has also negated. It resets the remaining modules (the modules not reset by other reset types).

# 6.2 Reset memory map and register descriptions

The reset control module (RCM) registers provide reset status information and reset filter control.

## **RCM** memory map

| Absolute<br>address<br>(hex) | Register name                                | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|------------------------------|----------------------------------------------|--------------------|--------|-------------|------------------|
| FFFF_8110                    | System Reset Status Register 0 (RCM_SRS0)    | 8                  | R      | 82h         | 6.2.1/159        |
| FFFF_8111                    | System Reset Status Register 1 (RCM_SRS1)    | 8                  | R      | 00h         | 6.2.2/161        |
| FFFF_8114                    | Reset Pin Filter Control Register (RCM_RPFC) | 8                  | R/W    | 00h         | 6.2.3/162        |
| FFFF_8115                    | Reset Pin Filter Width Register (RCM_RPFW)   | 8                  | R/W    | 00h         | 6.2.4/163        |
| FFFF_8117                    | Mode Register (RCM_MR)                       | 8                  | R      | 00h         | 6.2.5/164        |

# 6.2.1 System Reset Status Register 0 (RCM\_SRS0)

This register includes read-only status flags to indicate the source of the most recent reset. The reset state of these bits depends on what caused the MCU to reset.

### NOTE

The reset value of this register depends on the reset source:

- POR (including LVD) 0x82
- LVD (without POR) 0x02
- Low leakage wakeup due to RESET pin assertion 0x41
- Low leakage wakeup due to other wakeup sources 0x01
- Other reset a bit is set if its corresponding reset source caused the reset

Address: RCM\_SRS0 is FFFF\_8110h base + 0h offset = FFFF\_8110h



### RCM\_SRS0 field descriptions

| Field | Description    |
|-------|----------------|
| 7     | Power-on reset |
| POR   |                |

Table continues on the next page...

#### Reset memory map and register descriptions

# RCM\_SRS0 field descriptions (continued)

| Field       | Description                                                                                                                                                                                                                                                                                                        |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             | Indicates a reset was caused by the power-on detection logic. Because the internal supply voltage was ramping up at the time, the low-voltage reset (LVD) status bit is also set to indicate that the reset occurred while the internal supply was below the LVD threshold.                                        |
|             | 0 Reset not caused by POR                                                                                                                                                                                                                                                                                          |
|             | 1 Reset caused by POR                                                                                                                                                                                                                                                                                              |
| 6<br>PIN    | External reset pin                                                                                                                                                                                                                                                                                                 |
|             | Indicates a reset was caused by an active-low level on the external RESETpin.                                                                                                                                                                                                                                      |
|             | 0 Reset not caused by external reset pin                                                                                                                                                                                                                                                                           |
|             | 1 Reset caused by external reset pin                                                                                                                                                                                                                                                                               |
| 5<br>WDOG   | Watchdog                                                                                                                                                                                                                                                                                                           |
|             | Indicates a reset was caused by the Computer Operating Properly (COP) watchdog timer timing out. This reset source can be blocked by disabling the COP watchdog: write 00 to the SIM's COPC[COPT] field                                                                                                            |
|             | 0 Reset not caused by watchdog timeout                                                                                                                                                                                                                                                                             |
|             | 1 Reset caused by watchdog timeout                                                                                                                                                                                                                                                                                 |
| 4<br>ILOP   | Illegal opcode                                                                                                                                                                                                                                                                                                     |
| iEOi        | Indicates a reset was caused by an attempt to execute an unimplemented or illegal opcode. The STOP instruction is considered illegal if stop is disabled by ((SOPT4[STOPE] = 0) && (SOPT4[WAITE] = 0)) in the SIM. The HALT instruction is considered illegal if the BDM interface is disabled by XCSR[ENBDM] = 0. |
|             | 0 Reset not caused by an illegal opcode                                                                                                                                                                                                                                                                            |
|             | 1 Reset caused by an illegal opcode                                                                                                                                                                                                                                                                                |
| 3           | Illegal address                                                                                                                                                                                                                                                                                                    |
| ILAD        | Indicates a reset was caused by an attempt to access an illegal address in the memory map.                                                                                                                                                                                                                         |
|             | <ul><li>0 Reset not caused by an illegal access</li><li>1 Reset caused by an illegal access</li></ul>                                                                                                                                                                                                              |
| 2           | Loss-of-clock reset                                                                                                                                                                                                                                                                                                |
| LOC         | Indicates a reset was caused by a loss of external clock. The MCG clock monitor must be enabled for a loss of clock to be detected. Refer to the detailed MCG description for information on enabling the clock monitor.                                                                                           |
|             | Reset not caused by a loss of external clock.                                                                                                                                                                                                                                                                      |
|             | 1 Reset caused by a loss of external clock.                                                                                                                                                                                                                                                                        |
| 1<br>LVD    | Low-voltage detect reset                                                                                                                                                                                                                                                                                           |
|             | If the LVDRE bit is set and the supply drops below the LVD trip voltage, an LVD reset occurs. This bit is also set by POR.                                                                                                                                                                                         |
|             | 0 Reset not caused by LVD trip or POR                                                                                                                                                                                                                                                                              |
|             | 1 Reset caused by LVD trip or POR                                                                                                                                                                                                                                                                                  |
| 0<br>WAKEUP | Low leakage wakeup reset                                                                                                                                                                                                                                                                                           |

Table continues on the next page...

## RCM\_SRS0 field descriptions (continued)

| Field | Description                                                                                                                                                                                                                                                                                              |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | Indicates a reset was caused by an enabled LLWU module wakeup source while the chip was in a low leakage mode. In LLS mode, the RESET pin is the only wakeup source that can cause this reset. Any enabled wakeup source in a VLLSx mode causes a reset. This bit is cleared by any reset except WAKEUP. |
|       | Reset not caused by LLWU module wakeup source     Reset caused by LLWU module wakeup source                                                                                                                                                                                                              |

# 6.2.2 System Reset Status Register 1 (RCM\_SRS1)

This register includes read-only status flags to indicate the source of the most recent reset. The reset state of these bits depends on what caused the MCU to reset.

#### NOTE

The reset value of this register depends on the reset source:

- POR (including LVD) 0x00
- LVD (without POR) 0x00
- Low leakage wakeup (LLS mode exit via RESET pin or any exit from VLLSx modes) — 0x00
- Other reset a bit is set if its corresponding reset source caused the reset

Address: RCM\_SRS1 is FFFF\_8110h base + 1h offset = FFFF\_8111h



## **RCM\_SRS1** field descriptions

| Field         | Description                                                                                                                                                                                                                                                                                                                                                                        |
|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>Reserved | This read-only bit is reserved and always has the value zero.                                                                                                                                                                                                                                                                                                                      |
| 6<br>Reserved | This read-only bit is reserved and always has the value zero.                                                                                                                                                                                                                                                                                                                      |
| 5<br>SACKERR  | Stop Mode Acknowledge Error Reset  Indicates a reset was caused, after an attempt to enter stop mode, by a failure of one or more peripherals to acknowledge within approximately one second to enter stop mode.  O Reset not caused by peripheral failure to acknowledge attempt to enter stop mode  Reset caused by peripheral failure to acknowledge attempt to enter stop mode |

Table continues on the next page...

#### Reset memory map and register descriptions

### RCM\_SRS1 field descriptions (continued)

| Field         | Description                                                                                            |
|---------------|--------------------------------------------------------------------------------------------------------|
| 4<br>EZPT     | EzPort Reset                                                                                           |
|               | Indicates a reset was caused by EzPort receiving the RESET command while the device is in EzPort mode. |
|               | 0 Reset not caused by EzPort receiving the RESET command while the device is in EzPort mode            |
|               | 1 Reset caused by EzPort receiving the RESET command while the device is in EzPort mode                |
| 3<br>BDFR     | Background Debug Force Reset                                                                           |
|               | Indicates a reset was caused by the host debugger system setting of CSR2[BDFR] in the ColdFire core.   |
|               | 0 Reset not caused by host debugger system setting of CSR2[BDFR]                                       |
|               | Reset caused by host debugger system setting of CSR2[BDFR]                                             |
| 2<br>Reserved | This read-only bit is reserved and always has the value zero.                                          |
| 1             | This read-only bit is reserved and always has the value zero.                                          |
| Reserved      |                                                                                                        |
| 0<br>Reserved | This read-only bit is reserved and always has the value zero.                                          |

# 6.2.3 Reset Pin Filter Control Register (RCM\_RPFC)

#### **NOTE**

The reset values of bits 2-0 are for Chip POR only. They are unaffected by other reset types.

#### NOTE

The bus clock filter is reset when disabled or when entering stop mode. The LPO filter is reset when disabled or when entering any low leakage stop mode.

Address: RCM\_RPFC is FFFF\_8110h base + 4h offset = FFFF\_8114h



### RCM\_RPFC field descriptions

| Field           | Description                                                        |
|-----------------|--------------------------------------------------------------------|
| 7–3<br>Reserved | This read-only bitfield is reserved and always has the value zero. |

Table continues on the next page...

## RCM\_RPFC field descriptions (continued)

| Field         | Description                                                        |  |  |  |  |
|---------------|--------------------------------------------------------------------|--|--|--|--|
| 2<br>RSTFLTSS | Reset pin filter select in stop mode                               |  |  |  |  |
| 11011 2100    | Selects how the reset pin filter is enabled in stop mode.          |  |  |  |  |
|               | 0 All filtering disabled                                           |  |  |  |  |
|               | 1 LPO clock filter enabled                                         |  |  |  |  |
| 1–0           | Reset pin filter select in run and wait modes                      |  |  |  |  |
| RSTFLTSRW     | Selects how the reset pin filter is enabled in run and wait modes. |  |  |  |  |
|               | 00 All filtering disabled                                          |  |  |  |  |
|               | 01 Bus clock filter enabled for normal operation                   |  |  |  |  |
|               | 10 LPO clock filter enabled for normal operation                   |  |  |  |  |
|               | 11 Reserved (all filtering disabled)                               |  |  |  |  |

# 6.2.4 Reset Pin Filter Width Register (RCM\_RPFW)

The reset values of the bits in the RSTFLTSEL field are for Chip POR only. They are unaffected by other reset types.

Address: RCM\_RPFW is FFFF\_8110h base + 5h offset = FFFF\_8115h



## **RCM\_RPFW** field descriptions

| Field            | Description                                                        |  |  |  |  |
|------------------|--------------------------------------------------------------------|--|--|--|--|
| 7–5<br>Reserved  | This read-only bitfield is reserved and always has the value zero. |  |  |  |  |
| 4–0<br>RSTFLTSEL | Reset pin filter bus clock select                                  |  |  |  |  |
|                  | Selects the reset pin bus clock filter width.                      |  |  |  |  |
|                  | 00000 Bus clock filter count is 1                                  |  |  |  |  |
|                  | 00001 Bus clock filter count is 2                                  |  |  |  |  |
|                  | 00010 Bus clock filter count is 3                                  |  |  |  |  |
|                  | 00011 Bus clock filter count is 4                                  |  |  |  |  |
|                  | 00100 Bus clock filter count is 5                                  |  |  |  |  |
|                  | 00101 Bus clock filter count is 6                                  |  |  |  |  |
|                  | 00110 Bus clock filter count is 7                                  |  |  |  |  |
|                  | 00111 Bus clock filter count is 8                                  |  |  |  |  |
|                  | 01000 Bus clock filter count is 9                                  |  |  |  |  |

Table continues on the next page...

#### Reset memory map and register descriptions

## **RCM\_RPFW** field descriptions (continued)

| Field | Description |                              |  |  |  |  |
|-------|-------------|------------------------------|--|--|--|--|
|       | 01001       | Bus clock filter count is 10 |  |  |  |  |
|       | 01010       | Bus clock filter count is 11 |  |  |  |  |
|       | 01011       | Bus clock filter count is 12 |  |  |  |  |
|       | 01100       | Bus clock filter count is 13 |  |  |  |  |
|       | 01101       | Bus clock filter count is 14 |  |  |  |  |
|       | 01110       | Bus clock filter count is 15 |  |  |  |  |
|       | 01111       | Bus clock filter count is 16 |  |  |  |  |
|       | 10000       | Bus clock filter count is 17 |  |  |  |  |
|       | 10001       | Bus clock filter count is 18 |  |  |  |  |
|       | 10010       | Bus clock filter count is 19 |  |  |  |  |
|       | 10011       | Bus clock filter count is 20 |  |  |  |  |
|       | 10100       | Bus clock filter count is 21 |  |  |  |  |
|       | 10101       | Bus clock filter count is 22 |  |  |  |  |
|       | 10110       | Bus clock filter count is 23 |  |  |  |  |
|       | 10111       | Bus clock filter count is 24 |  |  |  |  |
|       | 11000       | Bus clock filter count is 25 |  |  |  |  |
|       | 11001       | Bus clock filter count is 26 |  |  |  |  |
|       | 11010       | Bus clock filter count is 27 |  |  |  |  |
|       | 11011       | Bus clock filter count is 28 |  |  |  |  |
|       | 11100       | Bus clock filter count is 29 |  |  |  |  |
|       | 11101       | Bus clock filter count is 30 |  |  |  |  |
|       | 11110       | Bus clock filter count is 31 |  |  |  |  |
|       | 11111       | Bus clock filter count is 32 |  |  |  |  |

# 6.2.5 Mode Register (RCM\_MR)

This register includes read-only status flags to indicate the state of the mode pins during the last Chip Reset.

Address: RCM\_MR is FFFF\_8110h base + 7h offset = FFFF\_8117h



## **RCM\_MR** field descriptions

| Field           | Description                                                                         |
|-----------------|-------------------------------------------------------------------------------------|
| 7–2<br>Reserved | This read-only bitfield is reserved and always has the value zero.                  |
| 1<br>EZP_MS     | EZP_MS_B pin state  Reflects the state of the EZP_MS pin during the last Chip Reset |

Table continues on the next page...

## RCM\_MR field descriptions (continued)

| Field   | Description                                                 |  |  |  |  |
|---------|-------------------------------------------------------------|--|--|--|--|
|         | 0 Pin negated (logic 1)                                     |  |  |  |  |
|         | 1 Pin asserted (logic 0)                                    |  |  |  |  |
| 0<br>MS | MS_B pin state                                              |  |  |  |  |
| 0       | Reflects the state of the MS pin during the last Chip Reset |  |  |  |  |
|         | 0 Pin negated (logic 1)                                     |  |  |  |  |
|         | 1 Pin asserted (logic 0)                                    |  |  |  |  |

## 6.3 Boot

The boot description includes information about boot sources and boot options available in the MCU.

## 6.3.1 Boot sources

The chip only supports booting from internal flash. Any secondary boot must go through an initialization sequence in flash.

# 6.3.2 Boot options

The device's functional mode is controlled by the two mode select (MS) pins, which have the following relative priority:

- 1. The BKGD/MS pin is used to select between active background debug mode (BDM) and single chip modes.
- 2. The EZP\_MS pin selects between EzPort serial flash programming mode and single chip mode.

The mode select functionality on these pins does not depend on the pin muxing setting of the pins. Upon power on reset, these pins are analyzed and the different modes are entered depending on the level provided on these pins.

By default, the device comes out of reset in functional mode. In functional mode, the device will be in single chip (default) mode. While in single chip mode only, the device can be in run mode or various low power modes described in Modes of Operation.

Table 6-7. BKGD/MS mode select decoding

| Mode select (BKGD/MS) | Description                        |  |  |
|-----------------------|------------------------------------|--|--|
| 0                     | Active background debug mode (BDM) |  |  |
| 1                     | Single chip (default)              |  |  |

Table 6-8. EZP\_MS mode select decoding

| Mode select (EZP_MS) | Description                            |  |  |
|----------------------|----------------------------------------|--|--|
| 0                    | Serial flash programming mode (EzPort) |  |  |
| 1                    | Single chip (default)                  |  |  |

# 6.3.3 FOPT boot options

The flash option (FOPT) register in the flash memory module (FTFL) allows the user to customize the operation of the MCU at boot time. The register contains read-only bits that are loaded from the NVM's option byte in the flash configuration field. The user can reprogram the option byte in flash to change the FOPT values that are used for subsequent resets. For more details on programming the option byte (OPT field), refer to the detailed description of the flash memory module.

The MCU uses the FTFL\_FOPT register bits to configure the device at reset as shown in the following table.

Table 6-9. Flash Option Register (FTFL\_FOPT) Bit Definitions

| Bit Num Field |            | Value | Definition                                                                                                                                                                                         |  |  |
|---------------|------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 7-2           | Reserved   |       | Reserved for future expansion.                                                                                                                                                                     |  |  |
| 1             | EZPORT_DIS | 0     | EzPort operation is disabled. If the device boots with the EZP_MS signal low, then the device boots in normal mode. This mode might be desired if the EZP_MS/IRQ pin is used for its IRQ function. |  |  |
|               |            | 1     | EzPort operation is enabled. The state of the EZP_MS pin during reset determines whether the device enters EzPort mode.                                                                            |  |  |

Table continues on the next page...

Table 6-9. Flash Option Register (FTFL\_FOPT) Bit Definitions (continued)

| Bit Num | Field  | Value | Definition                                                                                                                                                                                              |
|---------|--------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0       | LPBOOT | 0     | Low-power boot: At reset exit, the OUTDIV field's value in the SIM_CLKDIV0 register is auto-configured to 0xF for higher divide values (divide by 16) to produce lower power consumption at reset exit. |
|         |        | 1     | Normal boot: At reset exit, the OUTDIV field's value in the SIM_CLKDIV0 register is auto-configured to 0x0 for lower divide values (divide by 1) to produce faster operating frequencies at reset exit. |

# 6.3.4 Boot sequence

At power up, the on-chip regulator holds the system in a POR state until the input supply is above the POR threshold. The system continues to be held in this static state until the internally regulated supplies have reached a safe operating voltage as determined by the LVD. The Mode Controller reset logic then controls a sequence to exit reset.

- 1. A system reset is held on internal logic, the RESET pin is driven out low, and the MCG is enabled in its default clocking mode.
- 2. Required clocks are enabled: Core Clock, System Clock, and any Bus Clocks that do not have clock gate control.
- 3. The system reset on internal logic continues to be held, but the Flash Controller is released from reset and begins initialization operation while the Mode Control logic continues to drive the RESET pin out low for a count of ~128 Bus Clock cycles.
- 4. The RESET pin and system reset on internal logic continues to be asserted while the Flash Controller continues initialization.
  - a. Active background debug mode (BDM) will be selected instead of normal CPU execution if BKGD/MS is pulled low at the end of the RESET drive out low.
  - b. If BDM is not selected, EzPort mode will be selected instead of normal CPU execution if EZP\_MS is pulled low at the end of the RESET drive out low. EzPort mode can be disabled if the EZPORT\_DIS bit of the option byte loaded to the FTFL\_FOPT register is configured for the disabled setting.
- 5. During flash initialization, clocking is switched to a slow clock if the LPBOOT bit of the option byte loaded to the FTFL\_FOPT register is configured for low power boot.

#### **Boot**

- 6. When flash initialization completes, the  $\overline{RESET}$  pin is released. After the  $\overline{RESET}$  pin is released, if RESET continues to be asserted (an indication of a slow rise time on the  $\overline{RESET}$  pin or external drive in low), the system continues to be held in reset. After the RESET pin is detected high, the system is released from reset.
- 7. When the system exits reset, the processor fetches initial 32-bit values for the supervisor stack pointer and program counter (PC) from the locations 0x(00)00 0000and 0x(00)00\_0004, respectively. The CPU begins execution at the PC location. At this time:
  - a. If active background debug mode was latched during the sequence, BDM is entered instead of normal CPU execution.
  - b. If BDM was not latched but EzPort mode was latched during the sequence, EzPort mode is entered instead of normal CPU execution.
- 8. If FlexNVM is enabled, the Flash Controller continues to restore the FlexNVM data. This data is not available immediately out of reset, and the system should not access this data until the Flash Controller completes this initialization step as indicated by the EEERDY flag.

Subsequent system resets follow this reset flow beginning with the step where system clocks are enabled.

# **Chapter 7 Power Management**

## 7.1 Introduction

This chapter describes the various MCU power modes and functionality of the individual modules in these modes.

## 7.2 Power modes

The V1 ColdFire CPU has two primary modes of operation, run and stop. The STOP instruction can invoke both stop and wait modes. The CPU does not differentiate between stop and wait modes. Stop, wait, and run are augmented in a number of ways to provide a lower power MCU based on application needs.

The System Mode Controller (SMC) module in ColdFire+ device families provides multiple power options. The Very Low Power Run (VLPR) operating mode can reduce runtime power when maximum processor frequency is not required. Corresponding wait and stop modes are the Very Low Power Wait (VLPW) and Very Low Power Stop (VLPS) modes.

Depending on the stop requirements of the user application, a variety of stop modes are available that provide state retention, partial power down, or full power down of certain logic and/or memory. I/O states are held in all modes of operation. The following table compares the various power modes available.

Table 7-1. MCU power modes

| Power mode  | Description                                                                 | Normal recovery method |  |
|-------------|-----------------------------------------------------------------------------|------------------------|--|
| Normal run  | Allows maximum performance of MCU.                                          | -                      |  |
| Normal wait | Allows peripherals to function while allowing CPU to sleep, reducing power. | Interrupt              |  |

Table continues on the next page...

Table 7-1. MCU power modes (continued)

| Power mode                        | r mode Description                                                                                                                                               |                |
|-----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| Normal stop                       | Places MCU in static state. Lowest power mode that retains all registers while maintaining LVD protection.                                                       | Interrupt      |
| VLPR (Very Low Power<br>Run)      | Regulator in low power mode, LVD off. Internal regulator provides low power; maximum 2 MHz clock source to core and 1 MHz to peripherals and flash. <sup>1</sup> | Interrupt      |
| VLPW (Very Low Power Wait)        | Similar to VLPR, with CPU in sleep to further reduce power.                                                                                                      | Interrupt      |
| VLPS (Very Low Power<br>Stop)     | Places MCU in static state, with LVD operation off. Lowest power mode with ADC and pin interrupts functional. LPTMRs, TSI, CMP, 12-bit DAC functional.           | Interrupt      |
| LLS (Low Leakage Stop)            | State retention power mode. LLWU, LPTMRs, TSI, CMP, 12-bit DAC functional. All RAM powered.                                                                      | LLWU interrupt |
| VLLS3 (Very Low Leakage<br>Stop3) | LLWU, LPTMRs, TSI, CMP, 12-bit DAC functional. All RAM powered.                                                                                                  | Wakeup reset   |
| VLLS2 (Very Low Leakage<br>Stop2) | LLWU, LPTMRs, TSI, CMP, 12-bit DAC functional. Portion of RAM powered off.                                                                                       | Wakeup reset   |
| VLLS1 (Very Low Leakage<br>Stop1) | LLWU, LPTMRs, TSI, CMP, 12-bit DAC functional. All RAM powered off.                                                                                              | Wakeup reset   |

<sup>1.</sup> Some peripherals, such as the UARTs, use the system clock.

For additional information, refer to Power Mode Transitions.

# 7.3 Module Operation in Low Power Modes

The following table illustrates the available functionality of each module while the MCU is in each of the low power modes (stop, VLPx, LLS, and VLLSx).

Table 7-2. Module operation in low power modes

| Module            | STOP               | VLPR             | VLPW             | VLPS    | LLS     | VLLSx   |  |
|-------------------|--------------------|------------------|------------------|---------|---------|---------|--|
|                   | System peripherals |                  |                  |         |         |         |  |
| CPU clock         | OFF                | 2 MHz<br>maximum | OFF              | OFF     | OFF     | OFF     |  |
| Bus clock         | OFF                | 1 MHz<br>maximum | 1 MHz<br>maximum | OFF     | OFF     | OFF     |  |
| LLWU <sup>1</sup> | Static             | Static           | Static           | Static  | FF      | FF      |  |
| Register file     | Powered            | Powered          | Powered          | Powered | Powered | Powered |  |
| DMA               | Static             | FF               | FF               | Static  | Static  | OFF     |  |
| Power management  |                    |                  |                  |         |         |         |  |
| PMC/SMC/RCM       | FF                 | FF               | FF               | FF      | FF      | FF      |  |
| LVD               | ON                 | OFF              | OFF              | OFF     | OFF     | OFF     |  |

Table continues on the next page...

Table 7-2. Module operation in low power modes (continued)

| Module                                     | STOP                                                       | VLPR                                          | VLPW                           | VLPS                             | LLS                     | VLLSx                                                      |  |
|--------------------------------------------|------------------------------------------------------------|-----------------------------------------------|--------------------------------|----------------------------------|-------------------------|------------------------------------------------------------|--|
| Regulator                                  | ON                                                         | Low power                                     | Low power                      | Low power                        | Low power               | Low power                                                  |  |
| VREG                                       | Optional                                                   | Optional                                      | Optional                       | Optional                         | Optional                | Optional                                                   |  |
| Memory and memory interfaces               |                                                            |                                               |                                |                                  |                         |                                                            |  |
| Flash                                      | Low power                                                  | 1 MHz<br>maximum<br>access; no<br>programming | Low power                      | Low power                        | Low power               | OFF                                                        |  |
| RAM1: 1 KB<br>and periphery                | Low power                                                  | Powered / low<br>power (toggles)              | Low power                      | Low power                        | Low power               | Low power in<br>VLLS3 and<br>VLLS2                         |  |
| RAM2: 7 KB                                 | Low power                                                  | Low power                                     | Low power                      | Low power                        | Low power               | Low power in<br>VLLS3,<br>optionally low<br>power in VLLS2 |  |
| RAM3: 0 KB, 8<br>KB, or 24 KB <sup>2</sup> | Low power                                                  | Low power                                     | Low power                      | Low power                        | Low power               | Low power in<br>VLLS3                                      |  |
| FlexMemory                                 | Low power                                                  | Low power <sup>3</sup>                        | Low power                      | Low power                        | Low power               | OFF <sup>4</sup>                                           |  |
| Mini-FlexBus                               | Static                                                     | FF                                            | FF                             | Static                           | Static                  | OFF                                                        |  |
| EzPort                                     | Static                                                     | Static                                        | Static                         | Static                           | Static                  | OFF                                                        |  |
|                                            |                                                            |                                               | Clocks                         |                                  |                         |                                                            |  |
| MCG                                        | Static: IRC<br>optional; PLL<br>optionally on<br>but gated | 2 MHz IRC <sup>5</sup>                        | 2 MHz IRC                      | Static: no clock output          | Static: no clock output | OFF                                                        |  |
| OSCx (high range)                          | ERCLK optional                                             | ERCLK limited to 4 MHz crystal                | ERCLK limited to 4 MHz crystal | ERCLK limited to 4 MHz crystal   | ERCLK optional          | ERCLK optional                                             |  |
| OSCx (32 kHz)                              | FF                                                         | FF                                            | FF                             | FF                               | FF                      | FF                                                         |  |
| 1 kHz LPO                                  | ON                                                         | ON                                            | ON                             | ON                               | ON                      | ON                                                         |  |
|                                            |                                                            | Syster                                        | m security and in              | tegrity                          |                         |                                                            |  |
| CRC                                        | Static                                                     | FF                                            | FF                             | Static                           | Static                  | OFF                                                        |  |
| RNGB and CAU                               | Static                                                     | FF                                            | Static                         | Static                           | Static                  | OFF                                                        |  |
| СОР                                        | Static                                                     | FF                                            | FF                             | Static                           | Static                  | OFF                                                        |  |
| Analog                                     |                                                            |                                               |                                |                                  |                         |                                                            |  |
| 12-bit ADC                                 | ADC internal clock only                                    | FF                                            | FF                             | ADC internal clock only          | Static                  | OFF                                                        |  |
| СМР                                        | HS or LS<br>compare <sup>6</sup>                           | FF                                            | FF                             | HS or LS<br>compare <sup>6</sup> | LS compare <sup>7</sup> | LS compare <sup>7</sup>                                    |  |
| 6-bit DAC (integrated with CMP)            | Static                                                     | FF                                            | FF                             | Static                           | Static                  | Static                                                     |  |
| VREF                                       | FF                                                         | FF                                            | FF                             | FF                               | Static                  | OFF                                                        |  |

Table continues on the next page...

#### **Module Operation in Low Power Modes**

Table 7-2. Module operation in low power modes (continued)

| Module                        | STOP                                | VLPR                                                     | VLPW                                                                  | VLPS                           | LLS                     | VLLSx                |  |  |
|-------------------------------|-------------------------------------|----------------------------------------------------------|-----------------------------------------------------------------------|--------------------------------|-------------------------|----------------------|--|--|
| 12-bit DAC                    | Static                              | FF                                                       | FF                                                                    | Static                         | Static                  | Static               |  |  |
| Timers                        |                                     |                                                          |                                                                       |                                |                         |                      |  |  |
| FTM                           | Static                              | FF                                                       | FF                                                                    | Static                         | Static                  | OFF                  |  |  |
| MTIM                          | Static                              | FF                                                       | FF                                                                    | Static                         | Static                  | OFF                  |  |  |
| PDB                           | Static                              | FF                                                       | FF                                                                    | Static                         | Static                  | OFF                  |  |  |
| LPTMR                         | FF                                  | FF                                                       | FF                                                                    | FF                             | FF                      | FF                   |  |  |
| СМТ                           | Static                              | FF                                                       | FF                                                                    | Static                         | Static                  | OFF                  |  |  |
| Communication interfaces      |                                     |                                                          |                                                                       |                                |                         |                      |  |  |
| UART                          | Static, wakeup on edge              | 125 kbps                                                 | 125 kbps                                                              | Static, wakeup on edge         | Static                  | OFF                  |  |  |
| SPI                           | Static                              | 500 kbps in<br>master mode,<br>250 kbps in<br>slave mode | 500 kbps in<br>master mode,<br>250 kbps in<br>slave mode <sup>8</sup> | Static                         | Static                  | OFF                  |  |  |
| I <sup>2</sup> C              | Static, address match wakeup        | 50 kbps                                                  | 50 kbps                                                               | Static, address match wakeup   | Static                  | OFF                  |  |  |
| USB FS/LS                     | Static                              | Static                                                   | Static                                                                | Static                         | Static                  | OFF                  |  |  |
| USB DCD                       | Static                              | FF                                                       | FF                                                                    | Static                         | Static                  | OFF                  |  |  |
| I <sup>2</sup> S/SAI          | FF with external clock <sup>9</sup> | Maximum 2<br>Mbps                                        | Maximum 2<br>Mbps                                                     | Maximum 2<br>Mbps <sup>9</sup> | Static                  | OFF                  |  |  |
| Human-machine interface (HMI) |                                     |                                                          |                                                                       |                                |                         |                      |  |  |
| EGPIO                         | Wakeup                              | FF                                                       | FF                                                                    | Wakeup                         | Static, pins<br>latched | OFF, pins<br>latched |  |  |
| RGPIO                         | Static                              | FF                                                       | FF                                                                    | Static                         | Static                  | OFF                  |  |  |
| TSI                           | Wakeup                              | FF                                                       | FF                                                                    | Wakeup                         | Wakeup <sup>10</sup>    | Wakeup <sup>10</sup> |  |  |
| IRQ                           | Wakeup                              | FF                                                       | FF                                                                    | Wakeup                         | Static, pins latched    | OFF, pins<br>latched |  |  |

- Using the LLWU module, the external pins available for this MCU do not require the associated peripheral function to be enabled. The only requirement is for the function controlling the pin (GPIO or peripheral) to be configured as an input to allow a transition to occur to the LLWU.
- 2. For the RAM3 size on a particular device, refer to RAM sizes.
- 3. In VLPR mode, FlexRAM enabled as EEPROM is not writable (writes are ignored) but can be read. There are no access restrictions in VLPR mode for FlexRAM configured as traditional RAM.
- 4. FlexRAM is always powered off in VLLSx modes.
- 5. Before executing an entry to VLPR mode, the MCG must be in one of two of its operating modes, each with a particular clock source selected:
  - Either the MCG must be in its BLPE operating mode with only the low gain oscillator selected, or
  - The MCG must be in its BLPI operating mode with only the 2 MHz IRC selected.
- 6. The CMP in stop or VLPS mode supports high speed or low speed, external pin-to-pin or external pin-to-DAC compares. Windowed, sampled, and filtered modes of operation are not available in stop, VLPS, LLS, or VLLSx modes.
- 7. The CMP in LLS or VLLSx mode supports only low speed, external pin-to-pin or external pin-to-DAC compares. Windowed, sampled, and filtered modes of operation are not available in stop, VLPS, LLS, or VLLSx modes.
- 8. The SPISWAI bit must be cleared for master mode operation in wait modes.
- 9. Use an externally generated bit clock or an externally generated audio master clock (including EXTAL).
- 10. TSI wakeup from LLS and VLLSx modes is limited to a single selectable pin.

#### **NOTE**

- *ON* means the module is operational by default in the designated power mode.
- FF means "full functionality." The user has the option to enable the module's operation in the designated power mode. In VLPR and VLPW modes, the system frequency might limit some modules.
- *Static* means the digital modules' register states and associated memories are held.
- Powered means memory is powered to retain contents.
- Low power means flash has a low power state that retains configuration registers to support faster wakeup.
- Wakeup means the module can serve as a wakeup source for the chip. For more information, refer to the LLWU module's dedicated chapter and to its Chip Configuration details.
- *OFF* means the module is powered off and is in a reset state upon wakeup.



# Chapter 8 Security

## 8.1 Introduction

The device implements security based on the mode selected from the flash module. The following sections provide an overview of flash security and of the effects of security on non-flash modules.

# 8.2 Flash Security

The flash module provides security information to the MCU based on the state held by the flash memory (FTFL) module's FSEC[SEC] bits. The MCU, in turn, confirms the security request and limits access to flash resources. During reset, the flash module initializes the FSEC register using data read from the security byte of the flash configuration field. For more information, refer to the Flash Configuration Field Description.

#### NOTE

The security features apply only to external accesses via debug and EzPort. CPU accesses to the flash are not affected by the status of FSEC.

In the unsecured state, all flash commands are available to the programming interfaces (BDM and EzPort) and so is user code execution of Flash Controller commands. When the flash is secured, programmer interfaces have no access to memory locations and are allowed only to launch mass erase operations.

Further information regarding the flash security options and enabling/disabling flash security is available in the detailed description of the flash memory module. Further information regarding the flash security options and enabling/disabling flash security in BDM is available in the detailed description of V1 ColdFire debug.

#### Flash Security Options 8.3

In addition to enabling and disabling security, the flash security byte configures various security options.

#### 8.3.1 **Backdoor Key Access**

The FSEC[KEYEN] field's setting allows flash security to be disabled temporarily by entering an 8-byte key value.

KEYEN[1:0] **Status of Backdoor Key Access** 00 Disabled 01 Disabled (preferred setting to disable backdoor key access) 10 Enabled 11 Disabled

Table 8-1. Flash Key Enable States

# 8.3.2 Freescale Factory Access

The FSEC[FSLACC] field's setting enables or disables access to flash memory contents during returned part failure analysis at Freescale. When SEC is secure and FSLACC is denied, access to the program flash contents is denied and any failure analysis performed by Freescale factory testing must begin with a full erase operation to unsecure the part.

When access is granted (SEC is unsecure, or SEC is secure and FSLACC is granted), Freescale factory testing has visibility of the current flash memory contents. The state of the FSLACC bits is only relevant when the SEC bits are set to secure. When the SEC field is set to unsecure, the FSLACC setting does not matter.

**Table 8-2. Freescale Factory Access States** 

| FSLACC[1:0] | Freescale Factory Access |
|-------------|--------------------------|
| 00          | Granted                  |
| 01          | Denied                   |
| 10          | Denied                   |
| 11          | Granted                  |

## 8.3.3 Mass Erase Disable

Setting the FSEC[MEEN] field to 10 disables the Mass Erase Command.

This setting only takes effect when the flash memory is in a secure state. In secure mode, ERSALL and RD1ALL are the only commands available, and they are both disabled when the FSEC[MEEN] field is 10.

#### **CAUTION**

Disabling the mass erase capability might be irreversible. Simultaneously setting MEEN to disabled, KEYEN to disabled, and FSLACC to denied effectively locks the current security state permanently and cannot be undone.

MEEN[1:0] Mass Erase Capability

00 Enabled

01 Enabled

10 Disabled

11 Enabled

**Table 8-3. Mass Erase Enable States** 

# 8.4 Enabling Flash Security

Flash security can be enabled by programming the security byte of the flash configuration field. This assumes that flash is currently unsecured and that the region of the P-Flash containing the Flash Configuration Field is unprotected. If the Flash security byte is successfully programmed, its new value will take affect after the next MCU reset.

#### NOTE

Once enabled, the security options cannot be modified without disabling security first. The backdoor key access enable, 8-byte backdoor key, and Freescale access bits should be programmed to the desired settings before enabling security.

# 8.5 Unsecuring the MCU using Backdoor Key Access

The MCU may be unsecured by using the backdoor key access feature, which requires knowledge of the contents of the 8-byte backdoor key value stored in the Flash Configuration Field. If the KEYEN[1:0] bits are in the enabled state, the Verify Backdoor

#### **Unsecuring the MCU using Backdoor Key Access**

Access Key command can be run. This command allows the user to present prospective keys for comparison to the stored keys. If the keys match, the SEC bits in the FSEC register change to unsecure the MCU until the next reset.

#### NOTE

The entire 8-byte key cannot be 0000\_0000\_0000\_0000h or FFFF\_FFFF\_FFFF. These values are not accepted by the Verify Backdoor Access Key command as valid comparison values.

While the Verify Backdoor Access Key command is active, program flash memory is not available for read access and returns invalid data. The user code stored in the program flash memory must have a method of receiving the backdoor keys from an external stimulus. This external stimulus would typically be through one of the on-chip serial ports.

If the KEYEN[1:0] bits are in the enabled state, the MCU can be unsecured by this backdoor key access sequence:

- 1. Execute the Verify Backdoor Access Key command with the 8-byte key value loaded into the flash memory module's FCCOB0 to FCCOB7 registers.
- 2. If the Verify Backdoor Access Key command is successful, the MCU is unsecured and the SEC[1:0] bits in the FSEC register are forced to the unsecure state.
- 3. If the backdoor keys do not match, security is not released, all future attempts to execute the Verify Backdoor Access Key command are immediately aborted, and the ACCERR bit in the FSTAT register is (again) set to 1 until a power-down (cold) reset occurs.

A successful execution of the Verify Backdoor Access Key command changes the security in the FSEC register only; it does not alter the security byte or the keys stored in the Flash Configuration Field. After the next reset of the MCU, the security state of the flash memory module reverts to the value of the flash security byte in the Flash Configuration Field. The Verify Backdoor Access Key command sequence has no effect on the program and erase protections defined in the flash protection (FPROT) registers.

If the backdoor keys successfully match, the unsecured MCU has full control of the contents of the Flash Configuration Field. The MCU may erase the sector containing the Flash Configuration Field, reprogram the flash security byte to the unsecure state, and change the backdoor keys to any desired value.

# 8.6 Unsecuring the MCU using the Erase All Blocks command

The Erase All Blocks operation erases the entirety of the program flash memory, FlexNVM, and FlexRAM used as EEPROM; verifies the erase; and then releases MCU security.

When the chip is in BDM, the functionality of the Erase All Blocks command is also available in an uncommanded fashion using the DGBCR[0] bit. When invoked, this function erases all program flash memory, FlexNVM, and FlexRAM used as EEPROM regardless of the protection settings. This function, like the normal command activation, also initializes all locations in the FlexRAM used as EEPROM to the address FFFFh. If the Flash Erase Verify passes, the routine then releases security by setting the FSEC[SEC] field to the unsecure state.

# 8.7 Security Interactions with other Modules

The flash security settings will be used by the SoC to determine what resources are available. The following sections describe the interactions between modules and the flash security settings or the impact that the flash security has on non-flash modules.

# 8.7.1 Security interactions with Mini-FlexBus

If flash security is enabled, the SOPT6[MBSL] field in the SIM enables/disables off-chip accesses through the Mini-FlexBus interface. The field controls whether both instruction accesses and data accesses are allowed, whether both instruction accesses and data accesses are disallowed, or whether instruction accesses are disallowed while data accesses are allowed.

# 8.7.2 Security interactions with EzPort

When flash memory security is active, the MCU can still boot in EzPort mode. The EzPort module can execute an erase all blocks command (mass erase). The mass erase can be used to disable flash memory security, but all of the flash memory's contents are lost in the process.

# 8.7.3 Security interactions with Debug

When flash memory security is active, the BDM port cannot be used to access the MCU's internal flash memory. Scan chain operations work, but debugging capabilities are disabled so that the debug port cannot read out flash contents.

Although most debug functions are disabled when flash memory security is active, the debug port can be used to execute an erase all blocks command (mass erase).

# **Chapter 9 Signal Multiplexing and Signal Descriptions**

## 9.1 Introduction

To optimize functionality in small packages, pins have several functions available via signal multiplexing. This chapter illustrates which of this device's signals are multiplexed on which external pin.

The Port Mux Control block controls which signal is present on the external pin. Refer to that chapter to find which register controls the operation of a specific pin.

# 9.2 Signal Multiplexing Integration

This section summarizes how the module is integrated into the device. For a comprehensive description of the module itself, see the module's dedicated chapter.



Figure 9-1. Signal multiplexing integration

Table 9-1. Reference links to related information

| Topic             | Related module | Reference         |
|-------------------|----------------|-------------------|
| Full description  | Port control   | Port Mux Control  |
| System memory map |                | System Memory Map |

Table 9-1. Reference links to related information (continued)

| Topic           | Related module    | Reference          |
|-----------------|-------------------|--------------------|
| Clocking        |                   | Clock distribution |
| Register access | Peripheral Bridge |                    |

# 9.3 Port Mux Control Features

Package pins can be programmed for up to sixteen different functions using the mux control registers. Controls are organized by GPIO port. Each GPIO port has four mux control registers, consisting of 4 bits per package pin. All mux registers reset to 00h. Alternate values for each function match the column number in which that function occurs in the pin summary table. That is, default functions are assigned value 00h, ALT1 functions 01h, and so on. Setting the RESERVED setting in the port muxing results in the DEFAULT function for the pin.

#### **CAUTION**

Not all pins described in the port mux are available on every package in the device family. Do not change the port mux control field for pins that do not appear on the device in use. For example, in a 32-pin package, mask the PTCPF1[C6] field when writing to the PTCPF1 register. Changing the port mux control field for such unavailable pins can generate unnecessary current leakage.

Table 9-2. Port mux control registers overview

| Address           | Peripher<br>al | Register | Bit 7 | 6 | 5  | 4 | 3 | 2 | 1          | Bit 0 |
|-------------------|----------------|----------|-------|---|----|---|---|---|------------|-------|
| 0x(FF)FF<br>_8080 | MXC            | PTAPF1   |       | А | 7  |   |   | Α | 16         |       |
| 0x(FF)FF<br>_8081 | MXC            | PTAPF2   |       | А | .5 |   |   | Δ | <b>A</b> 4 |       |
| 0x(FF)FF<br>_8082 | MXC            | PTAPF3   |       | А | .3 |   |   | Д | 12         |       |
| 0x(FF)FF<br>_8083 | MXC            | PTAPF4   |       | А | .1 |   |   | Δ | ۸0         |       |
| 0x(FF)FF<br>_8084 | MXC            | PTBPF1   |       | В | 37 |   |   | Е | 36         |       |
| 0x(FF)FF<br>_8085 | MXC            | PTBPF2   |       | В | 55 |   |   | Е | 34         |       |
| 0x(FF)FF<br>_8086 | MXC            | PTBPF3   |       | В | 3  |   |   | E | 32         |       |

Table 9-2. Port mux control registers overview (continued)

| Address           | Peripher<br>al | Register | Bit 7 | 6 | 5              | 4 | 3 | 2 | 1              | Bit 0 |
|-------------------|----------------|----------|-------|---|----------------|---|---|---|----------------|-------|
| 0x(FF)FF<br>_8087 | MXC            | PTBPF4   |       | E | 31             | • |   | E | 30             |       |
| 0x(FF)FF<br>_8088 | MXC            | PTCPF1   |       | ( | 07             |   |   | C | C6             |       |
| 0x(FF)FF<br>_8089 | MXC            | PTCPF2   |       | ( | C5             |   |   | C | C4             |       |
| 0x(FF)FF<br>_808A | MXC            | PTCPF3   |       | ( | C3             |   |   | C | D2             |       |
| 0x(FF)FF<br>_808B | MXC            | PTCPF4   |       | ( | D1             |   |   | C | 00             |       |
| 0x(FF)FF<br>_808C | MXC            | PTDPF1   |       | Γ | 07             |   |   | Г | 06             |       |
| 0x(FF)FF<br>_808D | MXC            | PTDPF2   |       | Γ | D5             |   |   | Г | 04             |       |
| 0x(FF)FF<br>_808E | MXC            | PTDPF3   |       | Γ | 03             |   |   | Е | 02             |       |
| 0x(FF)FF<br>_808F | MXC            | PTDPF4   |       | Γ | D1             |   |   | Г | 00             |       |
| 0x(FF)FF<br>_8090 | MXC            | PTEPF1   |       | E | <b>E</b> 7     |   |   | E | <b>E</b> 6     |       |
| 0x(FF)FF<br>_8091 | MXC            | PTEPF2   |       | E | <b>5</b>       |   |   | E | <b>E</b> 4     |       |
| 0x(FF)FF<br>_8092 | MXC            | PTEPF3   |       | E | Ξ3             |   |   | E | <b>E</b> 2     |       |
| 0x(FF)FF<br>_8093 | MXC            | PTEPF4   |       | E | ≣1             |   |   | E | Ξ0             |       |
| 0x(FF)FF<br>_8094 | MXC            | PTFPF1   |       | F | 7              |   |   | F | <del>-</del> 6 |       |
| 0x(FF)FF<br>_8095 | MXC            | PTFPF2   |       | F | <del>-</del> 5 |   |   | F | <del>-</del> 4 |       |
| 0x(FF)FF<br>_8096 | MXC            | PTFPF3   |       | F | <del>-</del> 3 |   |   | F | -2             |       |
| 0x(FF)FF<br>_8097 | MXC            | PTFPF4   |       | F | <del>-</del> 1 |   |   | F | -0             |       |

# 9.4 Signal Multiplexing and Pin Assignments

The following table shows the signals available on each pin and the locations of these pins on the devices supported by this document. The Port Mux Control module is responsible for selecting which ALT functionality is available on each pin.

# **NOTE**

- On PTB0, EZP\_MS\_b is active only during reset. Refer to the detailed boot description.
- PTC1 is open drain.

| 64-<br>pin | 48-<br>pin | 44-<br>pin | 32-<br>pin | Default                | ALT0                   | ALT1 | ALT2            | ALT3           | ALT4     | ALT5      | ALT6     | ALT7                         | EzPort  |
|------------|------------|------------|------------|------------------------|------------------------|------|-----------------|----------------|----------|-----------|----------|------------------------------|---------|
| 1          | _          | _          | _          | VDD                    | VDD                    |      |                 |                |          |           |          |                              |         |
| 2          | _          | _          | _          | VSS                    | VSS                    |      |                 |                |          |           |          |                              |         |
| 3          | _          | _          | _          | Disabled               | Disabled               | PTC6 | UART0_TX        | I2C0_SCL       | RGPIO6   | SPI1_MOSI | FBa_AD11 |                              |         |
| 4          | _          | _          | _          | Disabled               | Disabled               | PTC7 | UARTO_RX        | I2C0_SDA       | RGPI07   | SPI1_MISO | FBa_AD12 |                              |         |
| 5          | 1          | _          | _          | Disabled               | Disabled               | PTD0 | UARTO_CT<br>S_b | I2C1_SDA       | RGPIO8   | SPI1_SCLK | FBa_AD13 | I2S0_MCLK<br>/<br>I2S0_CLKIN |         |
| 6          | 2          | _          | _          | Disabled               | Disabled               | PTD1 | UARTO_RT<br>S_b | I2C1_SCL       | RGPIO9   | SPI1_SS   | FBa_AD14 | I2S0_RX_B<br>CLK             |         |
| 7          | 3          | 1          | 1          | Disabled               | Disabled               | PTA0 |                 | I2C2_SCL       | FTM1_CH0 | SPI0_SS   | FBa_AD15 | I2S0_RX_F<br>S               |         |
| 8          | 4          | 2          | 2          | Disabled               | Disabled               | PTA1 |                 | I2C2_SDA       | FTM1_CH1 |           | FBa_AD16 | I2S0_RXD                     |         |
| 9          | 5          | 3          | 3          | Disabled               | Disabled               | PTA2 | UART1_TX        |                | FTM1_CH2 | SPI1_SS   |          |                              |         |
| 10         | 6          | 4          | 4          | Disabled               | Disabled               | PTA3 | UART1_RX        |                | FTM1_CH3 | SPI1_SCLK |          | I2S0_TX_B<br>CLK             | EZP_CLK |
| 11         | 7          | 5          | 5          | ADC0_SE2               | ADC0_SE2               | PTA4 | UART1_CT<br>S_b | I2C2_SCL       | FTM1_CH4 | SPI1_MISO |          | I2S0_TX_F<br>S               | EZP_DI  |
| 12         | 8          | 6          | 6          | ADC0_SE3               | ADC0_SE3               | PTA5 | UART1_RT<br>S_b | I2C2_SDA       | FTM1_CH5 | SPI1_MOSI | CLKOUT   | I2S0_TXD                     | EZP_DO  |
| 13         | 9          | 7          | 7          | VDDA                   | VDDA                   |      |                 |                |          |           |          |                              |         |
| 14         | 10         | 8          | _          | VREFH                  | VREFH                  |      |                 |                |          |           |          |                              |         |
| 15         | 11         | 9          | _          | VREF_OUT               | VREF_OUT               |      |                 |                |          |           |          |                              |         |
| 16         | 12         | 10         | _          | VREFL                  | VREFL                  |      |                 |                |          |           |          |                              |         |
| 17         | 13         | 11         | 8          | VSSA                   | VSSA                   |      |                 |                |          |           |          |                              |         |
| 18         | 14         | 12         | 9          | DAC0_OUT               | DAC0_OUT               |      |                 |                |          |           |          |                              |         |
| 19         | 15         | 13         | 10         | VREGIN                 | VREGIN                 |      |                 |                |          |           |          |                              |         |
| 20         | 16         | 14         | 11         | VOUT33                 | VOUT33                 |      |                 |                |          |           |          |                              |         |
| 21         | 17         | 15         | 12         | USB0_DM                | USB0_DM                |      |                 |                |          |           |          |                              |         |
| 22         | 18         | 16         | 13         | USB0_DP                | USB0_DP                |      |                 |                |          |           |          |                              |         |
| 23         | 19         | 17         | 14         | VSS                    | VSS                    |      |                 |                |          |           |          |                              |         |
| 24         | 20         | 18         | _          | VDD                    | VDD                    |      |                 |                |          |           |          |                              |         |
| 25         | 21         | 19         | 15         | ADC0_SE8/<br>TSI0_CH0  | ADC0_SE8/<br>TSI0_CH0  | PTA6 |                 | LPTMR_AL<br>T1 | FTM_FLT1 | FBa_D7    | FBa_AD17 |                              |         |
| 26         | _          | _          | -          | ADC0_SE9/<br>TSI0_CH1  | ADC0_SE9/<br>TSI0_CH1  | PTD2 | FTM0_QD_<br>PHA | RGPIO10        | FTM0_CH0 |           |          |                              |         |
| 27         | 22         | 20         | -          | ADC0_SE1<br>0/TSI0_CH2 | ADC0_SE1<br>0/TSI0_CH2 | PTD3 | FTM0_QD_<br>PHB | RGPIO11        | FTM0_CH1 | FBa_D6    | FBa_AD0  |                              |         |
| 28         | _          | _          | _          | ADC0_SE1<br>1/TSI0_CH3 | ADC0_SE1<br>1/TSI0_CH3 | PTD4 |                 | RGPIO12        |          |           | FBa_D7   |                              |         |

#### **Chapter 9 Signal Multiplexing and Signal Descriptions**

| 64-<br>pin | 48-<br>pin | 44-<br>pin | 32-<br>pin | Default                     | ALT0                        | ALT1 | ALT2            | ALT3           | ALT4            | ALT5             | ALT6            | ALT7          | EzPort   |
|------------|------------|------------|------------|-----------------------------|-----------------------------|------|-----------------|----------------|-----------------|------------------|-----------------|---------------|----------|
| 29         | _          | _          | _          | ADC0_SE1<br>2/TSI0_CH4      | ADC0_SE1<br>2/TSI0_CH4      | PTD5 |                 | RGPIO13        |                 |                  | FBa_D6          |               |          |
| 30         | 23         | 21         | 16         | ADC0_SE1<br>3/TSI0_CH5      | ADC0_SE1<br>3/TSI0_CH5      | PTA7 | UART0_TX        |                | FTM0_QD_<br>PHA |                  | FBa_D5          |               |          |
| 31         | 24         | 22         | _          | ADC0_SE1<br>4/TSI0_CH6      | ADC0_SE1<br>4/TSI0_CH6      | PTD6 | UARTO_RX        | RGPIO14        |                 |                  | FBa_D4          |               |          |
| 32         | -          | 1          | ı          | ADC0_SE1<br>5/TSI0_CH7      | ADC0_SE1<br>5/TSI0_CH7      | PTD7 | UARTO_CT<br>S_b | I2C3_SCL       | RGPIO15         |                  | FBa_D3          |               |          |
| 33         | _          | _          | _          | TSI0_CH8                    | TSI0_CH8                    | PTE0 | UARTO_RT<br>S_b | I2C3_SDA       |                 |                  | FBa_D2          |               |          |
| 34         | -          | _          | _          | TSI0_CH9                    | TSI0_CH9                    | PTE1 | SPI0_SS         |                | FTM_FLT0        |                  | FBa_D1          |               |          |
| 35         | 25         | 23         | 17         | IRQ/<br>EZP_MS_b            | Disabled                    | PTB0 |                 | I2C0_SCL       |                 | IRQ/<br>EZP_MS_b |                 |               | EZP_CS_b |
| 36         | 26         | 24         | 18         | TSI0_CH10                   | TSI0_CH10                   | PTB1 | SPI0_SCLK       | I2C0_SDA       | FTM_FLT2        | LPTMR_AL<br>T2   | FTM0_QD_<br>PHB | FB_CLKOU<br>T |          |
| 37         | _          | _          | _          | TSI0_CH11                   | TSI0_CH11                   | PTE2 |                 | I2C3_SCL       |                 |                  | FBa_D0          |               |          |
| 38         |            | -          | _          | ADC0_SE1<br>6/<br>TSI0_CH12 | ADC0_SE1<br>6/<br>TSI0_CH12 | PTE3 | SPI0_MOSI       | I2C3_SDA       |                 |                  | FBa_OE_b        |               |          |
| 39         | 27         | 25         | 19         | ADC0_SE1<br>7/<br>TSI0_CH13 | ADC0_SE1<br>7/<br>TSI0_CH13 | PTB2 | SPI0_MISO       |                |                 |                  | FBa_CS0_b       |               |          |
| 40         | 28         | 26         | 20         | ADC0_SE1<br>8/<br>TSI0_CH14 | ADC0_SE1<br>8/<br>TSI0_CH14 | PTB3 | SPI0_MOSI       |                |                 | FBa_CS1_b        | FBa_ALE         |               |          |
| 41         | 29         |            | _          | ADC0_SE1<br>9/<br>TSI0_CH15 | ADC0_SE1<br>9/<br>TSI0_CH15 | PTE4 | UARTO_RT<br>S_b | LPTMR_AL<br>T3 | SPI1_SS         |                  | FBa_AD1         |               |          |
| 42         | 30         | -          | _          | ADC0_SE2                    | ADC0_SE2                    | PTE5 | UARTO_CT<br>S_b | I2C1_SCL       | SPI1_SCLK       |                  | FBa_AD2         |               |          |
| 43         | _          | -          | _          | ADC0_SE2                    | ADC0_SE2                    | PTE6 | UARTO_RX        | I2C1_SDA       | SPI1_MISO       |                  | FBa_AD3         |               |          |
| 44         | 31         | 27         | _          | ADC0_SE2                    | ADC0_SE2                    | PTE7 | UART0_TX        | PDB0_EXT<br>RG | SPI1_MOSI       | FBa_RW_b         | FBa_AD4         |               |          |
| 45         | 32         | 28         | 21         | BKGD/MS                     | Disabled                    | PTB4 | BKGD/MS         |                |                 |                  |                 |               |          |
| 46         | 33         | 29         | 22         | XTAL2                       | XTAL2                       | PTB5 |                 |                |                 |                  |                 |               |          |
| 47         | 34         | 30         | 23         | EXTAL2                      | EXTAL2                      | PTB6 |                 |                |                 |                  |                 |               |          |
| 48         | 35         | 31         | 24         | VDD                         | VDD                         |      |                 |                |                 |                  |                 |               |          |
| 49         | 36         | 32         | 25         | VSS                         | VSS                         |      |                 |                |                 |                  |                 |               |          |
| 50         | 37         | 33         | 26         | EXTAL1                      | EXTAL1                      | PTB7 |                 | I2C1_SDA       | TMR_CLKI<br>N1  |                  |                 |               |          |
| 51         | 38         | 34         | 27         | XTAL1                       | XTAL1                       | PTC0 |                 | I2C1_SCL       | TMR_CLKI<br>N0  | RGPIO0           |                 |               |          |
| 52         | 39         | 35         | 28         | RESET_b                     | Disabled                    | PTC1 | RESET_b         |                |                 |                  |                 |               |          |
| 53         | -          | -          | _          | CMP0_IN0                    | CMP0_IN0                    | PTF0 | SPI0_SS         |                |                 |                  | FBa_AD5         |               |          |
| 54         | -          | -          | -          | Disabled                    | Disabled                    | PTF1 | SPI0_SCLK       |                |                 | CMP0_OUT         | FBa_AD6         |               |          |
| 55         | -          | -          | _          | CMP0_IN1                    | CMP0_IN1                    | PTF2 | SPI0_MISO       |                |                 |                  | FBa_AD7         |               |          |

#### **Pinout diagrams**

| 64-<br>pin | 48-<br>pin | 44-<br>pin | 32-<br>pin | Default  | ALT0     | ALT1 | ALT2            | ALT3      | ALT4      | ALT5           | ALT6              | ALT7                         | EzPort |
|------------|------------|------------|------------|----------|----------|------|-----------------|-----------|-----------|----------------|-------------------|------------------------------|--------|
| 56         | 40         | 36         | _          | CMP0_IN2 | CMP0_IN2 | PTF3 | SPI0_MOSI       |           |           | RGPIO1         | FBa_AD8           | I2S0_TXD                     |        |
| 57         | 41         | 37         | 29         | CMP0_IN3 | CMP0_IN3 | PTC2 | UART1_RT<br>S_b | SPI1_SS   |           | RGPIO2         | FBa_AD18          | I2S0_TX_F<br>S               |        |
| 58         | 42         | 38         | _          | Disabled | Disabled | PTF4 | UART1_CT<br>S_b | SPI1_SCLK |           | FBa_D3         | FBa_AD19          | I2S0_TX_B<br>CLK             |        |
| 59         | 43         | 39         | _          | Disabled | Disabled | PTF5 | UART1_RX        | SPI1_MISO |           | FBa_D2         | FBa_RW_b          | I2S0_RXD                     |        |
| 60         | 44         | 40         | _          | Disabled | Disabled | PTF6 | UART1_TX        | SPI1_MOSI |           | FBa_D1         | FBa_AD9           | I2S0_RX_F<br>S               |        |
| 61         | 45         | 41         | _          | Disabled | Disabled | PTF7 | UARTO_RT<br>S_b |           | SPI0_SS   | FBa_D0         | FBa_AD10          | I2S0_RX_B<br>CLK             |        |
| 62         | 46         | 42         | 30         | Disabled | Disabled | PTC3 | UARTO_CT<br>S_b | RGPIO3    | SPI0_SCLK | CLKOUT         | USB_CLKIN         | I2S0_MCLK<br>/<br>I2S0_CLKIN |        |
| 63         | 47         | 43         | 31         | Disabled | Disabled | PTC4 | UART0_RX        | RGPIO4    | SPI0_MISO | PDB0_EXT<br>RG | USB_SOF_<br>PULSE |                              |        |
| 64         | 48         | 44         | 32         | Disabled | Disabled | PTC5 | UART0_TX        | RGPIO5    | SPI0_MOSI | CMT_IRO        |                   |                              |        |

# 9.5 Pinout diagrams

The following diagrams show pinouts for the 64-pin, 48-pin, 44-pin, and 32-pin packages.

For each pin, the diagrams show the default function or (when disabled is the default) the ALT1 signal for a GPIO function. However, many signals may be multiplexed onto a single pin.



Figure 9-2. 64-pin Laminate QFN (pinout identical for 64-pin LQFP)



Figure 9-3. 48-pin LQFP



Figure 9-4. 44-pin Laminate QFN



Figure 9-5. 32-pin QFN

# 9.6 Module-by-module signals

#### **NOTE**

- On PTB0, EZP\_MS\_b is active only during reset. Refer to the detailed boot description.
- PTC1 is open drain.

Table 9-3. Module signals by GPIO port and pin

| 64-pin | 64-pin 48-pin 44-pin 32-pin Port |  |  |  |  |  |  |  |  |  |  |
|--------|----------------------------------|--|--|--|--|--|--|--|--|--|--|
|        | Power and ground                 |  |  |  |  |  |  |  |  |  |  |
| 1      | VDD                              |  |  |  |  |  |  |  |  |  |  |

Table continues on the next page...

Table 9-3. Module signals by GPIO port and pin (continued)

| 64-pin | 48-pin | 44-pin | 32-pin | Port | Module signal(s)          |
|--------|--------|--------|--------|------|---------------------------|
| 24     | 20     | 18     |        |      | VDD                       |
| 48     | 35     | 31     | 24     |      | VDD                       |
| 2      |        |        |        |      | VSS                       |
| 23     | 19     | 17     | 14     |      | VSS                       |
| 49     | 36     | 32     | 25     |      | VSS                       |
|        |        | Sy     | stem   |      |                           |
| 45     | 32     | 28     | 21     | PTB4 | BKGD/MS                   |
| 12     | 8      | 6      | 6      | PTA5 | CLKOUT                    |
| 62     | 46     | 42     | 30     | PTC3 | CLKOUT                    |
| 10     | 6      | 4      | 4      | PTA3 | EZP_CLK                   |
| 11     | 7      | 5      | 5      | PTA4 | EZP_DI                    |
| 12     | 8      | 6      | 6      | PTA5 | EZP_DO                    |
| 35     | 25     | 23     | 17     | PTB0 | IRQ/EZP_MS_b,<br>EZP_CS_b |
| 52     | 39     | 35     | 28     | PTC1 | RESET_b                   |
|        |        | C      | osc    |      | -                         |
| 50     | 37     | 33     | 26     | PTB7 | EXTAL1                    |
| 47     | 34     | 30     | 23     | PTB6 | EXTAL2                    |
| 51     | 38     | 34     | 27     | PTC0 | XTAL1                     |
| 46     | 33     | 29     | 22     | PTB5 | XTAL2                     |
|        |        | LI     | _WU    |      |                           |
| 4      |        |        |        | PTC7 | LLWU_P0                   |
| 6      | 2      |        |        | PTD1 | LLWU_P1                   |
| 55     |        |        |        | PTF2 | LLWU_P10                  |
| 56     | 40     | 36     |        | PTF3 | LLWU_P11                  |
| 57     | 41     | 37     | 29     | PTC2 | LLWU_P12                  |
| 59     | 43     | 39     |        | PTF5 | LLWU_P13                  |
| 62     | 46     | 42     | 30     | PTC3 | LLWU_P14                  |
| 63     | 47     | 43     | 31     | PTC4 | LLWU_P15                  |
| 12     | 8      | 6      | 6      | PTA5 | LLWU_P2                   |
| 30     | 23     | 21     | 16     | PTA7 | LLWU_P3                   |
| 32     |        |        |        | PTD7 | LLWU_P4                   |
| 35     | 25     | 23     | 17     | PTB0 | LLWU_P5                   |
| 36     | 26     | 24     | 18     | PTB1 | LLWU_P6                   |
| 39     | 27     | 25     | 19     | PTB2 | LLWU_P7                   |

#### Module-by-module signals

Table 9-3. Module signals by GPIO port and pin (continued)

| 64-pin | 48-pin | 44-pin | 32-pin | Port | Module signal(s) |
|--------|--------|--------|--------|------|------------------|
| 44     | 31     | 27     |        | PTE7 | LLWU_P8          |
| 45     | 32     | 28     | 21     | PTB4 | LLWU_P9          |
|        |        | RO     | PIO    |      |                  |
| 51     | 38     | 34     | 27     | PTC0 | RGPIO0           |
| 56     | 40     | 36     |        | PTF3 | RGPIO1           |
| 26     |        |        |        | PTD2 | RGPIO10          |
| 27     | 22     | 20     |        | PTD3 | RGPIO11          |
| 28     |        |        |        | PTD4 | RGPIO12          |
| 29     |        |        |        | PTD5 | RGPIO13          |
| 31     | 24     | 22     |        | PTD6 | RGPIO14          |
| 32     |        |        |        | PTD7 | RGPIO15          |
| 57     | 41     | 37     | 29     | PTC2 | RGPIO2           |
| 62     | 46     | 42     | 30     | PTC3 | RGPIO3           |
| 63     | 47     | 43     | 31     | PTC4 | RGPIO4           |
| 64     | 48     | 44     | 32     | PTC5 | RGPIO5           |
| 3      |        |        |        | PTC6 | RGPIO6           |
| 4      |        |        |        | PTC7 | RGPIO7           |
| 5      | 1      |        |        | PTD0 | RGPIO8           |
| 6      | 2      |        |        | PTD1 | RGPIO9           |
|        |        | LP     | TMR    |      | -                |
| 25     | 21     | 19     | 15     | PTA6 | LPTMR_ALT1       |
| 36     | 26     | 24     | 18     | PTB1 | LPTMR_ALT2       |
| 41     | 29     |        |        | PTE4 | LPTMR_ALT3       |
|        |        | P      | TA     |      |                  |
| 7      | 3      | 1      | 1      | PTA0 | PTA0             |
| 8      | 4      | 2      | 2      | PTA1 | PTA1             |
| 9      | 5      | 3      | 3      | PTA2 | PTA2             |
| 10     | 6      | 4      | 4      | PTA3 | PTA3             |
| 11     | 7      | 5      | 5      | PTA4 | PTA4             |
| 12     | 8      | 6      | 6      | PTA5 | PTA5             |
| 25     | 21     | 19     | 15     | PTA6 | PTA6             |
| 30     | 23     | 21     | 16     | PTA7 | PTA7             |
|        | •      | P      | тв     | •    | '                |
| 35     | 25     | 23     | 17     | PTB0 | PTB0             |
| 36     | 26     | 24     | 18     | PTB1 | PTB1             |
|        |        | 1      | 1      | •    | 1                |

Table 9-3. Module signals by GPIO port and pin (continued)

| 64-pin | 48-pin | 44-pin | 32-pin | Port | Module signal(s) |
|--------|--------|--------|--------|------|------------------|
| 39     | 27     | 25     | 19     | PTB2 | PTB2             |
| 40     | 28     | 26     | 20     | PTB3 | PTB3             |
| 45     | 32     | 28     | 21     | PTB4 | PTB4             |
| 46     | 33     | 29     | 22     | PTB5 | PTB5             |
| 47     | 34     | 30     | 23     | PTB6 | PTB6             |
| 50     | 37     | 33     | 26     | PTB7 | PTB7             |
|        |        | P.     | TC     |      | -                |
| 51     | 38     | 34     | 27     | PTC0 | PTC0             |
| 52     | 39     | 35     | 28     | PTC1 | PTC1             |
| 57     | 41     | 37     | 29     | PTC2 | PTC2             |
| 62     | 46     | 42     | 30     | PTC3 | PTC3             |
| 63     | 47     | 43     | 31     | PTC4 | PTC4             |
| 64     | 48     | 44     | 32     | PTC5 | PTC5             |
| 3      |        |        |        | PTC6 | PTC6             |
| 4      |        |        |        | PTC7 | PTC7             |
|        |        | P.     | TD     | 1    |                  |
| 5      | 1      |        |        | PTD0 | PTD0             |
| 6      | 2      |        |        | PTD1 | PTD1             |
| 26     |        |        |        | PTD2 | PTD2             |
| 27     | 22     | 20     |        | PTD3 | PTD3             |
| 28     |        |        |        | PTD4 | PTD4             |
| 29     |        |        |        | PTD5 | PTD5             |
| 31     | 24     | 22     |        | PTD6 | PTD6             |
| 32     |        |        |        | PTD7 | PTD7             |
|        |        | P'     | TE     |      |                  |
| 33     |        |        |        | PTE0 | PTE0             |
| 34     |        |        |        | PTE1 | PTE1             |
| 38     |        |        |        | PTE3 | PTE2             |
| 39     | 27     | 25     | 19     | PTB2 | PTE3             |
| 41     | 29     |        |        | PTE4 | PTE4             |
| 42     | 30     |        |        | PTE5 | PTE5             |
| 43     |        |        |        | PTE6 | PTE6             |
| 44     | 31     | 27     |        | PTE7 | PTE7             |
|        | -      | P      | TF     |      | 1                |
| 53     |        |        |        | PTF0 | PTF0             |

Table continues on the next page...

#### Module-by-module signals

Table 9-3. Module signals by GPIO port and pin (continued)

| 64-pin | 48-pin | 44-pin | 32-pin | Port | Module signal(s) |
|--------|--------|--------|--------|------|------------------|
| 54     |        |        |        | PTF1 | PTF1             |
| 55     |        |        |        | PTF2 | PTF2             |
| 56     | 40     | 36     |        | PTF3 | PTF3             |
| 58     | 42     | 38     |        | PTF4 | PTF4             |
| 59     | 43     | 39     |        | PTF5 | PTF5             |
| 60     | 44     | 40     |        | PTF6 | PTF6             |
| 61     | 45     | 41     |        | PTF7 | PTF7             |
|        |        | 5 V    | VREG   |      |                  |
| 20     | 16     | 14     | 11     |      | VOUT33           |
| 19     | 15     | 13     | 10     |      | VREGIN           |
|        |        | U      | SB0    |      |                  |
| 62     | 46     | 42     | 30     | PTC3 | USB_CLKIN        |
| 21     | 17     | 15     | 12     |      | USB0_DM          |
| 22     | 18     | 16     | 13     |      | USB0_DP          |
| 20     | 16     | 14     | 11     |      | VOUT33           |
| 19     | 15     | 13     | 10     |      | VREGIN           |
|        |        | Al     | DC0    |      | •                |
| 27     | 22     | 20     |        | PTD3 | ADC0_SE10        |
| 28     |        |        |        | PTD4 | ADC0_SE11        |
| 29     |        |        |        | PTD5 | ADC0_SE12        |
| 30     | 23     | 21     | 16     | PTA7 | ADC0_SE13        |
| 31     | 24     | 22     |        | PTD6 | ADC0_SE14        |
| 32     |        |        |        | PTD7 | ADC0_SE15        |
| 38     |        |        |        | PTE3 | ADC0_SE16        |
| 39     | 27     | 25     | 19     | PTB2 | ADC0_SE17        |
| 40     | 28     | 26     | 20     | PTB3 | ADC0_SE18        |
| 41     | 29     |        |        | PTE4 | ADC0_SE19        |
| 11     | 7      | 5      | 5      | PTA4 | ADC0_SE2         |
| 42     | 30     |        |        | PTE5 | ADC0_SE20        |
| 43     |        |        |        | PTE6 | ADC0_SE21        |
| 44     | 31     | 27     |        | PTE7 | ADC0_SE22        |
| 12     | 8      | 6      | 6      | PTA5 | ADC0_SE3         |
| 25     | 21     | 19     | 15     | PTA6 | ADC0_SE8         |
| 26     |        |        |        | PTD2 | ADC0_SE9         |
| 13     | 9      | 7      | 7      |      | VDDA             |

Table 9-3. Module signals by GPIO port and pin (continued)

| 64-pin | 48-pin | 44-pin     | 32-pin  | Port | Module signal(s)         |
|--------|--------|------------|---------|------|--------------------------|
| 14     | 10     | 8          |         |      | VREFH                    |
| 16     | 12     | 10         |         |      | VREFL                    |
| 17     | 13     | 11         | 8       |      | VSSA                     |
|        |        | D <i>A</i> | AC0     | •    |                          |
| 18     | 14     | 12         | 9       |      | DAC0_OUT                 |
|        |        | VF         | REF     |      |                          |
| 15     | 11     | 9          |         |      | VREF_OUT                 |
|        |        | LPTM       | R-TOD   |      | -                        |
| 50     | 37     | 33         | 26      | PTB7 | EXTAL1                   |
| 47     | 34     | 30         | 23      | PTB6 | EXTAL2                   |
| 25     | 21     | 19         | 15      | PTA6 | LPTMR_ALT1               |
| 36     | 26     | 24         | 18      | PTB1 | LPTMR_ALT2               |
| 41     | 29     |            |         | PTE4 | LPTMR_ALT3               |
| 51     | 38     | 34         | 27      | PTC0 | XTAL1                    |
| 46     | 33     | 29         | 22      | PTB5 | XTAL2                    |
|        |        | CN         | л<br>Р0 |      |                          |
| 53     |        |            |         | PTF0 | CMP0_IN0                 |
| 55     |        |            |         | PTF2 | CMP0_IN1                 |
| 56     | 40     | 36         |         | PTF3 | CMP0_IN2                 |
| 57     | 41     | 37         | 29      | PTC2 | CMP0_IN3                 |
| 54     |        |            |         | PTF1 | CMP0_OUT                 |
|        |        | C          | MT      |      |                          |
| 64     | 48     | 44         | 32      | PTC5 | CMT_IRO                  |
|        |        | 12         | S0      |      |                          |
| 5      | 1      |            |         | PTD0 | I2S0_MCLK/<br>I2S0_CLKIN |
| 62     | 46     | 42         | 30      | PTC3 | 12S0_MCLK/<br>12S0_CLKIN |
| 6      | 2      |            |         | PTD1 | I2S0_RX_BCLK             |
| 61     | 45     | 41         |         | PTF7 | I2S0_RX_BCLK             |
| 7      | 3      | 1          | 1       | PTA0 | I2S0_RX_FS               |
| 60     | 44     | 40         |         | PTF6 | I2S0_RX_FS               |
| 8      | 4      | 2          | 2       | PTA1 | I2S0_RXD                 |
| 59     | 43     | 39         |         | PTF5 | I2S0_RXD                 |
| 10     | 6      | 4          | 4       | PTA3 | I2S0_TX_BCLK             |
| 58     | 42     | 38         |         | PTF4 | I2S0_TX_BCLK             |

Table continues on the next page...

#### Module-by-module signals

Table 9-3. Module signals by GPIO port and pin (continued)

|        |        |        | T      | 1    | 1                         |
|--------|--------|--------|--------|------|---------------------------|
| 64-pin | 48-pin | 44-pin | 32-pin | Port | Module signal(s)          |
| 11     | 7      | 5      | 5      | PTA4 | I2S0_TX_FS                |
| 57     | 41     | 37     | 29     | PTC2 | I2S0_TX_FS                |
| 12     | 8      | 6      | 6      | PTA5 | I2S0_TXD                  |
| 56     | 40     | 36     |        | PTF3 | I2S0_TXD                  |
|        |        | TS     | SI0    |      |                           |
| 25     | 21     | 19     | 15     | PTA6 | TSI0_CH0                  |
| 26     |        |        |        | PTD2 | TSI0_CH1                  |
| 36     | 26     | 24     | 18     | PTB1 | TSI0_CH10                 |
| 37     |        |        |        | PTE2 | TSI0_CH11                 |
| 38     |        |        |        | PTE3 | TSI0_CH12                 |
| 39     | 27     | 25     | 19     | PTB2 | TSI0_CH13                 |
| 40     | 28     | 26     | 20     | PTB3 | TSI0_CH14                 |
| 41     | 29     |        |        | PTE4 | TSI0_CH15                 |
| 27     | 22     | 20     |        | PTD3 | TSI0_CH2                  |
| 28     |        |        |        | PTD4 | TSI0_CH3                  |
| 29     |        |        |        | PTD5 | TSI0_CH4                  |
| 30     | 23     | 21     | 16     | PTA7 | TSI0_CH5                  |
| 31     | 24     | 22     |        | PTD6 | TSI0_CH6                  |
| 32     |        |        |        | PTD7 | TSI0_CH7                  |
| 33     |        |        |        | PTE0 | TSI0_CH8                  |
| 34     |        |        |        | PTE1 | TSI0_CH9                  |
|        |        | P[     | DB0    |      |                           |
| 44     | 31     | 27     |        | PTE7 | PDB0_EXTRG                |
| 63     | 47     | 43     | 31     | PTC4 | PDB0_EXTRG                |
|        |        | FT     | M0     |      |                           |
| 34     |        |        |        | PTE1 | FTM_FLT0                  |
| 25     | 21     | 19     | 15     | PTA6 | FTM_FLT1                  |
| 36     | 26     | 24     | 18     | PTB1 | FTM_FLT2 /<br>FTM0_QD_PHB |
| 26     |        |        |        | PTD2 | FTM0_CH0/<br>FTM0_QD_PHA  |
| 27     | 22     | 20     |        | PTD3 | FTM0_CH1 /<br>FTM0_QD_PHB |
| 30     | 23     | 21     | 16     | PTA7 | FTM0_QD_PHA               |
| 51     | 38     | 34     | 27     | PTC0 | TMR_CLKIN0                |
| 50     | 37     | 33     | 26     | PTB7 | TMR_CLKIN1                |
|        |        |        |        | 1    |                           |

Table 9-3. Module signals by GPIO port and pin (continued)

| 64-pin | 48-pin | 44-pin | 32-pin  | Port | Module signal(s) |
|--------|--------|--------|---------|------|------------------|
|        |        | F.     | TM1     | •    |                  |
| 34     |        |        |         | PTE1 | FTM_FLT0         |
| 25     | 21     | 19     | 15      | PTA6 | FTM_FLT1         |
| 36     | 26     | 24     | 18      | PTB1 | FTM_FLT2         |
| 7      | 3      | 1      | 1       | PTA0 | FTM1_CH0         |
| 8      | 4      | 2      | 2       | PTA1 | FTM1_CH1         |
| 9      | 5      | 3      | 3       | PTA2 | FTM1_CH2         |
| 10     | 6      | 4      | 4       | PTA3 | FTM1_CH3         |
| 11     | 7      | 5      | 5       | PTA4 | FTM1_CH4         |
| 12     | 8      | 6      | 6       | PTA5 | FTM1_CH5         |
| 51     | 38     | 34     | 27      | PTC0 | TMR_CLKIN0       |
| 50     | 37     | 33     | 26      | PTB7 | TMR_CLKIN1       |
|        |        | M      | TIM     | •    |                  |
| 51     | 38     | 34     | 27      | PTC0 | TMR_CLKIN0       |
| 50     | 37     | 33     | 26      | PTB7 | TMR_CLKIN1       |
|        |        | Mini-I | FlexBus |      | ·                |
| 36     | 26     | 24     | 18      | PTB1 | FB_CLKOUT        |
| 27     | 22     | 20     |         | PTD3 | FBa_AD0          |
| 41     | 29     |        |         | PTE4 | FBa_AD1          |
| 61     | 45     | 41     |         | PTF7 | FBa_AD10         |
| 3      |        |        |         | PTC6 | FBa_AD11         |
| 4      |        |        |         | PTC7 | FBa_AD12         |
| 5      | 1      |        |         | PTD0 | FBa_AD13         |
| 6      | 2      |        |         | PTD1 | FBa_AD14         |
| 7      | 3      | 1      | 1       | PTA0 | FBa_AD15         |
| 8      | 4      | 2      | 2       | PTA1 | FBa_AD16         |
| 25     | 21     | 19     | 15      | PTA6 | FBa_AD17         |
| 57     | 41     | 37     | 29      | PTC2 | FBa_AD18         |
| 58     | 42     | 38     |         | PTF4 | FBa_AD19         |
| 42     | 30     |        |         | PTE5 | FBa_AD2          |
| 43     |        |        |         | PTE6 | FBa_AD3          |
| 44     | 31     | 27     |         | PTE7 | FBa_AD4          |
| 53     |        |        |         | PTF0 | FBa_AD5          |
| 54     |        |        |         | PTF1 | FBa_AD6          |
| 55     |        |        |         | PTF2 | FBa_AD7          |

#### Module-by-module signals

Table 9-3. Module signals by GPIO port and pin (continued)

| 64-pin | 48-pin | 44-pin | 32-pin  | Port | Module signal(s) |
|--------|--------|--------|---------|------|------------------|
| 56     | 40     | 36     |         | PTF3 | FBa_AD8          |
| 60     | 44     | 40     |         | PTF6 | FBa_AD9          |
| 40     | 28     | 26     | 20      | PTB3 | FBa_ALE          |
| 39     | 27     | 25     | 19      | PTB2 | FBa_CS0_b        |
| 37     |        |        |         | PTE2 | FBa_D0           |
| 34     |        |        |         | PTE1 | FBa_D1           |
| 33     |        |        |         | PTE0 | FBa_D2           |
| 32     |        |        |         | PTD7 | FBa_D3           |
| 31     | 24     | 22     |         | PTD6 | FBa_D4           |
| 30     | 23     | 21     | 16      | PTA7 | FBa_D5           |
| 29     |        |        |         | PTD5 | FBa_D6           |
| 28     |        |        |         | PTD4 | FBa_D7           |
| 38     |        |        |         | PTE3 | FBa_OE_b         |
| 59     | 43     | 39     |         | PTF5 | FBa_RW_b         |
|        |        | DATA   | A_BUS   |      |                  |
| 8      | 4      | 2      | 2       | PTA1 | FBa_AD16         |
| 39     | 27     | 25     | 19      | PTB2 | FBa_CS0_b        |
| 61     | 45     | 41     |         | PTF7 | FBa_D0           |
| 60     | 44     | 40     |         | PTF6 | FBa_D1           |
| 59     | 43     | 39     |         | PTF5 | FBa_D2           |
| 58     | 42     | 38     |         | PTF4 | FBa_D3           |
| 31     | 24     | 22     |         | PTD6 | FBa_D4           |
| 30     | 23     | 21     | 16      | PTA7 | FBa_D5           |
| 27     | 22     | 20     |         | PTD3 | FBa_D6           |
| 25     | 21     | 19     | 15      | PTA6 | FBa_D7           |
| 44     | 31     | 27     |         | PTE7 | FBa_RW_b         |
|        |        | I2C0 a | nd I2C1 | 1    |                  |
| 3      |        |        |         | PTC6 | I2C0_SCL         |
| 35     | 25     | 23     | 17      | PTB0 | I2C0_SCL         |
| 4      |        |        |         | PTC7 | I2C0_SDA         |
| 36     | 26     | 24     | 18      | PTB1 | I2C0_SDA         |
| 6      | 2      |        |         | PTD1 | I2C1_SCL         |
| 42     | 30     |        |         | PTE5 | I2C1_SCL         |
| 51     | 38     | 34     | 27      | PTC0 | I2C1_SCL         |
| 5      | 1      |        |         | PTD0 | I2C1_SDA         |

Table 9-3. Module signals by GPIO port and pin (continued)

| 64-pin | 48-pin       | 44-pin | 32-pin   | Port | Module signal(s) |
|--------|--------------|--------|----------|------|------------------|
| 43     |              |        |          | PTE6 | I2C1_SDA         |
| 50     | 37           | 33     | 26       | PTB7 | I2C1_SDA         |
|        |              | I2C2 a | ind I2C3 |      | 1                |
| 7      | 7 3 1 1 PTA0 |        | I2C2_SCL |      |                  |
| 11     | 7            | 5      | 5        | PTA4 | I2C2_SCL         |
| 8      | 4            | 2      | 2        | PTA1 | I2C2_SDA         |
| 12     | 8            | 6      | 6        | PTA5 | I2C2_SDA         |
| 32     |              |        |          | PTD7 | I2C3_SCL         |
| 37     |              |        |          | PTE2 | I2C3_SCL         |
| 33     |              |        |          | PTE0 | I2C3_SDA         |
| 38     |              |        |          | PTE3 | I2C3_SDA         |
|        | •            | S      | PI0      |      | ,                |
| 39     | 27           | 25     | 19       | PTB2 | SPI0_MISO        |
| 55     |              |        |          | PTF2 | SPI0_MISO        |
| 63     | 47           | 43     | 31       | PTC4 | SPI0_MISO        |
| 38     |              |        |          | PTE3 | SPI0_MOSI        |
| 40     | 28           | 26     | 20       | PTB3 | SPI0_MOSI        |
| 56     | 40           | 36     |          | PTF3 | SPI0_MOSI        |
| 64     | 48           | 44     | 32       | PTC5 | SPI0_MOSI        |
| 36     | 26           | 24     | 18       | PTB1 | SPI0_SCLK        |
| 54     |              |        |          | PTF1 | SPI0_SCLK        |
| 62     | 46           | 42     | 30       | PTC3 | SPI0_SCLK        |
| 7      | 3            | 1      | 1        | PTA0 | SPI0_SS          |
| 34     |              |        |          | PTE1 | SPI0_SS          |
| 53     |              |        |          | PTF0 | SPI0_SS          |
| 61     | 45           | 41     |          | PTF7 | SPI0_SS          |
|        | •            | S      | PI1      |      |                  |
| 4      |              |        |          | PTC7 | SPI1_MISO        |
| 11     | 7            | 5      | 5        | PTA4 | SPI1_MISO        |
| 43     |              |        |          | PTE6 | SPI1_MISO        |
| 59     | 43           | 39     |          | PTF5 | SPI1_MISO        |
| 3      |              |        |          | PTC6 | SPI1_MOSI        |
| 12     | 8            | 6      | 6        | PTA5 | SPI1_MOSI        |
| 44     | 31           | 27     |          | PTE7 | SPI1_MOSI        |
| 60     | 44           | 40     |          | PTF6 | SPI1_MOSI        |

Table continues on the next page...

#### Module-by-module signals

Table 9-3. Module signals by GPIO port and pin (continued)

| 64-pin | 48-pin | 44-pin | 32-pin | Port | Module signal(s) |
|--------|--------|--------|--------|------|------------------|
| 5      | 1      |        |        | PTD0 | SPI1_SCLK        |
| 10     | 6      | 4      | 4      | PTA3 | SPI1_SCLK        |
| 42     | 30     |        |        | PTE5 | SPI1_SCLK        |
| 58     | 42     | 38     |        | PTF4 | SPI1_SCLK        |
| 6      | 2      |        |        | PTD1 | SPI1_SS          |
| 9      | 5      | 3      | 3      | PTA2 | SPI1_SS          |
| 41     | 29     |        |        | PTE4 | SPI1_SS          |
| 57     | 41     | 37     | 29     | PTC2 | SPI1_SS          |
|        |        | UA     | RT0    |      |                  |
| 5      | 1      |        |        | PTD0 | UART0_CTS_b      |
| 32     |        |        |        | PTD7 | UART0_CTS_b      |
| 42     | 30     |        |        | PTE5 | UART0_CTS_b      |
| 62     | 46     | 42     | 30     | PTC3 | UART0_CTS_b      |
| 6      | 2      |        |        | PTD1 | UART0_RTS_b      |
| 33     |        |        |        | PTE0 | UART0_RTS_b      |
| 41     | 29     |        |        | PTE4 | UARTO_RTS_b      |
| 61     | 45     | 41     |        | PTF7 | UART0_RTS_b      |
| 4      |        |        |        | PTC7 | UART0_RX         |
| 31     | 24     | 22     |        | PTD6 | UART0_RX         |
| 43     |        |        |        | PTE6 | UART0_RX         |
| 63     | 47     | 43     | 31     | PTC4 | UART0_RX         |
| 3      |        |        |        | PTC6 | UART0_TX         |
| 30     | 23     | 21     | 16     | PTA7 | UART0_TX         |
| 44     | 31     | 27     |        | PTE7 | UART0_TX         |
| 64     | 48     | 44     | 32     | PTC5 | UART0_TX         |
|        |        | UA     | RT1    |      |                  |
| 11     | 7      | 5      | 5      | PTA4 | UART1_CTS_b      |
| 58     | 42     | 38     |        | PTF4 | UART1_CTS_b      |
| 12     | 8      | 6      | 6      | PTA5 | UART1_RTS_b      |
| 57     | 41     | 37     | 29     | PTC2 | UART1_RTS_b      |
| 10     | 6      | 4      | 4      | PTA3 | UART1_RX         |
| 59     | 43     | 39     |        | PTF5 | UART1_RX         |
| 9      | 5      | 3      | 3      | PTA2 | UART1_TX         |
| 60     | 44     | 40     |        | PTF6 | UART1_TX         |

Freescale Semiconductor, Inc.

# 9.7 Module Signal Description Tables

The following sections correlate the chip-level signal name with the signal name used in the module's chapter. They also briefly describe the signal function and direction.

## 9.7.1 Core Modules

Table 9-4. Background Debug Signal Descriptions

| Chip signal name | Module signal name | Description                                | I/O |
|------------------|--------------------|--------------------------------------------|-----|
| BKGD             | BKGD               | Single-wire background debug interface pin | I/O |

# 9.7.2 System Modules

**Table 9-5. System Signal Descriptions** 

| Chip signal name | Module signal name | Description              | I/O |
|------------------|--------------------|--------------------------|-----|
| RESET            | _                  | Reset input signal       | I   |
| VDD              | _                  | MCU power                | I   |
| VSS              | _                  | MCU ground               | I   |
| CLKOUT           | _                  | External clock reference | 0   |

## Table 9-6. LLWU Signal Descriptions

| Chip signal name | Module signal name | Description              | I/O |
|------------------|--------------------|--------------------------|-----|
| LLWU_Pn          | LLWU_Pn            | Wakeup inputs (n = 0-15) | I   |

#### **Table 9-7. USB VREG Signal Descriptions**

| Chip signal name | Module signal name | Description              | I/O |
|------------------|--------------------|--------------------------|-----|
| VOUT33           | reg33_out          | Regulator output voltage | 0   |
| VREGIN           | reg33_in           | Unregulated power supply | I   |

Downloaded from Elcodis.com electronic components distributor

# 9.7.3 Clock Modules

## Table 9-8. OSC1 Signal Descriptions

| Chip signal name | Module signal name | Description                     | I/O |
|------------------|--------------------|---------------------------------|-----|
| EXTAL1           | EXTAL              | External clock/Oscillator input | I   |
| XTAL1            | XTAL               | Oscillator output               | 0   |

## Table 9-9. OSC2 Signal Descriptions

| Chip signal name | Module signal name | Description                     | I/O |
|------------------|--------------------|---------------------------------|-----|
| EXTAL2           | EXTAL              | External clock/Oscillator input | I   |
| XTAL2            | XTAL               | Oscillator output               | 0   |

# 9.7.4 Memories and Memory Interfaces

# Table 9-10. EzPort Signal Descriptions

| Chip signal name | Module signal name | Description                                                               | I/O    |
|------------------|--------------------|---------------------------------------------------------------------------|--------|
| EZP_CLK          | EZP_CK             | EzPort Clock                                                              | Input  |
| EZP_CS           | EZP_CS             | EzPort Chip Select                                                        | Input  |
| EZP_DI           | EZP_D              | EzPort Serial Data In                                                     | Input  |
| EZP_DO           | EZP_Q              | EzPort Serial Data Out                                                    | Output |
| EZP_MS           | _                  | Selects between EzPort serial flash programming mode and single chip mode | I      |

## Table 9-11. Mini-FlexBus Signal Descriptions

| Chip signal name | Module signal name | Description                                                                                                                                | I/O |
|------------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------|-----|
| FB_CLKOUT        | FB_CLK             | FlexBus clock output                                                                                                                       | 0   |
| FBa_AD[19:0]     | FB_A[19:0]         | In a non-multiplexed configuration, this is the address bus. In a multiplexed configuration this bus is the address/data bus, FB_AD[19:0]. | I/O |
| FBa_ALE          | FB_TS              | Transfer start                                                                                                                             | 0   |
| FBa_CS0          | FB_CS[1:0]         | General purpose chip-selects. The actual number of chip selects available depends upon the device and its pin configuration.               | 0   |
| FBa_D[7:0]       | FB_D[7:0]          | In a non-multiplexed configuration, this is the data bus. In multiplexed configurations, this bus is not used.                             | I/O |

Table continues on the next page...

## **Table 9-11. Mini-FlexBus Signal Descriptions (continued)**

| Chip signal name | Module signal name | Description                     | I/O |
|------------------|--------------------|---------------------------------|-----|
| FBa_OE           | FB_OE              | Output enable                   | 0   |
| FBa_RW           | FB_R/W             | Read/write. 1 = Read, 0 = Write | 0   |

# **9.7.5 Analog**

## Table 9-12. ADC0 Signal Descriptions

| Chip signal name  | Module signal name | Description                        | I/O |
|-------------------|--------------------|------------------------------------|-----|
| ADC0_SE[22:8,3:2] | AD[23:4]           | Single-ended analog channel inputs | I   |
| VREFH             | $V_{REFSH}$        | Voltage reference select high      | I   |
| VREFL             | V <sub>REFSL</sub> | Voltage reference select low       | I   |
| VDDA              | $V_{DDA}$          | Analog power supply                | I   |
| VSSA              | V <sub>SSA</sub>   | Analog ground                      | I   |

## Table 9-13. CMP0 Signal Descriptions

| Chip signal name | Module signal<br>name | Description           | 1/0 |
|------------------|-----------------------|-----------------------|-----|
| CMP0_IN[3:0]     | IN[3:0]               | Analog voltage inputs | I   |
| CMP0_OUT         | СМРО                  | CMP output            | 0   |

# Table 9-14. DAC0 Signal Descriptions

| Chip signal name | Module signal name | Description | I/O |
|------------------|--------------------|-------------|-----|
| DAC0_OUT         | _                  | DAC output  | 0   |

## **Table 9-15. VREF Signal Descriptions**

| Chip signal name | Module signal name | Description                                   | I/O |
|------------------|--------------------|-----------------------------------------------|-----|
| VREF_OUT         | VREF_OUT           | Internally-generated Voltage Reference output | 0   |

# 9.7.6 Timer Modules

## Table 9-16. FTM0 Signal Descriptions

| Chip signal name | Module signal name  | Description                                                                              | I/O |
|------------------|---------------------|------------------------------------------------------------------------------------------|-----|
| TMR_CLKIN[1:0]   | EXTCLK              | external clock – FTM external clock can be selected to drive the FTM counter.            | I   |
| FTM0_CH[1:0]     | CHn <sup>1</sup>    | channel (n) – I/O pin associated with FTM channel (n).                                   | I/O |
| FTM0_FLT[2:0]    | FAULTj <sup>2</sup> | fault input (j) - input pin associated with fault input (j).                             | I   |
| FTM0_QD_PHA      | PHA                 | quadrature decoder phase A input – input pin associated with quadrature decoder phase A. | I   |
| FTM0_QD_PHB      | РНВ                 | quadrature decoder phase B input – input pin associated with quadrature decoder phase B. | I   |

- 1. n = channel number (0 to 7)
- 2. j = fault input (0 to 3)

## Table 9-17. FTM1 Signal Descriptions

| Chip signal name | Module signal name  | Description                                                                   | I/O |
|------------------|---------------------|-------------------------------------------------------------------------------|-----|
| TMR_CLKIN[1:0]   | EXTCLK              | external clock – FTM external clock can be selected to drive the FTM counter. | I   |
| FTM1_CH[5:0]     | CHn <sup>1</sup>    | channel (n) – I/O pin associated with FTM channel (n).                        | I/O |
| FTM1_FLT[2:0]    | FAULTj <sup>2</sup> | fault input (j) - input pin associated with fault input (j).                  | I   |

- 1. n = channel number (0 to 7)
- 2. j = fault input (0 to 3)

### Table 9-18. MTIM Signal Descriptions

| Chip signal name | Module signal name | Description                             | I/O |
|------------------|--------------------|-----------------------------------------|-----|
| TMR_CLKIN[1:0]   | TCLK               | External clock source input into MTIM16 | I   |

## **Table 9-19. CMT Signal Descriptions**

| Chip signal name | Module signal name | Description     | I/O |
|------------------|--------------------|-----------------|-----|
| CMT_IRO          | CMT_IRO            | Infrared Output | 0   |

## Table 9-20. PDB0 Signal Descriptions

| Chip signal name | Module signal<br>name | Description                                                                                                                                                            | 1/0 |
|------------------|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| PDB0_EXTRG       | EXTRG                 | External trigger input source. If the PDB is enabled and external trigger input source is selected, a positive edge on the EXTRG signal resets and starts the counter. | I   |

# Table 9-21. LPTMR0 and LPTMR1 Signal Descriptions

| Chip signal name | Module signal name | Description             | I/O |
|------------------|--------------------|-------------------------|-----|
| LPTMR_ALT[3:1]   | LPTMR_ALT <i>n</i> | Pulse counter input pin | 1   |

# 9.7.7 Communication Interfaces

# Table 9-22. USB0 Signal Descriptions

| Chip signal name | Module signal name | Description                               | I/O |
|------------------|--------------------|-------------------------------------------|-----|
| USB0_DM          | usb_dm             | USB D- analog data signal on the USB bus. | I/O |
| USB0_DP          | usb_dp             | USB D+ analog data signal on the USB bus. | I/O |
| USB_CLKIN        | _                  | Alternate USB clock input                 | I   |

# Table 9-23. SPI0 Signal Descriptions

| Chip signal name | Module signal name | Description                    | I/O |
|------------------|--------------------|--------------------------------|-----|
| SPI0_MISO        | MISO               | Master Data In, Slave Data Out | I/O |
| SPI0_MOSI        | MOSI               | Master Data Out, Slave Data In | I/O |
| SPI0_SCLK        | SPSCK              | SPI Serial Clock               | I/O |
| SPI0_SS          | SS                 | Slave Select                   | I/O |

# Table 9-24. SPI1 Signal Descriptions

| Chip signal name | Module signal name | Description                    | I/O |
|------------------|--------------------|--------------------------------|-----|
| SPI1_MISO        | MISO               | Master Data In, Slave Data Out | I/O |
| SPI1_MOSI        | MOSI               | Master Data Out, Slave Data In | I/O |
| SPI1_SCLK        | SPSCK              | SPI Serial Clock               | I/O |
| SPI1_SS          | SS                 | Slave Select                   | I/O |

# Table 9-25. I<sup>2</sup>C0 Signal Descriptions

| Chip signal name | Module signal name | Description                                                     | I/O |
|------------------|--------------------|-----------------------------------------------------------------|-----|
| I2C0_SCL         | SCL                | Bidirectional serial clock line of the I <sup>2</sup> C system. | I/O |
| I2C0_SDA         | SDA                | Bidirectional serial data line of the I <sup>2</sup> C system.  | I/O |

#### **Module Signal Description Tables**

# Table 9-26. I<sup>2</sup>C1 Signal Descriptions

| Chip signal name | Module signal name | Description                                                     | I/O |
|------------------|--------------------|-----------------------------------------------------------------|-----|
| I2C1_SCL         | SCL                | Bidirectional serial clock line of the I <sup>2</sup> C system. | I/O |
| I2C1_SDA         | SDA                | Bidirectional serial data line of the I <sup>2</sup> C system.  | I/O |

# Table 9-27. I<sup>2</sup>C2 Signal Descriptions

| Chip signal name | Module signal name | Description                                                     | I/O |
|------------------|--------------------|-----------------------------------------------------------------|-----|
| I2C2_SCL         | SCL                | Bidirectional serial clock line of the I <sup>2</sup> C system. | I/O |
| I2C2_SDA         | SDA                | Bidirectional serial data line of the I <sup>2</sup> C system.  | I/O |

# Table 9-28. I<sup>2</sup>C3 Signal Descriptions

| Chip signal name | Module signal name | Description                                                     | I/O |
|------------------|--------------------|-----------------------------------------------------------------|-----|
| I2C3_SCL         | SCL                | Bidirectional serial clock line of the I <sup>2</sup> C system. | I/O |
| I2C3_SDA         | SDA                | Bidirectional serial data line of the I <sup>2</sup> C system.  | I/O |

# Table 9-29. UART0 Signal Descriptions

| Chip signal name | Module signal<br>name | Description     | 1/0 |
|------------------|-----------------------|-----------------|-----|
| UARTO_CTS        | CTS                   | Clear to send   | I   |
| UARTO_RTS        | RTS                   | Request to send | 0   |
| UART0_TX         | TXD                   | Transmit data   | 0   |
| UART0_RX         | RXD                   | Receive data    | I   |

# Table 9-30. UART1 Signal Descriptions

| Chip signal name | Module signal name | Description     | I/O |
|------------------|--------------------|-----------------|-----|
| UART1_CTS        | CTS                | Clear to send   | I   |
| UART1_RTS        | RTS                | Request to send | 0   |
| UART1_TX         | TXD                | Transmit data   | 0   |
| UART1_RX         | RXD                | Receive data    | I   |

# Table 9-31. I<sup>2</sup>S0 Signal Descriptions

| Chip signal name | Module signal name | Description        | I/O |
|------------------|--------------------|--------------------|-----|
| I2S0_CLKIN       | _                  | Clock input        | I   |
| I2S0_MCLK        | SAI_MCLK           | Audio Master Clock | I/O |

Table continues on the next page...

## Table 9-31. I<sup>2</sup>S0 Signal Descriptions (continued)

| Chip signal name | Module signal name | Description         | I/O |
|------------------|--------------------|---------------------|-----|
| I2S0_RX_BCLK     | SAI_RX_BCLK        | Receive Bit Clock   | I/O |
| I2S0_RX_FS       | SAI_RX_SYNC        | Receive Frame Sync  | I/O |
| I2S0_RXD         | SAI_RX_DATA        | Receive Data        | I   |
| I2S0_TX_BCLK     | SAI_TX_BCLK        | Transmit Bit Clock  | I/O |
| I2S0_TX_FS       | SAI_TX_SYNC        | Transmit Frame Sync | I/O |
| I2S0_TXD         | SAI_TX_DATA        | Transmit Data       | 0   |

# 9.7.8 Human-Machine Interfaces (HMI)

## Table 9-32. GPIO Signal Descriptions

| Chip signal name      | Module signal name | Description                  | I/O |
|-----------------------|--------------------|------------------------------|-----|
| PTA[7:0] <sup>1</sup> | PTA[7:0]           | General purpose input/output | I/O |
| PTB[7:0] <sup>1</sup> | PTB[7:0]           | General purpose input/output | I/O |
| PTC[7:0] <sup>1</sup> | PTC[7:0]           | General purpose input/output | I/O |
| PTD[7:0] <sup>1</sup> | PTD[7:0]           | General purpose input/output | I/O |
| PTE[7:0] <sup>1</sup> | PTE[7:0]           | General purpose input/output | I/O |
| PTF[7:0] <sup>1</sup> | PTF[7:0]           | General purpose input/output | I/O |

<sup>1.</sup> The available GPIO pins depend on the specific package. See the signal multiplexing details for which exact GPIO signals are available.

# Table 9-33. RGPIO Signal Descriptions

| Chip signal name | Module signal name | Description                                                                                                                                                                                          | I/O |
|------------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| RGPIO[15:0]      | RGPIO[15:0]        | Data Input/Output. When configured as an input, the state of this signal is reflected in the read data register. When configured as an output, this signal is the output of the write data register. | I/O |

## Table 9-34. TSI0 Signal Descriptions

| Chip signal name | Module signal name | Description                                                                                                 | I/O |
|------------------|--------------------|-------------------------------------------------------------------------------------------------------------|-----|
| TSI0_CH[15:0]    | TSI_IN[15:0]       | TSI pins. Switchable driver that connects directly to the electrode pins TSI[15:0] can operate as GPIO pins | I/O |

# Module Signal Description Tables

# Table 9-35. IRQ Signal Descriptions

| Chip signal name | Module signal name | Description            | I/O |
|------------------|--------------------|------------------------|-----|
| IRQ              | IRQ                | External interrupt pin | I   |

# Chapter 10 Port Mux Control

#### 10.1 Port Mux Control

Package pins can be programmed for up to sixteen different functions using the mux control registers. Controls are organized by GPIO port. Each GPIO port has four mux control registers, consisting of 4 bits per package pin. All mux registers reset to 00h. Alternate values for each function match the column number in which that function occurs in the pin summary table. That is, default functions are assigned value 00h, ALT1 functions 01h, and so on. Setting the RESERVED setting in the port muxing results in the DEFAULT function for the pin.

#### **CAUTION**

Not all pins described in the port mux are available on every package in the device family. Do not change the port mux control field for pins that do not appear on the device in use. For example, in a 32-pin package, mask the PTCPF1[C6] field when writing to the PTCPF1 register. Changing the port mux control field for such unavailable pins can generate unnecessary current leakage.

# 10.2 Memory Map and Registers

#### **MXC** memory map

| Absolute<br>address<br>(hex) | Register name                               | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|------------------------------|---------------------------------------------|--------------------|--------|-------------|------------------|
| FFFF_8080                    | Port A Pin Function 1 Register (MXC_PTAPF1) | 8                  | R/W    | 00h         | 10.2.1/211       |
| FFFF_8081                    | Port A Pin Function 2 Register (MXC_PTAPF2) | 8                  | R/W    | 00h         | 10.2.2/211       |

## **Memory Map and Registers**

# MXC memory map (continued)

| Absolute<br>address<br>(hex) | Register name                               | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|------------------------------|---------------------------------------------|--------------------|--------|-------------|------------------|
| FFFF_8082                    | Port A Pin Function 3 Register (MXC_PTAPF3) | 8                  | R/W    | 00h         | 10.2.3/212       |
| FFFF_8083                    | Port A Pin Function 4 Register (MXC_PTAPF4) |                    | R/W    | 00h         | 10.2.4/213       |
| FFFF_8084                    | Port B Pin Function 1 Register (MXC_PTBPF1) | 8                  | R/W    | 00h         | 10.2.5/214       |
| FFFF_8085                    | Port B Pin Function 2 Register (MXC_PTBPF2) | 8                  | R/W    | 02h         | 10.2.6/215       |
| FFFF_8086                    | Port B Pin Function 3 Register (MXC_PTBPF3) | 8                  | R/W    | 00h         | 10.2.7/215       |
| FFFF_8087                    | Port B Pin Function 4 Register (MXC_PTBPF4) | 8                  | R/W    | 05h         | 10.2.8/216       |
| FFFF_8088                    | Port C Pin Function 1 Register (MXC_PTCPF1) | 8                  | R/W    | 00h         | 10.2.9/217       |
| FFFF_8089                    | Port C Pin Function 2 Register (MXC_PTCPF2) | 8                  | R/W    | 00h         | 10.2.10/<br>218  |
| FFFF_808A                    | Port C Pin Function 3 Register (MXC_PTCPF3) | 8                  | R/W    | 00h         | 10.2.11/<br>219  |
| FFFF_808B                    | Port C Pin Function 4 Register (MXC_PTCPF4) | 8                  | R/W    | 20h         | 10.2.12/<br>219  |
| FFFF_808C                    | Port D Pin Function 1 Register (MXC_PTDPF1) | 8                  | R/W    | 00h         | 10.2.13/<br>220  |
| FFFF_808D                    | Port D Pin Function 2 Register (MXC_PTDPF2) | 8                  | R/W    | 00h         | 10.2.14/<br>221  |
| FFFF_808E                    | Port D Pin Function 3 Register (MXC_PTDPF3) | 8                  | R/W    | 00h         | 10.2.15/<br>222  |
| FFFF_808F                    | Port D Pin Function 4 Register (MXC_PTDPF4) | 8                  | R/W    | 00h         | 10.2.16/<br>223  |
| FFFF_8090                    | Port E Pin Function 1 Register (MXC_PTEPF1) | 8                  | R/W    | 00h         | 10.2.17/<br>223  |
| FFFF_8091                    | Port E Pin Function 2 Register (MXC_PTEPF2) | 8                  | R/W    | 00h         | 10.2.18/<br>224  |
| FFFF_8092                    | Port E Pin Function 3 Register (MXC_PTEPF3) | 8                  | R/W    | 00h         | 10.2.19/<br>225  |
| FFFF_8093                    | Port E Pin Function 4 Register (MXC_PTEPF4) | 8                  | R/W    | 00h         | 10.2.20/<br>226  |
| FFFF_8094                    | Port F Pin Function 1 Register (MXC_PTFPF1) | 8                  | R/W    | 00h         | 10.2.21/<br>227  |
| FFFF_8095                    | Port F Pin Function 2 Register (MXC_PTFPF2) | 8                  | R/W    | 00h         | 10.2.22/<br>227  |
| FFFF_8096                    | Port F Pin Function 3 Register (MXC_PTFPF3) | 8                  | R/W    | 00h         | 10.2.23/<br>228  |
| FFFF_8097                    | Port F Pin Function 4 Register (MXC_PTFPF4) | 8                  | R/W    | 00h         | 10.2.24/<br>229  |

Downloaded from **Elcodis.com** electronic components distributor

# 10.2.1 Port A Pin Function 1 Register (MXC\_PTAPF1)

Address: MXC\_PTAPF1 is FFFF\_8080h base + 0h offset = FFFF\_8080h



# **MXC\_PTAPF1** field descriptions

| Field |             | Description         |
|-------|-------------|---------------------|
| 7–4   | Port A7 Pin | Mux Controls        |
| A7    | 0000        | ADO0 0540/T010 0115 |
|       | 0000        | ADC0_SE13/TSI0_CH5  |
|       | 0001        | PTA7                |
|       | 0010        | UARTO_TX            |
|       | 0011        | Reserved            |
|       | 0100        | FTM0_QD_PHA         |
|       | 0101        | Reserved            |
|       | 0110        | FBa_D5              |
|       | 0111        | Reserved            |
|       | 1000-1111   | Reserved            |
| 3–0   | Port A6 Pin | Mux Controls        |
| A6    |             | 4D00 0505010 0110   |
|       | 0000        | ADC0_SE8/TSI0_CH0   |
|       | 0001        | PTA6                |
|       | 0010        | Reserved            |
|       | 0011        | LPTMR_ALT1          |
|       | 0100        | FTM_FLT1            |
|       | 0101        | FBa_D7              |
|       | 0110        | FBa_AD17            |
|       | 0111        | Reserved            |
|       | 1000-1111   | Reserved            |

# 10.2.2 Port A Pin Function 2 Register (MXC\_PTAPF2)

Address: MXC\_PTAPF2 is FFFF\_8080h base + 1h offset = FFFF\_8081h



#### **Memory Map and Registers**

## MXC\_PTAPF2 field descriptions

| Field     |             | Description  |
|-----------|-------------|--------------|
| 7–4<br>A5 | Port A5 Pin | Mux Controls |
|           | 0000        | ADC0_SE3     |
|           | 0001        | PTA5         |
|           | 0010        | UART1_RTS_b  |
|           | 0011        | I2C2_SDA     |
|           | 0100        | FTM1_CH5     |
|           | 0101        | SPI1_MOSI    |
|           | 0110        | CLKOUT       |
|           | 0111        | I2S0_TXD     |
|           | 1000-1111   | Reserved     |
| 3–0<br>A4 | Port A4 Pin | Mux Controls |
|           | 0000        | ADC0_SE2     |
|           | 0001        | PTA4         |
|           | 0010        | UART1_CTS_b  |
|           | 0011        | I2C2_SCL     |
|           | 0100        | FTM1_CH4     |
|           | 0101        | SPI1_MISO    |
|           | 0110        | Reserved     |
|           | 0111        | 12S0_TX_FS   |
|           | 1000-1111   | Reserved     |

# 10.2.3 Port A Pin Function 3 Register (MXC\_PTAPF3)

Address: MXC\_PTAPF3 is FFFF\_8080h base + 2h offset = FFFF\_8082h



# **MXC\_PTAPF3** field descriptions

| Field     |           | Description              |  |  |  |  |
|-----------|-----------|--------------------------|--|--|--|--|
| 7–4<br>A3 | Port A3 F | Port A3 Pin Mux Controls |  |  |  |  |
|           | 0000      | Disabled                 |  |  |  |  |
|           | 0001      | PTA3                     |  |  |  |  |
|           | 0010      | UART1_RX                 |  |  |  |  |
|           | 0011      | Reserved                 |  |  |  |  |
|           | 0100      | FTM1_CH3                 |  |  |  |  |
|           | 0101      | SPI1_SCLK                |  |  |  |  |
|           | 0110      | Reserved                 |  |  |  |  |

Table continues on the next page...

# **MXC\_PTAPF3** field descriptions (continued)

| Field     |             | Description  |
|-----------|-------------|--------------|
|           | 0111        | I2S0_TX_BCLK |
|           | 1000-1111   | Reserved     |
| 3–0<br>A2 | Port A2 Pin | Mux Controls |
|           | 0000        | Disabled     |
|           | 0001        | PTA2         |
|           | 0010        | UART1_TX     |
|           | 0011        | Reserved     |
|           | 0100        | FTM1_CH2     |
|           | 0101        | SPI1_SS      |
|           | 0110        | Reserved     |
|           | 0111        | Reserved     |
|           | 1000-1111   | Reserved     |

# 10.2.4 Port A Pin Function 4 Register (MXC\_PTAPF4)

Address: MXC\_PTAPF4 is FFFF\_8080h base + 3h offset = FFFF\_8083h



## MXC\_PTAPF4 field descriptions

| Field |             | Description  |  |
|-------|-------------|--------------|--|
| 7–4   | Port A1 Pin | Mux Controls |  |
| A1    | 0000        | Disabled     |  |
|       | 0000        | Disabled     |  |
|       | 0001        | PTA1         |  |
|       | 0010        | Reserved     |  |
|       | 0011        | I2C2_SDA     |  |
|       | 0100        | FTM1_CH1     |  |
|       | 0101        | Reserved     |  |
|       | 0110        | FBa_AD16     |  |
|       | 0111        | 12S0_RXD     |  |
|       | 1000-1111   | Reserved     |  |
| 3–0   | Port A0 Pin | Mux Controls |  |
| A0    |             |              |  |
|       | 0000        | Disabled     |  |
|       | 0001        | PTA0         |  |
|       | 0010        | Reserved     |  |
|       | 0011        | 12C2_SCL     |  |
|       | 0100        | FTM1_CH0     |  |

Table continues on the next page...

#### **Memory Map and Registers**

# **MXC\_PTAPF4** field descriptions (continued)

| Field |           | Description |
|-------|-----------|-------------|
|       | 0101      | SPI0_SS     |
|       | 0110      | FBa_AD15    |
|       | 0111      | 12S0_RX_FS  |
|       | 1000-1111 | Reserved    |

# 10.2.5 Port B Pin Function 1 Register (MXC\_PTBPF1)

Address: MXC\_PTBPF1 is FFFF\_8080h base + 4h offset = FFFF\_8084h



# **MXC\_PTBPF1** field descriptions

| Field     |             | Description        |  |
|-----------|-------------|--------------------|--|
| 7–4<br>B7 | Port B7 Pin | Mux Controls       |  |
|           | 0000        | EXTAL1             |  |
|           | 0001        | PTB7               |  |
|           | 0010        | Reserved           |  |
|           | 0011        | I2C1_SDA           |  |
|           | 0100        | TMR_CLKIN1         |  |
|           | 0101        | Reserved           |  |
|           | 0110        | Reserved           |  |
|           | 0111        | Reserved           |  |
|           | 1000-1111   | Reserved           |  |
| 3–0<br>B6 | Port B6 Pin | 6 Pin Mux Controls |  |
|           | 0000        | EXTAL2             |  |
|           | 0001        | PTB6               |  |
|           | 0010        | Reserved           |  |
|           | 0011        | Reserved           |  |
|           | 0100        | Reserved           |  |
|           | 0101        | Reserved           |  |
|           | 0110        | Reserved           |  |
|           | 0111        | Reserved           |  |
|           | 1000-1111   | Reserved           |  |

# 10.2.6 Port B Pin Function 2 Register (MXC\_PTBPF2)

Address: MXC\_PTBPF2 is FFFF\_8080h base + 5h offset = FFFF\_8085h



# **MXC\_PTBPF2** field descriptions

| Field |                          | Description  |  |
|-------|--------------------------|--------------|--|
| 7–4   | Port B5 Pin Mux Controls |              |  |
| B5    | 0000                     | XTAL2        |  |
|       |                          | PTB5         |  |
|       | 0001                     |              |  |
|       | 0010                     | Reserved     |  |
|       | 0011                     | Reserved     |  |
|       | 0100                     | Reserved     |  |
|       | 0101                     | Reserved     |  |
|       | 0110                     | Reserved     |  |
|       | 0111                     | Reserved     |  |
|       | 1000-1111                | Reserved     |  |
| 3–0   | Port B4 Pin              | Mux Controls |  |
| B4    | 0000                     | B: 11 1      |  |
|       | 0000                     | Disabled     |  |
|       | 0001                     | PTB4         |  |
|       | 0010                     | BKGD/MS      |  |
|       | 0011                     | Reserved     |  |
|       | 0100                     | Reserved     |  |
|       | 0101                     | Reserved     |  |
|       | 0110                     | Reserved     |  |
|       | 0111                     | Reserved     |  |
|       | 1000-1111                | Reserved     |  |

# 10.2.7 Port B Pin Function 3 Register (MXC\_PTBPF3)

Address: MXC\_PTBPF3 is FFFF\_8080h base + 6h offset = FFFF\_8086h



#### **Memory Map and Registers**

Downloaded from Elcodis.com electronic components distributor

## MXC\_PTBPF3 field descriptions

| Field     |                          | Description             |  |  |
|-----------|--------------------------|-------------------------|--|--|
| 7–4<br>B3 | Port B3 Pin Mux Controls |                         |  |  |
|           | 0000                     | ADC0_SE18/TSI0_CH14     |  |  |
|           | 0001                     | PTB3                    |  |  |
|           | 0010                     | SPI0_MOSI               |  |  |
|           | 0011                     | Reserved                |  |  |
|           | 0100                     | Reserved                |  |  |
|           | 0101                     | FBa_CS1_b               |  |  |
|           | 0110                     | FBa_ALE                 |  |  |
|           | 0111                     | Reserved                |  |  |
|           | 1000-1111                | Reserved                |  |  |
| 3–0<br>B2 | Port B2 Pin              | ort B2 Pin Mux Controls |  |  |
|           | 0000                     | ADC0_SE17/TSI0_CH13     |  |  |
|           | 0001                     | PTB2                    |  |  |
|           | 0010                     | SPI0_MISO               |  |  |
|           | 0011                     | Reserved                |  |  |
|           | 0100                     | Reserved                |  |  |
|           | 0101                     | Reserved                |  |  |
|           | 0110                     | FBa_CS0_b               |  |  |
|           | 0111                     | Reserved                |  |  |
|           | 1000-1111                | Reserved                |  |  |

# 10.2.8 Port B Pin Function 4 Register (MXC\_PTBPF4)

Address: MXC\_PTBPF4 is FFFF\_8080h base + 7h offset = FFFF\_8087h



# **MXC\_PTBPF4** field descriptions

| Field     |           | Description              |  |  |  |
|-----------|-----------|--------------------------|--|--|--|
| 7–4<br>B1 | Port B1 F | Port B1 Pin Mux Controls |  |  |  |
|           | 0000      | TSI0_CH10                |  |  |  |
|           | 0001      | PTB1                     |  |  |  |
|           | 0010      | SPI0_SCLK                |  |  |  |
|           | 0011      | I2C0_SDA                 |  |  |  |
|           | 0100      | FTM_FLT2                 |  |  |  |
|           | 0101      | LPTMR_ALT2               |  |  |  |
|           | 0110      | FTM0_QD_PHB              |  |  |  |

Table continues on the next page...

## **MXC\_PTBPF4** field descriptions (continued)

| Field     |             | Description  |
|-----------|-------------|--------------|
|           | 0111        | FB_CLKOUT    |
|           | 1000-1111   | Reserved     |
| 3–0<br>B0 | Port B0 Pin | Mux Controls |
|           | 0000        | Disabled     |
|           | 0001        | PTB0         |
|           | 0010        | Reserved     |
|           | 0011        | I2C0_SCL     |
|           | 0100        | Reserved     |
|           | 0101        | IRQ/EZP_MS_b |
|           | 0110        | Reserved     |
|           | 0111        | Reserved     |
|           | 1000-1111   | Reserved     |

# 10.2.9 Port C Pin Function 1 Register (MXC\_PTCPF1)

Address: MXC\_PTCPF1 is FFFF\_8080h base + 8h offset = FFFF\_8088h



#### MXC\_PTCPF1 field descriptions

| Field     |             | Description  |  |
|-----------|-------------|--------------|--|
| 7–4<br>C7 | Port C7 Pin | Mux Controls |  |
|           | 0000        | Disabled     |  |
|           | 0001        | PTC7         |  |
|           | 0010        | UARTO_RX     |  |
|           | 0011        | I2CO_SDA     |  |
|           | 0100        | RGPIO7       |  |
|           | 0101        | SPI1_MISO    |  |
|           | 0110        | FBa_AD12     |  |
|           | 0111        | Reserved     |  |
|           | 1000-1111   | Reserved     |  |
| 3–0<br>C6 | Port C6 Pin | Mux Controls |  |
|           | 0000        | Disabled     |  |
|           | 0001        | PTC6         |  |
|           | 0010        | UARTO_TX     |  |
|           | 0011        | I2CO_SCL     |  |
|           | 0100        | RGPIO6       |  |

Table continues on the next page...

## **MXC\_PTCPF1** field descriptions (continued)

| Field |           | Description |
|-------|-----------|-------------|
|       | 0101      | SPI1_MOSI   |
|       | 0110      | FBa_AD11    |
|       | 0111      | Reserved    |
|       | 1000-1111 | Reserved    |

# 10.2.10 Port C Pin Function 2 Register (MXC\_PTCPF2)

Address: MXC\_PTCPF2 is FFFF\_8080h base + 9h offset = FFFF\_8089h



## **MXC\_PTCPF2** field descriptions

| Field |             | Description   |
|-------|-------------|---------------|
| 7–4   | Port C5 Pin | Mux Controls  |
| C5    | 0000        | B: 11 1       |
|       | 0000        | Disabled      |
|       | 0001        | PTC5          |
|       | 0010        | UART0_TX      |
|       | 0011        | RGPIO5        |
|       | 0100        | SPI0_MOSI     |
|       | 0101        | CMT_IRO       |
|       | 0110        | Reserved      |
|       | 0111        | Reserved      |
|       | 1000-1111   | Reserved      |
| 3–0   | Port C4 Pin | Mux Controls  |
| C4    | 0000        | Disabled      |
|       | 0001        | PTC4          |
|       | 0010        | UARTO_RX      |
|       | 0010        | RGPIO4        |
|       | 0100        | SPI0_MISO     |
|       | 0100        |               |
|       |             | PDB0_EXTRG    |
|       | 0110        | USB_SOF_PULSE |
|       | 0111        | Reserved      |
|       | 1000-1111   | Reserved      |

# 10.2.11 Port C Pin Function 3 Register (MXC\_PTCPF3)

Address: MXC\_PTCPF3 is FFFF\_8080h base + Ah offset = FFFF\_808Ah



## **MXC\_PTCPF3** field descriptions

| Field     |             | Description          |
|-----------|-------------|----------------------|
| 7–4<br>C3 | Port C3 Pin | Mux Controls         |
| 03        | 0000        | Disabled             |
|           | 0001        | PTC3                 |
|           | 0010        | UART0_CTS_b          |
|           | 0011        | RGPIO3               |
|           | 0100        | SPI0_SCLK            |
|           | 0101        | CLKOUT               |
|           | 0110        | USB_CLKIN            |
|           | 0111        | I2S0_MCLK/I2S0_CLKIN |
|           | 1000-1111   | Reserved             |
| 3–0       | Port C2 Pin | Mux Controls         |
| C2        | 0000        | CMP0_IN3             |
|           | 0001        | PTC2                 |
|           | 0010        | UART1_RTS_b          |
|           | 0011        | SPI1_SS              |
|           | 0100        | Reserved             |
|           | 0101        | RGPIO2               |
|           | 0110        | FBa_AD18             |
|           | 0111        | 12S0_TX_FS           |
|           | 1000-1111   | Reserved             |

# 10.2.12 Port C Pin Function 4 Register (MXC\_PTCPF4)

Address: MXC\_PTCPF4 is FFFF\_8080h base + Bh offset = FFFF\_808Bh



#### MXC\_PTCPF4 field descriptions

| Field     |                          | Description       |  |
|-----------|--------------------------|-------------------|--|
| 7–4       | Port C1 Pin Mux Controls |                   |  |
| C1        |                          |                   |  |
|           | NOTE: PT                 | C1 is open drain. |  |
|           | 0000                     | Disabled          |  |
|           | 0001                     | PTC1              |  |
|           | 0010                     | RESET_b           |  |
|           | 0011                     | Reserved          |  |
|           | 0100                     | Reserved          |  |
|           | 0101                     | Reserved          |  |
|           | 0110                     | Reserved          |  |
|           | 0111                     | Reserved          |  |
|           | 1000-1111                | Reserved          |  |
| 3–0<br>C0 | Port C0 Pin              | Mux Controls      |  |
|           | 0000                     | XTAL1             |  |
|           | 0001                     | PTC0              |  |
|           | 0010                     | Reserved          |  |
|           | 0011                     | I2C1_SCL          |  |
|           | 0100                     | TMR_CLKIN0        |  |
|           | 0101                     | RGPIO0            |  |
|           | 0110                     | Reserved          |  |
|           | 0111                     | Reserved          |  |
|           | 1000-1111                | Reserved          |  |

# 10.2.13 Port D Pin Function 1 Register (MXC\_PTDPF1)

Address: MXC\_PTDPF1 is FFFF\_8080h base + Ch offset = FFFF\_808Ch



## **MXC\_PTDPF1** field descriptions

| Field     |           | Description        |  |  |
|-----------|-----------|--------------------|--|--|
| 7–4<br>D7 | Port D7 I | Pin Mux Controls   |  |  |
|           | 0000      | ADC0_SE15/TSI0_CH7 |  |  |
|           | 0001      | PTD7               |  |  |
|           | 0010      | UART0_CTS_b        |  |  |
|           | 0011      | I2C3_SCL           |  |  |
|           | 0100      | RGPIO15            |  |  |

Table continues on the next page...

## **MXC\_PTDPF1** field descriptions (continued)

| Field     |             | Description        |
|-----------|-------------|--------------------|
|           | 0101        | Reserved           |
|           | 0110        | FBa_D3             |
|           | 0111        | Reserved           |
|           | 1000-1111   | Reserved           |
| 3–0<br>D6 | Port D6 Pin | Mux Controls       |
|           | 0000        | ADC0_SE14/TSI0_CH6 |
|           | 0001        | PTD6               |
|           | 0010        | UART0_RX           |
|           | 0011        | RGPIO14            |
|           | 0100        | Reserved           |
|           | 0101        | Reserved           |
|           | 0110        | FBa_D4             |
|           | 0111        | Reserved           |
|           | 1000-1111   | Reserved           |

# 10.2.14 Port D Pin Function 2 Register (MXC\_PTDPF2)

Address: MXC\_PTDPF2 is FFFF\_8080h base + Dh offset = FFFF\_808Dh



## **MXC\_PTDPF2** field descriptions

| Field | Description              |                     |  |
|-------|--------------------------|---------------------|--|
| 7–4   | Port D5 Pin Mux Controls |                     |  |
| D5    | 0000                     | ADO0 0540/5010 0114 |  |
|       | 0000                     | ADC0_SE12/TSI0_CH4  |  |
|       | 0001                     | PTD5                |  |
|       | 0010                     | Reserved            |  |
|       | 0011                     | RGPIO13             |  |
|       | 0100                     | Reserved            |  |
|       | 0101                     | Reserved            |  |
|       | 0110                     | FBa_D6              |  |
|       | 0111                     | Reserved            |  |
|       | 1000-1111                | Reserved            |  |
| 3–0   | Port D4 Pin Mux Controls |                     |  |
| D4    |                          |                     |  |
|       | 0000                     | ADC0_SE11/TSI0_CH3  |  |
|       | 0001                     | PTD4                |  |
|       | 0010                     | Reserved            |  |

Table continues on the next page...

## **MXC\_PTDPF2** field descriptions (continued)

| Field |           |          | Description |  |
|-------|-----------|----------|-------------|--|
|       | 0011      | RGPIO12  |             |  |
|       | 0100      | Reserved |             |  |
|       | 0101      | Reserved |             |  |
|       | 0110      | FBa_D7   |             |  |
|       | 0111      | Reserved |             |  |
|       | 1000-1111 | Reserved |             |  |

# 10.2.15 Port D Pin Function 3 Register (MXC\_PTDPF3)

Address: MXC\_PTDPF3 is FFFF\_8080h base + Eh offset = FFFF\_808Eh



#### MXC\_PTDPF3 field descriptions

| Field |                          | Description          |  |
|-------|--------------------------|----------------------|--|
| 7–4   | Port D3 Pin Mux Controls |                      |  |
| D3    |                          | ADOS OF ASTRONO OLIS |  |
|       | 0000                     | ADC0_SE10/TSI0_CH2   |  |
|       | 0001                     | PTD3                 |  |
|       | 0010                     | FTM0_QD_PHB          |  |
|       | 0011                     | RGPIO11              |  |
|       | 0100                     | FTM0_CH1             |  |
|       | 0101                     | FBa_D6               |  |
|       | 0110                     | FBa_AD0              |  |
|       | 0111                     | Reserved             |  |
|       | 1000-1111                | Reserved             |  |
| 3–0   | Port D2 Pin              | Mux Controls         |  |
| D2    |                          | 4D00 050/500 0111    |  |
|       | 0000                     | ADC0_SE9/TSI0_CH1    |  |
|       | 0001                     | PTD2                 |  |
|       | 0010                     | FTM0_QD_PHA          |  |
|       | 0011                     | RGPIO10              |  |
|       | 0100                     | FTM0_CH0             |  |
|       | 0101                     | Reserved             |  |
|       | 0110                     | Reserved             |  |
|       | 0111                     | Reserved             |  |
|       | 1000-1111                | Reserved             |  |

# 10.2.16 Port D Pin Function 4 Register (MXC\_PTDPF4)

Address: MXC\_PTDPF4 is FFFF\_8080h base + Fh offset = FFFF\_808Fh



## **MXC\_PTDPF4** field descriptions

| Field |             | Description          |
|-------|-------------|----------------------|
| 7–4   | Port D1 Pin | Mux Controls         |
| D1    |             |                      |
|       | 0000        | Disabled             |
|       | 0001        | PTD1                 |
|       | 0010        | UARTO_RTS_b          |
|       | 0011        | I2C1_SCL             |
|       | 0100        | RGPIO9               |
|       | 0101        | SPI1_SS              |
|       | 0110        | FBa_AD14             |
|       | 0111        | I2S0_RX_BCLK         |
|       | 1000-1111   | Reserved             |
| 3–0   | Port D0 Pin | Mux Controls         |
| D0    |             |                      |
|       | 0000        | Disabled             |
|       | 0001        | PTD0                 |
|       | 0010        | UARTO_CTS_b          |
|       | 0011        | I2C1_SDA             |
|       | 0100        | RGPIO8               |
|       | 0101        | SPI1_SCLK            |
|       | 0110        | FBa_AD13             |
|       | 0111        | 12S0_MCLK/12S0_CLKIN |
|       | 1000-1111   | Reserved             |

# 10.2.17 Port E Pin Function 1 Register (MXC\_PTEPF1)

Address: MXC\_PTEPF1 is FFFF\_8080h base + 10h offset = FFFF\_8090h



# **MXC\_PTEPF1** field descriptions

| Field     |             | Description  |
|-----------|-------------|--------------|
| 7–4<br>E7 | Port E7 Pin | Mux Controls |
|           | 0000        | ADC0_SE22    |
|           | 0001        | PTE7         |
|           | 0010        | UARTO_TX     |
|           | 0011        | PDB0_EXTRG   |
|           | 0100        | SPI1_MOSI    |
|           | 0101        | FBa_RW_b     |
|           | 0110        | FBa_AD4      |
|           | 0111        | Reserved     |
|           | 1000-1111   | Reserved     |
| 3–0<br>E6 | Port E6 Pin | Mux Controls |
|           | 0000        | ADC0_SE21    |
|           | 0001        | PTE6         |
|           | 0010        | UART0_RX     |
|           | 0011        | I2C1_SDA     |
|           | 0100        | SPI1_MISO    |
|           | 0101        | Reserved     |
|           | 0110        | FBa_AD3      |
|           | 0111        | Reserved     |
|           | 1000-1111   | Reserved     |

# 10.2.18 Port E Pin Function 2 Register (MXC\_PTEPF2)

Address: MXC\_PTEPF2 is FFFF\_8080h base + 11h offset = FFFF\_8091h



## **MXC\_PTEPF2** field descriptions

| Field     |                          | Description |
|-----------|--------------------------|-------------|
| 7–4<br>E5 | Port E5 Pin Mux Controls |             |
|           | 0000                     | ADC0_SE20   |
|           | 0001                     | PTE5        |
|           | 0010                     | UART0_CTS_b |
|           | 0011                     | I2C1_SCL    |
|           | 0100                     | SPI1_SCLK   |
|           | 0101                     | Reserved    |
|           | 0110                     | FBa_AD2     |

Table continues on the next page...

## **MXC\_PTEPF2** field descriptions (continued)

| Field     |             | Description         |
|-----------|-------------|---------------------|
|           | 0111        | Reserved            |
|           | 1000-1111   | Reserved            |
| 3–0<br>E4 | Port E4 Pin | Mux Controls        |
|           | 0000        | ADC0_SE19/TSI0_CH15 |
|           | 0001        | PTE4                |
|           | 0010        | UARTO_RTS_b         |
|           | 0011        | LPTMR_ALT3          |
|           | 0100        | SPI1_SS             |
|           | 0101        | Reserved            |
|           | 0110        | FBa_AD1             |
|           | 0111        | Reserved            |
|           | 1000-1111   | Reserved            |

# 10.2.19 Port E Pin Function 3 Register (MXC\_PTEPF3)

Address: MXC\_PTEPF3 is FFFF\_8080h base + 12h offset = FFFF\_8092h



#### **MXC\_PTEPF3** field descriptions

| Field |             | Description         |
|-------|-------------|---------------------|
| 7–4   | Port E3 Pin | Mux Controls        |
| E3    |             |                     |
|       | 0000        | ADC0_SE16/TSI0_CH12 |
|       | 0001        | PTE3                |
|       | 0010        | SPI0_MOSI           |
|       | 0011        | I2C3_SDA            |
|       | 0100        | Reserved            |
|       | 0101        | Reserved            |
|       | 0110        | FBa_OE_b            |
|       | 0111        | Reserved            |
|       | 1000-1111   | Reserved            |
| 3–0   | Port E2 Pin | Mux Controls        |
| E2    | 0000        | TOIO 01144          |
|       | 0000        | TSI0_CH11           |
|       | 0001        | PTE2                |
|       | 0010        | Reserved            |
|       | 0011        | I2C3_SCL            |
|       | 0100        | Reserved            |

Table continues on the next page...

## **MXC\_PTEPF3** field descriptions (continued)

| Field |           | Description |
|-------|-----------|-------------|
|       | 0101      | Reserved    |
|       | 0110      | FBa_D0      |
|       | 0111      | Reserved    |
|       | 1000-1111 | Reserved    |

# 10.2.20 Port E Pin Function 4 Register (MXC\_PTEPF4)

Address: MXC\_PTEPF4 is FFFF\_8080h base + 13h offset = FFFF\_8093h



## **MXC\_PTEPF4** field descriptions

| Field |             | Description  |
|-------|-------------|--------------|
| 7–4   | Port E1 Pin | Mux Controls |
| E1    | 0000        | TOIO OLIO    |
|       | 0000        | TSI0_CH9     |
|       | 0001        | PTE1         |
|       | 0010        | SPI0_SS      |
|       | 0011        | Reserved     |
|       | 0100        | FTM_FLT0     |
|       | 0101        | Reserved     |
|       | 0110        | FBa_D1       |
|       | 0111        | Reserved     |
|       | 1000-1111   | Reserved     |
| 3–0   | Port E0 Pin | Mux Controls |
| E0    | 0000        | TSI0_CH8     |
|       | 0001        | PTE0         |
|       | 0010        | UARTO_RTS_b  |
|       | 0011        | I2C3_SDA     |
|       | 0100        | Reserved     |
|       | 0100        | Reserved     |
|       | 0110        | FBa_D2       |
|       |             |              |
|       | 0111        | Reserved     |
|       | 1000-1111   | Reserved     |

# 10.2.21 Port F Pin Function 1 Register (MXC\_PTFPF1)

Address: MXC\_PTFPF1 is FFFF\_8080h base + 14h offset = FFFF\_8094h



## **MXC\_PTFPF1** field descriptions

| Field     |             | Description  |
|-----------|-------------|--------------|
| 7–4<br>F7 | Port F7 Pin | Mux Controls |
|           | 0000        | Disabled     |
|           | 0001        | PTF7         |
|           | 0010        | UART0_RTS_b  |
|           | 0011        | Reserved     |
|           | 0100        | SPI0_SS      |
|           | 0101        | FBa_D0       |
|           | 0110        | FBa_AD10     |
|           | 0111        | I2SO_RX_BCLK |
|           | 1000-1111   | Reserved     |
| 3–0       | Port F6 Pin | Mux Controls |
| F6        | 0000        | Disabled     |
|           | 0001        | PTF6         |
|           | 0010        | UART1_TX     |
|           | 0011        | SPI1_MOSI    |
|           | 0100        | Reserved     |
|           | 0101        | FBa_D1       |
|           | 0110        | FBa_AD9      |
|           | 0111        | 12S0_RX_FS   |
|           | 1000-1111   | Reserved     |

# 10.2.22 Port F Pin Function 2 Register (MXC\_PTFPF2)

Address: MXC\_PTFPF2 is FFFF\_8080h base + 15h offset = FFFF\_8095h



Downloaded from Elcodis.com electronic components distributor

# MXC\_PTFPF2 field descriptions

| Field     |             | Description  |
|-----------|-------------|--------------|
| 7–4<br>F5 | Port F5 Pin | Mux Controls |
|           | 0000        | Disabled     |
|           | 0001        | PTF5         |
|           | 0010        | UART1_RX     |
|           | 0011        | SPI1_MISO    |
|           | 0100        | Reserved     |
|           | 0101        | FBa_D2       |
|           | 0110        | FBa_RW_b     |
|           | 0111        | I2S0_RXD     |
|           | 1000-1111   | Reserved     |
| 3–0<br>F4 | Port F4 Pin | Mux Controls |
|           | 0000        | Disabled     |
|           | 0001        | PTF4         |
|           | 0010        | UART1_CTS_b  |
|           | 0011        | SPI1_SCLK    |
|           | 0100        | Reserved     |
|           | 0101        | FBa_D3       |
|           | 0110        | FBa_AD19     |
|           | 0111        | I2S0_TX_BCLK |
|           | 1000-1111   | Reserved     |

# 10.2.23 Port F Pin Function 3 Register (MXC\_PTFPF3)

Address: MXC\_PTFPF3 is FFFF\_8080h base + 16h offset = FFFF\_8096h



# MXC\_PTFPF3 field descriptions

| Field     |           | Description              |  |
|-----------|-----------|--------------------------|--|
| 7–4<br>F3 | Port F3 F | Port F3 Pin Mux Controls |  |
|           | 0000      | CMP0_IN2                 |  |
|           | 0001      | PTF3                     |  |
|           | 0010      | SPI0_MOSI                |  |
|           | 0011      | Reserved                 |  |
|           | 0100      | Reserved                 |  |
|           | 0101      | RGPIO1                   |  |
|           | 0110      | FBa_AD8                  |  |

Table continues on the next page...

## **MXC\_PTFPF3** field descriptions (continued)

| Field     |             | Description  |
|-----------|-------------|--------------|
|           | 0111        | 12S0_TXD     |
|           | 1000-1111   | Reserved     |
| 3–0<br>F2 | Port F2 Pin | Mux Controls |
|           | 0000        | CMP0_IN1     |
|           | 0001        | PTF2         |
|           | 0010        | SPI0_MISO    |
|           | 0011        | Reserved     |
|           | 0100        | Reserved     |
|           | 0101        | Reserved     |
|           | 0110        | FBa_AD7      |
|           | 0111        | Reserved     |
|           | 1000-1111   | Reserved     |

# 10.2.24 Port F Pin Function 4 Register (MXC\_PTFPF4)

Address: MXC\_PTFPF4 is FFFF\_8080h base + 17h offset = FFFF\_8097h



#### **MXC\_PTFPF4** field descriptions

| Field     |             | Description  |
|-----------|-------------|--------------|
| 7–4<br>F1 | Port F1 Pin | Mux Controls |
|           | 0000        | Disabled     |
|           | 0001        | PTF1         |
|           | 0010        | SPI0_SCLK    |
|           | 0011        | Reserved     |
|           | 0100        | Reserved     |
|           | 0101        | CMP0_OUT     |
|           | 0110        | FBa_AD6      |
|           | 0111        | Reserved     |
|           | 1000-1111   | Reserved     |
| 3–0<br>F0 | Port F0 Pin | Mux Controls |
|           | 0000        | CMP0_IN0     |
|           | 0001        | PTF0         |
|           | 0010        | SPIO_SS      |
|           | 0011        | Reserved     |
|           | 0100        | Reserved     |

Table continues on the next page...

## **MXC\_PTFPF4** field descriptions (continued)

| Field |           | Description |
|-------|-----------|-------------|
|       | 0101      | Reserved    |
|       | 0110      | FBa_AD5     |
|       | 0111      | Reserved    |
|       | 1000-1111 | Reserved    |

# Chapter 11 Core

## 11.1 Introduction

This section describes the organization of the Version 1 (V1) ColdFire® processor core and an overview of the program-visible registers. For detailed information on instructions, see the ISA\_ C definition in the *ColdFire Family Programmer's Reference Manual*.

#### 11.1.1 Overview

As with all ColdFire cores, the V1 ColdFire core consists of two separate pipelines decoupled by an instruction buffer.



Figure 11-1. V1 ColdFire Core Pipelines

The instruction fetch pipeline (IFP) is a two-stage pipeline for prefetching instructions. The prefetched instruction stream is then gated into the two-stage operand execution pipeline (OEP), that decodes the instruction, fetches the required operands, and then executes the required function. Because the IFP and OEP pipelines are decoupled by an instruction buffer serving as a FIFO queue, the IFP is able to prefetch instructions in advance of their actual use by the OEP thereby minimizing time stalled waiting for instructions.

The V1 ColdFire core pipeline stages include the following:

- Two-stage instruction fetch pipeline (IFP) (plus optional instruction buffer stage)
  - Instruction address generation (IAG) Calculates the next prefetch address
  - Instruction fetch cycle (IC) Initiates prefetch on the processor's local bus
  - Instruction buffer (IB) Optional buffer stage minimizes fetch latency effects using FIFO queue
- Two-stage operand execution pipeline (OEP)

- Decode and select/operand fetch cycle (DSOC) Decodes instructions and fetches the required components for effective address calculation, or the operand fetch cycle
- Address generation/execute cycle (AGEX) Calculates operand address or executes the instruction

When the instruction buffer is empty, opcodes are loaded directly from the IC cycle into the operand execution pipeline. If the buffer is not empty, the IFP stores the contents of the fetched instruction in the IB until it is required by the OEP. The instruction buffer on the V1 core contains three longwords of storage.

For register-to-register and register-to-memory store operations, the instruction passes through both OEP stages once. For memory-to-register and read-modify-write memory operations, an instruction is effectively staged through the OEP twice; the first time to calculate the effective address and initiate the operand fetch on the processor's local bus, and the second time to complete the operand reference and perform the required function defined by the instruction.

The resulting pipeline and local bus structure allow the V1 ColdFire core to deliver sustained high performance across a variety of demanding embedded applications.

# 11.2 Memory Map/Register Description

The following sections describe the processor registers in the user and supervisor programming models. The programming model is selected based on the processor privilege level (user mode or supervisor mode) as defined by the S bit of the status register (SR).

The user-programming model consists of the following registers:

- 16 general-purpose 32-bit registers (D0–D7, A0–A7)
- 32-bit program counter (PC)
- 8-bit condition code register (CCR)
- EMAC registers (refer to EMAC description)
  - Four 48-bit accumulator registers partitioned as follows:

#### **Memory Map/Register Description**

- Four 32-bit accumulators (ACC0–ACC3)
- Eight 8-bit accumulator extension bytes (two per accumulator). These are grouped into two 32-bit values for load and store operations (ACCEXT01 and ACCEXT23).

Accumulators and extension bytes can be loaded, copied, and stored, and results from EMAC arithmetic operations generally affect the entire 48-bit destination.

- One 16-bit mask register (MASK)
- One 32-bit status register (MACSR) including four indicator bits signaling product or accumulation overflow (one for each accumulator: PAV0–PAV3)

The supervisor programming model is to be used only by system control software to implement restricted operating system functions, I/O control, and memory management. All accesses that affect the control features of ColdFire processors are in the supervisor programming model, that consists of registers available in user mode as well as the following control registers:

- 16-bit status register (SR)
- 32-bit supervisor stack pointer (SSP)
- 32-bit vector base register (VBR)
- 32-bit CPU configuration register (CPUCR)

Table 11-1. ColdFire core programming model

| BDM<br>command <sup>1</sup> | Register <sup>2</sup>            | Width<br>(bits) | Access | Reset value      | Written<br>with<br>MOVEC <sup>3</sup> |  |  |  |  |  |
|-----------------------------|----------------------------------|-----------------|--------|------------------|---------------------------------------|--|--|--|--|--|
|                             | Supervisor/user access registers |                 |        |                  |                                       |  |  |  |  |  |
| Load: 0x60                  | Data register 0 (D0)             | 32              | R/W    | See Reset        | No                                    |  |  |  |  |  |
| Store: 0x40                 | see Data registers (D0-D7)       |                 |        | Exception        |                                       |  |  |  |  |  |
| Load: 0x61                  | Data register 1 (D1)             | 32              | R/W    | See Reset        | No                                    |  |  |  |  |  |
| Store: 0x41                 | see Data registers (D0-D7)       |                 |        | Exception        |                                       |  |  |  |  |  |
| Load: 0x62-7                | Data registers 2-7 (D2-7)        | 32              | R/W    | POR: Undefined   | No                                    |  |  |  |  |  |
| Store: 0x42-7               | see Data registers (D0-D7)       |                 |        | Else: Unaffected |                                       |  |  |  |  |  |
| Load: 0x68-E                | Address registers (A0–A6)        | 32              | R/W    | POR: Undefined   | No                                    |  |  |  |  |  |
| Store: 0x48-E               |                                  |                 |        | Else: Unaffected |                                       |  |  |  |  |  |

Table continues on the next page...

Table 11-1. ColdFire core programming model (continued)

| BDM<br>command <sup>1</sup> | Register <sup>2</sup>                                | Width<br>(bits) | Access | Reset value               | Written<br>with<br>MOVEC <sup>3</sup> |  |
|-----------------------------|------------------------------------------------------|-----------------|--------|---------------------------|---------------------------------------|--|
| Load: 0x6F                  | User stack pointer                                   | 32              | R/W    | POR: Undefined            | No                                    |  |
| Store: 0x4F                 | see Supervisor/user stack pointers (A7 and OTHER_A7) |                 |        | Else: Unaffected          |                                       |  |
| Load: 0xE4                  | MAC status register (MACSR)                          | 32              | R/W    | 0x0000_0000               | No                                    |  |
| Store: 0xC4                 |                                                      |                 |        |                           |                                       |  |
| Load: 0xE5                  | MAC address mask register (MASK)                     | 16              | R/W    | 0xFFFF                    | No                                    |  |
| Store: 0xC5                 |                                                      |                 |        |                           |                                       |  |
| Load: 0xE6                  | MAC accumulator (ACC)                                | 32              | R/W    | POR: Undefined            | No                                    |  |
| Store: 0xC6                 |                                                      |                 |        | Else: Unaffected          |                                       |  |
| Load: 0xE7                  | MAC accumulator 0,1 extension bytes                  | 32              | R/W    | POR: Undefined            | No                                    |  |
| Store: 0xC7                 | (ACCext01)                                           |                 |        | Else: Unaffected          |                                       |  |
| Load: 0xE8                  | MAC accumulator 2,3 extension bytes                  | 32              | R/W    | POR: Undefined            | No                                    |  |
| Store: 0xC8                 | (ACCext23)                                           |                 |        | Else: Unaffected          |                                       |  |
| Load: 0xEE                  | Condition code register (CCR) (LSB of Status         | 8               | R/W    | POR: Undefined            | No                                    |  |
| Store: 0xCE                 | register (SR))                                       |                 |        | Else: Unaffected          |                                       |  |
| Load: 0xEF                  | Program counter (PC)                                 | 32              | R/W    | Contents of               | No                                    |  |
| Store: 0xCF                 |                                                      |                 |        | location<br>0x(00)00_0004 |                                       |  |
|                             | Supervisor access o                                  | nly registers   |        |                           |                                       |  |
| Load: 0xE0                  | Supervisor stack pointer                             | 32              | R/W    | Contents of               | No                                    |  |
| Store: 0xC0                 | see Supervisor/user stack pointers (A7 and OTHER_A7) |                 |        | location<br>0x(00)00_0000 |                                       |  |
| Load: 0xE1                  | Vector base register (VBR)                           | 32              | R/W    | See register's            | Yes                                   |  |
| Store: 0xC1                 |                                                      |                 |        | description               | Rc = 0x801                            |  |
| Load: 0xE2                  | CPU configuration register (CPUCR)                   | 32              | W      | See register's            | Yes                                   |  |
| Store: 0xC2                 |                                                      |                 |        | description               | Rc = 0x802                            |  |
| Load: 0xEE                  | Status register (SR)                                 | 16              | R/W    | 0x27                      | No                                    |  |
| Store: 0xCE                 |                                                      |                 |        |                           |                                       |  |

<sup>1.</sup> The values listed in this column represent the 8-bit BDM command code used when accessing the core registers via the 1-pin BDM port. For details, see information about ColdFire debug operation. (These BDM commands are not similar to those of non-V1 ColdFire processors.)

<sup>2.</sup> The EMAC registers are available only if the EMAC module is present on the device.

<sup>3.</sup> If the given register is written using the MOVEC instruction, the 12-bit control register address (Rc) is also specified.

# 11.2.1 Data registers (D0-D7)

These registers are for bit (1-bit), byte (8-bit), word (16-bit) and longword (32-bit) operations; they can also be used as index registers.

#### **NOTE**

The D0 and D1 registers contain hardware configuration details after reset. See Reset Exception for more details.

BDM: Load: 0x60 + n; n = 0-7 (Dn) Access: User read/write Store: 0x40 + n; n = 0-7 (Dn) BDM read/write 31 30 29 28 27 26 25 24 23 22 20 19 18 17 16 21 R Data W Reset (D2-D7) Reset (D0, See Reset Exception D1) 15 14 13 12 11 10 5 3 2 0 1 Data W Reset (D2-Reset (D0, See Reset Exception D1)

Table 11-2. Data registers (D0-D7)

# 11.2.2 Address registers (A0-A6)

These registers can be used as software stack pointers, index registers, or base address registers. They can also be used for word and longword operations.



Table 11-3. Address registers (A0–A6)

Table continues on the next page...

#### Table 11-3. Address registers (A0-A6) (continued)



# 11.2.3 Supervisor/user stack pointers (A7 and OTHER\_A7)

This ColdFire architecture supports two independent stack pointer (A7) registers: the supervisor stack pointer (SSP) and the user stack pointer (USP). The hardware implementation of these two program-visible 32-bit registers does not identify one as the SSP and the other as the USP. Instead, the hardware uses one 32-bit register as the active A7 and the other as OTHER\_A7. Thus, the register contents are a function of the processor operation mode, as shown in the following:

The BDM programming model supports direct reads and writes to A7 and OTHER\_A7. It is the responsibility of the external development system to determine, based on the setting of SR[S], the mapping of A7 and OTHER\_A7 to the two program-visible definitions (SSP and USP).

To support dual stack pointers, the following two supervisor instructions are included in the ColdFire instruction set architecture to load/store the USP:

```
move.l Ay,USP;move to USP
move.l USP,Ax;move from USP
```

The *ColdFire Family Programmer's Reference Manual* describes these instructions. All other instruction references to the stack pointer, explicit or implicit, access the active A7 register.

#### NOTE

The USP must be initialized using the

```
move.l Ay, USP
```

instruction before any entry into user mode.

The SSP is loaded during reset exception processing with the contents of location  $0x(00)00\_0000$ .

Table 11-4. Stack pointer registers (A7 and OTHER\_A7)



# 11.2.4 Condition code register (CCR)

The CCR is the LSB of the processor status register (SR). Bits 4–0 act as indicator flags for results generated by processor operations. The extend bit (X) is also an input operand during multiprecision arithmetic computations. The CCR register must be explicitly loaded after reset and before any CMP, Bcc, or Scc instructions are executed.

Table 11-5. Condition code register (CCR)



Table 11-6. CCR field descriptions

| Field | Description                                                                                                          |
|-------|----------------------------------------------------------------------------------------------------------------------|
| 7–5   | Reserved; must be cleared.                                                                                           |
| 4     | Extend condition code                                                                                                |
| X     | This bit is set to the C bit's value for arithmetic operations; otherwise not affected or set to a specified result. |

Table continues on the next page...

Table 11-6. CCR field descriptions (continued)

| Field | Description                                                                                                                         |
|-------|-------------------------------------------------------------------------------------------------------------------------------------|
| 3     | Negative condition code                                                                                                             |
| N     | This bit is set if the most significant bit of the result is set; otherwise cleared.                                                |
| 2     | Zero condition code                                                                                                                 |
| Z     | This bit is set if result equals zero; otherwise cleared.                                                                           |
| 1     | Overflow condition code                                                                                                             |
| V     | This bit is set if an arithmetic overflow occurs implying the result cannot be represented in operand size; otherwise cleared.      |
| 0     | Carry condition code                                                                                                                |
| С     | This bit is set if a carry out of the operand msb occurs for an addition or if a borrow occurs in a subtraction; otherwise cleared. |

# 11.2.5 Program counter (PC)

The PC contains the currently executing instruction address. During instruction execution and exception processing, the processor automatically increments PC contents or places a new value in the PC. The PC is a base address for PC-relative operand addressing.

The PC is initially loaded during reset exception processing with the contents at location  $0x(00)00\_0004$ .

BDM: Load: 0xEF (PC) Access: User read/write Store: 0xCF (PC) BDM read/write Address W Reset R Address W Reset

Table 11-7. Program counter (PC) register

## 11.2.6 Vector base register (VBR)

The VBR contains the base address of the exception vector table in the memory. To access the vector table, the displacement of an exception vector is added to the value in VBR. The lower 20 bits of the VBR are not implemented by ColdFire processors. They are assumed to be zero, forcing the table to be aligned on a 1 MB boundary.

In addition, because the V1 ColdFire core supports a 16 MB address space, the upper byte of the VBR is also forced to zero. The VBR can be used to relocate the exception vector table from its default position in the flash memory (address  $0x(00)00\_0000$ ) to the base of the RAM (address  $0x(00)80\_0000$ ) if needed.

| BDM:  |    |    | 0x801 (VBR) |    |    |         |        |    |    |        | Access: Supervisor read/<br>write |    |    | read/  |          |    |
|-------|----|----|-------------|----|----|---------|--------|----|----|--------|-----------------------------------|----|----|--------|----------|----|
|       |    |    |             |    | Lo | oad: 0x | E1 (VB | R) |    |        |                                   |    |    |        |          |    |
|       |    |    |             |    | St | ore: 0x | C1 (VB | R) |    |        |                                   |    |    | BDM re | ad/write | Э  |
|       | 31 | 30 | 29          | 28 | 27 | 26      | 25     | 24 | 23 | 22     | 21                                | 20 | 19 | 18     | 17       | 16 |
| R     | 0  | 0  | 0           | 0  | 0  | 0       | 0      | 0  |    | Base A | ddraee                            |    | _  | _      | _        | _  |
| W     |    |    |             |    |    |         |        |    |    | Dase A | idal 633                          |    |    |        |          |    |
| Reset | 0  | 0  | 0           | 0  | 0  | 0       | 0      | 0  | 0  | 0      | 0                                 | 0  | _  | -      | -        | _  |
|       | 15 | 14 | 13          | 12 | 11 | 10      | 9      | 8  | 7  | 6      | 5                                 | 4  | 3  | 2      | 1        | 0  |
| R     | _  | _  | _           | _  | _  | _       | _      | _  | _  | _      | _                                 | -  | _  | _      | _        | _  |
| w [   |    |    |             |    |    |         |        |    |    |        |                                   |    |    |        |          |    |
| Reset | _  | _  | _           | _  | _  | _       | _      | _  | _  | _      | _                                 | _  | _  | _      | _        | -  |

Table 11-8. Vector base register (VBR)

# 11.2.7 CPU configuration register (CPUCR)

This register provides supervisor mode configurability of specific core functionality. Particular hardware features can be enabled/disabled individually based on the state of the CPUCR.

#### NOTE

Program the Flash Memory Controller's configuration and control settings only while the Flash Memory Controller is idle. Changing settings while a flash access is in progress can lead to non-deterministic behavior.

#### NOTE

System software is required to maintain memory coherence when any segment of the program flash memory cache is programmed. For example, all buffer data associated with the

reprogrammed flash should be invalidated. Accordingly, cache program visible writes must occur after a programming or erase event is completed and before the new memory image is accessed.

Table 11-9. CPU configuration register (CPUCR)

| BDM:  | BDM: 0x802 (CPUCR)  Load: 0xE2 (CPUCR)  Store: 0xC2 (CPUCR) |     |     |     |     |     |     |     |     | Access: Supervisor read/<br>write<br>BDM read/write |     |      |           |    |    |    |
|-------|-------------------------------------------------------------|-----|-----|-----|-----|-----|-----|-----|-----|-----------------------------------------------------|-----|------|-----------|----|----|----|
|       | 31                                                          | 30  | 29  | 28  | 27  | 26  | 25  | 24  | 23  | 22                                                  | 21  | 20   | 19        | 18 | 17 | 16 |
| R     |                                                             |     |     |     |     |     |     | CBR |     | FCDI                                                | FDC | FICD | 0         | _  | _  | _  |
| W     | ARD                                                         | IRD | IAE | IME | BWD | HAE | FSD | R   | FHP | S                                                   | EN  |      | FCC<br>LR |    |    |    |
| Reset | 0                                                           | 0   | 0   | 0   | 0   | 0   | 0   | 0   | _   | 0                                                   | 0   | 0    | 0         | _  | _  | _  |
|       | 15                                                          | 14  | 13  | 12  | 11  | 10  | 9   | 8   | 7   | 6                                                   | 5   | 4    | 3         | 2  | 1  | 0  |
| R     | -                                                           | -   | _   | _   | _   | _   | _   | _   | _   | _                                                   | 1   | _    | -         | _  | _  | _  |
| w     |                                                             |     |     |     |     |     |     |     |     |                                                     |     |      |           |    |    |    |
| Reset | _                                                           | _   | _   | _   | _   | _   | _   | _   | _   | _                                                   | _   | _    | _         | _  | _  | _  |

Table 11-10. CPUCR field descriptions

| Field | Description                                                                                                                                                                                                                                                                                       |  |  |  |  |  |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 31    | Address-related reset disable                                                                                                                                                                                                                                                                     |  |  |  |  |  |
| ARD   | Used to disable the generation of a reset event in response to a processor exception caused by an address error, a bus error, an RTE format error, or a fault-on-fault halt condition.                                                                                                            |  |  |  |  |  |
|       | The detection of these types of exception conditions or the fault-on-fault halt condition generate a reset event.                                                                                                                                                                                 |  |  |  |  |  |
|       | 1 No reset is generated in response to these exception conditions.                                                                                                                                                                                                                                |  |  |  |  |  |
| 30    | Instruction-related reset disable                                                                                                                                                                                                                                                                 |  |  |  |  |  |
| IRD   | Used to disable the generation of a reset event in response to a processor exception caused by the attempted execution of an illegal instruction (except for the ILLEGAL opcode), illegal line A, illegal line F instructions, or a privilege violation.                                          |  |  |  |  |  |
|       | The detection of these types of exception conditions generate a reset event.                                                                                                                                                                                                                      |  |  |  |  |  |
|       | 1 No reset is generated in response to these exception conditions.                                                                                                                                                                                                                                |  |  |  |  |  |
| 29    | Interrupt acknowledge (IACK) enable                                                                                                                                                                                                                                                               |  |  |  |  |  |
| IAE   | Forces the processor to generate an IACK read cycle from the interrupt controller during exception processing to retrieve the vector number of the interrupt request being acknowledged. The processor's execution time for an interrupt exception is slightly improved when this bit is cleared. |  |  |  |  |  |
|       | O The processor uses the vector number provided by the interrupt controller at the time the request is signaled.                                                                                                                                                                                  |  |  |  |  |  |
|       | 1 IACK read cycle from the interrupt controller is generated.                                                                                                                                                                                                                                     |  |  |  |  |  |

Table continues on the next page...

#### **Memory Map/Register Description**

Downloaded from Elcodis.com electronic components distributor

Table 11-10. CPUCR field descriptions (continued)

| Field | Description                                                                                                                                                                                                  |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 28    | Interrupt mask enable                                                                                                                                                                                        |
| IME   | Forces the processor to raise the interrupt level mask (SR[I]) to 7 during every interrupt exception.                                                                                                        |
|       | O As part of an interrupt exception, the processor sets SR[I] to the level of the interrupt being serviced.                                                                                                  |
|       | 1 As part of an interrupt exception, the processor sets SR[I] to 7. This disables all level 1-6 interrupt requests but allows recognition of the edge-sensitive level 7 requests.                            |
| 27    | Buffered write disable                                                                                                                                                                                       |
| BWD   | The ColdFire core is capable of marking processor memory writes as bufferable or non-bufferable.                                                                                                             |
|       | <b>NOTE:</b> If buffered writes are enabled (BWD is 0), any error status is lost as the immediate termination of the data transfer assumes an error-free completion.                                         |
|       | 0 Writes are buffered and the bus cycle is terminated immediately with zero wait states.                                                                                                                     |
|       | Disable the buffering of writes. In this configuration, the write transfer is terminated based on the response time of the addressed destination memory device.                                              |
| 26    | Crossbar high priority arbitration enable                                                                                                                                                                    |
| HAE   | Elevates the processor's fixed crossbar arbitration from lowest to highest during the processing of an interrupt service routine.                                                                            |
|       | O Do not enable the processor's fixed crossbar arbitration from lowest to highest during the processing of an interrupt service routine.                                                                     |
|       | 1 Enable the processor's fixed crossbar arbitration from lowest to highest during the processing of an interrupt service routine.                                                                            |
| 25    | Flash speculation disable                                                                                                                                                                                    |
| FSD   | This bit controls whether prefetching by the speculation buffer is enabled. When enabled, prefetching occurs only for program flash accesses. Disabling prefetching also clears the current prefetch buffer. |
|       | 0 Prefetching is enabled.                                                                                                                                                                                    |
|       | 1 Prefetching is disabled.                                                                                                                                                                                   |
| 24    | Crossbar round-robin arbitration enable                                                                                                                                                                      |
| CBRR  | Configures the crossbar slave ports to fixed-priority or round-robin arbitration.                                                                                                                            |
|       | 0 Fixed-priority arbitration                                                                                                                                                                                 |
|       | 1 Round-robin arbitration                                                                                                                                                                                    |
| 23    | Crossbar force high priority arbitration.                                                                                                                                                                    |
| FHP   | Elevates the processor's fixed crossbar arbitration from lowest to highest.                                                                                                                                  |
|       | O Do not force the elevation of the processor's fixed crossbar arbitration from lowest to highest.                                                                                                           |
|       | 1 Force the elevation of the processor's fixed crossbar arbitration from lowest to highest.                                                                                                                  |

Table continues on the next page...

Table 11-10. CPUCR field descriptions (continued)

| Field  | Description                                                                                                                  |  |  |  |  |  |
|--------|------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 22     | Flash controller cache disable                                                                                               |  |  |  |  |  |
| FCDIS  | Disables the caching of the flash read data. This bit overrides the instruction and data cache enables.                      |  |  |  |  |  |
|        | The flash controller's cache is enabled. Use the instruction and data cache enable bits to decide which accesses are cached. |  |  |  |  |  |
|        | 1 The flash controller's cache is disabled. (lower performance)                                                              |  |  |  |  |  |
| 21     | Flash data caching enable                                                                                                    |  |  |  |  |  |
| FDCEN  | Enables the caching of operand fetches from the flash memory controller.                                                     |  |  |  |  |  |
|        | 0 Data accesses via the flash controller cache are disabled.                                                                 |  |  |  |  |  |
|        | 1 Data accesses via the flash controller cache are enabled.                                                                  |  |  |  |  |  |
| 20     | Flash instruction caching disable                                                                                            |  |  |  |  |  |
| FICDIS | Disables the caching of instruction fetches from the flash memory controller.                                                |  |  |  |  |  |
|        | 0 Instruction fetches via the flash controller cache are enabled.                                                            |  |  |  |  |  |
|        | 1 Instruction fetches via the flash controller cache are disabled.                                                           |  |  |  |  |  |
| 19     | Clear flash controller cache                                                                                                 |  |  |  |  |  |
| FCCLR  | Setting this bit to 1 clears (invalidates) the cache immediately. This bit always reads as 0.                                |  |  |  |  |  |
| 18–0   | Reserved; must be cleared.                                                                                                   |  |  |  |  |  |

## 11.2.8 Status register (SR)

This register stores the processor status and includes the CCR, the interrupt priority mask, and other control bits. In supervisor mode, software can access the entire SR. In user mode, only the lower 8 bits (the CCR) are accessible. The control bits indicate the following states for the processor: trace mode (T bit), supervisor or user mode (S bit), and master or interrupt state (M bit). All defined bits in the SR have read/write access when in supervisor mode. The lower byte of the SR (the CCR) must be loaded explicitly after reset and before any compare (CMP), Bcc, or Scc instructions execute.

Table 11-11. Status register (SR)



#### **Functional Description**

Table 11-12. SR field descriptions

| Field | Description                                                                                                                                                                                    |  |  |  |  |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 15    | Trace enable                                                                                                                                                                                   |  |  |  |  |
| Т     | When this bit is set, the processor performs a trace exception after every instruction.                                                                                                        |  |  |  |  |
| 14    | Reserved; must be cleared.                                                                                                                                                                     |  |  |  |  |
| 13    | Supervisor/user state                                                                                                                                                                          |  |  |  |  |
| S     | 0 User mode                                                                                                                                                                                    |  |  |  |  |
|       | 1 Supervisor mode                                                                                                                                                                              |  |  |  |  |
| 12    | Master/interrupt state                                                                                                                                                                         |  |  |  |  |
| M     | This bit is cleared by an interrupt exception, and software can set it during execution of the RTE or move to SR instructions.                                                                 |  |  |  |  |
| 11    | Reserved; must be cleared.                                                                                                                                                                     |  |  |  |  |
| 10–8  | Interrupt level mask                                                                                                                                                                           |  |  |  |  |
| I     | Defines current interrupt level. Interrupt requests are inhibited for all priority levels less than or equal to current level, except edge-sensitive level 7 requests, which cannot be masked. |  |  |  |  |
| 7–0   | Refer to Condition code register (CCR)                                                                                                                                                         |  |  |  |  |

# 11.3 Functional Description

#### 11.3.1 Instruction Set Architecture

The original ColdFire instruction set architecture (ISA\_A) was derived from the M68000 family opcodes based on extensive analysis of embedded application code. The ISA was optimized for code compiled from high-level languages where the dominant operand size was the 32-bit integer declaration. This approach minimized processor complexity and cost, while providing excellent performance for compiled applications.

After the initial ColdFire compilers were created, developers noted there were certain ISA additions that would enhance code density and overall performance. Additionally, as users implemented ColdFire-based designs into a wide range of embedded systems, they found certain frequently-used instruction sequences that could be improved by the creation of additional instructions.

The original ISA definition minimized support for instructions referencing byte- and word-sized operands. Full support for the move byte and move word instructions was provided, but the only other opcodes supporting these data types are CLR (clear) and TST (test). A set of instruction enhancements has been implemented in subsequent ISA revisions, ISA\_B and ISA\_C. The new opcodes primarily addressed three areas:

- 1. Enhanced support for byte and word-sized operands
- 2. Enhanced support for position-independent code
- 3. Miscellaneous instruction additions to address new functionality

The following table summarizes the instructions added to revision ISA\_A to form revision ISA\_C. For more details see the *ColdFire Family Programmer's Reference Manual*.

Table 11-13. Instruction Enhancements over Revision ISA\_A

| Instruction   | Description                                                                                                                                                                                                                                                                 |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BITREV        | The contents of the destination data register are bit-reversed; that is, new Dn[31] equals old Dn[0], new Dn[30] equals old Dn[1],, new Dn[0] equals old Dn[31].                                                                                                            |
| BYTEREV       | The contents of the destination data register are byte-reversed; that is, new Dn[31:24] equals old Dn[7:0],, new Dn[7:0] equals old Dn[31:24].                                                                                                                              |
| FF1           | The data register, Dn, is scanned, beginning from the most-significant bit (Dn[31]) and ending with the least-significant bit (Dn[0]), searching for the first set bit. The data register is then loaded with the offset count from bit 31 where the first set bit appears. |
| MOV3Q.L       | Moves 3-bit immediate data to the destination location.                                                                                                                                                                                                                     |
| Move from USP | User Stack Pointer → Destination register                                                                                                                                                                                                                                   |
| Move to USP   | Source register → User Stack Pointer                                                                                                                                                                                                                                        |
| MVS.{B,W}     | Sign-extends source operand and moves it to destination register.                                                                                                                                                                                                           |
| MVZ.{B,W}     | Zero-fills source operand and moves it to destination register.                                                                                                                                                                                                             |
| SATS.L        | Performs saturation operation for signed arithmetic and updates destination register, depending on CCR[V] and bit 31 of the register.                                                                                                                                       |
| TAS.B         | Performs indivisible read-modify-write cycle to test and set addressed memory byte.                                                                                                                                                                                         |
| Bcc.L         | Branch conditionally, longword                                                                                                                                                                                                                                              |
| BSR.L         | Branch to sub-routine, longword                                                                                                                                                                                                                                             |
| CMP.{B,W}     | Compare, byte and word                                                                                                                                                                                                                                                      |
| CMPA.W        | Compare address, word                                                                                                                                                                                                                                                       |
| CMPI.{B,W}    | Compare immediate, byte and word                                                                                                                                                                                                                                            |
| MOVEI         | Move immediate, byte and word to memory using Ax with displacement                                                                                                                                                                                                          |
| STLDSR        | Pushes the contents of the status register onto the stack and then reloads the status register with the immediate data value.                                                                                                                                               |

# 11.3.2 Exception Processing Overview

Exception processing for ColdFire processors is streamlined for performance. The ColdFire processors differ from the M68000 family because they include:

#### **Functional Description**

- A simplified exception vector table
- Reduced relocation capabilities using the vector-base register
- A single exception stack frame format
- Use of separate system stack pointers for user and supervisor modes.

All ColdFire processors use an instruction restart exception model.

Exception processing includes all actions from fault condition detection to the initiation of fetch for first handler instruction. Exception processing is comprised of four major steps:

- 1. The processor makes an internal copy of the SR and then enters supervisor mode by setting the S bit and disabling trace mode by clearing the T bit. The interrupt exception also forces the M bit to be cleared and the interrupt priority mask to set to current interrupt request level.
- 2. The processor determines the exception vector number. For all faults except interrupts, the processor performs this calculation based on exception type. For interrupts, the processor performs an interrupt-acknowledge (IACK) bus cycle to obtain the vector number from the interrupt controller if CPUCR[IAE] is set. The IACK cycle is mapped to special locations within the interrupt controller's address space with the interrupt level encoded in the address. If CPUCR[IAE] is cleared, the processor uses the vector number supplied by the interrupt controller at the time the request was signaled for improved performance.
- 3. The processor saves the current context by creating an exception stack frame on the system stack. The exception stack frame is created at a 0-modulo-4 address on top of the system stack pointed to by the supervisor stack pointer (SSP). As shown in Figure 11-2, the processor uses a simplified fixed-length stack frame for all exceptions. The exception type determines whether the program counter placed in the exception stack frame defines the location of the faulting instruction (fault) or the address of the next instruction to be executed (next).
- 4. The processor calculates the address of the first instruction of the exception handler. By definition, the exception vector table is aligned on a 1 MB boundary. This instruction address is generated by fetching an exception vector from the table located at the address defined in the vector base register. The index into the exception table is calculated as (4 × vector number). After the exception vector has been fetched, the vector contents determine the address of the first instruction of the

desired handler. After the instruction fetch for the first opcode of the handler has initiated, exception processing terminates and normal instruction processing continues in the handler.

All ColdFire processors support a 1024-byte vector table aligned on any 1 MB address boundary (see Table 11-14). For the V1 ColdFire core, the only practical locations for the vector table are based at  $0x(00)00\_0000$  in the flash or  $0x(00)80\_0000$  in the internal SRAM.

The table contains 256 exception vectors; the first 64 are defined for the core and the remaining 192 are device-specific peripheral interrupt vectors. See the interrupt chapter for details on the device-specific interrupt sources.

For the V1 ColdFire core, the table is partially populated with the first 64 reserved for internal processor exceptions, while vectors 64-102 are reserved for the peripheral I/O requests and the seven software interrupts. Vectors 103–255 are unused and reserved.

**Table 11-14. Exception Vector Assignments** 

| Vector    | Vector Vector |                                      | Accienment                       |  |  |  |  |
|-----------|---------------|--------------------------------------|----------------------------------|--|--|--|--|
| Number(s) | Offset (Hex)  | Stacked Program Counter <sup>1</sup> | Assignment                       |  |  |  |  |
| 0         | 0x000         | _                                    | Initial supervisor stack pointer |  |  |  |  |
| 1         | 0x004         | _                                    | Initial program counter          |  |  |  |  |
| 2         | 0x008         | Fault                                | Access error                     |  |  |  |  |
| 3         | 0x00C         | Fault                                | Address error                    |  |  |  |  |
| 4         | 0x010         | Fault                                | Illegal instruction              |  |  |  |  |
| 5         | 0x014         | Fault                                | Divide by zero                   |  |  |  |  |
| 6–7       | 0x018-0x01C   | _                                    | Reserved                         |  |  |  |  |
| 8         | 0x020         | Fault                                | Privilege violation              |  |  |  |  |
| 9         | 0x024         | Next                                 | Trace                            |  |  |  |  |
| 10        | 0x028         | Fault                                | Unimplemented line-A opcode      |  |  |  |  |
| 11        | 0x02C         | Fault                                | Unimplemented line-F opcode      |  |  |  |  |
| 12        | 0x030         | Next                                 | Debug interrupt                  |  |  |  |  |
| 13        | 0x034         | _                                    | Reserved                         |  |  |  |  |
| 14        | 0x038         | Fault                                | Format error                     |  |  |  |  |
| 15–23     | 0x03C-0x05C   | _                                    | Reserved                         |  |  |  |  |
| 24        | 0x060         | Next                                 | Spurious interrupt               |  |  |  |  |
| 25–31     | 0x064-0x07C   | _                                    | Reserved                         |  |  |  |  |
| 32–47     | 0x080-0x0BC   | Next                                 | Trap # 0-15 instructions         |  |  |  |  |
| 48–60     | 0x0C0-0x0F0   | _                                    | Reserved                         |  |  |  |  |

Table continues on the next page...

**Table 11-14. Exception Vector Assignments (continued)** 

| Vector<br>Number(s) | Vector<br>Offset (Hex) | Stacked Program<br>Counter <sup>1</sup> | Assignment              |
|---------------------|------------------------|-----------------------------------------|-------------------------|
| 61                  | 0x0F4                  | Fault                                   | Unsupported instruction |
| 62–63               | 0x0F8-0x0FC            | _                                       | Reserved                |
| 64–102              | 0x100-0x198            | Next Device-specific interrupts         |                         |
| 103–255             | 0x19C-0x3FC            | _                                       | Reserved                |

<sup>1.</sup> Fault refers to the PC of the instruction that caused the exception.

Next refers to the PC of the instruction that follows the instruction that caused the fault.

All ColdFire processors inhibit interrupt sampling during the first instruction of all exception handlers. This allows any handler to disable interrupts effectively, if necessary, by raising the interrupt mask level contained in the status register. In addition, the ISA\_C architecture includes an instruction (STLDSR) that stores the current interrupt mask level and loads a value into the SR. This instruction is specifically intended for use as the first instruction of an interrupt service routine that services multiple interrupt requests with different interrupt levels. Finally, the V1 ColdFire core includes the CPUCR[IME] bit that forces the processor to automatically raise the mask level to 7 during the interrupt exception, removing the need for any explicit instruction in the service routine to perform this function. For more details, see *ColdFire Family Programmer's Reference Manual*.

## 11.3.2.1 Exception Stack Frame Definition

The following figures shows the exception stack frame. The first longword contains the 16-bit format/vector word (F/V) and the 16-bit status register, and the second longword contains the 32-bit program counter address.



Figure 11-2. Exception Stack Frame Form

The 16-bit format/vector word contains three unique fields:

• A 4-bit format field at the top of the system stack is always written with a value of 4, 5, 6, or 7 by the processor, indicating a two-longword frame format. See Table 11-15.

248

Table 11-15. Format Field Encodings

| Original SSP @ Time of Exception,<br>Bits 1:0 | SSP @ 1st Instruction of Handler | Format Field |
|-----------------------------------------------|----------------------------------|--------------|
| 00                                            | Original SSP - 8                 | 0100         |
| 01                                            | Original SSP - 9                 | 0101         |
| 10                                            | Original SSP - 10                | 0110         |
| 11                                            | Original SSP - 11                | 0111         |

• There is a 4-bit fault status field, FS[3:0], at the top of the system stack. This field is defined for access and address errors only and written as zeros for all other exceptions. See Table 11-16.

Table 11-16. Fault Status Encodings

| FS[3:0] | Definition                 |
|---------|----------------------------|
| 00xx    | Reserved                   |
| 0100    | Error on instruction fetch |
| 0101    | Reserved                   |
| 011x    | Reserved                   |
| 1000    | Error on operand write     |
| 1001    | Reserved                   |
| 101x    | Reserved                   |
| 1100    | Error on operand read      |
| 1101    | Reserved                   |
| 111x    | Reserved                   |

• The 8-bit vector number, vector[7:0], defines the exception type and is calculated by the processor for all internal faults and represents the value supplied by the interrupt controller in case of an interrupt. See Table 11-14.

## 11.3.2.2 S08 and ColdFire Exception Processing Comparison

This section presents a brief summary comparing the exception processing differences between the S08 and V1 ColdFire processor families.

#### **Functional Description**

Table 11-17. Exception Processing Comparison

| Attribute                     | S08                                                       | V1 ColdFire                                                                                                       |
|-------------------------------|-----------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------|
| Exception Vector Table        | 32, 2-byte entries, fixed location at upper end of memory | 103, 4-byte entries, located at lower end of memory at reset, relocatable with the VBR                            |
| More on Vectors               | 2 for CPU + 30 for IRQs, reset at upper address           | 64 for CPU + 39 for IRQs, reset at lowest address                                                                 |
| Exception Stack Frame         | 5-byte frame: CCR, A, X, PC                               | 8-byte frame: F/V, SR, PC; General-<br>purpose registers (An, Dn) must be saved/<br>restored by the ISR           |
| Interrupt Levels              | 1 = f(CCR[I])                                             | 7 = f(SR[I]) with automatic hardware support for nesting                                                          |
| Non-Maskable IRQ Support      | No                                                        | Yes, with level 7 interrupts                                                                                      |
| Core-enforced IRQ Sensitivity | No                                                        | Level 7 is edge sensitive, else level sensitive                                                                   |
| INTC Vectoring                | Fixed priorities and vector assignments                   | Fixed priorities and vector assignments, plus any 2 IRQs can be remapped as the highest priority level 6 requests |
| Software IACK                 | No                                                        | Yes                                                                                                               |
| Exit Instruction from ISR     | RTI                                                       | RTE                                                                                                               |

The notion of a software IACK refers to the ability to query the interrupt controller near the end of an interrupt service routine (after the current interrupt request has been cleared) to determine if there are any pending (but currently masked) interrupt requests. If the response to the software IACK's byte operand read is non-zero, the service routine uses the value as the vector number of the highest pending interrupt request and passes control to the appropriate new handler. This process avoids the overhead of a context restore and RTE instruction execution followed immediately by another interrupt exception and context save. In system environments with high rates of interrupt activity, this mechanism can improve overall performance noticeably.

Emulation of the S08's 1-level IRQ processing can easily be managed by software convention within the ColdFire interrupt service routines. For this type of operation, only two of the seven interrupt levels are used:

- SR[I] equals 0 indicates interrupts are enabled
- SR[I] equals 7 indicates interrupts are disabled

Recall that ColdFire treats true level 7 interrupts as edge-sensitive, non-maskable requests. Typically, only the IRQ input pin and a low-voltage detect are assigned as level 7 requests. All the remaining interrupt requests (levels 1-6) are masked when SR[I] equals 7. In any case, all ColdFire processors guarantee that the first instruction of any exception handler is executed before interrupt sampling resumes. By making the first

instruction of the ISR a store/load status register (STLDSR #0x2700) or a move-to-SR (MOVE.W #2700,SR) instruction, interrupts can be safely disabled until the service routine is exited with an RTE instruction that lowers the SR[I] back to level 0. The same functionality can also be provided without an explicit instruction by setting CPUCR[IME] because this forces the processor to load SR[I] with 7 on each interrupt exception.

## 11.3.3 Processor Exceptions

## 11.3.3.1 Access Error Exception

The default operation of the V1 ColdFire processor is the generation of an illegal address reset event if an access error (also known as a bus error) is detected. If CPUCR[ARD] is set, the reset is disabled and a processor exception is generated as detailed below.

The exact processor response to an access error depends on the memory reference being performed. For an instruction fetch, the processor postpones the error reporting until the faulted reference is needed by an instruction for execution. Therefore, faults during instruction prefetches followed by a change of instruction flow do not generate an exception. When the processor attempts to execute an instruction with a faulted opword and/or extension words, the access error is signaled and the instruction is aborted. For this type of exception, the programming model has not been altered by the instruction generating the access error.

If the access error occurs on an operand read, the processor immediately aborts the current instruction's execution and initiates exception processing. In this situation, any address register updates attributable to the auto-addressing modes, (for example, (An)+,-(An)), have already been performed, so the programming model contains the updated An value. In addition, if an access error occurs during a MOVEM instruction loading from memory, any registers already updated before the fault occurs contain the operands from memory.

The V1 ColdFire processor uses an imprecise reporting mechanism for access errors on operand writes. Because the actual write cycle may be decoupled from the processor's issuing of the operation, the signaling of an access error appears to be decoupled from the instruction that generated the write. Accordingly, the PC contained in the exception stack frame merely represents the location in the program when the access error was signaled. All programming model updates associated with the write instruction are completed. The NOP instruction can collect access errors for writes. This instruction delays its execution

#### **Processor Exceptions**

until all previous operations, including all pending write operations, are complete. If any previous write terminates with an access error, it is guaranteed to be reported on the NOP instruction.

## 11.3.3.2 Address Error Exception

The default operation of the V1 ColdFire processor is the generation of an illegal address reset event if an address error is detected. If CPUCR[ARD] equals 1, then the reset is disabled and a processor exception is generated as detailed below.

Any attempted execution transferring control to an odd instruction address (if bit 0 of the target address is set) results in an address error exception.

Any attempted use of a word-sized index register (Xn.w) or a scale factor of eight on an indexed effective addressing mode generates an address error, as does an attempted execution of a full-format indexed addressing mode, which is defined by bit 8 of extension word 1 being set.

If an address error occurs on an RTS instruction, the Version 1 ColdFire processor overwrites the faulting return PC with the address error stack frame.

## 11.3.3.3 Illegal Instruction Exception

The default operation of the V1 ColdFire processor is the generation of an illegal opcode reset event if an illegal instruction is detected. If CPUCR[IRD] is set, the reset is disabled and a processor exception is generated as detailed below. There is one special case involving the ILLEGAL opcode (0x4AFC); attempted execution of this instruction always generates an illegal instruction exception, regardless of the state of the CPUCR[IRD] bit.

The ColdFire variable-length instruction set architecture supports three instruction sizes: 16, 32, or 48 bits. The first instruction word is known as the operation word (or opword), while the optional words are known as extension word 1 and extension word 2. The opword is further subdivided into three sections: the upper four bits segment the entire ISA into 16 instruction lines, the next 6 bits define the operation mode (opmode), and the low-order 6 bits define the effective address. The opword line definition is shown below.



Figure 11-3. ColdFire Instruction Operation Word (Opword) Format

**Table 11-18. ColdFire Opword Line Definition** 

| Opword[Line] | Instruction Class                                                            |
|--------------|------------------------------------------------------------------------------|
| 0x0          | Bit manipulation, Arithmetic and Logical Immediate                           |
| 0x1          | Move Byte                                                                    |
| 0x2          | Move Long                                                                    |
| 0x3          | Move Word                                                                    |
| 0x4          | Miscellaneous                                                                |
| 0x5          | Add (ADDQ) and Subtract Quick (SUBQ), Set according to Condition Codes (Scc) |
| 0x6          | PC-relative change-of-flow instructions                                      |
|              | Conditional (Bcc) and unconditional (BRA) branches, subroutine calls (BSR)   |
| 0x7          | Move Quick (MOVEQ), Move with sign extension (MVS) and zero fill (MVZ)       |
| 0x8          | Logical OR (OR)                                                              |
| 0x9          | Subtract (SUB), Subtract Extended (SUBX)                                     |
| 0xA          | EMAC, Move 3-bit Quick (MOV3Q)                                               |
| 0xB          | Compare (CMP), Exclusive-OR (EOR)                                            |
| 0xC          | Logical AND (AND), Multiply Word (MUL)                                       |
| 0xD          | Add (ADD), Add Extended (ADDX)                                               |
| 0xE          | Arithmetic and logical shifts (ASL, ASR, LSL, LSR)                           |
| 0xF          | Write DDATA (WDDATA), Write Debug (WDEBUG)                                   |

In the original M68000 ISA definition, lines A and F were effectively reserved for user-defined operations (line A) and co-processor instructions (line F). Accordingly, there are two unique exception vectors associated with illegal opwords in these two lines.

Any attempted execution of an illegal 16-bit opcode (except for line-A and line-F opcodes) generates an illegal instruction exception (vector 4). Additionally, any attempted execution of any non-MAC line-A and most line-F opcodes generate their unique exception types, vector numbers 10 and 11, respectively. ColdFire cores do not provide illegal instruction detection on the extension words on any instruction, including MOVEC.

The V1 ColdFire processor also detects two special cases involving illegal instruction conditions:

- 1. If execution of the stop instruction is attempted and neither low-power stop nor wait modes are enabled, the processor signals an illegal instruction.
- 2. If execution of the halt instruction is attempted and BDM is not enabled (XCSR[ENBDM] equals 0), the processor signals an illegal instruction.

#### **Processor Exceptions**

In both cases, the processor response is then dependent on the state of CPUCR[IRD]— a reset event or a processor exception.

# 11.3.3.4 Divide-By-Zero

Attempting to divide by zero causes an exception (vector 5, offset equal 0x014).

# 11.3.3.5 Privilege Violation

The default operation of the V1 ColdFire processor is the generation of an illegal opcode reset event if a privilege violation is detected. If CPUCR[IRD] is set, the reset is disabled and a processor exception is generated as detailed below.

The attempted execution of a supervisor mode instruction while in user mode generates a privilege violation exception. See *ColdFire Programmer's Reference Manual* for a list of supervisor-mode instructions.

There is one special case involving the HALT instruction. Normally, this opcode is a supervisor mode instruction, but if the debug module's CSR[UHE] is set, then this instruction can be also be executed in user mode for debugging purposes.

# 11.3.3.6 Trace Exception

To aid in program development, all ColdFire processors provide an instruction-by-instruction tracing capability. While in trace mode, indicated by setting of the SR[T] bit, the completion of an instruction execution (for all but the stop instruction) signals a trace exception. This functionality allows a debugger to monitor program execution.

The stop instruction has the following effects:

- 1. The instruction before the stop executes and then generates a trace exception. In the exception stack frame, the PC points to the stop opcode.
- 2. When the trace handler is exited, the stop instruction executes, loading the SR with the immediate operand from the instruction.
- 3. The processor then generates a trace exception. The PC in the exception stack frame points to the instruction after the stop, and the SR reflects the value loaded in the previous step.

If the processor is not in trace mode and executes a stop instruction where the immediate operand sets SR[T], hardware loads the SR and generates a trace exception. The PC in the exception stack frame points to the instruction after the stop, and the SR reflects the value loaded in step 2.

Because ColdFire processors do not support any hardware stacking of multiple exceptions, it is the responsibility of the operating system to check for trace mode after processing other exception types. As an example, consider a TRAP instruction execution while in trace mode. The processor initiates the trap exception and then passes control to the corresponding handler. If the system requires that a trace exception be processed, it is the responsibility of the trap exception handler to check for this condition (SR[T] in the exception stack frame set) and pass control to the trace handler before returning from the original exception.

# 11.3.3.7 Unimplemented Line-A Opcode

The default operation of the V1 ColdFire processor is the generation of an illegal opcode reset event if an unimplemented line-A opcode is detected. If CPUCR[IRD] is set, the reset is disabled and a processor exception is generated as detailed below.

A line-A opcode is defined when bits 15-12 of the opword are 0b1010. This exception is generated by the attempted execution of an undefined line-A opcode.

# 11.3.3.8 Unimplemented Line-F Opcode

The default operation of the V1 ColdFire processor is the generation of an illegal opcode reset event if an unimplemented line-F opcode is detected. If CPUCR[IRD] is set, the reset is disabled and a processor exception is generated as detailed below.

A line-F opcode is defined when bits 15-12 of the opword are 0b1111. This exception is generated when attempting to execute an undefined line-F opcode.

# 11.3.3.9 Debug Interrupt

See the debug chapter for a detailed explanation of this exception, which is generated in response to a hardware breakpoint register trigger. The processor does not generate an IACK cycle, but rather calculates the vector number internally (vector number 12). Additionally, SR[M,I] are unaffected by the interrupt.

# 11.3.3.10 RTE and Format Error Exception

The default operation of the V1 ColdFire processor is the generation of an illegal address reset event if an RTE format error is detected. If CPUCR[ARD] is set, the reset is disabled and a processor exception is generated as detailed below.

When an RTE instruction is executed, the processor first examines the 4-bit format field to validate the frame type. For a ColdFire core, any attempted RTE execution (where the format is not equal to {4,5,6,7}) generates a format error. The exception stack frame for the format error is created without disturbing the original RTE frame and the stacked PC pointing to the RTE instruction.

The selection of the format value provides some limited debug support for porting code from M68000 applications. On M68000 family processors, the SR was located at the top of the stack. On those processors, bit 30 of the longword addressed by the system stack pointer is typically zero. Thus, if an RTE is attempted using this old format, it generates a format error on a ColdFire processor.

If the format field defines a valid type, the processor: (1) reloads the SR operand, (2) fetches the second longword operand, (3) adjusts the stack pointer by adding the format value to the auto-incremented address after the fetch of the first longword, and then (4) transfers control to the instruction address defined by the second longword operand within the stack frame.

# 11.3.3.11 TRAP Instruction Exception

The TRAP #n instruction always forces an exception as part of its execution and is useful for implementing system calls. The TRAP instruction may be used to change from user to supervisor mode.

This set of 16 instructions provides a similar but expanded functionality compared to the S08's SWI (software interrupt) instruction. Do not confuse these instructions and their functionality with the software-scheduled interrupt requests, which are handled like normal I/O interrupt requests by the interrupt controller. The processing of the software-scheduled IRQs can be masked, based on the interrupt priority level defined by the SR[I] field.

# 11.3.3.12 Unsupported Instruction Exception

If execution of a valid instruction is attempted but the required hardware is not present in the processor (e.g., if the MAC is not present), an unsupported instruction exception is generated. The instruction functionality can then be emulated in the exception handler, if desired.

All ColdFire cores record the processor hardware configuration in the D0 register immediately after the negation of  $\overline{RESET}$ . See Reset Exception," for details.

# 11.3.3.13 Interrupt Exception

Interrupt exception processing includes interrupt recognition and the fetch of the appropriate vector from the interrupt controller using an IACK cycle or using the previously-supplied vector number, under control of CPUCR[IAE]. See the interrupt chapter for details on the interrupt controller.

#### 11.3.3.14 Fault-on-Fault Halt

The default operation of the V1 ColdFire processor is the generation of an illegal address reset event if a fault-on-fault halt condition is detected. If CPUCR[ARD] is set, the reset is disabled and the processor is halted as detailed below.

If a ColdFire processor encounters any type of fault during the exception processing of another fault, the processor immediately halts execution with the catastrophic fault-on-fault condition. A reset is required to to exit this state.

# 11.3.3.15 Reset Exception

Resetting the processor causes a reset exception. The reset exception has the highest priority of any exception; it provides for system initialization and recovery from catastrophic failure. Reset also aborts any processing in progress when the reset input is recognized. Processing cannot be recovered.

The reset exception places the processor in the supervisor mode by setting the SR[S] bit and disables tracing by clearing the SR[T] bit. This exception also clears the SR[M] bit and sets the processor's SR[I] field to the highest level (level 7, 0b111). Next, the VBR is initialized to zero (0x0000\_0000). The control registers specifying the operation of any memories (such as cache and/or RAM modules) connected directly to the processor are disabled.

#### **Note**

Other implementation-specific registers are also affected. Refer to each module in this reference manual for details on these registers.

After the processor is granted the bus, it performs two longword read-bus cycles. The first longword at address  $0x(00)00\_0000$  is loaded into the supervisor stack pointer and the second longword at address  $0x(00)00\_0004$  is loaded into the program counter. After the initial instruction is fetched from memory, program execution begins at the address in the PC. If an access error or address error occurs before the first instruction is executed, the processor enters the fault-on-fault state.

ColdFire processors load hardware configuration information into the D0 and D1 general-purpose registers after system reset. The hardware configuration information is loaded immediately after the reset-in signal is negated. This allows an emulator to read out the contents of these registers via the BDM to determine the hardware configuration.

Information loaded into D0 defines the processor hardware configuration as shown in Table 11-19.



Table 11-19. D0 Hardware Configuration Information

Table 11-20. D0 Hardware Configuration Information Field Descriptions

| Field | Description                                                                                         |
|-------|-----------------------------------------------------------------------------------------------------|
| 31–24 | Processor family. This field is fixed to a hex value of 0xCF indicating a ColdFire core is present. |
| PF    |                                                                                                     |
| 23–20 | ColdFire core version number. Defines the hardware microarchitecture version of ColdFire core.      |
| VER   | 0001 V1 ColdFire core                                                                               |

Table continues on the next page...

Table 11-20. D0 Hardware Configuration Information Field Descriptions (continued)

| Field        | Description                                                                                                                                       |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| 19–16        | Processor revision number                                                                                                                         |
| REV          |                                                                                                                                                   |
| 15           | Reserved                                                                                                                                          |
| 14           | Divide present. This bit signals if the hardware divider (DIV) is present in the processor core.                                                  |
| DIV          | 0 Divide execute engine not present in core                                                                                                       |
|              | 1 Divide execute engine is present in core                                                                                                        |
| 13<br>EMAC   | EMAC present. This bit signals if the optional enhanced multiply-accumulate (EMAC) execution engine is present in processor core.                 |
|              | 0 EMAC execute engine not present in core                                                                                                         |
|              | 1 EMAC execute engine is present in core                                                                                                          |
| 12           | Reserved                                                                                                                                          |
| 11           | Reserved                                                                                                                                          |
| 10<br>CAU    | Cryptographic acceleration unit present. This bit signals if the optional cryptographic acceleration unit (CAU) is present in the processor core. |
|              | 0 CAU coprocessor engine not present in core                                                                                                      |
|              | 1 CAU coprocessor engine is present in core                                                                                                       |
| 9–8          | Reserved                                                                                                                                          |
| 7–4          | ISA revision. Defines the instruction-set architecture (ISA) revision level implemented in ColdFire                                               |
| ISA          | processor core.                                                                                                                                   |
|              | 0010 ISA_C                                                                                                                                        |
| 3–0<br>DEBUG | Debug module revision number. Defines revision level of the debug module used in the ColdFire processor core.                                     |
|              | 1001 DEBUG_B+                                                                                                                                     |

Information loaded into D1 defines the local memory hardware configuration as shown in the figure below.

**Table 11-21. D1 Hardware Configuration Information** 



Table continues on the next page...

#### **Processor Exceptions**

#### Table 11-21. D1 Hardware Configuration Information (continued)

Reset Device-specific

**Table 11-22. D1 Hardware Configuration Information Field Descriptions** 

| Field     | Description                                                                                  |
|-----------|----------------------------------------------------------------------------------------------|
| 31–28     | Program flash memory size                                                                    |
| FLASHSZ   | 0111: 32 KB                                                                                  |
|           | 1000: 64 KB                                                                                  |
|           | 1001: 128 KB                                                                                 |
|           | Other: Reserved                                                                              |
| 27–26     | Program flash memory hole                                                                    |
| FLASHH    | Reserved                                                                                     |
| 25–22     | FlexNVM size                                                                                 |
| FLEXNVMSZ | 0110: 16 KB                                                                                  |
|           | 0111: 32 KB                                                                                  |
|           | Other: Reserved                                                                              |
| 21–20     | FlexNVM hole                                                                                 |
| FLEXNVMH  | Reserved                                                                                     |
| 19–16     | Total available FlexRAM size as defined by the EEESIZE field of data flash IFR. Refer to the |
| EEESIZE   | detailed description of the flash memory module.                                             |
| 15–12     | FlexNVM partitioning between data flash and EEPROM as defined by the DEPART field of data    |
| DEPART    | flash IFR. Refer to the detailed description of the flash memory module.                     |
| 11–6      | Reserved                                                                                     |
| 5–2       | RAM size                                                                                     |
| RAMSZ     | 0101: 8 KB                                                                                   |
|           | 0110: 16 KB                                                                                  |
|           | 0111: 32 KB                                                                                  |
|           | Other: Reserved                                                                              |
| 1–0       | RAM hole                                                                                     |
| RAMH      | Reserved                                                                                     |

# 11.3.4 Instruction Execution Timing

This section presents processor instruction execution times in terms of processor-core clock cycles. The number of operand references for each instruction is enclosed in parentheses following the number of processor clock cycles. Each timing entry is presented as C(R/W) where:

- C is the number of processor clock cycles, including all applicable operand fetches and writes, and all internal core cycles required to complete the instruction execution.
- R/W is the number of operand reads (R) and writes (W) required by the instruction. An operation performing a read-modify-write function is denoted as (1/1).

This section includes the assumptions concerning the timing values and the execution time details.

# 11.3.4.1 Timing Assumptions

For the timing data presented in this section, these assumptions apply:

- 1. The OEP is loaded with the opword and all required extension words at the beginning of each instruction execution. This implies that the OEP does not wait for the IFP to supply opwords and/or extension words.
- 2. The OEP does not experience any sequence-related pipeline stalls. The most common example of stall involves consecutive store operations, excluding the MOVEM instruction. For all STORE operations (except MOVEM), certain hardware resources within the processor are marked as busy for two clock cycles after the final decode and select/operand fetch cycle (DSOC) of the store instruction. If a subsequent STORE instruction is encountered within this 2-cycle window, it is stalled until the resource again becomes available. Thus, the maximum pipeline stall involving consecutive STORE operations is two cycles. The MOVEM instruction uses a different set of resources and this stall does not apply.
- 3. The OEP completes all memory accesses without any stall conditions caused by the memory itself. Thus, the timing details provided in this section assume that an infinite zero-wait state memory is attached to the processor core.
- 4. All operand data accesses are aligned on the same byte boundary as the operand size; for example, 16-bit operands aligned on 0-modulo-2 addresses, 32-bit operands aligned on 0-modulo-4 addresses.

The processor core decomposes misaligned operand references into a series of aligned accesses as shown in Table 11-23.

Table 11-23. Misaligned Operand References

| address[1:0] | Size | Bus Operations | Additional C(R/W) |
|--------------|------|----------------|-------------------|
| 01 or 11     | Word | Byte, Byte     | 2(1/0) if read    |
|              |      |                | 1(0/1) if write   |

Table continues on the next page...

#### **Processor Exceptions**

Table 11-23. Misaligned Operand References (continued)

| address[1:0] | Size | Bus Operations   | Additional C(R/W) |
|--------------|------|------------------|-------------------|
| 01 or 11     | Long | Byte, Word, Byte | 3(2/0) if read    |
|              |      |                  | 2(0/2) if write   |
| 10           | Long | Word, Word       | 2(1/0) if read    |
|              |      |                  | 1(0/1) if write   |

### 11.3.4.2 MOVE Instruction Execution Times

Table 11-25 lists execution times for MOVE.{B,W} instructions. Table 11-26 lists execution times for MOVE.L.

For all tables in this section, the execution time of any instruction using the PC-relative effective addressing modes is the same for the comparable An-relative mode. Refer to the following table for elaboration.

Table 11-24. Effective addressing modes with equal execution time

| PC-relative effective addressing mode | An-relative effective addressing mode |
|---------------------------------------|---------------------------------------|
| ET with { <ea> = (d16,PC)}</ea>       | ET with { <ea> = (d16,An)}</ea>       |
| ET with $\{ = (d8,PC,Xi*SF)\}$        | ET with { <ea> = (d8,An,Xi*SF)}</ea>  |

The nomenclature xxx.wl refers to both forms of absolute addressing, xxx.w and xxx.l.

Table 11-25. MOVE Byte and Word Execution Times

| Sauras        |         | Destination |         |          |          |               |         |  |  |  |  |  |
|---------------|---------|-------------|---------|----------|----------|---------------|---------|--|--|--|--|--|
| Source        | RX      | (Ax)        | (Ax)+   | -(Ax)    | (d16,Ax) | (d8,Ax,Xi*SF) | xxx.wl  |  |  |  |  |  |
| Dy            | 1(0/0)  | 1(0/1)      | 1(0/1)  | 1(0/1)   | 1(0/1)   | 2(0/1)        | 1(0/1)  |  |  |  |  |  |
| Ау            | 1(0/0)  | 1(0/1)      | 1(0/1)  | 1(0/1)   | 1(0/1)   | 2(0/1)        | 1(0/1)  |  |  |  |  |  |
| (Ay)          | 2 (1/0) | 3 (1/1)     | 3 (1/1) | 3 (1/1)  | 3 (1/1)  | 4 (1/1))      | 3 (1/1) |  |  |  |  |  |
| (Ay)+         | 2 (1/0) | 3 (1/1)     | 3 (1/1) | 3 (1/1)  | 3 (1/1)  | 4 (1/1))      | 3 (1/1) |  |  |  |  |  |
| -(Ay)         | 2 (1/0) | 3 (1/1)     | 3 (1/1) | 3 (1/1)  | 3 (1/1)  | 4 (1/1))      | 3 (1/1) |  |  |  |  |  |
| (d16,Ay)      | 2 (1/0) | 3 (1/1)     | 3 (1/1) | 3 (1/1)  | 3 (1/1)  | _             | _       |  |  |  |  |  |
| (d8,Ay,Xi*SF) | 3 (1/0) | 4 (1/1)     | 4 (1/1) | 4 (1/1)  | _        | _             | _       |  |  |  |  |  |
| xxx.w         | 2 (1/0) | 3 (1/1)     | 3 (1/1) | 3 (1/1)  | _        | _             | _       |  |  |  |  |  |
| xxx.l         | 2 (1/0) | 3 (1/1)     | 3 (1/1) | 3 (1/1)  | _        | _             | _       |  |  |  |  |  |
| (d16,PC)      | 2 (1/0) | 3 (1/1)     | 3 (1/1) | 3 (1/1)  | 3 (1/1)  | _             | _       |  |  |  |  |  |
| (d8,PC,Xi*SF) | 3 (1/0) | 4 (1/1)     | 4 (1/1) | 4 (1/1)) | _        | _             | _       |  |  |  |  |  |
| #xxx          | 1(0/0)  | 3 (0/1)     | 3 (0/1) | 3 (0/1)  | 1(0/1)   | _             | _       |  |  |  |  |  |

262

Table 11-26. MOVE Long Execution Times

| Source        | Destination |         |                                    |         |         |         |         |  |  |  |  |
|---------------|-------------|---------|------------------------------------|---------|---------|---------|---------|--|--|--|--|
| Source        | Rx          | (Ax)    | (Ax)+ -(Ax) (d16,Ax) (d8,Ax,Xi*SF) |         | xxx.wl  |         |         |  |  |  |  |
| Dy            | 1(0/0)      | 1(0/1)  | 1(0/1)                             | 1(0/1)  | 1(0/1)  | 2(0/1)  | 1(0/1)  |  |  |  |  |
| Ау            | 1(0/0)      | 1(0/1)  | 1(0/1)                             | 1(0/1)  | 1(0/1)  | 2(0/1)  | 1(0/1)  |  |  |  |  |
| (Ay)          | 2 (1/0)     | 2 (1/1) | 2 (1/1)                            | 2 (1/1) | 2 (1/1) | 3 (1/1) | 2 (1/1) |  |  |  |  |
| (Ay)+         | 2 (1/0)     | 2 (1/1) | 2 (1/1)                            | 2 (1/1) | 2 (1/1) | 3 (1/1) | 2 (1/1) |  |  |  |  |
| -(Ay)         | 2 (1/0)     | 2 (1/1) | 2 (1/1)                            | 2 (1/1) | 2 (1/1) | 3 (1/1) | 2 (1/1) |  |  |  |  |
| (d16,Ay)      | 2 (1/0)     | 2 (1/1) | 2 (1/1)                            | 2 (1/1) | 2 (1/1) | _       | _       |  |  |  |  |
| (d8,Ay,Xi*SF) | 3 (1/0)     | 3 (1/1) | 3 (1/1)                            | 3 (1/1) | _       | _       | _       |  |  |  |  |
| xxx.w         | 2 (1/0)     | 2 (1/1) | 2 (1/1)                            | 2 (1/1) | _       | _       | _       |  |  |  |  |
| xxx.l         | 2 (1/0)     | 2 (1/1) | 2 (1/1)                            | 2 (1/1) | _       | _       | _       |  |  |  |  |
| (d16,PC)      | 2 (1/0)     | 2 (1/1) | 2 (1/1)                            | 2 (1/1) | 2 (1/1) | _       | _       |  |  |  |  |
| (d8,PC,Xi*SF) | 3 (1/0)     | 3 (1/1) | 3 (1/1)                            | 3 (1/1) | _       | _       | _       |  |  |  |  |
| #xxx          | 1(0/0)      | 2 (0/1) | 2 (0/1)                            | 2 (0/1) | _       | _       | _       |  |  |  |  |

# 11.3.4.3 Standard One Operand Instruction Execution Times Table 11-27. One Operand Instruction Execution Times

| Opendo  | <ea></ea> |        |        |        | Effe   | Effective Address |               |        |      |
|---------|-----------|--------|--------|--------|--------|-------------------|---------------|--------|------|
| Opcode  | <ea></ea> | Rn     | (An)   | (An)+  | -(An)  | (d16,An)          | (d8,An,Xn*SF) | xxx.wl | #xxx |
| BITREV  | Dx        | 1(0/0) | _      | _      | _      | _                 |               |        | _    |
| BYTEREV | Dx        | 1(0/0) | _      | _      | _      | _                 | _             | _      | _    |
| CLR.B   | <ea></ea> | 1(0/0) | 1(0/1) | 1(0/1) | 1(0/1) | 1(0/1)            | 2(0/1)        | 1(0/1) | _    |
| CLR.W   | <ea></ea> | 1(0/0) | 1(0/1) | 1(0/1) | 1(0/1) | 1(0/1)            | 2(0/1)        | 1(0/1) | _    |
| CLR.L   | <ea></ea> | 1(0/0) | 1(0/1) | 1(0/1) | 1(0/1) | 1(0/1)            | 2(0/1)        | 1(0/1) | _    |
| EXT.W   | Dx        | 1(0/0) | _      | _      | _      | _                 | _             | _      | _    |
| EXT.L   | Dx        | 1(0/0) | _      | _      | _      | _                 | _             | _      | _    |
| EXTB.L  | Dx        | 1(0/0) | _      | _      | _      | _                 | _             | _      | _    |
| FF1     | Dx        | 1(0/0) | _      | _      | _      | _                 | _             | _      | _    |
| NEG.L   | Dx        | 1(0/0) | _      | _      | _      | _                 | _             | _      | _    |
| NEGX.L  | Dx        | 1(0/0) | _      | _      | _      | _                 | _             | _      | _    |
| NOT.L   | Dx        | 1(0/0) | _      | _      | _      | _                 | _             | _      | _    |
| SATS.L  | Dx        | 1(0/0) | _      | _      | _      | _                 | _             | _      | _    |
| SCC     | Dx        | 1(0/0) | _      | _      | _      | _                 | _             | _      | _    |
| SWAP    | Dx        | 1(0/0) | _      | _      | _      | _                 | _             | _      | _    |

Table continues on the next page...

#### **Processor Exceptions**

**Table 11-27. One Operand Instruction Execution Times (continued)** 

| Opcode           | <ea></ea> | Effective Address |         |         |         |          |               |         |        |  |  |
|------------------|-----------|-------------------|---------|---------|---------|----------|---------------|---------|--------|--|--|
| Opcode <ea></ea> | (EA)      | Rn                | (An)    | (An)+   | -(An)   | (d16,An) | (d8,An,Xn*SF) | xxx.wl  | #xxx   |  |  |
| TAS.B            | <ea></ea> | _                 | 3 (1/1) | 3 (1/1) | 3 (1/1) | 3 (1/1)  | 4 (1/1)       | 3 (1/1) | _      |  |  |
| TST.B            | <ea></ea> | 1(0/0)            | 2 (1/0) | 2 (1/0) | 2 (1/0) | 2 (1/0)  | 3 (1/0)       | 2 (1/0) | 1(0/0) |  |  |
| TST.W            | <ea></ea> | 1(0/0)            | 2 (1/0) | 2 (1/0) | 2 (1/0) | 2 (1/0)  | 3 (1/0)       | 2 (1/0) | 1(0/0) |  |  |
| TST.L            | <ea></ea> | 1(0/0)            | 2 (1/0) | 2 (1/0) | 2 (1/0) | 2 (1/0)  | 3 (1/0)       | 2 (1/0) | 1(0/0) |  |  |

# 11.3.4.4 Standard Two Operand Instruction Execution Times

Table 11-28. Two Operand Instruction Execution Times

|        |                           | Effective Address |         |         |         |          |               |         |        |
|--------|---------------------------|-------------------|---------|---------|---------|----------|---------------|---------|--------|
| Opcode | <ea></ea>                 | Rn                | (An)    | (An)+   | -(An)   | (d16,An) | (d8,An,Xn*SF) | xxx.wl  | #xxx   |
|        |                           | nii               | (AII)   | (AII)+  | -(AII)  | (d16,PC) | (d8,PC,Xn*SF) | XXX.WI  | #***   |
| ADD.L  | <ea>,Rx</ea>              | 1(0/0)            | 3 (1/0) | 3 (1/0) | 3 (1/0) | 3 (1/0)  | 4 (1/0)       | 3 (1/0) | 1(0/0) |
| ADD.L  | Dy, <ea></ea>             | _                 | 3 (1/1) | 3 (1/1) | 3 (1/1) | 3 (1/1)  | 4 (1/1)       | 3 (1/1) | _      |
| ADDI.L | #imm,Dx                   | 1(0/0)            | _       | _       | _       | _        | _             | _       | _      |
| ADDQ.L | #imm, <ea<br>&gt;</ea<br> | 1(0/0)            | 3 (1/1) | 3 (1/1) | 3 (1/1) | 3 (1/1)  | 4 (1/1)       | 3 (1/1) | _      |
| ADDX.L | Dy,Dx                     | 1(0/0)            | _       | _       | _       | _        | _             | _       | _      |
| AND.L  | <ea>,Rx</ea>              | 1(0/0)            | 3 (1/0) | 3 (1/0) | 3 (1/0) | 3 (1/0)  | 4 (1/0)       | 3 (1/0) | 1(0/0) |
| AND.L  | Dy, <ea></ea>             | _                 | 3 (1/1) | 3 (1/1) | 3 (1/1) | 3 (1/1)  | 4 (1/1)       | 3 (1/1) | _      |
| ANDI.L | #imm,Dx                   | 1(0/0)            | _       | _       | _       | _        | _             | _       | _      |
| ASL.L  | <ea>,Dx</ea>              | 1(0/0)            | _       | _       | _       | _        | _             | _       | 1(0/0) |
| ASR.L  | <ea>,Dx</ea>              | 1(0/0)            | _       | _       | _       | _        | _             | _       | 1(0/0) |
| BCHG   | Dy, <ea></ea>             | 2(0/0)            | 4 (1/1) | 4 (1/1) | 4 (1/1) | 4 (1/1)  | 5 (1/1)       | 4 (1/1) | _      |
| BCHG   | #imm, <ea<br>&gt;</ea<br> | 2(0/0)            | 4 (1/1) | 4 (1/1) | 4 (1/1) | 4 (1/1)  | _             | _       | _      |
| BCLR   | Dy, <ea></ea>             | 2(0/0)            | 4 (1/1) | 4 (1/1) | 4 (1/1) | 4 (1/1)  | 5 (1/1)       | 4 (1/1) | _      |
| BCLR   | #imm, <ea<br>&gt;</ea<br> | 2(0/0)            | 4 (1/1) | 4 (1/1) | 4 (1/1) | 4 (1/1)  | _             | _       | _      |
| BSET   | Dy, <ea></ea>             | 2(0/0)            | 4 (1/1) | 4 (1/1) | 4 (1/1) | 4 (1/1)  | 5 (1/1)       | 4 (1/1) | _      |
| BSET   | #imm, <ea<br>&gt;</ea<br> | 2(0/0)            | 4 (1/1) | 4 (1/1) | 4 (1/1) | 4 (1/1)  | _             | _       | _      |
| BTST   | Dy, <ea></ea>             | 2(0/0)            | 3 (1/0) | 3 (1/0) | 3 (1/0) | 3 (1/0)  | 4 (1/0)       | 3 (1/0) | _      |
| BTST   | #imm, <ea<br>&gt;</ea<br> | 1(0/0)            | 3 (1/0) | 3 (1/0) | 3 (1/0) | 3 (1/0)  | _             | _       | _      |
| CMP.B  | <ea>,Rx</ea>              | 1(0/0)            | 3 (1/0) | 3 (1/0) | 3 (1/0) | 3 (1/0)  | 4 (1/0)       | 3 (1/0) | 1(0/0) |

Table continues on the next page...

Table 11-28. Two Operand Instruction Execution Times (continued)

|        |                           |          | Effective Address |           |           |           |               |          |         |
|--------|---------------------------|----------|-------------------|-----------|-----------|-----------|---------------|----------|---------|
| Opcode | < <b>EA</b> >             | Rn       | (Ap)              | (An):     | (An)      | (d16,An)  | (d8,An,Xn*SF) | yyy wl   | #xxx    |
|        |                           | KII      | (An)              | (An)+     | -(An)     | (d16,PC)  | (d8,PC,Xn*SF) | xxx.wl   | #XXX    |
| CMP.W  | <ea>,Rx</ea>              | 1(0/0)   | 3 (1/0)           | 3 (1/0)   | 3 (1/0)   | 3 (1/0)   | 4 (1/0)       | 3 (1/0)  | 1(0/0)  |
| CMP.L  | <ea>,Rx</ea>              | 1(0/0)   | 3 (1/0)           | 3 (1/0)   | 3 (1/0)   | 3 (1/0)   | 4 (1/0)       | 3 (1/0)  | 1(0/0)  |
| CMPI.B | #imm,Dx                   | 1(0/0)   | _                 | _         | _         | _         | _             | _        | _       |
| CMPI.W | #imm,Dx                   | 1(0/0)   | _                 | _         | _         | _         | _             | _        | _       |
| CMPI.L | #imm,Dx                   | 1(0/0)   | _                 | _         | _         | _         | _             | _        | _       |
| DIVS.W | <ea>,Dx</ea>              | 20(0/0)  | 23 (1/0)          | 23 (1/0)  | 23 (1/0)  | 23 (1/0)  | 24 (1/0)      | 23 (1/0) | 20(0/0) |
| DIVU.W | <ea>,Dx</ea>              | 20(0/0)  | 23 (1/0)          | 23 (1/0)  | 23 (1/0)  | 23 (1/0)  | 24 (1/0)      | 23 (1/0) | 20(0/0) |
| DIVS.L | <ea>,Dx</ea>              | ≤35(0/0) | ≤38 (1/0)         | ≤38 (1/0) | ≤38 (1/0) | ≤38 (1/0) | _             | _        | _       |
| DIVU.L | <ea>,Dx</ea>              | ≤35(0/0) | ≤38(1/0)          | ≤38 (1/0) | ≤38 (1/0) | ≤38 (1/0) | _             | _        | _       |
| EOR.L  | Dy, <ea></ea>             | 1(0/0)   | 3 (1/1)           | 3 (1/1)   | 3 (1/1)   | 3 (1/1)   | 4 (1/1)       | 3 (1/1)  | _       |
| EORI.L | #imm,Dx                   | 1(0/0)   | _                 | _         | _         | _         | _             | _        | _       |
| LEA    | <ea>,Ax</ea>              | _        | 1(0/0)            | _         | _         | 1(0/0)    | 2(0/0)        | 1(0/0)   | _       |
| LSL.L  | <ea>,Dx</ea>              | 1(0/0)   | _                 | _         | _         | _         | _             | _        | 1(0/0)  |
| LSR.L  | <ea>,Dx</ea>              | 1(0/0)   | _                 | _         | _         | _         | _             | _        | 1(0/0)  |
| MOVEQ. | #imm,Dx                   | _        | _                 | _         | _         | _         | _             | _        | 1(0/0)  |
| OR.L   | <ea>,Rx</ea>              | 1(0/0)   | 3 (1/0)           | 3 (1/0)   | 3 (1/0)   | 3 (1/0)   | 4 (1/0)       | 3 (1/0)  | 1(0/0)  |
| OR.L   | Dy, <ea></ea>             | _        | 3 (1/1)           | 3 (1/1)   | 3 (1/1)   | 3 (1/1)   | 4 (1/1)       | 3 (1/1)  | _       |
| ORI.L  | #imm,Dx                   | 1(0/0)   | _                 | _         | _         | _         | _             | _        | _       |
| REMS.L | <ea>,Dx</ea>              | ≤35(0/0) | ≤38 (1/0)         | ≤38 (1/0) | ≤38 (1/0) | ≤38 (1/0) | _             | _        | _       |
| REMU.L | <ea>,Dx</ea>              | ≤35(0/0) | ≤38 (1/0)         | ≤38 (1/0) | ≤38 (1/0) | ≤38 (1/0) | _             | _        | _       |
| SUB.L  | <ea>,Rx</ea>              | 1(0/0)   | 3 (1/0)           | 3 (1/0)   | 3 (1/0)   | 3 (1/0)   | 4 (1/0)       | 3 (1/0)  | 1(0/0)  |
| SUB.L  | Dy, <ea></ea>             | _        | 3 (1/1)           | 3 (1/1)   | 3 (1/1)   | 3 (1/1)   | 4 (1/1)       | 3 (1/1)  | _       |
| SUBI.L | #imm,Dx                   | 1(0/0)   | _                 | _         | _         | _         | _             | _        | _       |
| SUBQ.L | #imm, <ea<br>&gt;</ea<br> | 1(0/0)   | 3 (1/1)           | 3 (1/1)   | 3 (1/1)   | 3 (1/1)   | 4 (1/1)       | 3 (1/1)  | _       |
| SUBX.L | Dy,Dx                     | 1(0/0)   | _                 | _         | _         | _         | _             | _        | _       |

# 11.3.4.5 Miscellaneous Instruction Execution Times

#### Table 11-29. Miscellaneous Instruction Execution Times

|         |                           | Effective Address |                        |         |         |           |                   |         |           |
|---------|---------------------------|-------------------|------------------------|---------|---------|-----------|-------------------|---------|-----------|
| Opcode  | < <b>EA</b> >             | Rn                | (An)                   | (An)+   | -(An)   | (d16,An)  | (d8,An,Xn*SF<br>) | xxx.wl  | #xxx      |
| LINK.W  | Ay,#imm                   | 2(0/1)            | _                      | _       | _       | _         | _                 | _       | _         |
| MOV3Q.L | #imm, <ea<br>&gt;</ea<br> | 1(0/0)            | 1(0/1)                 | 1(0/1)  | 1(0/1)  | 1(0/1)    | 2(0/1)            | 1(0/1)  | _         |
| MOVE.L  | Ay,USP                    | 3(0/0)            | _                      | _       | _       | _         | _                 | _       | _         |
| MOVE.L  | USP,Ax                    | 3(0/0)            | _                      | _       | _       | _         | _                 | _       | _         |
| MOVE.W  | CCR,Dx                    | 1(0/0)            | _                      | _       | _       | _         | _                 | _       | _         |
| MOVE.W  | <ea>,CCR</ea>             | 1(0/0)            | _                      | _       | _       | _         | _                 | _       | 1(0/0)    |
| MOVE.W  | SR,Dx                     | 1(0/0)            | _                      | _       | _       | _         | _                 | _       | _         |
| MOVE.W  | <ea>,SR</ea>              | 7 (0/0)           | _                      | _       | _       | _         | _                 | _       | 7 (0/0) 1 |
| MOVEC   | Ry,Rc                     | 9 (0/1)           | _                      |         | _       | _         | _                 | _       | _         |
| MOVEM.L | <ea>,and<br/>list</ea>    | _                 | 1+ n(n/0) <sup>2</sup> | _       | _       | 1+ n(n/0) | _                 | _       | _         |
| MOVEM.L | and<br>list, <ea></ea>    | _                 | 1+ n(0/n)              | _       | _       | 1+ n(0/n) | _                 | _       | _         |
| MVS     | <ea>,Dx</ea>              | 1(0/0)            | 2 (1/0)                | 2 (1/0) | 2 (1/0) | 2 (1/0)   | 3 (1/0)           | 2 (1/0) | 1(0/0)    |
| MVZ     | <ea>,Dx</ea>              | 1(0/0)            | 2 (1/0)                | 2 (1/0) | 2 (1/0) | 2 (1/0)   | 3 (1/0)           | 2 (1/0) | 1(0/0)    |
| NOP     |                           | 3 (0/0)           | _                      | _       | _       | _         | _                 | _       | _         |
| PEA     | <ea></ea>                 | _                 | 2 (0/1)                | _       | _       | 2 (0/1) 3 | 3 (0/1) 4         | 2 (0/1) | _         |
| PULSE   |                           | 1(0/0)            | _                      | _       | _       | _         | _                 | _       | _         |
| STLDSR  | #imm                      | _                 | _                      | _       | _       | _         | _                 | _       | 5(0/1)    |
| STOP    | #imm                      | _                 | _                      | _       | _       | _         | _                 | _       | 3 (0/0) 5 |
| TRAP    | #imm                      | _                 | _                      | _       | _       | _         | _                 | _       | 13 (1/2)  |
| TPF     |                           | 1(0/0)            | _                      | _       | _       | _         | _                 | _       | _         |
| TPF.W   |                           | 1(0/0)            | _                      | _       | _       | _         | _                 | _       | _         |
| TPF.L   |                           | 1(0/0)            | _                      | _       | _       | _         | _                 | _       | _         |
| UNLK    | Ax                        | 2 (1/0)           | _                      | _       | _       | _         | _                 | _       | _         |
| WDDATA  | <ea></ea>                 | _                 | 3 (1/0)                | 3 (1/0) | 3 (1/0) | 3 (1/0)   | 4 (1/0)           | 3 (1/0) | _         |
| WDEBUG  | <ea></ea>                 | _                 | 5 (2/0)                | _       | _       | 5 (2/0)   | _                 | _       | _         |

- 1. If a MOVE.W #imm,SR instruction is executed and imm[13] equals 1, the execution time is 1(0/0).
- 2. The n is the number of registers moved by the MOVEM opcode.
- 3. PEA execution times are the same for (d16,PC).
- 4. PEA execution times are the same for (d8,PC,Xn\*SF).
- 5. The execution time for STOP is the time required until the processor begins sampling continuously for interrupts.

# 11.3.4.6 EMAC Instruction Execution Times

## **Table 11-30. EMAC Instruction Execution Times**

|            |                                                                                                                       |          | Effective Address |         |         |                      |                   |         |         |  |
|------------|-----------------------------------------------------------------------------------------------------------------------|----------|-------------------|---------|---------|----------------------|-------------------|---------|---------|--|
| Opcod<br>e | < <b>EA</b> >                                                                                                         | Rn       | (An)              | (An)+   | -(An)   | (d16,An)             | (d8,An,<br>Xn*SF) | xxx.wl  | #xxx    |  |
| MAC.L      | Ry, Rx, Raccx                                                                                                         | 1(0/0)   | _                 | _       | _       | _                    | _                 | _       | _       |  |
| MAC.L      | Ry, Rx, <ea>, Rw,<br/>Raccx</ea>                                                                                      | _        | 2 (1/0)           | 2 (1/0) | 2 (1/0) | 2 (1/0) 1            | _                 | _       | _       |  |
| MAC.W      | Ry, Rx, Raccx                                                                                                         | 1(0/0)   | _                 | _       | _       | _                    | _                 | _       | _       |  |
| MAC.W      | Ry, Rx, <ea>, Rw,<br/>Raccx</ea>                                                                                      | _        | 2 (1/0)           | 2 (1/0) | 2 (1/0) | 2 (1/0) <sup>1</sup> | _                 | _       | _       |  |
| MOVE.      | <ea>y, Raccx</ea>                                                                                                     | 1(0/0)   | _                 | _       | _       | _                    | _                 | _       | 1(0/0)  |  |
| MOVE.      | Raccy,Raccx                                                                                                           | 1(0/0)   | _                 | _       | _       | _                    | _                 | _       | _       |  |
| MOVE.      | <ea>y, MACSR</ea>                                                                                                     | 5 (0/0)  | _                 | _       | _       | _                    | _                 | _       | 5 (0/0) |  |
| MOVE.      | <ea>y, Rmask</ea>                                                                                                     | 4 (0/0)  | _                 | _       | _       | _                    | _                 | _       | 4 (0/0) |  |
| MOVE.      | <ea>y,Raccext01</ea>                                                                                                  | 1(0/0)   | _                 | _       | _       | _                    | _                 | _       | 1(0/0)  |  |
| MOVE.      | <ea>y,Raccext23</ea>                                                                                                  | 1(0/0)   | _                 | _       | _       | _                    | _                 | _       | 1(0/0)  |  |
| MOVE.      | Raccx, <ea>x</ea>                                                                                                     | 1(0/0) 2 | _                 | _       | _       | _                    | _                 | _       | _       |  |
| MOVE.      | MACSR, <ea>x</ea>                                                                                                     | 1(0/0)   | _                 | _       | _       | _                    | _                 | _       | _       |  |
| MOVE.      | Rmask, <ea>x</ea>                                                                                                     | 1(0/0)   | _                 | _       | _       | _                    | _                 | _       | _       |  |
| MOVE.      | Raccext01, <ea.x< td=""><td>1(0/0)</td><td>_</td><td>_</td><td>_</td><td>_</td><td>_</td><td>_</td><td>_</td></ea.x<> | 1(0/0)   | _                 | _       | _       | _                    | _                 | _       | _       |  |
| MOVE.      | Raccext23, <ea>x</ea>                                                                                                 | 1(0/0)   | _                 | _       | _       | _                    | _                 | _       | _       |  |
| MSAC.L     | Ry, Rx, Raccx                                                                                                         | 1(0/0)   | _                 | _       | _       | _                    | _                 | _       | _       |  |
| MSAC.<br>W | Ry, Rx, Raccx                                                                                                         | 1(0/0)   | _                 | _       | _       | _                    | _                 | _       | _       |  |
| MSAC.L     | Ry, Rx, <ea>, Rw,<br/>Raccx</ea>                                                                                      | _        | 2 (1/0)           | 2 (1/0) | 2 (1/0) | 2 (1/0) 1            | _                 | _       | _       |  |
| MSAC.<br>W | Ry, Rx, <ea>, Rw,<br/>Raccx</ea>                                                                                      | _        | 2 (1/0)           | 2 (1/0) | 2 (1/0) | 2 (1/0) 1            | _                 | _       | _       |  |
| MULS.L     | <ea>y, Dx</ea>                                                                                                        | 3 (0/0)  | 5 (1/0)           | 5 (1/0) | 5 (1/0) | 5 (1/0)              | _                 | _       | _       |  |
| MULS.<br>W | <ea>y, Dx</ea>                                                                                                        | 3 (0/0)  | 5 (1/0)           | 5 (1/0) | 5 (1/0) | 5 (1/0)              | 6 (1/0)           | 5 (1/0) | 3 (0/0) |  |

Table continues on the next page...

#### **Processor Exceptions**

Table 11-30. EMAC Instruction Execution Times (continued)

|            |                | Effective Address |         |         |         |          |                   |         |         |
|------------|----------------|-------------------|---------|---------|---------|----------|-------------------|---------|---------|
| Opcod<br>e | <ea></ea>      | Rn                | (An)    | (An)+   | -(An)   | (d16,An) | (d8,An,<br>Xn*SF) | xxx.wl  | #xxx    |
| MULU.L     | <ea>y, Dx</ea> | 3 (0/0)           | 5 (1/0) | 5 (1/0) | 5 (1/0) | 5 (1/0)  | _                 | _       | _       |
| MULU.<br>W | <ea>y, Dx</ea> | 3 (0/0)           | 5 (1/0) | 5 (1/0) | 5 (1/0) | 5 (1/0)  | 6 (1/0)           | 5 (1/0) | 3 (0/0) |

- 1. Effective address of (d16,PC) not supported
- 2. Storing an accumulator requires one additional processor clock cycle when saturation is enabled, or fractional rounding is performed (MACSR[7:4] equals 1---, -11-, --11)

#### **Note**

The execution times for moving the contents of the Racc, Raccext[01,23], MACSR, or Rmask into a destination location <ea>x shown in this table represent the best-case scenario when the store instruction is executed and there are no load or M{S}AC instructions in the EMAC execution pipeline. In general, these store operations require only a single cycle for execution, but if they are preceded immediately by a load, MAC, or MSAC instruction, the depth of the EMAC pipeline is exposed and the execution time is three cycles.

#### 11.3.4.7 Branch Instruction Execution Times

Table 11-31. General Branch Instruction Execution Times

|        |           |     |         |            | Effec  | tive Address          | S             |         |      |
|--------|-----------|-----|---------|------------|--------|-----------------------|---------------|---------|------|
| Opcode | <ea></ea> | Rn  | (An)    | (An)+      | -(An)  | (d <sub>16</sub> ,An) | (d8,An,Xi*SF) | xxx.wl  | #xxx |
|        |           | nii | (AII)   | (AII)+     | -(AII) | (d <sub>16</sub> ,PC) | (d8,PC,Xi*SF) | XXX.WI  | #*** |
| BRA    |           | _   | _       | _          | _      | 2 (0/1)               | _             | _       | _    |
| BSR    |           | _   | _       | _          | _      | 3 (0/1)               | _             | _       | _    |
| JMP    | <ea></ea> | _   | 3 (0/0) | _          | _      | 3 (0/0)               | 4 (0/0)       | 3 (0/0) | _    |
| JSR    | <ea></ea> | _   | 3 (0/1) | _          | _      | 3 (0/1)               | 4 (0/1)       | 3 (0/1) | _    |
| RTE    |           | _   | _       | 7<br>(2/0) | _      | _                     | _             | _       | _    |
| RTS    |           | _   | _       | 5 (1/0)    | _      | _                     | _             | _       | _    |

Table 11-32. Bcc Instruction Execution Times

| Opendo | Forward | Forward   | Backward | Backward  |
|--------|---------|-----------|----------|-----------|
| Opcode | Taken   | Not Taken | Taken    | Not Taken |
| Bcc    | 3 (0/0) | 1(0/0)    | 2 (0/0)  | 3 (0/0)   |

**Processor Exceptions** 

# Chapter 12 Enhanced Multiply-Accumulate Unit (EMAC)

## 12.1 Introduction

This chapter describes the functionality, microarchitecture, and performance of the enhanced multiply-accumulate (EMAC) unit in the ColdFire family of processors.

#### 12.1.1 Overview

The EMAC design provides a set of DSP operations that can improve the performance of embedded code while supporting the integer multiply instructions of the baseline ColdFire architecture.

The EMAC provides functionality in three related areas:

- 1. Signed and unsigned integer multiplication
- 2. Multiply-accumulate operations supporting signed and unsigned integer operands as well as signed, fixed-point, and fractional operands
- 3. Miscellaneous register operations

The ColdFire family supports two MAC implementations with different performance levels and capabilities. The original MAC features a three-stage execution pipeline optimized for 16-bit operands, with a 16×16 multiply array and a single 32-bit accumulator. The EMAC features a three-stage pipeline optimized for 32-bit operands, with a fully pipelined 32×32 multiply array and four 48-bit accumulators.

The first ColdFire MAC supported signed and unsigned integer operands and was optimized for 16x16 operations, such as those found in applications including servo control and image compression. As ColdFire-based systems proliferated, the desire for more precision on input operands increased. The result was an improved ColdFire MAC with user-programmable control to optionally enable use of fractional input operands.

#### Introduction

EMAC improvements target three primary areas:

- Improved performance of  $32 \times 32$  multiply operation.
- Addition of three more accumulators to minimize MAC pipeline stalls caused by exchanges between the accumulator and the pipeline's general-purpose registers
- A 48-bit accumulation data path to allow a 40-bit product, plus 8 extension bits increase the dynamic number range when implementing signal processing algorithms

The three areas of functionality are addressed in detail in following sections. The logic required to support this functionality is contained in a MAC module as shown below.



Figure 12-1. Multiply-Accumulate Functionality Diagram

#### 12.1.1.1 Introduction to the MAC

The MAC is an extension of the basic multiplier in most microprocessors. It is typically implemented in hardware within an architecture and supports rapid execution of signal processing algorithms in fewer cycles than comparable non-MAC architectures. For example, small digital filters can tolerate some variance in an algorithm's execution time, but larger, more complicated algorithms such as orthogonal transforms may have more demanding speed requirements beyond scope of any processor architecture and may require full DSP implementation.

To balance speed, size, and functionality, the ColdFire MAC is optimized for a small set of operations that involve multiplication and cumulative additions. Specifically, the multiplier array is optimized for single-cycle pipelined operations with a possible accumulation after product generation. This functionality is common in many signal processing applications. The ColdFire core architecture is also modified to allow an operand to be fetched in parallel with a multiply, increasing overall performance for certain DSP operations.

Consider a typical filtering operation where the filter is defined as in the following equation.

$$y(i) = \sum_{k=1}^{N-1} a(k)y(i-k) + \sum_{k=0}^{N-1} b(k)x(i-k)$$

Here, the output y(i) is determined by past output values and past input values. This is the general form of an infinite impulse response (IIR) filter. A finite impulse response (FIR) filter can be obtained by setting coefficients a(k) to zero. In either case, the operations involved in computing such a filter are multiplies and product summing. To show this point, reduce the preceding equation to a simple, four-tap FIR filter, shown in the following equation, in which the accumulated sum is a past data values and coefficients sum.

$$y(i) = \sum_{k=0}^{3} b(k) x (i - k) = b(0) x (i) + b(1) x (i - 1) + b(2) x (i - 2) + b(3) x (i - 3)$$

# 12.2 Memory Map/Register Definition

The following table and sections explain the MAC registers.

**BDM** Register Width (bits) **Access Reset Value** Read: 0xE4 MAC status register (MACSR) 32 R/W 0x0000\_0000 Write: 0xC4 Read: 0xE5 MAC address mask register (MASK) 32 R/W 0xFFFF\_FFFF Write: 0xC5 Read: 0xE6 MAC accumulator 0 (ACC0) R/W Undefined 32 Write: 0xC6 Read: 0xE7 MAC accumulator 0,1 extension bytes R/W Undefined 32 (ACCext01) Write: 0xC7 Read: 0xE8 MAC accumulator 2,3 extension bytes 32 R/W Undefined (ACCext23) Write: 0xC8 Read: 0xE9 MAC accumulator 1 (ACC1) R/W Undefined 32 Write: 0xC9 Read: 0xEA MAC accumulator 2 (ACC2) R/W Undefined 32 Write: 0xCA Read: 0xEB MAC accumulator 2 (ACC3) 32 R/W Undefined

Table 12-1. EMAC Memory Map

Write: 0xCB

# 12.2.1 MAC Status Register (MACSR)

The MAC status register (MACSR) contains a 4-bit operational mode field and condition flags. Operational mode bits control whether operands are signed or unsigned and whether they are treated as integers or fractions. These bits also control the overflow/saturation mode and the way in which rounding is performed. Negative, zero, and multiple overflow condition flags are also provided.

BDM: Read: 0xE4 (MACSR) Access: Supervisor read/ write Write: 0xC4 BDM read/write R W Reset R PAVn OMC S/U F/I R/T Ζ ΕV Ν W Reset

Table 12-2. MAC Status Register (MACSR)

Table 12-3. MACSR Field Descriptions

| Field                | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–12                | Reserved, must be cleared.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 11–8<br>PAV <i>n</i> | Product/accumulation overflow flags. Contains four flags, one per accumulator, that indicate if past MAC or MSAC instructions generated an overflow during product calculation or the 48-bit accumulation. When a MAC or MSAC instruction is executed, the PAVn flag associated with the destination accumulator forms the general overflow flag, MACSR[V]. Once set, each flag remains set until V is cleared by a move.l, MACSR instruction or the accumulator is loaded directly.  Bit 11: Accumulator 3  Bit 8: Accumulator 0 |
| 7<br>OMC             | Overflow saturation mode. Enables or disables saturation mode on overflow. If set, the accumulator is set to the appropriate constant (see S/U field description) on any operation that overflows the accumulator. After saturation, the accumulator remains unaffected by any other MAC or MSAC instructions until the overflow bit is cleared or the accumulator is directly loaded.                                                                                                                                            |

Table continues on the next page...

# **Table 12-3. MACSR Field Descriptions (continued)**

| Field    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |
|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 6        | Signed/unsigned operations.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |
| S/U      | In integer mode:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |
|          | S/U determines whether operations performed are signed or unsigned. It also determines the accumulator value during saturation, if enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |
|          | O Signed numbers. On overflow, if OMC is enabled, an accumulator saturates to the most positive (0x7FFF_FFFF) or the most negative (0x8000_0000) number, depending on the instruction and the product value that overflowed.                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |
|          | 1 Unsigned numbers. On overflow, if OMC is enabled, an accumulator saturates to the smallest value (0x0000_0000) or the largest value (0xFFFF_FFFF), depending on the instruction.                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |
|          | In fractional mode:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |
|          | S/U controls rounding while storing an accumulator to a general-purpose register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |
|          | 0 Move accumulator without rounding to a 16-bit value. Accumulator is moved to a general-purpose register as a 32-bit value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |
|          | The accumulator is rounded to a 16-bit value using the round-to-nearest (even) method when moved to a general-purpose register. The resulting 16-bit value is stored in the lower word of the destination register. The upper word is zero-filled. This rounding procedure does not affect the accumulator value.                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |
| 5        | Fractional/integer mode. Determines whether input operands are treated as fractions or integers.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |
| F/I      | 0 Integers can be represented in signed or unsigned notation, depending on the value of S/U.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |
|          | Fractions are represented in signed, fixed-point, two's complement notation. Values range from $-1$ to $1-2^{-15}$ for 16-bit fractions and $-1$ to $1-2^{-31}$ for 32-bit fractions.                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |
| 4<br>R/T | Round/truncate mode. Controls rounding procedure for move.I ACCx,Rx, or MSAC.L instructions when in fractional mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |
|          | Truncate. The product's lsbs are dropped before it is combined with the accumulator. Additionally, when a store accumulator instruction is executed (move.l ACCx,Rx), the 8 lsbs of the 48-bit accumulator logic are truncated.                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |
|          | Round-to-nearest (even). The 64-bit product of two 32-bit, fractional operands is rounded to the nearest 40-bit value. If the low-order 24 bits equal 0x80_0000, the upper 40 bits are rounded to the nearest even (lsb = 0) value. Additionally, when a store accumulator instruction is executed (move.I ACCx,Rx), the lsbs of the 48-bit accumulator logic round the resulting 16- or 32-bit value. If MACSR[S/U] is cleared and MACSR[R/T] is set, the low-order 8 bits are used to round the resulting 32-bit fraction. If MACSR[S/U] is set, the low-order 24 bits are used to round the resulting 16-bit fraction. |  |  |  |  |  |
| 3<br>N   | Negative. Set if the msb of the result is set, otherwise cleared. N is affected only by MAC, MSAC, and load operations; it is not affected by MULS and MULU instructions.                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |
| 2<br>Z   | Zero. Set if the result equals zero, otherwise cleared. This bit is affected only by MAC, MSAC, and load operations; it is not affected by MULS and MULU instructions.                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |
| 1        | Overflow. Set if an arithmetic overflow occurs on a MAC or MSAC instruction, indicating that the result                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |
| V        | cannot be represented in the limited width of the EMAC. V is set only if a product overflow occurs or the accumulation overflows the 48-bit structure. V is evaluated on each MAC or MSAC operation and uses the appropriate PAVn flag in the next-state V evaluation.                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |
| 0<br>EV  | Extension overflow. Signals that the last MAC or MSAC instruction overflowed the 32 lsbs in integer mode or the 40 lsbs in fractional mode of the destination accumulator. However, the result remains accurately represented in the combined 48-bit accumulator structure. Although an overflow has occurred, the correct result, sign, and magnitude are contained in the 48-bit accumulator. Subsequent MAC or MSAC operations may return the accumulator to a valid 32/40-bit result.                                                                                                                                 |  |  |  |  |  |

#### **Memory Map/Register Definition**

This table summarizes the interaction of the MACSR[S/U,F/I,R/T] control bits.

Table 12-4. Summary of S/U, F/I, and R/T Control Bits

| S/U | F/I | R/T | Operational Modes                      |
|-----|-----|-----|----------------------------------------|
| 0   | 0   | х   | Signed, integer                        |
| 0   | 1   | 0   | Signed, fractional                     |
|     |     |     | Truncate on MAC.L and MSAC.L           |
|     |     |     | No round on accumulator stores         |
| 0   | 1   | 1   | Signed, fractional                     |
|     |     |     | Round on MAC.L and MSAC.L              |
|     |     |     | Round-to-32-bits on accumulator stores |
| 1   | 0   | х   | Unsigned, integer                      |
| 1   | 1   | 0   | Signed, fractional                     |
|     |     |     | Truncate on MAC.L and MSAC.L           |
|     |     |     | Round-to-16-bits on accumulator stores |
| 1   | 1   | 1   | Signed, fractional                     |
|     |     |     | Round on MAC.L and MSAC.L              |
|     |     |     | Round-to-16-bits on accumulator stores |

# 12.2.2 Mask Register (MASK)

The 32-bit MASK implements the low-order 16 bits to minimize the alignment complications involved with loading and storing only 16 bits. When the MASK is loaded, the low-order 16 bits of the source operand are actually loaded into the register. When it is stored, the upper 16 bits are all forced to ones. This register performs a simple AND with the operand address for MAC instructions. The processor calculates the normal operand address and, if enabled, that address is then ANDed with {0xFFFF, MASK[15:0]} to form the final address. Therefore, with certain MASK bits cleared, the operand address can be constrained to a certain memory region. This is used primarily to implement circular queues with the (An)+ addressing mode.

This minimizes the addressing support required for filtering, convolution, or any routine that implements a data array as a circular queue. For MAC + MOVE operations, the MASK contents can optionally be included in all memory effective address calculations. The syntax is as follows:

```
mac.sz Ry,RxSF,<ea>y&,Rw
```

The & operator enables the MASK use and causes bit 5 of the extension word to be set. The exact algorithm for the use of MASK is:

```
if extension word, bit [5] = 1, the MASK bit, then
if <ea> = (An)
oa = An & {0xFFFF, MASK}

if <ea> = (An) +
oa = An
An = (An + 4) & {0xFFFF, MASK}

if <ea> = -(An)
oa = (An - 4) & {0xFFFF, MASK}
An = (An - 4) & {0xFFFF, MASK}

if <ea> = (d16,An)
oa = (An + se d16) & {0xFFFF0x, MASK}
```

Here, oa is the calculated operand address and se\_d16 is a sign-extended 16-bit displacement. For auto-addressing modes of post-increment and pre-decrement, the updated An value calculation is also shown.

Use of the post-increment addressing mode, {(An)+} with the MASK is suggested for circular queue implementations.



Table 12-5. Mask Register (MASK)

Table 12-6. MASK Field Descriptions

| Field | Description            |
|-------|------------------------|
| 31–12 | Reserved; must be set. |

Table continues on the next page...

#### **Memory Map/Register Definition**

Table 12-6. MASK Field Descriptions (continued)

| Field | Description                                                          |
|-------|----------------------------------------------------------------------|
| 15–0  | Performs a simple AND with the operand address for MAC instructions. |
| MASK  |                                                                      |

# 12.2.3 Accumulator Registers (ACC0-3)

Each accumulator register stores 32 bits of the MAC operation result. The entire 48-bit accumulator result consists of the accumulator register concatenated with the corresponding fields of the accumulator extension registers.

Table 12-7. Accumulator Registers (ACC0-3)



Table 12-8. ACC0-3 Field Descriptions

| Field       | Description                                       |
|-------------|---------------------------------------------------|
| 31–0        | Store 32-bits of the result of the MAC operation. |
| Accumulator |                                                   |

# 12.2.4 Accumulator Extension Registers (ACCext01, ACCext23)

Each pair of 8-bit accumulator extension fields are concatenated with the corresponding 32-bit accumulator register to form the 48-bit accumulator. For more information, see the functional description.

Table 12-9. Accumulator Extension Register (ACCext01)



Table 12-10. ACCext01 Field Descriptions

| Field | Description                        |
|-------|------------------------------------|
| 31–24 | Accumulator 0 upper extension byte |
| ACC0U |                                    |
| 23–16 | Accumulator 0 lower extension byte |
| ACC0L |                                    |
| 15–8  | Accumulator 1 upper extension byte |
| ACC1U |                                    |
| 7–0   | Accumulator 1 lower extension byte |
| ACC1L |                                    |

Table 12-11. Accumulator Extension Register (ACCext23)

| BDM:  |    | Read: 0xE8 (ACCext01) |    |    |    |    |    |       | 1) Access: User read/write |    |    |    |    |        | /write   |    |
|-------|----|-----------------------|----|----|----|----|----|-------|----------------------------|----|----|----|----|--------|----------|----|
|       |    | Write: 0xC8           |    |    |    |    |    |       |                            |    |    |    | E  | BDM re | ad/write | е  |
|       | 31 | 30                    | 29 | 28 | 27 | 26 | 25 | 24    | 23                         | 22 | 21 | 20 | 19 | 18     | 17       | 16 |
| R W   |    | ACC2U                 |    |    |    |    |    | ACC2L |                            |    |    |    |    |        |          |    |
| Reset | -  | _                     | _  | _  | _  | _  | _  | _     | _                          | _  | _  | _  | _  | _      | _        | _  |
|       | 15 | 14                    | 13 | 12 | 11 | 10 | 9  | 8     | 7                          | 6  | 5  | 4  | 3  | 2      | 1        | 0  |

Table continues on the next page...

#### Table 12-11. Accumulator Extension Register (ACCext23) (continued)

| R<br>W | ACC3U |   |   |   |   |   |   | AC | C3L |   |   |   |   |   |   |   |  |
|--------|-------|---|---|---|---|---|---|----|-----|---|---|---|---|---|---|---|--|
| Reset  | _     | _ | _ | _ | _ | _ | _ | _  | _   | _ | _ | _ | _ | _ | _ | _ |  |

Table 12-12. ACCext23 Field Descriptions

| Field | Description                        |
|-------|------------------------------------|
| 31–24 | Accumulator 2 upper extension byte |
| ACC2U |                                    |
| 23–16 | Accumulator 2 lower extension byte |
| ACC2L |                                    |
| 15–8  | Accumulator 3 upper extension byte |
| ACC3U |                                    |
| 7–0   | Accumulator 3 lower extension byte |
| ACC3L |                                    |

# 12.3 Functional Description

The MAC speeds execution of ColdFire integer-multiply instructions (MULS and MULU) and provides additional functionality for multiply-accumulate operations. By executing MULS and MULU in the MAC, execution times are minimized and deterministic compared to the 2-bit/cycle algorithm with early termination that the OEP normally uses if no MAC hardware is present.

The added MAC instructions to the ColdFire ISA provide for the multiplication of two numbers, followed by the addition or subtraction of the product to or from the value in an accumulator. Optionally, the product may be shifted left or right by 1 bit before addition or subtraction. Hardware support for saturation arithmetic can be enabled to minimize software overhead when dealing with potential overflow conditions. Multiply-accumulate operations support 16- or 32-bit input operands in these formats:

- Signed integers
- Unsigned integers
- Signed, fixed-point, fractional numbers

The EMAC is optimized for single-cycle, pipelined  $32 \times 32$  multiplications. For word-and longword-sized integer input operands, the low-order 40 bits of the product are formed and used with the destination accumulator. For fractional operands, the entire 64-

bit product is calculated and truncated or rounded to the most-significant 40-bit result using the round-to-nearest (even) method before it is combined with the destination accumulator.

For all operations, the resulting 40-bit product is extended to a 48-bit value (using sign-extension for signed integer and fractional operands, zero-fill for unsigned integer operands) before being combined with the 48-bit destination accumulator.

The following two figures show relative alignment of input operands, the full 64-bit product, the resulting 40-bit product used for accumulation, and 48-bit accumulator formats.



Figure 12-3. Signed and Unsigned Integer Alignment

Therefore, the 48-bit accumulator definition is a function of the EMAC operating mode. Given that each 48-bit accumulator is the concatenation of 16-bit accumulator extension register (ACCext*n*) contents and 32-bit ACC*n* contents, the specific definitions are:

#### **Functional Description**

The four accumulators are represented as an array, ACCn, where n selects the register.

Although the multiplier array is implemented in a three-stage pipeline, all arithmetic MAC instructions have an effective issue rate of 1 cycle, regardless of input operand size or type.

All arithmetic operations use register-based input operands, and summed values are stored in an accumulator. Therefore, an additional MOVE instruction is needed to store data in a general-purpose register. One new feature in EMAC instructions is the ability to choose the upper or lower word of a register as a 16-bit input operand. This is useful in filtering operations if one data register is loaded with the input data and another is loaded with the coefficient. Two 16-bit multiply accumulates can be performed without fetching additional operands between instructions by alternating word choice during calculations.

The EMAC has four accumulator registers versus the MAC's single accumulator. The additional registers improve the performance of some algorithms by minimizing pipeline stalls needed to store an accumulator value back to general-purpose registers. Many algorithms require multiple calculations on a given data set. By applying different accumulators to these calculations, it is often possible to store one accumulator without any stalls while performing operations involving a different destination accumulator.

The need to move large amounts of data presents an obstacle to obtaining high throughput rates in DSP engines. Existing ColdFire instructions can accommodate these requirements. A MOVEM instruction can efficiently move large data blocks. The ability to load an operand simultaneously from memory into a register and execute a MAC instruction makes some DSP operations such as filtering and convolution more manageable.

The programming model includes a mask register (MASK), which can optionally be used to generate an operand address during MAC + MOVE instructions. The register application with auto-increment addressing mode supports efficient implementation of circular data queues for memory operands.

# 12.3.1 Fractional Operation Mode

This section describes behavior when the fractional mode is used (MACSR[F/I] is set).

# 12.3.1.1 Rounding

When the processor is in fractional mode, there are two operations during which rounding can occur:

- 1. Execution of a store accumulator instruction (move.l ACCx,Rx). The lsbs of the 48-bit accumulator logic are used to round the resulting 16- or 32-bit value. If MACSR[S/U] is cleared, the low-order 8 bits round the resulting 32-bit fraction. If MACSR[S/U] is set, the low-order 24 bits are used to round the resulting 16-bit fraction.
- 2. Execution of a MAC (or MSAC) instruction with 32-bit operands. If MACSR[R/T] is zero, multiplying two 32-bit numbers creates a 64-bit product truncated to the upper 40 bits; otherwise, it is rounded using round-to-nearest (even) method.

To understand the round-to-nearest-even method, consider the following example involving the rounding of a 32-bit number, R0, to a 16-bit number. Using this method, the 32-bit number is rounded to the closest 16-bit number possible. Let the high-order 16 bits of R0 be named R0.U and the low-order 16 bits be R0.L.

- If R0.L is less than 0x8000, the result is truncated to the value of R0.U.
- If R0.L is greater than 0x8000, the upper word is incremented (rounded up).
- If R0.L is 0x8000, R0 is half-way between two 16-bit numbers. In this case, rounding is based on the lsb of R0.U, so the result is always even (lsb = 0).
  - If the lsb of R0.U equals 1 and R0.L equals 0x8000, the number is rounded up.
  - If the lsb of R0.U equals 0 and R0.L equals 0x8000, the number is rounded down.

This method minimizes rounding bias and creates as statistically correct an answer as possible.

The rounding algorithm is summarized in the following pseudocode:

The round-to-nearest-even technique is also known as convergent rounding.

# 12.3.1.2 Saving and Restoring the EMAC Programming Model

The presence of rounding logic in the EMAC output datapath requires special care during the EMAC's save/restore process. In particular, any result rounding modes must be disabled during the save/restore process so the exact bit-wise contents of the EMAC registers are accessed. Consider the memory structure containing the EMAC programming model:

```
struct macState {
    int acc0;
    int acc1;
    int acc2;
    int acc3;
    int accext01;
    int accext02;
    int mask;
    int macsr;
}
```

The following assembly language routine shows the proper sequence for a correct EMAC state save. This code assumes all Dn and An registers are available for use, and the memory location of the state save is defined by A7.

```
EMAC state save:
        move.l macsr,d7
                                           ; save the macsr
        clr.l d0
                                           ; zero the register to ...
        move.1 d0, macsr
                                           ; disable rounding in the macsr
        move.l acc0,d0
                                           ; save the accumulators
        move.l acc1,d1
        move.l acc2,d2
        move.l acc3,d3
        move.l accext01,d4
move.l accext23,d5
                                           ; save the accumulator extensions
        move.1 mask,d6
                                           ; save the address mask
        movem.1 #0x00ff,(a7)
                                           ; move the state to memory
```

This code performs the EMAC state restore:

```
EMAC_state_restore:

movem.l (a7),#0x00ff ; restore the state from memory

move.l d5,acc ; restore the accumulator
move.l d0,acc0 ; restore the accumulators
move.l d1,acc1
move.l d2,acc2
move.l d3,acc3
move.l d4,accext01 ; restore the accumulator extensions
move.l d5,accext23
move.l d6,mask ; restore the address mask
move.l d7,macsr ; restore the macsr
```

Executing this sequence type can correctly save and restore the exact state of the EMAC programming model.

#### 12.3.1.3 MULS/MULU

MULS and MULU are unaffected by fractional-mode operation; operands remain assumed to be integers.

### 12.3.1.4 Scale Factor in MAC or MSAC Instructions

The scale factor is ignored while the MAC is in fractional mode.

# 12.3.2 EMAC Instruction Set Summary

The following table summarizes EMAC unit instructions.

Table 12-13. EMAC Instruction Summary

| Command                        | Mnemonic                       | Description                                                                |
|--------------------------------|--------------------------------|----------------------------------------------------------------------------|
| Multiply Signed                | muls <ea>y,Dx</ea>             | Multiplies two signed operands yielding a signed result                    |
| Multiply Unsigned              | mulu <ea>y,Dx</ea>             | Multiplies two unsigned operands yielding an unsigned result               |
| Multiply Accumulate            | mac Ry,RxSF,ACCx               | Multiplies two operands and adds/subtracts the                             |
|                                | msac Ry,RxSF,ACCx              | product to/from an accumulator                                             |
| Multiply Accumulate with       | mac Ry,Rx, <ea>y,Rw,ACCx</ea>  | Multiplies two operands and combines the                                   |
| Load                           | msac Ry,Rx, <ea>y,Rw,ACCx</ea> | product to an accumulator while loading a register with the memory operand |
| Load Accumulator               | move.l {Ry,#imm},ACCx          | Loads an accumulator with a 32-bit operand                                 |
| Store Accumulator              | move.I ACCx,Rx                 | Writes the contents of an accumulator to a CPU register                    |
| Copy Accumulator               | move.l ACCy,ACCx               | Copies a 48-bit accumulator                                                |
| Load MACSR                     | move.I {Ry,#imm},MACSR         | Writes a value to MACSR                                                    |
| Store MACSR                    | move.I MACSR,Rx                | Write the contents of MACSR to a CPU register                              |
| Store MACSR to CCR             | move.I MACSR,CCR               | Write the contents of MACSR to the CCR                                     |
| Load MAC Mask Reg              | move.l {Ry,#imm},MASK          | Writes a value to the MASK register                                        |
| Store MAC Mask Reg             | move.l MASK,Rx                 | Writes the contents of the MASK to a CPU register                          |
| Load Accumulator Extensions 01 | move.l {Ry,#imm},ACCext01      | Loads the accumulator 0,1 extension bytes with a 32-bit operand            |

Table continues on the next page...

#### **Functional Description**

Table 12-13. EMAC Instruction Summary (continued)

| Command                            | Mnemonic                  | Description                                                                |  |  |  |
|------------------------------------|---------------------------|----------------------------------------------------------------------------|--|--|--|
| Load Accumulator Extensions 23     | move.I {Ry,#imm},ACCext23 | Loads the accumulator 2,3 extension bytes with a 32-bit operand            |  |  |  |
| Store Accumulator<br>Extensions 01 | move.l ACCext01,Rx        | Writes the contents of accumulator 0,1 extension bytes into a CPU register |  |  |  |
| Store Accumulator<br>Extensions 23 | move.I ACCext23,Rx        | Writes the contents of accumulator 2,3 extension bytes into a CPU register |  |  |  |

#### 12.3.3 EMAC Instruction Execution Times

The instruction execution times for the EMAC can be found in the "EMAC instruction execution times" section of the core chapter.

The EMAC execution pipeline overlaps the AGEX stage of the OEP (the first stage of the EMAC pipeline is the last stage of the basic OEP). EMAC units are designed for sustained, fully-pipelined operation on accumulator load, copy, and multiply-accumulate instructions. However, instructions that store contents of the multiply-accumulate programming model can generate OEP stalls that expose the EMAC execution pipeline depth:

The MOVE.L instruction that stores the accumulator to an integer register (Rz) stalls until the program-visible copy of the accumulator is available. The following figure shows EMAC timing.



Figure 12-4. EMAC-Specific OEP Sequence Stall

The OEP stalls the store-accumulator instruction for two cycles: the EMAC pipeline depth minus 1. The minus 1 factor is needed because the OEP and EMAC pipelines overlap by a cycle, the AGEX stage. As the store-accumulator instruction reaches the AGEX stage where the operation is performed, the recently updated accumulator 0 value is available.

As with change or use stalls between accumulators and general-purpose registers, introducing intervening instructions that do not reference the busy register can reduce or eliminate sequence-related store-MAC instruction stalls. A major benefit of the EMAC is the addition of three accumulators to minimize stalls caused by exchanges between the accumulator(s) and general-purpose registers.

# 12.3.4 Data Representation

MACSR[S/U,F/I] selects one of the following three modes, where each mode defines a unique operand type:

- 1. Two's complement signed integer: In this format, an N-bit operand value lies in the range  $-2^{(N-1)} \le \text{operand} \le 2^{(N-1)} 1$ . The binary point is right of the lsb.
- 2. Unsigned integer: In this format, an N-bit operand value lies in the range  $0 \le 0$  operand  $0 \le 2^N 1$ . The binary point is right of the lsb.
- 3. Two's complement signed fractional: In an N-bit number, the first bit is the sign bit. The remaining bits signify the first N-1 bits after the binary point. Given an N-bit number,  $a_{N-1}a_{N-2}a_{N-3}...$   $a_2a_1a_0$ , its value is given by the equation in the following equation.

value = 
$$-(1.a_{N-1}) + \sum_{i=0}^{N-2} 2^{-(i+1-N)}$$
ai

This format can represent numbers in the range  $-1 \le \text{operand} \le 1 - 2^{-(N-1)}$ .

For words and longwords, the largest negative number that can be represented is -1, whose internal representation is 0x8000 and  $0x8000\_0000$ , respectively. The largest positive word is 0x7FFF or  $(1 - 2^{-15})$ ; the most positive longword is  $0x7FFF\_FFFF$  or  $(1 - 2^{-31})$ . Thus, the number range for these signed fractional numbers is [-1.0, ..., 1.0].

# 12.3.5 MAC Opcodes

MAC opcodes are described in the ColdFire Programmer's Reference Manual.

Remember the following:

#### **Functional Description**

- Unless otherwise noted, the value of MACSR[N,Z] is based on the result of the final operation that involves the product and the accumulator.
- The overflow (V) flag is managed differently. It is set if the complete product cannot be represented as a 40-bit value (this applies to 32 × 32 integer operations only) or if the combination of the product with an accumulator cannot be represented in the given number of bits. The EMAC design includes an additional product/ accumulation overflow bit for each accumulator that are treated as sticky indicators and are used to calculate the V bit on each MAC or MSAC instruction. See MAC Status Register (MACSR).
- For the MAC design, the assembler syntax of the MAC (multiply and add to accumulator) and MSAC (multiply and subtract from accumulator) instructions does not include a reference to the single accumulator. For the EMAC, assemblers support this syntax and no explicit reference to an accumulator is interpreted as a reference to ACCO. Assemblers also support syntaxes where the destination accumulator is explicitly defined.
- The optional 1-bit shift of the product is specified using the notation {<< |>>} SF, where <<1 indicates a left shift and >>1 indicates a right shift. The shift is performed before the product is added to or subtracted from the accumulator. Without this operator, the product is not shifted. If the EMAC is in fractional mode (MACSR[F/I] is set), SF is ignored and no shift is performed. Because a product can overflow, the following guidelines are implemented:
  - For unsigned word and longword operations, a zero is shifted into the product on right shifts.
  - For signed, word operations, the sign bit is shifted into the product on right shifts unless the product is zero. For signed, longword operations, the sign bit is shifted into the product unless an overflow occurs or the product is zero, in which case a zero is shifted in.
  - For all left shifts, a zero is inserted into the lsb position.

The following pseudocode explains basic MAC or MSAC instruction functionality. This example is presented as a case statement covering the three basic operating modes with signed integers, unsigned integers, and signed fractionals. Throughout this example, a comma-separated list in curly brackets, {}, indicates a concatenation operation.

MCF51JF128 Reference Manual, Rev. 2, 03/2011

288

```
MACSR.PAVn = 0
        /* select the input operands */
        if (sz == word)
           then \{if (U/Ly == 1)\}
                then operandY[31:0] = \{\text{sign-extended Ry[31], Ry[31:16]}\}
                 else operandY[31:0] = \{ sign-extended Ry[15], Ry[15:0] \}
                 if (U/Lx == 1)
                then operandX[31:0] = \{sign-extended Rx[31], Rx[31:16]\}
                 else operandX[31:0] = \{sign-extended Rx[15], Rx[15:0]\}
           else {operandY[31:0] = Ry[31:0]
                 operandX[31:0] = Rx[31:0]
        /* perform the multiply */
        product[63:0] = operandY[31:0] * operandX[31:0]
        /* check for product overflow */
if ((product[63:39] != 0x0000_00_0) && (product[63:39] != 0xffff_ff_1))
           then {
                          /* product overflow */
                 MACSR.PAVn = 1
                 MACSR.V = 1
                 if (inst == MSAC && MACSR.OMC == 1)
                    then if (product[63] == 1)
                             then result[47:0] = 0x0000_{7}fff_{fff}
                             else result[47:0] = 0xffff 8000 0000
                    else if (MACSR.OMC == 1)
                             then /* overflowed MAC,
                                     saturationMode enabled */
                                  if (product[63] == 1)
                                    then result [47:0] = 0xffff 8000 0000
                                    else result[47:0] = 0x0000_7fff_fff
         /\star sign-extend to 48 bits before performing any scaling \star/
         product [47:40] = {8{product [39]}}
                                             /* sign-extend */
        /* scale product before combining with accumulator */
        switch (SF)
                        /* 2-bit scale factor */
            case 0:
                        /* no scaling specified */
               break;
                         /* SF = "<< 1" */
            case 1:
               product[40:0] = \{product[39:0], 0\}
               break:
            case 2:
                        /* reserved encoding */
               break:
                         /* SF = ">> 1" */
            case 3:
               product[39:0] = {product[39], product[39:1]}
               break;
        if (MACSR.PAVn == 0)
           then {if (inst == MSAC)
                    then result [47:0] = ACCx[47:0] - product[47:0]
                    else result [47:0] = ACCx[47:0] + product [47:0]
        /* check for accumulation overflow */
        if (accumulationOverflow == 1)
           then \{MACSR.PAVn = 1\}
                 MACSR.V = 1
                 if (MACSR.OMC == 1)
                    then /* accumulation overflow,
                             saturationMode enabled */
                          if (result[47] == 1)
                             then result [47:0] = 0x0000 7fff ffff
                             else result[47:0] = 0xffff 8000 0000
        /* transfer the result to the accumulator */
        ACCx[47:0] = result[47:0]
 MACSR.V = MACSR.PAVn
 MACSR.N = ACCx[47]
  if (ACCx[47:0] == 0x0000_0000_0000)
     then MACSR.Z = 1
```

#### **Functional Description**

```
else MACSR.Z = 0
      if ((ACCx[47:31] == 0x0000_0) | (ACCx[47:31] == 0xffff_1))
         then MACSR.EV = 0
         else MACSR.EV = 1
break:
   case 1,3:
                            /* signed fractionals */
   if (MACSR.OMC == 0 | MACSR.PAVn == 0)
      then {
            MACSR.PAVn = 0
            if (sz == word)
                then \{if (U/Ly == 1)\}
                         then operandY[31:0] = \{Ry[31:16], 0x0000\}
                         else operandY[31:0] = \{Ry[15:0], 0x0000\}
                      if (U/Lx == 1)
                         then operandX[31:0] = \{Rx[31:16], 0x0000\}
                         else operandX[31:0] = \{Rx[15:0], 0x0000\}
                else {operandY[31:0] = Ry[31:0]
                      operandX[31:0] = Rx[31:0]
             /* perform the multiply */
            product[63:0] = (operandY[31:0] * operandX[31:0]) << 1</pre>
             /* check for product rounding */
            if (MACSR.R/T == 1)
                then { /* perform convergent rounding */
                      if (product[23:0] > 0x80_0000)
                         then product[63:24] = product[63:24] + 1
                else if ((product[23:0] == 0x80_0000) && (product[24] == 1))
                                  then product [6\overline{3}:24] = product [63:24] + 1
             /* sign-extend to 48 bits and combine with accumulator */
            /* check for the -1 * -1 overflow case */
    if ((operandY[31:0] == 0x8000 0000) && (operandX[31:0] == 0x8000 0000))
                then product [71:64] = 0x00
                                                              /* zero-fill */
                else product[71:64] = {8{product[63]}}
                                                             /* sign-extend */
            if (inst == MSAC)
                then result [47:0] = ACCx[47:0] - product[71:24]
                else result[47:0] = ACCx[47:0] + product[71:24]
             /* check for accumulation overflow */
            if (accumulationOverflow == 1)
                then \{MACSR.PAVn = 1\}
                      MACSR.V = 1
                      if (MACSR.OMC == 1)
                         then /* accumulation overflow,
                                  saturationMode enabled */
                               if (result[47] == 1)
                                  then result [47:0] = 0 \times 007f ffff ff00
                                  else result[47:0] = 0xff80 0000 0000
             /* transfer the result to the accumulator */
            ACCx[47:0] = result[47:0]
      MACSR.V = MACSR.PAVn
      MACSR.N = ACCx[47]
      if (ACCx[47:0] == 0x0000 0000 0000)
          then MACSR.Z = 1
          else MACSR.Z = 0
      if ((ACCx[47:39] == 0x00 0) | (ACCx[47:39] == 0xff 1))
          then MACSR.EV = 0
          else MACSR.EV = 1
break;
                      /* unsigned integers */
case 2:
   if (MACSR.OMC == 0 | MACSR.PAVn == 0)
      then {
            MACSR.PAVn = 0
             /* select the input operands */
            if (sz == word)
                then \{if (U/Ly == 1)\}
                         then operandY[31:0] = \{0x0000, Ry[31:16]\}
else operandY[31:0] = \{0x0000, Ry[15:0]\}
```

MCF51JF128 Reference Manual, Rev. 2, 03/2011

290

```
then operandX[31:0] = \{0x00000, Rx[31:16]\}
                         else operandX[31:0] = \{0x0000, Rx[15:0]\}
               else \{\text{operandY}[31:0] = \text{Ry}[31:0]
                      operandX[31:0] = Rx[31:0]
            /* perform the multiply */
            product[63:0] = operandY[31:0] * operandX[31:0]
            /* check for product overflow */
            if (product[63:40] != 0x0000 00)
                              /* product overflow */
               then {
                      MACSR.PAVn = 1
                      MACSR.V = 1
                      if (inst == MSAC && MACSR.OMC == 1)
                         then result [47:0] = 0x0000 0000 0000
                         else if (MACSR.OMC == 1)
                                 then /* overflowed MAC,
                                          saturationMode enabled */
                                       result[47:0] = 0xffff_ffff_ffff
               }
              /* zero-fill to 48 bits before performing any scaling */
             product[47:40] = 0  /* zero-fill upper byte */
            /{f \hat{*}} scale product before combining with accumulator */
            switch (SF)
                            /* 2-bit scale factor */
                             /* no scaling specified */
                case 0:
                   break;
                case 1:
                             /* SF = "<< 1" */
                   product[40:0] = {product[39:0], 0}
                   break;
                             /* reserved encoding */
                case 2:
                   break;
                             /* SF = ">> 1" */
                 case 3:
                   product[39:0] = \{0, product[39:1]\}
                    break;
             /* combine with accumulator */
            if (MACSR.PAVn == 0)
               then {if (inst == MSAC)
                         then result [47:0] = ACCx [47:0] - product [47:0]
                         else result[47:0] = ACCx[47:0] + product[47:0]
             /* check for accumulation overflow */
            if (accumulationOverflow == 1)
               then \{MACSR.PAVn = 1
                      MACSR.V = 1
                      if (inst == MSAC && MACSR.OMC == 1)
                         then result [47:0] = 0x0000 0000 0000
                         else if (MACSR.OMC == 1)
                              then /* overflowed MAC,
                                      saturationMode enabled */
                                   result[47:0] = 0xffff_ffff_ffff
            /* transfer the result to the accumulator */
            ACCx[47:0] = result[47:0]
      MACSR.V = MACSR.PAVn
      MACSR.N = ACCx[47]
      if (ACCx[47:0] == 0x0000_0000_0000)
         then MACSR.Z = 1
         else MACSR.Z = 0
      if (ACCx[47:32] == 0x0000)
         then MACSR.EV = 0
         else MACSR.EV = 1
break;
```

if (U/Lx == 1)

**Functional Description** 

# **Chapter 13 System Integration Module (SIM)**

### 13.1 Introduction

The system integration module (SIM) provides system control and chip configuration registers.

# 13.2 Memory Map and Registers

### **NOTE**

Different SIM registers reset on different MCU reset types. The reset type represented by each register's displayed reset value is as follows:

- For SOPT1-2 registers: Chip POR not VLLS
- For SOPT3-4 registers: Chip Reset not VLLS
- For SOPT5-7, COPC, SRVCOP, OSC1, SCGC1-6, CLKOUT, and CLKDIV1 registers: Chip Reset
- For SDIDH, SDIDL, CLKDIVO, SPCR, and UID\* registers: Chip POR

For each list, the registers are reset only by the specified reset type or any reset type that triggers the specified reset type. Other reset types do not affect the registers. For information about the various reset types on this chip, refer to the Reset details.

### **Memory Map and Registers**

# SIM memory map

| Absolute<br>address<br>(hex) | Register name                                   | Width<br>(in bits) | Access                         | Reset value | Section/<br>page |
|------------------------------|-------------------------------------------------|--------------------|--------------------------------|-------------|------------------|
| FFFF_80C0                    | System Options Register 1 (SIM_SOPT1)           | 8                  | R/W                            | 80h         | 13.2.1/296       |
| FFFF_80C1                    | System Options Register 2 (SIM_SOPT2)           | 8                  | R/W                            | See section | 13.2.2/297       |
| FFFF_80C2                    | System Options Register 3 (SIM_SOPT3)           | 8                  | R/W                            | 00h         | 13.2.3/298       |
| FFFF_80C3                    | System Options Register 4 (SIM_SOPT4)           | 8                  | R/W                            | 10h         | 13.2.4/298       |
| FFFF_80C4                    | System Options Register 5 (SIM_SOPT5)           | 8                  | R/W                            | 02h         | 13.2.5/299       |
| FFFF_80C5                    | System Options Register 6 (SIM_SOPT6)           | 8                  | R/W                            | 00h         | 13.2.6/300       |
| FFFF_80C6                    | System Options Register 7 (SIM_SOPT7)           | 8                  | R/W                            | 00h         | 13.2.7/301       |
| FFFF_80CA                    | COP Control Register (SIM_COPC)                 | 8                  | R/W                            | 0Ch         | 13.2.8/302       |
| FFFF_80CB                    | Service COP Register (SIM_SRVCOP)               | 8                  | W<br>(always<br>reads<br>zero) | 00h         | 13.2.9/303       |
| FFFF_80CD                    | Oscillator 1 Control Register (SIM_OSC1)        | 8                  | R/W                            | 00h         | 13.2.10/<br>303  |
| FFFF_80D0                    | Device Identification High Register (SIM_SDIDH) | 8                  | R                              | 0Dh         | 13.2.11/<br>304  |
| FFFF_80D1                    | Device Identification Low Register (SIM_SDIDL)  | 8                  | R                              | 00h         | 13.2.12/<br>305  |
| FFFF_80D2                    | Clock Gate Control Register 1 (SIM_SCGC1)       | 8                  | R/W                            | 00h         | 13.2.13/<br>306  |
| FFFF_80D3                    | Clock Gate Control Register 2 (SIM_SCGC2)       | 8                  | R/W                            | 10h         | 13.2.14/<br>307  |
| FFFF_80D4                    | Clock Gate Control Register 3 (SIM_SCGC3)       | 8                  | R/W                            | 00h         | 13.2.15/<br>308  |
| FFFF_80D5                    | Clock Gate Control Register 4 (SIM_SCGC4)       | 8                  | R/W                            | 81h         | 13.2.16/<br>310  |
| FFFF_80D6                    | Clock Gate Control Register 5 (SIM_SCGC5)       | 8                  | R/W                            | 01h         | 13.2.17/<br>311  |
| FFFF_80D7                    | Clock Gate Control Register 6 (SIM_SCGC6)       | 8                  | R/W                            | 00h         | 13.2.18/<br>312  |
| FFFF_80DA                    | Clockout Register (SIM_CLKOUT)                  | 8                  | R/W                            | 07h         | 13.2.19/<br>313  |
| FFFF_80DB                    | Clock Divider 0 Register (SIM_CLKDIV0)          | 8                  | R/W                            | 00h         | 13.2.20/<br>314  |
| FFFF_80DC                    | Clock Divider 1 Register (SIM_CLKDIV1)          | 8                  | R/W                            | 00h         | 13.2.21/<br>315  |
| FFFF_80E0                    | Flash Configuration Register (SIM_SPCR)         | 8                  | R                              | See section | 13.2.22/<br>316  |
| FFFF_80E4                    | Unique Identification Register (SIM_UIDH3)      | 8                  | R                              | See section | 13.2.23/<br>317  |

Table continues on the next page...

#### **Chapter 13 System Integration Module (SIM)**

# SIM memory map (continued)

| Absolute address (hex) | Register name                               | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|------------------------|---------------------------------------------|--------------------|--------|-------------|------------------|
| FFFF_80E5              | Unique Identification Register (SIM_UIDH2)  | 8                  | R      | See section | 13.2.24/<br>317  |
| FFFF_80E6              | Unique Identification Register (SIM_UIDH1)  | 8                  | R      | See section | 13.2.25/<br>318  |
| FFFF_80E7              | Unique Identification Register (SIM_UIDH0)  | 8                  | R      | See section | 13.2.26/<br>318  |
| FFFF_80E8              | Unique Identification Register (SIM_UIDMH3) | 8                  | R      | See section | 13.2.27/<br>319  |
| FFFF_80E9              | Unique Identification Register (SIM_UIDMH2) | 8                  | R      | See section | 13.2.28/<br>319  |
| FFFF_80EA              | Unique Identification Register (SIM_UIDMH1) | 8                  | R      | See section | 13.2.29/<br>320  |
| FFFF_80EB              | Unique Identification Register (SIM_UIDMH0) | 8                  | R      | See section | 13.2.30/<br>320  |
| FFFF_80EC              | Unique Identification Register (SIM_UIDML3) | 8                  | R      | See section | 13.2.31/<br>321  |
| FFFF_80ED              | Unique Identification Register (SIM_UIDML2) | 8                  | R      | See section | 13.2.32/<br>321  |
| FFFF_80EE              | Unique Identification Register (SIM_UIDML1) | 8                  | R      | See section | 13.2.33/<br>322  |
| FFFF_80EF              | Unique Identification Register (SIM_UIDML0) | 8                  | R      | See section | 13.2.34/<br>322  |
| FFFF_80F0              | Unique Identification Register (SIM_UIDL3)  | 8                  | R      | See section | 13.2.35/<br>323  |
| FFFF_80F1              | Unique Identification Register (SIM_UIDL2)  | 8                  | R      | See section | 13.2.36/<br>323  |
| FFFF_80F2              | Unique Identification Register (SIM_UIDL1)  | 8                  | R      | See section | 13.2.37/<br>324  |
| FFFF_80F3              | Unique Identification Register (SIM_UIDL0)  | 8                  | R      | See section | 13.2.38/<br>324  |

# 13.2.1 System Options Register 1 (SIM\_SOPT1)

The following Reset row refers to Chip POR not VLLS. Only that type of reset, or any reset type that triggers Chip POR not VLLS, affects this register. Other reset types do not affect this register.

Address: SIM\_SOPT1 is FFFF\_80C0h base + 0h offset = FFFF\_80C0h



<sup>\*</sup> Notes:

### SIM\_SOPT1 field descriptions

| Field           | Description                                                                                                                                                            |
|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>REGE       | USB Voltage Regulator enable                                                                                                                                           |
|                 | This bit is writable when the SOPT3[RWE] bit is set.                                                                                                                   |
|                 | 0 USB VREG is disabled.                                                                                                                                                |
|                 | 1 USB VREG is enabled (reset value).                                                                                                                                   |
| 6<br>SSTB       | USB Voltage Regulator standby in stop modes                                                                                                                            |
| 3316            | This bit controls whether the USB VREG enters standby in stop, VLPS, LLS and VLLS modes. The bit is writable when the SOPT3[SWE] bit is set.                           |
|                 | <ul> <li>USB VREG does not enter standby in Stop, VLPS, LLS and VLLS modes (reset value)</li> <li>USB VREG enters standby in Stop, VLPS, LLS and VLLS modes</li> </ul> |
| 5               | USB Voltage Regulator standby in run/wait modes                                                                                                                        |
| VSTB            | This bit controls whether the USB VREG enters standby in VLPW and VLPR modes. The bit is writable when the SOPT3[SWE] bit is set.                                      |
|                 | 0 USB VREG does not enter standby in VLPW and VLPR modes (reset value)                                                                                                 |
|                 | 1 USB VREG enters standby in VLPW and VLPR modes                                                                                                                       |
| 4–2             | This bitfield is reserved.                                                                                                                                             |
| Reserved        | The value of each bit can be 0 or 1.                                                                                                                                   |
| 1–0<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                                     |

<sup>•</sup> Reserved bitfield:The value of each bit of this reserved field can be 0 or 1.

# 13.2.2 System Options Register 2 (SIM\_SOPT2)

The following Reset row refers to Chip POR not VLLS. Only that type of reset, or any reset type that triggers Chip POR not VLLS, affects this register. Other reset types do not affect this register.

Address: SIM\_SOPT2 is FFFF\_80C0h base + 1h offset = FFFF\_80C1h



<sup>\*</sup> Notes:

### SIM\_SOPT2 field descriptions

| Field           | Description                                                                                          |
|-----------------|------------------------------------------------------------------------------------------------------|
| 7–4<br>RAMSIZE  | Size of RAM array                                                                                    |
|                 | Specifies the amount of system RAM available on the device. Its reset value is loaded from IFR bits. |
|                 | 0000 Reserved                                                                                        |
|                 | 0001 8 KB                                                                                            |
|                 | 0010 Reserved                                                                                        |
|                 | 0011 16 KB                                                                                           |
|                 | 0100 Reserved                                                                                        |
|                 | 0101 32 KB                                                                                           |
|                 | Other Reserved                                                                                       |
| 3<br>Reserved   | This read-only bit is reserved and always has the value zero.                                        |
| 2–0<br>Reserved | This bitfield is reserved.                                                                           |

<sup>•</sup> x = Undefined at reset.

# 13.2.3 System Options Register 3 (SIM\_SOPT3)

The following Reset row refers to Chip Reset not VLLS. Only that type of reset, or any reset type that triggers Chip Reset not VLLS, affects this register. Other reset types do not affect this register.





### SIM\_SOPT3 field descriptions

| Field           | Description                                                                                                                                                                                                                                                                                                      |
|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–2<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                                                               |
| 1<br>SWE        | USB Standby write enable  Writing 1 to this bit allows the SSTB and VSTB bits in the SOPT1 register to be written. This bit clears after a write to SSTB, VSTB, or both (a simultaneous write to SSTB and VSTB is allowed).  O The SSTB and VSTB bits cannot be written.  The SSTB and VSTB bits can be written. |
| 0<br>RWE        | USB Voltage Regulator write enable  Writing 1 to this bit allows the REGE bit in the SOPT1 register to be written. This bit clears after a write to the REGE bit.  The REGE bit cannot be written.  The REGE bit can be written.                                                                                 |

# 13.2.4 System Options Register 4 (SIM\_SOPT4)

The following Reset row refers to Chip Reset not VLLS. Only that type of reset, or any reset type that triggers Chip Reset not VLLS, affects this register. Other reset types do not affect this register.

Address: SIM\_SOPT4 is FFFF\_80C0h base + 3h offset = FFFF\_80C3h



# SIM\_SOPT4 field descriptions

| Field           | Description                                                                                                                                                                                                                                                                                                    |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–6<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                                                             |
| 5<br>STOPE      | Stop mode enable  This bit can be written only once after each reset.  0 Disable entry to stop mode 1 Enable entry to stop mode                                                                                                                                                                                |
| 4<br>WAITE      | Wait mode enable  0 Disable entry to wait mode  1 Enable entry to wait mode                                                                                                                                                                                                                                    |
| 3–1<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                                                             |
| 0<br>VLLDBGREQ  | Very Low Leakage Debug Request upon Wakeup  This bit can be written through the BDM interface.  Wakeup from a VLLSx mode (except via the RESET pin) is via Chip POR into single chip mode (reset value)  Wakeup from a VLLSx mode (except via the RESET pin) is via Chip POR into active background debug mode |

# 13.2.5 System Options Register 5 (SIM\_SOPT5)

Address: SIM\_SOPT5 is FFFF\_80C0h base + 4h offset = FFFF\_80C4h



### SIM\_SOPT5 field descriptions

| Field           | Description                                                                                                      |
|-----------------|------------------------------------------------------------------------------------------------------------------|
| 7–4<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                               |
| 3–2<br>MECS     | MTIM16 external clock source select  00 TMR_CLKIN0 (reset value)  01 TMR_CLKIN1  10 FTM0 Ch1 Out  11 FTM1Ch1 Out |

Table continues on the next page...

#### **Memory Map and Registers**

# SIM\_SOPT5 field descriptions (continued)

| Field      | Description                |
|------------|----------------------------|
| 1<br>F1ECS | FTM1 external clock select |
|            | 0 TMR_CLKIN0               |
|            | 1 TMR_CLKIN1 (reset value) |
| 0<br>F0ECS | FTM0 external clock select |
| . 0200     | 0 TMR_CLKIN0 (reset value) |
|            | 1 TMR_CLKIN1               |

# 13.2.6 System Options Register 6 (SIM\_SOPT6)

Address: SIM\_SOPT6 is FFFF\_80C0h base + 5h offset = FFFF\_80C5h



# SIM\_SOPT6 field descriptions

| Field          | Description                                                                                                                                                                   |
|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–6<br>MBSL    | Mini-FlexBus security level                                                                                                                                                   |
| BGE            | If flash security is enabled, this field affects what CPU operations can access off-chip via the Mini-FlexBus interface. This field has no effect if security is not enabled. |
|                | 0x All off-chip accesses (opcode and data) by the Mini-FlexBus are disallowed (reset value: 00)                                                                               |
|                | 10 Off-chip opcode accesses are disallowed. Data accesses are allowed.                                                                                                        |
|                | 11 Off-chip op code accesses and data accesses are allowed.                                                                                                                   |
| 5–4<br>MTBASE1 | UART1 TX modulation time base select                                                                                                                                          |
|                | 00 FTM0 Ch0 (reset value)                                                                                                                                                     |
|                | 01 FTM0 Ch1                                                                                                                                                                   |
|                | 10 FTM1 Ch0                                                                                                                                                                   |
|                | 11 MTIM                                                                                                                                                                       |
| 3<br>RX1IN     | UART1 RX input pin selection                                                                                                                                                  |
|                | 0 RX1 is fed from the digital input pin (assuming the RX1 is enabled on that pin via the mux pin registers) (reset value)                                                     |
|                | 1 RX1 is fed from the CMP output                                                                                                                                              |
| 2<br>MODTX1    | Modulate T                                                                                                                                                                    |
|                | 0 Do not modulate the output of UART1 (reset value)                                                                                                                           |
|                | 1 Modulate the output of UART1 with the timebase selected via the MTBASE1 field                                                                                               |

Table continues on the next page...

# SIM\_SOPT6 field descriptions (continued)

| Field        | Description                                                                                   |
|--------------|-----------------------------------------------------------------------------------------------|
| 1<br>PTF6PAD | PTF6 double pad strength  0 Standard drive strength (reset value)                             |
|              | 1 High drive strength                                                                         |
| 0<br>PTC5PAD | PTC5 pad double pad strength                                                                  |
|              | Controls the output drive strength of PTC5 by selecting either one or two pads to drive it.   |
|              | <ul><li>0 Single-pad drive strength (reset value)</li><li>1 Dual-pad drive strength</li></ul> |

# 13.2.7 System Options Register 7 (SIM\_SOPT7)

Address: SIM\_SOPT7 is FFFF\_80C0h base + 6h offset = FFFF\_80C6h



### SIM\_SOPT7 field descriptions

| Field       | Description                                                                                                                                                                                                                                                                 |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>USBBE  | USB Byte-swap Enable                                                                                                                                                                                                                                                        |
|             | Enables byte swapping for all USB master accesses via the crossbar (swaps [31:24] with [7:0] and swaps [23:16] with [15:8]). Byte swapping affects all USB read data, USB write data, and USB BD accesses. This enable bit should only be written when the USB is disabled. |
|             | 0 Byte-swap disabled (reset value)                                                                                                                                                                                                                                          |
|             | 1 Byte-swap enabled                                                                                                                                                                                                                                                         |
| 6<br>ADTRGS | ADC hardware trigger source                                                                                                                                                                                                                                                 |
|             | 0 PDB (reset value)                                                                                                                                                                                                                                                         |
|             | 1 LPTMR0 (trigger ADCSC1A only)                                                                                                                                                                                                                                             |
| 5<br>ACFTM  | CMP output connection to FTM0 Ch0                                                                                                                                                                                                                                           |
|             | 0 CMP Output disconnected to FTM0 Ch0 (reset value)                                                                                                                                                                                                                         |
|             | 1 CMP Output connected to FTM0 Ch0                                                                                                                                                                                                                                          |
| 4<br>I2CDR2 | I2C Link for I2C2 and I2C3                                                                                                                                                                                                                                                  |
|             | 0 I2C2 and I2C3 operate in their respective pins (reset value)                                                                                                                                                                                                              |
|             | 1 I2C2 and I2C3 have their pins are connected internally                                                                                                                                                                                                                    |
| 3<br>I2CDR0 | I2C Link for I2C0 and I2C1                                                                                                                                                                                                                                                  |

Table continues on the next page...

#### **Memory Map and Registers**

# SIM\_SOPT7 field descriptions (continued)

| Field    | Description                                                    |
|----------|----------------------------------------------------------------|
|          | 0 I2C0 and I2C1 operate in their respective pins (reset value) |
|          | 1 I2C0 and I2C1 have their pins are connected internally       |
| 2        | This read-only bit is reserved and always has the value zero.  |
| Reserved |                                                                |
| 1        | FTM1 synchronization trigger                                   |
| FTM1SYNC |                                                                |
|          | 0 No trigger generated. (reset value)                          |
|          | 1 Generate a PWM synchronization trigger to the FTM1 modules.  |
| 0        | FTM0 synchronization trigger                                   |
| FTM0SYNC |                                                                |
|          | 0 No trigger generated. (reset value).                         |
|          | 1 Generate a PWM synchronization trigger to the FTM0 module.   |

# 13.2.8 COP Control Register (SIM\_COPC)

All of the bits in this register can be written only once after a reset.

The following table summarizes the control functions of this register's bitfields for COP clock selection, windowed mode, and timeout count.

| Control Bits  |            | - Clock Source | COP Window Opens | COP Overflow Count                              |
|---------------|------------|----------------|------------------|-------------------------------------------------|
| COPC[COPCLKS] | COPC[COPT] | Clock Source   | (COPC[COPW] = 1) | COP Overnow Count                               |
| N/A           | 00         | N/A            | N/A              | COP is disabled                                 |
| 0             | 01         | 1 kHz          | N/A              | 2 <sup>5</sup> cycles (32 ms <sup>-</sup> )     |
| 0             | 10         | 1 kHz          | N/A              | 28 cycles (256 ms.)                             |
| 0             | 11         | 1 kHz          | N/A              | 2 <sup>10</sup> cycles (1,024 ms <sup>-</sup> ) |
| 1             | 01         | Bus            | 6,144 cycles     | 2 <sup>13</sup> cycles                          |
| 1             | 10         | Bus            | 49,152 cycles    | 2 <sup>16</sup> cycles                          |
| 1             | 11         | Bus            | 196,608 cycles   | 2 <sup>18</sup> cycles                          |

Address: SIM\_COPC is FFFF\_80C0h base + Ah offset = FFFF\_80CAh



# SIM\_COPC field descriptions

| Field           | Description                                                                                                                                                                         |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–4<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                                                  |
| 3–2<br>COPT     | COP watchdog timeout  These write-once bits select the timeout period of the COP. The COPT field along with the COPCLKS bit define the COP timeout period.                          |
| 1<br>COPCLKS    | COP watchdog clock select  This write-once bit selects the clock source of the COP watchdog.  0 Internal 1 kHz clock is source to COP (reset value).  1 Bus clock is source to COP. |
| 0<br>COPW       | COP windowed mode  0 Normal mode (reset value).  1 Windowed mode.                                                                                                                   |

# 13.2.9 Service COP Register (SIM\_SRVCOP)

Address: SIM\_SRVCOP is FFFF\_80C0h base + Bh offset = FFFF\_80CBh



### SIM\_SRVCOP field descriptions

| Field         | Description                      |
|---------------|----------------------------------|
| 7–0<br>SRVCOP | Refer to COP watchdog operation. |

# 13.2.10 Oscillator 1 Control Register (SIM\_OSC1)

Controls the OSC1 crystal oscillator.

Address: SIM\_OSC1 is FFFF\_80C0h base + Dh offset = FFFF\_80CDh



#### **Memory Map and Registers**

### SIM\_OSC1 field descriptions

| Field            | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 7<br>OSC1EN      | Oscillator 1 enable  Enables oscillator 1.  0 Oscillator 1 inactive.  1 Oscillator 1 active.                                                                                                                                                                                                                                                                                                                                                                                   |  |  |
| 6<br>Reserved    | This read-only bit is reserved and always has the value zero.                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |
| 5<br>Reserved    | This read-only bit is reserved and always has the value zero.                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |
| 4–3<br>OSC1RANGE | Frequency range select  Selects the frequency range for the crystal oscillator or external clock source. For details, refer to the OSC chapter.  00 Encoding 0: Low frequency range for the crystal oscillator of 32 kHz to 40 kHz (reset default).  01 Encoding 1: High frequency range selected for the crystal oscillator of 1 MHz to 8 MHz.  1x Encoding 2: Very high frequency range selected for the crystal oscillator of 8 MHz to 32 MHz.  High gain oscillator select |  |  |
| OSC1HGO          | Controls the crystal oscillator mode of operation. For details, refer to the OSC chapter.  Configure crystal oscillator for low-power operation.  Configure crystal oscillator for high-gain operation.                                                                                                                                                                                                                                                                        |  |  |
| 1<br>OSC1EREFS   | External reference select  Selects the source for the external reference clock. Refer to the OSC chapter for details.  0 External reference clock requested.  1 Oscillator requested.                                                                                                                                                                                                                                                                                          |  |  |
| 0<br>Reserved    | This read-only bit is reserved and always has the value zero.                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |

# 13.2.11 Device Identification High Register (SIM\_SDIDH)

Together, the SDIDH and SDIDL registers contain the 12 ID bits that specify the device identification number set by the IFR bits.

For a definition of the bit encodings for the ID bits in these registers, see the bit encodings for the SDIDL register.

### **NOTE**

The following Reset row refers to Chip POR. Only that type of reset, or any reset type that triggers Chip POR, affects this register. Other reset types do not affect this register.

Address: SIM\_SDIDH is FFFF\_80C0h base + 10h offset = FFFF\_80D0h



### SIM\_SDIDH field descriptions

| Field           | Description                                                                                                                                                           |
|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–4<br>REV      | Device Revision Number                                                                                                                                                |
|                 | Specifies the silicon implementation number for the device. This value comes from plugs, not IFR bits.                                                                |
| 3–0<br>ID[11:8] | Device identification number                                                                                                                                          |
|                 | Specifies the device identification number as set by the IFR bits. For information about the bit encodings for this field, see the description of the SDIDL register. |

# 13.2.12 Device Identification Low Register (SIM\_SDIDL)

Together, the SDIDH and SDIDL registers contain the 12 ID bits that specify the device identification number set by the IFR bits, whose values replace the default reset values. The bit encodings for all 12 ID bits correspond to the three LSBs in the IFR, which is a range from D01h to D07h (110100000001b to 1101000000111b).

### **NOTE**

The following Reset row refers to Chip POR. Only that type of reset, or any reset type that triggers Chip POR, affects this register. Other reset types do not affect this register.

Address: SIM\_SDIDL is FFFF\_80C0h base + 11h offset = FFFF\_80D1h



<sup>\*</sup> Notes:

• ID[7:0] bitfield:Refer to this bitfield's description for its value, which is set by IFR bits.

### SIM\_SDIDL field descriptions

| Field   | Description                                                                                                                                                                                                  |
|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ID[7:0] | Device identification number                                                                                                                                                                                 |
|         | Specifies the device identification number as set by the IFR bits, whose values replace the default reset values. The bit encodings for bits 2-0 specify the ColdFire+ family of which the chip is a member. |

#### **Memory Map and Registers**

# SIM\_SDIDL field descriptions (continued)

| Field |          |          | Description |
|-------|----------|----------|-------------|
|       | 00000001 | MCF51JF  |             |
|       | 00000010 | MCF51JU  |             |
|       | 00000011 | MCF51QM  |             |
|       | 00000100 | MCF51QH  |             |
|       | 00000101 | MCF51QF  |             |
|       | 00000110 | MCF51QU  |             |
|       | 00000111 | Reserved |             |

# 13.2.13 Clock Gate Control Register 1 (SIM\_SCGC1)

Each bit in SCGC1 controls the clock gate to its respective module.

Address: SIM\_SCGC1 is FFFF\_80C0h base + 12h offset = FFFF\_80D2h



# SIM\_SCGC1 field descriptions

| Field     | Description                                 |
|-----------|---------------------------------------------|
| 7<br>I2C3 | I2C3 clock gate control                     |
|           | Controls the clock gate to the I2C3 module. |
|           | 0 The clock to the module is disabled.      |
|           | 1 The clock to the module is enabled.       |
| 6<br>I2C2 | I2C2 clock gate control                     |
|           | Controls the clock gate to the I2C2 module. |
|           | 0 The clock to the module is disabled.      |
|           | 1 The clock to the module is enabled.       |
| 5<br>I2C1 | I2C1 clock gate control                     |
| 1201      | Controls the clock gate to the I2C1 module. |
|           | 0 The clock to the module is disabled       |
|           | 1 The clock to the module is enabled.       |
| 4         | I2C0 clock gate control                     |
| I2C0      | Controls the clock gate to the I2C0 module. |

Table continues on the next page...

### SIM\_SCGC1 field descriptions (continued)

| Field      | Description                                  |  |  |
|------------|----------------------------------------------|--|--|
|            | 0 The clock to the module is disabled.       |  |  |
|            | 1 The clock to the module is enabled.        |  |  |
| 3<br>SPI1  | SPI1 clock gate control                      |  |  |
|            | Controls the clock gate to the SPI1 module.  |  |  |
|            | 0 The clock to the module is disabled.       |  |  |
|            | 1 The clock to the module is enabled.        |  |  |
| 2<br>SPI0  | SPI0 clock gate control                      |  |  |
|            | Controls the clock gate to the SPI0 module.  |  |  |
|            | 0 The clock to the module is disabled.       |  |  |
|            | 1 The clock to the module is enabled.        |  |  |
| 1<br>UART1 | UART1 clock gate control                     |  |  |
| 0/4111     | Controls the clock gate to the UART1 module. |  |  |
|            | 0 The clock to the module is disabled.       |  |  |
|            | 1 The clock to the module is enabled.        |  |  |
| 0<br>UART0 | UART0 clock gate control                     |  |  |
| <b>5</b> 7 | Controls the clock gate to the UART0 module. |  |  |
|            | 0 The clock to the module is disabled.       |  |  |
|            | 1 The clock to the module is enabled.        |  |  |

# 13.2.14 Clock Gate Control Register 2 (SIM\_SCGC2)

Each bit in SCGC2 controls the clock gate to its respective module.

Address: SIM\_SCGC2 is FFFF\_80C0h base + 13h offset = FFFF\_80D3h



### SIM\_SCGC2 field descriptions

| Field | Description                                |
|-------|--------------------------------------------|
| 7     | I2S clock gate control                     |
| I2S   | Controls the clock gate to the I2S module. |

Table continues on the next page...

#### **Memory Map and Registers**

# SIM\_SCGC2 field descriptions (continued)

| Field           | Description                                                        |
|-----------------|--------------------------------------------------------------------|
|                 | 0 The clock to the module is disabled.                             |
|                 | 1 The clock to the module is enabled.                              |
| 6               | ANL clock gate control                                             |
| ANL             | Controls the clock gate to the ANL module.                         |
|                 | 0 The clock to the module is disabled.                             |
|                 | 1 The clock to the module is enabled.                              |
| 5<br>TSI        | TSI clock gate control                                             |
| 1.01            | Controls the clock gate to the TSI module.                         |
|                 | 0 The clock to the module is disabled                              |
|                 | 1 The clock to the module is enabled.                              |
| 4<br>VREF       | VREF clock gate control                                            |
|                 | Controls the clock gate to the VREF module.                        |
|                 | 0 The clock to the module is disabled.                             |
|                 | 1 The clock to the module is enabled.                              |
| 3–2<br>Reserved | This read-only bitfield is reserved and always has the value zero. |
| 1<br>ADC        | ADC clock gate control                                             |
| ADO             | Controls the clock gate to the ADC module.                         |
|                 | 0 The clock to the module is disabled.                             |
|                 | 1 The clock to the module is enabled.                              |
| 0<br>DAC12B     | 12-bit DAC clock gate control                                      |
|                 | Controls the clock gate to the 12-bit DAC module.                  |
|                 | 0 The clock to the module is disabled.                             |
|                 | 1 The clock to the module is enabled.                              |

# 13.2.15 Clock Gate Control Register 3 (SIM\_SCGC3)

Each bit in SCGC3 controls the clock gate to its respective module.

Address: SIM\_SCGC3 is FFFF\_80C0h base + 14h offset = FFFF\_80D4h



# SIM\_SCGC3 field descriptions

| Field           | Description                                 |
|-----------------|---------------------------------------------|
| 7<br>CRC        | CRC clock gate control                      |
| CHC             | Controls the clock gate to the CRC module.  |
|                 | 0 The clock to the module is disabled.      |
|                 | 1 The clock to the module is enabled.       |
| 6<br>PDB        | PDB clock gate control                      |
| FDB             | Controls the clock gate to the PDB module.  |
|                 | 0 The clock to the module is disabled.      |
|                 | 1 The clock to the module is enabled.       |
| 5<br>CMT        | CMT clock gate control                      |
| Civi i          | Controls the clock gate to the CMT module.  |
|                 | 0 The clock to the module is disabled.      |
|                 | 1 The clock to the module is enabled.       |
| 4<br>MTIM       | MTIM clock gate control                     |
| IVITIVI         | Controls the clock gate to the MTIM module. |
|                 | 0 The clock to the module is disabled.      |
|                 | 1 The clock to the module is enabled.       |
| 3<br>FTM1       | FTM1 clock gate control                     |
| FINI            | Controls the clock gate to the FTM1 module. |
|                 | 0 The clock to the module is disabled.      |
|                 | 1 The clock to the module is enabled.       |
| 2<br>FTM0       | FTM0 clock gate control                     |
| 1 TIVIO         | Controls the clock gate to the FTM0 module. |
|                 | 0 The clock to the module is disabled.      |
|                 | 1 The clock to the module is enabled.       |
| 1–0<br>Reserved | This bitfield is reserved.                  |

# 13.2.16 Clock Gate Control Register 4 (SIM\_SCGC4)

Each bit in SCGC4 controls the clock gate to its respective module.

Address: SIM\_SCGC4 is FFFF\_80C0h base + 15h offset = FFFF\_80D5h



### SIM\_SCGC4 field descriptions

| Field           | Description                                                                                                                                                                                                                                                                                                                                                    |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>FTFL       | FTFL clock gate control  Controls the clock gate to the FTFL module.                                                                                                                                                                                                                                                                                           |
|                 | <ul><li>The clock to the module is disabled.</li><li>The clock to the module is enabled.</li></ul>                                                                                                                                                                                                                                                             |
| 6–4<br>Reserved | This bitfield is reserved.                                                                                                                                                                                                                                                                                                                                     |
| 3<br>DMA        | DMA clock gate control  Controls the clock gate to the DMA module.  0 The clock to the module is disabled.  1 The clock to the module is enabled.                                                                                                                                                                                                              |
| 2<br>Reserved   | This bit is reserved.                                                                                                                                                                                                                                                                                                                                          |
| 1<br>IRQ        | IRQ clock gate control  Controls the clock gate to the IRQ module.  The clock to the module is disabled.  The clock to the module is enabled.                                                                                                                                                                                                                  |
| 0<br>WDOG       | COP clock gate control  Controls the bus clock gate to the COP module.  CAUTION: If the COP is using the bus clock and is enabled and counting, and then the bus clock to the COP is disabled:  • The COP cannot be serviced.  • The COP will still time out and cause a reset.  O The clock to the module is disabled.  1 The clock to the module is enabled. |

# 13.2.17 Clock Gate Control Register 5 (SIM\_SCGC5)

Each bit in SCGC5 controls the clock gate to its respective module.

Address: SIM\_SCGC5 is FFFF\_80C0h base + 16h offset = FFFF\_80D6h



### SIM\_SCGC5 field descriptions

| Field           | Description                                                                                                                                     |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>RNGB       | RNGB clock gate control  Controls the clock gate to the RNGB module.                                                                            |
|                 | <ul><li>The clock to the module is disabled.</li><li>The clock to the module is enabled.</li></ul>                                              |
| 6<br>MFBUS      | MFBUS clock gate control  Controls the clock gate to the MFBUS module.                                                                          |
|                 | 0 The clock to the module is disabled. 1 The clock to the module is enabled.                                                                    |
| 5–3<br>Reserved | This bitfield is reserved.                                                                                                                      |
| 2<br>OSC2       | OSC2 clock gate control  Controls the clock gate to the OSC2 module.  The clock to the module is disabled.  The clock to the module is enabled. |
| 1<br>OSC1       | OSC1 clock gate control  Controls the clock gate to the OSC1 module.  The clock to the module is disabled.  The clock to the module is enabled. |
| 0<br>MCG        | MCG clock gate control  Controls the clock gate to the MCG module.  0 The clock to the module is disabled.                                      |
|                 | 1 The clock to the module is enabled.                                                                                                           |

# 13.2.18 Clock Gate Control Register 6 (SIM\_SCGC6)

Each bit in SCGC6 controls the clock gate to its respective module.

Address: SIM\_SCGC6 is FFFF\_80C0h base + 17h offset = FFFF\_80D7h



### SIM\_SCGC6 field descriptions

| Field       | Description                                   |
|-------------|-----------------------------------------------|
| 7           | USBOTG clock gate control                     |
| USBOTG      | Controls the clock gate to the USBOTG module. |
|             | 0 The clock to the module is disabled.        |
|             | 1 The clock to the module is enabled.         |
| 6<br>USBDCD | USBDCD clock gate control                     |
| 000000      | Controls the clock gate to the USBDCD module. |
|             | 0 The clock to the module is disabled.        |
|             | 1 The clock to the module is enabled.         |
| 5<br>PORTF  | Port F clock gate control                     |
| PORTE       | Controls the clock gate to the Port F module. |
|             | 0 The clock to the module is disabled.        |
|             | 1 The clock to the module is enabled.         |
| 4<br>PORTE  | Port E clock gate control                     |
|             | Controls the clock gate to the Port E module. |
|             | 0 The clock to the module is disabled.        |
|             | 1 The clock to the module is enabled.         |
| 3<br>PORTD  | Port D clock gate control                     |
|             | Controls the clock gate to the Port D module. |
|             | 0 The clock to the module is disabled.        |
|             | 1 The clock to the module is enabled.         |
| 2<br>PORTC  | Port C clock gate control                     |
|             | Controls the clock gate to the Port C module. |
|             | 0 The clock to the module is disabled.        |
|             | 1 The clock to the module is enabled          |

Table continues on the next page...

# SIM\_SCGC6 field descriptions (continued)

| Field      | Description                                   |
|------------|-----------------------------------------------|
| 1<br>PORTB | Port B clock gate control                     |
|            | Controls the clock gate to the Port B module. |
|            | 0 The clock to the module is disabled.        |
|            | 1 The clock to the module is enabled          |
| 0<br>PORTA | Port A clock gate control                     |
| 1 511111   | Controls the clock gate to the Port A module. |
|            | 0 The clock to the module is disabled.        |
|            | 1 The clock to the module is enabled.         |

# 13.2.19 Clockout Register (SIM\_CLKOUT)

Address: SIM\_CLKOUT is FFFF\_80C0h base + 1Ah offset = FFFF\_80DAh



### SIM\_CLKOUT field descriptions

| Field            | Description                                                   |
|------------------|---------------------------------------------------------------|
| 7<br>Reserved    | This read-only bit is reserved and always has the value zero. |
| 6–4<br>CS        | CLKOUT pin clock select                                       |
|                  | 000 Disabled (reset value)                                    |
|                  | 001 OSC1                                                      |
|                  | 010 OSC2                                                      |
|                  | 011 MCGOUT                                                    |
|                  | 100 CPUCLK                                                    |
|                  | 101 BUSCLK (Note: For PTB1, BUSCLK can be used as FB_CLKOUT.) |
|                  | 110 LPOCLK                                                    |
|                  | 111 LPTMR0 OUT                                                |
| 3<br>Reserved    | This read-only bit is reserved and always has the value zero. |
| 2–0<br>CLKOUTDIV | Division of the CLKOUT pin                                    |
|                  | 000 Division by 1                                             |
|                  | 001 Division by 2                                             |
|                  | 010 Division by 4                                             |

Table continues on the next page...

#### **Memory Map and Registers**

### SIM\_CLKOUT field descriptions (continued)

| Field | Description                       |
|-------|-----------------------------------|
|       | 011 Division by 8                 |
|       | 100 Division by 16                |
|       | 101 Division by 32                |
|       | 110 Division by 64                |
|       | 111 Division by 128 (reset value) |

# 13.2.20 Clock Divider 0 Register (SIM\_CLKDIV0)

The following Reset row refers to Chip POR. Only that type of reset, or any reset type that triggers Chip POR, affects this register. Other reset types do not affect this register.

Address: SIM\_CLKDIV0 is FFFF\_80C0h base + 1Bh offset = FFFF\_80DBh



- \* Notes:
- OUTDIV bitfield:At end of reset, loaded with either 0000 or 1111 depending on flash option register bit 0 (FOPT[0])

### SIM\_CLKDIV0 field descriptions

| Field           | Description                                                                                                                  |
|-----------------|------------------------------------------------------------------------------------------------------------------------------|
| 7–4<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                           |
| 3–0             | Clock output divider value to generate CPU clock                                                                             |
| OUTDIV          | Sets the divide value for the core/system clock.                                                                             |
|                 | NOTE: At the end of reset, this field is loaded with either 0000 or 1111 depending on flash option register bit 0 (FOPT[0]). |
|                 | Restriction: This bitfield cannot be changed when the MCU is in a VLPx mode.                                                 |
|                 | Restriction: The CPU clock should never exceed 50 MHz.                                                                       |
|                 | 0000 Divide-by-1                                                                                                             |
|                 | 0001 Divide-by-2                                                                                                             |
|                 | 0010 Divide-by-3                                                                                                             |
|                 | 0011 Divide-by-4                                                                                                             |
|                 | 0100 Divide-by-5                                                                                                             |
|                 | 0101 Divide-by-6                                                                                                             |
|                 | 0110 Divide-by-7                                                                                                             |
|                 | 0111 Divide-by-8                                                                                                             |
|                 | 1000 Divide-by-9                                                                                                             |
|                 | 1001 Divide-by-10                                                                                                            |

Table continues on the next page...

# SIM\_CLKDIV0 field descriptions (continued)

| Field | Description       |  |
|-------|-------------------|--|
|       | 1010 Divide-by-11 |  |
|       | 1011 Divide-by-12 |  |
|       | 1100 Divide-by-13 |  |
|       | 1101 Divide-by-14 |  |
|       | 1110 Divide-by-15 |  |
|       | 1111 Divide-by-16 |  |

# 13.2.21 Clock Divider 1 Register (SIM\_CLKDIV1)

Address: SIM\_CLKDIV1 is FFFF\_80C0h base + 1Ch offset = FFFF\_80DCh



# SIM\_CLKDIV1 field descriptions

| Field           | Description                                                                                                                                                                                                                                                      |
|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–5<br>USBDIV   | USB clock divider divisor                                                                                                                                                                                                                                        |
|                 | Sets the divide value for the fractional clock divider used as a source for the USB clock. The source clock for the fractional clock divider is set by the USBSRC register bit. Divider output clock = Divider input clock * ( (USBFRAC+1) / (USBDIV+1) ).       |
| 4<br>USBFRAC    | USB clock divider fraction                                                                                                                                                                                                                                       |
| OGBITING        | Sets the fraction multiply value for the fractional clock divider used as a source for USB clock. The source clock for the fractional clock divider is set by the USBSRC register bit. Divider output clock = Divider input clock * ( (USBFRAC+1) / (USBDIV+1) ) |
| 3–2<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                               |
| 1–0<br>USBSRC   | USB clock source select                                                                                                                                                                                                                                          |
| 0020110         | 00 Divided PLL (reset value)                                                                                                                                                                                                                                     |
|                 | 01 Divided FLL                                                                                                                                                                                                                                                   |
|                 | 10 USB CLK pin                                                                                                                                                                                                                                                   |
|                 | 11 Reserved                                                                                                                                                                                                                                                      |

# 13.2.22 Flash Configuration Register (SIM\_SPCR)

The following Reset row refers to Chip POR. Only that type of reset, or any reset type that triggers Chip POR, affects this register. Other reset types do not affect this register.

Address: SIM\_SPCR is FFFF\_80C0h base + 20h offset = FFFF\_80E0h



<sup>\*</sup> Notes:

### SIM\_SPCR field descriptions

| Field          | Description                                                                      |
|----------------|----------------------------------------------------------------------------------|
| 7–4<br>NVMSIZE | FlexNVM size                                                                     |
|                | This field specifies the amount of FlexNVM available on the device.              |
|                | 0000 Reserved                                                                    |
|                | 0001 16 KB of FlexNVM, 2 KB protection region                                    |
|                | 0010 Reserved                                                                    |
|                | 0011 32 KB of FlexNVM, 4 KB protection region                                    |
|                | x1xx Reserved                                                                    |
| 3–0<br>PFSIZE  | Program flash size                                                               |
|                | This field specifies the amount of program flash memory available on the device. |
|                | 0000 Reserved                                                                    |
|                | 0001 Reserved                                                                    |
|                | 0010 Reserved                                                                    |
|                | 0011 32 KB of program flash memory, 1 KB protection region                       |
|                | 0100 Reserved                                                                    |
|                | 0101 64 KB of program flash memory, 2 KB protection region                       |
|                | 0110 Reserved                                                                    |
|                | 0111 128 KB of program flash memory, 4 KB protection region                      |
|                | 1xxx Reserved                                                                    |

<sup>•</sup> x = Undefined at reset.

# 13.2.23 Unique Identification Register (SIM\_UIDH3)

The following Reset row refers to Chip POR. Only that type of reset, or any reset type that triggers Chip POR, affects this register. Other reset types do not affect this register.

Address: SIM\_UIDH3 is FFFF\_80C0h base + 24h offset = FFFF\_80E4h



- \* Notes:
- x = Undefined at reset.

### SIM\_UIDH3 field descriptions

| Field               | Description                                                                        |
|---------------------|------------------------------------------------------------------------------------|
| 7–0<br>UID[127:120] | Unique identification                                                              |
|                     | Provides unique identification for the device. These bits are set by the IFR bits. |

# 13.2.24 Unique Identification Register (SIM\_UIDH2)

The following Reset row refers to Chip POR. Only that type of reset, or any reset type that triggers Chip POR, affects this register. Other reset types do not affect this register.

Address: SIM\_UIDH2 is FFFF\_80C0h base + 25h offset = FFFF\_80E5h



- \* Notes:
- x = Undefined at reset.

# SIM\_UIDH2 field descriptions

| Field        | Description                                                                        |
|--------------|------------------------------------------------------------------------------------|
| 7–0          | Unique identification                                                              |
| UID[119:112] | Provides unique identification for the device. These bits are set by the IFR bits. |

# 13.2.25 Unique Identification Register (SIM\_UIDH1)

The following Reset row refers to Chip POR. Only that type of reset, or any reset type that triggers Chip POR, affects this register. Other reset types do not affect this register.

Address: SIM\_UIDH1 is FFFF\_80C0h base + 26h offset = FFFF\_80E6h



- \* Notes:
- x = Undefined at reset.

### SIM\_UIDH1 field descriptions

| Field               | Description                                                                        |
|---------------------|------------------------------------------------------------------------------------|
| 7–0<br>UID[111:104] | Unique identification                                                              |
|                     | Provides unique identification for the device. These bits are set by the IFR bits. |

# 13.2.26 Unique Identification Register (SIM\_UIDH0)

The following Reset row refers to Chip POR. Only that type of reset, or any reset type that triggers Chip POR, affects this register. Other reset types do not affect this register.

Address: SIM\_UIDH0 is FFFF\_80C0h base + 27h offset = FFFF\_80E7h



- \* Notes:
- x = Undefined at reset.

# SIM\_UIDH0 field descriptions

| Field       | Description                                                                        |
|-------------|------------------------------------------------------------------------------------|
| 7–0         | Unique identification                                                              |
| UID[103:96] | Provides unique identification for the device. These bits are set by the IFR bits. |

# 13.2.27 Unique Identification Register (SIM\_UIDMH3)

The following Reset row refers to Chip POR. Only that type of reset, or any reset type that triggers Chip POR, affects this register. Other reset types do not affect this register.

Address: SIM\_UIDMH3 is FFFF\_80C0h base + 28h offset = FFFF\_80E8h



- \* Notes:
- x = Undefined at reset.

### SIM\_UIDMH3 field descriptions

| Field             | Description                                                                        |
|-------------------|------------------------------------------------------------------------------------|
| 7–0<br>UID[95:88] | Unique identification                                                              |
|                   | Provides unique identification for the device. These bits are set by the IFR bits. |

# 13.2.28 Unique Identification Register (SIM\_UIDMH2)

The following Reset row refers to Chip POR. Only that type of reset, or any reset type that triggers Chip POR, affects this register. Other reset types do not affect this register.

Address: SIM\_UIDMH2 is FFFF\_80C0h base + 29h offset = FFFF\_80E9h



- \* Notes:
- x = Undefined at reset.

#### SIM UIDMH2 field descriptions

| Field             | Description                                                                        |
|-------------------|------------------------------------------------------------------------------------|
| 7–0<br>UID[87:80] | Unique identification                                                              |
|                   | Provides unique identification for the device. These bits are set by the IFR bits. |

# 13.2.29 Unique Identification Register (SIM\_UIDMH1)

The following Reset row refers to Chip POR. Only that type of reset, or any reset type that triggers Chip POR, affects this register. Other reset types do not affect this register.

Address: SIM\_UIDMH1 is FFFF\_80C0h base + 2Ah offset = FFFF\_80EAh



- \* Notes:
- x = Undefined at reset.

### SIM\_UIDMH1 field descriptions

| Field             | Description                                                                        |
|-------------------|------------------------------------------------------------------------------------|
| 7–0<br>UID[79:72] | Unique identification                                                              |
| 0.5[70.72]        | Provides unique identification for the device. These bits are set by the IFR bits. |

# 13.2.30 Unique Identification Register (SIM\_UIDMH0)

The following Reset row refers to Chip POR. Only that type of reset, or any reset type that triggers Chip POR, affects this register. Other reset types do not affect this register.

Address: SIM\_UIDMH0 is FFFF\_80C0h base + 2Bh offset = FFFF\_80EBh



- \* Notes:
- x = Undefined at reset.

### SIM\_UIDMH0 field descriptions

| Field             | Description                                                                        |
|-------------------|------------------------------------------------------------------------------------|
| 7–0<br>UID[71:64] | Unique identification                                                              |
|                   | Provides unique identification for the device. These bits are set by the IFR bits. |

# 13.2.31 Unique Identification Register (SIM\_UIDML3)

The following Reset row refers to Chip POR. Only that type of reset, or any reset type that triggers Chip POR, affects this register. Other reset types do not affect this register.

Address: SIM\_UIDML3 is FFFF\_80C0h base + 2Ch offset = FFFF\_80ECh



- \* Notes:
- x = Undefined at reset.

### SIM\_UIDML3 field descriptions

| Field             | Description                                                                        |
|-------------------|------------------------------------------------------------------------------------|
| 7–0<br>UID[63:56] | Unique identification                                                              |
|                   | Provides unique identification for the device. These bits are set by the IFR bits. |

# 13.2.32 Unique Identification Register (SIM\_UIDML2)

The following Reset row refers to Chip POR. Only that type of reset, or any reset type that triggers Chip POR, affects this register. Other reset types do not affect this register.

Address: SIM\_UIDML2 is FFFF\_80C0h base + 2Dh offset = FFFF\_80EDh



- \* Notes:
- x = Undefined at reset.

# SIM\_UIDML2 field descriptions

| Field             | Description                                                                        |
|-------------------|------------------------------------------------------------------------------------|
| 7–0<br>UID[55:48] | Unique identification                                                              |
| UID[55.46]        | Provides unique identification for the device. These bits are set by the IFR bits. |

# 13.2.33 Unique Identification Register (SIM\_UIDML1)

The following Reset row refers to Chip POR. Only that type of reset, or any reset type that triggers Chip POR, affects this register. Other reset types do not affect this register.

Address: SIM\_UIDML1 is FFFF\_80C0h base + 2Eh offset = FFFF\_80EEh



- \* Notes:
- x = Undefined at reset.

### SIM\_UIDML1 field descriptions

| Field             | Description                                                                        |
|-------------------|------------------------------------------------------------------------------------|
| 7–0<br>UID[47:40] | Unique identification                                                              |
| 0.5[.77.10]       | Provides unique identification for the device. These bits are set by the IFR bits. |

# 13.2.34 Unique Identification Register (SIM\_UIDML0)

The following Reset row refers to Chip POR. Only that type of reset, or any reset type that triggers Chip POR, affects this register. Other reset types do not affect this register.

Address: SIM\_UIDML0 is FFFF\_80C0h base + 2Fh offset = FFFF\_80EFh



- \* Notes:
- x = Undefined at reset.

# SIM\_UIDML0 field descriptions

| Field             | Description                                                                        |
|-------------------|------------------------------------------------------------------------------------|
| 7–0<br>UID[39:32] | Unique identification                                                              |
|                   | Provides unique identification for the device. These bits are set by the IFR bits. |

# 13.2.35 Unique Identification Register (SIM\_UIDL3)

The following Reset row refers to Chip POR. Only that type of reset, or any reset type that triggers Chip POR, affects this register. Other reset types do not affect this register.

Address: SIM\_UIDL3 is FFFF\_80C0h base + 30h offset = FFFF\_80F0h



- \* Notes:
- x = Undefined at reset.

### SIM\_UIDL3 field descriptions

| Field             | Description                                                                        |
|-------------------|------------------------------------------------------------------------------------|
| 7–0<br>UID[31:24] | Unique identification                                                              |
|                   | Provides unique identification for the device. These bits are set by the IFR bits. |

# 13.2.36 Unique Identification Register (SIM\_UIDL2)

The following Reset row refers to Chip POR. Only that type of reset, or any reset type that triggers Chip POR, affects this register. Other reset types do not affect this register.

Address: SIM\_UIDL2 is FFFF\_80C0h base + 31h offset = FFFF\_80F1h



- \* Notes:
- x = Undefined at reset.

# SIM\_UIDL2 field descriptions

| Field             | Description                                                                        |
|-------------------|------------------------------------------------------------------------------------|
| 7–0<br>UID[23:16] | Unique identification                                                              |
| 010[23:16]        | Provides unique identification for the device. These bits are set by the IFR bits. |

# 13.2.37 Unique Identification Register (SIM\_UIDL1)

The following Reset row refers to Chip POR. Only that type of reset, or any reset type that triggers Chip POR, affects this register. Other reset types do not affect this register.

Address: SIM\_UIDL1 is FFFF\_80C0h base + 32h offset = FFFF\_80F2h



- \* Notes:
- x = Undefined at reset.

### SIM\_UIDL1 field descriptions

| Field            | Description                                                                        |
|------------------|------------------------------------------------------------------------------------|
| 7–0<br>UID[15:8] | Unique identification                                                              |
|                  | Provides unique identification for the device. These bits are set by the IFR bits. |

# 13.2.38 Unique Identification Register (SIM\_UIDL0)

The following Reset row refers to Chip POR. Only that type of reset, or any reset type that triggers Chip POR, affects this register. Other reset types do not affect this register.

Address: SIM\_UIDL0 is FFFF\_80C0h base + 33h offset = FFFF\_80F3h



- \* Notes:
- x = Undefined at reset.

# SIM\_UIDL0 field descriptions

| Field           | Description                                                                        |
|-----------------|------------------------------------------------------------------------------------|
| 7–0<br>UID[7:0] | Unique identification                                                              |
|                 | Provides unique identification for the device. These bits are set by the IFR bits. |

# Chapter 14 Crossbar Switch

### 14.1 Introduction

This chapter provides information on the layout, configuration, and programming of the crossbar switch. The crossbar switch connects bus masters and bus slaves using a crossbar switch structure. This structure allows up to four bus masters to access different bus slaves simultaneously, while providing arbitration among the bus masters when they access the same slave.

#### **14.1.1 Features**

The crossbar switch includes these distinctive features:

- Symmetric crossbar bus switch implementation
  - Allows concurrent accesses from different masters to different slaves
  - Slave arbitration attributes configured on a slave by slave basis
- 32-bit width and support for byte, 2-byte, 4-byte, and 16-byte burst transfers
- Operation at a 1-to-1 clock frequency with the bus masters
- Low-power park mode support
- Dynamic master priority elevation

# 14.2 Memory Map / Register Definition

This design was meant to be as small as possible. To help achieve this, the crossbar switch contains no memory-mapped registers for configuring.

# 14.3 Functional Description

This section provides the functional details of the crossbar switch.

# 14.3.1 General Operation

When a master accesses the crossbar switch the access is immediately taken. If the targeted slave port of the access is available then the access is immediately presented on the slave port. It is possible to make single-clock (zero wait state) accesses through the crossbar. If the targeted slave port of the access is busy or parked on a different master port, the requesting master simply sees wait states inserted until the targeted slave port can service the master's request. The latency in servicing the request depends on each master's priority level and the responding peripheral's access time.

Since the crossbar switch appears to be just another slave to the master device, the master device has no knowledge of whether it actually owns the slave port it is targeting. While the master does not have control of the slave port it is targeting, it simply enters a wait state.

A master is given control of the targeted slave port only after a previous access to a different slave port completes, regardless of its priority on the newly targeted slave port. This prevents deadlock from occurring when:

- A higher priority master has:
  - An outstanding request to one slave port that has a long response time and
  - A pending access to a different slave port, and
- A lower priority master is also making a request to the same slave port as the pending access of the higher priority master.

After the master has control of the slave port it is targeting, the master remains in control of that slave port until it gives up the slave port by running an IDLE cycle or by leaving that slave port for its next access. The master could also lose control of the slave port if another higher priority master makes a request to the slave port; however, if the master is running a fixed- or undefined-length burst transfer it retains control of the slave port until that transfer completes.

The crossbar terminates all master IDLE transfers (as opposed to allowing the termination to come from one of the slave busses). Additionally, when no master is requesting access to a slave port the crossbar drives IDLE transfers onto the slave bus, even though a default master may be granted access to the slave port.

When a slave bus is being IDLEd by the crossbar it remains parked with the last master to use the slave port. This is done in an attempt to save the initial clock of arbitration delay that otherwise would be seen if the master had to arbitrate to gain control of the slave port.

#### 14.3.2 Arbitration

The crossbar switch supports two arbitration schemes: a simple fixed-priority comparison algorithm and a simple round-robin fairness algorithm.

The crossbar arbitration scheme is controlled by CPUCR[CBRR] bit in the processor's CPU Configuration Register (CPUCR). See CPU Configuration Register (CPUCR) for details. At reset, fixed-priority arbitration is enabled.

# 14.3.2.1 Arbitration During Undefined Length Bursts

All lengths of burst accesses lock out arbitration until the last beat of the burst.

## 14.3.2.2 Fixed-Priority Operation

When operating in fixed-priority mode, each master is assigned a unique priority level with the highest numbered master having the highest priority (master 1 has lower priority than master 3). If two masters request access to a slave port, the master with the highest priority gains control over the slave port.

When a master makes a request to a slave port, the slave port checks if the new requesting master's priority level is higher than that of the master that currently has control over the slave port (unless the slave port is in a parked state). The slave port performs an arbitration check at every clock edge to ensure that the proper master (if any) has control of the slave port.

If the new requesting master's priority level is higher than that of the master that currently has control of the slave port, the new requesting master is granted control over the slave port at the next clock edge. The exception to this rule is if the master that currently has control over the slave port is running a fixed length burst transfer or a locked transfer. In this case, the new requesting master must wait until the end of the burst transfer or locked transfer before it is granted control of the slave port.

If the new requesting master's priority level is lower than the master that currently has control of the slave port, the new requesting master is forced to wait until the current master runs one of the following cycles:

#### **Functional Description**

- An IDLE cycle
- A non-IDLE cycle to a location other than the current slave port.

## 14.3.2.3 Round-Robin Priority Operation

When operating in round-robin mode, each master is assigned a relative priority based on the master port number. This relative priority is compared to the ID (master port number) of the last master to perform a transfer on the slave bus. The highest priority requesting master becomes owner of the slave bus at the next transfer boundary (accounting for locked and fixed-length burst transfers). Priority is based on how far ahead the ID of the requesting master is to the ID of the last master.

After granted access to a slave port, a master may perform as many transfers as desired to that port until another master makes a request to the same slave port. The next master in line is granted access to the slave port at the next transfer boundary, or possibly on the next clock cycle if the current master has no pending access request.

As an example of arbitration in round-robin mode, assume the crossbar is implemented with master ports 0, 1, 4, and 5. If the last master of the slave port was master 1, and master 0, 4 and 5 make simultaneous requests, they are serviced in the order 4, 5, and then 0.

Parking may continue to be used in a round-robin mode, but does not affect the round-robin pointer unless the parked master actually performs a transfer. Handoff occurs to the next master in line after one cycle of arbitration.

# 14.3.2.4 Priority Elevation

The processor master port may elevate it's priority level to the slave ports. This is controlled by CPUCR[HAE] and CPUCR[FHP] bits. See CPU Configuration Register (CPUCR) for details. The CPUCR[FHP] bit always elevates the processor's priority while the CPUCR[HAE] bit elevates the processor's priority while it is processing any interrupt service routine.

When priority elevation is enabled for the processor's master port, that master port has a higher priority than the other master ports that do not, regardless of the fixed priority level or round robin conditions.

This functionality allows the user to automatically elevate a master port's priority level throughout the crossbar to quickly perform temporary tasks such as servicing interrupts. However, when using this functionality take care to not to occupy 100% of a slave's bandwidth with one master, and essentially locking out the rest of the masters. This should only be used for important temporary tasks, such as interrupt handling.

### 14.3.2.4.1 Priority Elevation in Round-Robin Mode

If a slave port is programmed for round-robin mode and a master is configured for priority elevation, that master can force the slave port into fixed priority mode. The slave port remains in fixed priority mode while that master's (or any other master's) configured for priority elevation and it attempts access to that particular slave port.

After the masters are no longer configured for priority elevation, or the masters no longer attempt accesses to that particular slave port, the slave port reverts to round-robin priority mode. Then, the pointer is set on the last master to access the slave port.

# 14.4 Initialization/Application Information

No initialization is required by or for the crossbar switch.



# **Chapter 15 Interrupt Controller (INTC)**

### 15.1 Introduction

The CF1\_INTC interrupt controller (CF1\_INTC) is intended for use in low-cost microcontroller designs using the Version 1 (V1) ColdFire processor core. In keeping with the general philosophy for devices based on this low-end 32-bit processor, the interrupt controller generally supports less programmability compared to similar modules in other ColdFire microcontrollers and embedded microprocessors. However, CF1\_INTC provides the required functionality with a minimal silicon cost.

These requirements guide the CF1\_INTC module definition to support Freescale's Controller Continuum:

- The priorities of the interrupt requests between comparable HCS08 and V1 ColdFire devices are identical.
- Supports a mode of operation (through software convention with hardware assists) equivalent to the S08's interrupt processing with only one level of nesting.
- Leverages the current ColdFire interrupt controller programming model and functionality, but with a minimal hardware implementation and cost.

The following table provides a high-level architectural comparison between HCS08 and ColdFire exception processing as these differences are important in the definition of the CF1\_INTC module. Throughout this document, the term IRQ refers to an interrupt request and ISR refers to an interrupt service routine to process an interrupt exception.

Table 15-1. Exception Processing Comparison

| Attribute              | HCS08                                                      | V1 ColdFire                                                                              |
|------------------------|------------------------------------------------------------|------------------------------------------------------------------------------------------|
| Exception Vector Table | 32 two-byte entries, fixed location at upper end of memory | 115 four-byte entries, located at lower end of memory at reset, relocatable with the VBR |

Table continues on the next page...

#### Introduction

Table 15-1. Exception Processing Comparison (continued)

| Attribute                     | HCS08                                           | V1 ColdFire                                                                                                       |
|-------------------------------|-------------------------------------------------|-------------------------------------------------------------------------------------------------------------------|
| More on Vectors               | 2 for CPU + 30 for IRQs, reset at upper address | 64 for CPU + 39 for IRQs, reset at lowest address                                                                 |
| Exception Stack Frame         | 5-byte frame: CCR, A, X, PC                     | 8-byte frame: F/V, SR, PC; General-<br>purpose registers (An, Dn) must be saved/<br>restored by the ISR           |
| Interrupt Levels              | 1 = f(CCR[I])                                   | 7= f (SR[I]) with automatic hardware support for nesting                                                          |
| Non-Maskable IRQ Support      | No                                              | Yes, with level 7 interrupts                                                                                      |
| Core-enforced IRQ Sensitivity | No                                              | Level 7 is edge sensitive, else level sensitive                                                                   |
| INTC Vectoring                | Fixed priorities and vector assignments         | Fixed priorities and vector assignments, plus any 2 IRQs can be remapped as the highest priority level 6 requests |
| Software IACK                 | No                                              | Yes                                                                                                               |
| Exit Instruction from ISR     | RTI                                             | RTE                                                                                                               |

#### **15.1.1 Overview**

Interrupt exception processing includes interrupt recognition, aborting the current instruction execution stream, storing an 8-byte exception stack frame in the memory, calculation of the appropriate vector, and passing control to the specified interrupt service routine.

Unless specifically noted otherwise, all ColdFire processors sample for interrupts once during each instruction's execution during the first cycle of execution in the OEP. Additionally, all ColdFire processors use an instruction restart exception model.

The ColdFire processor architecture defines a 3-bit interrupt priority mask field in the processor's status register (SR[I]). This field, and the associated hardware, support seven levels of interrupt requests with the processor providing automatic nesting capabilities. The levels are defined in descending numeric order with  $7 > 6 \dots > 1$ . Level 7 interrupts are treated as non-maskable, edge-sensitive requests while levels 6–1 are maskable, level-sensitive requests. The SR[I] field defines the processor's current interrupt level. The processor continuously compares the encoded IRQ level from CF1\_INTC against SR[I]. Recall that interrupt requests are inhibited for all levels less than or equal to the current level, except the edge-sensitive level 7 request that cannot be masked.

Exception processing for ColdFire processors is streamlined for performance and includes all actions from detecting the fault condition to the initiation of fetch for the first handler instruction. Exception processing is comprised of four major steps.

- 1. The processor makes an internal copy of the status register (SR) and enters supervisor mode by setting SR[S] and disabling trace mode by clearing SR[T]. The occurrence of an interrupt exception also forces the master mode (M) bit to clear and the interrupt priority mask (I) to set to the level of the current interrupt request.
- 2. The processor determines the exception vector number. For all faults except interrupts, the processor performs this calculation based on the exception type. For interrupts, the processor performs an IACK bus cycle to obtain the vector number from the interrupt controller if CPUCR[IAE] equals 1. The IACK cycle is mapped to special locations within the interrupt controller's IPS address space with the interrupt level encoded in the address. If CPUCR[IAE] equals 0, the processor uses the vector number supplied by the interrupt controller at the time the request was signaled (for improved performance).
- 3. The processor saves the current context by creating an exception stack frame on the system stack. As a result, exception stack frame is created at a 0-modulo-4 address on top of the system stack defined by the supervisor stack pointer (SSP). The processor uses an 8-byte stack frame for all exceptions. It contains the vector number of the exception, the contents of the status register at the time of the exception, and the program counter (PC) at the time of the exception. The exception type determines whether the program counter placed in the exception stack frame defines the location of the faulting instruction (fault) or the address of the next instruction to be executed (next). For interrupts, the stacked PC is always the address of the next instruction to be executed.
- 4. The processor calculates the address of the first instruction of the exception handler. By definition, the exception vector table is aligned on a 1MB boundary. This instruction address is generated by fetching a 32-bit exception vector from the table located at the address defined in the vector base register (VBR). The index into the exception table is calculated as (4 × vector number). After the exception vector has been fetched, the contents of the vector serves as a 32-bit pointer to the address of the first instruction of the desired handler. After the instruction fetch for the first opcode of the handler has been initiated, exception processing terminates and normal instruction processing continues in the handler.

All ColdFire processors support a 1024-byte vector table aligned on any 1 MB address boundary. For the V1 ColdFire core, the only practical locations for the vector table are based at  $0x(00)00\_0000$  in the flash or  $0x(00)80\_0000$  in the RAM. The table contains 256 exception vectors; the first 64 are reserved for internal processor exceptions, and the remaining 192 are device-specific interrupt vectors. The IRQ assignment table is partially populated depending on the exact set of peripherals for the given device.

#### Introduction

The basic ColdFire interrupt controller supports up to 63 request sources mapped as nine priorities for each of the seven supported levels (7 levels  $\times$  9 priorities per level). Within the nine priorities within a level, the mid-point is typically reserved for package-level IRQ inputs. The levels and priorities within the level follow a descending order: 7 > 6 > ... > 1 > 0.

The HCS08 architecture supports a 32-entry exception vector table: the first two vectors are reserved for internal CPU/system exceptions and the remaining are available for I/O interrupt requests. The requirement for an exact match between the interrupt requests and priorities across two architectures means the sources are mapped to a sparsely-populated two-dimensional ColdFire array of seven interrupt levels and nine priorities within the level. The following association between the HCS08 and ColdFire vector numbers applies:

ColdFire Vector Number = 62 + HCS08 Vector Number

The CF1\_INTC performs a cycle-by-cycle evaluation of the active requests and signals the highest-level, highest-priority request to the V1 ColdFire core in the form of an encoded interrupt level and the exception vector associated with the request. The module also includes a byte-wide interface to access its programming model. These interfaces are shown in the following simplified block diagram.



Figure 15-1. CF1\_INTC Block Diagram

## 15.1.2 Features

The Version 1 ColdFire interrupt controller includes:

- Memory-mapped off-platform slave module
  - 64-byte space located at top end of memory:  $0x(FF)FF\_FFC0-0x(FF)FF\_FFFF$
  - Programming model accessed via the peripheral bus
  - Encoded interrupt level and vector sent directly to processor core

#### Introduction

- Support of 30 peripheral I/O interrupt requests plus seven software (one per level) interrupt requests
- Fixed association between interrupt request source and level plus priority
  - 30 I/O requests assigned across seven available levels and nine priorities per level
  - Exactly matches HCS08 interrupt request priorities
  - Up to two requests can be remapped to the highest maskable level + priority
- Unique vector number for each interrupt source
  - ColdFire vector number = 62 + HCS08 vector number
  - Details on IRQ and vector assignments are device-specific
- Support for service routine interrupt acknowledge (software IACK) read cycles for improved system performance
- Combinatorial path provides wakeup signal from wait and stop modes
- Ability to mask any individual interrupt source, plus global mask-all capability

# 15.1.3 Modes of Operation

The CF1\_INTC module does not support any special modes of operation. As a memory-mapped slave peripheral located on the platform's slave bus, it responds based strictly on the memory addresses of the connected bus.

One special behavior of the CF1\_INTC deserves mention. When the device enters a wait or stop mode and certain clocks are disabled, there is an input signal that can be asserted to enable a purely-combinational logic path for monitoring the assertion of an interrupt request. After a request of unmasked level is asserted, this combinational logic path asserts an output signal that is sent to the clock generation logic to re-enable the internal device clocks to exit the low-power mode.

# 15.1.4 Device-Specific Exception and Interrupt Vector Tables

Refer to the Chip Configuration details for this information.

# 15.2 External Signal Description

The CF1\_INTC module does not include any external interfaces.

# 15.3 Interrupt Request Level and Priority Assignments

The CF1\_INTC module implements a sparsely populated  $7 \times 9$  matrix of levels (7) and priorities within each level (9).

Refer to the Chip Configuration information for assignment details for the device.

#### **Note**

For remapped and forced interrupts, the interrupt source number entry indicates the register or register field that enables the corresponding interrupt.

# 15.4 Memory Map and Registers

The CF1\_INTC module provides a 64-byte programming model mapped to the upper region of the 16 MB address space. All the register names are prefixed with INTC\_ as an abbreviation for the full module name.

In the programming model, attempted references to undefined (reserved) addresses or with a non-supported access type (for example, a write to a read-only register) generate a bus error termination.

The programming model follows the definition from previous ColdFire interrupt controllers. This compatibility accounts for the various memory holes in this module memory map.

The CF1\_INTC module is referred to as CF1\_INTC\_BASE throughout the chapter and occupies the upper 64 bytes of the peripheral space.

#### **INTC** memory map

| Absolute address (hex) | Register name                                             | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|------------------------|-----------------------------------------------------------|--------------------|--------|-------------|------------------|
| FFFF_FFC8              | Interrupt Mask Register High (INTC_IMRH)                  | 32                 | R/W    | 0000_0000h  | 15.4.1/338       |
| FFFF_FFCC              | Interrupt Mask Register Low (INTC_IMRL)                   | 32                 | R/W    | 0000_0000h  | 15.4.2/341       |
| FFFF_FFD0              | Force Interrupt Register (INTC_FRC)                       | 8                  | R/W    | 00h         | 15.4.3/344       |
| FFFF_FFD8              | INTC Programmable Level 6 Priority Registers (INTC_PL6P7) | 8                  | R/W    | 00h         | 15.4.4/346       |
| FFFF_FFD9              | INTC Programmable Level 6 Priority Registers (INTC_PL6P6) | 8                  | R/W    | 00h         | 15.4.4/346       |
| FFFF_FFDB              | INTC Wakeup Control Register (INTC_WCR)                   | 8                  | R/W    | 80h         | 15.4.5/347       |
| FFFF_FFDC              | Set Interrupt Mask Register (INTC_SIMR)                   | 8                  | W      | 00h         | 15.4.6/348       |
| FFFF_FFDD              | Clear Interrupt Mask Register (INTC_CIMR)                 | 8                  | W      | 00h         | 15.4.7/349       |
| FFFF_FFDE              | INTC Set Interrupt Force Register (INTC_SFRC)             | 8                  | W      | 00h         | 15.4.8/349       |
| FFFF_FFDF              | INTC Clear Interrupt Force Register (INTC_CFRC)           | 8                  | W      | 00h         | 15.4.9/350       |
| FFFF_FFE0              | INTC Software IACK Register (INTC_SWIACK)                 | 8                  | R      | 00h         | 15.4.10/<br>351  |
| FFFF_FFE4              | INTC Level-n IACK Registers (INTC_LVL1IACK)               | 8                  | R      | 18h         | 15.4.11/<br>352  |
| FFFF_FFE8              | INTC Level-n IACK Registers (INTC_LVL2IACK)               | 8                  | R      | 18h         | 15.4.11/<br>352  |
| FFFF_FFEC              | INTC Level-n IACK Registers (INTC_LVL3IACK)               | 8                  | R      | 18h         | 15.4.11/<br>352  |
| FFFF_FFF0              | INTC Level-n IACK Registers (INTC_LVL4IACK)               | 8                  | R      | 18h         | 15.4.11/<br>352  |
| FFFF_FFF4              | INTC Level-n IACK Registers (INTC_LVL5IACK)               | 8                  | R      | 18h         | 15.4.11/<br>352  |
| FFFF_FFF8              | INTC Level-n IACK Registers (INTC_LVL6IACK)               | 8                  | R      | 18h         | 15.4.11/<br>352  |
| FFFF_FFFC              | INTC Level-n IACK Registers (INTC_LVL7IACK)               | 8                  | R      | 18h         | 15.4.11/<br>352  |

# 15.4.1 Interrupt Mask Register High (INTC\_IMRH)

INTC\_IMRH, along with INTC\_IMRL, provides a bit map for each interrupt to allow the request to be disabled (masked) (1 = disable the request, 0 = enable the request). The IMR is cleared by reset, enabling all interrupt requests to preserve compatibility with earlier V1 ColdFire devices. The IMR can be read and written directly, or individual mask flags can be set or cleared by accessing set/clear interrupt mask registers (INTC\_SIMR, INTC\_CIMR).

Each bit of the IMR[n] is associated with a corresponding bit of the interrupt request input vector. The equations defining this association are:

```
For Vectors 64-102, n=Vector Number - 64, else for Vectors 110-114, n = Vector Number - 71
```

Therefore, vector 64 corresponds to n = 0, vector 65 to n = 1, etc., vector 113 to n = 42, and vector 114 to n = 43.

Each peripheral request input is first qualified by the contents of the IMR registers before it is used elsewhere in the interrupt controller, that is:

```
qualified_interrupt_request[n] = interrupt_request_input[n] + ~INTC_IMR[n]
```

Since this interrupt controller supports 44 request inputs, the upper 20 bits of the INTC\_IMRH are reserved for future use. Writes to these bits are ignored and reads return zeroes.

The contents of the IMR do not affect the operation of the software settable force interrupt registers.

#### NOTE

Because this register and the corresponding low register together represent 64 bits, this register's bits are actually numbered 63-32 (not 31-0).





#### **INTC\_IMRH** field descriptions

| Field             | Description                                                        |
|-------------------|--------------------------------------------------------------------|
| 31–12<br>Reserved | This read-only bitfield is reserved and always has the value zero. |
| 11<br>IMR43       | Interrupt mask register 43  O The interrupt request is enabled.    |
|                   | 1 The interrupt request is disabled.                               |
| 10<br>IMR42       | Interrupt mask register 42                                         |
|                   | 0 The interrupt request is enabled.                                |
|                   | 1 The interrupt request is disabled.                               |
| 9<br>IMR41        | Interrupt mask register 41                                         |

Table continues on the next page...

#### **Memory Map and Registers**

## **INTC\_IMRH** field descriptions (continued)

| Field      | Description                          |
|------------|--------------------------------------|
|            | 0 The interrupt request is enabled.  |
|            | 1 The interrupt request is disabled. |
| 8<br>IMR40 | Interrupt mask register 40           |
|            | 0 The interrupt request is enabled.  |
|            | 1 The interrupt request is disabled. |
| 7<br>IMR39 | Interrupt mask register 39           |
|            | 0 The interrupt request is enabled.  |
|            | 1 The interrupt request is disabled. |
| 6<br>IMR38 | Interrupt mask register 38           |
|            | 0 The interrupt request is enabled.  |
|            | 1 The interrupt request is disabled. |
| 5<br>IMR37 | Interrupt mask register 37           |
|            | 0 The interrupt request is enabled.  |
|            | 1 The interrupt request is disabled. |
| 4<br>IMR36 | Interrupt mask register 36           |
|            | 0 The interrupt request is enabled.  |
|            | 1 The interrupt request is disabled. |
| 3<br>IMR35 | Interrupt mask register 35           |
|            | 0 The interrupt request is enabled.  |
|            | 1 The interrupt request is disabled. |
| 2<br>IMR34 | Interrupt mask register 34           |
|            | 0 The interrupt request is enabled.  |
|            | 1 The interrupt request is disabled. |
| 1<br>IMR33 | Interrupt mask register 33           |
|            | 0 The interrupt request is enabled.  |
|            | 1 The interrupt request is disabled. |
| 0<br>IMR32 | Interrupt mask register 32           |
|            | 0 The interrupt request is enabled.  |
|            | 1 The interrupt request is disabled. |

## 15.4.2 Interrupt Mask Register Low (INTC\_IMRL)

INTC\_IMRL, along with INTC\_IMRH, provides a bit map for each interrupt to allow the request to be disabled (masked) (1 = disable the request, 0 = enable the request). The IMR is cleared by reset, enabling all interrupt requests to preserve compatibility with earlier V1 ColdFire devices. The IMR can be read and written directly, or individual mask flags can be set or cleared by accessing set/clear interrupt mask registers (INTC\_SIMR, INTC\_CIMR).

Each bit of the IMR[n] is associated with a corresponding bit of the interrupt request input vector. The equations defining this association are:

```
For Vectors 64-102, n=Vector Number - 64, else for Vectors 110-114, n = Vector Number - 71
```

Therefore, vector 64 corresponds to n = 0, vector 65 to n = 1, etc., vector 113 to n = 42, and vector 114 to n = 43.

Each peripheral request input is first qualified by the contents of the IMR registers before it is used elsewhere in the interrupt controller, that is:

```
qualified_interrupt_request[n] = interrupt_request_input[n] + ~INTC_IMR[n]
```

Since this interrupt controller supports 44 request inputs, the upper 20 bits of the INTC\_IMRH are reserved for future use. Writes to these bits are ignored and reads return zeroes.

The contents of the IMR do not affect the operation of the software settable force interrupt registers.

Address: INTC\_IMRL is FFFF\_FFC0h base + Ch offset = FFFF\_FFCCh



#### INTC\_IMRL field descriptions

| Field       | Description                          |
|-------------|--------------------------------------|
| 31<br>IMR31 | Interrupt mask register 31           |
|             | 0 The interrupt request is enabled.  |
|             | 1 The interrupt request is disabled. |
| 30<br>IMR30 | Interrupt mask register 30           |

Table continues on the next page...

#### **Memory Map and Registers**

## **INTC\_IMRL** field descriptions (continued)

| Field       | Description                                                                                    |
|-------------|------------------------------------------------------------------------------------------------|
|             | 0 The interrupt request is enabled.                                                            |
|             | 1 The interrupt request is disabled.                                                           |
| 29<br>IMR29 | Interrupt mask register 29                                                                     |
|             | 0 The interrupt request is enabled.                                                            |
|             | 1 The interrupt request is disabled.                                                           |
| 28<br>IMR28 | Interrupt mask register 28                                                                     |
|             | 0 The interrupt request is enabled.                                                            |
|             | 1 The interrupt request is disabled.                                                           |
| 27<br>IMR27 | Interrupt mask register 27                                                                     |
|             | 0 The interrupt request is enabled.                                                            |
|             | 1 The interrupt request is disabled.                                                           |
| 26<br>IMR26 | Interrupt mask register 26                                                                     |
|             | 0 The interrupt request is enabled.                                                            |
|             | 1 The interrupt request is disabled.                                                           |
| 25<br>IMR25 | Interrupt mask register 25                                                                     |
|             | 0 The interrupt request is enabled.                                                            |
|             | 1 The interrupt request is disabled.                                                           |
| 24<br>IMR24 | Interrupt mask register 24                                                                     |
|             | 0 The interrupt request is enabled.                                                            |
|             | 1 The interrupt request is disabled.                                                           |
| 23<br>IMR23 | Interrupt mask register 23                                                                     |
|             | <ul><li>The interrupt request is enabled.</li><li>The interrupt request is disabled.</li></ul> |
| 22          | Interrupt mask register 22                                                                     |
| IMR22       | 0 The interrupt request is enabled.                                                            |
|             | 1 The interrupt request is disabled.                                                           |
| 21<br>IMR21 | Interrupt mask register 21                                                                     |
|             | 0 The interrupt request is enabled.                                                            |
|             | 1 The interrupt request is disabled.                                                           |
| 20<br>IMR20 | Interrupt mask register 20                                                                     |
|             | 0 The interrupt request is enabled.                                                            |
|             | 1 The interrupt request is disabled.                                                           |
| 19<br>IMR19 | Interrupt mask register 19                                                                     |
|             | 0 The interrupt request is enabled.                                                            |
|             | 1 The interrupt request is disabled.                                                           |

Table continues on the next page...

## **INTC\_IMRL** field descriptions (continued)

| Field       | Description                                                                                    |
|-------------|------------------------------------------------------------------------------------------------|
| 18<br>IMR18 | Interrupt mask register 18                                                                     |
|             | The interrupt request is enabled.  The interrupt request is disabled.                          |
|             | 1 The interrupt request is disabled.                                                           |
| 17<br>IMR17 | Interrupt mask register 17                                                                     |
|             | O The interrupt request is enabled.                                                            |
|             | 1 The interrupt request is disabled.                                                           |
| 16<br>IMR16 | Interrupt mask register 16                                                                     |
|             | <ul><li>The interrupt request is enabled.</li><li>The interrupt request is disabled.</li></ul> |
| 15          | Interrupt mask register 15                                                                     |
| IMR15       |                                                                                                |
|             | <ul><li>The interrupt request is enabled.</li><li>The interrupt request is disabled.</li></ul> |
| 14<br>IMR14 | Interrupt mask register 14                                                                     |
| IIVII LI T  | 0 The interrupt request is enabled.                                                            |
|             | 1 The interrupt request is disabled.                                                           |
| 13<br>IMR13 | Interrupt mask register 13                                                                     |
|             | <ul><li>The interrupt request is enabled.</li><li>The interrupt request is disabled.</li></ul> |
| 10          |                                                                                                |
| 12<br>IMR12 | Interrupt mask register 12                                                                     |
|             | <ul><li>The interrupt request is enabled.</li><li>The interrupt request is disabled.</li></ul> |
| 11          | Interrupt mask register 11                                                                     |
| IMR11       | The interrupt request is enabled.                                                              |
|             | 1 The interrupt request is disabled.                                                           |
| 10<br>IMR10 | Interrupt mask register 10                                                                     |
|             | 0 The interrupt request is enabled.                                                            |
|             | 1 The interrupt request is disabled.                                                           |
| 9<br>IMR9   | Interrupt mask register 9                                                                      |
|             | <ul><li>The interrupt request is enabled.</li><li>The interrupt request is disabled.</li></ul> |
| 8           | Interrupt mask register 8                                                                      |
| IMR8        |                                                                                                |
|             | <ul><li>The interrupt request is enabled.</li><li>The interrupt request is disabled.</li></ul> |
| 7           | Interrupt mask register 7                                                                      |
| IMR7        |                                                                                                |

Table continues on the next page...

#### **Memory Map and Registers**

#### INTC\_IMRL field descriptions (continued)

| Field     | Description                          |
|-----------|--------------------------------------|
|           | 0 The interrupt request is enabled.  |
|           | 1 The interrupt request is disabled. |
| 6<br>IMR6 | Interrupt mask register 6            |
|           | 0 The interrupt request is enabled.  |
|           | 1 The interrupt request is disabled. |
| 5<br>IMR5 | Interrupt mask register 5            |
|           | 0 The interrupt request is enabled.  |
|           | 1 The interrupt request is disabled. |
| 4<br>IMR4 | Interrupt mask register 4            |
|           | 0 The interrupt request is enabled.  |
|           | 1 The interrupt request is disabled. |
| 3<br>IMR3 | Interrupt mask register 3            |
|           | 0 The interrupt request is enabled.  |
|           | 1 The interrupt request is disabled. |
| 2<br>IMR2 | Interrupt mask register 2            |
|           | 0 The interrupt request is enabled.  |
|           | 1 The interrupt request is disabled. |
| 1<br>IMR1 | Interrupt mask register 1            |
|           | 0 The interrupt request is enabled.  |
|           | 1 The interrupt request is disabled. |
| 0<br>IMR0 | Interrupt mask register 0            |
|           | 0 The interrupt request is enabled.  |
|           | 1 The interrupt request is disabled. |

## 15.4.3 Force Interrupt Register (INTC\_FRC)

The INTC\_FRC register allows software to generate a unique interrupt for each possible level at the lowest priority within the level for functional or debug purposes. These interrupts may be self-scheduled by setting one or more of the bits in the INTC\_FRC register. In some cases, the handling of a normal interrupt request may cause critical processing by the service routine along with the scheduling (using the INTC\_FRC register) of a lower priority level interrupt request to be processed at a later time for less-critical task handling.

The INTC\_FRC register may be modified directly using a read-modify-write sequence or through a simple write operation using the set/clear force interrupt registers (INTC\_SFRC, INTC\_CFRC).

# **NOTE**

For compatibility with other ColdFire interrupt controllers, this register's bit numbers are actually 63-56 (not 7-0).

Address: INTC\_FRC is FFFF\_FFC0h base + 10h offset = FFFF\_FFD0h



#### **INTC\_FRC** field descriptions

| Field         | Description                                                                                                     |
|---------------|-----------------------------------------------------------------------------------------------------------------|
| 7<br>Reserved | This read-only bit is reserved and always has the value zero.                                                   |
| 6<br>LVL1     | Force level 1 interrupt  O Negates the forced level 1 interrupt request.  1 Forces a level 1 interrupt request. |
| 5<br>LVL2     | Force level 2 interrupt  O Negates the forced level 2 interrupt request.  1 Forces a level 2 interrupt request. |
| 4<br>LVL3     | Force level 3 interrupt  O Negates the forced level 3 interrupt request.  1 Forces a level 3 interrupt request. |
| 3<br>LVL4     | Force level 4 interrupt  O Negates the forced level 4 interrupt request.  1 Forces a level 4 interrupt request. |
| 2<br>LVL5     | Force level 5 interrupt  O Negates the forced level 5 interrupt request.  1 Forces a level 5 interrupt request. |
| 1<br>LVL6     | Force level 6 interrupt  O Negates the forced level 6 interrupt request.  1 Forces a level 6 interrupt request. |
| 0<br>LVL7     | Force level 7 interrupt  O Negates the forced level 7 interrupt request.  1 Forces a level 7 interrupt request. |

## 15.4.4 INTC Programmable Level 6 Priority Registers (INTC\_PL6Pn)

The level seven interrupt requests cannot have their levels reassigned. However, any of the remaining peripheral interrupt requests can be reassigned as the highest priority maskable requests using these two registers (INTC\_PL6P7 and INTC\_PL6P6). The vector number associated with the interrupt requests does not change. Rather, only the interrupt request's level and priority are altered, based on the contents of the INTC\_PL6P{7,6} registers.

#### NOTE

The requests associated with the INTC\_FRC register have a fixed level and priority that cannot be altered.

The INTC\_PL6P7 register specifies the highest-priority, maskable interrupt request that is defined as the level six, priority seven request. The INTC\_PL6P6 register specifies the second-highest-priority, maskable interrupt request defined as the level six, priority six request. Reset clears both registers, disabling any request re-mapping.

For an example of the use of these registers, see Using INTC\_PL6P{7,6} Registers.





#### INTC\_PL6Pn field descriptions

| Field           | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 7–6<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |
| 5–0<br>REQN     | Pequest number  Defines the peripheral IRQ number to be remapped as the level 6, priority 7 (for INTC_PL6P7) request and level 6, priority 6 (for INTC_PL6P6) request.  NOTE: The value must be a valid interrupt number. Unused or reserved interrupt numbers are ignored. The selected vector number is derived from the decimal value of the REQN field, which is <i>n</i> in the following mapping formula: for vectors 64-102, <i>n</i> = <i>Vector_Number</i> - <i>64</i> , while for vectors 110-114, <i>n</i> = <i>Vector_Number</i> - <i>71</i> . In other words, the REQN field's minimum value is 4d (selecting vector 68) and maximum value is 43d (selecting vector 114). |  |

## 15.4.5 INTC Wakeup Control Register (INTC\_WCR)

The interrupt controller provides a combinatorial logic path to generate a special wakeup signal to exit from the wait or stop modes. The INTC\_WCR register defines wakeup condition for interrupt recognition during wait and stop modes. This mode of operation works as follows:

- 1. Write to the INTC\_WCR to enable this operation (set INTC\_WCR[ENB]) and define the interrupt mask level needed to force the core to exit wait or stop mode (INTC\_WCR[MASK]). The maximum value of INTC\_WCR[MASK] is 0x6 (0b110). The INTC\_WCR is enabled with a mask level of 0 as the default after reset.
- 2. Execute a stop instruction to place the processor into wait or stop mode.
- 3. After the processor is stopped, the interrupt controller enables special logic that evaluates the incoming interrupt sources in a purely combinatorial path; no clocked storage elements are involved.
- 4. If an active interrupt request is asserted and the resulting interrupt level is greater than the mask value contained in INTC\_WCR[MASK], the interrupt controller asserts the wakeup output signal. This signal is routed to the clock generation logic to exit the low-power mode and resume processing.

Typically, the interrupt mask level loaded into the processor's status register field (SR[I]) during the execution of the stop instruction matches the INTC\_WCR[MASK] value.

The interrupt controller wakeup signal is defined as:

Address: INTC\_WCR is FFFF\_FFC0h base + 1Bh offset = FFFF\_FFDBh



#### **INTC\_WCR** field descriptions

| Field    | Description                                                                               |
|----------|-------------------------------------------------------------------------------------------|
| 7<br>ENB | Enable wakeup signal                                                                      |
|          | 0 Wakeup signal disabled.                                                                 |
|          | 1 Enables the assertion of the combinational wakeup signal to the clock generation logic. |

Table continues on the next page...

#### **Memory Map and Registers**

#### **INTC\_WCR field descriptions (continued)**

| Field           | Description                                                        |
|-----------------|--------------------------------------------------------------------|
| 6–3<br>Reserved | This read-only bitfield is reserved and always has the value zero. |
| 2-0<br>MASK     | Interrupt mask level                                               |

# 15.4.6 Set Interrupt Mask Register (INTC\_SIMR)

The INTC\_SIMR register provides a simple memory-mapped mechanism to set a given bit in the INTC\_IMR{H,L} registers to disable (mask) a given interrupt request. The data value on a register write causes the corresponding bit in the INTC\_IMR{H,L} registers to be set. Setting INTC\_SIMR[SALL] forces the entire contents of INTC\_IMR{H,L} registers to set, masking all interrupts. Attempting to read this register generates an error termination.

IMR[63:44] are reserved for future use, so writes using these data values are ignored.

This register is provided so interrupt service routines can easily mask the given interrupt request without the need to perform a read-modify-write sequence on the INTC\_IMR{H,L} registers.

Address: INTC\_SIMR is FFFF\_FFC0h base + 1Ch offset = FFFF\_FFDCh



#### **INTC SIMR field descriptions**

| Field         | Description                                                                                                                                                                                                  |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>Reserved | This bit is reserved.                                                                                                                                                                                        |
| 6<br>SALL     | Set all  Set all bits in the INTC_IMR{H,L} register, masking all interrupt requests.  O Set only those bits specified in the SIMR field.  Set all bits in INTC_IMR{H,L} register. The SIMR field is ignored. |
| 5–0<br>SIMR   | Set IMR Set the corresponding bit in the INTC_IMR{H,L} register, masking the interrupt request.                                                                                                              |

348

## 15.4.7 Clear Interrupt Mask Register (INTC\_CIMR)

The INTC\_SIMR register provides a simple memory-mapped mechanism to set a given bit in the INTC\_IMR{H,L} registers to disable (mask) a given interrupt request. The data value on a register write causes the corresponding bit in the INTC\_IMR{H,L} registers to be set. Setting INTC\_SIMR[SALL] forces the entire contents of INTC\_IMR{H,L} registers to set, masking all interrupts. Attempting to read this register generates an error termination.

IMR[63:44] are reserved for future use, so writes using these data values are ignored.

This register is provided so interrupt service routines can easily mask the given interrupt request without the need to perform a read-modify-write sequence on the INTC\_IMR{H,L} registers.





#### **INTC\_CIMR** field descriptions

| Field         | Description                                                                                                                                                                                                         |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>Reserved | This bit is reserved.                                                                                                                                                                                               |
| 6<br>CALL     | Clear all  Clear all bits in the INTC_IMR{H,L} register, enabling all interrupt requests.  O Set only those bits specified in the CIMR field.  Clear all bits in INTC_IMR{H,L} register. The CIMR field is ignored. |
| 5–0<br>CIMR   | Clear the corresponding bit in the INTC_IMR{H,L} registers, enabling the interrupt request.                                                                                                                         |

# 15.4.8 INTC Set Interrupt Force Register (INTC\_SFRC)

The INTC\_SFRC register provides a simple memory-mapped mechanism to set a given bit in the INTC\_FRC register to assert a specific level interrupt request. The data value written causes the appropriate bit in the INTC\_FRC register to be set. Attempted reads of this register generate an error termination.

#### **Memory Map and Registers**

This register is provided so interrupt service routines can generate a forced interrupt request without the need to perform a read-modify-write sequence on the INTC\_FRC register.

Address: INTC\_SFRC is FFFF\_FFC0h base + 1Eh offset = FFFF\_FFDEh



#### **INTC\_SFRC** field descriptions

| Field           | Description                                                                                                                                                                                                  |
|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–6<br>Reserved | This bitfield is reserved.                                                                                                                                                                                   |
| 5–0<br>SET      | For data values within the 56–62 range, the corresponding bit in the INTC_FRC register is set, as defined below.                                                                                             |
|                 | <b>NOTE:</b> Data values outside this range do not affect the INTC_FRC register. It is recommended the data values be restricted to the 0x38–0x3E (56–62) range to ensure compatibility with future devices. |
|                 | 111000 Bit 56, INTC_FRC[LVL7] is set                                                                                                                                                                         |
|                 | 111001 Bit 57, INTC_FRC[LVL6] is set                                                                                                                                                                         |
|                 | 111010 Bit 58, INTC_FRC[LVL5] is set                                                                                                                                                                         |
|                 | 111011 Bit 59, INTC_FRC[LVL4] is set                                                                                                                                                                         |
|                 | 111100 Bit 60, INTC_FRC[LVL3] is set                                                                                                                                                                         |
|                 | 111101 Bit 61, INTC_FRC[LVL2] is set                                                                                                                                                                         |
|                 | 111110 Bit 62, INTC_FRC[LVL1] is set                                                                                                                                                                         |

# 15.4.9 INTC Clear Interrupt Force Register (INTC\_CFRC)

The INTC\_CFRC register provides a simple memory-mapped mechanism to clear a given bit in the INTC\_FRC register to negate a specific level interrupt request. The data value on the register write causes the appropriate bit in the INTC\_FRC register to be cleared. Attempted reads of this register generate an error termination.

This register is provided so interrupt service routines can negate a forced interrupt request without the need to perform a read-modify-write sequence on the INTC\_FRC register.

Address: INTC\_CFRC is FFFF\_FFC0h base + 1Fh offset = FFFF\_FFDFh



## **INTC\_CFRC** field descriptions

| Field           | Description                                                                                                                                                                                           |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–6<br>Reserved | This bitfield is reserved.                                                                                                                                                                            |
| 5–0<br>CLR      | For data values within the 56–62 range, the corresponding bit in the INTC_FRC register is cleared, as defined below.                                                                                  |
|                 | NOTE: Data values outside this range do not affect the INTC_FRC register. It is recommended the data values be restricted to the 0x38–0x3E (56–62) range to ensure compatibility with future devices. |
|                 | 111000 Bit 56, INTC_FRC[LVL7] is cleared                                                                                                                                                              |
|                 | 111001 Bit 57, INTC_FRC[LVL6] is cleared                                                                                                                                                              |
|                 | 111010 Bit 58, INTC_FRC[LVL5] is cleared                                                                                                                                                              |
|                 | 111011 Bit 59, INTC_FRC[LVL4] is cleared                                                                                                                                                              |
|                 | 111100 Bit 60, INTC_FRC[LVL3] is cleared                                                                                                                                                              |
|                 | 111101 Bit 61, INTC_FRC[LVL2] is cleared                                                                                                                                                              |
|                 | 111110 Bit 62, INTC_FRC[LVL1] is cleared                                                                                                                                                              |

# 15.4.10 INTC Software IACK Register (INTC\_SWIACK)

Refer to the description of the Level-n IACK registers.

Address: INTC\_SWIACK is FFFF\_FFC0h base + 20h offset = FFFF\_FFE0h



## **INTC\_SWIACK** field descriptions

| Field         | Description                                                                                                                                                                                                 |
|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>Reserved | This read-only bit is reserved and always has the value zero.                                                                                                                                               |
| 6–0<br>VECN   | Vector number  Indicates the appropriate vector number.  It is the highest-level, highest-priority request currently being asserted in the CF1_INTC module. If there are no pending requests, VECN is zero. |

## 15.4.11 INTC Level-n IACK Registers (INTC\_LVLnIACK)

The eight read-only interrupt acknowledge (IACK) registers can be explicitly addressed by the memory-mapped accesses or implicitly addressed by a processor-generated interrupt acknowledge cycle during exception processing when CPUCR[IAE] is set. In either case, the interrupt controller's actions are similar.

First, consider an IACK cycle to a specific level, a level-n IACK. When this type of IACK arrives in the interrupt controller, the controller examines all currently-active level-n interrupt requests, determines the highest priority within the level, and then responds with the unique vector number corresponding to that specific interrupt source. The vector number is supplied as the data for the byte-sized IACK read cycle.

If there is no active interrupt source at the time of the level-n IACK, a special spurious interrupt vector (vector number 24 [0x18]) is returned. It is the responsibility of the service routine to manage this error situation.

This protocol implies the interrupting peripheral is not accessed during the acknowledge cycle because the interrupt controller completely services the acknowledge. This means the interrupt source must be explicitly disabled in the peripheral device by the interrupt service routine. This approach provides unique vector capability for all interrupt requests, regardless of the complexity of the peripheral device.

Second, the interrupt controller also supports the concept of a software IACK. This is the ability to query the interrupt controller near the end of an interrupt service routine (after the current interrupt request has been negated) to determine if there are any pending (but currently masked) interrupt requests. If the response to the software IACK's byte operand read is non-zero, the service routine uses the returned value as the vector number of the highest pending interrupt request and passes control to the appropriate new handler. If the returned value is zero, there is no pending interrupt request.

This process avoids the overhead of a context restore and RTE instruction execution, followed immediately by another interrupt exception and context save. In system environments with high rates of interrupt activity, this mechanism can noticeably improve overall performance.



#### INTC\_LVLnIACK field descriptions

| Field         | Description                                                                                                                                                                                                                  |
|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>Reserved | This read-only bit is reserved and always has the value zero.                                                                                                                                                                |
| 6–0<br>VECN   | Vector number Indicates the appropriate vector number. It is the highest priority request within the specified level-n. If there are no pending requests within the level, VECN is 0x18 (24) to signal a spurious interrupt. |

# 15.5 Functional Description

The basic operation of the CF1\_INTC is detailed in the preceding sections. This section describes special rules applicable to non-maskable level seven interrupt requests and the module's interfaces.

# 15.5.1 Handling of Non-Maskable Level 7 Interrupt Requests

In this context of this discussion, the non-maskable level 7 interrupt requests refer only to the masking capability provided by the processor's SR[I] field. The ability to mask individual interrupt requests using the interrupt controller's IMR is always available, regardless of the level of a particular interrupt request.

The CPU treats level 7 interrupts as non-maskable, edge-sensitive requests, while levels 1 through 6 are maskable, level-sensitive requests. As a result of this definition, level 7 interrupt requests are a special case. The edge-sensitive nature of these requests means the encoded 3-bit level input from the CF1\_INTC to the V1 ColdFire core must change state before the CPU detects an interrupt. A non-maskable interrupt (NMI) is generated

#### **Initialization Information**

each time the encoded interrupt level changes to level 7 (regardless of the SR[I] field) and each time the SR[I] mask changes from 7 to a lower value while the encoded request level remains at 7.

### 15.6 Initialization Information

The reset state of the CF1\_INTC module enables the default IRQ mappings and clears any software-forced interrupt requests (INTC\_FRC is cleared). Immediately after reset, the CF1\_INTC begins its cycle-by-cycle evaluation of any asserted interrupt requests and forms the appropriate encoded interrupt level and vector information for the V1 ColdFire processor core. The ability to mask individual interrupt requests using the interrupt controller's IMR is always available, regardless of the level of a particular interrupt request.

# 15.7 Application Information

This section discusses three application topics: emulation of the HCS08's one level interrupt nesting structure, elevating the priority of two IRQs, and more details on the operation of the software interrupt acknowledge (SWIACK) mechanism.

# 15.7.1 Emulation of the HCS08's 1-Level IRQ Handling

As noted in Table 10-7, the HCS08 architecture specifies a 1-level IRQ nesting capability. Interrupt masking is controlled by CCR[I], the interrupt mask flag: clearing CCR[I] enables interrupts, while setting CCR[I] disables interrupts. The ColdFire architecture defines seven interrupt levels, controlled by the 3-bit interrupt priority mask field in the status register, SR[I], and the hardware automatically supports nesting of interrupts.

To emulate the HCS08's 1-level IRQ capabilities on V1 ColdFire, only two SR[I] settings are used:

- Writing 0 to SR[I] enables interrupts.
- Writing 7 to SR[I] disables interrupts.

The ColdFire core treats the level seven requests as non-maskable, edge-sensitive interrupts.

354

ColdFire processors inhibit interrupt sampling during the first instruction of all exception handlers. This allows any handler to effectively disable interrupts, if necessary, by raising the interrupt mask level contained in the status register as the first instruction in the ISR. In addition, the V1 instruction set architecture (ISA\_C) includes an instruction (STLDSR) that stores the current interrupt mask level and loads a value into the SR. This instruction is specifically intended for use as the first instruction of an interrupt service routine that services multiple interrupt requests with different interrupt levels. For more details see the *ColdFire Family Programmer's Reference Manual*. A MOVE-to-SR instruction also performs a similar function.

To emulate the HCS08's 1-level IRQ nesting mechanisms, the ColdFire implementation enables interrupts by clearing SR[I] (typically when using RTE to return to a process) and disables interrupts upon entering every interrupt service routine by one of three methods:

- 1. Execution of STLDSR #0x2700 as the first instruction of an ISR.
- 2. Execution of MOVE.w #0x2700,SR as the first instruction of an ISR.
- 3. Static assertion of CPUCR[IME] that forces the processor to load SR[I] with seven automatically upon the occurrence of an interrupt exception. Because this method removes the need to execute multi-cycle instructions of #1 or #2, this approach improves system performance.

# 15.7.2 Using INTC\_PL6P{7,6} Registers

The INTC Programmable Level 6, Priority {7,6} registers (INTC\_PL6P{7,6}) provide the ability to dynamically alter the request level and priority of two IRQs. Specifically, these registers provide the ability to reassign two IRQs to be the highest level 6 (maskable) requests. Consider the following example.

Suppose the system operation desires to remap the receive and transmit interrupt requests of a serial communication device (SCI1) as the highest two maskable interrupts. The default assignments for the SCI1 transmit and receive interrupts are:

- sci1\_rx = interrupt source 13 (0Dh) = vector 77 = level 24, priority 6
- sci1\_tx = interrupt source 14 (0Eh) = vector 78 = level 24, priority 5

To remap these two requests, the INTC\_PL6P{7,6} registers are programmed with the desired interrupt source number:

#### **Application Information**

- Setting INTC\_PL6P7 to 13 (0Dh), remaps sci1\_rx as level 6, priority 7.
- Setting INTC\_PL6P6 to 14 (0Eh), remaps sci1\_tx as level 6, priority 6.

The reset state of the INTC\_PL6P{7,6} registers disables any request remapping.

#### 15.7.3 More on Software IACKs

As previously mentioned, the notion of a software IACK refers to the ability to query the interrupt controller near the end of an interrupt service routine (after the current interrupt request has been cleared) to determine if there are any pending (but currently masked) interrupt requests. If the response to the software IACK's byte operand read is non-zero, the service routine uses the value as the vector number of the highest pending interrupt request and passes control to the appropriate new handler. This process avoids the overhead of a context restore and RTE instruction execution, followed immediately by another interrupt exception and context save. In system environments with high rates of interrupt activity, this mechanism can improve overall system performance noticeably.

To illustrate this concept, consider the following ISR code snippet shown in Figure 15-22.

```
align 4
                  irqxx_entry:
irgxx alternate entry:
00590:
                 irqxx swiack:
005c0: 71b8 ffe0 mvz.b INTC_SWIACK.w,d0 # perform software IACK
005c4: 0c00 0041 cmpi.b #0x41,d0 # pending IRQ or level 7?
005c8: 6f0a ble.b irqxx_exit # no pending IRQ, then exit
005ca: 91c8 sub.l a0,a0 # clear a0
005cc: 2270 0c00 move.l 0(a0,d0.1*4),a1 # fetch pointer from xcpt table
005d0: 4ee9 0008 jmp 8(a1)
                                             # goto alternate isr entry point
                  align 4
                  irqxx exit:
005d4: 4cd7 0303 movem.l (sp),#0x0303 # restore d0/d1/a0/a1 005d8: 4fef 0010 lea 16(sp),sp # deallocate stack sp
                                              # deallocate stack space
005dc: 4e73 rte
                                              # return from handler
```

Figure 15-22. ISR Code Snippet with SWIACK

This snippet includes the prologue and epilogue for an interrupt service routine as well as code needed to perform software IACK.

At the entry point (irqxx\_entry), there is a two-instruction prologue to allocate space on the supervisor stack to save the four volatile registers (d0, d1, a0, a1) defined in the ColdFire application binary interface. After saving these registers, the ISR continues at the alternate entry point.

The software IACK is performed near the end of the ISR, after the source of the current interrupt request is negated. First, the appropriate memory-mapped byte location in the interrupt controller is read (PC = 0x5C0). The CF1\_INTC module returns the vector number of the highest priority pending request. If no request is pending, zero is returned. The compare instruction is needed to manage a special case involving pending level seven requests. Because the level seven requests are non-maskable, the ISR is interrupted to service one of these requests. To avoid any race conditions, this check ignores the level seven vector numbers. The result is the conditional branch (PC = 0x5C8) is taken if there are no pending requests or if the pending request is a level seven.

If there is a pending non-level seven request, execution continues with a three instruction sequence to calculate and then branch to the appropriate alternate ISR entry point. This sequence assumes the exception vector table is based at address  $0x(00)00\_0000$  and that each ISR uses the same two-instruction prologue shown here. The resulting alternate entry point is a fixed offset (8 bytes) from the normal entry point defined in the exception vector table.

The ISR epilogue includes a three instruction sequence to restore the volatile registers from the stack and return from the interrupt exception.

This example is intentionally simple, but does show how performing the software IACK and passing control to an alternate entry point when there is a pending but masked interrupt request can avoid the execution of the ISR epilogue, another interrupt exception, and the ISR prologue.



# Chapter 16 Low Leakage Wakeup Unit (LLWU)

## 16.1 Introduction

The LLWU module allows the user to select up to 16 external pin sources and up to 8 internal modules as a wakeup source from low-leakage power modes. The input sources are described in the device's Chip Configuration details. Each of the available wakeup sources can be individually enabled.

The RESET pin is an additional source for triggering an exit from low-leakage power modes and causes the MCU to exit both LLS and VLLS through a reset flow. The LLWU\_RST[LLRSTE] bit must be set to allow an exit from low-leakage modes via the RESET pin. On a device where the RESET pin is shared with other functions, the explicit port mux control register must be set for the RESET pin before the RESET pin can be used as a low-leakage reset source.

The LLWU module also includes three optional digital pin filters: two for the external wakeup pins and one for the  $\overline{RESET}$  pin.

## 16.1.1 Features

The LLWU module features include:

- Supports up to 16 external input pins and up to 8 internal modules with individual enable bits
- Input sources may be external pins or from internal peripherals capable of running in LLS or VLLS. See the Chip Configuration information for wakeup input sources for this device.
- Each external pin wakeup input is programmable as falling edge, rising edge, or any change
- Wakeup inputs are activated if enabled once MCU enters a low-leakage power mode
- Optional digital filters provided to qualify an external pin detect and RESET pin detect.

## 16.1.2 Modes of operation

The LLWU module becomes functional on entry into a low-leakage power mode. After recovery from LLS, the LLWU is then immediately disabled. After recovery from VLLS, the LLWU continues to detect wakeup events until the user has acknowledged the wakeup via a write to the PMC\_REGSC[ACKISO] bit.

#### 16.1.2.1 LLS mode

The LLWU module provides up to 16 external wakeup inputs and up to 8 internal module wakeup inputs. In addition, an LLS reset event can be initiated via assertion of the RESET pin.

Wakeup events due to external wakeup inputs and internal module wakeup inputs result in an interrupt flow when exiting LLS. A reset event due to RESET pin assertion results in a reset flow when exiting LLS.

#### NOTE

The LLWU interrupt must not be masked by the interrupt controller to avoid a scenario where the system does not fully exit stop mode on an LLS recovery.

#### 16.1.2.2 VLLS modes

The LLWU module provides up to 16 external wakeup inputs and up to 8 internal module wakeup inputs. In addition, a VLLS reset event can be initiated via assertion of the RESET pin. All wakeup and reset events result in VLLS exit via a reset flow.

## 16.1.2.3 Non-low leakage modes

The LLWU is not active in all non-low leakage modes where detection and control logic are in a static state. The LLWU registers are accessible in non-low leakage modes and are available for configuring and reading status when bus transactions are possible.

When the reset or wakeup pin filters are enabled, filter operation begins immediately. If a low leakage mode is entered within 5 LPO clock cycles of an active edge, the edge event will be detected by the LLWU. For RESET pin filtering, this means there is no restart to the minimum LPO cycle duration as the filtering transitions from a non-low leakage filter (implemented in the RCM) to the LLWU filter.

# 16.1.2.4 Debug mode

When the chip is in debug mode and then enters LLS or a VLLSx mode, no debug logic works in the fully functional low leakage mode. Upon an exit from the LLS or VLLSx mode, the LLWU becomes inactive. If the exit is from a VLLSx mode, the wakeup did not occur via the RESET pin, and the SIM's SOPT4[VLLDBGREQ] bit is set to 1, the debug logic becomes active again upon the exit from the VLLSx mode.

# 16.1.3 Block diagram

The following figure is the block diagram for the LLWU module.

#### **LLWU Signal Descriptions**



Figure 16-1. LLWU block diagram

# 16.2 LLWU Signal Descriptions

The signal properties of LLWU are shown in the following table. The external wakeup input pins can be enabled to detect either rising edge, falling edge, or on any change.

Table 16-1. LLWU Signal Descriptions

| Signal  | Description              | I/O |
|---------|--------------------------|-----|
| LLWU_Pn | Wakeup inputs (n = 0-15) | I   |

# 16.3 Memory map/register definition

The LLWU includes the following registers:

- Five 8-bit wakeup source enable registers
  - Enable external pin input sources
  - Enable internal peripheral sources
- Three 8-bit wakeup flag registers
  - Indication of wakeup source that caused exit from a low-leakage power mode includes external pin or internal module interrupt
- Two 8-bit wakeup pin filter enable registers
- One 8-bit RESET pin filter enable register

#### NOTE

All LLWU registers are reset by Chip Reset not VLLS and by reset types that trigger Chip Reset not VLLS. Each register's displayed reset value represents this subset of reset types. LLWU registers are unaffected by reset types that do not trigger Chip Reset not VLLS. For more information about the types of reset on this chip, refer to the Reset details.

#### **LLWU** memory map

| Absolute<br>address<br>(hex) | Register name                           | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|------------------------------|-----------------------------------------|--------------------|--------|-------------|------------------|
| FFFF_80B0                    | LLWU Pin Enable 1 Register (LLWU_PE1)   | 8                  | R/W    | 00h         | 16.3.1/364       |
| FFFF_80B1                    | LLWU Pin Enable 2 Register (LLWU_PE2)   | 8                  | R/W    | 00h         | 16.3.2/365       |
| FFFF_80B2                    | LLWU Pin Enable 3 Register (LLWU_PE3)   | 8                  | R/W    | 00h         | 16.3.3/366       |
| FFFF_80B3                    | LLWU Pin Enable 4 Register (LLWU_PE4)   | 8                  | R/W    | 00h         | 16.3.4/367       |
| FFFF_80B4                    | LLWU Module Enable Register (LLWU_ME)   | 8                  | R/W    | 00h         | 16.3.5/368       |
| FFFF_80B5                    | LLWU Flag 1 Register (LLWU_F1)          | 8                  | R/W    | 00h         | 16.3.6/370       |
| FFFF_80B6                    | LLWU Flag 2 Register (LLWU_F2)          | 8                  | R/W    | 00h         | 16.3.7/372       |
| FFFF_80B7                    | LLWU Flag 3 Register (LLWU_F3)          | 8                  | R/W    | 00h         | 16.3.8/373       |
| FFFF_80B8                    | LLWU Pin Filter 1 Register (LLWU_FILT1) | 8                  | R/W    | 00h         | 16.3.9/375       |
| FFFF_80B9                    | LLWU Pin Filter 2 Register (LLWU_FILT2) | 8                  | R/W    | 00h         | 16.3.10/<br>376  |
| FFFF_80BA                    | LLWU Reset Enable Register (LLWU_RST)   | 8                  | R/W    | 02h         | 16.3.11/<br>377  |

# 16.3.1 LLWU Pin Enable 1 Register (LLWU\_PE1)

LLWU\_PE1 contains the bit field to enable and select the edge detect type for the external wakeup input pins LLWU\_P3-LLWU\_P0.

#### **NOTE**

This register is reset on Chip Reset not VLLS and by reset types that trigger Chip Reset not VLLS. It is unaffected by reset types that do not trigger Chip Reset not VLLS. See the Reset details for more information.

Address: LLWU\_PE1 is FFFF\_80B0h base + 0h offset = FFFF\_80B0h



#### LLWU\_PE1 field descriptions

| Field        | Description                                                   |
|--------------|---------------------------------------------------------------|
| 7–6<br>WUPE3 | Wakeup Pin Enable for LLWU_P3                                 |
| 110. 20      | Enables and configures the edge detection for the wakeup pin. |
|              | 00 External input pin disabled as wakeup input                |
|              | 01 External input pin enabled with rising edge detection      |
|              | 10 External input pin enabled with falling edge detection     |
|              | 11 External input pin enabled with any change detection       |
| 5–4<br>WUPE2 | Wakeup Pin Enable for LLWU_P2                                 |
|              | Enables and configures the edge detection for the wakeup pin. |
|              | 00 External input pin disabled as wakeup input                |
|              | 01 External input pin enabled with rising edge detection      |
|              | 10 External input pin enabled with falling edge detection     |
|              | 11 External input pin enabled with any change detection       |
| 3–2<br>WUPE1 | Wakeup Pin Enable for LLWU_P1                                 |
| VVOILI       | Enables and configures the edge detection for the wakeup pin. |
|              | 00 External input pin disabled as wakeup input                |
|              | 01 External input pin enabled with rising edge detection      |
|              | 10 External input pin enabled with falling edge detection     |
|              | 11 External input pin enabled with any change detection       |
| 1–0          | Wakeup Pin Enable for LLWU_P0                                 |
| WUPE0        |                                                               |

Table continues on the next page...

#### LLWU\_PE1 field descriptions (continued)

| Field | Description                                                   |
|-------|---------------------------------------------------------------|
|       | Enables and configures the edge detection for the wakeup pin. |
|       | 00 External input pin disabled as wakeup input                |
|       | 01 External input pin enabled with rising edge detection      |
|       | 10 External input pin enabled with falling edge detection     |
|       | 11 External input pin enabled with any change detection       |

# 16.3.2 LLWU Pin Enable 2 Register (LLWU\_PE2)

LLWU\_PE2 contains the bit field to enable and select the edge detect type for the external wakeup input pins LLWU\_P7-LLWU\_P4.

#### **NOTE**

This register is reset on Chip Reset not VLLS and by reset types that trigger Chip Reset not VLLS. It is unaffected by reset types that do not trigger Chip Reset not VLLS. See the Reset details for more information.

Address: LLWU\_PE2 is FFFF\_80B0h base + 1h offset = FFFF\_80B1h



#### LLWU\_PE2 field descriptions

| Field        | Description                                                   |
|--------------|---------------------------------------------------------------|
| 7–6<br>WUPE7 | Wakeup Pin Enable for LLWU_P7                                 |
|              | Enables and configures the edge detection for the wakeup pin. |
|              | 00 External input pin disabled as wakeup input                |
|              | 01 External input pin enabled with rising edge detection      |
|              | 10 External input pin enabled with falling edge detection     |
|              | 11 External input pin enabled with any change detection       |
| 5–4<br>WUPE6 | Wakeup Pin Enable for LLWU_P6                                 |
|              | Enables and configures the edge detection for the wakeup pin. |
|              | 00 External input pin disabled as wakeup input                |
|              | 01 External input pin enabled with rising edge detection      |
|              | 10 External input pin enabled with falling edge detection     |
|              | 11 External input pin enabled with any change detection       |

Table continues on the next page...

#### Memory map/register definition

#### LLWU\_PE2 field descriptions (continued)

| Field        | Description                                                   |
|--------------|---------------------------------------------------------------|
| 3–2<br>WUPE5 | Wakeup Pin Enable for LLWU_P5                                 |
|              | Enables and configures the edge detection for the wakeup pin. |
|              | 00 External input pin disabled as wakeup input                |
|              | 01 External input pin enabled with rising edge detection      |
|              | 10 External input pin enabled with falling edge detection     |
|              | 11 External input pin enabled with any change detection       |
| 1–0<br>WUPE4 | Wakeup Pin Enable for LLWU_P4                                 |
| WOILT        | Enables and configures the edge detection for the wakeup pin. |
|              | 00 External input pin disabled as wakeup input                |
|              | 01 External input pin enabled with rising edge detection      |
|              | 10 External input pin enabled with falling edge detection     |
|              | 11 External input pin enabled with any change detection       |

# 16.3.3 LLWU Pin Enable 3 Register (LLWU\_PE3)

LLWU\_PE3 contains the bit field to enable and select the edge detect type for the external wakeup input pins LLWU\_P11-LLWU\_P8.

#### NOTE

This register is reset on Chip Reset not VLLS and by reset types that trigger Chip Reset not VLLS. It is unaffected by reset types that do not trigger Chip Reset not VLLS. See the Reset details for more information.

Address: LLWU PE3 is FFFF 80B0h base + 2h offset = FFFF 80B2h



#### LLWU\_PE3 field descriptions

| Field         | Description                                                   |
|---------------|---------------------------------------------------------------|
| 7–6<br>WUPE11 | Wakeup Pin Enable for LLWU_P11                                |
| _             | Enables and configures the edge detection for the wakeup pin. |
|               | 00 External input pin disabled as wakeup input                |
|               | 01 External input pin enabled with rising edge detection      |

Table continues on the next page...

#### LLWU\_PE3 field descriptions (continued)

| Field         | Description                                                   |
|---------------|---------------------------------------------------------------|
|               | 10 External input pin enabled with falling edge detection     |
|               | 11 External input pin enabled with any change detection       |
| 5–4<br>WUPE10 | Wakeup Pin Enable for LLWU_P10                                |
|               | Enables and configures the edge detection for the wakeup pin. |
|               | 00 External input pin disabled as wakeup input                |
|               | 01 External input pin enabled with rising edge detection      |
|               | 10 External input pin enabled with falling edge detection     |
|               | 11 External input pin enabled with any change detection       |
| 3–2<br>WUPE9  | Wakeup Pin Enable for LLWU_P9                                 |
|               | Enables and configures the edge detection for the wakeup pin. |
|               | 00 External input pin disabled as wakeup input                |
|               | 01 External input pin enabled with rising edge detection      |
|               | 10 External input pin enabled with falling edge detection     |
|               | 11 External input pin enabled with any change detection       |
| 1–0<br>WUPE8  | Wakeup Pin Enable for LLWU_P8                                 |
|               | Enables and configures the edge detection for the wakeup pin. |
|               | 00 External input pin disabled as wakeup input                |
|               | 01 External input pin enabled with rising edge detection      |
|               | 10 External input pin enabled with falling edge detection     |
|               | 11 External input pin enabled with any change detection       |

# 16.3.4 LLWU Pin Enable 4 Register (LLWU\_PE4)

LLWU\_PE4 contains the bit field to enable and select the edge detect type for the external wakeup input pins LLWU\_P15-LLWU\_P12.

#### NOTE

This register is reset on Chip Reset not VLLS and by reset types that trigger Chip Reset not VLLS. It is unaffected by reset types that do not trigger Chip Reset not VLLS. See the Reset details for more information.

Address: LLWU\_PE4 is FFFF\_80B0h base + 3h offset = FFFF\_80B3h



#### Memory map/register definition

## LLWU\_PE4 field descriptions

| Field         | Description                                                   |
|---------------|---------------------------------------------------------------|
| 7–6<br>WUPE15 | Wakeup Pin Enable for LLWU_P15                                |
|               | Enables and configures the edge detection for the wakeup pin. |
|               | 00 External input pin disabled as wakeup input                |
|               | 01 External input pin enabled with rising edge detection      |
|               | 10 External input pin enabled with falling edge detection     |
|               | 11 External input pin enabled with any change detection       |
| 5–4<br>WUPE14 | Wakeup Pin Enable for LLWU_P14                                |
|               | Enables and configures the edge detection for the wakeup pin. |
|               | 00 External input pin disabled as wakeup input                |
|               | 01 External input pin enabled with rising edge detection      |
|               | 10 External input pin enabled with falling edge detection     |
|               | 11 External input pin enabled with any change detection       |
| 3–2<br>WUPE13 | Wakeup Pin Enable for LLWU_P13                                |
|               | Enables and configures the edge detection for the wakeup pin. |
|               | 00 External input pin disabled as wakeup input                |
|               | 01 External input pin enabled with rising edge detection      |
|               | 10 External input pin enabled with falling edge detection     |
|               | 11 External input pin enabled with any change detection       |
| 1–0<br>WUPE12 | Wakeup Pin Enable for LLWU_P12                                |
|               | Enables and configures the edge detection for the wakeup pin. |
|               | 00 External input pin disabled as wakeup input                |
|               | 01 External input pin enabled with rising edge detection      |
|               | 10 External input pin enabled with falling edge detection     |
|               | 11 External input pin enabled with any change detection       |

# 16.3.5 LLWU Module Enable Register (LLWU\_ME)

LLWU\_ME contains the bits to enable the internal module flag as a wakeup input source for inputs MWUF7-MWUF0.

#### **NOTE**

This register is reset on Chip Reset not VLLS and by reset types that trigger Chip Reset not VLLS. It is unaffected by reset types that do not trigger Chip Reset not VLLS. See the Reset details for more information.

Address: LLWU\_ME is FFFF\_80B0h base + 4h offset = FFFF\_80B4h



## **LLWU\_ME** field descriptions

| Field      | Description                                          |
|------------|------------------------------------------------------|
| 7<br>WUME7 | Wakeup Module Enable for Module 7                    |
| VVOIVIL7   | Enables an internal module as a wakeup source input. |
|            | 0 Internal module flag not used as wakeup source     |
|            | 1 Internal module flag used as wakeup source         |
| 6<br>WUME6 | Wakeup Module Enable for Module 6                    |
|            | Enables an internal module as a wakeup source input. |
|            | 0 Internal module flag not used as wakeup source     |
|            | 1 Internal module flag used as wakeup source         |
| 5<br>WUME5 | Wakeup Module Enable for Module 5                    |
|            | Enables an internal module as a wakeup source input. |
|            | 0 Internal module flag not used as wakeup source     |
|            | 1 Internal module flag used as wakeup source         |
| 4<br>WUME4 | Wakeup Module Enable for Module 4                    |
|            | Enables an internal module as a wakeup source input. |
|            | 0 Internal module flag not used as wakeup source     |
|            | 1 Internal module flag used as wakeup source         |
| 3<br>WUME3 | Wakeup Module Enable for Module 3                    |
|            | Enables an internal module as a wakeup source input. |
|            | 0 Internal module flag not used as wakeup source     |
|            | 1 Internal module flag used as wakeup source         |
| 2<br>WUME2 | Wakeup Module Enable for Module 2                    |
|            | Enables an internal module as a wakeup source input. |
|            | 0 Internal module flag not used as wakeup source     |
|            | 1 Internal module flag used as wakeup source         |
| 1<br>WUME1 | Wakeup Module Enable for Module 1                    |
|            | Enables an internal module as a wakeup source input. |
|            | 0 Internal module flag not used as wakeup source     |
|            | 1 Internal module flag used as wakeup source         |

Table continues on the next page...

#### Memory map/register definition

## **LLWU\_ME field descriptions (continued)**

| Field      | Description                                          |
|------------|------------------------------------------------------|
| 0<br>WUME0 | Wakeup Module Enable for Module 0                    |
|            | Enables an internal module as a wakeup source input. |
|            | 0 Internal module flag not used as wakeup source     |
|            | 1 Internal module flag used as wakeup source         |

# 16.3.6 LLWU Flag 1 Register (LLWU\_F1)

LLWU\_F1 contains the wakeup flags indicating which wakeup source caused the MCU to exit LLS or VLLS mode. For LLS, this will be the source causing the CPU interrupt flow. For VLLS, this will be the source causing the MCU reset flow.

The external wakeup flags are read only and clearing a flag is accomplished by a write of a one to the corresponding WUFx bit. The wakeup flag (WUFx) if set will remain set if the associated WUPEx bit is cleared.

#### NOTE

This register is reset on Chip Reset not VLLS and by reset types that trigger Chip Reset not VLLS. It is unaffected by reset types that do not trigger Chip Reset not VLLS. See the Reset details for more information.

Address: LLWU\_F1 is FFFF\_80B0h base + 5h offset = FFFF\_80B5h



#### LLWU F1 field descriptions

| Field     | Description                                                                                                                                                                                                                                  |
|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>WUF7 | Wakeup Flag for LLWU_P7  Indicates that an enabled external wakeup pin was a source of exiting a low-leakage power mode. To clear the flag write a one to WUF7.  0 LLWU_P7 input was not a wakeup source 1 LLWU_P7 input was a wakeup source |
| 6<br>WUF6 | Wakeup Flag for LLWU_P6                                                                                                                                                                                                                      |

Table continues on the next page...

# LLWU\_F1 field descriptions (continued)

| Field     | Description                                                                                                                            |
|-----------|----------------------------------------------------------------------------------------------------------------------------------------|
|           | Indicates that an enabled external wakeup pin was a source of exiting a low-leakage power mode. To clear the flag write a one to WUF6. |
|           | 0 LLWU_P6 input was not a wakeup source                                                                                                |
|           | 1 LLWU_P6 input was a wakeup source                                                                                                    |
| 5<br>WUF5 | Wakeup Flag for LLWU_P5                                                                                                                |
|           | Indicates that an enabled external wakeup pin was a source of exiting a low-leakage power mode. To clear the flag write a one to WUF5. |
|           | 0 LLWU_P5 input was not a wakeup source                                                                                                |
|           | 1 LLWU_P5 input was a wakeup source                                                                                                    |
| 4<br>WUF4 | Wakeup Flag for LLWU_P4                                                                                                                |
|           | Indicates that an enabled external wakeup pin was a source of exiting a low-leakage power mode. To clear the flag write a one to WUF4. |
|           | 0 LLWU_P4 input was not a wakeup source                                                                                                |
|           | 1 LLWU_P4 input was a wakeup source                                                                                                    |
| 3<br>WUF3 | Wakeup Flag for LLWU_P3                                                                                                                |
|           | Indicates that an enabled external wakeup pin was a source of exiting a low-leakage power mode. To clear the flag write a one to WUF3. |
|           | 0 LLWU_P3 input was not a wakeup source                                                                                                |
|           | 1 LLWU_P3 input was a wakeup source                                                                                                    |
| 2<br>WUF2 | Wakeup Flag for LLWU_P2                                                                                                                |
|           | Indicates that an enabled external wakeup pin was a source of exiting a low-leakage power mode. To clear the flag write a one to WUF2. |
|           | 0 LLWU_P2 input was not a wakeup source                                                                                                |
|           | 1 LLWU_P2 input was a wakeup source                                                                                                    |
| 1<br>WUF1 | Wakeup Flag for LLWU_P1                                                                                                                |
|           | Indicates that an enabled external wakeup pin was a source of exiting a low-leakage power mode. To clear the flag write a one to WUF1. |
|           | 0 LLWU_P1 input was not a wakeup source                                                                                                |
|           | 1 LLWU_P1 input was a wakeup source                                                                                                    |
| 0<br>WUF0 | Wakeup Flag for LLWU_P0                                                                                                                |
|           | Indicates that an enabled external wakeup pin was a source of exiting a low-leakage power mode. To clear the flag write a one to WUF0. |
|           | 0 LLWU_P0 input was not a wakeup source                                                                                                |
|           | 1 LLWU_P0 input was a wakeup source                                                                                                    |
|           | <u> </u>                                                                                                                               |

# 16.3.7 LLWU Flag 2 Register (LLWU\_F2)

LLWU\_F2 contains the wakeup flags indicating which wakeup source caused the MCU to exit LLS or VLLS mode. For LLS, this will be the source causing the CPU interrupt flow. For VLLS, this will be the source causing the MCU reset flow.

The external wakeup flags are read only and clearing a flag is accomplished by a write of a one to the corresponding WUFx bit. The wakeup flag (WUFx) if set will remain set if the associated WUPEx bit is cleared.

#### NOTE

This register is reset on Chip Reset not VLLS and by reset types that trigger Chip Reset not VLLS. It is unaffected by reset types that do not trigger Chip Reset not VLLS. See the Reset details for more information.

Address: LLWU\_F2 is FFFF\_80B0h base + 6h offset = FFFF\_80B6h

| Bit   | 7     | 6     | 5     | 4     | 3     | 2     | 1    | 0    |
|-------|-------|-------|-------|-------|-------|-------|------|------|
| Read  | WUF15 | WUF14 | WUF13 | WUF12 | WUF11 | WUF10 | WUF9 | WUF8 |
| Write | w1c   | w1c   | w1c   | w1c   | w1c   | w1c   | w1c  | w1c  |
| Reset | 0     | 0     | 0     | 0     | 0     | 0     | 0    | 0    |

#### LLWU\_F2 field descriptions

| Field      | Description                                                                                                                             |
|------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>WUF15 | Wakeup Flag for LLWU_P15  Indicates that an enabled external wakeup pin was a source of exiting a low-leakage power mode. To            |
|            | clear the flag write a one to WUF15.  0 LLWU_P15 input was not a wakeup source                                                          |
|            | 1 LLWU_P15 input was a wakeup source                                                                                                    |
| 6<br>WUF14 | Wakeup Flag for LLWU_P14                                                                                                                |
|            | Indicates that an enabled external wakeup pin was a source of exiting a low-leakage power mode. To clear the flag write a one to WUF14. |
|            | 0 LLWU_P14 input was not a wakeup source                                                                                                |
|            | 1 LLWU_P14 input was a wakeup source                                                                                                    |
| 5<br>WUF13 | Wakeup Flag for LLWU_P13                                                                                                                |
|            | Indicates that an enabled external wakeup pin was a source of exiting a low-leakage power mode. To clear the flag write a one to WUF13. |
|            | 0 LLWU_P13 input was not a wakeup source                                                                                                |
|            | 1 LLWU_P13 input was a wakeup source                                                                                                    |

Table continues on the next page...

#### LLWU\_F2 field descriptions (continued)

| Field      | Description                                                                                                                             |
|------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 4<br>WUF12 | Wakeup Flag for LLWU_P12  Indicates that an enabled external wakeup pin was a source of exiting a low-leakage power mode. To            |
|            | clear the flag write a one to WUF12.                                                                                                    |
|            | 0 LLWU_P12 input was not a wakeup source 1 LLWU_P12 input was a wakeup source                                                           |
| 3<br>WUF11 | Wakeup Flag for LLWU_P11                                                                                                                |
|            | Indicates that an enabled external wakeup pin was a source of exiting a low-leakage power mode. To clear the flag write a one to WUF11. |
|            | 0 LLWU_P11 input was not a wakeup source                                                                                                |
|            | 1 LLWU_P11 input was a wakeup source                                                                                                    |
| 2<br>WUF10 | Wakeup Flag for LLWU_P10                                                                                                                |
|            | Indicates that an enabled external wakeup pin was a source of exiting a low-leakage power mode. To clear the flag write a one to WUF10. |
|            | 0 LLWU_P10 input was not a wakeup source                                                                                                |
|            | 1 LLWU_P10 input was a wakeup source                                                                                                    |
| 1<br>WUF9  | Wakeup Flag for LLWU_P9                                                                                                                 |
|            | Indicates that an enabled external wakeup pin was a source of exiting a low-leakage power mode. To clear the flag write a one to WUF9.  |
|            | 0 LLWU_P9 input was not a wakeup source                                                                                                 |
|            | 1 LLWU_P9 input was a wakeup source                                                                                                     |
| 0<br>WUF8  | Wakeup Flag for LLWU_P8                                                                                                                 |
|            | Indicates that an enabled external wakeup pin was a source of exiting a low-leakage power mode. To clear the flag write a one to WUF8.  |
|            | 0 LLWU_P8 input was not a wakeup source                                                                                                 |
|            | 1 LLWU_P8 input was a wakeup source                                                                                                     |

# 16.3.8 LLWU Flag 3 Register (LLWU\_F3)

LLWU\_F3 contains the wakeup flags indicating which internal wakeup source caused the MCU to exit LLS or VLLS mode. For LLS, this will be the source causing the CPU interrupt flow. For VLLS, this will be the source causing the MCU reset flow.

For internal peripherals that are capable of running in a low-leakage power mode, such as RTC or CMP modules, the flag from the associated peripheral is accessible as the MWUFx bit. Clearing of the flag will need to be done in the peripheral instead of writing a one to the MWUFx bit.

## **NOTE**

This register is reset on Chip Reset not VLLS and by reset types that trigger Chip Reset not VLLS. It is unaffected by reset types that do not trigger Chip Reset not VLLS. See the Reset details for more information.

Address: LLWU\_F3 is FFFF\_80B0h base + 7h offset = FFFF\_80B7h



## LLWU\_F3 field descriptions

| Field      | Description                                                                                                                                                               |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>MWUF7 | Wakeup flag for module 7                                                                                                                                                  |
| INIVO: 7   | Indicates that an enabled internal peripheral was a source of exiting a low-leakage power mode. To clear the flag follow the internal peripheral flag clearing mechanism. |
|            | 0 Module 7 input was not a wakeup source                                                                                                                                  |
|            | 1 Module 7 input was a wakeup source                                                                                                                                      |
| 6<br>MWUF6 | Wakeup flag for module 6                                                                                                                                                  |
|            | Indicates that an enabled internal peripheral was a source of exiting a low-leakage power mode. To clear the flag follow the internal peripheral flag clearing mechanism. |
|            | 0 Module 6 input was not a wakeup source                                                                                                                                  |
|            | 1 Module 6 input was a wakeup source                                                                                                                                      |
| 5<br>MWUF5 | Wakeup flag for module 5                                                                                                                                                  |
|            | Indicates that an enabled internal peripheral was a source of exiting a low-leakage power mode. To clear the flag follow the internal peripheral flag clearing mechanism. |
|            | 0 Module 5 input was not a wakeup source                                                                                                                                  |
|            | 1 Module 5 input was a wakeup source                                                                                                                                      |
| 4<br>MWUF4 | Wakeup flag for module 4                                                                                                                                                  |
|            | Indicates that an enabled internal peripheral was a source of exiting a low-leakage power mode. To clear the flag follow the internal peripheral flag clearing mechanism. |
|            | 0 Module 4 input was not a wakeup source                                                                                                                                  |
|            | 1 Module 4 input was a wakeup source                                                                                                                                      |
| 3<br>MWUF3 | Wakeup flag for module 3                                                                                                                                                  |
|            | Indicates that an enabled internal peripheral was a source of exiting a low-leakage power mode. To clear the flag follow the internal peripheral flag clearing mechanism. |
|            | 0 Module 3 input was not a wakeup source                                                                                                                                  |
|            | 1 Module 3 input was a wakeup source                                                                                                                                      |

Table continues on the next page...

#### LLWU\_F3 field descriptions (continued)

| Field      | Description                                                                                                                                                               |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2<br>MWUF2 | Wakeup flag for module 2                                                                                                                                                  |
|            | Indicates that an enabled internal peripheral was a source of exiting a low-leakage power mode. To clear the flag follow the internal peripheral flag clearing mechanism. |
|            | 0 Module 2 input was not a wakeup source                                                                                                                                  |
|            | 1 Module 2 input was a wakeup source                                                                                                                                      |
| 1<br>MWUF1 | Wakeup flag for module 1                                                                                                                                                  |
|            | Indicates that an enabled internal peripheral was a source of exiting a low-leakage power mode. To clear the flag follow the internal peripheral flag clearing mechanism. |
|            | 0 Module 1 input was not a wakeup source                                                                                                                                  |
|            | 1 Module 1 input was a wakeup source                                                                                                                                      |
| 0<br>MWUF0 | Wakeup flag for module 0                                                                                                                                                  |
|            | Indicates that an enabled internal peripheral was a source of exiting a low-leakage power mode. To clear the flag follow the internal peripheral flag clearing mechanism. |
|            | 0 Module 0 input was not a wakeup source                                                                                                                                  |
|            | 1 Module 0 input was a wakeup source                                                                                                                                      |

# 16.3.9 LLWU Pin Filter 1 Register (LLWU\_FILT1)

LLWU\_FILT1 is a control and status register that is used to enable/disable the digital filter 1 features for an external pin.

#### NOTE

This register is reset on Chip Reset not VLLS and by reset types that trigger Chip Reset not VLLS. It is unaffected by reset types that do not trigger Chip Reset not VLLS. See the Reset details for more information.

Address: LLWU\_FILT1 is FFFF\_80B0h base + 8h offset = FFFF\_80B8h



#### LLWU\_FILT1 field descriptions

| Field      | Description        |
|------------|--------------------|
| 7<br>FILTF | Filter Detect Flag |

Table continues on the next page...

#### Memory map/register definition

## LLWU\_FILT1 field descriptions (continued)

| Field          | Description                                                                                                                                                     |  |  |  |  |
|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
|                | Indicates that the filtered external wakeup pin, selected by FILTSEL, was a source of exiting a low-leakage power mode. To clear the flag write a one to FILTF. |  |  |  |  |
|                | <ul><li>0 Pin Filter 1 was not a wakeup source</li><li>1 Pin Filter 1 was a wakeup source</li></ul>                                                             |  |  |  |  |
| 6–5<br>FILTE   | Digital Filter on External Pin  Controls the digital filter options for the external pin detect.                                                                |  |  |  |  |
|                | 00 Filter disabled 01 Filter posedge detect enabled 10 Filter negedge detect enabled 11 Filter any edge detect enabled                                          |  |  |  |  |
| 4<br>Reserved  | This read-only bit is reserved and always has the value zero.                                                                                                   |  |  |  |  |
| 3–0<br>FILTSEL | Filter pin select Selects 1 out of the 16 wakeup pins to be muxed into the filter.                                                                              |  |  |  |  |
|                | 0000 Select LLWU_P0 for filter 1111 Select LLWU_P15 for filter                                                                                                  |  |  |  |  |

# 16.3.10 LLWU Pin Filter 2 Register (LLWU\_FILT2)

LLWU\_FILT2 is a control and status register that is used to enable/disable the digital filter 2 features for an external pin.

#### **NOTE**

This register is reset on Chip Reset not VLLS and by reset types that trigger Chip Reset not VLLS. It is unaffected by reset types that do not trigger Chip Reset not VLLS. See the Reset details for more information.

Address: LLWU\_FILT2 is FFFF\_80B0h base + 9h offset = FFFF\_80B9h



## LLWU\_FILT2 field descriptions

| Field          | Description                                                                                                                                                     |
|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>FILTF     | Filter Detect Flag                                                                                                                                              |
|                | Indicates that the filtered external wakeup pin, selected by FILTSEL, was a source of exiting a low-leakage power mode. To clear the flag write a one to FILTF. |
|                | 0 Pin Filter 2 was not a wakeup source                                                                                                                          |
|                | 1 Pin Filter 2 was a wakeup source                                                                                                                              |
| 6–5<br>FILTE   | Digital Filter on External Pin                                                                                                                                  |
|                | Controls the digital filter options for the external pin detect.                                                                                                |
|                | 00 Filter disabled                                                                                                                                              |
|                | 01 Filter posedge detect enabled                                                                                                                                |
|                | 10 Filter negedge detect enabled                                                                                                                                |
|                | 11 Filter any edge detect enabled                                                                                                                               |
| 4<br>Reserved  | This read-only bit is reserved and always has the value zero.                                                                                                   |
| 3–0<br>FILTSEL | Filter pin select                                                                                                                                               |
| TILTOLL        | Selects 1 out of the 16 wakeup pins to be muxed into the filter.                                                                                                |
|                | 0000 Select LLWU_P0 for filter                                                                                                                                  |
|                |                                                                                                                                                                 |
|                | 1111 Select LLWU_P15 for filter                                                                                                                                 |

# 16.3.11 LLWU Reset Enable Register (LLWU\_RST)

LLWU\_RST is a control register that is used to enable/disable the digital filter for the external pin detect and RESET pin.

#### NOTE

This register is reset on Chip Reset not VLLS and by reset types that trigger Chip Reset not VLLS. It is unaffected by reset types that do not trigger Chip Reset not VLLS. See the Reset details for more information.

Address: LLWU\_RST is FFFF\_80B0h base + Ah offset = FFFF\_80BAh



#### **Functional description**

#### LLWU\_RST field descriptions

| Field           | Description                                                                                                                                                                                                                                                                                                                                              |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–2<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                                                                                                       |
| 1<br>LLRSTE     | Low Leakage mode RESET enable  This bit must be set to allow the device to be reset while in a low-leakage power mode. On devices where Reset is not a dedicated pin, the RESET pin must also be enabled in the explicit port mux control.  O RESET pin not enabled as a leakage mode exit source  1 RESET pin enabled as a low leakage mode exit source |
| 0<br>RSTFILT    | Digital Filter on RESET Pin  Enables the digital filter for the RESET pin during LLS or VLLS mode.  0 Filter not enabled 1 Filter enabled                                                                                                                                                                                                                |

# 16.4 Functional description

This on-chip peripheral module is called a low leakage wakeup unit (LLWU) module because it allows internal peripherals and external input pins as a source of wakeup from low leakage modes. It is operational only in LLS and VLLSx modes.

The LLWU module contains pin enables for each external pin and internal module. For each external pin, the user can disable or select the edge type for the wakeup. Type options are falling, rising, or either edge. When an external pin is enabled as a wakeup source, the pin must be configured as an input pin.

The LLWU implements optional 3-cycle glitch filters, based on the LPO clock, such that a detected external pin (wakeup or RESET) is required to remain asserted until the enabled glitch filter times out. Additional latency of up to 2 cycles is due to synchronization, which results in a total of up to 5 cycles of delay before the detect circuit alerts the system to the wakeup or reset event when the filter function is enabled. Two wakeup detect filters are available to detect up to two external pins. A separate reset filter is on the RESET pin. Glitch filtering is not provided on the internal modules.

For internal module wakeup operation, the WUMEx bit enables the associated module as a wakeup source.

# 16.4.1 LLS mode

Wakeup events triggered from either an external pin input or an internal module input result in a CPU interrupt flow to begin user code execution.

An LLS reset event due to RESET pin assertion causes an exit via a system reset. State retention data is lost, the I/O states return to their reset state. The RCM\_SRS[WAKEUP] and RCM\_SRS[PIN] bits are set and the system executes a reset flow before CPU operation begins with a reset vector fetch.

## **16.4.2 VLLS modes**

In the case of a wakeup due to external pin or internal module wakeup, recovery is always via a reset flow and the RCM\_SRS[WAKEUP] is set indicating the low leakage mode was active. State retention data is lost and I/O will be restored after the PMC\_REGSC[ACKISO] has been written.

A VLLS exit event due to RESET pin assertion causes an exit via a system reset. State retention data is lost, the I/O states immediately return to their reset state. The RCM\_SRS[WAKEUP] and RCM\_SRS[PIN] bits are set and the system executes a reset flow before CPU operation begins with a reset vector fetch.

# 16.4.3 Initialization

For an enabled peripheral wakeup input, the peripheral flag should be cleared by software before entering LLS or VLLSx mode to avoid an immediate exit from the mode.

Flags associated with external input pins (filtered and unfiltered) should also be cleared by software prior to entry to LLS or VLLSx mode.

After enabling an external pin filter or changing the source pin, wait at least 5 LPO clock cycles before entering LLS or VLLSx mode to allow the filter to initialize.

**Functional description** 

# **Chapter 17 System Mode Controller (SMC)**

## 17.1 Introduction

The System Mode Controller (SMC) is responsible for sequencing the system into and out of all low power stop and run modes. Specifically, it monitors events to trigger transitions between power modes while controlling the power, clocks and memories of the system to achieve the power consumption and functionality of that mode.

This chapter describes all the available low power modes, the sequence followed to enter/exit each mode and the functionality available while in each of the modes.

The SMC is able to function during even the deepest low power modes.

# 17.2 Modes of Operation

The V1 ColdFire CPU has two primary modes of operation: run and stop. The STOP instruction is used to invoke both stop and wait modes. The CPU does not differentiate between stop and wait modes.

In addition, Freescale MCUs also augment stop, wait, and run modes in a number of ways. The power management controller (PMC) contains a run and a stop mode regulator. Run regulation is used in normal run, wait and stop modes. Stop mode regulation is used during all very low power and low leakage modes. During stop mode regulation the bus frequencies are limited for the very low power modes.

The SMC provides the user with multiple power options. The very low power run (VLPR) mode can drastically reduce run time power when maximum bus frequency is not required to handle the application needs. From normal run mode, the run mode (RUNM) bit field can be modified to change the the MCU into VLPR mode when limited frequency is sufficient for the application. From VLPR mode, a corresponding wait (VLPW) and stop (VLPS) mode can be entered.

#### **Modes of Operation**

Depending on the needs of the user application, a variety of stop modes are available that allow the state retention, partial power down or full power down of certain logic and/or memory. I/O states are held in all modes of operation. Several registers are used to configure the various modes of operation for the device.

The following table describes the power modes available for the device.

Table 17-1. Power modes

| Mode  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RUN   | MCU can be run at full speed and the internal supply is fully regulated (run regulation mode). This mode is also referred to as normal run mode.                                                                                                                                                                                                                                                                                                                                                                               |
| WAIT  | The CPU clock is gated off. The System Clock continues to operate; Bus Clocks, if enabled, continue to operate; and run regulation is maintained.                                                                                                                                                                                                                                                                                                                                                                              |
| STOP  | The Core Clock is gated off. System Clock to other masters and Bus Clocks are stopped after all stop acknowledge signals from supporting peripherals are valid.                                                                                                                                                                                                                                                                                                                                                                |
| VLPR  | The Core, System, Bus, and Flash Clock maximum frequencies are restricted in this mode. See the Power Management chapter for details about the maximum allowable frequencies.                                                                                                                                                                                                                                                                                                                                                  |
| VLPW  | The Core Clock is gated off. The System, Bus, and Flash Clocks continue to operate, although their maximum frequency is restricted. See the Power Management chapter for details on what the maximum allowable frequencies are.                                                                                                                                                                                                                                                                                                |
| VLPS  | The Core Clock to the CPU is gated off. System clock to other masters and Bus Clocks are stopped after all stop acknowledge signals from supporting peripherals are valid.                                                                                                                                                                                                                                                                                                                                                     |
| LLS   | The CPU clocks are gated off. System clock and Bus Clocks are stopped after all stop acknowledge signals from supporting peripherals are valid. MCU is placed in a low leakage mode by reducing the voltage to internal logic. Internal logic states are retained.                                                                                                                                                                                                                                                             |
| VLLS3 | The CPU clocks are gated off. System clock to other masters and Bus Clocks are stopped after all stop acknowledge signals from supporting peripherals are valid. MCU is placed in a low leakage mode by powering down the internal logic. All system RAM contents are retained and I/O states held. FlexRAM contents are not retained. Internal logic states are not retained.                                                                                                                                                 |
| VLLS2 | The CPU clocks are gated off. System clock to other masters and Bus Clocks are stopped after all stop acknowledge signals from supporting peripherals are valid. MCU is placed in a low leakage mode by powering down the internal logic and the system RAM3 partition. The system RAM2 partition can be optionally retained using the VLLSCTRL[RAM2PO] bit while the system RAM1 partition contents are always retained in this mode. FlexRAM contents are not retained. Internal logic states are not retained. <sup>1</sup> |
| VLLS1 | The CPU clocks are gated off. System clock to other masters and Bus Clocks are stopped after all stop acknowledge signals from supporting peripherals are valid. MCU is placed in a low leakage mode by powering down the internal logic and all system RAM. A 32-byte register file (available in all modes) contents are retained and I/O states held. FlexRAM contents are not retained. Internal logic states are not retained.                                                                                            |

<sup>1.</sup> See the devices Chip Configuration details for the size and location of the system RAM partitions.

382

# 17.3 Memory Map and Register Descriptions

Details follow about the registers related to the System Mode Controller.

Different SMC registers reset on different reset types. Each register's description provides details. For more information about the types of reset on this chip, refer to the Reset details.

| Absolute<br>address<br>(hex) | Register name                               | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|------------------------------|---------------------------------------------|--------------------|--------|-------------|------------------|
| FFFF_8118                    | Power Mode Protection Register (SMC_PMPROT) | 8                  | R/W    | 00h         | 17.3.1/383       |
| FFFF_8119                    | Power Mode Control Register (SMC_PMCTRL)    | 8                  | R/W    | 00h         | 17.3.2/384       |
| FFFF_811A                    | VLLS Control Register (SMC_VLLSCTRL)        | 8                  | R/W    | 03h         | 17.3.3/386       |
| FFFF_811B                    | Power Mode Status Register (SMC_PMSTAT)     | 8                  | R      | 01h         | 17.3.4/387       |

#### **SMC** memory map

# 17.3.1 Power Mode Protection Register (SMC\_PMPROT)

This register provides protection for entry into any low power run or stop mode. The actual enabling of the low power run or stop mode occurs by configuring the power mode control register (PMCTRL).

The PMPROT register can be written only once after any system reset.

If the MCU is configured for a disallowed or reserved power mode, the MCU remains in its current power mode. For example, if the MCU is in normal RUN mode and AVLP is 0, an attempt to enter VLPR mode using PMCTRL[RUNM] is blocked and the RUNM bits remain 00b, indicating the MCU is still in normal run mode.

#### NOTE

This register is reset on Chip Reset not VLLS and by reset types that trigger Chip Reset not VLLS. It is unaffected by reset types that do not trigger Chip Reset not VLLS. See the Reset details for more information.





#### **Memory Map and Register Descriptions**

#### SMC\_PMPROT field descriptions

| Field           | Description                                                                                                                                                                                                                                                                      |  |  |  |  |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 7–6<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                               |  |  |  |  |
| 5<br>AVLP       | Allow very low power modes  Provided the appropriate control bits are set up in PMCTRL, this write-once bit allows the MCU to enter any very low power modes: VLPR, VLPW, and VLPS.  0 VLPR, VLPW and VLPS are not allowed 1 VLPR, VLPW and VLPS are allowed                     |  |  |  |  |
| 4<br>Reserved   | This read-only bit is reserved and always has the value zero.                                                                                                                                                                                                                    |  |  |  |  |
| 3<br>ALLS       | Allow low leakage stop mode  This write once bit allows the MCU to enter any low leakage stop mode (LLS) provided the appropriate control bits are set up in PMCTRL.  0 LLS is not allowed 1 LLS is allowed                                                                      |  |  |  |  |
| 2<br>Reserved   | This read-only bit is reserved and always has the value zero.                                                                                                                                                                                                                    |  |  |  |  |
| 1<br>AVLLS      | Allow very low leakage stop mode  Provided the appropriate control bits are set up in PMCTRL, this write once bit allows the MCU to enter any very low leakage stop mode: VLLS3, VLLS2 and VLLS1.  0 VLLS3, VLLS2 and VLLS1 are not allowed 1 VLLS3, VLLS2 and VLLS1 are allowed |  |  |  |  |
| 0<br>Reserved   | This read-only bit is reserved and always has the value zero.                                                                                                                                                                                                                    |  |  |  |  |

# 17.3.2 Power Mode Control Register (SMC\_PMCTRL)

The PMCTRL register controls entry into low power run and stop modes, provided that the selected power mode is allowed via an appropriate setting of the protection (PMPROT) register.

#### **NOTE**

This register is reset on Chip POR not VLLS and by reset types that trigger Chip POR not VLLS. It is unaffected by reset types that do not trigger Chip POR not VLLS. See the Reset details for more information.

Address: SMC\_PMCTRL is FFFF\_8118h base + 1h offset = FFFF\_8119h



## **SMC\_PMCTRL** field descriptions

| Field         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |
|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 7             | Low Power Wake Up on Interrupt                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |
| LPWUI         | Causes the SMC to exit to normal RUN mode when any active MCU interrupt occurs while in a VLP mode (VLPR, VLPW or VLPS).                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |
|               | NOTE: If VLPS mode was entered directly from RUN mode, the SMC will always exit back to normal RUN mode regardless of the LPWUI setting.                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |
|               | NOTE: LPWUI should only be modified while the system is in RUN mode i.e. when PMSTAT=RUN.                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |
|               | <ul> <li>The system remains in a VLP mode on an interrupt</li> <li>The system exits to normal RUN mode on an interrupt</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |
| 6–5           | Run Mode Control                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |
| RUNM          | When written, this field causes entry into the selected run mode. Writes to this field are blocked if the protection level has not been enabled using the PMPROT register. This field is cleared by hardware on any exit to normal RUN mode.                                                                                                                                                                                                                                                                            |  |  |  |  |
|               | <b>NOTE:</b> RUNM should only be set to VLPR when PMSTAT=RUN. Once written to VLPR, RUNM should not be written back to RUN until PMSTAT=VLPR.                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |
|               | NOTE: RUNM should only be set to RUN when PMSTAT=VLPR. Once written to RUN, RUNM should not be written back to VLPR until PMSTAT=RUN.                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |
|               | 00 Normal run mode (RUN)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |
|               | 01 Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |
|               | <ul><li>10 Very low power run mode (VLPR)</li><li>11 Reserved</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |
| 4<br>Reserved | This read-only bit is reserved and always has the value zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |
| 3<br>STOPA    | Stop Aborted                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |
| STOPA         | When set, this read-only status bit indicates an interrupt or reset occured during the previous stop mode entry sequence, preventing the system from entering that mode. This bit is cleared by hardware at the beginning of any stop mode entry sequence and is set if the sequence was aborted.                                                                                                                                                                                                                       |  |  |  |  |
|               | 0 The previous stop mode entry was successsful.                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |
|               | 1 The previous stop mode entry was aborted.                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |
| 2–0           | Stop Mode Control                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |
| STOPM         | When written, this field controls entry into the selected stop mode when the next STOP instruction is executed with STOPE=1 and WAITE=0. When this field is set to VLLS, the VLLSCTRL register is used to further select the particular VLLS sub-mode (VLLS3, VLLS2 or VLLS1) which will be entered. Writes to this field are blocked if the protection level has not been enabled using the PMPROT register. After any system reset, this field is cleared by hardware on any successful write to the PMPROT register. |  |  |  |  |

Table continues on the next page...

#### **Memory Map and Register Descriptions**

#### SMC\_PMCTRL field descriptions (continued)

| Field | Description                                       |  |  |
|-------|---------------------------------------------------|--|--|
|       | 000 Normal stop (STOP)                            |  |  |
|       | 001 Reserved                                      |  |  |
|       | 010 Very low power stop (VLPS)                    |  |  |
|       | 011 Low leakage stop (LLS)                        |  |  |
|       | 100 Very low leakage stop (VLLS3, VLLS2 or VLLS1) |  |  |
|       | 101 Reserved                                      |  |  |
|       | 110 Reseved                                       |  |  |
|       | 111 Reserved                                      |  |  |

# 17.3.3 VLLS Control Register (SMC\_VLLSCTRL)

The VLLSCTRL register selects which VLLSx mode is entered if STOPM=VLLS and controls power to FlexRAM during VLLS2.

#### NOTE

This register is reset on Chip POR not VLLS and by reset types that trigger Chip POR not VLLS. It is unaffected by reset types that do not trigger Chip POR not VLLS. See the Reset details for more information.

Address: SMC\_VLLSCTRL is FFFF\_8118h base + 2h offset = FFFF\_811Ah



#### SMC\_VLLSCTRL field descriptions

| Field           | Description                                                                                                                                                                                                                          |  |  |  |
|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 7–5<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                   |  |  |  |
| 4<br>RAM2PO     | RAM2 Power Option  This bit controls powering of RAM partition 2 in VLLS2 mode.  NOTE: See the device's Chip Configuration details for the size and location of RAM parition 2  0 RAM2 not powered in VLLS2  1 RAM2 powered in VLLS2 |  |  |  |
| 3<br>Reserved   | This read-only bit is reserved and always has the value zero.                                                                                                                                                                        |  |  |  |

Table continues on the next page...

#### SMC\_VLLSCTRL field descriptions (continued)

| Field        | Description                                                                        |  |  |  |
|--------------|------------------------------------------------------------------------------------|--|--|--|
| 2–0<br>VLLSM | VLLS Mode Control  This field controls which VLLS sub-mode to enter if STOPM=VLLS. |  |  |  |
| VELOW        |                                                                                    |  |  |  |
|              | 000 Reserved                                                                       |  |  |  |
|              | 001 VLLS1                                                                          |  |  |  |
|              | 010 VLLS2                                                                          |  |  |  |
|              | 011 VLLS3                                                                          |  |  |  |
|              | 100 Reserved                                                                       |  |  |  |
|              | 101 Reserved                                                                       |  |  |  |
|              | 110 Reseved                                                                        |  |  |  |
|              | 111 Reserved                                                                       |  |  |  |

# 17.3.4 Power Mode Status Register (SMC\_PMSTAT)

PMSTAT is a read-only, one-hot register which indicates the current power mode of the system.

#### **NOTE**

This register is reset on Chip POR not VLLS and by reset types that trigger Chip POR not VLLS. It is unaffected by reset types that do not trigger Chip POR not VLLS. See the Reset details for more information.

Address: SMC\_PMSTAT is FFFF\_8118h base + 3h offset = FFFF\_811Bh



#### **SMC\_PMSTAT** field descriptions

| Field         | Description                                                             |  |  |  |
|---------------|-------------------------------------------------------------------------|--|--|--|
| 7<br>Reserved | This read-only bit is reserved and always has the value zero.           |  |  |  |
| 6–0<br>PMSTAT | NOTE: When debug is enabled, the PMSTAT will not update to STOP or VLPS |  |  |  |
|               | 000_0001 Current power mode is RUN                                      |  |  |  |
|               | 000_0010 Current power mode is STOP                                     |  |  |  |
|               | 000_0100 Current power mode is VLPR                                     |  |  |  |
|               | 000_1000 Current power mode is VLPW                                     |  |  |  |

Table continues on the next page...

#### **Functional Description**

# **SMC\_PMSTAT** field descriptions (continued)

| Field | Description                         |  |  |
|-------|-------------------------------------|--|--|
|       | 001_0000 Current power mode is VLPS |  |  |
|       | 010_0000 Current power mode is LLS  |  |  |
|       | 100_0000 Current power mode is VLLS |  |  |

# 17.4 Functional Description

## 17.4.1 Power Mode Transitions

The following figure shows the power mode state transitions available on the chip. Any reset always brings the MCU back to the normal run state.



Figure 17-5. Power Mode State Diagram

The following table defines triggers for the various state transitions shown in the previous figure.

Table 17-7. Power mode transition triggers

| Transition # | From | То   | Trigger Conditions      |
|--------------|------|------|-------------------------|
| 1            | RUN  | WAIT | WAITE=1,                |
|              |      |      | Issue STOP instruction. |
|              |      |      | See note. <sup>1</sup>  |
|              | WAIT | RUN  | Interrupt or Reset      |

Table continues on the next page...

#### **Functional Description**

Table 17-7. Power mode transition triggers (continued)

| Transition # | From        | То          | Trigger Conditions                                                                                                   |
|--------------|-------------|-------------|----------------------------------------------------------------------------------------------------------------------|
| 2            | RUN         | STOP        | PMCTRL[RUNM]=00, PMCTRL[STOPM]=000, STOPE=1, WAITE=0,                                                                |
|              |             |             | Issue STOP instruction.                                                                                              |
|              |             |             | See note. <sup>1</sup>                                                                                               |
|              | STOP        | RUN         | Interrupt or Reset                                                                                                   |
| 3            | RUN         | VLPR        | Reduce system, bus and core frequency to 2 MHz or less,                                                              |
|              |             |             | Flash access limited to 1MHz.                                                                                        |
|              |             |             | Set PMPROT[AVLP]=1, PMCTRL[RUNM]=10.                                                                                 |
|              | VLPR        | RUN         | Set PMCTRL[RUNM]=00 or                                                                                               |
|              |             |             | Interrupt with PMCTRL[LPWUI] =1 or                                                                                   |
|              |             |             | Reset.                                                                                                               |
| 4            | VLPR        | VLPW        | WAITE=1,                                                                                                             |
|              |             |             | Issue STOP instruction.                                                                                              |
|              |             |             | See note.1                                                                                                           |
|              | VLPW        | VLPR        | Interrupt with PMCTRL[LPWUI]=0                                                                                       |
| 5            | VLPW        | RUN         | Interrupt with PMCTRL[LPWUI]=1 or                                                                                    |
|              |             |             | Reset                                                                                                                |
| 6            | VLPR        | VLPS        | PMCTRL[STOPM]=000 or 010, STOPE=1, WAITE=0,                                                                          |
|              |             |             | Issue STOP instruction.                                                                                              |
|              |             |             | See note.1                                                                                                           |
|              | VLPS        | VLPR        | Interrupt with PMCTRL[LPWUI]=0                                                                                       |
|              |             |             | NOTE: If VLPS was entered directly from RUN, hardware will not allow this transition and will force exit back to RUN |
| 7            | RUN         | VLPS        | PMPROT[AVLP]=1, PMCTRL[STOPM]=010, STOPE=1, WAITE=0,                                                                 |
|              |             |             | Issue STOP instruction.                                                                                              |
|              |             |             | See note.1                                                                                                           |
|              | VLPS        | RUN         | Interrupt with PMCTRL[LPWUI]=1 or                                                                                    |
|              |             |             | Interrupt with PMCTRL[LPWUI]=0 and VLPS mode was entered directly from RUN or                                        |
|              |             |             | Reset                                                                                                                |
| 8            | RUN         | VLLS(3,2,1) | PMPROT[AVLLS]=1, PMCTRL[STOPM]=100,<br>VLLSCTRL[VLLSM]=001(VLLS1) or 010 (VLLS2) or 011<br>(VLLS3), STOPE=1, WAITE=0 |
|              |             |             | Issue STOP instruction.                                                                                              |
|              | VLLS(3,2,1) | RUN         | Wakeup from enabled LLWU input source or RESET pin                                                                   |

Table continues on the next page...

Table 17-7. Power mode transition triggers (continued)

| Transition # | From | То          | Trigger Conditions                                                                                                   |
|--------------|------|-------------|----------------------------------------------------------------------------------------------------------------------|
| 9            | VLPR | VLLS(3,2,1) | PMPROT[AVLLS]=1, PMCTRL[STOPM]=100,<br>VLLSCTRL[VLLSM]=001(VLLS1) or 010 (VLLS2) or 011<br>(VLLS3), STOPE=1, WAITE=0 |
|              |      |             | Issue STOP instruction.                                                                                              |
| 10           | RUN  | LLS         | PMPROT[ALLS]=1, PMCTRL[STOPM]=011, STOPE=1, WAITE=0                                                                  |
|              |      |             | Issue STOP instruction.                                                                                              |
|              | LLS  | RUN         | Wakeup from enabled LLWU input source or RESET pin                                                                   |
| 11           | VLPR | LLS         | PMPROT[ALLS]=1, PMCTRL[STOPM]=011, STOPE=1, WAITE=0                                                                  |
|              |      |             | Issue STOP instruction.                                                                                              |

<sup>1.</sup> If debug is enabled, the core clock remains to support debug.

# 17.4.2 Power Mode Entry/Exit Sequencing

When entering or exiting low power modes, the system must conform to an orderly sequence to manage transitions safely. The SMC manages the system's entry to and exit from all power modes. The following diagram illustrates the connections of the SMC with other system components in the chip that are necessary to sequence the system through all power modes.



Figure 17-6. Low power system components and connections

# 17.4.2.1 Stop Mode Entry Sequence

Entry to a low power stop mode (STOP, VLPS, LLS, VLLSx) is initiated by CPU execution of the STOP instruction. After the stop instruction is executed, the following sequence occurs:

- 1. The CPU clock is gated off immediately.
- 2. Requests are made to all non-CPU bus masters to enter stop mode.
- 3. After all masters have acknowledged they are ready to enter stop mode, requests are made to all bus slaves to enter stop mode.
- 4. After all slaves have acknowledged they are ready to enter stop mode, all system and bus clocks are gated off.
- 5. Clock generators are disabled in the MCG.
- 6. The on-chip regulator in the PMC and internal power switches are configured to meet the power consumption goals for the targeted low power mode.

392

# 17.4.2.2 Stop Mode Exit Sequence

Exit from a low power stop mode is initiated by either a reset or an interrupt event. The following sequence then executes to restore the system to a run mode (RUN or VLPR):

- 1. The on-chip regulator in the PMC and internal power switches are restored.
- 2. Clock generators are enabled in the MCG.
- 3. System and bus clocks are enabled to all masters and slaves.
- 4. The CPU clock is enabled and the CPU begins servicing the reset or interrupt that initiated the exit from the low power stop mode.

# 17.4.2.3 Aborted Stop Mode Entry

If an interrupt or a reset occurs during a stop entry sequence, the SMC can abort the transition early and return to RUN mode without completely entering the stop mode. An aborted entry is only possible if the reset or interrupt occurs before the PMC begins the transition to stop mode regulation. After this point, the interrupt or reset is ignored until the PMC has completed its transition to stop mode regulation. When an aborted stop mode entry sequence occurs, the SMC's PMCTRL[STOPA] bit is set to 1.

#### Restriction

Aborted entry to a stop mode is not supported when an interrupt occurs during a transition from VLPR mode to any stop mode.

#### 17.4.2.4 Transition to Wait Modes

For wait modes (WAIT and VLPW), the CPU clock is gated off with all other clocking continuing, as in RUN and VLPR mode operation. Some modules that support stop-in-wait functionality have their clocks disabled in these configurations.

# 17.4.2.5 Transition from Stop Modes to Debug Mode

The debugger module supports a transition from STOP, WAIT, VLPS, and VLPW back to a Halted state when the debugger has been enabled (ENBDM is 1). This transition is initiated by executing a BDC BACKGROUND command. As part of this transition, system clocking is re-established and is equivalent to the normal RUN and VLPR mode clocking configuration.

#### 17.4.3 Run Modes

The device contains two different run modes:

- Run
- Very low power run (VLPR)

#### 17.4.3.1 RUN Mode

This is the normal operating mode for the device.

This mode is selected after any internal reset including LVD and when the BKGD/MS pin is high after a POR exit or a BDM-initiated force reset. When the ColdFire processor exits reset, it fetches initial 32-bit values for the supervisor stack pointer and program counter from locations 0x00\_0000 and 0x00\_0004 respectively and user code execution begins.

- The processor reads the start SP (SP\_main) from vector-table offset 0x000
- The processor reads the start PC from vector-table offset 0x004
- LR is set to 0xFFFF\_FFFF.

To reduce power in this mode, disable unused modules by clearing the peripherals corresponding clock gating control bit in the SIM's registers.

# 17.4.3.2 Very Low Power Run (VLPR) Mode

In VLPR mode, the on-chip voltage regulator is put into a stop mode regulation state. In this state, the regulator is designed to supply enough current to the MCU over a reduced frequency. To further reduce power in this mode, disable the clocks to unused modules using the peripherals' corresponding clock gating control bits in the SIM's registers.

Before entering this mode, the following conditions must be met:

- The MCG must be configured in a mode which is supported during VLPR. See the Power Management details for information about these MCG modes.
- The maximum frequencies of the system, bus, flash, and core are restricted. See the Power Management details about which frequencies are supported.
- Mode protection must be set to allow VLP modes (PMPROT[AVLP] is 1).
- PMCTRL[RUNM] is set to 10b to enter VLPR.
- Flash programming/erasing is not allowed.

While in VLPR mode, the regulator is slow responding and cannot manage fast load transitions. Therefore, do not change the clock frequency. In addition, do not modify the clock source or BDIV in the MCG module, the module clock enables in the SIM, or any clock divider registers.

To re-enter normal run mode, simply clear RUNM. The PMSTAT register is a read-only status register that can be used to determine when the system has completed an exit to RUN mode. When PMSTAT=RUN, the system is in run regulation mode and the MCU can run at full speed in any clock mode. If a higher execution frequency is desired, poll the PMSTAT register until it is set to RUN when returning from VLPR mode.

VLPR mode also provides the option to return to run regulation if any interrupt occurs. Implement this option by setting the low power wakeup on interrupt (LPWUI) bit in the PMCTRL register. Any reset always causes an exit from VLPR and returns the device run mode after the MCU exits its reset flow. The RUNM bits are cleared by hardware on any interrupt when LPWUI is set or on any reset.

#### 17.4.3.3 BDM in Run and VLPR Mode

If the MCU is unsecure and BDM mode is enabled, then the MCU can be fully debugged using the BDM in RUN and VLPR modes. If XCSR[ENBDM] = 0, before entering active BDM mode, the host must write XCSR[ENBDM] = 1 before sending a BACKGROUND command.

## 17.4.4 Wait Modes

This device contains two different wait modes:

- Wait
- Very low power wait (VLPW)

#### 17.4.4.1 WAIT Mode

WAIT mode is entered by executing a STOP instruction after configuring the device appropriately. Upon execution of the STOP instruction, the CPU enters a low-power state in which it is not clocked.

#### **Functional Description**

The V1 ColdFire core does not differentiate between STOP and WAIT modes. Both are considered STOP mode from the core's perspective. The difference between the two is at the device level. In STOP mode, most peripheral clocks are shut down. In WAIT mode, the global peripheral clocks continue to run and can be enabled or disabled on a per peripheral basis using clock gating control bits in the SIM.

When an interrupt request occurs, the CPU exits WAIT mode and resumes processing in RUN mode, beginning with the stacking operations leading to the interrupt service routine.

A system reset will cause an exit from WAIT mode, returning the device to normal RUN mode.

# 17.4.4.2 Very Low Power Wait (VLPW) Mode

VLPW mode is entered by executing a STOP instruction while the MCU is in very low power run (VLPR) mode and configured as per Table 17-7.

In VLPW, the on-chip voltage regulator remains in its stop regulation state. In this state, the regulator is designed to supply enough current to the MCU over a reduced frequency. To further reduce power in this mode, disable the clocks to unused modules by clearing the peripherals' corresponding clock gating control bits in the SIM.

VLPR mode restrictions also apply to VLPW.

VLPW mode provides the option to return to full-regulated normal RUN mode if any enabled interrupt occurs. This is done by setting the low power wake up on interrupt (LPWUI) bit in the PMCTRL register. Wait for the PMSTAT register to set to RUN before increasing the frequency.

If the LPWUI bit is clear, when an interrupt from VLPW occurs, the device returns to VLPR mode to execute the interrupt service routine.

A system reset will cause an exit from WAIT mode, returning the device to normal RUN mode.

## 17.4.4.3 BDM in Wait and VLPW Mode

If the MCU is unsecure, BDM mode is enabled, and XCSR[ENBDM] is set prior to entering wait then the MCU can support debugging using the BDM.

396

While the MCU is in wait mode, there are some restrictions on which background debug commands can be used. Only the BACKGROUND command and memory-access-with-status commands are available when the MCU is in wait mode. The memory-access-with-status commands do not allow memory access, but they report an error indicating that the MCU is in either stop or wait mode.

The BACKGROUND command can be used to wake the MCU from wait mode and enter active background mode. After entering halt mode, all background commands are available.

## **17.4.5 Stop Modes**

This device contains a variety of stop modes to meet your application needs. The stop modes range from:

• a stopped CPU, with all I/O, logic and memory states retained, certain asynchronous mode peripherals operating

to:

• a powered down CPU, with only I/O and a small register file retained, very few asynchronous mode peripherals operating, while the remainder of the MCU is powered down

The choice of stop mode depends upon the user's application, where power usage and state retention versus functional needs are traded off.

The various stop modes are selected by setting the appropriate bits in the power mode protection (PMPROT) and power mode control (PMCTRL) registers. The selected mode is entered following the execution of a STOP instruction.

The available stop modes are:

- Normal stop (STOP)
- Very low power stop (VLPS)
- Low leakage stop (LLS)
- Very low leakage stop 3 (VLLS3)
- Very low leakage stop 2 (VLLS2)
- Very low leakage stop 1 (VLLS1)

#### 17.4.5.1 STOP Mode

STOP mode is entered by executing a STOP instruction after configuring the device as per Table 17-7. In STOP mode, the bus and CPU clocks are halted. If the ENBDM is set prior to entering stop, only the peripheral clocks are halted.

The MCG module can be configured to leave the reference clocks running.

#### NOTE

If neither the WAITE or STOPE bit is set when the CPU executes a STOP instruction, the MCU will not enter either of the stop modes. Executing a STOP instruction under this condition results in either a system reset if the instruction-related reset disable bit in the CPU control register is cleared (CPUCR[IRD]=0) or an illegal instruction exception if it is set (CPUCR[IRD]=1).

A module capable of providing an asynchronous interrupt to the device takes the device out of STOP mode and returns the device to normal RUN mode. Refer to the device's Power Management chapter for peripheral, I/O, and memory operation in STOP mode. When an interrupt request occurs, the CPU exits STOP mode and resumes processing, beginning with the stacking operations leading to the interrupt service routine.

A system reset will cause an exit from STOP mode, returning the device to normal RUN mode via a MCU reset.

## 17.4.5.2 Very Low Power Stop (VLPS) Mode

VLPS mode can be entered in one of two ways:

- Executing a STOP instruction while the MCU is in VLPR mode and STOPM=010 or 000 in the PMCTRL register.
- Executing a STOP instruction while the MCU is in normal RUN mode and STOPM=010 in the PMCTRL register. Note, when VLPS is entered directly from RUN mode, exit to VLPR is disabled by hardware and the system will always exit back to RUN.

In VLPS, the on-chip voltage regulator remains in its stop regulation state as in VLPR.

A module capable of providing an asynchronous interrupt to the device takes the device out of VLPS and returns the device to VLPR mode provided the LPWUI bit is clear.

If LPWUI is set, the device returns to normal RUN mode upon an interrupt request. The PMSTAT register must be set to RUN before allowing the system to return to a frequency higher than that allowed in VLPR mode.

A system reset will cause a VLPS exit, returning the device to normal RUN mode.

## 17.4.5.3 BDM in Stop and VLPS Modes

If the MCU is unsecure, BDM is enabled, XCSR[ENBDM] is set prior to entering stop, and the current mode is RUN (debug from VLPR is not supported), then the MCU can support debugging using BDM. To support debugging, the CPU clock remains running after the STOP instruction is executed. While the MCU is in stop or VLPS mode, some restrictions affect which background debug commands can be used. Only the BACKGROUND command and memory-access-with-status commands are available when the MCU is in stop mode. The memory-access-with-status commands do not allow memory access, but they report an error indicating that the MCU is in either stop or wait mode.

The BACKGROUND command can wake the MCU from stop or VLPS mode and cause it to enter active background mode. After entering halt mode, all background commands are available.

#### NOTE

When the chip is attempting to enter VLPS mode directly from RUN mode while BDM is enabled, the MCU regulator remains in full regulation. In other words, when BDM is enabled, the regulation of the chip retains its previous state when executing STOP.

## 17.4.5.4 Low-Leakage Stop (LLS) Mode

Low leakage stop (LLS) mode can be entered from normal RUN or VLPR modes.

By executing a STOP instruction while the MCU is in RUN or VLPR mode and device configured as per Table 17-7 the MCU will enter LLS mode.

In LLS, the on-chip voltage regulator is in stop regulation. Most of the peripherals are put in a state-retention mode that does not allow them to operate while in LLS.

Before entering LLS mode, user should configure the low leakage wake up (LLWU) module to enable the desired wakeup sources. The available wakeup sources in LLS are detailed in the Chip Configuration details for this device.

After wakeup from LLS, the device returns to normal RUN mode with a pending LLWU module interrupt. In the LLWU interrupt service routine (ISR), user can poll the LLWU module wakeup flags to determine the source of the wakeup.

#### **NOTE**

The LLWU interrupt must not be masked by the interrupt controller to avoid a scenario where the system does not fully exit stop mode on an LLS recovery.

An asserted RESET pin will cause an exit from LLS mode returning the device to normal RUN mode. When LLS is exiting via the  $\overline{RESET}$  pin, the PIN and WAKEUP bits are set in the SRSL register of the reset control module (RCM).

## 17.4.5.5 Very Low-Leakage Stop (VLLS3,2,1) Modes

This device contains three very low leakage modes: VLLS3, VLLS2, and VLLS1. VLLS is often used in this document to refer to all three VLLS3, VLLS2 and VLLS1 modes.

All three of the VLLS modes can be entered from normal RUN or VLPR modes.

By executing a STOP instruction while the MCU is in a run mode and configured as per Table 17-7 the MCU will enter the configured VLLS mode.

In VLLS, the on-chip voltage regulator is in its stop-regulation state while most digital logic is powered off.

In VLLS, configure the LLWU module to enable the desired wakeup sources. The available wakeup sources in VLLS are detailed LLWU's Chip Configuration details for this device.

When entering VLLS, each I/O pin is latched as configured before executing VLLS. Since all digital logic in the MCU is powered off, all port and peripheral data is lost during VLLS. This information must be restored before ACKISO in the PMC is set.

An asserted  $\overline{RESET}$  pin will cause an exit from any VLLS mode returning the device to normal RUN mode. When exiting VLLS via the  $\overline{RESET}$  pin, the PIN and WAKEUP bits are set in the SRSL register of the reset control module (RCM).

#### 17.4.5.6 BDM in LLS and VLLSx Modes

No debug is available while the MCU is in LLS or a VLLSx mode. LLS is a state retention mode and all debug operation can continue after wakeup from LLS, unless system wakeup is a reset event.

Entering a VLLSx mode causes all the BDM and debug controls and settings to be powered off. Therefore, any breakpoints or other debug triggers set prior to entering the VLLSx mode are lost.

To support debug immediately after a wakeup from a VLLSx mode, the VLLDBGREQ bit in the SIM's SOPT4 register can be set before entering the VLLSx mode via a BDM write. If this bit is set, the wakeup from a VLLSx mode (except for wakeup via the RESET pin) causes the CPU to enter active background mode immediately upon exiting the VLLSx mode.

**Functional Description** 

# **Chapter 18 Power Management Controller (PMC)**

#### 18.1 Introduction

The PMC contains the internal voltage regulator, power on reset (POR), and low voltage detect system.

#### 18.2 Features

- Internal voltage regulator
- Active POR providing brown-out detect
- Low-voltage detect supporting two low-voltage trip points with four warning levels per trip point

## 18.3 Low-Voltage Detect (LVD) System

This device includes a system to protect against low-voltage conditions to protect memory contents and control MCU system states during supply voltage variations. The system is comprised of a power-on reset (POR) circuit and a LVD circuit with a user-selectable trip voltage: high  $(V_{LVDH})$  or low  $(V_{LVDL})$ . The trip voltage is selected by the LVDSC1[LVDV] bits. The LVD is disabled upon entering VLPx, LLS, and VLLSx modes.

Two flags are available to indicate the status of the low-voltage detect system:

- The low voltage detect flag (LVDF) operates in a level sensitive manner. The LVDF bit is set when the supply voltage falls below the selected trip point (VLVD). The LVDF bit is cleared by writing one to the LVDACK bit, but only if the internal supply has returned above the trip point; otherwise, the LVDF bit remains set.
- The low voltage warning flag (LVWF) operates in a level sensitive manner. The LVWF bit is set when the supply voltage falls below the selected monitor trip point

#### Low-Voltage Detect (LVD) System

(VLVW). The LVWF bit is cleared by writing one to the LVWACK bit, but only if the internal supply has returned above the trip point; otherwise, the LVWF bit remains set.

## 18.3.1 LVD Reset Operation

By setting the LVDRE bit, the LVD generates a reset upon detection of a low voltage condition. The low voltage detection threshold is determined by the LVDV bits. After an LVD reset occurs, the LVD system holds the MCU in reset until the supply voltage rises above this threshold. The LVD bit in the SRS register is set following an LVD or power-on reset.

## 18.3.2 LVD Interrupt Operation

By configuring the LVD circuit for interrupt operation (LVDIE set and LVDRE clear), LVDSC1[LVDF] is set and an LVD interrupt request occurs upon detection of a low voltage condition. The LVDF bit is cleared by writing one to the LVDSC1[LVDACK] bit.

## 18.3.3 Low-Voltage Warning (LVW) Interrupt Operation

The LVD system contains a low voltage warning flag (LVWF) to indicate that the supply voltage is approaching, but is above, the LVD voltage. The LVW also has an interrupt, which is enabled by setting the LVDSC2[LVWIE] bit. If enabled, an LVW interrupt request occurs when the LVWF is set. LVWF is cleared by writing one to the LVDSC2[LVWACK] bit.

The LVDSC2[LVWV] bits select one of four trip voltages:

- Highest (V<sub>LVW4</sub>)
- Two mid-levels (V<sub>LVW3</sub> and V<sub>LVW2</sub>)
- Lowest (V<sub>LVW1</sub>)

## 18.4 I/O Retention

When in LLS mode, the I/O pins are held in their input or output state. Upon wakeup, the power management control (PMC) is re-enabled, goes through a power up sequence to full regulation, and releases the logic from state retention mode. The I/O are released immediately after ACKISO clears, soon after a wakeup or reset event. In the case of LLS exit via a RESET pin, the I/O default to their reset state.

When in VLLS modes, the I/O states are held on a wakeup event (with the exception of wakeup by reset event) until the wakeup has been acknowledged via a write to the ACKISO bit. In the case of VLLS exit via a RESET pin, the I/O are released and default to their reset state. In this case, no write to the ACKISO is needed.

## 18.5 Memory Map and Register Descriptions

PMC register details follow.

#### **NOTE**

Different portions of PMC registers are reset only by particular reset types. Each register's description provides details. For more information about the types of reset on this chip, refer to the Reset details.

#### **PMC** memory map

| Absolute address (hex) | Register name                                                 | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|------------------------|---------------------------------------------------------------|--------------------|--------|-------------|------------------|
| FFFF_8100              | Low Voltage Detect Status and Control 1 Register (PMC_LVDSC1) | 8                  | R/W    | 10h         | 18.5.1/406       |
| FFFF_8101              | Low Voltage Detect Status and Control 2 Register (PMC_LVDSC2) | 8                  | R/W    | 00h         | 18.5.2/407       |
| FFFF_8102              | Regulator Status and Control Register (PMC_REGSC)             | 8                  | R/W    | 04h         | 18.5.3/408       |

## 18.5.1 Low Voltage Detect Status and Control 1 Register (PMC\_LVDSC1)

This register contains status and control bits to support the low voltage detect function. This register should be written during the reset initialization program to set the desired controls even if the desired settings are the same as the reset settings.

While the device is in the very low power or low leakage modes, the LVD system is disabled regardless of LVDSC1 settings. To protect systems that must have LVD always on, configure the SMC's power mode protection register (PMPROT) to disallow any very low power or low leakage modes from being enabled.

See the device's data sheet for the exact LVD trip voltages.

#### **NOTE**

The LVDV bits are reset solely on a POR Only event. The register's other bits are reset on Chip Reset not VLLS. For more information about these reset types, refer to the Reset details.





#### PMC\_LVDSC1 field descriptions

| Field       | Description                                                                                                             |
|-------------|-------------------------------------------------------------------------------------------------------------------------|
| 7<br>LVDF   | Low-Voltage Detect Flag                                                                                                 |
|             | This read-only status bit indicates a low-voltage detect event.                                                         |
|             | 0 Low-voltage event not detected                                                                                        |
|             | 1 Low-voltage event detected                                                                                            |
| 6<br>LVDACK | Low-Voltage Detect Acknowledge                                                                                          |
|             | This write-only bit is used to acknowledge low voltage detection errors (write 1 to clear LVDF). Reads always return 0. |
| 5<br>LVDIE  | Low-Voltage Detect Interrupt Enable                                                                                     |
|             | Enables hardware interrupt requests for LVDF.                                                                           |
|             | 0 Hardware interrupt disabled (use polling)                                                                             |
|             | 1 Request a hardware interrupt when LVDF = 1.                                                                           |

Table continues on the next page...

#### PMC\_LVDSC1 field descriptions (continued)

| Field       | Description                                                                                          |
|-------------|------------------------------------------------------------------------------------------------------|
| 4<br>LVDRE  | Low-Voltage Detect Reset Enable                                                                      |
|             | This write-once bit enables LVDF events to generate a hardware reset. Additional writes are ignored. |
|             | 0 LVDF does not generate hardware resets                                                             |
|             | 1 Force an MCU reset when LVDF = 1                                                                   |
| 3–2         | This read-only bitfield is reserved and always has the value zero.                                   |
| Reserved    |                                                                                                      |
| 1–0<br>LVDV | Low-Voltage Detect Voltage Select                                                                    |
|             | Selects the LVD trip point voltage (V <sub>LVD</sub> ).                                              |
|             | 00 Low trip point selected (V LVD = V LVDL)                                                          |
|             | 01 High trip point selected (V LVD = V LVDH )                                                        |
|             | 10 Reserved                                                                                          |
|             | 11 Reserved                                                                                          |

## 18.5.2 Low Voltage Detect Status and Control 2 Register (PMC\_LVDSC2)

This register contains status and control bits to support the low voltage warning function.

While the device is in the very low power or low leakage modes, the LVD system is disabled regardless of LVDSC2 settings.

See the device's data sheet for the exact LVD trip voltages.

#### **NOTE**

The LVW trip voltages depend on LVWV and LVDV bits.

#### **NOTE**

The LVWV bits are reset solely on a POR Only event. The register's other bits are reset on Chip Reset not VLLS. For more information about these reset types, refer to the Reset details.

Address: PMC\_LVDSC2 is FFFF\_8100h base + 1h offset = FFFF\_8101h



#### **Memory Map and Register Descriptions**

#### PMC\_LVDSC2 field descriptions

| Field           | Description                                                                                                                                                                                                          |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>LVWF       | Low-Voltage Warning Flag                                                                                                                                                                                             |
|                 | This read-only status bit indicates a low-voltage warning event. LVWF is set when V $_{\text{Supply}}$ transitions below the trip point or after reset and V $_{\text{Supply}}$ is already below V $_{\text{LVW}}$ . |
|                 | Low-voltage warning event not detected                                                                                                                                                                               |
|                 | 1 Low-voltage warning event detected                                                                                                                                                                                 |
| 6<br>LVWACK     | Low-Voltage Warning Acknowledge                                                                                                                                                                                      |
|                 | This write-only bit is used to acknowledge low voltage warning errors (write 1 to clear LVWF). Reads always return 0.                                                                                                |
| 5               | Low-Voltage Warning Interrupt Enable                                                                                                                                                                                 |
| LVWIE           | Enables hardware interrupt requests for LVWF.                                                                                                                                                                        |
|                 | 0 Hardware interrupt disabled (use polling)                                                                                                                                                                          |
|                 | 1 Request a hardware interrupt when LVWF = 1.                                                                                                                                                                        |
| 4–2<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                   |
| 1–0<br>LVWV     | Low-Voltage Warning Voltage Select                                                                                                                                                                                   |
| LVVV            | Selects the LVW trip point voltage (V <sub>LVW</sub> ). The actual voltage for the warning depends on LVDSC1[LVDV].                                                                                                  |
|                 | 00 Low trip point selected (V LVW = V LVW1 )                                                                                                                                                                         |
|                 | 01 Mid 1 trip point selected (V LVW = V LVW2)                                                                                                                                                                        |
|                 | 10 Mid 2 trip point selected (V LVW = V LVW3)                                                                                                                                                                        |
|                 | 11 High trip point selected (V LVW = V LVW4)                                                                                                                                                                         |

## 18.5.3 Regulator Status and Control Register (PMC\_REGSC)

The power management controller contains an internal voltage regulator. The voltage regulator design uses a bandgap reference that is also available through a buffer as input to certain internal peripherals, such as the CMP and ADC. The internal regulator provides a status bit (REGONS) indicating the regulator is in run regulation.

#### **NOTE**

This register is reset on Chip Reset not VLLS and by reset types that trigger Chip Reset not VLLS. See the Reset details for more information.

Address: PMC\_REGSC is FFFF\_8100h base + 2h offset = FFFF\_8102h



## PMC\_REGSC field descriptions

| Field           | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–4<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 3<br>ACKISO     | Acknowledge Isolation  Reading this bit indicates whether certain peripherals and the I/O pads are in a latched state as a result of having been in a VLLS mode. Writing one to this bit when it is set releases the I/O pads and certain peripherals to their normal run mode state.  NOTE: After recovering from a VLLS mode, user should restore chip configuration before clearing ACKISO. In particular, pin configuration for enabled LLWU wakeup pins should be restored to |
|                 | avoid any LLWU flag from being falsely set when ACKISO is cleared.  O Peripherals and I/O pads are in normal run state  Certain peripherals and I/O pads are in an isolated and latched state                                                                                                                                                                                                                                                                                      |
| 2<br>REGONS     | Regulator in Run Regulation Status  This read-only bit provides the current status of the internal voltage regulator.  Regulator is in stop regulation or in transition to/from it Regulator is in run regulation                                                                                                                                                                                                                                                                  |
| 1<br>Reserved   | This read-only bit is reserved and always has the value zero. This reserved bit must remain cleared (set to 0).                                                                                                                                                                                                                                                                                                                                                                    |
| 0<br>BGBE       | Bandgap Buffer Enable  Enables the bandgap buffer.  0 Bandgap buffer not enabled 1 Bandgap buffer enabled                                                                                                                                                                                                                                                                                                                                                                          |



## Chapter 19 DMA Controller

#### 19.1 Introduction

This chapter describes the direct memory access (DMA) controller module. It provides an overview of the module and describes in detail its signals and programming model. The latter sections of this chapter describe operations, features, and supported data transfer modes in detail.

#### Note

The designation *n* is used throughout this section to refer to registers or signals associated with one of the four identical DMA channels: DMA0, DMA1, DMA2, or DMA3.

#### **19.1.1 Overview**

The DMA controller module enables fast transfers of data, providing an efficient way to move blocks of data with minimal processor interaction. The DMA module, shown in the following figure, has four channels that allow byte, word, or longword data transfers. Each channel has a dedicated source address register (SARn), destination address register (DARn), status register (DSRn), byte count register (BCRn), and control register (DCRn). Collectively, the combined program-visible registers associated with each channel define a transfer control descriptor (TCD). All transfers are dual address, moving data from a source memory location to a destination memory location with the module operating as a 32-bit bus master connected to the system bus. The programming model is accessed through a 32-bit connection with the slave peripheral bus. DMA data transfers may be explicitly initiated by software or by peripheral hardware requests.

The following figure is a simplified block diagram of the 4-channel DMA controller.

Introduction



Figure 19-1. 4-Channel DMA Block Diagram

The terms *peripheral request* and *DREQ* refer to a DMA request from one of the on-chip peripherals or package pins. The DMA provides hardware handshake signals: either a DMA acknowledge (DACK) or a done indicator back to the peripheral. For details on the connections associated with DMA request inputs, see the register definition for DMA Request Control (DMAREQC).

## 19.1.2 Features

The DMA controller module features:

• Four independently programmable DMA controller channels

- Dual-address transfers via 32-bit master connection to the system bus
- Data transfers in 8-, 16-, or 32-bit blocks
- Continuous-mode or cycle-steal transfers from software or peripheral initiation
- One programmable input selected from 16 possible peripheral requests per channel
- Automatic hardware acknowledge/done indicator from each channel
- Independent source and destination address registers
- Optional modulo addressing and automatic updates of source and destination addresses
- Independent transfer sizes for source and destination
- Optional auto-alignment feature for source or destination accesses
- Optional automatic single or double channel linking
- Programming model accessed via 32-bit slave peripheral bus
- Channel arbitration on transfer boundaries using fixed priority scheme

## 19.2 DMA Transfer Overview

The DMA module can move data within system memory (including memory and peripheral devices) with minimal processor intervention, greatly improving overall system performance. The DMA module consists of four independent, functionally equivalent channels, so references to DMA in this chapter apply to any of the channels. It is not possible to address all four channels at once.

The processor generates DMA requests by setting DCR[START]. Each channel can be programmed to select one peripheral request from a set of 16 possible request inputs. The channels support cycle-steal and continuous transfer modes; see Transfer Requests (Cycle-Steal and Continuous Modes).

The DMA controller supports dual-address transfers using its bus master connection to the system bus. The DMA channels support transfers up to 32 data bits in size and have the same memory map addressibility as the processor.

#### **Memory Map and Registers**

• Dual-address transfers—A dual-address transfer consists of a read followed by a write and is initiated by a request using the DCRn[START] bit or by a peripheral DMA request. The read data is temporarily held in the DMA channel hardware until the write operation. Two types of single transfers occur: a read from a source address followed by a write to a destination address. See the following figure.



Figure 19-2. Dual-Address Transfer

Any operation involving a DMA channel follows the same three steps:

- 1. Channel initialization—The transfer control descriptor, contained in the channel registers, is loaded with address pointers, a byte-transfer count, and control information using accesses from the slave peripheral bus.
- 2. Data transfer—The DMA accepts requests for data transfers. Upon receipt of a request, it provides address and bus control for the transfers via its master connection to the system bus and temporary storage for the read data. The channel performs one or more source read and destination write data transfers.
- 3. Channel termination—Occurs after the operation is finished successfully or due to an error. The channel indicates the operation status in the channel's DSR, described in the definitions of the DMA Status Registers (DSRn) and Byte Count Registers (BCRn).

## 19.3 Memory Map and Registers

Descriptions of each register and its bit assignments follow. Modifying DMA control registers during a transfer can result in undefined operation. The following table shows the mapping of DMA controller registers. The DMA programming model is accessed via

the slave peripheral bus. The concatenation of the source and destination address registers, the status and byte count register, and the control register creates a 128-bit transfer control descriptor (TCD) that defines the operation of each DMA channel.

#### **DMA** memory map

| Absolute<br>address<br>(hex) | Register name                                            |    | Access | Reset value | Section/<br>page |
|------------------------------|----------------------------------------------------------|----|--------|-------------|------------------|
| FFFF_E400                    | DMA Request Control Register (DMA_REQC)                  | 32 | R/W    | 0000_0000h  | 19.3.1/415       |
| FFFF_E500                    | Source Address Register (DMA_SAR0)                       | 32 | R/W    | 0000_0000h  | 19.3.2/419       |
| FFFF_E504                    | Destination Address Register (DMA_DAR0)                  | 32 | R/W    | 0000_0000h  | 19.3.3/420       |
| FFFF_E508                    | DMA Status Register / Byte Count Register (DMA_DSR_BCR0) | 32 | R/W    | 0000_0000h  | 19.3.4/420       |
| FFFF_E50C                    | DMA Control Register (DMA_DCR0)                          | 32 | R/W    | 0000_0000h  | 19.3.5/422       |
| FFFF_E510                    | Source Address Register (DMA_SAR1)                       | 32 | R/W    | 0000_0000h  | 19.3.2/419       |
| FFFF_E514                    | Destination Address Register (DMA_DAR1)                  | 32 | R/W    | 0000_0000h  | 19.3.3/420       |
| FFFF_E518                    | DMA Status Register / Byte Count Register (DMA_DSR_BCR1) | 32 | R/W    | 0000_0000h  | 19.3.4/420       |
| FFFF_E51C                    | DMA Control Register (DMA_DCR1)                          | 32 | R/W    | 0000_0000h  | 19.3.5/422       |
| FFFF_E520                    | Source Address Register (DMA_SAR2)                       | 32 | R/W    | 0000_0000h  | 19.3.2/419       |
| FFFF_E524                    | Destination Address Register (DMA_DAR2)                  | 32 | R/W    | 0000_0000h  | 19.3.3/420       |
| FFFF_E528                    | DMA Status Register / Byte Count Register (DMA_DSR_BCR2) | 32 | R/W    | 0000_0000h  | 19.3.4/420       |
| FFFF_E52C                    | DMA Control Register (DMA_DCR2)                          | 32 | R/W    | 0000_0000h  | 19.3.5/422       |
| FFFF_E530                    | Source Address Register (DMA_SAR3)                       | 32 | R/W    | 0000_0000h  | 19.3.2/419       |
| FFFF_E534                    | Destination Address Register (DMA_DAR3)                  | 32 | R/W    | 0000_0000h  | 19.3.3/420       |
| FFFF_E538                    | DMA Status Register / Byte Count Register (DMA_DSR_BCR3) | 32 | R/W    | 0000_0000h  | 19.3.4/420       |
| FFFF_E53C                    | DMA Control Register (DMA_DCR3)                          | 32 | R/W    | 0000_0000h  | 19.3.5/422       |

## 19.3.1 DMA Request Control Register (DMA\_REQC)

This register provides a software-controlled connection matrix for DMA requests and acknowledges. Each channel supports 16 possible peripheral requests. The register is programmed to select one peripheral request from the available sources for each channel of the DMA controller. Additionally, the register routes a DMA acknowledge from the channel back to the appropriate peripheral. Writing to this register determines the exact routing of the DMA requests to each of the four channels of the DMA module.

If DCRn[ERQ] is set and the channel is idle, the assertion of the appropriate DREQn signal activates channel n.

#### **Memory Map and Registers**

The connections of the DMA request sources to the specific channels are device-specific. Refer to the Chip Configuration details for more information.





#### **DMA\_REQC** field descriptions

| Field             | Description                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>CFSM0       | Clear state machine control 0  This bit clears the state machine for DMA channel 0. When changing the DMAC0 field to select a different requester, set (write 1) to the CFSM0 bit to clear the channel's state machine. Writing 0 to this bit has no effect. The bit always reads as 0.                                                                                                                                       |
|                   | 0 No effect                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                   | 1 Clear state machine for DMA channel 0                                                                                                                                                                                                                                                                                                                                                                                       |
| 30–28<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                                                                                                                                                                            |
| 27–24<br>DMAC0    | DMA channel 0  This four-bit field defines the logical connection between the DMA requesters and DMA channel 0. There are sixteen possible requesters per channel and any request from the possible sources can be routed to the DMA channel 0. Effectively, the DMAREQC register provides a software-controlled routing matrix of the DMA request signals to the 4 channels of the DMA module. DMACO controls DMA channel 0. |
|                   | The DMA also uses this register to control the broadcasting of acknowledge/done signals back to the selected peripheral to complete the hardware-initiated data transfer.                                                                                                                                                                                                                                                     |
|                   | The definition of the 16 possible DMA request sources for each channel is device specific. Refer to the Chip Configuration details for more information.                                                                                                                                                                                                                                                                      |
|                   | 0000 Select request 0 as the source 0001 Select request 1 as the source 0010 Select request 2 as the source 0011 Select request 3 as the source 0100 Select request 4 as the source                                                                                                                                                                                                                                           |

Table continues on the next page...

#### MCF51JF128 Reference Manual, Rev. 2, 03/2011

Freescale Semiconductor, Inc.

416

## **DMA\_REQC** field descriptions (continued)

| Field             | Description                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                   | 0101 Select request 5 as the source                                                                                                                                                                                                                                                                                                                                                                            |
|                   | 0110 Select request 6 as the source                                                                                                                                                                                                                                                                                                                                                                            |
|                   | 0111 Select request 7 as the source                                                                                                                                                                                                                                                                                                                                                                            |
|                   | 1000 Select request 8 as the source                                                                                                                                                                                                                                                                                                                                                                            |
|                   | 1001 Select request 9 as the source 1010 Select request 10 as the source                                                                                                                                                                                                                                                                                                                                       |
|                   | 1010 Select request 10 as the source 1011 Select request 11 as the source                                                                                                                                                                                                                                                                                                                                      |
|                   | 1100 Select request 12 as the source                                                                                                                                                                                                                                                                                                                                                                           |
|                   | 1101 Select request 13 as the source                                                                                                                                                                                                                                                                                                                                                                           |
|                   | 1110 Select request 14 as the source                                                                                                                                                                                                                                                                                                                                                                           |
|                   | 1111 Select request 15 as the source                                                                                                                                                                                                                                                                                                                                                                           |
| 23<br>CFSM1       | Clear state machine control 1                                                                                                                                                                                                                                                                                                                                                                                  |
| OI GWI            | This bit clears the state machine for DMA channel 1. When changing the DMAC1 field to select a different requester, set (write 1) to the CFSM1 bit to clear the channel's state machine. Writing 0 to this bit has no effect. The bit always reads as 0.                                                                                                                                                       |
|                   | No effect     Clear state machine for DMA channel 1                                                                                                                                                                                                                                                                                                                                                            |
| 22–20<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                                                                                                                                                             |
| 19–16             | DMA channel 1                                                                                                                                                                                                                                                                                                                                                                                                  |
| DMAC1             | This four-bit field defines the logical connection between the DMA requesters and DMA channel 1. There are sixteen possible requesters per channel and any request from the possible sources can be routed to the DMA channel 1. Effectively, the DMAREQC register provides a software-controlled routing matrix of the DMA request signals to the 4 channels of the DMA module. DMAC1 controls DMA channel 1. |
|                   | The DMA also uses this register to control the broadcasting of acknowledge/done signals back to the selected peripheral to complete the hardware-initiated data transfer.                                                                                                                                                                                                                                      |
|                   | The definition of the 16 possible DMA request sources for each channel is device specific. Refer to the Chip Configuration details for more information.                                                                                                                                                                                                                                                       |
|                   | 0000 Select request 0 as the source                                                                                                                                                                                                                                                                                                                                                                            |
|                   | 0001 Select request 1 as the source                                                                                                                                                                                                                                                                                                                                                                            |
|                   | 0010 Select request 2 as the source                                                                                                                                                                                                                                                                                                                                                                            |
|                   | 0011 Select request 3 as the source                                                                                                                                                                                                                                                                                                                                                                            |
|                   | 0100 Select request 4 as the source                                                                                                                                                                                                                                                                                                                                                                            |
|                   | 0101 Select request 5 as the source                                                                                                                                                                                                                                                                                                                                                                            |
|                   | 0110 Select request 6 as the source                                                                                                                                                                                                                                                                                                                                                                            |
|                   | 0111 Select request 7 as the source                                                                                                                                                                                                                                                                                                                                                                            |
|                   | 1000 Select request 8 as the source                                                                                                                                                                                                                                                                                                                                                                            |
|                   | 1001 Select request 9 as the source                                                                                                                                                                                                                                                                                                                                                                            |
|                   | 1010 Select request 10 as the source                                                                                                                                                                                                                                                                                                                                                                           |
|                   | 1011 Select request 11 as the source                                                                                                                                                                                                                                                                                                                                                                           |
|                   | 1100 Select request 12 as the source                                                                                                                                                                                                                                                                                                                                                                           |
|                   | <ul><li>1101 Select request 13 as the source</li><li>1110 Select request 14 as the source</li></ul>                                                                                                                                                                                                                                                                                                            |
|                   | 1111 Select request 14 as the source                                                                                                                                                                                                                                                                                                                                                                           |
|                   | 1111 Ooloot toquest to as the source                                                                                                                                                                                                                                                                                                                                                                           |

Table continues on the next page...

## Memory Map and Registers

## **DMA\_REQC** field descriptions (continued)

| Field             | Description                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |
|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 15                | Clear state machine control 2                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |
| CFSM2             | This bit clears the state machine for DMA channel 2. When changing the DMAC2 field to select a different requester, set (write 1) to the CFSM2 bit to clear the channel's state machine. Writing 0 to this bit has no effect. The bit always reads as 0.                                                                                                                                                       |  |  |  |  |  |
|                   | 0 No effect                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |
|                   | 1 Clear state machine for DMA channel 2                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |
| 14–12<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |
| 11–8              | DMA channel 2                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |
| DMAC2             | This four-bit field defines the logical connection between the DMA requesters and DMA channel 2. There are sixteen possible requesters per channel and any request from the possible sources can be routed to the DMA channel 2. Effectively, the DMAREQC register provides a software-controlled routing matrix of the DMA request signals to the 4 channels of the DMA module. DMAC2 controls DMA channel 2. |  |  |  |  |  |
|                   | The DMA also uses this register to control the broadcasting of acknowledge/done signals back to the selected peripheral to complete the hardware-initiated data transfer.                                                                                                                                                                                                                                      |  |  |  |  |  |
|                   | The definition of the 16 possible DMA request sources for each channel is device specific. Refer to the Chip Configuration details for more information.                                                                                                                                                                                                                                                       |  |  |  |  |  |
|                   | 0000 Select request 0 as the source                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |
|                   | 0001 Select request 1 as the source                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |
|                   | 0010 Select request 2 as the source                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |
|                   | 0011 Select request 3 as the source                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |
|                   | 0100 Select request 4 as the source                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |
|                   | 0101 Select request 5 as the source                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |
|                   | 0110 Select request 6 as the source                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |
|                   | 0111 Select request 7 as the source                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |
|                   | 1000 Select request 8 as the source                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |
|                   | 1001 Select request 9 as the source                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |
|                   | 1010 Select request 10 as the source                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |
|                   | 1011 Select request 11 as the source                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |
|                   | 1100 Select request 12 as the source                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |
|                   | 1101 Select request 13 as the source                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |
|                   | 1110 Select request 14 as the source                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |
|                   | 1111 Select request 15 as the source                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |
| 7<br>CFSM3        | Clear state machine control 3                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |
|                   | This bit clears the state machine for DMA channel 3. When changing the DMAC3 field to select a different requester, set (write 1) to the CFSM3 bit to clear the channel's state machine. Writing 0 to this bit has no effect. The bit always reads as 0.                                                                                                                                                       |  |  |  |  |  |
|                   | 0 No effect 1 Clear state machine for DMA channel 3                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |
| 6–4<br>Reserved   | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |
| 3-0<br>DMAC3      | DMA channel 3                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |

Table continues on the next page...

#### DMA\_REQC field descriptions (continued)

| Field |           | Description                                                                                                                                                                                                                                                                                                                                                                         |
|-------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | are sixte | ur-bit field defines the logical connection between the DMA requesters and DMA channel 3. There een possible requesters per channel and any request from the possible sources can be routed to A channel 3. Effectively, the DMAREQC register provides a software-controlled routing matrix of A request signals to the 4 channels of the DMA module. DMAC3 controls DMA channel 3. |
|       |           | MA also uses this register to control the broadcasting of acknowledge/done signals back to the depripheral to complete the hardware-initiated data transfer.                                                                                                                                                                                                                        |
|       |           | finition of the 16 possible DMA request sources for each channel is device specific. Refer to the onfiguration details for more information.                                                                                                                                                                                                                                        |
|       | 0000      | Select request 0 as the source                                                                                                                                                                                                                                                                                                                                                      |
|       | 0001      | Select request 1 as the source                                                                                                                                                                                                                                                                                                                                                      |
|       | 0010      | Select request 2 as the source                                                                                                                                                                                                                                                                                                                                                      |
|       | 0011      | Select request 3 as the source                                                                                                                                                                                                                                                                                                                                                      |
|       | 0100      | Select request 4 as the source                                                                                                                                                                                                                                                                                                                                                      |
|       | 0101      | Select request 5 as the source                                                                                                                                                                                                                                                                                                                                                      |
|       | 0110      | Select request 6 as the source                                                                                                                                                                                                                                                                                                                                                      |
|       | 0111      | Select request 7 as the source                                                                                                                                                                                                                                                                                                                                                      |
|       | 1000      | Select request 8 as the source                                                                                                                                                                                                                                                                                                                                                      |
|       | 1001      | Select request 9 as the source                                                                                                                                                                                                                                                                                                                                                      |
|       | 1010      | Select request 10 as the source                                                                                                                                                                                                                                                                                                                                                     |
|       | 1011      | Select request 11 as the source                                                                                                                                                                                                                                                                                                                                                     |
|       | 1100      | Select request 12 as the source                                                                                                                                                                                                                                                                                                                                                     |
|       | 1101      | Select request 13 as the source                                                                                                                                                                                                                                                                                                                                                     |
|       | 1110      | Select request 14 as the source                                                                                                                                                                                                                                                                                                                                                     |
|       | 1111      | Select request 15 as the source                                                                                                                                                                                                                                                                                                                                                     |

## 19.3.2 Source Address Register (DMA\_SARn)

Addresses: DMA\_SAR0 is FFFF\_E400h base + 100h offset = FFFF\_E500h

DMA\_SAR1 is FFFF\_E400h base + 110h offset = FFFF\_E510h

DMA\_SAR2 is FFFF\_E400h base + 120h offset = FFFF\_E520h

DMA\_SAR3 is FFFF\_E400h base + 130h offset = FFFF\_E530h



#### DMA\_SARn field descriptions

| Field | Description                                                                                                                                                                                                                                                             |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | Each SAR contains the byte address used by the DMA controller to read data. The SARn is typically aligned on a 0-modulo-ssize boundary—that is, on the natural alignment of the source data. Because the system only supports 24-bit addresses, SARn[31:24] is ignored. |

## 19.3.3 Destination Address Register (DMA\_DARn)



#### DMA\_DARn field descriptions

| Field       | Description                                                                                                                                                                                                                                                                   |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–0<br>DAR | Each DAR contains the byte address used by the DMA controller to write data. The DARn is typically aligned on a 0-modulo-dsize boundary—that is, on the natural alignment of the destination data. Because the system only supports 24-bit addresses, DARn[31:24] is ignored. |

## 19.3.4 DMA Status Register / Byte Count Register (DMA\_DSR\_BCRn)

DSR and BCR are two logical registers that occupy one 32-bit address. DSRn occupies bits 31–24, and BCRn occupies bits 23–0. DSRn contains flags indicating the channel status, and BCRn contains the number of bytes yet to be transferred for a given block.

On the successful completion of the write transfer, BCRn decrements by 1, 2, or 4 for byte, word, or longword accesses, respectively. BCRn is cleared if a 1 is written to DSR[DONE].

In response to an event, the DMA controller writes to the appropriate DSRn bit. Only a write to DSRn[DONE] results in action. DSRn[DONE] is set when the block transfer is complete.

When a transfer sequence is initiated and BCRn[BCR] is not a multiple of 4 or 2 when the DMA is configured for longword or word transfers, respectively, DSRn[CE] is set and no transfer occurs.



#### DMA\_DSR\_BCRn field descriptions

| Field          | Description                                                                                                                                                                                                                                                                                                                                              |
|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>Reserved | This read-only bit is reserved and always has the value zero.                                                                                                                                                                                                                                                                                            |
| 30<br>CE       | Configuration error  Occurs when BCR, SAR, or DAR does not match the requested transfer size, or if SSIZE, DSIZE is set to an unsupported value, or if BCR equals 0 when the DMA receives a start condition. CE is cleared at hardware reset or by writing a 1 to the DONE bit.  0 No configuration error exists.  1 A configuration error has occurred. |
| 29<br>BES      | Bus error on source  BES is cleared at hardware reset or by writing a 1 to the DONE bit.  O No bus error occurred.  The DMA channel terminated with a bus error during the read portion of a transfer.                                                                                                                                                   |
| 28<br>BED      | Bus error on destination  BED is cleared at hardware reset or by writing a 1 to the DONE bit.  O No bus error occurred.  The DMA channel terminated with a bus error during the write portion of a transfer.                                                                                                                                             |
| 27<br>Reserved | This read-only bit is reserved and always has the value zero.                                                                                                                                                                                                                                                                                            |

Table continues on the next page...

W

Reset

#### **Memory Map and Registers**

#### DMA\_DSR\_BCRn field descriptions (continued)

| Field       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 26<br>REQ   | Request  O No request is pending or the channel is currently active. Cleared when the channel is selected.  The DMA channel has a transfer remaining and the channel is not selected.                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 25<br>BSY   | Busy  0 DMA channel is inactive. Cleared when the DMA has finished the last transaction.  1 BSY is set the first time the channel is enabled after a transfer is initiated.                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 24<br>DONE  | Transactions done  Set when all DMA controller transactions complete as determined by transfer count, or based on error conditions. When BCR reaches zero, DONE is set when the final transfer completes successfully. DONE can also be used to abort a transfer by resetting the status bits. When a transfer completes, software must clear DONE before reprogramming the DMA.  0 DMA transfer is not yet complete. Writing a 0 has no effect.  1 DMA transfer completed. Writing a 1 to this bit clears all DMA status bits and should be used in an interrupt service routine to clear the DMA interrupt and error bits. |
| 23–0<br>BCR | This field contains the number of bytes yet to be transferred for a given block.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

## 19.3.5 DMA Control Register (DMA\_DCRn)

Addresses: DMA\_DCR0 is FFFF\_E400h base + 10Ch offset = FFFF\_E50Ch DMA\_DCR1 is FFFF\_E400h base + 11Ch offset = FFFF\_E51Ch

DMA\_DCR2 is FFFF\_E400h base + 12Ch offset = FFFF\_E52Ch

DMA\_DCR3 is FFFF\_E400h base + 13Ch offset = FFFF\_E53Ch



## DMA\_DCRn field descriptions

| Field             | Description                                                                                                                                                                                                                                                                                                                                                    |
|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>EINT        | Enable interrupt on completion of transfer                                                                                                                                                                                                                                                                                                                     |
|                   | Determines whether an interrupt is generated by completing a transfer or by the occurrence of an error condition.                                                                                                                                                                                                                                              |
|                   | <ul><li>0 No interrupt is generated.</li><li>1 Interrupt signal is enabled.</li></ul>                                                                                                                                                                                                                                                                          |
| 30<br>ERQ         | Enable peripheral request                                                                                                                                                                                                                                                                                                                                      |
|                   | <b>CAUTION:</b> Be careful: a collision can occur between the START bit and D_REQ when the ERQ bit is 1.                                                                                                                                                                                                                                                       |
|                   | <ul> <li>Peripheral request is ignored.</li> <li>Enables peripheral request, defined by the appropriate REQC[DMACn] field, to initiate transfer. A software-initiated request (setting the START bit) is always enabled.</li> </ul>                                                                                                                            |
| 29                | Cycle steal                                                                                                                                                                                                                                                                                                                                                    |
| CS                | <ul> <li>DMA continuously makes read/write transfers until the BCR decrements to 0.</li> <li>Forces a single read/write transfer per request.</li> </ul>                                                                                                                                                                                                       |
| 28<br>AA          | Auto-align  AA and SIZE bits determine whether the source or destination is auto-aligned; that is, transfers are optimized based on the address and size.                                                                                                                                                                                                      |
|                   | <ul> <li>Auto-align disabled</li> <li>If SSIZE indicates a transfer no smaller than DSIZE, source accesses are auto-aligned; otherwise, destination accesses are auto-aligned. Source alignment takes precedence over destination alignment. If auto-alignment is enabled, the appropriate address register increments, regardless of DINC or SINC.</li> </ul> |
| 27–25<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                                                                                                             |
| 24–23<br>Reserved | This bitfield is reserved.                                                                                                                                                                                                                                                                                                                                     |
| rieserveu         | CAUTION: Must be written as zero; otherwise, undefined behavior results.                                                                                                                                                                                                                                                                                       |
| 22                | Source increment                                                                                                                                                                                                                                                                                                                                               |
| SINC              | Controls whether the source address increments after each successful transfer.                                                                                                                                                                                                                                                                                 |
|                   | No change to SAR after a successful transfer.  The CAR increments by 1.0.4 as determined by the transfer size.                                                                                                                                                                                                                                                 |
| 21–20             | The SAR increments by 1, 2, 4 as determined by the transfer size.  Source size                                                                                                                                                                                                                                                                                 |
| SSIZE             | Determines the data size of the source bus cycle for the DMA controller.                                                                                                                                                                                                                                                                                       |
|                   | <ul> <li>Longword</li> <li>Byte</li> <li>Word</li> <li>Reserved (generates a configuration error (DSRn[CE]) if incorrectly specified at time of channel activation)</li> </ul>                                                                                                                                                                                 |
| 19<br>DINC        | Destination increment                                                                                                                                                                                                                                                                                                                                          |

Table continues on the next page...

#### **Memory Map and Registers**

## DMA\_DCRn field descriptions (continued)

| Field          | Description                                                                                                                                                                   |
|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                | Controls whether the destination address increments after each successful transfer.                                                                                           |
|                | No change to the DAR after a successful transfer.                                                                                                                             |
|                | 1 The DAR increments by 1, 2, 4 depending upon the size of the transfer.                                                                                                      |
| 18–17<br>DSIZE | Destination size                                                                                                                                                              |
|                | Determines the data size of the destination bus cycle for the DMA controller.                                                                                                 |
|                |                                                                                                                                                                               |
|                | 00 Longword                                                                                                                                                                   |
|                | 01 Byte<br>10 Word                                                                                                                                                            |
|                | 11 Reserved (generates a configuration error (DSRn[CE]) if incorrectly specified at time of channel                                                                           |
|                | activation)                                                                                                                                                                   |
| 16             | Start transfer                                                                                                                                                                |
| START          | O DMA inactive                                                                                                                                                                |
|                | DMA inactive     The DMA begins the transfer in accordance to the values in the TCDn. START is cleared                                                                        |
|                | automatically after one module clock and always reads as logic 0.                                                                                                             |
| 15–12          | Source address modulo                                                                                                                                                         |
| SMOD           | Defines the size of the source data circular buffer used by the DMA Controller. If enabled (SMOD is non-                                                                      |
|                | zero), the buffer base address is located on a boundary of the buffer size. The value of this boundary is                                                                     |
|                | based upon the initial source address (SAR). The base address should be aligned to a 0-modulo-(circular                                                                       |
|                | buffer size) boundary. Misaligned buffers are not possible. The boundary is forced to the value determined by the upper address bits in the field selection.                  |
|                |                                                                                                                                                                               |
|                | 0000 Buffer disabled                                                                                                                                                          |
|                | 0001 Circular buffer size is 16 bytes 0010 Circular buffer size is 32 bytes                                                                                                   |
|                | 0010 Circular buffer size is 32 bytes<br>0011 Circular buffer size is 64 bytes                                                                                                |
|                | 0100 Circular buffer size is 128 bytes                                                                                                                                        |
|                | 0101 Circular buffer size is 256 bytes                                                                                                                                        |
|                | 0110 Circular buffer size is 512 bytes                                                                                                                                        |
|                | 0111 Circular buffer size is 1 KB                                                                                                                                             |
|                | 1000 Circular buffer size is 2 KB                                                                                                                                             |
|                | 1001 Circular buffer size is 4 KB                                                                                                                                             |
|                | 1010 Circular buffer size is 8 KB 1011 Circular buffer size is 16 KB                                                                                                          |
|                | 1100 Circular buffer size is 32 KB                                                                                                                                            |
|                | 1101 Circular buffer size is 64 KB                                                                                                                                            |
|                | 1110 Circular buffer size is 128 KB                                                                                                                                           |
|                | 1111 Circular buffer size is 256 KB                                                                                                                                           |
| 11–8           | Destination address modulo                                                                                                                                                    |
| DMOD           | Defines the size of the destination data circular buffer used by the DMA Controller. If enabled (DMOD                                                                         |
|                | value is non-zero), the buffer base address is located on a boundary of the buffer size. The value of this                                                                    |
|                | boundary depends on the initial destination address (DAR). The base address should be aligned to a 0-                                                                         |
|                | modulo-(circular buffer size) boundary. Misaligned buffers are not possible. The boundary is forced to the value determined by the upper address bits in the field selection. |
| 1              | value determined by the upper dudress bles in the neid selection.                                                                                                             |

Table continues on the next page...

## DMA\_DCRn field descriptions (continued)

| Field       | Description                                                                                                                                                                                                      |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             | 0000 Buffer disabled                                                                                                                                                                                             |
|             | 0001 Circular buffer size is 16 bytes                                                                                                                                                                            |
|             | 0010 Circular buffer size is 32 bytes                                                                                                                                                                            |
|             | 0011 Circular buffer size is 64 bytes                                                                                                                                                                            |
|             | 0100 Circular buffer size is 128 bytes                                                                                                                                                                           |
|             | 0101 Circular buffer size is 256 bytes                                                                                                                                                                           |
|             | 0110 Circular buffer size is 512 bytes                                                                                                                                                                           |
|             | 0111 Circular buffer size is 1 KB                                                                                                                                                                                |
|             | 1000 Circular buffer size is 2 KB<br>1001 Circular buffer size is 4 KB                                                                                                                                           |
|             | 1010 Circular buffer size is 4 KB                                                                                                                                                                                |
|             | 1010 Circular buller size is 6 KB                                                                                                                                                                                |
|             | 1100 Circular buffer size is 32 KB                                                                                                                                                                               |
|             | 1101 Circular buffer size is 64 KB                                                                                                                                                                               |
|             | 1110 Circular buffer size is 128 KB                                                                                                                                                                              |
|             | 1111 Circular buffer size is 256 KB                                                                                                                                                                              |
| 7           |                                                                                                                                                                                                                  |
| D_REQ       | Disable request                                                                                                                                                                                                  |
| D_MEQ       | DMA hardware automatically clears the corresponding DCRn[ERQ] bit when the byte count register                                                                                                                   |
|             | reaches zero.                                                                                                                                                                                                    |
|             | 0 ERQ bit is not affected.                                                                                                                                                                                       |
|             | 1 ERQ bit is cleared when the BCR is exhausted.                                                                                                                                                                  |
| 6           | This read-only bit is reserved and always has the value zero.                                                                                                                                                    |
| Reserved    | This road only bit is received and anways has the value 2016.                                                                                                                                                    |
| 5–4         | Link channel control                                                                                                                                                                                             |
| LINKCC      |                                                                                                                                                                                                                  |
|             | Allows DMA channels to have their transfers linked. The current DMA channel triggers a DMA request to the linked channels (LCH1 or LCH2) depending on the condition described by the LINKCC bits.                |
|             |                                                                                                                                                                                                                  |
|             | If not in cycle steal mode (DCRn[CS]=0) and LINKCC equals 01 or 10, no link to LCH1 occurs.                                                                                                                      |
|             | If LINKCC equals 01, a link to LCH1 is created after each cycle-steal transfer performed by the current                                                                                                          |
|             | DMA channel is completed. As the last cycle-steal is performed and the BCR reaches zero, then the link to LCH1 is closed and a link to LCH2 is created.                                                          |
|             | to Lot IT is closed and a link to Lot iz is created.                                                                                                                                                             |
|             | 00 No channel-to-channel linking                                                                                                                                                                                 |
|             | 01 Perform a link to channel LCH1 after each cycle-steal transfer followed by a link to LCH2 after the BCR decrements to zero                                                                                    |
|             | 10 Perform a link to channel LCH1 after each cycle-steal transfer                                                                                                                                                |
|             | 11 Perform a link to channel LCH1 after the BCR decrements to zero                                                                                                                                               |
| 2.0         | Link channel 1                                                                                                                                                                                                   |
| 3–2<br>LCH1 |                                                                                                                                                                                                                  |
| LOTTI       | Indicates the DMA channel assigned as link channel 1. The link channel number cannot be the same as the currently executing channel, and generates a configuration error if this is attempted (DSRn[CE] is set). |
|             | 00 DMA Channel 0                                                                                                                                                                                                 |
|             | 01 DMA Channel 1                                                                                                                                                                                                 |
|             | 10 DMA Channel 2                                                                                                                                                                                                 |
|             | 11 DMA Channel 3                                                                                                                                                                                                 |
|             |                                                                                                                                                                                                                  |

Table continues on the next page...

#### **Functional Description**

#### DMA\_DCRn field descriptions (continued)

| Field       | Description                                                                                                                                                                                                                                                                                          |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1–0<br>LCH2 | Link channel 2 Indicates the DMA channel assigned as link channel 2. The link channel number cannot be the same as the currently executing channel, and generates a configuration error if this is attempted (DSRn[CE] is set).  00 DMA Channel 0 01 DMA Channel 1 10 DMA Channel 2 11 DMA Channel 3 |

## 19.4 Functional Description

In the following discussion, the term DMA request implies that DCR*n*[START] is set, or DCRn[ERQ] is set and then followed by assertion of the properly selected DMA peripheral request. The START bit is cleared when the channel is activated.

Before initiating a dual-address access, the DMA module verifies that DCRn[SSIZE] and DCRn[DSIZE] are consistent with the source and destination addresses. If they are not consistent, the configuration error bit, DSRn[CE], is set. If misalignment is detected, no transfer occurs, DSRn[CE] is set, and, depending on the DCR configuration, an interrupt event may be issued. If the auto-align bit, DCRn[AA], is set, error checking is performed on the appropriate registers.

A read/write transfer sequence reads data from the source address and writes it to the destination address. The number of bytes transferred is the largest of the sizes specified by DCRn[SSIZE] and DCRn[DSIZE] in the DMA Control Registers (DCRn).

Source and destination address registers (SARn and DARn) can be programmed in the DCRn to increment at the completion of a successful transfer.

## 19.4.1 Transfer Requests (Cycle-Steal and Continuous Modes)

The DMA channel supports software-initiated or peripheral-initiated requests. A request is issued by setting DCRn[START] or when the selected peripheral request asserts and DCRn[ERQ] is set. Setting DCRn[ERQ] enables recognition of the peripheral DMA requests. Selecting between cycle-steal and continuous modes minimizes bus usage for either type of request.

- Cycle-steal mode (DCRn[CS] = 1)—Only one complete transfer from source to destination occurs for each request. If DCRn[ERQ] is set, the request is peripheral initiated. A software-initiated request is enabled by setting DCRn[START].
- Continuous mode (DCRn[CS] = 0)—After a software-initiated or peripheral request, the DMA continuously transfers data until BCRn reaches zero. The DMA performs the specified number of transfers, then retires the channel.

In either mode, the crossbar switch performs independent arbitration on each slave port after each transaction.

## 19.4.2 Channel Initialization and Startup

Before a data transfer starts, the channel's transfer control descriptor must be initialized with information describing configuration, request-generation method, and pointers to the data to be moved.

#### 19.4.2.1 Channel Prioritization

The four DMA channels are prioritized based on number, with channel 0 having highest priority and channel 3 having the lowest, that is, channel 0 > channel 1 > channel 2 > channel 3.

Simultaneous peripheral requests activate the channels based on this priority order. Once activated, a channel runs to completion as defined by DCRn[CS] and BCRn.

## 19.4.2.2 Programming the DMA Controller Module

There is no mechanism within the DMA module itself to prevent writes to programming model registers during DMA accesses and corrupting the data transfer.

General guidelines for programming the DMA are:

- The DMAREQC register is configured to select the peripheral DMA requests and assign them to the individual DMA channels.
- Next, the TCD*n* is initialized.

#### **Functional Description**

- The SAR*n* is loaded with the source (read) address. If the transfer is from a peripheral device to memory, the source address is the location of the peripheral data register. If the transfer is from memory to a peripheral device or memory, the source address is the starting address of the data block. This can be any appropriately-aligned address.
- The DAR*n* is initialized with the destination (write) address. If the transfer is from a peripheral device to memory, or from memory to memory, the DAR*n* is loaded with the starting address of the data block to be written. If the transfer is from memory to a peripheral device, DAR*n* is loaded with the address of the peripheral data register. This address can be any appropriately-aligned address.
- SARn and DARn change after each data transfer depending on DCRn[SSIZE, DSIZE, SINC, DINC, SMOD, DMOD] and the starting addresses. Increment values can be 1, 2, 4 for byte, word, or longword transfers, respectively. If the address register is programmed to remain unchanged, the register is not incremented after the data transfer.
- BCR*n*[BCR] must be loaded with the total number of bytes to be transferred. It is decremented by 1, 2, or 4 at the end of each transfer, depending on the transfer size. DSR*n*[DONE] must be cleared for channel startup.
- As soon as the channel has been initialized, it may be started by setting DCRn[START] or a properly-selected peripheral DMA request, depending on the status of DCRn[ERQ]. For a software-initiated transfer, the channel can be started by setting DCRn[START] as part of a single 32-bit write to the last longword of the TCDn, that is, it is not required to write the DCRn with START cleared and then perform a second write to explicitly set START.
- Programming the channel for a software-initiated request causes the channel to request the system bus and start transferring data immediately. If the channel is programmed for peripheral-initiated request, a properly-selected peripheral DMA request must be asserted before the channel begins the system bus transfers.
- The hardware can automatically clear DCRn[ERQ], disabling the peripheral request, when BCRn reaches zero by setting DCR $n[D\_REQ]$ .
- Changes to DCR*n* are effective immediately while the channel is active. To avoid problems with changing a DMA channel setup, write a one to DSRn[DONE] to stop the DMA channel.

#### 19.4.3 Dual-Address Data Transfer Mode

Each channel supports dual-address transfers. Dual-address transfers consist of a source data read and a destination data write. The DMA controller module begins a dual-address transfer sequence after a DMA request. If no error condition exists, DSR*n*[REQ] is set.

• Dual-address read—The DMA controller drives the SAR*n* value onto the system address bus. If DCR*n*[SINC] is set, the SAR*n* increments by the appropriate number of bytes upon a successful read cycle. When the appropriate number of read cycles complete (multiple reads if the destination size is larger than the source), the DMA initiates the write portion of the transfer.

If a termination error occurs, DSRn[BES, DONE] are set and DMA transactions stop.

• Dual-address write—The DMA controller drives the DARn value onto the system address bus. When the appropriate number of write cycles complete (multiple writes if the source size is larger than the destination), DARn increments by the appropriate number of bytes if DCRn[DINC] is set. BCRn decrements by the appropriate number of bytes. DSRn[DONE] is set when BCRn reaches zero. If the BCRn is greater than zero, another read/write transfer is initiated if continuous mode is enabled (DCRn[CS] = 0).

If a termination error occurs, DSRn[BED, DONE] are set and DMA transactions stop.

## 19.4.4 Advanced Data Transfer Controls: Auto-Alignment

This section describes auto-alignment for DMA transfers. Typically, this DMA feature is applicable for transfers of large blocks of data, and therefore is not applicable for peripheral-initiated cycle-steal transfers.

Auto-alignment allows block transfers to occur at the optimal size based on the address, byte count, and programmed size. To use this feature, DCRn[AA] must be set. The source is auto-aligned if DCRn[SSIZE] indicates a transfer size larger than DCRn[DSIZE]. Source alignment takes precedence over the destination when the source and destination sizes are equal. Otherwise, the destination is auto-aligned. The address register chosen for alignment increments regardless of the increment value. Configuration error checking is performed on registers not chosen for alignment.

If BCRn is greater than 16, the address determines transfer size. Bytes, words, or longwords are transferred until the address is aligned to the programmed size boundary, at which time accesses begin using the programmed size.

#### **Functional Description**

If BCRn is less than 16 at the start of a transfer, the number of bytes remaining dictates transfer size. For example, AA equals 1, SARn equals  $0x(00)80\_0001$ , BCRn equals  $0x00\_00F0$ , SSIZE equals 00 (longword), and DSIZE equals 01 (byte). Because SSIZE > DSIZE, the source is auto-aligned. Error checking is performed on destination registers. The access sequence is as follows:

- 1. Read byte from  $0x(00)80\_0001$ , increment SARn, write 1 byte (using DARn).
- 2. Read word from 0x(00)80\_0002, increment SARn, write 2 bytes.
- 3. Read longword from  $0x(00)80\_0004$ , increment SARn, write 4 bytes.
- 4. Repeat longwords until  $SARn = 0x(00)80\_00F0$ .
- 5. Read byte from  $0x(00)80\_00F0$ , increment SAR*n*, write byte.

If DSIZE is another size, data writes are optimized to write the largest size allowed based on the address, but not exceeding the configured size.

#### 19.4.5 Termination

An unsuccessful transfer can terminate for one of the following reasons:

- Error conditions—When the DMA encounters a read or write cycle that terminates with an error condition, DSRn[BES] is set for a read and DSRn[BED] is set for a write before the transfer is halted. If the error occurred in a write cycle, data in the internal holding registers is lost.
- Interrupts—If DCR*n*[EINT] is set, the DMA drives the appropriate interrupt request signal. The processor can read DSR*n* to determine whether the transfer terminated successfully or with an error. DSR*n*[DONE] is then written with a one to clear the interrupt, the DONE, and error status bits.

# **Chapter 20 Multipurpose Clock Generator (MCG)**

#### 20.1 Introduction

The multipurpose clock generator (MCG) module provides several clock source choices for the MCU. The module contains a frequency-locked loop (FLL) and a phase-locked loop (PLL). The FLL is controllable by either an internal or an external reference clock. The PLL is controllable by the external reference clock. The module can select either of the FLL or PLL output clocks, or either of the internal or external reference clocks as a source for the MCU system clock. The MCG operates in conjuction with a crystal oscillator, which allows an external crystal, ceramic resonator, or another external clock source to produce the external reference clock.

## 20.1.1 Features

Key features of the MCG module are:

- Frequency-locked loop (FLL)
  - Digitally-controlled oscillator (DCO)
  - DCO frequency range is programmable for up to four different frequency ranges.
  - Option to program and maximize DCO output frequency for a low frequency external reference clock source.
  - Option to prevent FLL from resetting its current locked frequency when switching clock modes if FLL reference frequency is not changed.
  - Internal or external reference clock can be used as the FLL source.
  - Can be used as a clock source for other on-chip peripherals.
- Phase-locked loop (PLL)

#### Introduction

- Voltage-controlled oscillator (VCO)
- External reference clock is used as the PLL source
- Modulo VCO frequency divider
- Phase/Frequency detector
- Integrated loop filter
- Can be used as a clock source for other on-chip peripherals.
- Internal reference clock generator
  - Slow clock with nine trim bits for accuracy
  - Fast clock with four trim bits
  - Can be used as source clock for the FLL. In FEI mode, only the slow Internal Reference Clock (IRC) can be used as the FLL source.
  - Either the slow or the fast clock can be selected as the clock source for the MCU
  - Can be used as a clock source for other on-chip peripherals
- Control signals for "the MCG external reference low power oscillator clock generators are provided:
  - HGO, RANGE, EREFS
- External clock from the Crystal Oscillator
  - Can be used as a source for the FLL and/or the PLL.
  - Can be selected as the clock source for the MCU
- External clock from the Real Time Counter (RTC)
  - Can only be used as a source for the FLL.
  - Can be selected as the clock source for the MCU
- External clock monitor with reset and interrupt request capability to check for external clock failure when running in FBE, PEE, BLPE, or FEE modes
- Lock detector with interrupt request capability for use with the PLL

- Internal Reference Clocks Auto Trim Machine (ATM) capability using an external clock as a reference
- Reference dividers for both the FLL and PLL are provided
- Reference dividers for both the Fast Internal Reference Clock are provided
- MCG Background Debug Controller Clock (MCGBDCCLK) is provided as a clock source for the Background Debug Controller (BDC)
- MCG PLL Clock (MCGPLLCLK) is provided as a clock source for other on-chip peripherals
- MCG FLL Clock (MCGFLLCLK) is provided as a clock source for other on-chip peripherals
- MCG Fixed Frequency Clock (MCGFFCLK) is provided as a clock source for other on-chip peripherals
- MCG Internal Reference Clock (MCGIRCLK) is provided as a clock source for other on-chip peripherals.



Figure 20-1. Multipurpose Clock Generator (MCG) Block Diagram

## 20.1.2 Modes of Operation

There are nine modes of operation for the MCG: FEI, FEE, FBI, FBE, PBE, PEE, BLPI, BLPE, and Stop. For details, see MCG Modes of Operation.

## 20.2 External Signal Description

There are no MCG signals that connect off chip.

## 20.3 Memory Map/Register Definition

This section includes the memory map and register definition.

Write accesses by user software to any register when the supervisor access is enabled will terminate with a bus error. Read accesses by user software complete as normaol.

#### MCG memory map

| Absolute<br>address<br>(hex) | Register name                                         | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|------------------------------|-------------------------------------------------------|--------------------|--------|-------------|------------------|
| FFFF_8400                    | MCG Control 1 Register (MCG_C1)                       | 8                  | R/W    | 04h         | 20.3.1/436       |
| FFFF_8401                    | MCG Control 2 Register (MCG_C2)                       | 8                  | R/W    | 00h         | 20.3.2/437       |
| FFFF_8402                    | MCG Control 3 Register (MCG_C3)                       | 8                  | R/W    | See section | 20.3.3/438       |
| FFFF_8403                    | MCG Control 4 Register (MCG_C4)                       | 8                  | R/W    | See section | 20.3.4/439       |
| FFFF_8404                    | MCG Control 5 Register (MCG_C5)                       | 8                  | R/W    | 00h         | 20.3.5/440       |
| FFFF_8405                    | MCG Control 6 Register (MCG_C6)                       | 8                  | R/W    | 00h         | 20.3.6/441       |
| FFFF_8406                    | MCG Status Register (MCG_S)                           | 8                  | R      | 10h         | 20.3.7/443       |
| FFFF_8408                    | MCG Auto Trim Control Register (MCG_ATC)              | 8                  | R/W    | 00h         | 20.3.8/444       |
| FFFF_840A                    | MCG Auto Trim Compare Value High Register (MCG_ATCVH) | 8                  | R/W    | 00h         | 20.3.9/445       |
| FFFF_840B                    | MCG Auto Trim Compare Value Low Register (MCG_ATCVL)  | 8                  | R/W    | 00h         | 20.3.10/<br>445  |

## 20.3.1 MCG Control 1 Register (MCG\_C1)

Address: MCG\_C1 is FFFF\_8400h base + 0h offset = FFFF\_8400h



#### MCG\_C1 field descriptions

| Field         | Description                                                                                                                                                                                                                                                                                                                                            |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–6<br>CLKS   | Clock Source Select                                                                                                                                                                                                                                                                                                                                    |
|               | Selects the clock source for MCGOUTCLK .                                                                                                                                                                                                                                                                                                               |
|               | 00 Encoding 0 — Output of FLL or PLL is selected (depends on PLLS control bit).                                                                                                                                                                                                                                                                        |
|               | 01 Encoding 1 — Internal reference clock is selected.                                                                                                                                                                                                                                                                                                  |
|               | 10 Encoding 2 — External reference clock is selected.                                                                                                                                                                                                                                                                                                  |
|               | 11 Encoding 3 — Reserved, defaults to 00.                                                                                                                                                                                                                                                                                                              |
| 5–3<br>FRDIV  | FLL External Reference Divider                                                                                                                                                                                                                                                                                                                         |
| FRDIV         | Selects the amount to divide down the external reference clock for the FLL. The resulting frequency must be in the range 31.25 kHz to 39.0625 kHz (This is required when FLL/DCO is the clock source for MCGOUTCLK . In FBE mode, it is not required to meet this range, but it is recommended in the cases when trying to enter a FLL mode from FBE). |
|               | 000 If RANGE = 0, Divide Factor is 1; for all other RANGE values, Divide Factor is 32.                                                                                                                                                                                                                                                                 |
|               | 001 If RANGE = 0, Divide Factor is 2; for all other RANGE values, Divide Factor is 64.                                                                                                                                                                                                                                                                 |
|               | 010 If RANGE = 0, Divide Factor is 4; for all other RANGE values, Divide Factor is 128.                                                                                                                                                                                                                                                                |
|               | 011 If RANGE = 0, Divide Factor is 8; for all other RANGE values, Divide Factor is 256.                                                                                                                                                                                                                                                                |
|               | 100 If RANGE = 0, Divide Factor is 16; for all other RANGE values, Divide Factor is 512.                                                                                                                                                                                                                                                               |
|               | <ul> <li>101 If RANGE = 0, Divide Factor is 32; for all other RANGE values, Divide Factor is 1024.</li> <li>110 If RANGE = 0, Divide Factor is 64; for all other RANGE values, Divide Factor is Reserved.</li> </ul>                                                                                                                                   |
|               | 111 If RANGE = 0, Divide Factor is 128; for all other RANGE values, Divide Factor is Reserved.                                                                                                                                                                                                                                                         |
| 2             | Internal Reference Select                                                                                                                                                                                                                                                                                                                              |
| IREFS         | Selects the reference clock source for the FLL.                                                                                                                                                                                                                                                                                                        |
|               | 0 External reference clock is selected.                                                                                                                                                                                                                                                                                                                |
|               | 1 The slow internal reference clock is selected.                                                                                                                                                                                                                                                                                                       |
| 1             | Internal Reference Clock Enable                                                                                                                                                                                                                                                                                                                        |
| IRCLKEN       | Enables the internal reference clock for use as MCGIRCLK.                                                                                                                                                                                                                                                                                              |
|               | 0 MCGIRCLK inactive.                                                                                                                                                                                                                                                                                                                                   |
|               | 1 MCGIRCLK active.                                                                                                                                                                                                                                                                                                                                     |
| 0<br>IREFSTEN | Internal Reference Stop Enable                                                                                                                                                                                                                                                                                                                         |

Table continues on the next page...

## MCG\_C1 field descriptions (continued)

| Field | Description                                                                                                                                                                                                           |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | Controls whether or not the internal reference clock remains enabled when the MCG enters Stop mode.                                                                                                                   |
|       | <ul> <li>Internal reference clock is disabled in Stop mode.</li> <li>Internal reference clock is enabled in Stop mode if IRCLKEN is set or if MCG is in FEI, FBI, or BLPI modes before entering Stop mode.</li> </ul> |

## 20.3.2 MCG Control 2 Register (MCG\_C2)

Address: MCG\_C2 is FFFF\_8400h base + 1h offset = FFFF\_8401h



## MCG\_C2 field descriptions

| Field         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>Reserved | This read-only bit is reserved and always has the value zero.                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 6<br>Reserved | This read-only bit is reserved and always has the value zero.                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 5–4<br>RANGE  | Frequency Range Select  Selects the frequency range for the crystal oscillator or external clock source. Refer to the Oscillator (OSC) chapter for more details.  00 Encoding 0 — Low frequency range selected for the crystal oscillator of 32 kHz to 40 kHz (reset default).  01 Encoding 1 — High frequency range selected for the crystal oscillator of 1 MHz to 8 MHz.  1X Encoding 2 — Very high frequency range selected for the crystal oscillator of 8 MHz to 32 MHz. |
| 3<br>HGO      | High Gain Oscillator Select  Controls the crystal oscillator mode of operation. Refer to the Oscillator (OSC) chapter for more details.  O Configure crystal oscillator for low-power operation.  1 Configure crystal oscillator for high-gain operation.                                                                                                                                                                                                                      |
| 2<br>EREFS    | External Reference Select  Selects the source for the external reference clock. Refer to the Oscillator (OSC) chapter for more details.  0 External reference clock requested.  1 Oscillator requested.                                                                                                                                                                                                                                                                        |
| 1<br>LP       | Low Power Select                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

Table continues on the next page...

#### **Memory Map/Register Definition**

## MCG\_C2 field descriptions (continued)

| Field     | Description                                                                                                                                                                                                                                                                                                                                                                                                       |
|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|           | Controls whether the FLL (or PLL) is disabled in BLPI and BLPE modes. In FBE or PBE modes, setting this bit to 1 will transition the MCG into BLPE mode; in FBI mode, setting this bit to 1 will transition the MCG into BLPI mode. In any other MCG mode, LP bit has no affect.  0 FLL (or PLL) is not disabled in bypass modes.  1 FLL (or PLL) is disabled in bypass modes (lower power) unless BDM is active. |
| 0<br>IRCS | Internal Reference Clock Select  Selects between the fast or slow internal reference clock source.  O Slow internal reference clock selected.  Tast internal reference clock selected.                                                                                                                                                                                                                            |

## 20.3.3 MCG Control 3 Register (MCG\_C3)

Address: MCG\_C3 is FFFF\_8400h base + 2h offset = FFFF\_8402h



<sup>\*</sup> Notes:

#### MCG\_C3 field descriptions

| Field         | Description                                                                                                                                                                                                                                                                                                                                                         |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-0<br>SCTRIM | Slow Internal Reference Clock Trim Setting  SCTRIM <sup>1</sup> controls the slow internal reference clock frequency by controlling the slow internal reference clock period. The SCTRIM bits are binary weighted (that is, bit 1 adjusts twice as much as bit 0). Increasing the binary value increases the period, and decreasing the value decreases the period. |
|               | An additional fine trim bit is available in C4 register as the SCFTRIM bit. Upon reset this value is loaded with a factory trim value.                                                                                                                                                                                                                              |
|               | If an SCTRIM value stored in nonvolatile memory is to be used, it is your responsibility to copy that value from the nonvolatile memory location to this register.                                                                                                                                                                                                  |

1. A value for SCTRIM is loaded during reset from a factory programmed location .

<sup>•</sup> x = Undefined at reset.

## 20.3.4 MCG Control 4 Register (MCG\_C4)

Reset values for DRST and DMX32 bits are 0.

Address: MCG C4 is FFFF 8400h base + 3h offset = FFFF 8403h



- \* Notes:
- x = Undefined at reset.
- A value for SCFTRIM is loaded during reset from a factory programmed location. x = Undefined at reset.

#### MCG\_C4 field descriptions

| Field      | Description                                                                                                                                                                                                                                                                                                                                                                                 |                          |                        |                         |                   |  |  |  |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|------------------------|-------------------------|-------------------|--|--|--|
| 7<br>DMX32 | DCO Maximum Frequency with 32.768 kHz Reference                                                                                                                                                                                                                                                                                                                                             |                          |                        |                         |                   |  |  |  |
|            | The DMX32 bit control with a 32.768 kHz re                                                                                                                                                                                                                                                                                                                                                  |                          | e DCO frequency rang   | ge is narrowed to its r | maximum frequency |  |  |  |
|            | The following table is                                                                                                                                                                                                                                                                                                                                                                      | dentifies settings for t | he DCO frequency rai   | nge.                    |                   |  |  |  |
|            | NOTE: The system                                                                                                                                                                                                                                                                                                                                                                            | clocks derived from      | this source should not | exceed their specifie   | ed maximums.      |  |  |  |
|            | DRST_DRS                                                                                                                                                                                                                                                                                                                                                                                    | DMX32                    | Reference Range        | FLL Factor              | DCO Range         |  |  |  |
|            | 00                                                                                                                                                                                                                                                                                                                                                                                          | 0                        | 31.25-39.0625 kHz      | 640                     | 20-25 MHz         |  |  |  |
|            |                                                                                                                                                                                                                                                                                                                                                                                             | 1                        | 32.768 kHz             | 732                     | 24 MHz            |  |  |  |
|            | 01                                                                                                                                                                                                                                                                                                                                                                                          | 0                        | 31.25-39.0625 kHz      | 1280                    | 40-50 MHz         |  |  |  |
|            |                                                                                                                                                                                                                                                                                                                                                                                             | 1                        | 32.768 kHz             | 1464                    | 48 MHz            |  |  |  |
|            | 10                                                                                                                                                                                                                                                                                                                                                                                          | 0                        | 31.25-39.0625 kHz      | 1920                    | 60-75 MHz         |  |  |  |
|            |                                                                                                                                                                                                                                                                                                                                                                                             | 1                        | 32.768 kHz             | 2197                    | 72 MHz            |  |  |  |
|            | 11                                                                                                                                                                                                                                                                                                                                                                                          | 0                        | 31.25-39.0625 kHz      | 2560                    | 80-100 MHz        |  |  |  |
|            |                                                                                                                                                                                                                                                                                                                                                                                             | 1                        | 32.768 kHz             | 2929                    | 96 MHz            |  |  |  |
|            | <ul> <li>DCO has a default range of 25%.</li> <li>DCO is fine-tuned for maximum frequency with 32.768 kHz reference.</li> </ul>                                                                                                                                                                                                                                                             |                          |                        |                         |                   |  |  |  |
| 6–5        | DCO Range Select                                                                                                                                                                                                                                                                                                                                                                            |                          |                        |                         |                   |  |  |  |
| DRST_DRS   | The DRS bits select the frequency range for the FLL output, DCOOUT. When the LP bit is set, writes to the DRS bits are ignored. The DRST read field indicates the current frequency range for DCOOUT. The DRST field does not update immediately after a write to the DRS field due to internal synchronization between clock domains. Refer to DCO Frequency Range table for more details. |                          |                        |                         |                   |  |  |  |
|            | <ul><li>00 Encoding 0 — Low range (reset default).</li><li>01 Encoding 1 — Mid range.</li></ul>                                                                                                                                                                                                                                                                                             |                          |                        |                         |                   |  |  |  |

Table continues on the next page...

#### **Memory Map/Register Definition**

## MCG\_C4 field descriptions (continued)

| Field         | Description                                                                                                                                                                                                                                                                                                             |
|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|               | 10 Encoding 2 — Mid-high range.                                                                                                                                                                                                                                                                                         |
|               | 11 Encoding 3 — High range.                                                                                                                                                                                                                                                                                             |
| 4–1<br>FCTRIM | Fast Internal Reference Clock Trim Setting                                                                                                                                                                                                                                                                              |
|               | FCTRIM <sup>1</sup> controls the fast internal reference clock frequency by controlling the fast internal reference clock period. The FCTRIM bits are binary weighted (that is, bit 1 adjusts twice as much as bit 0). Increasing the binary value increases the period, and decreasing the value decreases the period. |
|               | If an FCTRIM[3:0] value stored in nonvolatile memory is to be used, it is your responsibility to copy that value from the nonvolatile memory location to this register.                                                                                                                                                 |
| 0             | Slow Internal Reference Clock Fine Trim                                                                                                                                                                                                                                                                                 |
| SCFTRIM       | SCFTRIM <sup>2</sup> controls the smallest adjustment of the slow internal reference clock frequency. Setting SCFTRIM increases the period and clearing SCFTRIM decreases the period by the smallest amount possible.                                                                                                   |
|               | If an SCFTRIM value stored in nonvolatile memory is to be used, it is your responsibility to copy that value from the nonvolatile memory location to this bit.                                                                                                                                                          |

- 1. A value for FCTRIM is loaded during reset from a factory programmed location .
- 2. A value for SCFTRIM is loaded during reset from a factory programmed location.

## 20.3.5 MCG Control 5 Register (MCG\_C5)

Address: MCG\_C5 is FFFF\_8400h base + 4h offset = FFFF\_8404h



#### MCG\_C5 field descriptions

| Field         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>Reserved | This read-only bit is reserved and always has the value zero.                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 6<br>PLLCLKEN | PLL Clock Enable  Enables the PLL independent of PLLS and enables the PLL clock for use as MCGPLLCLK. (PRDIV needs to be programmed to the correct divider to generate a PLL reference clock in the range of 2 - 4 MHz range prior to setting the PLLCLKEN bit). Setting PLLCLKEN will enable the external oscillator if not already enabled. Check for OSCINIT assertion while enabling the external oscillator after being turned off.  0 MCGPLLCLK is inactive.  1 MCGPLLCLK is active. |
| 5<br>PLLSTEN  | PLL Stop Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

Table continues on the next page...

## MCG\_C5 field descriptions (continued)

| Field        | Description                                                                                                                                                                                                                        |                                       |              |                  |                 |                  |                  |                  |  |  |  |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------|--------------|------------------|-----------------|------------------|------------------|------------------|--|--|--|
|              | Enables the PLL Clock during Normal Stop (In Low Power Stop mode, the PLL clock gets disabled even if PLLSTEN=1). All other power modes, PLLSTEN bit has no affect and does not enable the PLL Clock to run if it is written to 1. |                                       |              |                  |                 |                  |                  |                  |  |  |  |
|              |                                                                                                                                                                                                                                    | , , , , , , , , , , , , , , , , , , , |              |                  |                 |                  |                  |                  |  |  |  |
| 4–0<br>PRDIV |                                                                                                                                                                                                                                    | ernal Reference                       |              | e external refer | rence clock for | the PLL. The I   | resulting freque | ncy must         |  |  |  |
|              | be in the                                                                                                                                                                                                                          | range of 2 MI                         | Hz to 4 MHz. | LL Extern        | al Referen      | ce Divide        | Factor           |                  |  |  |  |
|              | PRDIV                                                                                                                                                                                                                              | Divide<br>Factor                      | PRDIV        | Divide<br>Factor | PRDIV           | Divide<br>Factor | PRDIV            | Divide<br>Factor |  |  |  |
|              | 00000                                                                                                                                                                                                                              | 1                                     | 01000        | 9                | 10000           | 17               | 11000            | 25               |  |  |  |
|              | 00001                                                                                                                                                                                                                              | 2                                     | 01001        | 10               | 10001           | 18               | 11001            | Reserv<br>ed     |  |  |  |
|              | 00010                                                                                                                                                                                                                              | 3                                     | 01010        | 11               | 10010           | 19               | 11010            | Reserv<br>ed     |  |  |  |
|              | 00011                                                                                                                                                                                                                              | 4                                     | 01011        | 12               | 10011           | 20               | 11011            | Reserv<br>ed     |  |  |  |
|              | 00100                                                                                                                                                                                                                              | 5                                     | 01100        | 13               | 10100           | 21               | 11100            | Reserv<br>ed     |  |  |  |
|              | 00101                                                                                                                                                                                                                              | 6                                     | 01101        | 14               | 10101           | 22               | 11101            | Reserv<br>ed     |  |  |  |
|              | 00110                                                                                                                                                                                                                              | 7                                     | 01110        | 15               | 10110           | 23               | 11110            | Reserv           |  |  |  |
|              |                                                                                                                                                                                                                                    |                                       |              |                  |                 |                  |                  | 00               |  |  |  |

## 20.3.6 MCG Control 6 Register (MCG\_C6)

Address: MCG\_C6 is FFFF\_8400h base + 5h offset = FFFF\_8405h



#### **Memory Map/Register Definition**

## MCG\_C6 field descriptions

| Field       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                    |                 |                    |                                   |                    |                         |           |                    |  |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------|-----------------|--------------------|-----------------------------------|--------------------|-------------------------|-----------|--------------------|--|
| 7           | Loss of Lock Interrrupt Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                    |                 |                    |                                   |                    |                         |           |                    |  |
| LOLIE       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Determines if an interrupt request is made following a loss of lock indication. The LOLIE bit only has an effect when LOLS is set. |                 |                    |                                   |                    |                         |           |                    |  |
|             | 0 No ir                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | nterrupt reques                                                                                                                    | st is generated | on loss of l       | ock.                              |                    |                         |           |                    |  |
|             | 1 Gene                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | erate an interru                                                                                                                   | upt request on  | loss of lock       |                                   |                    |                         |           |                    |  |
| 6<br>PLLS   | PLL Sele                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | ect                                                                                                                                |                 |                    |                                   |                    |                         |           |                    |  |
| FLLS        | bit is clea                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                    |                 |                    | ed as the MCG<br>is disabled in a |                    |                         |           |                    |  |
|             | 0 FLL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | is selected.                                                                                                                       |                 |                    |                                   |                    |                         |           |                    |  |
|             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                    |                 |                    | med to the correg the PLLS bit).  |                    | generate                | a PLL ref | erence             |  |
| 5           | Clock Mo                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | onitor Enable                                                                                                                      |                 |                    |                                   |                    |                         |           |                    |  |
| CME         | Determines if a reset request is made following a loss of external clock indication. The CME bit should only be set to a logic 1 when either the MCG is in an operational mode that uses the external clock (FEE FBE, PEE, PBE, or BLPE) or the external reference is enabled. Whenever the CME bit is set to a logic 1 the value of the RANGE bits in the C2 register should not be changed. CME bit should be set to a logic 0 before the MCG enters Stop mode. Otherwise, a reset request may occur while in Stop mode.  0 External clock monitor is disabled. |                                                                                                                                    |                 |                    |                                   |                    | ock (FEE,<br>a logic 1, |           |                    |  |
|             | 1 Gene                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | erate a reset re                                                                                                                   | equest on loss  | of external        | clock.                            |                    |                         |           |                    |  |
| 4–0<br>VDIV |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | divide the VCO                                                                                                                     |                 | he PLL. The VI     | IV bits estab                     | olish the m        | ultiplication           | on factor |                    |  |
|             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                    | Table           | 20 0 D             | LL VCO Di                         | rido Egot          | or                      |           |                    |  |
|             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                    |                 |                    |                                   |                    | UI                      |           |                    |  |
|             | VDIV                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Multiply<br>Factor                                                                                                                 | VDIV            | Multiply<br>Factor | VDIV                              | Multiply<br>Factor |                         | VDIV      | Multiply<br>Factor |  |
|             | 00000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 24                                                                                                                                 | 01000           | 32                 | 1000                              | 0 40               |                         | 11000     | 48                 |  |
|             | 00001                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 25                                                                                                                                 | 01001           | 33                 | 1000                              | 1 41               |                         | 11001     | 49                 |  |
|             | 00010                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 26                                                                                                                                 | 01010           | 34                 | 1001                              | ) 42               |                         | 11010     | 50                 |  |
|             | 00011                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 27                                                                                                                                 | 01011           | 35                 | 1001                              | 1 43               |                         | 11011     | 51                 |  |
|             | 00100                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 28                                                                                                                                 | 01100           | 36                 | 1010                              | 0 44               |                         | 11100     | 52                 |  |
|             | 00101                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 29                                                                                                                                 | 01101           | 37                 | 1010                              | 1 45               |                         | 11101     | 53                 |  |
|             | 00110                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 30                                                                                                                                 | 01110           | 38                 | 1011                              | 0 46               |                         | 11110     | 54                 |  |
|             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 31                                                                                                                                 | 01111           | 39                 | 1011                              | 1 47               |                         |           |                    |  |

## 20.3.7 MCG Status Register (MCG\_S)

Address: MCG\_S is FFFF\_8400h base + 6h offset = FFFF\_8406h



## MCG\_S field descriptions

| Field       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>LOLS   | Loss of Lock Status  This bit is a sticky bit indicating the lock status for the PLL. LOLS is set if after acquiring lock, the PLL output frequency has fallen outside the lock exit frequency tolerance, D <sub>unl</sub> . LOLIE determines whether an interrupt request is made when LOLS is set. LOLS is cleared by reset or by writing a logic 1 to LOLS when LOLS is set. Writing a logic 0 to LOLS has no effect.  O PLL has not lost lock since LOLS was last cleared.  1 PLL has lost lock since LOLS was last cleared.                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 6<br>LOCK   | Lock Status  This bit indicates whether the PLL has acquired lock. Lock detection is disabled when not operating in either PBE or PEE mode unless PLLCLKEN=1 and the MCG is not configured in BLPI or BLPE mode. While the PLL clock is locking to the desired frequency, the MCG PLL clock (MCGPLLCLK) will be gated off until the LOCK bit gets asserted. If the lock status bit is set, changing the value of the PRDIV[4:0] bits in the C5 register or the VDIV[4:0] bits in the C6 register causes the lock status bit to clear and stay cleared until the PLL has reacquired lock. Entry into LLS, VLPS, or regular Stop with PLLSTEN=0 also causes the lock status bit to clear and stay cleared until Stop mode is exited and the PLL has reacquired lock. Any time the PLL is enabled and the LOCK bit is cleared, the MCGPLLCLK will be gated off until the LOCK bit is asserted again.  O PLL is currently unlocked.  1 PLL is currently locked. |
| 5<br>PLLST  | PLL Select Status  This bit indicates the clock source selected by PLLS . The PLLST bit does not update immediately after a write to the PLLS bit due to internal synchronization between clock domains.  O Source of PLLS clock is FLL clock.  Source of PLLS clock is PLL clock.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 4<br>IREFST | Internal Reference Status  This bit indicates the current source for the FLL reference clock. The IREFST bit does not update immediately after a write to the IREFS bit due to internal synchronization between clock domains.  O Source of FLL reference clock is the external reference clock.  Source of FLL reference clock is the internal reference clock.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

Table continues on the next page...

#### **Memory Map/Register Definition**

## MCG\_S field descriptions (continued)

| Field        | Description                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 3–2<br>CLKST | Clock Mode Status                                                                                                                                                                                                                                                                                                                                                                                         |  |  |
|              | These bits indicate the current clock mode. The CLKST bits do not update immediately after a write to the CLKS bits due to internal synchronization between clock domains.                                                                                                                                                                                                                                |  |  |
|              | 00 Encoding 0 — Output of the FLL is selected (reset default).                                                                                                                                                                                                                                                                                                                                            |  |  |
|              | 01 Encoding 1 — Internal reference clock is selected.                                                                                                                                                                                                                                                                                                                                                     |  |  |
|              | 10 Encoding 2 — External reference clock is selected.                                                                                                                                                                                                                                                                                                                                                     |  |  |
|              | 11 Encoding 3 — Output of the PLL is selected.                                                                                                                                                                                                                                                                                                                                                            |  |  |
| 1<br>OSCINIT | OSC Initialization                                                                                                                                                                                                                                                                                                                                                                                        |  |  |
|              | This bit is set after the initialization cycles of the crystal oscillator clock have completed. Refer to the OSC Block Guide for more details.                                                                                                                                                                                                                                                            |  |  |
| 0<br>IRCST   | Internal Reference Clock Status                                                                                                                                                                                                                                                                                                                                                                           |  |  |
|              | The IRCST bit indicates the current source for the internal reference clock select clock (IRCSCLK). The IRCST bit does not update immediately after a write to the IRCS bit due to internal synchronization between clock domains. The IRCST bit will only be updated if the internal reference clock is enabled, either by the MCG being in a mode that uses the IRC or by setting the C1[IRCLKEN] bit . |  |  |
|              | 0 Source of internal reference clock is the slow clock (32 kHz IRC).                                                                                                                                                                                                                                                                                                                                      |  |  |
|              | 1 Source of internal reference clock is the fast clock (2 MHz IRC).                                                                                                                                                                                                                                                                                                                                       |  |  |

## 20.3.8 MCG Auto Trim Control Register (MCG\_ATC)

Address: MCG\_ATC is FFFF\_8400h base + 8h offset = FFFF\_8408h



#### MCG\_ATC field descriptions

| Field     | Description                                                                                                                       |
|-----------|-----------------------------------------------------------------------------------------------------------------------------------|
| 7<br>ATME | Automatic Trim Machine Enable                                                                                                     |
| 7.1       | Enables the Auto Trim Machine to start automatically trimming the selected Internal Reference Clock.                              |
|           | NOTE: ATME deasserts after the Auto Trim Machine has completed trimming all trim bits of the IRCS clock selected by the ATMS bit. |
|           | Writing to C1, C3, C4, and ATC registers or entering Stop mode aborts the auto trim operation and clears this bit.                |
|           | 0 Auto Trim Machine disabled.                                                                                                     |
|           | 1 Auto Trim Machine enabled.                                                                                                      |

Table continues on the next page...

#### MCG\_ATC field descriptions (continued)

| Field           | Description                                                                                                                                                                                                                                              |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6<br>ATMS       | Automatic Trim Machine Select                                                                                                                                                                                                                            |
|                 | Selects the IRCS clock for Auto Trim Test.                                                                                                                                                                                                               |
|                 | 0 32 kHz Internal Reference Clock selected.                                                                                                                                                                                                              |
|                 | 1 4 MHz Internal Reference Clock selected.                                                                                                                                                                                                               |
| 5<br>ATMF       | Automatic Trim machine Fail Flag                                                                                                                                                                                                                         |
|                 | Fail flag for the Automatic Trim Machine (ATM). This bit asserts when the Automatic Trim Machine is enabled (ATME=1) and a write to the C1, C3, C4, and ATC registers is detected or the MCG enters into any Stop mode. A write to ATMF clears the flag. |
|                 | 0 Automatic Trim Machine completed normally.                                                                                                                                                                                                             |
|                 | 1 Automatic Trim Machine failed.                                                                                                                                                                                                                         |
| 4–0<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                       |

## 20.3.9 MCG Auto Trim Compare Value High Register (MCG\_ATCVH)

Address: MCG\_ATCVH is FFFF\_8400h base + Ah offset = FFFF\_840Ah



#### MCG\_ATCVH field descriptions

| Field        | Description                                                                                                                                  |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| 7–0<br>ATCVH | ATM Compare Value High  Values are used by Auto Trim Machine to compare and adjust Internal Reference trim values during ATM SAR conversion. |

## 20.3.10 MCG Auto Trim Compare Value Low Register (MCG\_ATCVL)

Address: MCG\_ATCVL is FFFF\_8400h base + Bh offset = FFFF\_840Bh



#### **Functional Description**

#### MCG\_ATCVL field descriptions

| Field        | Description                                                                                                                                 |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| 7–0<br>ATCVL | ATM Compare Value Low  Values are used by Auto Trim Machine to compare and adjust Internal Reference trim values during ATM SAR conversion. |

## 20.4 Functional Description

## 20.4.1 MCG Mode State Diagram

The nine states of the MCG are shown in the following figure and are described in Table 20-14. The arrows indicate the permitted MCG mode transitions.



Figure 20-12. MCG Mode State Diagram

#### **NOTE**

- During exits from LLS or VLPS when the MCG is in PEE mode, the MCG will reset to PBE clock mode and the C1[CLKS] and S[CLKST] will automatically be set to 2'b10.
- If entering Normal Stop mode when the MCG is in PEE mode with C5[PLLSTEN]=0, the MCG will reset to PBE clock mode and C1[CLKS] and S[CLKST] will automatically be set to 2'b10.

## 20.4.1.1 MCG Modes of Operation

The MCG operates in one of the following modes.

#### **Note**

The MCG restricts transitions between modes. For the permitted transitions, see Figure 20-12.

Table 20-14. MCG Modes of Operation

| Mode                       | Description                                                                                                                                                                                                                                                                                                                                                                                                                     |  |
|----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| FLL Engaged Internal (FEI) | FLL engaged internal (FEI) is the default mode of operation and is entered when all the following condtions occur:                                                                                                                                                                                                                                                                                                              |  |
|                            | C1[CLKS] bits are written to 00                                                                                                                                                                                                                                                                                                                                                                                                 |  |
|                            | C1[IREFS] bit is written to 1                                                                                                                                                                                                                                                                                                                                                                                                   |  |
|                            | C6[PLLS] bit is written to 0                                                                                                                                                                                                                                                                                                                                                                                                    |  |
|                            | In FEI mode, MCGOUT is derived from the FLL clock (DCOCLK) that is controlled by the 32 kHz Internal Reference Clock (IRC). The FLL loop will lock the DCO frequency to the FLL factor, as selected by the C4[DRST_DRS] and C4[DMX32] bits, times the internal reference frequency . Refer to the C4[DMX32] bit description for more details. In FEI mode, the PLL is disabled in a low-power state unless C5[PLLCLKEN] is set. |  |

#### **Functional Description**

## **Table 20-14. MCG Modes of Operation (continued)**

| Mode                  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |
|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| FLL Engaged External  | FLL engaged external (FEE) mode is entered when all the following conditions occur:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |
| (FEE)                 | C1[CLKS] bits are written to 00                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |
|                       | C1[IREFS] bit is written to 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |
|                       | C1[FRDIV] must be written to divide external reference clock to be within the range of 31.25 kHz to 39.0625 kHz                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |
|                       | C6[PLLS] bit is written to 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |
|                       | In FEE mode, MCGOUT is derived from the FLL clock (DCOCLK) that is controlled by the external reference clock. The FLL loop will lock the DCO frequency to the FLL factor, as selected by C4[DRST_DRS] and C4[DMX32] bits, times the external reference frequency, as specified by the C1[FRDIV] and C2[RANGE]. Refer to the C4[DMX32] bit description for more details. In FEE mode, the PLL is disabled in a low-power state unless C5[PLLCLKEN] is set.                                                                                                                                                                                                                                                                                              |  |  |
| FLL Bypassed Internal | FLL bypassed internal (FBI) mode is entered when all the following conditions occur:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
| (FBI)                 | C1[CLKS] bits are written to 01                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |
|                       | C1[IREFS] bit is written to 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |
|                       | C6[PLLS] is written to 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
|                       | C2[LP] is written to 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |
|                       | In FBI mode, the MCGOUT clock is derived either from the slow (32 kHz IRC) or fast (2 MHz IRC) internal reference clock, as selected by the C2[IRCS] bit. The FLL is operational but its output is not used. This mode is useful to allow the FLL to acquire its target frequency while the MCGOUT clock is driven from the C2[IRCS] selected internal reference clock. The FLL clock (DCOCLK) is controlled by the slow internal reference clock, and the DCO clock frequency locks to a multiplication factor, as selected by the C4[DRST_DRS] and C4[DMX32] bits, times the internal reference frequency. Refer to the C4[DMX32] bit description for more details. In FBI mode, the PLL is disabled in a low-power state unless C5[PLLCLKEN] is set. |  |  |
| FLL Bypassed External | FLL bypassed external (FBE) mode is entered when all the following conditions occur:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
| (FBE)                 | C1[CLKS] bits are written to 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |
|                       | C1[IREFS] bit is written to 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |
|                       | <ul> <li>C1[FRDIV] must be written to divide external reference clock to be within the range of 31.25<br/>kHz to 39.0625 kHz.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
|                       | C6[PLLS] bit is written to 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |
|                       | C2[LP] is written to 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |
|                       | In FBE mode, the MCGOUT clock is derived from the external reference clock. The FLL is operational but its output is not used. This mode is useful to allow the FLL to acquire its target frequency while the MCGOUT clock is driven from the external reference clock. The FLL clock (DCOCLK) is controlled by the external reference clock, and the DCO clock frequency locks to a multiplication factor, as selected by the C4[DRST_DRS] and C4[DMX32] bits, times the divided external reference frequency. Refer to the C4[DMX32] bit description for more details. In FBI mode the PLL is disabled in a low-power state unless PLLCLKEN is set.                                                                                                   |  |  |

## **Table 20-14. MCG Modes of Operation (continued)**

| Mode                                  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|---------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PLL Engaged External                  | PLL Engaged External (PEE) mode is entered when all the following conditions occur:                                                                                                                                                                                                                                                                                                                                                                                    |
| (PEE)                                 | C1[CLKS] bits are written to 00                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                                       | C1[IREFS] bit is written to 0                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                                       | C5[PRDIV] bits must be written to divide the external reference clock to be within the range of                                                                                                                                                                                                                                                                                                                                                                        |
|                                       | C6[PLLS] bit is written to 1                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                                       | In PEE mode, the MCGOUT is derived from the PLL clock, which is controlled by the external reference clock. The PLL clock frequency locks to a multiplication factor, as specified by C6[VDIV], times the external reference frequency, as specified by C5[PRDIV]. The FLL is disabled in a low-power state.                                                                                                                                                           |
| PLL Bypassed External                 | PLL Bypassed External (PBE) mode is entered when all the following conditions occur:                                                                                                                                                                                                                                                                                                                                                                                   |
| (PBE)                                 | C1[CLKS] bits are written to 10                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                                       | C1[IREFS] bit is written to 0                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                                       | C5[PRDIV] bits are programmed to divide the external reference clock to be within the range of 2 to 4 MHz                                                                                                                                                                                                                                                                                                                                                              |
|                                       | C6[PLLS] bit is writtent o 1                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                                       | C2[LP] bit is written to 0                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                                       | In PBE mode, MCGOUT is derived from the OSCSEL external reference clock; the PLL is operational, but its output clock is not used. This mode is useful to allow the PLL to acquire its target frequency while MCGOUT is driven from the external reference clock. The PLL clock frequency locks to a multiplication factor, as specified by its [VDIV], times the external reference frequency, as specified by its [PRDIV]. The FLL is disabled in a low-power state. |
| Bypassed Low Power                    | Bypassed Low Power Internal (BLPI) mode is entered when all the following conditions occur:                                                                                                                                                                                                                                                                                                                                                                            |
| Internal (BLPI)1                      | C1[CLKS] bits are written to 01                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                                       | C1[IREFS] bit is written to 1                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                                       | C6[PLLS] bit is written to 0                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                                       | C2[LP] bit is written to 1                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                                       | In BLPI mode, MCGOUT is derived from the internal reference clock. The FLL is disabled and PLL is disabled even if the C5[PLLCLKEN] is set to 1.                                                                                                                                                                                                                                                                                                                       |
| Bypassed Low Power<br>External (BLPE) | Bypassed Low Power External (BLPE) mode is mode is entered when all the following conditions occur:                                                                                                                                                                                                                                                                                                                                                                    |
|                                       | C1[CLKS] bits are written to 10                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                                       | C1[IREFS] bit is written to 0                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                                       | C2[LP] bit is written to 1                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                                       | In BLPE mode, MCGOUT is derived from the external reference clock. The FLL is disabled and PLL is disabled even if the C5[PLLCLKEN] is set to 1.                                                                                                                                                                                                                                                                                                                       |

#### **Functional Description**

Table 20-14. MCG Modes of Operation (continued)

| Mode | Description                                                                                                                                                                                                                                                                                                                                                    |  |  |  |
|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Stop | Entered whenever the MCU enters a Stop state. The power modes are chip specific. For power mode assignments, see the chapter that describes how modules are configured and MCG behaived during Stop recovery. Entering Stop mode, the FLL is disabled, and all MCG clock signals are static except in the following case:                                      |  |  |  |
|      | MCGPLLCLK is active in Normal Stop mode when PLLSTEN=1                                                                                                                                                                                                                                                                                                         |  |  |  |
|      | MCGIRCLK is active in Stop mode when all the following conditions become true:                                                                                                                                                                                                                                                                                 |  |  |  |
|      | • C1[IRCLKEN] = 1                                                                                                                                                                                                                                                                                                                                              |  |  |  |
|      | • C1[IREFSTEN] = 1                                                                                                                                                                                                                                                                                                                                             |  |  |  |
|      | • When entering Low Power Stop modes (LLS or VLPS) from PEE mode, on exit the MCG clock mode is forced to PBE clock mode, the C1[CLKS] and S[CLKST] will be configured to 2'b10 and S[LOCK] bit will be cleared without setting S[LOLS].                                                                                                                       |  |  |  |
|      | <ul> <li>When entering Normal Stop mode from PEE mode and if C5[PLLSTEN]=0, on exit the MCG clock mode is forced to PBE mode, the C1[CLKS] and S[CLKST] will be configured to 2'b10 and S[LOCK] bit will clear without setting S[LOLS]. If S[PLLSTEN]=1, the S[LOCK] bit will not get cleared and on exit the MCG will continue to run in PEE mode.</li> </ul> |  |  |  |

If entering VLPR mode, MCG has to be configured and enter BLPE mode or BLPI mode with the 2 MHz IRC clock selected (C2[IRCS]=1). Once in VLPR mode, writes to any of the MCG control registers that can cause a MCG clock mode switch to a non low power clock mode must be avoided.

#### NOTE

For the chip-specific modes of operation, refer to the power management chapter of this MCU.

## 20.4.1.2 MCG Mode Switching

The C1[IREFS] bit can be changed at any time, but the actual switch to the newly selected reference clocks is shown by the S[IREFST] bit. When switching between engaged internal and engaged external modes, the FLL will begin locking again after the switch is completed.

The C1[CLKS] bits can also be changed at anytime, but the actual switch to the newly selected clock is shown by the S[CLKST] bits. If the newly selected clock is not available, the previous clock will remain selected.

The C4[DRST\_DRS] write bits can be changed at anytime except when C2[LP] bit is 1. If the C4[DRST\_DRS] write bits are changed while in FLL engaged internal (FEI) or FLL engaged external (FEE), the MCGOUT clock will switch to the new selected DCO range within three clocks of the selected DCO clock. After switching to the new DCO,

the FLL remains unlocked for several reference cycles. DCO startup time is equal to the FLL acquisition time. After the selected DCO startup time is over, the FLL is locked. The completion of the switch is shown by the C4[DRST\_DRS] read bits.

## 20.4.2 Low Power Bit Usage

The C2[LP] bit is provided to allow the FLL or PLL to be disabled and thus conserve power when these systems are not being used. The C4[DRST\_DRS] can not be written while C2[LP] bit is 1. However, in some applications, it may be desirable to enable the FLL or PLL and allow it to lock for maximum accuracy before switching to an engaged mode. Do this by writing C2[LP] to 0.

#### 20.4.3 MCG Internal Reference Clocks

This module supports internal reference clocks with frequencies of 32 kHz and a 4 MHz.

#### 20.4.3.1 MCG Internal Reference Clock

The MCG Internal Reference Clock (MCGIRCLK) provides a clock source for other onchip peripherals and is enabled when C1[IRCLKEN]=1. When enabled, MCGIRCLK is driven by either the fast internal reference clock (2 MHz IRC) or the slow internal reference clock (32 kHz IRC). The IRCS clock frequency can be re-targeted by trimming the period of its IRCS selected internal reference clock. This can be done by writing a new trim value to the C3[SCTRIM]:C4[SCFTRIM] bits when the slow IRC clock is selected or by writing a new trim value to the C4[FCTRIM] bits when the fast IRC clock is selected. The internal reference clock period is proportional to the trim value written. C3[SCTRIM]:C4[SCFTRIM] (if C2[IRCS]=0) and C4[FCTRIM] (if C2[IRCS]=1) bits affect the MCGOUT frequency if the MCG is in FBI or BLPI modes. C3[SCTRIM]:C4[SCFTRIM] (if C2[IRCS]=0) bits also affect the MCGOUT frequency if the MCG is in FEI mode.

Additionally, this clock can be enabled in Stop mode by setting C1[IRCLKEN] and C1[IREFSTEN], otherwise this clock is disabled in Stop mode.

#### 20.4.4 External Reference Clock

The MCG module can support an external reference clock in all modes. Refer to the device datasheet for external reference frequency range. When C1[IREFS] is set, the external reference clock will not be used by the FLL or PLL. In these modes, the frequency can be equal to the maximum frequency the chip-level timing specifications will support.

If the CME bit is asserted the slow internal reference clock gets enabledincluding the clock monitor. If the external reference falls below a certain frequency for the case when C6[CME]=1 ( $f_{loc\_high}$  or  $f_{loc\_low}$  depending on C2[RANGE]), the MCU will reset and S[LOCK] will be cleared.

## 20.4.5 MCG Fixed Frequency Clock

The MCG Fixed Frequency Clock (MCGFFCLK) provides a fixed frequency clock source for other on-chip peripherals. This clock is driven by either the slow clock from the internal reference clock generator or the external reference clock from the Crystal Oscillator, divided by the FLL reference clock divider. The source of MCGFFCLK is selected by C1[IREFS]. Additionally, this clock is divided by two.

Finally, this clock is synchronized to the peripheral bus clock and altered to have a duty cycle width equal to one peripheral bus clock period. This clock is only valid when it's frequency is not more than 1/8 of the MCGOUT clock frequency. When it is not valid, it is disabled and held high. This clock is also disabled in Stop mode.

## 20.4.6 MCG Background Debug Controller Clock

The MCG Background Debug Controller Clock (MCGBDCCLK) provides a clock source to the Background Debug Controller (BDC). This clock is driven by either the CORECLK or the fast clock from the 4 Mhz internal reference clock generator as selected by the CLKSW bit. The CLKSW bit is located in the BDC Status and Control Register.

#### 20.4.7 MCG PLL Clock

The MCG PLL Clock (MCGPLLCLK) is available depending on the device's configuration of the MCG module. For more details, refer to the clock distribution chapter of this MCU. The MCGPLLCLK is prevented from coming out of the MCG until it is enabled and S[LOCK] is set.

## 20.4.8 MCG Auto TRIM (ATM)

The MCG Auto Trim (ATM) is a MCG feature that when enabled, it configures the MCG hardware to automatically trim the MCG Internal Reference Clocks using an external clock as a reference. The selection between which MCG IRC clock gets tested and enabled is controlled by the ATC[ATMS] control bit (ATC[ATMS]=0 selects the 32 kHz IRC and ATC[ATMS]=1 selects the 4 MHz IRC). If 4 MHz IRC is selected for the ATM, a divide by 128 is enabled to divide down the 4 MHz IRC to a range of 31.250 kHz.

When MCG ATM is enabled by writing ATC[ATME] bit to 1, ATM machine will start auto trimming the selected IRC clock. During the autotrim process, ATC[ATME] will remain asserted and will deassert after ATM is completed or abort occurs. The MCG ATM is aborted if a write to any of the following control registers is detected including: C1, C3, C4, or ATC or if Stop mode is enabled. If an abort occurs, ATC[ATMF] fail flag will get asserted.

The ATM machine uses the bus clock as the external reference clock to perform the IRC auto-trim. Therefore, it is required that the MCG is configured in a clock mode where the reference clock used to generate the system clock is the external reference clock such as FBE clock mode. The MCG must not be configured in a clock mode where selected IRC ATM clock is used to generate the system clock. The bus clock is also required to be running with in the range of 8 - 16 MHz.

To perform the ATM on the selected IRC, the ATM machine uses the successive approximation technique to adjust the IRC trim bits to generate the desired IRC trimmed frequency. The ATM SARs each of the ATM IRC trim bits starting with the MSB. For each trim bit test, the ATM uses a pulse that is generated by the ATM selected IRC clock to enable a counter that counts number of ATM external clocks. At end of each trim bit, the ATM external counter value is compared to the ATCV[15:0] register value. Based on the comparison result, the ATM trim bit under test will get cleared or stay asserted. This is done until all trim bits have been tested by ATM SAR machine.

#### **Initialization / Application Information**

Before the ATM can be enabled, the ATM expected count needs to get derived and stored into the ATCV register. The ATCV expected count is derived based on the required target Internal Reference Clock (IRC) frequency, the frequency of the external reference clock, and using the following formula:

ATCV Expected Count Value = 
$$21*(Fe/Fr)$$

- Fr = Target Internal Reference Clock (IRC) Trimmed Frequency
- Fe = External Clock Frequency

If the auto trim is being performed on the 4 MHz IRC, the calculated expected count value must be multiplied by 128 before storing it in the ATCV register. Therefore, the ATCV Expected Count Value for trimming the 4 MHz IRC is calculated using the following farmula.

Expected Count Value = 
$$(Fe/Fr) *21*(128)$$

## 20.5 Initialization / Application Information

This section describes how to initialize and configure the MCG module in an application. The following sections include examples on how to initialize the MCG and properly switch between the various available modes.

## 20.5.1 MCG Module Initialization Sequence

The MCG comes out of reset configured for FEI mode. The internal reference will stabilize in  $t_{irefsts}$  microseconds before the FLL can acquire lock. As soon as the internal reference is stable, the FLL will acquire lock in  $t_{fll\ acquire}$  milliseconds.

## 20.5.1.1 Initializing the MCG

Because the MCG comes out of reset in FEI mode, the only MCG modes that can be directly switched to upon reset are FEE, FBE, and FBI modes (see Figure 20-12). Reaching any of the other modes requires first configuring the MCG for one of these three intermediate modes. Care must be taken to check relevant status bits in the MCG status register reflecting all configuration changes within each mode.

To change from FEI mode to FEE or FBE modes, follow this procedure:

1. Enable the external clock source by setting the appropriate bits in C2 register.

- 2. Write to C1 register to select the clock mode.
  - If entering FEE mode, set C1[FRDIV] appropriately, clear the C1[IREFS] bit to switch to the external reference, and leave the C1[CLKS] bits at 2'b00 so that the output of the FLL is selected as the system clock source.
  - If entering FBE, clear the C1[IREFS] bit to switch to the external reference and change the C1[CLKS] bits to 2'b10 so that the external reference clock is selected as the system clock source. The C1[FRDIV] bits should also be set appropriately here according to the external reference frequency to keep the FLL reference clock in the range of 31.25 kHz to 39.0625 kHz. Although the FLL is bypassed, it is still on in FBE mode.
  - The internal reference can optionally be kept running by setting the C1[IRCLKEN] bit. This is useful if the application will switch back and forth between internal and external modes. For minimum power consumption, leave the internal reference disabled while in an external clock mode.
- 3. Once the proper configuration bits have been set, wait for the affected bits in the MCG status register to be changed appropriately, reflecting that the MCG has moved into the proper mode.
  - If the MCG is in FEE, FBE, PEE, PBE, or BLPE mode, and C2[EREFS] was also set in step 1, wait here for S[OSCINIT] bit to become set indicating that the external clock source has finished its initialization cycles and stabilized.
  - If in FEE mode, check to make sure the S[IREFST] bit is cleared before moving on.
  - If in FBE mode, check to make sure the S[IREFST] bit is cleared and S[CLKST] bits have changed to 2'b10 indicating the external reference clock has been appropriately selected. Although the FLL is bypassed, it is still on in FBE mode.
- 4. Write to the C4 register to determine the DCO output (MCGFLLCLK) frequency range.
  - By default, with C4[DMX32] cleared to 0, the FLL multiplier for the DCO output is 640. For greater flexibility, if a mid-low-range FLL multiplier of 1280 is desired instead, set C4[DRST\_DRS] bits to 2'b01 for a DCO output frequency of 40 MHz. If a mid high-range FLL multiplier of 1920 is desired instead, set the C4[DRST\_DRS] bits to 2'b10 for a DCO output frequency of 60 MHz. If a high-range FLL multiplier of 2560 is desired instead, set the C4[DRST\_DRS] bits to 2'b11 for a DCO output frequency of 80 MHz.

#### **Initialization / Application Information**

- When using a 32.768 kHz external reference, if the maximum low-range DCO frequency that can be achieved with a 32.768 kHz reference is desired, set C4[DRST\_DRS] bits to 2'b00 and set C4[DMX32] bit to 1. The resulting DCO output (MCGOUTCLK) frequency with the new multiplier of 732 will be 24 MHz.
- When using a 32.768 kHz external reference, if the maximum mid-range DCO frequency that can be achieved with a 32.768 kHz reference is desired, set C4[DRST\_DRS] bits to 2'b01 and set C4[DMX32] bit to 1. The resulting DCO output (MCGOUTCLK) frequency with the new multiplier of 1464 will be 48 MHz.
- When using a 32.768 kHz external reference, if the maximum mid high-range DCO frequency that can be achieved with a 32.768 kHz reference is desired, set C4[DRST\_DRS] bits to 2'b10 and set C4[DMX32] bit to 1. The resulting DCO output (MCGOUTCLK) frequency with the new multiplier of 2197 will be 72 MHz.
- When using a 32.768 kHz external reference, if the maximum high-range DCO frequency that can be achieved with a 32.768 kHz reference is desired, set C4[DRST\_DRS] bits to 2'b11 and set C4[DMX32] bit to 1. The resulting DCO output (MCGOUTCLK) frequency with the new multiplier of 2929 will be 96 MHz.
- 5. Wait for the FLL lock time to guarantee FLL is running at new C4[DRST\_DRS] and C4[DMX32] programmed frequency.

To change from FEI clock mode to FBI clock mode, follow this procedure:

- 1. Change C1[CLKS] bits in C1 register to 2'b01 so that the internal reference clock is selected as the system clock source.
- 2. Wait for S[CLKST] bits in the MCG status register to change to 2'b01, indicating that the internal reference clock has been appropriately selected.
- 3. Write to the C2 register to determine the IRCS output (IRCSCLK) frequency range.
  - By default, with C2[IRCS] cleared to 0, the IRCS selected output clock is the slow internal reference clock (32 kHz IRC). If the faster IRC is desired, set C2[IRCS] bit to 1 for a IRCS output frequency of 2 MHz.

## 20.5.2 Using a 32.768 kHz Reference

In FEE and FBE modes, if using a 32.768 kHz external reference, at the default FLL multiplication factor of 640, the DCO output (MCGFLLCLK) frequency is 20.97 MHz at low-range. If C4[DRST\_DRS] bits are set to 2'b01, the multiplication factor is doubled to 1280, and the resulting DCO output frequency is 41.94 Mhz at mid-low-range. If C4[DRST\_DRS] bits are set to 2'b10, the multiplication factor is set to 1920, and the resulting DCO output frequency is 62.91 MHz at mid high-range. If C4[DRST\_DRS] bits are set to 2'b11, the multiplication factor is set to 2560, and the resulting DCO output frequency is 83.89 MHz at high-range.

In FBI and FEI modes, setting C4[DMX32] bit is not recommended. If the internal reference is trimmed to a frequency above 32.768 kHz, the greater FLL multiplication factor could potentially push the microcontroller system clock out of specification and damage the part.

## 20.5.3 MCG Mode Switching

When switching between operational modes of the MCG, certain configuration bits must be changed in order to properly move from one mode to another. Each time any of these bits are changed (C6[PLLS], C1[IREFS], C1[CLKS], C2[IRCS], or C2[EREFS]), the corresponding bits in the MCG status register (PLLST, IREFST, CLKST, IRCST, or OSCINIT) must be checked before moving on in the application software.

Additionally, care must be taken to ensure that the reference clock divider (C1[FRDIV] and C5[PRDIV]) is set properly for the mode being switched to. For instance, in PEE mode, if using a 4 MHz crystal, C5[PRDIV] must be set to 2'b000 (divide-by-1) or 2'b001 (divide -by-2) in order to divide the external reference down to the required frequency between 2 and 4 MHz.

In FBE, FEE, FBI, and FEI modes, at any time, the application can switch the FLL multiplication factor between 640, 1280, 1920, and 2560 with C4[DRST\_DRS] bits. Writes to C4[DRST\_DRS] bits will be ignored if C2[LP]=1.

The table below shows MCGOUT frequency calculations using C1[FRDIV], C5[PRDIV], and C6[VDIV] settings for each clock mode.

**Table 20-15. MCGOUT Frequency Calculation Options** 

| Clock Mode                 | f <sub>MCGOUT</sub> 1  | Note                                                          |
|----------------------------|------------------------|---------------------------------------------------------------|
| FEI (FLL engaged internal) | (f <sub>int</sub> * F) | Typical f <sub>MCGOUT</sub> = 20 MHz immediately after reset. |

#### **Initialization / Application Information**

Table 20-15. MCGOUT Frequency Calculation Options (continued)

| Clock Mode                         | f <sub>MCGOUT</sub> 1          | Note                                                                      |
|------------------------------------|--------------------------------|---------------------------------------------------------------------------|
| FEE (FLL engaged external)         | (f <sub>ext</sub> / FLL_R) *F  | f <sub>ext</sub> / FLL_R must be in the range of 31.25 kHz to 39.0625 kHz |
| FBE (FLL bypassed external)        | f <sub>ext</sub>               | f <sub>ext</sub> / FLL_R must be in the range of 31.25 kHz to 39.0625 kHz |
| FBI (FLL bypassed internal)        | f <sub>int</sub>               | Typical f <sub>int</sub> = 32 kHz                                         |
| PEE (PLL engaged external)         | (f <sub>ext</sub> / PLL_R) * M | f <sub>ext</sub> / PLL_R must be in the range of 2 MHz to 4 MHz           |
| PBE (PLL bypassed external)        | f <sub>ext</sub>               | f <sub>ext</sub> / PLL_R must be in the range of 2 MHz to 4 MHz           |
| BLPI (Bypassed low power internal) | f <sub>int</sub>               |                                                                           |
| BLPE (Bypassed low power external) | f <sub>ext</sub>               |                                                                           |

<sup>1.</sup> FLL\_R is the reference divider selected by the C1[FRDIV] bits, PLL\_R is the reference divider selected by C5[PRDIV] bits, F is the FLL factor selected by C4[DRST\_DRS] and C4[DMX32] bits, and M is the multiplier selected by C6[VDIV] bits.

This section will include 3 mode switching examples using an 4 MHz external crystal. If using an external clock source less than 2 MHz, the MCG should not be configured for any of the PLL modes (PEE and PBE).

## 20.5.3.1 Example 1: Moving from FEI to PEE Mode: External Crystal = 4 MHz, MCGOUT Frequency = 48 MHz

In this example, the MCG will move through the proper operational modes from FEI to PEE to achieve 48 MHz MCGOUT frequency from 4 MHz external crystal reference.. First, the code sequence will be described. Then a flowchart will be included which illustrates the sequence.

- 1. First, FEI must transition to FBE mode:
  - a. C2 = 0x1C (2'b00011100)
    - C2[RANGE] set to 2'b01 because the frequency of 4 MHz is within the high frequency range
    - C2[HGO] set to 1 to configure the crystal oscillator for high gain operation
    - C2[EREFS] set to 1, because a crystal is being used
  - b. C1 = 0x90 (2'b10010000)
    - C1[CLKS] set to 2'b10 in order to select external reference clock as system clock source

- C1[FRDIV] set to 2'b010, or divide-by-128 because 4 MHz / 128 = 31.25 kHz which is in the 31.25 kHz to 39.0625 kHz range required by the FLL
- C1[IREFS] cleared to 0, selecting the external reference clock and enabling the external oscillator.
- c. Loop until S[OSCINIT] is 1, indicating the crystal selected by C2[EREFS] has been initialized..
- d. Loop until S[IREFST] is 0, indicating the external reference is the current source for the reference clock
- e. Loop until S[CLKST] is 2'b10, indicating that the external reference clock is selected to feed MCGOUT
- 2. Then configure C5[PRDIV] to generate correct PLL reference frequency.
  - a. C5 = 0x01 (2'b00000001)
    - C5[PRDIV] set to 2'b001, or divide-by-2 resulting in a pll reference frequency of 4 MHz/2 = 2 MHz.
- 3. Then, FBE must transition either directly to PBE mode or first through BLPE mode and then to PBE mode:
  - a. BLPE: If a transition through BLPE mode is desired, first set C2[LP] to 1.
  - b. BLPE/PBE: C6 = 0x40 (2'b01000000)
    - C6[PLLS] set to 1, selects the PLL. At this time, with a C1[PRDIV] value of 2'b001, the PLL reference divider is 2 (see PLL External Reference Divide Factor table), resulting in a reference frequency of 4 MHz/ 2 = 2 MHz. In BLPE mode, changing the C6[PLLS] bit only prepares the MCG for PLL usage in PBE mode.
    - C6[VDIV] set to 2'b0000, or multiply-by-24 because 2 MHz reference \* 24 = 48 MHz. In BLPE mode, the configuration of the VDIV bits does not matter because the PLL is disabled. Changing them only sets up the multiply value for PLL usage in PBE mode.
  - c. BLPE: If transitioning through BLPE mode, clear C2[LP] to 0 here to switch to PBE mode.

#### **Initialization / Application Information**

- d. PBE: Loop until S[PLLST] is set, indicating that the current source for the PLLS clock is the PLL.
- e. PBE: Then loop until S[LOCK] is set, indicating that the PLL has acquired lock.
- 4. Lastly, PBE mode transitions into PEE mode:
  - a. C1 = 0x10 (2'b00010000)
    - C1[CLKS] set to 2'b00 in order to select the output of the PLL as the system clock source.
  - b. Loop until S[CLKST] are 2'b11, indicating that the PLL output is selected to feed MCGOUT in the current clock mode.
    - Now, With PRDIV of divide-by-2, and C6[VDIV] of multiply-by-24, MCGOUT = [(4 MHz / 2) \* 24] = 48 MHz.



Figure 20-13. Flowchart of FEI to PEE Mode Transition using an 4 MHz crystal MCF51JF128 Reference Manual, Rev. 2, 03/2011

## 20.5.3.2 Example 2: Moving from PEE to BLPI Mode: MCGOUT Frequency =32 kHz

In this example, the MCG will move through the proper operational modes from PEE mode with a 4 MHz crystal configured for a 48 MHz MCGOUT frequency (see previous example) to BLPI mode with a 32 kHz MCGOUT frequency. First, the code sequence will be described. Then a flowchart will be included which illustrates the sequence.

- 1. First, PEE must transition to PBE mode:
  - a. C1 = 0x90 (2'b10010000)
    - C1[CLKS] set to 2'b10 in order to switch the system clock source to the external reference clock.
  - b. Loop until S[CLKST] are 2'b10, indicating that the external reference clock is selected to feed MCGOUT.
- 2. Then, PBE must transition either directly to FBE mode or first through BLPE mode and then to FBE mode:
  - a. BLPE: If a transition through BLPE mode is desired, first set C2[LP] to 1
  - b. BLPE/FBE: C6 = 0x00(2'b00000000)
    - C6[PLLS] clear to 0 to select the FLL. At this time, with C1[FRDIV] value of 2'b010, the FLL divider is set to 128, resulting in a reference frequency of 4 MHz / 128 = 31.25 kHz. If C1[FRDIV] was not previously set to 2'b010 (necessary to achieve required 31.25-39.06 kHz FLL reference frequency with an 4 MHz external source frequency), it must be changed prior to clearing C6[PLLS] bit. In BLPE mode, changing this bit only prepares the MCG for FLL usage in FBE mode. With C6[PLLS] = 0, the C6[VDIV] value does not matter.
  - c. BLPE: If transitioning through BLPE mode, clear C2[LP] to 0 here to switch to FBE mode.
  - d. FBE: Loop until S[PLLST] is cleared, indicating that the current source for the PLLS clock is the FLL.
- 3. Next, FBE mode transitions into FBI mode:
  - a. C1 = 0x54 (2'b01010100)

- C1[CLKS] set to 2'b01 in order to switch the system clock to the internal reference clock.
- C1[IREFS] set to 1 to select the internal reference clock as the reference clock source.
- C1[FRDIV] remain unchanged because the reference divider does not affect the internal reference.
- b. Loop until S[IREFST] is 1, indicating the internal reference clock has been selected as the reference clock source.
- c. Loop until S[CLKST] are 2'b01, indicating that the internal reference clock is selected to feed MCGOUT.
- 4. Lastly, FBI transitions into BLPI mode.
  - a. C2 = 0x02 (2'b00000010)
    - C2[LP] is 1
    - C2[RANGE], C2[HGO], C2[EREFS], C1[IRCLKEN], and C1[IREFSTEN] bits are ignored when the C1[IREFS] bit is set. They can remain set, or be cleared at this point.

#### **Initialization / Application Information**



Figure 20-14. Flowchart of PEE to BLPI Mode Transition using an 4 MHz crystal

## 20.5.3.3 Example 3: Moving from BLPI to FEE Mode

In this example, the MCG will move through the proper operational modes from BLPI mode at a 32 kHz MCGOUT frequency running off the internal reference clock (see previous example) to FEE mode using a 4 MHz crystal configured for a 20 MHz MCGOUT frequency. First, the code sequence will be described. Then a flowchart will be included which illustrates the sequence.

- 1. First, BLPI must transition to FBI mode.
  - a. C2 = 0x00 (2'b00000000)
    - C2[LP] is 0
- 2. Next, FBI will transition to FEE mode.
  - a. C2 = 0x1C (2'b00011100)
    - C2[RANGE] set to 2'b01 because the frequency of 4 MHz is within the high frequency range.
    - C2[HGO] set to 1 to configure the crystal oscillator for high gain operation.
    - C2[EREFS] set to 1, because a crystal is being used.
  - b. C1 = 0x10 (2'b00010000)
    - C1[CLKS] set to 2'b00 in order to select the output of the FLL as system clock source.
    - C1[FRDIV] remain at 2'b010, or divide-by-128 for a reference of 4 MHz / 128= 31.25 kHz.
    - C1[IREFS] cleared to 0, selecting the external reference clock.
  - c. Loop until S[OSCINIT] is 1, indicating the crystal selected by the C2[EREFS] bit has been initialized.
  - d. Loop until S[IREFST] is 0, indicating the external reference clock is the current source for the reference clock.
  - e. Loop until S[CLKST] are 2'b00, indicating that the output of the FLL is selected to feed MCGOUT.
  - f. Now, with a 31.25 kHz reference frequency, a fixed DCO multiplier of 640, MCGOUT = 31.25 kHz \* 640 / 1 = 20 MHz.

g. At this point, by default, the C4[DRST\_DRS] bits are set to 2'b00 and C4[DMX32] is cleared to 0. If the MCGOUT frequency of 40 MHz is desired instead, set the C4[DRST\_DRS] bits to 0x01 to switch the FLL multiplication factor from 640 to 1280. To return the MCGOUT frequency to 20 MHz, set C4[DRST\_DRS] bits to 2'b00 again, and the FLL multiplication factor will switch back to 640.



Figure 20-15. Flowchart of BLPI to FEE Mode Transition using an 4 MHz crystal

# Chapter 21 Oscillator (OSC)

#### 21.1 Introduction

The OSC module is a crystal oscillator. The module, in conjunction with an external crystal or resonator, generates a reference clock for the MCU.

### 21.2 Features and Modes

Key features of the module are:

- Supports 32 kHz crystals (Low Range mode)
- Supports 1–8 MHz, 8–32 MHz crystals and resonators (High Range mode)
- Automatic Gain Control (AGC) to optimize power consumption in high frequency ranges 1–8 MHz, 8–32 MHz using low-power mode
- High gain option in frequency ranges: 32 kHz, 1–8 MHz, and 8–32 MHz
- Voltage and frequency filtering to guarantee clock frequency and stability
- Optionally external input bypass clock from EXTAL signal directly
- One clock for MCU clock system
- Two clocks for on-chip peripherals that can work in Stop modes

Functional Description describes the module's operation in more detail.

## 21.3 Block Diagram

The OSC module uses a crystal or resonator to generate three filtered oscillator clock signals. Three clocks are output from OSC module: OSCCLK for MCU system, OSCERCLK for on-chip peripherals, and OSC32KCLK. The OSCCLK can only work in run mode. OSCERCLK and OSC32KCLK can work in low power modes. For the clock source assignments, refer to the clock distribution information of this MCU.

Refer to the chip configuration chapter for the external reference clock source in this MCU.

The following figure shows the block diagram of the OSC module.



Figure 21-1. OSC Module Block Diagram

## 21.4 OSC Signal Descriptions

The following table shows the user-accessible signals available for the OSC module. Refer to signal multiplexing information for this MCU for more details.

Table 21-1. OSC Signal Descriptions

| Signal | Description                     | I/O |
|--------|---------------------------------|-----|
| EXTAL  | External clock/Oscillator input | I   |
| XTAL   | Oscillator output               | 0   |

# 21.5 External Crystal / Resonator Connections

The connections for a crystal/resonator frequency reference are shown in the following figures. When using low-frequency, low-power mode, the only external component is the crystal or ceramic resonator itself. In the other oscillator modes, load capacitors  $(C_x, C_y)$  and feedback resistor  $(R_F)$  are required. In addition, a series resistor  $(R_S)$  may be used in high-gain modes. The following table shows all possible connections.

Table 21-2. External Caystal/Resonator Connections

| Oscillator Mode                      | Connections                                                        |
|--------------------------------------|--------------------------------------------------------------------|
| Low-frequency (32 kHz), low-power    | Connection 1                                                       |
| Low-frequency (32 kHz), high-gain    | Connection 2/Connection 4 <sup>1</sup> / Connection 3 <sup>2</sup> |
| High-frequency (1~32 MHz), low-power | Connection 1/Connection 3 <sup>2,3</sup>                           |
| High-frequency (1~32 MHz), high-gain | Connection 2/Connection 4 <sup>1</sup> / Connection 3 <sup>2</sup> |

- 1. When the frequency of the crystal is 32 kHz and the load capacitors (Cx, Cy) are less than 16 pF, use Connection 4.
- 2. When the load capacitors (Cx, Cy) are greater than 30 pF, use Connection 3.
- 3. With the low-power mode, the oscillator has the internal feedback resistor R<sub>F</sub>. Therefore, the feedback resistor must not be externally with the Connection 3.



Figure 21-2. Crystal/Ceramic Resonator Connections - Connection 1



Figure 21-3. Crystal/Ceramic Resonator Connections - Connection 2

### **NOTE**

Connection 1 and Connection 2 should use internal capacitors as the load of the oscillator by configuring the CR[SCxP] bits.



Figure 21-4. Crystal/Ceramic Resonator Connections - Connection 3



Figure 21-5. Crystal/Ceramic Resonator Connections - Connection 4

### 21.6 External Clock Connections

In external clock mode, the pins can be connected as shown below.

### **NOTE**

XTAL can be used as a GPIO when the GPIO alternate function is configured for it.



Figure 21-6. External Clock Connections

# 21.7 Memory Map/Register Definitions

Some oscillator module register bits are typically incorporated into other peripherals such as MCG or SIM.

### **OSCx** memory map

| Absolute address (hex) | Register name                  |  | Access | Reset value | Section/<br>page |
|------------------------|--------------------------------|--|--------|-------------|------------------|
| FFFF_8120              | OSC Control Register (OSC1_CR) |  | R/W    | 00h         | 21.7.1/472       |
| FFFF_8130              | OSC Control Register (OSC2_CR) |  | R/W    | 00h         | 21.7.1/472       |

# 21.7.1 OSC Control Register (OSCx\_CR)

After OSC is enabled and starts generating the clocks, the configurations such as low power and frequency range, must not be changed.

Addresses: OSC1\_CR is FFFF\_8120h base + 0h offset = FFFF\_8120h OSC2\_CR is FFFF\_8130h base + 0h offset = FFFF\_8130h



### OSCx\_CR field descriptions

| Field         | Description                                                                                                |
|---------------|------------------------------------------------------------------------------------------------------------|
| 7<br>ERCLKEN  | External Reference Enable Enables external reference clock (OSCERCLK).                                     |
|               | 0 External reference clock is inactive.                                                                    |
|               | 1 External reference clock is enabled.                                                                     |
| 6<br>Reserved | This read-only bit is reserved and always has the value zero.                                              |
| 5<br>EREFSTEN | External Reference Stop Enable                                                                             |
|               | Controls whether or not the external reference clock (OSCERCLK) remains enabled when MCU enters Stop mode. |
|               | 0 External reference clock is disabled in Stop mode.                                                       |
|               | 1 External reference clock stays enabled in Stop mode if ERCLKEN is set before entering Stop mode.         |
| 4<br>Reserved | This read-only bit is reserved and always has the value zero.                                              |
| 3<br>SC2P     | Oscillator 2 pF Capacitor Load Configure                                                                   |
|               | Configures the oscillator load.                                                                            |
|               | 0 Disable the selection.                                                                                   |
|               | 1 Add 2 pF capacitor to the oscillator load.                                                               |
| 2<br>SC4P     | Oscillator 4 pF Capacitor Load Configure                                                                   |

Table continues on the next page...

### OSCx\_CR field descriptions (continued)

| Field      | Description                                   |
|------------|-----------------------------------------------|
|            | Configures the oscillator load.               |
|            | 0 Disable the selection.                      |
|            | 1 Add 4 pF capacitor to the oscillator load.  |
| 1<br>SC8P  | Oscillator 8 pF Capacitor Load Configure      |
|            | Configures the oscillator load.               |
|            | 0 Disable the selection.                      |
|            | 1 Add 8 pF capacitor to the oscillator load.  |
| 0<br>SC16P | Oscillator 16 pF Capacitor Load Configure     |
|            | Configures the oscillator load.               |
|            | 0 Disable the selection.                      |
|            | 1 Add 16 pF capacitor to the oscillator load. |

# 21.8 Functional Description

This following sections provide functional details of the module.

# 21.8.1 OSC Module States

The states of the OSC module are shown in the following figure. The states and their transitions between each other are described in this section.

#### **Functional Description**



Figure 21-10. OSC Module State Diagram
NOTE

XTL\_CLK is the clock generated internally from OSC circuits.

### 21.8.1.1 Off

The OSC enters the Off state when the system does not require OSC clocks. Upon entering this state, XTL\_CLK is static unless OSC is configured to select the clock from the EXTAL pad by clearing the external reference clock selection bit. For details regarding the external reference clock source in this MCU, refer to the chip configuration chapter. The EXTAL and XTAL pins are also decoupled from all other oscillator circuitry in this state. The OSC module circuitry is configured to draw minimal current.

# 21.8.1.2 Oscillator Start-Up

The OSC enters start-up state when it is configured to generate clocks (internally the OSC\_EN transitions high) using the internal oscillator circuits by setting the external reference clock selection bit. In this state, the OSC module is enabled and oscillations are starting up, but have not yet stabilized. When the oscillation amplitude becomes large enough to pass through the input buffer, XTL\_CLK begins clocking the counter. When the counter reaches 4096 cycles of XTL\_CLK, the oscillator is considered stable and XTL\_CLK is passed to the output clock OSC\_CLK\_OUT.

### 21.8.1.3 Oscillator Stable

The OSC enters stable state when it is configured to generate clocks (internally the OSC\_EN transitions high) using the internal oscillator circuits by setting the external reference clock selection bit and the counter reaches 4096 cycles of XTL\_CLK (when CNT\_DONE\_4096 is high). In this state, the OSC module is producing a stable output clock on OSC\_CLK\_OUT. Its frequency is determined by the external components being used.

### 21.8.1.4 External Clock Mode

The OSC enters external clock state when it is enabled and external reference clock selection bit is cleared. For details regarding external reference clock source in this MCU, refer to the chip configuration chapter. In this state, the OSC module is set to buffer (with hysteresis) a clock from EXTAL onto the OSC\_CLK\_OUT. Its frequency is determined by the external clock being supplied.

### 21.8.2 OSC Module Modes

The OSC is a Pierce-type oscillator that supports external crystals or resonators operating over the frequency ranges shown in Table 21-9. These modes assume the following conditions: OSC is enabled to generate clocks (OSC\_EN=1), configured to generate clocks internally (MCG\_C2[EREFS] = 1), and some or one of the other peripherals (MCG, Timer, and so on) is configured to use the oscillator output clock (OSC\_CLK\_OUT).

#### **Functional Description**

Table 21-9. Oscillator Modes

| Mode                            | Frequency Range                                                      |  |
|---------------------------------|----------------------------------------------------------------------|--|
| Low-frequency, high-gain        | f <sub>osc lo</sub> (1 kHz) up to f <sub>osc lo</sub> (32.768 kHz)   |  |
| Low-frequency, low-power (VLP)  | - 1 <sub>osc_lo</sub> (1 κπ2) up to 1 <sub>osc_lo</sub> (32.766 κπ2) |  |
| High-frequency mode1, high-gain | f (1 MHz) up to f (9 MHz)                                            |  |
| High-frequency mode1, low-power | f <sub>osc_hi_1</sub> (1 MHz) up to f <sub>osc_hi_1</sub> (8 MHz)    |  |
| High-frequency mode2, high-gain | f <sub>osc hi 2</sub> (8 MHz) up to f <sub>osc hi 2</sub> (32 MHz)   |  |
| High-frequency mode2, low-power | - Tosc_hi_2 (6 Wil12) up to Tosc_hi_2 (32 Wil12)                     |  |

#### NOTE

For information about low power modes of operation used in this chip and their alignment with some OSC modes, refer to the chip's Power Management details.

# 21.8.2.1 Low-Frequency, High-Gain Mode

In Low-frequency, high-gain mode, the oscillator uses a simple inverter-style amplifier. The gain is set to achieve rail-to-rail oscillation amplitudes.

The oscillator input buffer in this mode is single-ended. It provides low pass frequency filtering as well as hysteresis for voltage filtering and converts the output to logic levels. In this mode, the internal capacitors could be used.

# 21.8.2.2 Low-Frequency, Low-Power Mode

In low-frequency, low-power mode, the oscillator uses a gain control loop to minimize power consumption. As the oscillation amplitude increases, the amplifier current is reduced. This continues until a desired amplitude is achieved at steady-state. This mode provides low pass frequency filtering as well as hysteresis for voltage filtering and converts the output to logic levels. In this mode, the internal capacitors could be used, the internal feedback resistor is connected, and no external resistor should be used.

In this mode, the amplifier inputs, gain-control input, and input buffer input are all capacitively coupled for leakage tolerance (not sensitive to the DC level of EXTAL).

Also in this mode, all external components except for the resonator itself are integrated, which includes the load capacitors and feeback resistor that biases EXTAL.

# 21.8.2.3 High-Frequency, High-Gain Mode

In high-frequency, high-gain mode, the oscillator uses a simple inverter-style amplifier. The gain is set to achieve rail-to-rail oscillation amplitudes. This mode provides low pass frequency filtering as well as hysteresis for voltage filtering and converts the output to logic levels. In this mode, the internal capacitors could be used.

# 21.8.2.4 High-Frequency, Low-Power Mode

In high-frequency, low-power mode, the oscillator uses a gain control loop to minimize power consumption. As the oscillation amplitude increases, the amplifier current is reduced. This continues until a desired amplitude is achieved at steady-state. In this mode, the internal capacitors could be used, the internal feedback resistor is connected, and no external resistor should be used.

The oscillator input buffer in this mode is differential. It provides low pass frequency filtering as well as hysteresis for voltage filtering and converts the output to logic levels.

### 21.8.3 Counter

The oscillator output clock (OSC\_CLK\_OUT) is gated off until the counter has detected 4096 cycles of its input clock (XTL\_CLK). After 4096 cycles are completed, the counter passes XTL\_CLK onto OSC\_CLK\_OUT. This counting time-out is used to guarantee output clock stability.

# 21.8.4 Reference Clock Pin Requirements

The OSC module requires use of both the EXTAL and XTAL pins to generate an output clock in Oscillator mode, but requires only the EXTAL pin in External clock mode. The EXTAL and XTAL pins are available for I/O. For the implementation of these pins on this device, refer to the Signal Multiplexing chapter.

# **21.9** Reset

There is no reset state associated with the OSC module. The counter logic is reset when the OSC is not configured to generate clocks.

There are no sources of reset requests for the OSC module.

# 21.10 Low Power Modes Operation

When the MCU enters Stop modes, the OSC is functional depending on ERCLKEN and EREFSETN bit settings. If both these bits are set, the OSC is in operation. In Low Leakage Stop (LLS) modes, the OSC holds all register settings. If ERCLKEN and EREFSTEN bits are set before entry to Low Leakage Stop modes, the OSC is still functional in these modes. After waking up from Very Low Leakage Stop (VLLSx) modes, all OSC register bits are reset and initialization is required through software.

# 21.11 Interrupts

The OSC module does not generate any interrupts.

# **Chapter 22 Flash Memory Controller (FMC)**

### 22.1 Introduction

The Flash Memory Controller (FMC) is a memory acceleration unit that provides:

- an interface between the chip and the 32-bit program flash memory and FlexMemory (FlexNVM and FlexRAM used as EEPROM).
- a buffer and a cache that can accelerate program flash memory data transfers.

### 22.1.1 Overview

The Flash Memory Controller manages the interface between the chip and the 32-bit program flash memory and FlexMemory (FlexNVM as well as FlexRAM used as EEPROM). The FMC receives status information detailing the configuration of the flash memory and FlexMemory and uses this information to ensure a proper interface. The FMC supports 8-bit, 16-bit, and 32-bit read operations from the program flash memory and FlexNVM used as data flash memory. A write operation to program flash or FlexNVM used as data flash memory results in a bus error. The FMC interface to FlexNVM and FlexRAM when they are used as EEPROM allows both read and write 8-bit, 16-bit, and 32-bit operations.

In addition, for program flash memory, the FMC provides two separate mechanisms for accelerating the interface between the device and the flash. A 32-bit speculation buffer can prefetch the next 32-bit flash memory location, and a 4-way, 4-set program flash memory cache can store previously accessed program flash memory data for quick access times.

# 22.1.2 Features

The FMC's features include:

#### **Modes of operation**

- Interface between the device and the 32-bit program flash memory and FlexMemory:
  - 8-bit, 16-bit, and 32-bit read operations to nonvolatile memory (flash and FlexNVM used as data flash memory).
  - 8-bit, 16-bit, and 32-bit read and write operations to the FlexNVM and FlexRAM used as EEPROM.
  - Consecutive read accesses (such as 0x0,0x4) to program flash memory return the second read data with no wait states when the buffer or cache is enabled. The memory returns 32 bits via the 32-bit bus access.
- Acceleration of data transfer from the program flash memory to the device:
  - 32-bit prefetch speculation buffer for program flash accesses for crossbar switch master 0 (V1 ColdFire CPU) with controls for instruction/data access
  - 4-way, 4-set, 32-bit line size program flash memory cache for a total of sixteen 32-bit entries with invalidation control

# 22.2 Modes of operation

The FMC operates only when the chip accesses the program flash memory or FlexMemory. In terms of chip power modes:

- The FMC operates only in run and wait modes, including VLPR and VLPW modes.
- For any power mode where the program flash memory or FlexMemory cannot be accessed, the FMC is disabled.

# 22.3 External signal description

The FMC has no external (off-chip) signals.

# 22.4 Memory map and register descriptions

The ColdFire CPU's programming model provides control and configuration of the flash controller's speculation and cache functions with bits in the CPU Control Register (CPUCR). For details, see the description of the CPUCR register.

#### **NOTE**

Program the Flash Memory Controller's configuration and control settings only while the Flash Memory Controller is idle.

Changing settings while a flash access is in progress can lead to non-deterministic behavior.

#### **NOTE**

System software is required to maintain memory coherence when any segment of the program flash memory cache is programmed. For example, all buffer data associated with the reprogrammed flash should be invalidated. Accordingly, cache program visible writes must occur after a programming or erase event is completed and before the new memory image is accessed.

# 22.5 Functional description

The FMC is a flash acceleration unit with flexible buffers for user configuration. Besides managing the interface between the chip and the program flash memory and FlexMemory, the FMC can be used to customize the program flash memory cache and buffer to provide single-cycle system clock data access times. Whenever a hit occurs for the prefetch speculation buffer or the cache (when enabled), the requested data is transferred within a single system clock. (The basic flash access time is two processor cycles.)

Upon system reset, the FMC is configured to provide buffering for transfers from the program flash memory. Prefetch support for data and instructions is enabled for program flash accesses for crossbar switch master 0 (V1 ColdFire CPU). The program flash memory cache is enabled and configured for instruction replacement.

Though the default configuration provides flash acceleration, advanced users may desire to customize the FMC buffer configurations to maximize throughput for their use cases. For example, the controls enable buffering per access type (data or instruction). When reconfiguring the FMC, do not program the control and configuration inputs to the FMC while the program flash memory or FlexMemory is being accessed. Instead, change them with a routine executing from RAM in supervisor mode.

**Functional description** 

# **Chapter 23 Flash Memory Module (FTFL)**

### 23.1 Introduction

The FTFL module includes the following accessible memory regions:

- Program flash memory for vector space and code store
- FlexNVM for data store and additional code store
- FlexRAM for high-endurance data store or traditional RAM

Flash memory is ideal for single-supply applications, permitting in-the-field erase and reprogramming operations without the need for any external high voltage power sources.

The FTFL module includes a memory controller that executes commands to modify flash memory contents. An erased bit reads '1' and a programmed bit reads '0'. The programming operation is unidirectional; it can only move bits from the '1' state (erased) to the '0' state (programmed). Only the erase operation restores bits from '0' to '1'; bits cannot be programmed from a '0' to a '1'.

#### **CAUTION**

A flash memory location must be in the erased state before being programmed. Cumulative programming of bits (back-to-back program operations without an intervening erase) within a flash memory location is not allowed. Re-programming of existing 0s to 0 is not allowed as this overstresses the device.

The standard shipping condition for flash memory is erased with security disabled. Data loss over time may occur due to degradation of the erased ('1') states and/or programmed ('0') states. Therefore, it is recommended that each flash block or sector be re-erased immediately prior to factory programming to ensure that the full data retention capability is achieved.

### **23.1.1 Features**

The FTFL module includes the following features.

#### NOTE

See the device's Chip Configuration details for the exact amount of flash memory available on your device.

# 23.1.1.1 Program Flash Memory Features

- Program flash protection scheme prevents accidental program or erase of stored data
- Automated, built-in, program and erase algorithms with verify
- Section programming for faster bulk programming times
- Read access to program flash memory possible while programming or erasing data in the data flash memory or FlexRAM

# 23.1.1.2 FlexNVM Memory Features

When FlexNVM is partitioned for data flash memory:

- Protection scheme prevents accidental program or erase of stored data
- Automated, built-in program and erase algorithms with verify
- Section programming for faster bulk programming times
- Read access to data flash memory possible while programming or erasing data in the program flash memory

### 23.1.1.3 FlexRAM Features

- Memory that can be used as traditional RAM or as high-endurance EEPROM storage
- Up to 2 Kbytes of FlexRAM configured for EEPROM or traditional RAM operations
- When configured for EEPROM:
  - Protection scheme prevents accidental program or erase of data written for EEPROM

- Built-in hardware emulation scheme to automate EEPROM record maintenance functions
- Programmable EEPROM data set size and FlexNVM partition code facilitating EEPROM memory endurance trade-offs
- Supports FlexRAM aligned writes of 1, 2, or 4 bytes at a time
- Read access to FlexRAM possible while programming or erasing data in the program or data flash memory
- When configured for traditional RAM:
  - Read and write access possible to the FlexRAM while programming or erasing data in the program or data flash memory

#### 23.1.1.4 Other FTFL Module Features

- Internal high-voltage supply generator for flash memory program and erase operations
- Optional interrupt generation upon flash command completion
- Supports MCU security mechanisms which prevent unauthorized access to the flash memory contents

# 23.1.2 Block Diagram

The block diagram of the FTFL module is shown in the following figure.

#### Introduction



Figure 23-1. FTFL Block Diagram

# 23.1.3 Glossary

**Command write sequence** — A series of MCU writes to the Flash FCCOB register group that initiates and controls the execution of Flash algorithms that are built into the FTFL module.

**Data flash memory** — Partitioned from the FlexNVM block, the data flash memory provides nonvolatile storage for user data, boot code, and additional code store.

**Data flash sector** — The data flash sector is the smallest portion of the data flash memory that can be erased.

**EEPROM** — Using a built-in filing system, the FTFL module emulates the characteristics of an EEPROM by effectively providing a high-endurance, byte-writeable (program and erase) NVM.

**EEPROM backup data header** — The EEPROM backup data header is comprised of a 32-bit field found in EEPROM backup data memory which contains information used by the EEPROM filing system to determine the status of a specific EEPROM backup flash sector.

**EEPROM backup data record** — The EEPROM backup data record is comprised of a 2-bit status field, a 14-bit address field, and a 16-bit data field found in EEPROM backup data memory which is used by the EEPROM filing system. If the status field indicates a record is valid, the data field is mirrored in the FlexRAM at a location determined by the address field.

**EEPROM backup data memory** — Partitioned from the FlexNVM block, EEPROM backup data memory provides nonvolatile storage for the EEPROM filing system representing data written to the FlexRAM requiring highest endurance.

**EEPROM backup data sector** — The EEPROM backup data sector contains one EEPROM header and up to 255 EEPROM backup data records, which are used by the EEPROM filing system.

**Endurance** — The number of times that a flash memory location can be erased and reprogrammed.

**FCCOB** (**Flash Common Command Object**) — A group of flash registers that are used to pass command, address, data, and any associated parameters to the memory controller in the FTFL module.

**Flash block** — A macro within the FTFL module which provides the nonvolatile memory storage.

**FlexMemory** — FTFL configuration that supports data flash, EEPROM, and FlexRAM.

**FlexNVM Block** — The FlexNVM block can be configured to be used as data flash memory, EEPROM backup flash memory, or a combination of both.

**FlexRAM** — The FlexRAM refers to a RAM, dedicated to the FTFL module, that can be configured to store EEPROM data or as traditional RAM. When configured for EEPROM, valid writes to the FlexRAM generates a new EEPROM backup data record stored in the EEPROM backup flash memory.

**FTFL Module** — All flash blocks plus a digital logic wrapper providing high-level control, an interface to MCU buses.

**IFR** — Nonvolatile information register found in each flash block, separate from the main memory array.

**NVM** — Nonvolatile memory. A memory technology that maintains stored data during power-off. The flash array is an NVM using NOR-type flash memory technology.

**NVM Normal Mode** — An NVM mode that provides basic user access to FTFL resources. The CPU or other bus masters initiate flash program and erase operations (or other FTFL commands) using writes to the FCCOB register group in the FTFL module.

#### **External Signal Description**

**NVM Special Mode** — An NVM mode enabling external, off-chip access to the memory resources in the FTFL module. A reduced FTFL command set is available when the MCU is secured. See the Chip Configuration details for information on when this mode is used.

**Phrase** — 64 bits of data with an aligned phrase having byte-address[2:0] = 000.

**Longword** — 32 bits of data with an aligned longword having byte-address[1:0] = 00.

**Word** — 16 bits of data with an aligned word having byte-address[0] = 0.

**Program flash** — The program flash memory provides nonvolatile storage for vectors and code store.

**Program flash Sector** — The smallest portion of the program flash memory (consecutive addresses) that can be erased.

**Retention** — The length of time that data can be kept in the NVM without experiencing errors upon readout. Since erased (1) states are subject to degradation just like programmed (0) states, the data retention limit may be reached from the last erase operation (not from the programming time).

**RWW**— Read-While-Write. The ability to simultaneously read from one memory resource while commanded operations are active in another memory resource.

**Section Program Buffer** — Lower half of the FlexRAM allocated for storing large amounts of data for programming via the Program Section command.

**Secure** — An MCU state conveyed to the FTFL module as described in the Chip Configuration details for this device. In the secure state, reading and changing NVM contents is restricted.

# 23.2 External Signal Description

The FTFL module contains no signals that connect off-chip.

# 23.3 Memory Map and Registers

This section describes the memory map and registers for the FTFL module. Data read from unimplemented memory space in the FTFL module is undefined. Writes to unimplemented or reserved memory space (registers) in the FTFL module are ignored.

# 23.3.1 Flash Configuration Field Description

The program flash memory contains a 16-byte flash configuration field that stores default protection settings (loaded on reset) and security information that allows the MCU to restrict access to the FTFL module.

| Flash Configuration Field Byte<br>Address | Size (Bytes) | Field Description                                                                                                               |
|-------------------------------------------|--------------|---------------------------------------------------------------------------------------------------------------------------------|
| 0x0_0400 - 0x0_0407                       | 8            | Backdoor Comparison Key. Refer to<br>Verify Backdoor Access Key Command<br>and Unsecuring the MCU Using<br>Backdoor Key Access. |
| 0x0_0408 - 0x0_040B                       | 4            | Program flash protection bytes. Refer to the description of the Program Flash Protection Registers (FPROT0-3).                  |
| 0x0_040C                                  | 1            | Data flash protection byte. Refer to the description of the Data Flash Protection Register (FDPROT).                            |
| 0x0_040D                                  | 1            | EEPROM protection byte. Refer to the description of the EEPROM Protection Register (FEPROT).                                    |
| 0x0_040E                                  | 1            | Flash nonvolatile option byte. Refer to the description of the Flash Option Register (FOPT).                                    |
| 0x0_040F                                  | 1            | Flash security byte. Refer to the description of the Flash Security Register (FSEC).                                            |

# 23.3.2 Program Flash IFR Map

The program flash IFR is nonvolatile information memory that can be read freely, but the user has no erase and limited program capabilities (see the Read Once, Program Once, and Read Resource commands in Read Once Command, Program Once Command and Read Resource Command). The contents of the program flash IFR are summarized in the following table and further described in the subsequent paragraphs.

| Address Range | ange Size (Bytes) Field Description |                    |
|---------------|-------------------------------------|--------------------|
| 0x00 – 0xBD   | 190                                 | Reserved           |
| 0xC0 – 0xFF   | 64                                  | Program Once Field |

**Memory Map and Registers** 

# 23.3.2.1 Program Once Field

The Program Once Field in the program flash IFR provides 64 bytes of user data storage separate from the program flash main array. The user can program the Program Once Field one time only as there is no program flash IFR erase mechanism available to the user. The Program Once Field can be read any number of times. This section of the program flash IFR is accessed in 4-Byte records using the Read Once and Program Once commands (see Read Once Command and Program Once Command).

# 23.3.3 Data Flash IFR Map

The data flash IFR is a 256 byte nonvolatile information memory that can be read and erased, but the user has limited program capabilities in the data flash IFR (see the Program Partition command in Program Partition Command, the Erase All Blocks command in Erase All Blocks Command, and the Read Resource command in Read Resource Command). The contents of the data flash IFR are summarized in the following table and further described in the subsequent paragraphs.

| Address Range Size (Bytes) Field Description |     | Field Description      |
|----------------------------------------------|-----|------------------------|
| 0x00 – 0xFD                                  | 254 | Reserved               |
| 0xFE                                         | 1   | EEPROM data set size   |
| 0xFF                                         | 1   | FlexNVM partition code |

### 23.3.3.1 EEPROM Data Set Size

The EEPROM data set size byte in the data flash IFR supplies information which determines the amount of FlexRAM used in each of the available EEPROM subsystems. To program the EEESIZE value, see the Program Partition command described in Program Partition Command.

Table 23-1. EEPROM Data Set Size



Table 23-2. EEPROM Data Set Size Field Description

| Field    | Description                                                                                                           |
|----------|-----------------------------------------------------------------------------------------------------------------------|
| 7-4      | This read-only bitfield is reserved and must always be written as one.                                                |
| Reserved |                                                                                                                       |
| 3-0      | EEPROM Size — Encoding of the total available FlexRAM for EEPROM use.                                                 |
| EEESIZE  | NOTE: EEESIZE must be 0 bytes (1111b) when the FlexNVM partition code (FlexNVM Partition Code) is set to 'No EEPROM'. |
|          | '0000' = Reserved                                                                                                     |
|          | '0001' = Reserved                                                                                                     |
|          | '0010' = Reserved                                                                                                     |
|          | '0011' = 2,048 Bytes                                                                                                  |
|          | '0100' = 1,024 Bytes                                                                                                  |
|          | '0101' = 512 Bytes                                                                                                    |
|          | '0110' = 256 Bytes                                                                                                    |
|          | '0111' = 128 Bytes                                                                                                    |
|          | '1000' = 64 Bytes                                                                                                     |
|          | '1001' = 32 Bytes                                                                                                     |
|          | '1010' = Reserved                                                                                                     |
|          | '1011' = Reserved                                                                                                     |
|          | '1100' = Reserved                                                                                                     |
|          | '1101' = Reserved                                                                                                     |
|          | '1110' = Reserved                                                                                                     |
|          | '1111' = 0 Bytes                                                                                                      |

### 23.3.3.2 FlexNVM Partition Code

The FlexNVM Partition Code byte in the data flash IFR supplies a code which specifies how to split the FlexNVM block between data flash memory and EEPROM backup memory supporting EEPROM functions. To program the DEPART value, see the Program Partition command described in Program Partition Command.

Table 23-3. FlexNVM Partition Code

|   | Data                        | a Flash IFR: 0x0 | 00FF |   |     |     |   |
|---|-----------------------------|------------------|------|---|-----|-----|---|
| 7 | 6                           | 5                | 4    | 3 | 2   | 1   | 0 |
| 1 | 1                           | 1                | 1    |   | DEP | ART |   |
|   | = Unimplemented or Reserved |                  |      |   |     |     |   |

#### **Memory Map and Registers**

Table 23-4. FlexNVM Partition Code Field Description

| Field    | Description                                                                                       |
|----------|---------------------------------------------------------------------------------------------------|
| 7-4      | This read-only bitfield is reserved and must always be written as one.                            |
| Reserved |                                                                                                   |
| 3-0      | FlexNVM Partition Code — Encoding of the data flash / EEPROM backup split within the FlexNVM      |
| DEPART   | memory block. FlexNVM memory not partitioned for data flash will be used to store EEPROM records. |
|          | 0000 = 32 Kbytes of data flash, No EEPROM backup (No EEPROM)                                      |
|          | 0001 = 24 Kbytes of data flash, 8 Kbytes of EEPROM backup                                         |
|          | 0010 = 16 Kbytes of data flash, 16 Kbytes of EEPROM backup                                        |
|          | 0011 = No data flash, 32 Kbytes of EEPROM backup                                                  |
|          | 0100 = Reserved                                                                                   |
|          | 0101 = Reserved                                                                                   |
|          | 0110 = Reserved                                                                                   |
|          | 0111 = Reserved                                                                                   |
|          | 1000 = No data flash, 32 Kbytes of EEPROM backup                                                  |
|          | 1001 = 8 Kbytes of data flash, 24 Kbytes of EEPROM backup                                         |
|          | 1010 = 16 Kbytes of data flash, 16 Kbytes of EEPROM backup                                        |
|          | 1011 = 32 Kbytes of data flash, No EEPROM backup (No EEPROM)                                      |
|          | 1100 = Reserved                                                                                   |
|          | 1101 = Reserved                                                                                   |
|          | 1110 = Reserved                                                                                   |
|          | 1111 = Reserved (defaults to 32 Kbytes of data flash, No EEPROM)                                  |

# 23.3.4 Register Descriptions

The FTFL module contains a set of memory-mapped control and status registers.

#### NOTE

While a command is running (FSTAT[CCIF]=0), register writes are not accepted to any register except FCNFG and FSTAT. The no-write rule is relaxed during the start-up reset sequence, prior to the initial rise of CCIF. During this initialization period the user may write any register. All register writes are also disabled (except for registers FCNFG and FSTAT) whenever an erase suspend request is active (FCNFG[ERSSUSP]=1).

# FTFL memory map

| Absolute address (hex) | Register name                                       | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|------------------------|-----------------------------------------------------|--------------------|--------|-------------|------------------|
| FFFF_84E0              | Flash Option Register (FTFL_FOPT)                   |                    | R      | See section | 23.34.1/<br>494  |
| FFFF_84E1              | Flash Security Register (FTFL_FSEC)                 | 8                  | R      | See section | 23.34.2/<br>494  |
| FFFF_84E2              | Flash Configuration Register (FTFL_FCNFG)           | 8                  | R/W    | 00h         | 23.34.3/<br>496  |
| FFFF_84E3              | Flash Status Register (FTFL_FSTAT)                  | 8                  | R/W    | 00h         | 23.34.4/<br>497  |
| FFFF_84E4              | Flash Common Command Object Registers (FTFL_FCCOB0) | 8                  | R/W    | 00h         | 23.34.5/<br>499  |
| FFFF_84E5              | Flash Common Command Object Registers (FTFL_FCCOB1) | 8                  | R/W    | 00h         | 23.34.5/<br>499  |
| FFFF_84E6              | Flash Common Command Object Registers (FTFL_FCCOB2) | 8                  | R/W    | 00h         | 23.34.5/<br>499  |
| FFFF_84E7              | Flash Common Command Object Registers (FTFL_FCCOB3) |                    | R/W    | 00h         | 23.34.5/<br>499  |
| FFFF_84E8              | Flash Common Command Object Registers (FTFL_FCCOB4) |                    | R/W    | 00h         | 23.34.5/<br>499  |
| FFFF_84E9              | Flash Common Command Object Registers (FTFL_FCCOB5) |                    | R/W    | 00h         | 23.34.5/<br>499  |
| FFFF_84EA              | Flash Common Command Object Registers (FTFL_FCCOB6) |                    | R/W    | 00h         | 23.34.5/<br>499  |
| FFFF_84EB              | Flash Common Command Object Registers (FTFL_FCCOB7) |                    | R/W    | 00h         | 23.34.5/<br>499  |
| FFFF_84EC              | Flash Common Command Object Registers (FTFL_FCCOB8) | 8                  | R/W    | 00h         | 23.34.5/<br>499  |
| FFFF_84ED              | Flash Common Command Object Registers (FTFL_FCCOB9) | 8                  | R/W    | 00h         | 23.34.5/<br>499  |
| FFFF_84EE              | Flash Common Command Object Registers (FTFL_FCCOBA) | 8                  | R/W    | 00h         | 23.34.5/<br>499  |
| FFFF_84EF              | Flash Common Command Object Registers (FTFL_FCCOBB) |                    | R/W    | 00h         | 23.34.5/<br>499  |
| FFFF_84F0              | Program Flash Protection Registers (FTFL_FPROT0)    |                    | R/W    | See section | 23.34.6/<br>500  |
| FFFF_84F1              | Program Flash Protection Registers (FTFL_FPROT1)    |                    | R/W    | See section | 23.34.6/<br>500  |
| FFFF_84F2              | Program Flash Protection Registers (FTFL_FPROT2)    |                    | R/W    | See section | 23.34.6/<br>500  |
| FFFF_84F3              | Program Flash Protection Registers (FTFL_FPROT3)    | 8                  | R/W    | See section | 23.34.6/<br>500  |

Table continues on the next page...

#### **Memory Map and Registers**

### FTFL memory map (continued)

| Absolute<br>address<br>(hex) | Register name                                |  | Access | Reset value | Section/<br>page |
|------------------------------|----------------------------------------------|--|--------|-------------|------------------|
| FFFF_84F4                    | Data Flash Protection Register (FTFL_FDPROT) |  | R/W    | See section | 23.34.7/<br>502  |
| FFFF_84F5                    | EEPROM Protection Register (FTFL_FEPROT)     |  | R/W    | See section | 23.34.8/<br>503  |

# 23.34.1 Flash Option Register (FTFL\_FOPT)

The flash option register allows the MCU to customize its operations by examining the state of these read-only bits, which are loaded from NVM at reset. The function of the bits is defined in the device's Chip Configuration details.

All bits in the register are read-only.

During the reset sequence, the register is loaded from the flash nonvolatile option byte in the Flash Configuration Field located in program flash memory. The flash basis for the values is signified by X in the reset value.

Address: FTFL\_FOPT is FFFF\_84E0h base + 0h offset = FFFF\_84E0h



<sup>\*</sup> Notes:

### FTFL\_FOPT field descriptions

| Field      | Description                                                                                                                                                                |
|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–0<br>OPT | Nonvolatile Option  These bits are loaded from flash to this register at reset. Refer to the device's Chip Configuration details for the definition and use of these bits. |

# 23.34.2 Flash Security Register (FTFL\_FSEC)

This read-only register holds all bits associated with the security of the MCU and FTFL module.

<sup>•</sup> x = Undefined at reset.

During the reset sequence, the register is loaded with the contents of the flash security byte in the Flash Configuration Field located in program flash memory. The Flash basis for the values is signified by X in the reset value.

Address: FTFL\_FSEC is FFFF\_84E0h base + 1h offset = FFFF\_84E1h



<sup>\*</sup> Notes:

### FTFL\_FSEC field descriptions

| Field       | Description                                                                                                                                                                                                                                                                                                                  |  |  |  |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 7–6         | Backdoor Key Security Enable                                                                                                                                                                                                                                                                                                 |  |  |  |
| KEYEN       | These bits enable and disable backdoor key access to the FTFL module.                                                                                                                                                                                                                                                        |  |  |  |
|             | 00 Backdoor key access disabled                                                                                                                                                                                                                                                                                              |  |  |  |
|             | 01 Backdoor key access disabled (preferred KEYEN state to disable backdoor key access)                                                                                                                                                                                                                                       |  |  |  |
|             | 10 Backdoor key access enabled                                                                                                                                                                                                                                                                                               |  |  |  |
|             | 11 Backdoor key access disabled                                                                                                                                                                                                                                                                                              |  |  |  |
| 5–4<br>MEEN | Mass Erase Enable Bits                                                                                                                                                                                                                                                                                                       |  |  |  |
| WILLIA      | Enables and disables mass erase capability of the FTFL module. The state of the MEEN bits is only relevant when the SEC bits are set to secure outside of NVM Normal Mode. When the SEC field is set to unsecure, the MEEN setting does not matter.                                                                          |  |  |  |
|             | 00 Mass erase is enabled                                                                                                                                                                                                                                                                                                     |  |  |  |
|             | 01 Mass erase is enabled                                                                                                                                                                                                                                                                                                     |  |  |  |
|             | 10 Mass erase is disabled                                                                                                                                                                                                                                                                                                    |  |  |  |
|             | 11 Mass erase is enabled                                                                                                                                                                                                                                                                                                     |  |  |  |
| 3–2         | Freescale Failure Analysis Access Code                                                                                                                                                                                                                                                                                       |  |  |  |
| FSLACC      | These bits enable or disable access to the flash memory contents during returned part failure analysis at Freescale. When SEC is secure and FSLACC is denied, access to the program flash contents is denied and any failure analysis performed by Freescale factory test must begin with a full erase to unsecure the part. |  |  |  |
|             | When access is granted (SEC is unsecure, or SEC is secure and FSLACC is granted), Freescale factory testing has visibility of the current flash contents. The state of the FSLACC bits is only relevant when the SEC bits are set to secure. When the SEC field is set to unsecure, the FSLACC setting does not matter.      |  |  |  |
|             | 00 Freescale factory access granted                                                                                                                                                                                                                                                                                          |  |  |  |
|             | 01 Freescale factory access denied                                                                                                                                                                                                                                                                                           |  |  |  |
|             | 10 Freescale factory access denied                                                                                                                                                                                                                                                                                           |  |  |  |
|             | 11 Freescale factory access granted                                                                                                                                                                                                                                                                                          |  |  |  |
| 1–0<br>SEC  | Flash Security                                                                                                                                                                                                                                                                                                               |  |  |  |

Table continues on the next page...

<sup>•</sup> x = Undefined at reset.

#### **Memory Map and Registers**

### FTFL\_FSEC field descriptions (continued)

| Field | Description                                                                                                                                                                                                                                                                                                 |  |  |  |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
|       | These bits define the security state of the MCU. In the secure state, the MCU limits access to FTFL module resources. The limitations are defined per device and are detailed in the Chip Configuration details. If the FTFL module is unsecured using backdoor key access, the SEC bits are forced to 10b. |  |  |  |
|       | 00 MCU security status is secure                                                                                                                                                                                                                                                                            |  |  |  |
|       | 01 MCU security status is secure                                                                                                                                                                                                                                                                            |  |  |  |
|       | <ul> <li>MCU security status is unsecure (The standard shipping condition of the FTFL is unsecure.)</li> <li>MCU security status is secure</li> </ul>                                                                                                                                                       |  |  |  |

# 23.34.3 Flash Configuration Register (FTFL\_FCNFG)

This register provides information on the current functional state of the FTFL module.

The erase control bits (ERSAREQ and ERSSUSP) have write restrictions. RAMRDY, and EEERDY are read-only status bits. The unassigned bits read as noted and are not writable. The reset values for the RAMRDY, and EEERDY bits are determined during the reset sequence.

Address: FTFL\_FCNFG is FFFF\_84E0h base + 2h offset = FFFF\_84E2h



### FTFL\_FCNFG field descriptions

| Field        | Description                                                                                                                                                             |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7            | Command Complete Interrupt Enable                                                                                                                                       |
| CCIE         | The CCIE bit controls interrupt generation when an FTFL command completes.                                                                                              |
|              | 0 Command complete interrupt disabled                                                                                                                                   |
|              | Command complete interrupt enabled. An interrupt request is generated whenever the FSTAT[CCIF] flag is set.                                                             |
| 6            | Read Collision Error Interrupt Enable                                                                                                                                   |
| RDCOLLIE     | The RDCOLLIE bit controls interrupt generation when an FTFL read collision error occurs.                                                                                |
|              | 0 Read collision error interrupt disabled                                                                                                                               |
|              | 1 Read collision error interrupt enabled. An interrupt request is generated whenever an FTFL read collision error is detected (see the description of FSTAT[RDCOLERR]). |
| 5<br>ERSAREQ | Erase All Request                                                                                                                                                       |

Table continues on the next page...

### FTFL\_FCNFG field descriptions (continued)

| Field         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
|               | This bit issues a request to the memory controller to execute the Erase All Blocks command and release security. ERSAREQ is not directly writable but is under indirect user control. Refer to the device's Chip Configuration details on how to request this command.                                                                                                                                                                                                                                                   |  |  |  |
|               | The ERSAREQ bit sets when an erase all request is triggered external to the FTFL and CCIF is set (no command is currently being executed). ERSAREQ is cleared by the FTFL when the operation completes.                                                                                                                                                                                                                                                                                                                  |  |  |  |
|               | <ul> <li>No request or request complete</li> <li>Request to: 1.run the Erase All Blocks command,2.verify the erased state,3.program the security byte in the Flash Configuration Field to the unsecure state, and4.release MCU security by setting the FSEC[SEC] field to the unsecure state.</li> </ul>                                                                                                                                                                                                                 |  |  |  |
| 4             | Erase Suspend                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |
| ERSSUSP       | The ERSSUSP bit allows the user to suspend (interrupt) the Erase Flash Sector command while it is executing.                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |
|               | 0 No suspend requested                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |
|               | Suspend the current Erase Flash Sector command execution.                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |
| 3<br>Reserved | This read-only bit is reserved and always has the value zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |
| 2<br>PFLSH    | FTFL configuration                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |
| 112311        | FTFL configured for FlexMemory that supports data flash and/or EEPROM     Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |
| 1<br>RAMRDY   | RAM Ready                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |
| naivinu i     | This flag indicates the current status of the FlexRAM.                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |
|               | The state of the RAMRDY flag is normally controlled by the Set FlexRAM Function command. During the reset sequence, the RAMRDY flag is cleared if the FlexNVM block is partitioned for EEPROM and is set if the FlexNVM block is not partitioned for EEPROM. The RAMRDY flag is cleared if the Program Partition command is run to partition the FlexNVM block for EEPROM. The RAMRDY flag sets after completion of the Erase All Blocks command or execution of the erase-all operation triggered external to the FTFL. |  |  |  |
|               | 0 FlexRAM is not available for traditional RAM access.                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |
|               | FlexRAM is available as traditional RAM only; writes to the FlexRAM do not trigger EEPROM operations.                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |
| 0<br>EEERDY   | This flag indicates if the EEPROM backup data has been copied to the FlexRAM and is therefore available for read access.                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |
|               | 0 FlexRAM is not available for EEPROM operation.                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |
|               | 1 FlexRAM is available for EEPROM operations where: •reads from the FlexRAM return data previously written to the FlexRAM in EEPROM mode and•writes launch an EEPROM operation to store the written data in the FlexRAM and EEPROM backup.                                                                                                                                                                                                                                                                               |  |  |  |

# 23.34.4 Flash Status Register (FTFL\_FSTAT)

The FSTAT register reports the operational status of the FTFL module.

#### **Memory Map and Registers**

The CCIF, RDCOLERR, ACCERR, and FPVIOL bits are readable and writable. The MGSTAT0 bit is read only. The unassigned bits read 0 and are not writable.

### **NOTE**

When set, the Access Error (ACCERR) and Flash Protection Violation (FPVIOL) bits in this register prevent the launch of any more commands until the flag is cleared (by writing a one to it).

Address: FTFL\_FSTAT is FFFF\_84E0h base + 3h offset = FFFF\_84E3h

| Bit   | 7    | 6        | 5      | 4      | 3 | 2 | 1 | 0       |
|-------|------|----------|--------|--------|---|---|---|---------|
| Read  | CCIF | RDCOLERR | ACCERR | FPVIOL |   | 0 |   | MGSTAT0 |
| Write | w1c  | w1c      | w1c    | w1c    |   |   |   |         |
| Reset | 0    | 0        | 0      | 0      | 0 | 0 | 0 | 0       |

### FTFL\_FSTAT field descriptions

| Field       | Description                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 7           | Command Complete Interrupt Flag                                                                                                                                                                                                                                                                                                                                                 |  |  |  |
| CCIF        | The CCIF flag indicates that a FTFL command has completed. The CCIF flag is cleared by writing a 1 to CCIF to launch a command, and CCIF stays low until command completion or command violation.                                                                                                                                                                               |  |  |  |
|             | The CCIF bit is reset to 0 but is set to 1 by the memory controller at the end of the reset initialization sequence. Depending on how quickly the read occurs after reset release, the user may or may not see the 0 hardware reset value.                                                                                                                                      |  |  |  |
|             | 0 FTFL command in progress                                                                                                                                                                                                                                                                                                                                                      |  |  |  |
|             | 1 FTFL command has completed                                                                                                                                                                                                                                                                                                                                                    |  |  |  |
| 6           | FTFL Read Collision Error Flag                                                                                                                                                                                                                                                                                                                                                  |  |  |  |
| RDCOLERR    | The RDCOLERR error bit indicates that the MCU attempted a read from an FTFL resource that was being manipulated by an FTFL command (CCIF=0). Any simultaneous access is detected as a collision error by the block arbitration logic. The read data in this case cannot be guaranteed. The RDCOLERR bit is cleared by writing a 1 to it. Writing a 0 to RDCOLERR has no effect. |  |  |  |
|             | 0 No collision error detected                                                                                                                                                                                                                                                                                                                                                   |  |  |  |
|             | 1 Collision error detected                                                                                                                                                                                                                                                                                                                                                      |  |  |  |
| 5           | Flash Access Error Flag                                                                                                                                                                                                                                                                                                                                                         |  |  |  |
| ACCERR      | The ACCERR error bit indicates an illegal access has occurred to an FTFL resource caused by a violation of the command write sequence or issuing an illegal FTFL command. While ACCERR is set, the CCIF flag cannot be cleared to launch a command. The ACCERR bit is cleared by writing a 1 to it. Writing a 0 to the ACCERR bit has no effect.                                |  |  |  |
|             | 0 No access error detected                                                                                                                                                                                                                                                                                                                                                      |  |  |  |
|             | 1 Access error detected                                                                                                                                                                                                                                                                                                                                                         |  |  |  |
| 4<br>FPVIOL | Flash Protection Violation Flag                                                                                                                                                                                                                                                                                                                                                 |  |  |  |

Table continues on the next page...

### FTFL\_FSTAT field descriptions (continued)

| Field           | Description                                                                                                                                                                                                                                                                            |  |  |  |  |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
|                 | The FPVIOL error bit indicates an attempt was made to program or erase an address in a protected area of program flash or data flash memory during a command write sequence or a write was attempted to a protected area of the FlexRAM while enabled for EEPROM.                      |  |  |  |  |
|                 | The FPVIOL bit is cleared by writing a 1 to it. Writing a 0 to the FPVIOL bit has no effect. While FPVIOL is set, the CCIF flag cannot be cleared to launch a command.                                                                                                                 |  |  |  |  |
|                 | 0 No protection violation detected                                                                                                                                                                                                                                                     |  |  |  |  |
|                 | 1 Protection violation detected                                                                                                                                                                                                                                                        |  |  |  |  |
| 3–1<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                                     |  |  |  |  |
| 0               | Memory Controller Command Completion Status Flag                                                                                                                                                                                                                                       |  |  |  |  |
| MGSTAT0         | The MGSTAT0 status flag is set if an error is detected during execution of an FTFL command or during the flash reset sequence. As a status flag, this bit cannot (and need not) be cleared by the user like the other error flags in this register.                                    |  |  |  |  |
|                 | The value of the MGSTAT0 bit for "command-N" is valid only at the end of the "command-N" execution when CCIF=1 and before the next command has been launched. At some point during the execution of "command-N+1," the previous result is discarded and any previous error is cleared. |  |  |  |  |

# 23.34.5 Flash Common Command Object Registers (FTFL\_FCCOBn)

The FCCOB register group provides 12 bytes for command codes and parameters. The individual bytes within the set append a 0-B hex identifier to the FCCOB register name: FCCOB0, FCCOB1, ..., FCCOBB.

Addresses: FFFF\_84E0h base + 4h offset +  $(1d \times n)$ , where n = 0d to 11d



### FTFL\_FCCOBn field descriptions

| Field        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–0<br>CCOBn | The FCCOB register provides a command code and relevant parameters to the memory controller. The individual registers that compose the FCCOB data set can be written in any order, but you must provide all needed values, which vary from command to command. First, set up all required FCCOB fields and then initiate the command's execution by writing a 1 to the FSTAT[CCIF] bit. This clears the CCIF bit, which locks all FCCOB parameter fields and they cannot be changed by the user until the command completes (CCIF returns to 1). No command buffering or queueing is provided; the next command can be loaded only after the current command completes. |
|              | Some commands return information to the FCCOB registers. Any values returned to FCCOB are available for reading after the FSTAT[CCIF] flag returns to 1 by the memory controller.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

#### **Memory Map and Registers**

### FTFL\_FCCOBn field descriptions (continued)

| Field | Description                                                                                                                                                                                                                                                                                                        |                                                                                                                                                 |  |  |  |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
|       | The following table shows a generic FTFL command format. The first FCCOB register, FCCOB0, always contains the command code. This 8-bit value defines the command to be executed. The command code is followed by the parameters required for this specific FTFL command, typically an address and/or data values. |                                                                                                                                                 |  |  |  |
|       | The command parameter table is written in terms of FCCOB Number (which is equivalent to the byte number). This number is a reference to the FCCOB register name and is not the register address.                                                                                                                   |                                                                                                                                                 |  |  |  |
|       | FCCOB Number <sup>1</sup>                                                                                                                                                                                                                                                                                          | Typical Command Parameter Contents [7:0]                                                                                                        |  |  |  |
|       | 0                                                                                                                                                                                                                                                                                                                  | FCMD (a code that defines the FTFL command)                                                                                                     |  |  |  |
|       | 1                                                                                                                                                                                                                                                                                                                  | Flash address [23:16]                                                                                                                           |  |  |  |
|       | 2                                                                                                                                                                                                                                                                                                                  | Flash address [15:8]                                                                                                                            |  |  |  |
|       | 3 Flash address [7:0]                                                                                                                                                                                                                                                                                              |                                                                                                                                                 |  |  |  |
|       | 4                                                                                                                                                                                                                                                                                                                  | Data Byte 0                                                                                                                                     |  |  |  |
|       | 5                                                                                                                                                                                                                                                                                                                  | Data Byte 1                                                                                                                                     |  |  |  |
|       | 6                                                                                                                                                                                                                                                                                                                  | Data Byte 2                                                                                                                                     |  |  |  |
|       | 7                                                                                                                                                                                                                                                                                                                  | Data Byte 3                                                                                                                                     |  |  |  |
|       | 8                                                                                                                                                                                                                                                                                                                  | Data Byte 4                                                                                                                                     |  |  |  |
|       | 9                                                                                                                                                                                                                                                                                                                  | Data Byte 5                                                                                                                                     |  |  |  |
|       | Α                                                                                                                                                                                                                                                                                                                  | Data Byte 6                                                                                                                                     |  |  |  |
|       | B Data Byte 7                                                                                                                                                                                                                                                                                                      |                                                                                                                                                 |  |  |  |
|       | Refers to FCCOB register name, not register address                                                                                                                                                                                                                                                                |                                                                                                                                                 |  |  |  |
|       | FCCOB Endianness:                                                                                                                                                                                                                                                                                                  |                                                                                                                                                 |  |  |  |
|       |                                                                                                                                                                                                                                                                                                                    | up uses a big endian addressing convention. For all command parameter fields most significant data resides in the lowest FCCOB register number. |  |  |  |

<sup>1.</sup> Refers to FCCOB register name, not register address

# 23.34.6 Program Flash Protection Registers (FTFL\_FPROT*n*)

The FPROT registers define which logical program flash regions are protected from program and erase operations. Protected flash regions cannot have their content changed; that is, these regions cannot be programmed and cannot be erased by any FTFL command. Unprotected regions can be changed by program and erase operations.

The four FPROT registers allow 32 protectable regions. Each bit protects a 1/32 region of the program flash memory.

During the reset sequence, the FPROT registers are loaded with the contents of the program flash protection bytes in the Flash Configuration Field as indicated in the following table.

| Program flash protection register | Flash Configuration Field offset address |
|-----------------------------------|------------------------------------------|
| FPROT0                            | 0x0008                                   |
| FPROT1                            | 0x0009                                   |
| FPROT2                            | 0x000A                                   |
| FPROT3                            | 0x000B                                   |

To change the program flash protection that is loaded during the reset sequence, unprotect the sector of program flash memory that contains the Flash Configuration Field. Then, reprogram the program flash protection byte.



<sup>\*</sup> Notes:

### FTFL\_FPROTn field descriptions

| Field       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–0<br>PROT | Program Flash Region Protect                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|             | Each program flash region can be protected from program and erase operations by setting the associated PROT bit.                                                                                                                                                                                                                                                                                                                                                                |
|             | In NVM Normal mode: The protection can only be increased, meaning that currently unprotected memory can be protected, but currently protected memory cannot be unprotected. Since unprotected regions are marked with a 1 and protected regions use a 0, only writes changing 1s to 0s are accepted. This 1-to-0 transition check is performed on a bit-by-bit basis. Those FPROT bits with 1-to-0 transitions are accepted while all bits with 0-to-1 transitions are ignored. |
|             | In NVM Special mode All bits of FPROT are writable without restriction. Unprotected areas can be protected and protected areas can be unprotected.                                                                                                                                                                                                                                                                                                                              |
|             | <b>Restriction:</b> The user must never write to any FPROT register while a command is running (CCIF=0).                                                                                                                                                                                                                                                                                                                                                                        |
|             | Trying to alter data in any protected area in the program flash memory results in a protection violation error and sets the FSTAT[FPVIOL] bit. A full block erase of a program flash block is not possible if it contains any protected region.                                                                                                                                                                                                                                 |
|             | Each bit in the 32-bit protection register represents 1/32 of the total program flash.                                                                                                                                                                                                                                                                                                                                                                                          |
|             | <ul><li>0 Program flash region is protected.</li><li>1 Program flash region is not protected</li></ul>                                                                                                                                                                                                                                                                                                                                                                          |

<sup>•</sup> x = Undefined at reset.

# 23.34.7 Data Flash Protection Register (FTFL\_FDPROT)

The FDPROT register defines which data flash regions are protected against program and erase operations. Protected Flash regions cannot have their content changed; that is, these regions cannot be programmed and cannot be erased by any FTFL command. Unprotected regions can be changed by both program and erase operations.

Address: FTFL\_FDPROT is FFFF\_84E0h base + 14h offset = FFFF\_84F4h



- \* Notes:
- x = Undefined at reset.

### FTFL\_FDPROT field descriptions

| Field        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–0<br>DPROT | Data Flash Region Protect                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Di ilio      | Individual data flash regions can be protected from program and erase operations by setting the associated DPROT bit. Each DPROT bit protects one-eighth of the partitioned data flash memory space. The granularity of data flash protection cannot be less than the data flash sector size. If an unused DPROT bit is set, the Erase all Blocks command does not execute and the FSTAT[FPVIOL] flag is set.                                                                                                |
|              | In NVM Normal mode: The protection can only be increased, meaning that currently unprotected memory can be protected but currently protected memory cannot be unprotected. Since unprotected regions are marked with a 1 and protected regions use a 0, only writes changing 1s to 0s are accepted. This 1-to-0 transition check is performed on a bit-by-bit basis. Those FDPROT bits with 1-to-0 transitions are accepted while all bits with 0-to-1 transitions are ignored.                              |
|              | <b>In NVM Special mode:</b> All bits of the FDPROT register are writable without restriction. Unprotected areas can be protected and protected areas can be unprotected.                                                                                                                                                                                                                                                                                                                                     |
|              | Restriction: The user must never write to the FDPROT register while a command is running (CCIF=0).                                                                                                                                                                                                                                                                                                                                                                                                           |
|              | <b>Reset:</b> During the reset sequence, the FDPROT register is loaded with the contents of the data flash protection byte in the Flash Configuration Field located in program flash memory. The flash basis for the reset values is signified by X in the register diagram. To change the data flash protection that will be loaded during the reset sequence, unprotect the sector of program flash that contains the Flash Configuration Field. Then, erase and reprogram the data flash protection byte. |
|              | Trying to alter data with the program and erase commands in any protected area in the data flash memory results in a protection violation error and sets the FSTAT[FPVIOL] bit. A full block erase of the data flash memory (see the Erase Flash Block command description) is not possible if the data flash memory contains any protected region or if the FlexNVM block has been partitioned for EEPROM.                                                                                                  |
|              | 0 Data Flash region is protected                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|              | 1 Data Flash region is not protected                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

# 23.34.8 EEPROM Protection Register (FTFL\_FEPROT)

The FEPROT register defines which EEPROM regions of the FlexRAM are protected against program and erase operations. Protected EEPROM regions cannot have their content changed by writing to it. Unprotected regions can be changed by writing to the FlexRAM.

Address: FTFL\_FEPROT is FFFF\_84E0h base + 15h offset = FFFF\_84F5h



- \* Notes:
- x = Undefined at reset.

### FTFL\_FEPROT field descriptions

| Field        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–0<br>EPROT | EEPROM Region Protect                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|              | Individual EEPROM regions can be protected from alteration by setting the associated EPROT bit. The EPROT bits are not used when the FlexNVM Partition Code is set to data flash only. When the FlexNVM Partition Code is set to data flash and EEPROM or EEPROM only, each EPROT bit covers one-eighth of the configured EEPROM data (see the EEPROM Data Set Size parameter description).                                                                                                                     |
|              | In NVM Normal mode: The protection can only be increased. This means that currently-unprotected memory can be protected, but currently-protected memory cannot be unprotected. Since unprotected regions are marked with a 1 and protected regions use a 0, only writes changing 1s to 0s are accepted. This 1-to-0 transition check is performed on a bit-by-bit basis. Those FEPROT bits with 1-to-0 transitions are accepted while all bits with 0-to-1 transitions are ignored.                             |
|              | In NVM Special mode: All bits of the FEPROT register are writable without restriction. Unprotected areas can be protected and protected areas can be unprotected.                                                                                                                                                                                                                                                                                                                                               |
|              | Restriction: Never write to the FEPROT register while a command is running (CCIF=0).                                                                                                                                                                                                                                                                                                                                                                                                                            |
|              | <b>Reset:</b> During the reset sequence, the FEPROT register is loaded with the contents of the FlexRAM protection byte in the Flash Configuration Field located in program flash. The flash basis for the reset values is signified by X in the register diagram. To change the EEPROM protection that will be loaded during the reset sequence, the sector of program flash that contains the Flash Configuration Field must be unprotected; then the EEPROM protection byte must be erased and reprogrammed. |
|              | Trying to alter data by writing to any protected area in the EEPROM results in a protection violation error and sets the FPVIOL bit in the FSTAT register.                                                                                                                                                                                                                                                                                                                                                      |
|              | 0 EEPROM region is protected 1 EEPROM region is not protected                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

# 23.4 Functional Description

The following sections describe functional details of the FTFL module.

### 23.4.1 Flash Protection

Individual regions within the flash memory can be protected from program and erase operations. Protection is controlled by the following registers:

• FPROT*n* — Four registers that protect 32 regions of the program flash memory as shown in the following figure



Figure 23-26. Program flash protection

• FDPROT —

Downloaded from **Elcodis.com** electronic components distributor

• protects eight regions of the data flash memory as shown in the following figure



Figure 23-27. Data flash protection

• FEPROT — Protects eight regions of the EEPROM memory as shown in the following figure

#### **Functional Description**



Figure 23-28. EEPROM protection

# 23.4.2 FlexNVM Description

This section describes the FlexNVM memory.

# 23.4.2.1 FlexNVM Block Partitioning for FlexRAM

The user can configure the FlexNVM block as either:

- Basic data flash,
- EEPROM flash records to support the built-in EEPROM feature, or
- A combination of both.

The user's FlexNVM configuration choice is specified using the Program Partition command described in Program Partition Command.

### **CAUTION**

While different partitions of the FlexNVM block are available, the intention is that a single partition choice is used throughout the entire lifetime of a given application. The FlexNVM partition code choices affect the endurance and data retention characteristics of the device.

## 23.4.2.2 EEPROM User Perspective

The EEPROM system is shown in the following figure.



Figure 23-29. Top Level EEPROM Architecture

To handle varying customer requirements, the FlexRAM and FlexNVM blocks can be split into partitions as shown in the figure below.

- 1. **EEPROM partition** (EEESIZE) The amount of FlexRAM used for EEPROM can be set from 0 Bytes (no EEPROM) to the maximum FlexRAM size (see Table 23-2). The remainder of the FlexRAM is not accessible while the FlexRAM is configured for EEPROM (see Set FlexRAM Function Command). The EEPROM partition grows upward from the bottom of the FlexRAM address space.
- 2. **Data flash partition** (DEPART) The amount of FlexNVM memory used for data flash can be programmed from 0 bytes (all of the FlexNVM block is available for EEPROM backup) to the maximum size of the FlexNVM block (see Table 23-4).
- 3. **FlexNVM EEPROM partition** The amount of FlexNVM memory used for EEPROM backup, which is equal to the FlexNVM block size minus the data flash memory partition size. The EEPROM backup size must be at least 16 times the EEPROM partition size in FlexRAM.

The partition information (EEESIZE, DEPART) is stored in the data flash IFR and is programmed using the Program Partition command (see Program Partition Command). Typically, the Program Partition command is executed only once in the lifetime of the device.

#### **Functional Description**

Data flash memory is useful for applications that need to quickly store large amounts of data or store data that is static. The EEPROM partition in FlexRAM is useful for storing smaller amounts of data that will be changed often.



Figure 23-30. FlexRAM to FlexNVM Memory Mapping

# 23.4.2.3 **EEPROM Implementation Overview**

Out of reset, the partition settings (EEESIZE, DEPART) are read from the data flash IFR and the EEPROM file system is initialized accordingly. The EEPROM file system locates all valid EEPROM data records in EEPROM backup and copies the newest data to FlexRAM. The FCNFG[EEERDY] bit is set after data from all valid EEPROM data records is copied to the FlexRAM. After the EEERDY bit is set, the FlexRAM is available for read or write access.

When configured for EEPROM use, writes to an unprotected location in FlexRAM invokes the EEPROM file system to program a new EEPROM data record in the EEPROM backup memory in a round-robin fashion. As needed, the EEPROM file system identifies the EEPROM backup sector that is being erased for future use and partially erases that EEPROM backup sector. After a write to the FlexRAM, the FlexRAM is not accessible until the FCNFG[EEERDY] bit is set.

After a sector in EEPROM backup is full of EEPROM data records, EEPROM data records from the sector holding the oldest data are gradually copied over to a previously-erased EEPROM backup sector. When the sector copy completes, the EEPROM backup sector holding the oldest data is tagged for erase.

## 23.4.2.4 Write endurance to FlexRAM for EEPROM

When the FlexNVM partition code is not set to full data flash, the EEPROM data set size can be set to any of several non-zero values.

The bytes not assigned to data flash via the FlexNVM partition code are used by the FTFL to obtain an effective endurance increase for the EEPROM data. The built-in EEPROM record management system raises the number of program/erase cycles that can be attained prior to device wear-out by cycling the EEPROM data through a larger EEPROM NVM storage space.

While different partitions of the FlexNVM are available, the intention is that a single choice for the FlexNVM partition code and EEPROM data set size is used throughout the entire lifetime of a given application. The EEPROM endurance equation and graph shown below assume that only one configuration is ever used.

Writes\_FlexRAM = 
$$\frac{\text{EEPROM} - 2 \times \text{EEESIZE}}{\text{EEESIZE}} \times \text{Write\_efficiency} \times n_{\text{nvmcycd}}$$

#### where

- Writes\_FlexRAM minimum number of writes to each FlexRAM location
- EEPROM allocated FlexNVM based on DEPART; entered with Program Partition command
- EEESIZE allocated FlexRAM based on DEPART; entered with Program Partition command
- Write\_efficiency
  - 0.25 for 8-bit writes to FlexRAM
  - 0.50 for 16-bit or 32-bit writes to FlexRAM
- n<sub>nvmcycd</sub> data flash cycling endurance



Figure 23-31. EEPROM backup writes to FlexRAM

# 23.4.3 Interrupts

The FTFL module can generate interrupt requests to the MCU upon the occurrence of various FTFL events. These interrupt events and their associated status and control bits are shown in the following table.

 FTFL Event
 Readable
 Interrupt

 Status Bit
 Enable Bit

 FTFL Command Complete
 FSTAT[CCIF]
 FCNFG[CCIE]

 FTFL Read Collision Error
 FSTAT[RDCOLERR]
 FCNFG[RDCOLLIE]

Table 23-30. FTFL Interrupt Sources

### **Note**

Vector addresses and their relative interrupt priority are determined at the MCU level.

## 23.4.4.1 Wait Mode

When the MCU enters wait mode, the FTFL module is not affected. The FTFL module can recover the MCU from wait via the command complete interrupt (see Interrupts).

## 23.4.4.2 Stop Mode

When the MCU requests stop mode, if an FTFL command is active (CCIF = 0) the command execution completes before the MCU is allowed to enter stop mode.

#### **CAUTION**

The MCU should never enter stop mode while any FTFL command is running (CCIF = 0).

#### NOTE

While the MCU is in very-low-power modes (VLPR, VLPW, VLPS), the FTFL module does not accept flash commands.

# 23.4.5 Functional Modes of Operation

The FTFL module has two operating modes: NVM Normal and NVM Special. The operating mode affects the command set availability (see Table 23-31). Refer to the Chip Configuration details of this device for how to activate each mode.

## 23.4.6 Flash Reads and Ignored Writes

The FTFL module requires only the flash address to execute a flash memory read. MCU read access is available to all flash blocks.

The MCU must not read from the flash memory while commands are running (as evidenced by CCIF=0) on that block. Read data cannot be guaranteed from a flash block while any command is processing within that block. The block arbitration logic detects any simultaneous access and reports this as a read collision error (see the FSTAT[RDCOLERR] bit).

# 23.4.7 Read While Write (RWW)

The following simultaneous accesses are allowed:

- The user may read from the program flash memory while commands (typically program and erase operations) are active in the data flash and FlexRAM memory space.
- The MCU can fetch instructions from program flash during both data flash program and erase operations and while EEPROM backup data is maintained by the EEPROM commands.
- Conversely, the user may read from data flash and FlexRAM while program and erase commands are executing on the program flash.
- When configured as traditional RAM, writes to the FlexRAM are allowed during program and data flash operations.

Simultaneous data flash operations and FlexRAM writes, when FlexRAM is used for EEPROM, are not possible.

Simultaneous operations are further discussed in Allowed Simultaneous Flash Operations.

# 23.4.8 Flash Program and Erase

All flash functions except read require the user to setup and launch an FTFL command through a series of peripheral bus writes. The user cannot initiate any further FTFL commands until notified that the current command has completed. The FTFL command structure and operation are detailed in FTFL Command Operations.

# 23.4.9 FTFL Command Operations

FTFL command operations are typically used to modify flash memory contents. The next sections describe:

- The command write sequence used to set FTFL command parameters and launch execution
- A description of all FTFL commands available

## 23.4.9.1 Command Write Sequence

FTFL commands are specified using a command write sequence illustrated in Figure 23-32. The FTFL module performs various checks on the command (FCCOB) content and continues with command execution if all requirements are fulfilled.

Before launching a command, the ACCERR and FPVIOL bits in the FSTAT register must be zero and the CCIF flag must read 1 to verify that any previous command has completed. If CCIF is zero, the previous command execution is still active, a new command write sequence cannot be started, and all writes to the FCCOB registers are ignored.

## 23.4.9.1.1 Load the FCCOB Registers

The user must load the FCCOB registers with all parameters required by the desired FTFL command. The individual registers that make up the FCCOB data set can be written in any order.

## 23.4.9.1.2 Launch the Command by Clearing CCIF

Once all relevant command parameters have been loaded, the user launches the command by clearing the FSTAT[CCIF] bit by writing a '1' to it. The CCIF flag remains zero until the FTFL command completes.

The FSTAT register contains a blocking mechanism, which prevents a new command from launching (can't clear CCIF) if the previous command resulted in an access error (FSTAT[ACCERR]=1) or a protection violation (FSTAT[FPVIOL]=1). In error scenarios, two writes to FSTAT are required to initiate the next command: the first write clears the error flags, the second write clears CCIF.

# 23.4.9.1.3 Command Execution and Error Reporting

The command processing has several steps:

1. In the first step, the FTFL reads the command code and performs a series of parameter checks which are unique to each command.

If the initial parameter check fails, the FSTAT[ACCERR] (access error) bit is set. ACCERR reports invalid instruction codes and out-of bounds addresses. Usually, access errors suggest that the command was not set-up with valid parameters in the FCCOB register group. Command processing never proceeds to execution when the parameter checking step fails. Instead, the FSTAT[ACCERR] flag is set and the command processing is terminated after setting CCIF.

- 2. If the initial parameter checking passes, the command proceeds to execution. Runtime errors, such as failure to erase verify, may occur during the execution phase. Run-time errors are reported in the FSTAT[MGSTAT0] bit. A command may have access and run-time errors, but the run-time errors are not seen until all access errors have been corrected.
- 3. In the next step, results, if any, are reported back to the user via the FCCOB and FSTAT registers.
- 4. In the final step, the FTFL sets the FSTAT[CCIF] bit signifying that the command has completed.

The flow for a generic command write sequence is illustrated in the following figure.



Figure 23-32. Generic FTFL Command Write Sequence Flowchart

## 23.4.9.2 FTFL Commands

The following table summarizes the function of all FTFL commands. If the program flash, data flash, or FlexRAM column is marked with an 'X', the FTFL command is relevant to that particular memory resource.

| FCMD | Command            | Program flash | Data flash | FlexRAM | Function                                                                                                                                                          |
|------|--------------------|---------------|------------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x00 | Read 1s Block      | ×             | ×          |         | Verify that a program flash or data flash block is erased. FlexNVM block must not be partitioned for EEPROM.                                                      |
| 0x01 | Read 1s Section    | ×             | ×          |         | Verify that a given<br>number of program<br>flash or data flash<br>phrases from a<br>starting address<br>are erased.                                              |
| 0x02 | Program Check      | ×             | ×          |         | Tests previously-<br>programmed<br>phrases at margin<br>read levels.                                                                                              |
| 0x03 | Read Resource      | IFR           | IFR        |         | Read 4 bytes from<br>program flash IFR,<br>data flash IFR, or<br>version ID.                                                                                      |
| 0x06 | Program Longword   | ×             | ×          |         | Program 4 bytes in<br>a program flash<br>block or a data<br>flash block.                                                                                          |
| 0x08 | Erase Flash Block  | ×             | ×          |         | Erase a program flash block or data flash block. An erase of any flash block is only possible when unprotected. FlexNVM block must not be partitioned for EEPROM. |
| 0x09 | Erase Flash Sector | ×             | ×          |         | Erase all bytes in a program flash or data flash sector.                                                                                                          |
| 0x0B | Program Section    | ×             | ×          | ×       | Program data from<br>the Section<br>Program Buffer to<br>a program flash or<br>data flash block.                                                                  |

Table continues on the next page...

| FCMD | Command                       | Program flash | Data flash | FlexRAM | Function                                                                                                                                                                                                                    |
|------|-------------------------------|---------------|------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x40 | Read 1s All Blocks            | ×             | ×          | X       | Verify that all program flash, data flash blocks, FlexRAM, EEPROM backup data records, and data flash IFR are erased then release MCU security.                                                                             |
| 0x41 | Read Once                     | IFR           |            |         | Read 4 bytes of a dedicated 64 byte field in the program flash IFR.                                                                                                                                                         |
| 0x43 | Program Once                  | IFR           |            |         | One-time program<br>of 4 bytes of a<br>dedicated 64-byte<br>field in the program<br>flash IFR.                                                                                                                              |
| 0x44 | Erase All Blocks              | ×             | ×          | ×       | Erase all program flash, data flash blocks, FlexRAM, EEPROM backup data records, and data flash IFR. Then, verify-erase and release MCU security.  NOTE: An erase is only possible when all memory locations are unprotecte |
| 0x45 | Verify Backdoor<br>Access Key | ×             |            |         | Release MCU security after comparing a set of user-supplied security keys to those stored in the program flash.                                                                                                             |
| 0x80 | Program Partition             |               | IFR        | ×       | Program the FlexNVM Partition Code and EEPROM Data Set Size into the data flash IFR. Format all EEPROM backup data sectors allocated for EEPROM. Initialize the FlexRAM.                                                    |

Table continues on the next page...

| FCMD | Command                 | Program flash | Data flash | FlexRAM | Function                                                                                                                                                                      |
|------|-------------------------|---------------|------------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x81 | Set FlexRAM<br>Function |               | x          | ×       | Switches FlexRAM function between RAM and EEPROM. When switching to EEPROM, FlexNVM is not available while valid data records are being copied from EEPROM backup to FlexRAM. |

# 23.4.9.3 FTFL Commands by Mode

The following table shows the FTFL commands that can be executed in each flash operating mode.

Table 23-31. FTFL Commands by Mode

| FOMD | Commond               |          | NVM Normal |         | NVM Special |        |         |  |
|------|-----------------------|----------|------------|---------|-------------|--------|---------|--|
| FCMD | Command               | Unsecure | Secure     | MEEN=10 | Unsecure    | Secure | MEEN=10 |  |
| 0x00 | Read 1s<br>Block      | ×        | ×          | ×       | ×           | _      | _       |  |
| 0x01 | Read 1s<br>Section    | ×        | ×          | ×       | ×           | _      | _       |  |
| 0x02 | Program<br>Check      | ×        | ×          | ×       | ×           | _      | _       |  |
| 0x03 | Read<br>Resource      | ×        | ×          | ×       | ×           | _      | _       |  |
| 0x06 | Program<br>Longword   | ×        | ×          | ×       | ×           | _      | _       |  |
| 0x08 | Erase Flash<br>Block  | ×        | ×          | ×       | ×           | _      | _       |  |
| 0x09 | Erase Flash<br>Sector | ×        | ×          | ×       | ×           | _      | _       |  |
| 0x0B | Program<br>Section    | ×        | ×          | ×       | ×           | _      | _       |  |
| 0x40 | Read 1s All<br>Blocks | ×        | ×          | ×       | ×           | ×      | _       |  |
| 0x41 | Read Once             | ×        | ×          | ×       | ×           | _      | _       |  |
| 0x43 | Program<br>Once       | ×        | ×          | ×       | ×           | _      | _       |  |
| 0x44 | Erase All<br>Blocks   | ×        | ×          | ×       | ×           | ×      | _       |  |

Table continues on the next page...

Table 23-31. FTFL Commands by Mode (continued)

| ECMD   | FCMD Command                     |   | NVM Normal |         | NVM Special |        |         |  |
|--------|----------------------------------|---|------------|---------|-------------|--------|---------|--|
| PCIVID |                                  |   | Secure     | MEEN=10 | Unsecure    | Secure | MEEN=10 |  |
| 0x45   | Verify<br>Backdoor<br>Access Key | × | ×          | ×       | ×           | _      | _       |  |
| 0x80   | Program<br>Partition             | × | ×          | ×       | ×           | _      | _       |  |
| 0x81   | Set FlexRAM<br>Function          | × | ×          | ×       | ×           | _      | _       |  |

## 23.4.9.4 Allowed Simultaneous Flash Operations

Only the operations marked 'OK' in the following table are permitted to run simultaneously on the program flash, data flash, and FlexRAM memories. Some operations cannot be executed simultaneously because certain hardware resources are shared by the memories. The priority has been placed on permitting program flash reads while program and erase operations execute on the FlexNVM and FlexRAM. This provides read (program flash) while write (FlexNVM, FlexRAM) functionality.

**Table 23-32. Allowed Simultaneous Memory Operations** 

|         |                      | P    | rogram Fla | sh              |      | Data Flash | l               |      | FlexRAM              |                      |
|---------|----------------------|------|------------|-----------------|------|------------|-----------------|------|----------------------|----------------------|
|         |                      | Read | Program    | Sector<br>Erase | Read | Program    | Sector<br>Erase | Read | E-Write <sup>1</sup> | R-Write <sup>2</sup> |
|         | Read                 | _    |            |                 |      | ОК         | OK              |      | ОК                   |                      |
| Program | Program              |      | _          |                 | ОК   |            |                 | ОК   |                      | OK <sup>3</sup>      |
| flash   | Sector<br>Erase      |      |            | _               | ОК   |            |                 | ОК   |                      | ок                   |
|         | Read                 |      | OK         | OK              | _    |            |                 |      |                      |                      |
| Data    | Program              | OK   |            |                 |      | _          |                 | ОК   |                      | OK                   |
| flash   | Sector<br>Erase      | ОК   |            |                 |      |            | _               | ОК   |                      | ок                   |
|         | Read                 |      | ОК         | OK              |      | ОК         | OK              | _    |                      |                      |
| FlexRAM | E-Write <sup>1</sup> | ОК   |            |                 |      |            |                 |      | _                    |                      |
|         | R-Write <sup>2</sup> |      | ОК         | ОК              |      | ОК         | ОК              |      |                      | _                    |

- 1. When FlexRAM configured for EEPROM (writes are effectively multi-cycle operations).
- 2. When FlexRAM configured as traditional RAM (writes are single-cycle operations).
- 3. When FlexRAM configured as traditional RAM, writes to the RAM are ignored while the Program Section command is active (CCIF = 0).

# 23.4.10 Margin Read Commands

The Read-1s commands (Read 1s All Blocks, Read 1s Block, and Read 1s Section) and the Program Check command have a margin choice parameter that allows the user to apply non-standard read reference levels to the program flash and data flash array reads performed by these commands. Using the preset 'user' and 'factory' margin levels, these commands perform their associated read operations at tighter tolerances than a 'normal' read. These non-standard read levels are applied only during the command execution. All simple (uncommanded) flash array reads to the MCU always use the standard, unmargined, read reference level.

Only the 'normal' read level should be employed during normal flash usage. The non-standard, 'user' and 'factory' margin levels should be employed only in special cases. They can be used during special diagnostic routines to gain confidence that the device is not suffering from the end-of-life data loss customary of flash memory devices.

Erased ('1') and programmed ('0') bit states can degrade due to elapsed time and data cycling (number of times a bit is erased and re-programmed). The lifetime of the erased states is relative to the last erase operation. The lifetime of the programmed states is measured from the last program time.

The 'user' and 'factory' levels become, in effect, a minimum safety margin; i.e. if the reads pass at the tighter tolerances of the 'user' and 'factory' margins, then the 'normal' reads have at least this much safety margin before they experience data loss.

The 'user' margin is a small delta to the normal read reference level. 'User' margin levels can be employed to check that flash memory contents have adequate margin for normal level read operations. If unexpected read results are encountered when checking flash memory contents at the 'user' margin levels, loss of information might soon occur during 'normal' readout.

The 'factory' margin is a bigger deviation from the norm, a more stringent read criteria that should only be attempted immediately (or very soon) after completion of an erase or program command, early in the cycling life. 'Factory' margin levels can be used to check that flash memory contents have adequate margin for long-term data retention at the normal level setting. If unexpected results are encountered when checking flash memory contents at 'factory' margin levels, the flash memory contents should be erased and reprogrammed.

### CAUTION

Factory margin levels must only be used during verify of the initial factory programming.

# 23.4.11 FTFL Command Description

This section describes all FTFL commands that can be launched by a command write sequence. The FTFL sets the FSTAT[ACCERR] bit and aborts the command execution if any of the following illegal conditions occur:

- There is an unrecognized command code in the FCCOB FCMD field.
- There is an error in a FCCOB field for the specific commands. Refer to the error handling table provided for each command.

Ensure that the ACCERR and FPVIOL bits in the FSTAT register are cleared prior to starting the command write sequence. As described in Launch the Command by Clearing CCIF, a new command cannot be launched while these error flags are set.

Do not attempt to read a flash block while the FTFL is running a command (CCIF = 0) on that same block. The FTFL may return invalid data to the MCU with the collision error flag (FSTAT[RDCOLERR]) set.

When required by the command, address bit 23 selects between:

- program flash (=0) block
- data flash (=1) block

#### CAUTION

Flash data must be in the erased state before being programmed. Cumulative programming of bits (adding more zeros) is not allowed.

## 23.4.11.1 Read 1s Block Command

The Read 1s Block command checks to see if an entire program flash or data flash block has been erased to the specified margin level. The FCCOB flash address bits determine which logical block is erase-verified.

Table 23-33. Read 1s Block Command FCCOB Requirements

| FCCOB Number | FCCOB Number FCCOB Contents [7:0]                       |  |  |
|--------------|---------------------------------------------------------|--|--|
| 0            | 0x00 (RD1BLK)                                           |  |  |
| 1            | Flash address [23:16] in the flash block to be verified |  |  |
| 2            | Flash address [15:8] in the flash block to be verified  |  |  |

Table continues on the next page...

Table 23-33. Read 1s Block Command FCCOB Requirements (continued)

| FCCOB Number FCCOB Contents [7:0] |                                                                    |  |
|-----------------------------------|--------------------------------------------------------------------|--|
| 3                                 | Flash address [7:0] <sup>1</sup> in the flash block to be verified |  |
| 4                                 | Read-1 Margin Choice                                               |  |

<sup>1.</sup> Must be 32-bit aligned (Flash address [1:0] = 00).

After clearing CCIF to launch the Read 1s Block command, the FTFL sets the read margin for 1s according to Table 23-34 and then reads all locations within the selected program flash or data flash block.

When the data flash is targeted, DEPART must be set for no EEPROM, else the Read 1s Block command aborts setting the FSTAT[ACCERR] bit. If the FTFL fails to read all 1s (i.e. the flash block is not fully erased), the FSTAT[MGSTAT0] bit is set. The CCIF flag sets after the Read 1s Block operation has completed.

Table 23-34. Margin Level Choices for Read 1s Block

| Read Margin Choice Margin Level Description |                                                       |
|---------------------------------------------|-------------------------------------------------------|
| 0x00                                        | Use the 'normal' read level for 1s                    |
| 0x01                                        | Apply the 'User' margin to the normal read-1 level    |
| 0x02                                        | Apply the 'Factory' margin to the normal read-1 level |

Table 23-35. Read 1s Block Command Error Handling

| Error Condition                                                         | Error Bit      |
|-------------------------------------------------------------------------|----------------|
| Command not available in current mode/security                          | FSTAT[ACCERR]  |
| An invalid margin choice is specified                                   | FSTAT[ACCERR]  |
| Program flash is selected and the address is out of program flash range | FSTAT[ACCERR]  |
| Data flash is selected and the address is out of data flash range       | FSTAT[ACCERR]  |
| Data flash is selected with EEPROM enabled                              | FSTAT[ACCERR]  |
| Flash address is not longword aligned                                   | FSTAT[ACCERR]  |
| Read-1s fails                                                           | FSTAT[MGSTAT0] |

### 23.4.11.2 Read 1s Section Command

The Read 1s Section command checks if a section of program flash or data flash memory is erased to the specified read margin level. The Read 1s Section command defines the starting address and the number of longwords to be verified.

Table 23-36. Read 1s Section Command FCCOB Requirements

| FCCOB Number | FCCOB Contents [7:0]                                                  |
|--------------|-----------------------------------------------------------------------|
| 0            | 0x01 (RD1SEC)                                                         |
| 1            | Flash address [23:16] of the first longword to be verified            |
| 2            | Flash address [15:8] of the first longword to be verified             |
| 3            | Flash address [7:0] <sup>1</sup> of the first longword to be verified |
| 4            | Number of longwords to be verified [15:8]                             |
| 5            | Number of longwords to be verified [7:0]                              |
| 6            | Read-1 Margin Choice                                                  |

<sup>1.</sup> Must be longword aligned (Flash address [1:0] = 00).

Upon clearing CCIF to launch the Read 1s Section command, the FTFL sets the read margin for 1s according to Table 23-37 and then reads all locations within the specified section of flash memory. If the FTFL fails to read all 1s (i.e. the flash section is not erased), the FSTAT(MGSTAT0) bit is set. The CCIF flag sets after the Read 1s Section operation completes.

Table 23-37. Margin Level Choices for Read 1s Section

| Read Margin Choice | Margin Level Description                              |
|--------------------|-------------------------------------------------------|
| 0x00               | Use the 'normal' read level for 1s                    |
| 0x01               | Apply the 'User' margin to the normal read-1 level    |
| 0x02               | Apply the 'Factory' margin to the normal read-1 level |

Table 23-38. Read 1s Section Command Error Handling

| Error Condition                                      | Error Bit      |
|------------------------------------------------------|----------------|
| Command not available in current mode/security       | FSTAT[ACCERR]  |
| An invalid margin code is supplied                   | FSTAT[ACCERR]  |
| An invalid flash address is supplied                 | FSTAT[ACCERR]  |
| Flash address is not longword aligned                | FSTAT[ACCERR]  |
| The requested section crosses a Flash block boundary | FSTAT[ACCERR]  |
| The requested number of longwords is zero            | FSTAT[ACCERR]  |
| Read-1s fails                                        | FSTAT[MGSTAT0] |

# 23.4.11.3 Program Check Command

The Program Check command tests a previously programmed program flash or data flash longword to see if it reads correctly at the specified margin level.

Table 23-39. Program Check Command FCCOB Requirements

| FCCOB Number | FCCOB Contents [7:0]             |
|--------------|----------------------------------|
| 0            | 0x02 (PGMCHK)                    |
| 1            | Flash address [23:16]            |
| 2            | Flash address [15:8]             |
| 3            | Flash address [7:0] <sup>1</sup> |
| 4            | Margin Choice                    |
| 8            | Byte 0 expected data             |
| 9            | Byte 1 expected data             |
| Α            | Byte 2 expected data             |
| В            | Byte 3 expected data             |

<sup>1.</sup> Must be longword aligned (Flash address [1:0] = 00).

Upon clearing CCIF to launch the Program Check command, the FTFL sets the read margin for 1s according to Table 23-40, reads the specified longword, and compares the actual read data to the expected data provided by the FCCOB. If the comparison at margin-1 fails, the MGSTAT0 bit is set.

The FTFL then sets the read margin for 0s, re-reads, and compares again. If the comparison at margin-0 fails, the MGSTAT0 bit is set. The CCIF flag is set after the Program Check operation completes.

The starting address must be 32-bit aligned (the lowest two bits of the phrase byte address must be 00):

- Byte 0 data is expected at the supplied 32-bit aligned address,
- Byte 1 data is expected at byte address specified + 0b01,
- Byte 2 data is expected at byte address specified + 0b10, and
- Byte 3 data is expected at byte address specified + 0b11.

#### NOTE

See the description of margin reads, Margin Read Commands

Table 23-40. Margin Level Choices for Program Check

| Read Margin Choice | Margin Level Description                          |
|--------------------|---------------------------------------------------|
| 0x01               | Read at 'User' margin-1 and 'User' margin-0       |
| 0x02               | Read at 'Factory' margin-1 and 'Factory' margin-0 |

Table 23-41. Program Check Command Error Handling

| Error Condition                                | Error Bit     |
|------------------------------------------------|---------------|
| Command not available in current mode/security | FSTAT[ACCERR] |

Table continues on the next page...

Table 23-41. Program Check Command Error Handling (continued)

| Error Condition                                             | Error Bit      |
|-------------------------------------------------------------|----------------|
| An invalid flash address is supplied                        | FSTAT[ACCERR]  |
| Flash address is not longword aligned                       | FSTAT[ACCERR]  |
| An invalid margin choice is supplied                        | FSTAT[ACCERR]  |
| Either of the margin reads does not match the expected data | FSTAT[MGSTAT0] |

### 23.4.11.4 Read Resource Command

The Read Resource command allows the user to read data from special-purpose memory resources located within the FTFL module. The special-purpose memory resources available include program flash IFR space, data flash IFR space, and the Version ID field. Each resource is assigned a select code as shown in Table 23-43.

**Table 23-42. Read Resource Command FCCOB Requirements** 

| FCCOB Number         | FCCOB Contents [7:0]                   |  |
|----------------------|----------------------------------------|--|
| 0                    | 0x03 (RDRSRC)                          |  |
| 1                    | Flash address [23:16]                  |  |
| 2                    | Flash address [15:8]                   |  |
| 3                    | Flash address [7:0] <sup>1</sup>       |  |
| Returned Values      |                                        |  |
| 4                    | Read Data [31:24]                      |  |
| 5                    | Read Data [23:16]                      |  |
| 6                    | Read Data [15:8]                       |  |
| 7 Read Data [7:0]    |                                        |  |
| User-provided values |                                        |  |
| 8                    | Resource Select Code (see Table 23-43) |  |

<sup>1.</sup> Must be 32-bit aligned (Flash address [1:0] = 00).

Table 23-43. Read Resource Select Codes

| Resource<br>Select Code <sup>1</sup> | Description | Resource Size | Local Address Range |
|--------------------------------------|-------------|---------------|---------------------|
| 0x00                                 | IFR         | 256 Bytes     | 0x0000 - 0x00FF     |
| 0x01 <sup>2</sup>                    | Version ID  | 8 Bytes       | 0x0000 - 0x0007     |

- 1. Flash address [23] selects between program flash (=0) and FlexNVM (=1) resources..
- 2. Located in program flash 0 reserved space; Flash address [23] = 0

After clearing CCIF to launch the Read Resource command, four consecutive bytes are read from the selected resource at the provided relative address and stored in the FCCOB register. The CCIF flag sets after the Read Resource operation completes. The Read Resource command exits with an access error if an invalid resource code is provided or if the address for the applicable area is out-of-range.

Table 23-44. Read Resource Command Error Handling

| Error Condition                                          | Error Bit     |
|----------------------------------------------------------|---------------|
| Command not available in current mode/security           | FSTAT[ACCERR] |
| An invalid resource code is entered                      | FSTAT[ACCERR] |
| Flash address is out-of-range for the targeted resource. | FSTAT[ACCERR] |
| Flash address is not longword aligned                    | FSTAT[ACCERR] |

## 23.4.11.5 Program Longword Command

The Program Longword command programs four previously-erased bytes in the program flash memory or in the data flash memory using an embedded algorithm.

### **CAUTION**

A Flash memory location must be in the erased state before being programmed. Cumulative programming of bits (back-to-back program operations without an intervening erase) within a Flash memory location is not allowed. Re-programming of existing 0s to 0 is not allowed as this overstresses the device.

**Table 23-45. Program Longword Command FCCOB Requirements** 

| FCCOB Number | FCCOB Contents [7:0]             |
|--------------|----------------------------------|
| 0            | 0x06 (PGM4)                      |
| 1            | Flash address [23:16]            |
| 2            | Flash address [15:8]             |
| 3            | Flash address [7:0] <sup>1</sup> |
| 4            | Byte 0 program value             |
| 5            | Byte 1 program value             |
| 6            | Byte 2 program value             |
| 7            | Byte 3 program value             |

1. Must be 32-bit aligned (Flash address [1:0] = 00).

Upon clearing CCIF to launch the Program Longword command, the FTFL programs the data bytes into the flash using the supplied address. The protection status is always checked. The targeted flash locations must be currently unprotected (see the description of the FPROT registers) to permit execution of the Program Longword operation.

The programming operation is unidirectional. It can only move NVM bits from the erased state ('1') to the programmed state ('0'). Erased bits that fail to program to the '0' state are flagged as errors in MGSTAT0. The CCIF flag is set after the Program Longword operation completes.

The starting address must be longword aligned (flash address [1:0] = 00):

- Byte 0 data is written to the starting address ('start'),
- Byte 1 data is programmed to byte address start+0b01,
- Byte 2 data is programmed to byte address start+0b10, and
- Byte 3 data is programmed to byte address start+0b11.

**Table 23-46. Program Longword Command Error Handling** 

| Error Condition                                              | Error Bit      |
|--------------------------------------------------------------|----------------|
| Command not available in current mode/security               | FSTAT[ACCERR]  |
| An invalid flash address is supplied                         | FSTAT[ACCERR]  |
| Flash address is not longword aligned                        | FSTAT[ACCERR]  |
| Flash address points to a protected area                     | FSTAT[FPVIOL]  |
| Any errors have been encountered during the verify operation | FSTAT[MGSTAT0] |

## 23.4.11.6 Erase Flash Block Command

The Erase Flash Block operation erases all addresses in a single program flash or data flash block.

Table 23-47. Erase Flash Block Command FCCOB Requirements

| FCCOB Number | FCCOB Contents [7:0]                                             |
|--------------|------------------------------------------------------------------|
| 0            | 0x08 (ERSBLK)                                                    |
| 1            | Flash address [23:16] in the flash block to be erased            |
| 2            | Flash address [15:8] in the flash block to be erased             |
| 3            | Flash address [7:0] <sup>1</sup> in the flash block to be erased |

<sup>1.</sup> Must be 32-bit aligned (Flash address [1:0] = 00).

Upon clearing CCIF to launch the Erase Flash Block command, the FTFL erases the main array of the selected flash block and verifies that it is erased. When the data flash is targeted, DEPART must be set for no EEPROM (see Table 23-4) else the Erase Flash

Block command aborts setting the FSTAT[ACCERR] bit. The Erase Flash Block command aborts and sets the FSTAT[FPVIOL] bit if any region within the block is protected (see the description of the program flash protection (FPROT) registers and the data flash protection (FDPROT) registers) in NVM Normal mode or NVM Special mode. If the erase verify fails, the MGSTAT0 bit in FSTAT is set. The CCIF flag will set after the Erase Flash Block operation has completed.

Table 23-48. Erase Flash Block Command Error Handling

| Error Condition                                                                           | Error Bit      |
|-------------------------------------------------------------------------------------------|----------------|
| Command not available in current mode/security                                            | FSTAT[ACCERR]  |
| Program flash is selected and the address is out of program flash range                   | FSTAT[ACCERR]  |
| Data flash is selected and the address is out of data flash range                         | FSTAT[ACCERR]  |
| Data flash is selected with EEPROM enabled                                                | FSTAT[ACCERR]  |
| Flash address is not 32-bit aligned                                                       | FSTAT[ACCERR]  |
| Any area of the selected flash block is protected in NVM Normal mode or NVM Special mode. | FSTAT[FPVIOL]  |
| Any errors have been encountered during the verify operation                              | FSTAT[MGSTAT0] |

## 23.4.11.7 Erase Flash Sector Command

The Erase Flash Sector operation erases all addresses in a Flash sector.

Table 23-49. Erase Flash Sector Command FCCOB Requirements

| FCCOB Number | FCCOB Contents [7:0]                                              |
|--------------|-------------------------------------------------------------------|
| 0            | 0x09 (ERSSCR)                                                     |
| 1            | Flash address [23:16] in the flash sector to be erased            |
| 2            | Flash address [15:8] in the flash sector to be erased             |
| 3            | Flash address [7:0] <sup>1</sup> in the flash sector to be erased |

<sup>1.</sup> Must be 32-bit aligned (flash address [1:0] = 00).

After clearing CCIF to launch the Erase Flash Sector command, the FTFL erases the selected program flash or data flash sector and then verifies that it is erased. The Erase Flash Sector command aborts if the selected sector is protected (see the description of the FPROT registers) in NVM Normal mode or NVM Special mode. If the erase-verify fails the FSTAT[MGSTAT0] bit is set. The CCIF flag is set after the Erase Flash Sector operation completes. The Erase Flash Sector command is suspendable (see the FCNFG[ERSSUSP] bit and Figure 23-33).

Table 23-50. Erase Flash Sector Command Error Handling

| Error Condition                                                                                      | Error Bit      |
|------------------------------------------------------------------------------------------------------|----------------|
| Command not available in current mode/security                                                       | FSTAT[ACCERR]  |
| An invalid Flash address is supplied FSTAT[ACCEF                                                     |                |
| Flash address is not 32-bit aligned                                                                  | FSTAT[ACCERR]  |
| The selected program flash or data flash sector is protected in NVM Normal mode or NVM Special mode. | FSTAT[FPVIOL]  |
| Any errors have been encountered during the verify operation                                         | FSTAT[MGSTAT0] |

## 23.4.11.7.1 Suspending an Erase Flash Sector Operation

To suspend an Erase Flash Sector operation set the FCNFG[ERSSUSP] bit (see Flash Configuration Field Description) when CCIF is clear and the CCOB command field holds the code for the Erase Flash Sector command. During the Erase Flash Sector operation (see Erase Flash Sector Command), the FTFL samples the state of the ERSSUSP bit at convenient points. If the FTFL detects that the ERSSUSP bit is set, the Erase Flash Sector operation is suspended and the FTFL sets CCIF. While ERSSUSP is set, all writes to FTFL registers are ignored except for writes to the FSTAT and FCNFG registers.

If an Erase Flash Sector operation effectively completes before the FTFL detects that a suspend request has been made, the FTFL clears the ERSSUSP bit prior to setting CCIF. When an Erase Flash Sector operation has been successfully suspended, the FTFL sets CCIF and leaves the ERSSUSP bit set. While CCIF is set, the ERSSUSP bit can only be cleared to prevent the withdrawal of a suspend request before the FTFL has acknowledged it.

# 23.4.11.7.2 Resuming a Suspended Erase Flash Sector Operation

If the ERSSUSP bit is still set when CCIF is cleared to launch the next command, the previous Erase Flash Sector operation resumes. The FTFL acknowledges the request to resume a suspended operation by clearing the ERSSUSP bit. A new suspend request can then be made by setting ERSSUSP. A single Erase Flash Sector operation can be suspended and resumed multiple times.

There is a minimum elapsed time limit between the request to resume the Erase Flash Sector operation (CCIF is cleared) and the request to suspend the operation again (ERSSUSP is set). This minimum time period is required to ensure that the Erase Flash Sector operation will eventually complete. If the minimum period is continually violated, i.e. the suspend requests come repeatedly and too quickly, no forward progress is made by the Erase Flash Sector algorithm. The resume/suspend sequence runs indefinitely without completing the erase.

## 23.4.11.7.3 Aborting a Suspended Erase Flash Sector Operation

The user may choose to abort a suspended Erase Flash Sector operation by clearing the ERSSUSP bit prior to clearing CCIF for the next command launch. When a suspended operation is aborted, the FTFL starts the new command using the new FCCOB contents.

While FCNFG[ERSSUSP] is set, a write to the FlexRAM while FCNFG[EEERDY] is set clears ERSSUSP and aborts the suspended operation. The FlexRAM write operation is executed by the FTFL.

#### **Note**

Aborting the erase leaves the bitcells in an indeterminate, partially-erased state. Data in this sector is not reliable until a new erase command fully completes.

The following figure shows how to suspend and resume the Erase Flash Sector operation.



Figure 23-33. Suspend and Resume of Erase Flash Sector Operation

## 23.4.11.8 Program Section Command

The Program Section operation programs the data found in the section program buffer to previously erased locations in the flash memory using an embedded algorithm. Data is preloaded into the section program buffer by writing to the FlexRAM while it is set to function as traditional RAM (see Flash Sector Programming).

The section program buffer is limited to the lower half of the RAM. Data written to the upper half of the RAM is ignored and may be overwritten during Program Section command execution.

## **CAUTION**

A flash memory location must be in the erased state before being programmed. Cumulative programming of bits (back-toback program operations without an intervening erase) within a flash memory location is not allowed. Re-programming of existing 0s to 0 is not allowed as this overstresses the device.

| FCCOB Number | FCCOB Contents [7:0]                  |  |
|--------------|---------------------------------------|--|
| 0            | 0x0B (PGMSEC)                         |  |
| 1            | Flash address [23:16]                 |  |
| 2            | Flash address [15:8]                  |  |
| 3            | Flash address [7:0] <sup>1</sup>      |  |
| 4            | Number of longwords to program [15:8] |  |
| 5            | Number of longwords to program [7:0]  |  |

Table 23-51. Program Section Command FCCOB Requirements

After clearing CCIF to launch the Program Section command, the FTFL blocks access to the FlexRAM and programs the data residing in the section program buffer into the flash memory starting at the flash address provided.

The protection status is checked in NVM Normal mode and in NVM Special mode. The starting address must be unprotected (see the description of the FPROT registers) to permit execution of the Program Section operation. Programming, which is not allowed to cross a flash sector boundary, continues until all requested longwords have been programmed. The Program Section command also verifies that after programming, all bits requested to be programmed are programmed.

After the Program Section operation completes, the CCIF flag is set and normal access to the FlexRAM is restored. The contents of the section program buffer may be changed by the Program Section operation.

<sup>1.</sup> Must be 32-bit aligned (Flash address [1:0] = 00).

Table 23-52. Program Section Command Error Handling

| Error Condition                                                                                                  | Error Bit      |
|------------------------------------------------------------------------------------------------------------------|----------------|
| Command not available in current mode/security                                                                   | FSTAT[ACCERR]  |
| An invalid flash address is supplied                                                                             | FSTAT[ACCERR]  |
| Flash address is not 32-bit aligned                                                                              | FSTAT[ACCERR]  |
| The requested section crosses a program flash sector boundary                                                    | FSTAT[ACCERR]  |
| The requested number of longwords is zero                                                                        | FSTAT[ACCERR]  |
| The space required to store data for the requested number of longwords is more than half the size of the FlexRAM | FSTAT[ACCERR]  |
| The FlexRAM is not set to function as a traditional RAM, i.e. set if RAMRDY=0                                    | FSTAT[ACCERR]  |
| The flash address falls in a protected area                                                                      | FSTAT[FPVIOL]  |
| Any errors have been encountered during the verify operation                                                     | FSTAT[MGSTAT0] |

## 23.4.11.8.1 Flash Sector Programming

The process of programming an entire flash sector using the Program Section command is as follows:

- 1. If required, execute the Set FlexRAM Function command to make the FlexRAM available as traditional RAM and initialize the FlexRAM to all ones.
- 2. Launch the Erase Flash Sector command to erase the flash sector to be programmed.
- 3. Beginning with the starting address of the FlexRAM, sequentially write enough data to the RAM to fill an entire flash sector or half the FlexRAM, whichever is less. This area of the RAM serves as the section program buffer.

### **NOTE**

In step 1, the section program buffer was initialized to all ones, the erased state of the flash memory.

The section program buffer can be written to while the operation launched in step 2 is executing, i.e. while CCIF = 0.

- 4. Execute the Program Section command to program the contents of the section program buffer into the selected flash sector.
- 5. If a flash sector is larger than half the FlexRAM, repeat steps 3 and 4 until the sector is completely programmed.
- 6. To program additional flash sectors, repeat steps 2 through 4.
- 7. To restore EEPROM functionality, execute the Set FlexRAM Function command to make the FlexRAM available for EEPROM.

## 23.4.11.9 Read 1s All Blocks Command

The Read 1s All Blocks command checks if the program flash blocks, data flash blocks, FlexRAM, EEPROM backup records, and data flash IFR have been erased to the specified read margin level, if applicable, and releases security if the readout passes, i.e. all data reads as '1'.

Table 23-53. Read 1s All Blocks Command FCCOB Requirements

| FCCOB Number | FCCOB Contents [7:0] |
|--------------|----------------------|
| 0            | 0x40 (RD1ALL)        |
| 1            | Read-1 Margin Choice |

After clearing CCIF to launch the Read 1s All Blocks command, the FTFL:

- sets the read margin for 1s according to Table 23-54,
- checks the contents of the program flash, data flash, EEPROM backup records, data flash IFR, and FlexRAM are in the erased state.

If the FTFL confirms that these memory resources are erased, security is released by setting the FSEC[SEC] field to the unsecure state. The security byte in the flash configuration field (see Flash Configuration Field Description) remains unaffected by the Read 1s All Blocks command. If the read fails, i.e. all memory resources are not in the fully erased state, the FSTAT[MGSTAT0] bit is set.

The EEERDY and RAMRDY bits are clear during the Read 1s All Blocks operation and are restored at the end of the Read 1s All Blocks operation.

The CCIF flag sets after the Read 1s All Blocks operation has completed.

Table 23-54. Margin Level Choices for Read 1s All Blocks

| Read Margin Choice | Margin Level Description                              |
|--------------------|-------------------------------------------------------|
| 0x00               | Use the 'normal' read level for 1s                    |
| 0x01               | Apply the 'User' margin to the normal read-1 level    |
| 0x02               | Apply the 'Factory' margin to the normal read-1 level |

Table 23-55. Read 1s All Blocks Command Error Handling

| Error Condition                       | Error Bit      |
|---------------------------------------|----------------|
| An invalid margin choice is specified | FSTAT[ACCERR]  |
| Read-1s fails                         | FSTAT[MGSTAT0] |

## 23.4.11.10 Read Once Command

The Read Once command provides read access to a reserved 64-byte field located in the program flash IFR (see Program Flash IFR Map and Program Once Field). Access to this field is via 16 records, each 4 bytes long. The Read Once field is programmed using the Program Once command described in Program Once Command.

| FCCOB Number | FCCOB Contents [7:0]                 |  |
|--------------|--------------------------------------|--|
| 0            | 0x41 (RDONCE)                        |  |
| 1            | Read Once record index (0x00 - 0x0F) |  |
| 2            | Not used                             |  |
| 3            | Not used                             |  |
| ,            | Returned Values                      |  |
| 4            | Read Once byte 0 value               |  |
| 5            | Read Once byte 1 value               |  |
| 6            | Read Once byte 2 value               |  |
| 7            | Read Once byte 3 value               |  |

Table 23-56. Read Once Command FCCOB Requirements

After clearing CCIF to launch the Read Once command, a 4-byte Read Once record is read from the program flash IFR and stored in the FCCOB register. The CCIF flag is set after the Read Once operation completes. Valid record index values for the Read Once command range from 0x00 to 0x0F. During execution of the Read Once command, any attempt to read addresses within the program flash block containing this 64-byte field returns invalid data. The Read Once command can be executed any number of times.

Table 23-57. Read Once Command Error Handling

| Error Condition                                | Error Bit     |
|------------------------------------------------|---------------|
| Command not available in current mode/security | FSTAT[ACCERR] |
| An invalid record index is supplied            | FSTAT[ACCERR] |

# 23.4.11.11 Program Once Command

The Program Once command enables programming to a reserved 64-byte field in the program flash IFR (see Program Flash IFR Map and Program Once Field). Access to the Program Once field is via 16 records, each 4 bytes long. The Program Once field can be read using the Read Once command (see Read Once Command) or using the Read Resource command (see Read Resource Command). Each Program Once record can be programmed only once since the program flash IFR cannot be erased.

**Table 23-58. Program Once Command FCCOB Requirements** 

| FCCOB Number | FCCOB Contents [7:0]                    |
|--------------|-----------------------------------------|
| 0            | 0x43 (PGMONCE)                          |
| 1            | Program Once record index (0x00 - 0x0F) |
| 2            | Not Used                                |
| 3            | Not Used                                |
| 4            | Program Once Byte 0 value               |
| 5            | Program Once Byte 1 value               |
| 6            | Program Once Byte 2 value               |
| 7            | Program Once Byte 3 value               |

After clearing CCIF to launch the Program Once command, the FTFL first verifies that the selected record is erased. If erased, then the selected record is programmed using the values provided. The Program Once command also verifies that the programmed values read back correctly. The CCIF flag is set after the Program Once operation has completed.

The reserved program flash IFR location accessed by the Program Once command cannot be erased and any attempt to program one of these records when the existing value is not Fs (erased) is not allowed. Valid record index values for the Program Once command range from 0x00 to 0x0F. During execution of the Program Once command, any attempt to read addresses within program flash returns invalid data.

Table 23-59. Program Once Command Error Handling

| Error Condition                                                                   | Error Bit      |
|-----------------------------------------------------------------------------------|----------------|
| Command not available in current mode/security                                    | FSTAT[ACCERR]  |
| An invalid record index is supplied                                               | FSTAT[ACCERR]  |
| The requested record has already been programmed to a non-FFFF value <sup>1</sup> | FSTAT[ACCERR]  |
| Any errors have been encountered during the verify operation                      | FSTAT[MGSTAT0] |

<sup>1.</sup> If a Program Once record is initially programmed to 0xFFFF\_FFFF, the Program Once command is allowed to execute again on that same record.

## 23.4.11.12 Erase All Blocks Command

The Erase All Blocks operation erases all flash memory, initializes the FlexRAM, verifies all memory contents, and releases MCU security.

Table 23-60. Erase All Blocks Command FCCOB Requirements

| FCCOB Number | FCCOB Contents [7:0] |
|--------------|----------------------|
| 0            | 0x44 (ERSALL)        |

After clearing CCIF to launch the Erase All Blocks command, the FTFL erases all program flash memory, data flash memory, data flash IFR space, EEPROM backup memory, and FlexRAM, then verifies that all are erased.

If the FTFL verifies that all flash memories and the FlexRAM were properly erased, security is released by setting the FSEC[SEC] field to the unsecure state and the FCNFG[RAMRDY] bit is set. The Erase All Blocks command aborts if any flash or FlexRAM region is protected. The security byte and all other contents of the flash configuration field (see Flash Configuration Field Description) is erased by the Erase All Blocks command. If the erase-verify fails, the FSTAT[MGSTAT0] bit is set. The CCIF flag is set after the Erase All Blocks operation completes.

Table 23-61. Erase All Blocks Command Error Handling

| Error Condition                                                                    | Error Bit      |
|------------------------------------------------------------------------------------|----------------|
| Command not available in current mode/security                                     | FSTAT[ACCERR]  |
| Any region of the program flash memory, data flash memory, or FlexRAM is protected | FSTAT[FPVIOL]  |
| Any errors have been encountered during the verify operation                       | FSTAT[MGSTAT0] |

## 23.4.11.12.1 Triggering an Erase All External to the FTFL

The functionality of the Erase All Blocks command is also available in an uncommanded fashion outside of the flash memory. Refer to the device's Chip Configuration details for information on this functionality.

Before invoking the external erase all function, the FSTAT[ACCERR and PVIOL] flags must be cleared and the FCCOB0 register must not contain 0x44. When invoked, the erase-all function erases all program flash memory, data flash memory, data flash IFR space, EEPROM backup, and FlexRAM regardless of the protection settings. If the posterase verify passes, the routine then releases security by setting the FSEC[SEC] field register to the unsecure state and the FCNFG[RAMRDY] bit sets. The security byte in the Flash Configuration Field is also programmed to the unsecure state. The status of the erase-all request is reflected in the FCNFG[ERSAREQ] bit. The FCNFG[ERSAREQ] bit is cleared once the operation completes and the normal FSTAT error reporting is available as described in Erase All Blocks Command.

# 23.4.11.13 Verify Backdoor Access Key Command

The Verify Backdoor Access Key command only executes if the mode and security conditions are satisfied (see FTFL Commands by Mode). Execution of the Verify Backdoor Access Key command is further qualified by the FSEC[KEYEN] bits. The Verify Backdoor Access Key command releases security if user-supplied keys in the

FCCOB match those stored in the Backdoor Comparison Key bytes of the Flash Configuration Field (see Flash Configuration Field Description). The column labelled Flash Configuration Field offset address shows the location of the matching byte in the Flash Configuration Field.

Table 23-62. Verify Backdoor Access Key Command FCCOB Requirements

| FCCOB Number | FCCOB Contents [7:0] | Flash Configuration Field Offset Address |
|--------------|----------------------|------------------------------------------|
| 0            | 0x45 (VFYKEY)        |                                          |
| 1-3          | Not Used             |                                          |
| 4            | Key Byte 0           | 0x0_0000                                 |
| 5            | Key Byte 1           | 0x0_0001                                 |
| 6            | Key Byte 2           | 0x0_0002                                 |
| 7            | Key Byte 3           | 0x0_0003                                 |
| 8            | Key Byte 4           | 0x0_0004                                 |
| 9            | Key Byte 5           | 0x0_0005                                 |
| А            | Key Byte 6           | 0x0_0006                                 |
| В            | Key Byte 7           | 0x0_0007                                 |

After clearing CCIF to launch the Verify Backdoor Access Key command, the FTFL checks the FSEC[KEYEN] bits to verify that this command is enabled. If not enabled, the FTFL sets the FSTAT[ACCERR] bit and terminates. If the command is enabled, the FTFL compares the key provided in FCCOB to the backdoor comparison key in the Flash Configuration Field. If the backdoor keys match, the FSEC[SEC] field is changed to the unsecure state and security is released. If the backdoor keys do not match, security is not released and all future attempts to execute the Verify Backdoor Access Key command are immediately aborted and the FSTAT[ACCERR] bit is (again) set to 1 until a reset of the FTFL module occurs. If the entire 8-byte key is all zeros or all ones, the Verify Backdoor Access Key command fails with an access error. The CCIF flag is set after the Verify Backdoor Access Key operation completes.

Table 23-63. Verify Backdoor Access Key Command Error Handling

| Error Condition                                                                              | Error Bit     |
|----------------------------------------------------------------------------------------------|---------------|
| The supplied key is all-0s or all-Fs                                                         | FSTAT[ACCERR] |
| An incorrect backdoor key is supplied                                                        | FSTAT[ACCERR] |
| Backdoor key access has not been enabled (see the description of the FSEC register)          | FSTAT[ACCERR] |
| This command is launched and the backdoor key has mismatched since the last power down reset | FSTAT[ACCERR] |

## 23.4.11.14 Program Partition Command

The Program Partition command prepares the FlexNVM block for use as data flash, EEPROM backup, or a combination of both and initializes the FlexRAM. The Program Partition command must not be launched from flash memory, since flash memory resources are not accessible during Program Partition command execution.

### **CAUTION**

While different partitions of the FlexNVM are available, the intention is that a single partition choice is used throughout the entire lifetime of a given application. The FlexNVM Partition Code choices affect the endurance and data retention characteristics of the device.

Table 23-64. Program Partition Command FCCOB Requirements

| FCCOB Number | FCCOB Contents [7:0]                |
|--------------|-------------------------------------|
| 0            | 0x80 (PGMPART)                      |
| 1            | Not Used                            |
| 2            | Not Used                            |
| 3            | Not Used                            |
| 4            | EEPROM Data Size Code <sup>1</sup>  |
| 5            | FlexNVM Partition Code <sup>2</sup> |

- 1. See Table 23-65 and EEPROM Data Set Size
- 2. See Table 23-66 and

Table 23-65. Valid EEPROM Data Set Size Codes

| EEPROM Data Size Code (FCCOB4) <sup>1</sup> |                 | EEPROM Data Set Size (Bytes) |
|---------------------------------------------|-----------------|------------------------------|
| FCCOB4[5:4]                                 | FCCOB4[EEESIZE] |                              |
| 11                                          | 0xF             | 02                           |
| 11                                          | 0x9             | 32                           |
| 11                                          | 0x8             | 64                           |
| 11                                          | 0x7             | 128                          |
| 11                                          | 0x6             | 256                          |
| 11                                          | 0x5             | 512                          |
| 11                                          | 0x4             | 1024                         |
| 11                                          | 0x3             | 2048                         |

- 1. FCCOB4[7:6] = 00
- 2. EEPROM Data Set Size must be set to 0 bytes when the FlexNVM Partition Code is set for no EEPROM.

538

Table 23-66. Valid FlexNVM Partition Codes

| FlexNVM Partition Code<br>(FCCOB5[DEPART]) <sup>1</sup> | Data flash Size (Kbytes) | EEPROM backup Size (Kbytes) |
|---------------------------------------------------------|--------------------------|-----------------------------|
| 0000                                                    | 32                       | 0                           |
| 0001                                                    | 24                       | 8                           |
| 0010                                                    | 16                       | 16                          |
| 0011                                                    | 0                        | 32                          |
| 1000                                                    | 0                        | 32                          |
| 1001                                                    | 8                        | 24                          |
| 1010                                                    | 16                       | 16                          |
| 1011                                                    | 32                       | 0                           |

#### 1. FCCOB5[7:4] = 0000

After clearing CCIF to launch the Program Partition command, the FTFL first verifies that the EEPROM Data Size Code and FlexNVM Partition Code in the data flash IFR are erased. If erased, the Program Partition command erases the contents of the FlexNVM memory. If the FlexNVM is to be partitioned for EEPROM backup, the allocated EEPROM backup sectors are formatted for EEPROM use. Finally, the partition codes are programmed into the data flash IFR using the values provided. The Program Partition command also verifies that the partition codes read back correctly after programming. If the FlexNVM is partitioned for EEPROM, the allocated EEPROM backup sectors are formatted for EEPROM use. The CCIF flag is set after the Program Partition operation completes.

Prior to launching the Program Partition command, the data flash IFR must be in an erased state, which can be accomplished by executing the Erase All Blocks command or by an external request (see Erase All Blocks Command). The EEPROM Data Size Code and FlexNVM Partition Code are read using the Read Resource command (see Read Resource Command).

 Table 23-67.
 Program Partition Command Error Handling

| Error Condition                                                                                                     | Error Bit     |
|---------------------------------------------------------------------------------------------------------------------|---------------|
| Command not available in current mode/security                                                                      | FSTAT[ACCERR] |
| The EEPROM data size and FlexNVM partition code bytes are not initially 0xFFFF                                      | FSTAT[ACCERR] |
| Invalid EEPROM Data Size Code is entered (see Table 23-65 for valid codes)                                          | FSTAT[ACCERR] |
| Invalid FlexNVM Partition Code is entered (see Table 23-66 for valid codes)                                         | FSTAT[ACCERR] |
| FlexNVM Partition Code = full data flash (no EEPROM) and EEPROM Data Size Code allocates FlexRAM for EEPROM         | FSTAT[ACCERR] |
| FlexNVM Partition Code allocates space for EEPROM backup, but EEPROM Data Size Code allocates no FlexRAM for EEPROM | FSTAT[ACCERR] |
| FCCOB4[7:6] != 00                                                                                                   | FSTAT[ACCERR] |

Table continues on the next page...

Table 23-67. Program Partition Command Error Handling (continued)

| Error Condition                                              | Error Bit      |
|--------------------------------------------------------------|----------------|
| FCCOB5[7:3] != 00000                                         | FSTAT[ACCERR]  |
| Any errors have been encountered during the verify operation | FSTAT[MGSTAT0] |

## 23.4.11.15 Set FlexRAM Function Command

The Set FlexRAM Function command changes the function of the FlexRAM:

- When not partitioned for EEPROM, the FlexRAM is typically used as traditional RAM.
- When partitioned for EEPROM, the FlexRAM is typically used to store EEPROM data

Table 23-68. Set FlexRAM Function Command FCCOB Requirements

| FCCOB Number | FCCOB Contents [7:0]          |
|--------------|-------------------------------|
| 0            | 0x81 (SETRAM)                 |
| 4            | FlexRAM Function Control Code |
| l l          | (see Table 23-69)             |

Table 23-69. FlexRAM Function Control

| FlexRAM Function<br>Control Code | Action                                                                                                                                                                                                       |
|----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0xFF                             | Make FlexRAM available as RAM:  Clear the FCNFG[RAMRDY] and FCNFG[EEERDY] flags Write a background of ones to all FlexRAM locations Set the FCNFG[RAMRDY] flag                                               |
| 0x00                             | Make FlexRAM available for EEPROM:  Clear the FCNFG[RAMRDY] and FCNFG[EEERDY] flags Write a background of ones to all FlexRAM locations Copy-down existing EEPROM data to FlexRAM Set the FCNFG[EEERDY] flag |

After clearing CCIF to launch the Set FlexRAM Function command, the FTFL sets the function of the FlexRAM based on the FlexRAM Function Control Code.

When making the FlexRAM available as traditional RAM, the FTFL clears the FCNFG[EEERDY] flag, overwrites the contents of the entire FlexRAM with a background pattern of all ones, and sets the FCNFG[RAMRDY] flag. The state of the EPROT register does not prevent the FlexRAM from being overwritten. When the FlexRAM is set to function as a RAM, normal read and write accesses to the FlexRAM

are available. When large sections of flash memory need to be programmed, e.g. during factory programming, the FlexRAM can be used as the Section Program Buffer for the Program Section command (see Program Section Command).

When making the FlexRAM available for EEPROM, the FTFL clears the FCNFG[RAMRDY] flag, overwrites the contents of the FlexRAM allocated for EEPROM with a background pattern of all ones, and copies the existing EEPROM data from the EEPROM backup record space to the FlexRAM. After completion of the EEPROM copy-down, the FCNFG[EEERDY] flag is set. When the FlexRAM is set to function as EEPROM, normal read and write access to the FlexRAM is available, but writes to the FlexRAM also invoke EEPROM activity.

 Error Condition
 Error Bit

 Command not available in current mode/security
 FSTAT[ACCERR]

 FlexRAM Function Control Code is not defined
 FSTAT[ACCERR]

 FlexRAM Function Control Code is set to make the FlexRAM available for EEPROM, but FlexNVM is not partitioned for EEPROM
 FSTAT[ACCERR]

Table 23-70. Set FlexRAM Function Command Error Handling

# 23.4.12 **Security**

The FTFL module provides security information to the MCU based on contents of the FSEC security register. The MCU then limits access to FTFL resources as defined in the device's Chip Configuration details. During reset, the FTFL module initializes the FSEC register using data read from the security byte of the Flash Configuration Field (see Flash Configuration Field Description).

The following fields are available in the FSEC register. Details of the settings are described in the FSEC register description.

| FSEC field | Description              |  |
|------------|--------------------------|--|
| KEYEN      | Backdoor Key Access      |  |
| MEEN       | Mass Erase Capability    |  |
| FSLACC     | Freescale Factory Access |  |
| SEC        | MCU security             |  |

Table 23-71. FSEC fields

### 23.4.12.1 FTFL Access by Mode and Security

The following table summarizes how access to the FTFL module is affected by security and operating mode.

Table 23-72. FTFL Access Summary

| Operating Mode | MCU Security State                                                   |        |  |
|----------------|----------------------------------------------------------------------|--------|--|
| Operating Mode | Unsecure                                                             | Secure |  |
| NVM Normal     | Full command set                                                     |        |  |
| NVM Special    | Full command set  Only the Erase All Blocks and Rea Blocks commands. |        |  |

# 23.4.12.2 Changing the Security State

The security state out of reset can be permanently changed by programming the security byte of the flash configuration field. This assumes that you are starting from a mode where the necessary program flash erase and program commands are available and that the region of the program flash containing the flash configuration field is unprotected. If the flash security byte is successfully programmed, its new value takes affect after the next MCU reset.

### 23.4.12.2.1 Unsecuring the MCU Using Backdoor Key Access

The MCU may be unsecured by using the backdoor key access feature which requires knowledge of the contents of the 8-byte backdoor key value stored in the Flash Configuration Field (see Flash Configuration Field Description). If the FSEC[KEYEN] bits are in the enabled state, the Verify Backdoor Access Key command (see Verify Backdoor Access Key Command) can be run which allows the user to present prospective keys for comparison to the stored keys. If the keys match, the FSEC[SEC] bits are changed to unsecure the MCU. The entire 8-byte key cannot be all 0s or all 1s, i.e. 0x0000\_0000\_0000\_0000 and 0xFFFF\_FFFF\_FFFF\_FFFF are not accepted by the Verify Backdoor Access Key command as valid comparison values. While the Verify Backdoor Access Key command is active, program flash memory is not available for read access and returns invalid data.

The user code stored in the program flash memory must have a method of receiving the backdoor keys from an external stimulus. This external stimulus would typically be through one of the on-chip serial ports.

If the KEYEN bits are in the enabled state, the MCU can be unsecured by the backdoor key access sequence described below:

- 1. Follow the command sequence for the Verify Backdoor Access Key command as explained in Verify Backdoor Access Key Command
- 2. If the Verify Backdoor Access Key command is successful, the MCU is unsecured and the FSEC[SEC] bits are forced to the unsecure state

The Verify Backdoor Access Key command is monitored by the FTFL and an illegal key prohibits future use of the Verify Backdoor Access Key command. A reset of the MCU is the only method to re-enable the Verify Backdoor Access Key command when a comparison fails.

After the backdoor keys have been correctly matched, the MCU is unsecured by changing the FSEC[SEC] bits. A successful execution of the Verify Backdoor Access Key command changes the security in the FSEC register only. It does not alter the security byte or the keys stored in the Flash Configuration Field (Flash Configuration Field Description). After the next reset of the MCU, the security state of the FTFL module reverts back to the Flash security byte in the Flash Configuration Field. The Verify Backdoor Access Key command sequence has no effect on the program and erase protections defined in the program flash protection registers.

If the backdoor keys successfully match, the unsecured MCU has full control of the contents of the Flash Configuration Field. The MCU may erase the sector containing the Flash Configuration Field and reprogram the flash security byte to the unsecure state and change the backdoor keys to any desired value.

# 23.4.13 Reset Sequence

On each system reset the FTFL module executes a sequence which establishes initial values for the flash block configuration parameters, FPROT, FDPROT, FEPROT, FOPT, and FSEC registers and the FCNFG[RAMRDY, EEERDY] bits.

CCIF is cleared throughout the reset sequence. The FTFL module holds off all CPU access for a portion of the reset sequence. Flash reads are possible when the hold is removed. Completion of the reset sequence is marked by setting CCIF which enables flash user commands.

If a reset occurs while any FTFL command is in progress, that command is immediately aborted. The state of the word being programmed or the sector/block being erased is not guaranteed. Commands and operations do not automatically resume after exiting reset.



# Chapter 24 External Bus Interface (Mini-FlexBus)

### 24.1 Introduction

This chapter describes external bus data transfer operations and error conditions. It describes transfers initiated by the core processor (or any other bus master) and includes detailed timing diagrams showing the interaction of signals in supported bus operations.

The Mini-FlexBus is a subset of the FlexBus module found on other ColdFire microprocessors. The Mini-FlexBus minimizes package pin-outs while maintaining a high level of configurability and functionality.

### 24.1.1 Overview

A multi-function external bus interface called the Mini-FlexBus interface controller is provided on the device with basic functionality of interfacing to slave-only devices. It can be directly connected to the following asynchronous or synchronous devices with little or no additional circuitry:

- External ROMs
- Flash memories
- Programmable logic devices
- Other simple target (slave) devices

For asynchronous devices, a simple chip-select based interface can be used.

The Mini-FlexBus interface has up to two general purpose chip-selects,  $\overline{FB\_CS}[1:0]$ . The actual number of chip selects available depends upon the device and its pin configuration.

#### **24.1.2 Features**

Key Mini-FlexBus features include:

- Two independent, user-programmable chip-select signals (FB\_CS[1:0]) that can interface with external SRAM, PROM, EPROM, EEPROM, flash, and other peripherals
- 8- and 16-bit port sizes with configuration for multiplexed or non-multiplexed address and data buses
- 8-bit, 16-bit, 32-bit, and 16-byte transfers
- Programmable address-setup time with respect to the assertion of chip select
- Programmable address-hold time with respect to the negation of chip select and transfer direction
- Extended address latch enable option helps with glueless connections to synchronous and asynchronous memory devices

# 24.1.3 Modes of Operation

The external interface is a configurable multiplexed bus set to one of the following modes:

- Up to a 20-bit address (non-multiplexed) with 8-bit data
- Up to a 20-bit address (multiplexed) with 16-bit data (write masking of upper/lower bytes not supported)
- Up to a 20-bit address (multiplexed) with 8-bit data

# 24.2 Signal Descriptions

This section describes the external signals involved in data-transfer operations.

#### NOTE

Not all of the following signals may be available on a particular device. See the Chip Configuration details for information on which signals are available.

Table 24-1. Mini-FlexBus Signal Descriptions

| Signal     | Description                                                                                                                                | I/O |
|------------|--------------------------------------------------------------------------------------------------------------------------------------------|-----|
| FB_A[19:0] | In a non-multiplexed configuration, this is the address bus. In a multiplexed configuration this bus is the address/data bus, FB_AD[19:0]. | I/O |
| FB_D[7:0]  | In a non-multiplexed configuration, this is the data bus. In multiplexed configurations, this bus is not used.                             | I/O |
| FB_CS[1:0] | General purpose chip-selects. The actual number of chip selects available depends upon the device and its pin configuration.               |     |
| FB_OE      | Output enable                                                                                                                              | 0   |
| FB_R/W     | FB_R/W Read/write. 1 = Read, 0 = Write                                                                                                     |     |
| FB_TS      | Transfer start                                                                                                                             | 0   |
| FB_ALE     | Address latch enable (an inverse of FB_TS)                                                                                                 | 0   |

### 24.2.1 Address and Data Buses (FB\_An, FB\_Dn, FB\_ADn)

In non-multiplexed mode, the FB\_A[19:0] and FB\_D[7:0] buses carry the address and data, respectively.

In multiplexed mode, the FB\_AD[19:0] bus carries the address and data. The full 20-bit address is driven on the first clock of a bus cycle (address phase). Following the first clock, the data is driven on the bus (data phase). During the data phase, the address continues driving on the pins not used for data. For example, in 16-bit mode the lower address continues driving on FB\_AD[19:16] and in 8-bit mode the lower address continues driving on FB\_AD[19:8].

# 24.2.2 Chip Selects (FB\_CS[ 1:0])

The chip-select signal indicates which device is selected. A particular chip-select asserts when the transfer address is within the device's address space, as defined in the base- and mask-address registers. The actual number of chip selects available depends upon the pin configuration.

# 24.2.3 Output Enable (FB\_OE)

The output enable signal (FB\_OE) is sent to the interfacing memory and/or peripheral to enable a read transfer. FB\_OE is only asserted during read accesses when a chip select matches the current address decode.

# 24.2.4 Read/Write (FB\_R/W)

The processor drives the  $FB_R/\overline{W}$  signal to indicate the current bus operation direction. It is driven high during read bus cycles and low during write bus cycles.

# 24.2.5 Transfer Start/Address Latch Enable (FB\_TS/FB\_ALE)

The assertion of FB\_TS indicates that the device has begun a bus transaction and the address and attributes are valid.

In multiplexed mode, an inverted FB\_TS (FB\_ALE) is available as an address latch enable, which indicates when the address is being driven on the FB\_AD bus.

FB\_TS/FB\_ALE is asserted for one bus clock cycle.

This device can extend this signal until the first positive clock edge after  $\overline{FB\_CSn}$  asserts. See CSCRn[EXTS] and Extended Transfer Start/Address Latch Enable.

# 24.3 Memory Map/Register Definition

The following tables describe the registers and bit meanings for configuring chip-select operation.

The actual number of chip selects available depends upon the device and its pin configuration. If the device does not support certain chip select signals or the pin is not configured for a chip-select function, then that corresponding set of chip-select registers has no effect on an external pin.

#### Note

You must set CSMR0[V] before the chip select registers take effect.

A bus error occurs when writing to reserved register locations.

#### FB memory map

| Absolute address (hex) | Register name                                   |  | Access | Reset value | Section/<br>page |
|------------------------|-------------------------------------------------|--|--------|-------------|------------------|
| FFFF_E800              | Chip select address register (FB_CSAR0)         |  | R/W    | 0000_0000h  | 24.3.1/<br>549   |
| FFFF_E804              | FF_E804 Chip select mask register (FB_CSMR0)    |  | R/W    | 0000_0000h  | 24.3.2/<br>550   |
| FFFF_E808              | Chip select control register (FB_CSCR0)         |  | R/W    | 0000_0000h  | 24.3.3/<br>551   |
| FFFF_E80C              | C Chip select address register (FB_CSAR1)       |  | R/W    | 0000_0000h  | 24.3.1/<br>549   |
| FFFF_E810              | FFFF_E810 Chip select mask register (FB_CSMR1)  |  | R/W    | 0000_0000h  | 24.3.2/<br>550   |
| FFFF_E814              | FF_E814 Chip select control register (FB_CSCR1) |  | R/W    | 0000_0000h  | 24.3.3/<br>551   |

# 24.3.1 Chip select address register (FB\_CSARn)

The CSARn registers specify the chip-select base addresses.

#### **NOTE**

Refer to the device memory map for the only applicable Mini-FlexBus "expansion" address range for which the chip-selects can be active. Set the CSARn and CSMRn registers appropriately before accessing this region.

Addresses: FB\_CSAR0 is FFFF\_E800h base + 0h offset = FFFF\_E800h FB\_CSAR1 is FFFF\_E800h base + Ch offset = FFFF\_E80Ch



#### FB\_CSARn field descriptions

| Field            | Description                                                                                                        |
|------------------|--------------------------------------------------------------------------------------------------------------------|
| 31–16<br>BA      | Base address  Defines the base address for memory dedicated to chip-select FB_CSn. BA is compared to bits 31–16 on |
|                  | the internal address bus to determine if chip-select memory is being accessed.                                     |
| 15–0<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                 |

# 24.3.2 Chip select mask register (FB\_CSMRn)

CSMRn registers specify the address mask and allowable access types for the respective chip-selects.

Addresses: FB\_CSMR0 is FFFF\_E800h base + 4h offset = FFFF\_E804h FB\_CSMR1 is FFFF\_E800h base + 10h offset = FFFF\_E810h



#### FB\_CSMRn field descriptions

| Field            | Description                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 31–16<br>BAM     | Base address mask                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |
| DAIN             | Defines the chip-select block size by masking address bits. Setting a BAM bit causes the corresponding CSAR bit to be a don't care in the decode.                                                                                                                                                                                                                                                                   |  |  |
|                  | The block size for $\overline{FB}$ _CSn is $2^n$ ; n = (number of bits set in respective CSMR[BAM]) + 16.                                                                                                                                                                                                                                                                                                           |  |  |
|                  | For example, if CSAR0[BA] equals 0x8000 and CSMR0[BAM] equals 0x0007, FB_CS0 addresses one 512 KB memory block from 0x8000_0000 - 0x8007_FFFF.                                                                                                                                                                                                                                                                      |  |  |
|                  | To access 2 MB of address space starting at location 0x8000_0000, FB_CS1 must begin at the next byte after FB_CS0 for a 1 MB address space. Therefore, CSAR0[BA] equals 0x8000, CSMR0[BAM] equals 0x000F, CSAR1[BA] equals 0x8010, and CSMR1[BAM] equals 0x000F. Then, FB_CS0 addresses one 1 MB memory block from 0x8000_0000 – 0x800F_FFFF. FB_CS1 addresses one 1MB memory block from 0x8010_0000 – 0x801F_FFFF. |  |  |
|                  | 0 Corresponding address bit is used in chip-select decode                                                                                                                                                                                                                                                                                                                                                           |  |  |
|                  | 1 Corresponding address bit is a don't care in chip-select decode.                                                                                                                                                                                                                                                                                                                                                  |  |  |
| 15–9<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                                                                                                                                                                  |  |  |
| 8                | Write protect                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |
| WP               | Controls write accesses to the address range in the corresponding CSAR. Attempting to write to the range of addresses for which CSARn[WP] is set results in a bus error termination of the internal cycle and no external cycle.                                                                                                                                                                                    |  |  |
|                  | 0 Read and write accesses are allowed                                                                                                                                                                                                                                                                                                                                                                               |  |  |
|                  | 1 Only read accesses are allowed                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
| 7–1<br>Reserved  | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                                                                                                                                                                  |  |  |
| 0                | Valid                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
| V                | Indicates whether the corresponding CSAR, CSMR, and CSCR contents are valid. Programmed chip-selects do not assert until V bit is set. Reset clears each CSMRn[V].                                                                                                                                                                                                                                                  |  |  |

Table continues on the next page...

### FB\_CSMRn field descriptions (continued)

| Field | Description                                                                                                                 |  |  |
|-------|-----------------------------------------------------------------------------------------------------------------------------|--|--|
|       | <b>NOTE:</b> At reset, no chip-select can be used until the CSMR0[V] is set. Afterward, FB_CS[1:0] functions as programmed. |  |  |
|       | Chip select invalid     Chip select valid                                                                                   |  |  |

## 24.3.3 Chip select control register (FB\_CSCRn)

Each CSCRn controls the auto-acknowledge, address setup and hold times, port size, burst capability, and number of wait states.

#### NOTE

The CSCR0 reset value differs from the other CSCRs:

- Bits 31-23 are 0
- Bit 22 is device-dependent
- Bits 21-10 are 1
- Bits 9-5 are device-dependent
- Bits 4-0 are 0

See the Chip Configuration details for your particular device for information on the exact CSCR0 reset value.

Addresses: FB\_CSCR0 is FFFF\_E800h base + 8h offset = FFFF\_E808h FB\_CSCR1 is FFFF\_E800h base + 14h offset = FFFF\_E814h



#### FB\_CSCRn field descriptions

| Field             | Description                                                                                                                                                                                                  |
|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–22<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                                                                           |
| 21–20<br>ASET     | Address setup  Controls the assertion of the chip-select with respect to assertion of a valid address and attributes. The address and attributes are considered valid at the same time FB_TS/FB_ALE asserts. |
|                   | 00 Assert FB_CSn on first rising clock edge after address is asserted. (Default FB_CS1) 01 Assert FB_CSn on second rising clock edge after address is asserted.                                              |

Table continues on the next page...

#### **Memory Map/Register Definition**

### FB\_CSCRn field descriptions (continued)

| Field         | Description                                                                                                                                                                                                                                                                                                                       |  |  |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|               | 10 Assert FB_CSn on third rising clock edge after address is asserted.                                                                                                                                                                                                                                                            |  |  |
|               | 11 Assert FB_CSn on fourth rising clock edge after address is asserted. (Default FB_CS0)                                                                                                                                                                                                                                          |  |  |
| 19–18<br>RDAH | Read address hold or deselect                                                                                                                                                                                                                                                                                                     |  |  |
| NDAH          | This field controls the address and attribute hold time after the termination during a read cycle that hits in the chip-select address space.                                                                                                                                                                                     |  |  |
|               | <b>NOTE:</b> The hold time applies only at the end of a transfer. Therefore, during a transfer to a port size smaller than the transfer size, the hold time is only added after the last bus cycle.                                                                                                                               |  |  |
|               | The number of cycles the address and attributes are held after FB_CSn negation depends on the value of CSCRn[AA].                                                                                                                                                                                                                 |  |  |
|               | 00 If AA is set, 0 cycles.                                                                                                                                                                                                                                                                                                        |  |  |
|               | 01 If AA is set, 1 cycle.                                                                                                                                                                                                                                                                                                         |  |  |
|               | 10 If AA is set, 2 cycles.                                                                                                                                                                                                                                                                                                        |  |  |
|               | 11 If AA is set, 3 cycles.                                                                                                                                                                                                                                                                                                        |  |  |
| 17–16         | Write address hold or deselect                                                                                                                                                                                                                                                                                                    |  |  |
| WRAH          | Write address hold or deselect. This field controls the address, data, and attribute hold time after the termination of a write cycle that hits in the chip-select address space.                                                                                                                                                 |  |  |
|               | <b>NOTE:</b> The hold time applies only at the end of a transfer. Therefore, during a transfer to a port size smaller than the transfer size, the hold time is only added after the last bus cycle.                                                                                                                               |  |  |
|               | 00 Hold address and attributes one cycle after FB_CSn negates on writes. (Default FB_CS0)                                                                                                                                                                                                                                         |  |  |
|               | 01 Hold address and attributes two cycles after FB_CSn negates on writes.                                                                                                                                                                                                                                                         |  |  |
|               | 10 Hold address and attributes three cycles after FB_CSn negates on writes.                                                                                                                                                                                                                                                       |  |  |
|               | 11 Hold address and attributes four cycles after FB_CSn negates on writes. (Default FB_CS0)                                                                                                                                                                                                                                       |  |  |
| 15–10         | Wait states                                                                                                                                                                                                                                                                                                                       |  |  |
| WS            | The number of wait states inserted after FB_CSn asserts and before an internal transfer acknowledge is generated (WS = 0 inserts zero wait states, WS = 0x3F inserts 63 wait states).                                                                                                                                             |  |  |
| 9             | Multiplexed mode                                                                                                                                                                                                                                                                                                                  |  |  |
| MUX           | Selects between multiplexed and non-multiplexed address/data bus.                                                                                                                                                                                                                                                                 |  |  |
|               | 0 Non-multiplexed configuration. Address information is driven on FB_An and data is read/written on FB_Dn.                                                                                                                                                                                                                        |  |  |
|               | Multiplexed configuration. Address information is driven on FB_ADn, and low-order address lines (FB_AD[7:0] for byte port size or FB_AD[15:0] for word port size) must be latched using the falling edge of FB_ALE as the latch enable. Data is read/written on FB_AD[7:0] for byte port size and FB_AD[15:0] for word port size. |  |  |
| 8             | Auto-acknowledge enable                                                                                                                                                                                                                                                                                                           |  |  |
| AA            | Determines the assertion of the internal transfer acknowledge for accesses specified by the chip-select address. This bit must be set.                                                                                                                                                                                            |  |  |
|               | NOTE: This bit must be set, since only internal termination is supported by the Mini-FlexBus.                                                                                                                                                                                                                                     |  |  |
|               | <ul> <li>Reserved</li> <li>Internal transfer acknowledge is asserted as specified by WS</li> </ul>                                                                                                                                                                                                                                |  |  |
|               |                                                                                                                                                                                                                                                                                                                                   |  |  |

Table continues on the next page...

#### FB\_CSCRn field descriptions (continued)

| Field           | Description                                                                                                                                                                                                                                                                                                                                 |  |  |
|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 7–6<br>PS       | Port size  Specifies the data port width associated with each chip-select. It determines where data is driven during                                                                                                                                                                                                                        |  |  |
|                 | write cycles and where data is sampled during read cycles.  O Reserved O1 8-bit port size. Valid data sampled and driven on FB_D[7:0] 10 16-bit port size. Valid data sampled and driven on FB_D[15:0]. Only supported in multiplexed mode. 11 16-bit port size. Valid data sampled and driven on FB_D[15:0]. Only supported in multiplexed |  |  |
|                 | mode.                                                                                                                                                                                                                                                                                                                                       |  |  |
| 5–0<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                                                                                          |  |  |

# 24.4 Functional Description

This section provides the functional description of the module.

# 24.4.1 Chip-Select Operation

Each chip-select has a dedicated set of registers for configuration and control:

- Chip-select address registers (CSARn) control the base address space of the chip-select.
- Chip-select mask registers (CSMRn) provide 16-bit address masking and access control.
- Chip-select control registers (CSCRn) provide port size, wait-state generation, address setup and hold times, and automatic acknowledge generation features.

### 24.4.1.1 General Chip-Select Operation

When a bus cycle is routed to the Mini-FlexBus, the device first compares its address with the base address and mask configurations programmed for chip-selects 0 and 1 (configured in CSCRn). The results depend on if the address matches or not as shown in the following table.

Table 24-12. Results of Address Comparison

| Address Matches CSARn? | Result                                                                                                                                                                      |
|------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Yes,                   | The appropriate chip-select is asserted, generating a Mini-FlexBus bus cycle as defined in the chip-select control register.                                                |
| one CSAR               | If CSMR[WP] is set and a write access is performed, the internal bus cycle terminates with a bus error, no chip select is asserted, and no external bus cycle is performed. |
| No                     | The access is terminated with a bus error response, no chip select is asserted and no Mini-FlexBus cycle is performed.                                                      |
| Yes,<br>multiple CSARs | The access is terminated with a bus error response, no chip select is asserted and no Mini-FlexBus cycle is performed.                                                      |

### 24.4.1.2 8- and 16-Bit Port Sizing

Static bus sizing is programmable through the port size bits, CSCR[PS]. The processor always drives a 20-bit address on the FB AD bus regardless of the external device's address size. The external device must connect its address/data lines as follows:

- Address lines
  - FB AD from FB AD0 upward
- Data lines
  - In multiplexed mode (CSCR[BLS] = 1)
    - If CSCR[PS] = 10 or 11, FB\_AD[15:0]
    - If CSCR[PS] = 01, FB\_AD[7:0]
  - In non-multiplexed mode (CSCR[BLS] = 0), FB\_AD[7:0]

No bit ordering is required when connecting address and data lines to the FB\_AD bus. For example, a full 16-bit address/16-bit data device connects its addr[15:0] to FB\_AD[16:1] and data[15:0] to FB\_AD[15:0]. See Data Byte Alignment and Physical Connections for a graphical connection.

#### **Data Transfer Operation** 24.4.2

Data transfers between the chip and other devices involve these signals:

- Address/data bus (FB\_AD[19:0])
- Control signals (FB\_TS/FB\_ALE, FB\_CSn, FB\_OE)
- Attribute signals (FB\_R/W)

Downloaded from **Elcodis.com** electronic components distributor

The address, write data, FB\_TS/FB\_ALE, FB\_CSn, and all attribute signals change on the rising edge of the Mini-FlexBus clock (FB\_CLK). Read data is latched into the device on the rising edge of the clock.

The Mini-FlexBus supports 8-bit, 16-bit, 32-bit, and 16-byte (line) operand transfers and allows accesses to 8- and 16-bit data ports. Transfer parameters (address setup and hold, port size, the number of wait states for the external device being accessed, automatic internal transfer termination enable or disable) are programmed in the chip-select control registers (CSCRs).

### 24.4.3 Data Byte Alignment and Physical Connections

The device aligns data transfers in Mini-FlexBus byte lanes with the number of lanes depending on the data port width.

The following figure shows the byte lanes that external memory connects to and the sequential transfers of a 32-bit transfer for the supported port sizes when byte lane shift is disabled. For example, an 8-bit memory connects to the single lane FB\_AD[7:0]. A 32-bit transfer through this 8-bit port takes four transfers, starting with the MSB to the LSB.

#### **Non-multiplexed Mode**



Figure 24-10. Connections for External Memory Port Sizes (Non-Multiplexed Mode)

#### **Multiplexed Mode**



Figure 24-11. Connections for External Memory Port Sizes (Multiplexed Mode)

The following figure shows the byte lanes that external memory connects to and the sequential transfers of a 32-bit transfer for the supported port sizes when byte lane shift is enabled.



Figure 24-12. Connections for External Memory Port Sizes (CSCRn[BLS] = 1)

# 24.4.4 Address/Data Bus Multiplexing

The interface supports a single 20-bit wide multiplexed address and data bus (FB\_AD[19:0]). The full 20-bit address is always driven on the first clock of a bus cycle. During the data phase, the FB\_AD[19:0] lines used for data are determined by the programmed port size for the corresponding chip select. The device continues to drive the address on any FB\_AD[19:0] lines not used for data.

The table below lists the supported combinations of address and data bus widths.

FB AD **Port Size & Phase** [19:16] [15:8] [7:0] Address phase Address 16-bit Data phase Address Data Address phase Address 8-bit Data phase Address Data

Table 24-13. Mini-FlexBus Multiplexed Operating Modes

### 24.4.5 Bus Cycle Execution

As shown in Figure 24-15 and Figure 24-17, basic bus operations occur in four clocks:

- 1. S0: At the first clock edge, the address, attributes, and FB\_TS/FB\_ALE are driven.
- 2. S1: FB\_CSn is asserted at the second rising clock edge to indicate the device selected; by that time, the address and attributes are valid and stable. FB\_TS/FB\_ALE is negated at this edge.

For a write transfer, data is driven on the bus at this clock edge and continues to be driven until one clock cycle after  $\overline{FB\_CSn}$  negates. For a read transfer, data is also driven into the device during this cycle.

- 3. S2: Read data is sampled on the third clock edge. After this edge read data can be tristated.
- 4. S3: FB\_CSn is negated at the fourth rising clock edge. This last clock of the bus cycle uses what would be an idle clock between cycles to provide hold time for address, attributes, and write data.

### 24.4.5.1 Data Transfer Cycle States

An on-chip state machine controls the data-transfer operation in the device. The following figure shows the state-transition diagram for basic read and write cycles.



Figure 24-13. Data-Transfer-State-Transition Diagram

The following table describes the states as they appear in subsequent timing diagrams.

Table 24-14. Bus Cycle States

| State | Cycle | Description                                                                                                                                                                                                                            |
|-------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| S0    | All   | The read or write cycle is initiated. On the rising clock edge, the device places a valid address on FB_AD $n$ , asserts $\overline{\text{FB}}$ TS/FB_ALE, and drives FB_R/ $\overline{\text{W}}$ high for a read and low for a write. |

Table continues on the next page...

Table 24-14. Bus Cycle States (continued)

| State | Cycle | Description                                                                                                                                                                                                                              |
|-------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| S1    | All   | FB_TS/FB_ALE is negated on the rising edge of FB_CLK, and FB_CSn is asserted. Data is driven on FB_AD[X:0] for writes, and FB_AD[X:0] is tristated for reads. Address continues to be driven on the FB_AD pins that are unused for data. |
|       | Read  | Data is driven by the external device before the next rising edge of FB_CLK (the rising edge that begins S2).                                                                                                                            |
| S2    | All   | FB_CSn is negated and the internal system bus transfer is completed.                                                                                                                                                                     |
|       | Read  | The processor latches data on the rising clock edge entering S2. The external device can stop driving data after this edge. However, data can be driven until the end of S3 or any additional address hold cycles.                       |
| S3    | All   | Address, data, and FB_R/W go invalid off the rising edge of FB_CLK at the beginning of S3, terminating the read or write cycle.                                                                                                          |

# 24.4.6 Mini-FlexBus Timing Examples

#### **Note**

The timing diagrams throughout this section use signal names that may not be included on your particular device. Ignore these extraneous signals.

Also, ignore the AA=0 portions of the diagrams, since this setting is not supported in the Mini-FlexBus.

#### **Note**

Throughout this section:

- FB\_D[X] indicates a 16-, or 8-bit wide data bus
- FB\_A[Y] indicates an address bus that can be 20 bits wide.

### 24.4.6.1 Basic Read Bus Cycle

During a read cycle, the MCU receives data from memory or a peripheral device. The following figure shows a read cycle flowchart.

558



Figure 24-14. Read Cycle Flowchart

The read cycle timing diagram is shown in the following figure.

#### **Note**

The processor drives the data lines during the first clock cycle of the transfer with the full 20-bit address. This may be ignored by standard connected devices using non-multiplexed address and data buses. However, some applications may find this feature beneficial.



Figure 24-15. Basic Read-Bus Cycle

# 24.4.6.2 Basic Write Bus Cycle

During a write cycle, the device sends data to memory or to a peripheral device. The following figure shows the write cycle flowchart.

#### Chapter 24 External Bus Interface (Mini-FlexBus)



Figure 24-16. Write-Cycle Flowchart

The following figure shows the write cycle timing diagram.



Figure 24-17. Basic Write-Bus Cycle

### 24.4.6.3 Bus Cycle Sizing

This section shows timing diagrams for various port size scenarios.

### 24.4.6.3.1 Bus Cycle Sizing—Byte Transfer, 8-bit Device, No Wait States

The following figure illustrates the basic byte read transfer to an 8-bit device with no wait states:

- The address is driven on the full FB\_AD[19:8] bus in the first clock.
- The device tristates FB\_AD[7:0] on the second clock and continues to drive address on FB\_AD[19:8] throughout the bus cycle.
- The external device returns the read data on FB\_AD[7:0].



Figure 24-18. Single Byte-Read Transfer

The following figure shows the similar configuration for a write transfer. The data is driven from the second clock on FB\_AD[7:0].



Figure 24-19. Single Byte-Write Transfer

### 24.4.6.3.2 Bus Cycle Sizing—Word Transfer, 16-bit Device, No Wait States

The following figure illustrates the basic word read transfer to a 16-bit device with no wait states.

- The address is driven on the full FB\_AD[19:8] bus in the first clock.
- The device tristates FB\_AD[15:0] on the second clock and continues to drive address on FB\_AD[19:16] throughout the bus cycle.
- The external device returns the read data on FB\_AD[15:0].

#### **Note**

In non-multiplexed mode, the Mini-FlexBus does not support connection to a 16-bit device.



Figure 24-20. Single Word-Read Transfer

The following figure shows the similar configuration for a write transfer. The data is driven from the second clock on FB\_AD[15:0].

#### **Note**

In non-multiplexed mode, the Mini-FlexBus does not support connection to a 16-bit device.



Figure 24-21. Single Word-Write Transfer

# 24.4.6.4 Timing Variations

The Mini-FlexBus module has several features that can change the timing characteristics of a basic read- or write-bus cycle to provide additional address setup, address hold, and time for a device to provide or latch data.

#### 24.4.6.4.1 Wait States

Wait states can be inserted before each beat of a transfer by programming the CSCR*n* registers. Wait states can give the peripheral or memory more time to return read data or sample write data.

The following figures show the basic read and write bus cycles (also shown in Figure 24-15 and Figure 24-20) with the default of no wait states respectively.



Figure 24-22. Basic Read-Bus Cycle (No Wait States)



Figure 24-23. Basic Write-Bus Cycle (No Wait States)

If wait states are used, the S1 state repeats continuously until the the chip-select auto-acknowledge unit asserts internal transfer acknowledge. The following figures show a read and write cycle with one wait state respectively.



Figure 24-24. Read-Bus Cycle (One Wait State)



Figure 24-25. Write-Bus Cycle (One Wait State)

### 24.4.6.4.2 Address Setup and Hold

The timing of the assertion and negation of the chip selects, byte selects, and output enable can be programmed on a chip-select basis. Each chip-select can be programmed to assert one to four clocks after transfer start/address-latch enable (FB\_TS/FB\_ALE) is asserted. The following figures show read- and write-bus cycles with two clocks of address setup respectively.



Figure 24-26. Read-Bus Cycle with Two-Clock Address Setup (No Wait States)



Figure 24-27. Write-Bus Cycle with Two Clock Address Setup (No Wait States)

In addition to address setup, a programmable address hold option for each chip select exists. Address and attributes can be held one to four clocks after chip-select, byte-selects, and output-enable negate. The following figures show read and write bus cycles with two clocks of address hold respectively.



Figure 24-28. Read Cycle with Two-Clock Address Hold (No Wait States)



Figure 24-29. Write Cycle with Two-Clock Address Hold (No Wait States)

The following figure shows a bus cycle using address setup, wait states, and address hold.



Figure 24-30. Write Cycle with Two-Clock Address Setup and Two-Clock Hold (One Wait State)

### 24.4.7 Extended Transfer Start/Address Latch Enable

The  $\overline{FB}$ \_TS/FB\_ALE signal indicates that a bus transaction has begun and the address and attributes are valid. By default, the  $\overline{FB}$ \_TS/FB\_ALE signal asserts for a single bus clock cycle. When CSCRn[EXTS] is set, the  $\overline{FB}$ \_TS/FB\_ALE signal asserts and remain asserted until the first positive clock edge after FB\_CSn asserts. See the following figure.

#### **NOTE**

When EXTS is set, CSCRn[WS] must be programmed to have at least one primary wait state.



Figure 24-31. Read-Bus Cycle with CSCRn[EXTS] = 1 (One Wait State)

### 24.4.8 Bus Errors

There are certain accesses to the Mini-FlexBus that cause the system bus to hang. It is important to have a good access-error handler to manage these conditions.

The types of accesses that cause the access to terminate with a bus error are:

- CSCRn[AA] is cleared.
- The clock to the Mini-Flexbus module is disabled. Mini-FlexBus accesses cause an error termination on the bus and prohibit the access to the Mini-FlexBus.
- Attempted writes to space defined as write protected (CSMRn[WP] is set) are terminated with an error response and the access is inhibited to the Mini-FlexBus.
- Mini-FlexBus access not hitting in either chip select region is terminated with an error response and the access is inhibited to the Mini-FlexBus.
- Mini-FlexBus access hitting in both chip select regions is terminated with an error response and the access is inhibited to the Mini-FlexBus.

# 24.5 Initialization/Application Information

# 24.5.1 Initializing a Chip Select

To initially use a chip select:

- 1. Configure the CSAR register.
- 2. Configure the CSCR register.
- 3. Configure the CSMR register, setting the valid bit.

# 24.5.2 Reconfiguring a Chip Select

To reconfigure a previously-used chip select, the chip select must be specified as invalid as shown below:

- 1. Clear the CSMR register's valid bit.
- 2. Change settings in the CSAR register as necessary.
- 3. Change settings in the CSCR register as necessary.
- 4. Change settings in the CSMR register as necessary, and set the valid bit.

# Chapter 25 EzPort

### 25.1 Overview

EzPort is a serial flash programming interface that allows In-System Programming (ISP) of flash memory contents on a 32 bit general purpose micro-controller. Memory contents can be read, erased and programmed from off-chip in a compatible format to many standalone flash memory chips, without necessitating the removal of the micro-controller from the system.

### 25.1.1 Introduction

The block diagram of the EzPort is as following.

Overview



Figure 25-1. EzPort Block Diagram

### **25.1.2 Features**

The EzPort includes the following features:

- Serial interface that is compatible with a subset of the SPI format.
- Able to read, erase and program flash memory.
- Able to reset the micro-controller, allowing it to boot from the flash memory after the memory has been configured.

# 25.1.3 Modes of Operation

The EzPort can operate in one of two different modes, enabled or disabled.

- Enabled When enabled, the EzPort steals access to the flash memory, preventing access from other cores or peripherals. The rest of the microcontroller is disabled to avoid conflicts. The flash is configured for NVM Special Mode.
- Disabled When the EzPort is disabled, the rest of the micro-controller can access flash memory as normal.

The EzPort provides a simple interface to connect an external device to the flash memory on board a 32 bit micro-controller. The interface itself is compatible with the SPI interface (with the EzPort operating as a slave) running in either of the two following modes with data transmitted most significant bit first:

- CPOL = 0, CPHA = 0
- CPOL = 1, CPHA = 1

Commands are issued by the external device to erase, program or read the contents of the flash memory. The serial data out from the EzPort is tri-stated unless data is being driven, allowing the signal to be shared among several different EzPort (or compatible) devices in parallel, provided they have different chip selects.

# 25.2 External Signal Description

The following table contains a list of EzPort external signals, and the following sections explain them in detail.

 Name
 Description
 I/O

 EZP\_CK
 EzPort Clock
 Input

 EZP\_CS
 EzPort Chip Select
 Input

 EZP\_D
 EzPort Serial Data In
 Input

 EZP\_Q
 EzPort Serial Data Out
 Output

Table 25-1. EzPort External Signal Descriptions

# 25.2.1 EzPort Clock (EZP\_CK)

Serial clock for data transfers. The serial data in (EZP\_D) and chip select (EZP\_CS) are registered on the rising edge of EZP\_CK while serial data out (EZP\_Q) is driven on the falling edge of EZP\_CK.

The maximum frequency of the EzPort clock is half the system clock frequency for all commands except when executing the Read Data or Read FlexRAM commands. When executing these commands, the EzPort clock has a maximum frequency of one-eighth the system clock frequency.

# 25.2.2 EzPort Chip Select (EZP\_CS)

Chip select for signalling the start and end of serial transfers. If  $\overline{EZP\_CS}$  is asserted during and when the micro-controller's reset out signal is negated, then EzPort is enabled out of reset; otherwise it is disabled. After EzPort is enabled, asserting  $\overline{EZP\_CS}$  commences a serial data transfer, which continues until  $\overline{EZP\_CS}$  is negated again. The negation of  $\overline{EZP\_CS}$  indicates the current command is finished and resets the EzPort state machine so that it is ready to receive the next command.

## 25.2.3 EzPort Serial Data In (EZP\_D)

Serial data in for data transfers. EZP\_D is registered on the rising edge of EZP\_CK. All commands, addresses, and data are shifted in most significant bit first. When the EzPort is driving output data on EZP\_Q, the data shifted in EZP\_D is ignored.

## 25.2.4 EzPort Serial Data Out (EZP\_Q)

Serial data out for data transfers. EZP\_Q is driven on the falling edge of EZP\_CK. It is tri-stated unless EZP\_CS is asserted and the EzPort is driving data out. All data is shifted out most significant bit first.

### 25.3 Command Definition

The EzPort receives commands from an external device and translates those commands into flash memory accesses. The following table lists the supported commands.

**Address** Accepted when Command **Description** Code **Data Bytes Bytes** secure? **WREN** 0 0 Write Enable 0x06 Yes **WRDI** Write Disable 0x04 0 Yes **RDSR** 0 1 Yes Read Status Register 0x05 **READ** 31 Flash Read Data 0x03 1+ Nο 1+2 FAST\_READ Flash Read Data at High Speed 0x0B 31 No SP 33 4 - SECTION4 Flash Section Program 0x02 No SE Flash Sector Erase 0xD8 33 0 No Yes<sup>5</sup> BE Flash Bulk Erase 0xC7 0 0

Table 25-2. EzPort Commands

Table continues on the next page...

Table 25-2. EzPort Commands (continued)

| Command        | Description                        | Code | Address<br>Bytes | Data Bytes          | Accepted when secure? |
|----------------|------------------------------------|------|------------------|---------------------|-----------------------|
| RESET          | Reset Chip                         | 0xB9 | 0                | 0                   | Yes                   |
| WRFCCOB        | Write FCCOB Registers              | 0xBA | 0                | 12                  | Yes <sup>6</sup>      |
| FAST_RDFCCOB   | Read FCCOB registers at high speed | 0xBB | 0                | 1 - 12 <sup>2</sup> | No                    |
| WRFLEXRAM      | Write FlexRAM                      | 0xBC | 3 <sup>1</sup>   | 4                   | No                    |
| RDFLEXRAM      | Read FlexRAM                       | 0xBD | 3 <sup>1</sup>   | 1+                  | No                    |
| FAST_RDFLEXRAM | Read FlexRAM at high speed         | 0xBE | 3 <sup>1</sup>   | 1+ <sup>2</sup>     | No                    |

- 1. Address must be 32-bit aligned (two LSBs must be zero).
- 2. One byte of dummy data must be shifted in before valid data is shifted out.
- 3. Address must be 32-bit aligned (two LSBs must be zero).
- 4. A section is defined as the smaller of either half the size of FlexRAM or the flash sector size. Total number of data bytes programmed must be a multiple of 4.
- 5. Bulk Erase is accepted when security is set only if the BEDIS status bit is not set.
- 6. Note that the Flash will be in NVM Special mode, restricting which types of commands can be executed through WRITE\_FCCOB when security is enabled.

### 25.3.1 Command Descriptions

This section describes the module commands.

#### **25.3.1.1 Write Enable**

The Write Enable command (WREN) sets the write enable register bit in the EzPort status register. The write enable bit must be set for a write command (SP, SE, BE, WRFCCOB or WRFLEXRAM) to be accepted. The write enable register bit clears on reset, on a Write Disable command, and at the completion of write command. This command should not be used if a write is already in progress.

#### 25.3.1.2 Write Disable

The Write Disable command (WRDI) clears the write enable register bit in the status register. This command should not be used if a write is already in progress.

### 25.3.1.3 Read Status Register

The Read Status Register command (RDSR) returns the contents of the EzPort status register.

#### **Command Definition**

### Table 25-3. EzPort Status Register

|        | 7    | 6   | 5 | 4 | 3       | 2                | 1   | 0   |
|--------|------|-----|---|---|---------|------------------|-----|-----|
| R      | FS   | WEF |   |   | FLEXRAM | BEDIS            | WEN | WIP |
| W      |      |     |   |   |         |                  |     |     |
| Reset: | 0/11 | 0   | 0 | 0 | 0/12    | 0/1 <sup>3</sup> | 0   | 14  |

- 1. Reset value reflects the status of flash security out of reset.
- Reset value reflects FlexNVM flash partitioning. If FlexNVM flash has been paritioned for EEPROM, this bit is set immediately after reset. Note that FLEXRAM is cleared after the EzPort initialization sequence completes, as indicated by clearing of WIP.
- 3. Reset value reflects if bulk erase is enabled or disabled out of reset
- 4. Initial value of WIP is 1, but the value clears to 0 after EzPort initialization is complete

Table 25-4. EzPort Status Register Field Descriptions

| Field   | Description                                                                                                                                                                                                                                                                                                                                                                                                                          |
|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0       | Write in progress.                                                                                                                                                                                                                                                                                                                                                                                                                   |
| WIP     | Status flag that sets after a write command (SP, SE, BE, WRFCCOB, or WRFLEXRAM) is accepted and clears once the flash memory has completed all operations associated with that command as indicated by the Command Complete Interrupt Flag (CCIF) inside the Flash. Also asserted on reset and clears when EzPort initialization is complete. Only the Read Status Register (RDSR) command is accepted while a write is in progress. |
|         | 0 = Write is not in progress. Accept any command.                                                                                                                                                                                                                                                                                                                                                                                    |
|         | 1 = Write is in progress. Only accept RDSR command.                                                                                                                                                                                                                                                                                                                                                                                  |
| 1       | Write enable                                                                                                                                                                                                                                                                                                                                                                                                                         |
| WEN     | Control bit that must be set before a write command (SP, SE, BE, WRFCCOB, or WRFLEXRAM) is accepted. Is set by the Write Enable (WREN) command and cleared by reset or a Write Disable (WRDI) command. It also clears when the flash memory has completed all operations associated with the command.                                                                                                                                |
|         | 0 = Disables the following write command.                                                                                                                                                                                                                                                                                                                                                                                            |
|         | 1 = Enables the following write command.                                                                                                                                                                                                                                                                                                                                                                                             |
| 2       | Bulk erase disable                                                                                                                                                                                                                                                                                                                                                                                                                   |
| BEDIS   | Status flag which indicates if bulk erase (BE) is disabled when Flash is secure.                                                                                                                                                                                                                                                                                                                                                     |
|         | 0 = Bulk Erase is enabled.                                                                                                                                                                                                                                                                                                                                                                                                           |
|         | 1 = Bulk Erase is disabled if the FS bit is also set. Attempts to issue a BE command will result in the WEF flag being set.                                                                                                                                                                                                                                                                                                          |
| 3       | FlexRAM mode                                                                                                                                                                                                                                                                                                                                                                                                                         |
| FLEXRAM | Status flag that indicates the current mode of the FlexRAM. Only valid when the WIP bit is cleared.                                                                                                                                                                                                                                                                                                                                  |
|         | 0 = FlexRAM is in RAM mode. RD/WRFLEXRAM command can be used to read/write data in FlexRAM.                                                                                                                                                                                                                                                                                                                                          |
|         | 1 = FlexRAM is in EEPROM mode. SP command is not accepted. RD/WRFLEXRAM command can be used to read/write data in the FlexRAM.                                                                                                                                                                                                                                                                                                       |

Table continues on the next page...

Table 25-4. EzPort Status Register Field Descriptions (continued)

| Field | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6     | Write error flag                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| WEF   | Status flag that indicates if there has been an error while executing a write command (SP, SE, BE, WRFCCOB, or WRFLEXRAM). The WEF flag will set if either the Flash Access Error Flag (ACCERR) or the Flash Protection Violation Flag (FPVIOL) or the Memory Controller Command Completion Status Flag (MGSTAT0) inside the flash memory is set at the completion of the write command. See the flash memory chapter for further description of these flags and their sources. The WEF flag clears after a Read Status Register (RDSR) command.  0 = No error on previous write command. |
| 7     | Flash security                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| FS    | Status flag that indicates if the flash is secure. See Table 25-2 for the list of commands which will be accepted when flash is secure. Flash security can be disabled by performing a Bulk Erase (BE) command.                                                                                                                                                                                                                                                                                                                                                                           |
|       | 0 = Flash is not secure                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|       | 1 = Flash is secure.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

### 25.3.1.4 Read Data

The Read Data (READ) command returns data from the flash memory or FlexNVM, depending on the initial address specified in the command word. The initial address must be 32-bit aligned (the two LSBs must be zero).

Data continues being returned for as long as the EzPort chip select (EZP\_CS) is asserted, with the address automatically incrementing. In this way, the entire contents of flash can be returned by one command. Attempts to read from an address which does not fall within the valid address range (see Flash Memory Map for EzPort Access) for the flash memory regions returns junk data.

For this command to return the correct data, the EzPort clock (EZP\_CK) must run at the internal system clock divided by eight or slower. This command is not accepted if the WEF, WIP, or FS bit in the EzPort status register is set.

### 25.3.1.5 Read Data at High Speed

The Read Data at High Speed command (FAST\_READ) is identical to the READ command, except for the inclusion of a dummy byte following the address bytes and before the first data byte is returned.

This command can be run with an EzPort clock (EZP\_CK) frequency of half the internal system clock frequency of the micro-controller or slower. This command is not accepted if the WEF, WIP, or FS bit in the EzPort status register is set.

### 25.3.1.6 Section Program

The Section Program (SP) command programs up to one section of flash memory which has previously been erased. A section is defined as the smaller of the flash sector size or half the size of the FlexRAM. The starting address of the memory to program is sent after the command word and must be a 32-bit aligned address (the two LSBs must be zero).

As data is shifted in, the EzPort buffers the data in FlexRAM before executing a 'Program Section' command within the flash (see Flash Block Guide for more detail). For this reason, the number of bytes to program must be a multiple of 4 and up to one flash section can be programmed at a time.

Attempts to program more than one section, across a sector boundary or from an initial address which does not fall within the valid address range (see Flash Memory Map for EzPort Access) for the flash causes the WEF flag to set.

This command requires the FlexRAM to be configured for traditional RAM operation. By default, after entering EzPort mode, the FlexRAM is configured for traditional RAM operation. If the user reconfigures FlexRAM for EEPROM operation (see Flash Memory chapter for details on how FlexRAM function is modified), then the user should use the WRFCCOB command to configure FlexRAM back to traditional RAM operation before issuing a SP command.

This command is not accepted if the WEF, WIP, FLEXRAM, or FS bit is set or if the WEN bit is not set in the EzPort status register.

### 25.3.1.7 Sector Erase

The Sector Erase (SE) command erases the contents of one sector of flash memory. The three byte address sent after the command byte can be any address within the sector to erase, but must be a 32-bit aligned address (the two LSBs must be zero). Attempts to erase from an initial address which does not fall within the valid address range (see Flash Memory Map for EzPort Access) for the flash results in the WEF flag being set.

This command is not accepted if the WEF, WIP or FS bit is set or if the WEN bit is not set in the EzPort status register.

#### 25.3.1.8 Bulk Erase

The Bulk Erase (BE) command erases the entire contents of flash memory, ignoring any protected sectors or flash security. Flash security is disabled upon successful completion of the BE command.

Attempts to issue a BE command while the BEDIS and FS bits are set results in the WEF flag being set in the EzPort status register. Also, this command is not accepted if the WEF or WIP bit is set or if the WEN bit is not set in the EzPort status register.

### 25.3.1.9 EzPort Reset Chip

The Reset Chip (RESET) command forces the chip into the reset state. If the EzPort chip select (EZP\_CS) pin is asserted at the end of the reset period then EzPort is enabled; otherwise, it is disabled. This command allows the chip to boot up from flash memory after it has been programmed by an external source.

This command is not accepted if the WIP bit is set in the EzPort status register.

### 25.3.1.10 Write FCCOB Registers

The Write FCCOB Registers (WRFCCOB) command allows the user to write to the flash common command object registers and execute any command allowed by the flash.

#### NOTE

The flash is configured in NVM special mode, restricting which commands can be executed by the flash when security is enabled.

After receiving 12 bytes of data, EzPort writes the data to the FCCOB 0-B registers in the flash and then automatically launches the command within the flash. If greater or less than 12 bytes of data is received, this command has unexpected results and may result in the WEF flag being set.

This command is not accepted if the WEF or WIP bit is set or if the WEN bit is not set in the EzPort status register.

### 25.3.1.11 Read FCCOB Registers at High Speed

The Read FCCOB Registers at High Speed (FAST\_RDFCCOB) command allows the user to read the contents of the flash common command object registers. After receiving the command, EzPort waits for one dummy byte of data before returning FCCOB register data starting at FCCOB 0 and ending with FCCOB B.

This command can be run with an EzPort clock (EZP\_CK) frequency half the internal system clock frequency of the micro-controller or slower. Attempts to read greater than 12 bytes of data returns junk data. This command is not be accepted if the WEF, WIP, or FS bit in the EzPort status register is set.

#### 25.3.1.12 Write FlexRAM

The Write FlexRAM (WRFLEXRAM) command allows the user to write 4-bytes of data to the FlexRAM. If the FlexRAM is configured for EEPROM operation, the WRFLEXRAM command can effectively be used to create data records in EEPROM-flash memory.

By default, after entering EzPort mode, the FlexRAM is configured for traditional RAM operation and functions as direct RAM. The user can alter the FlexRAM configuration by using WRFCCOB to execute a 'Set FlexRAM' or 'Program Partition' command within the Flash.

The address of the FlexRAM location to be written is sent after the command word and must be a 32-bit aligned address (the two LSBs must be zero). Attempts to write an address which does not fall within the valid address range (see Flash Memory Map for EzPort Access) for the FlexRAM results in the WEF flag being set.

After receiving 4 bytes of data, EzPort writes the data to the FlexRAM. If greater or less than 4 bytes of data is received, this command has unexpected results and may result in the WEF flag being set.

This command is not accepted if the WEF, WIP or FS bit is set or if the WEN bit is not set in the EzPort status register.

#### 25.3.1.13 Read FlexRAM

The Read FlexRAM (RDFLEXRAM) command returns data from the FlexRAM. If the FlexRAM is configured for EEPROM operation, the RDFLEXRAM command can effectively be used to read data from EEPROM-flash memory.

Data continues being returned for as long as the EzPort chip select (EZP\_CS) is asserted, with the address automatically incrementing. In this way, the entire contents of FlexRAM can be returned by one command.

The initial address must be 32-bit aligned (the two LSBs must be zero). Attempts to read from an address which does not fall within the valid address range (see Flash Memory Map for EzPort Access) for the FlexRAM returns junk data.

For this command to return the correct data, the EzPort clock (EZP\_CK) must run at the internal system clock divided by eight or slower. This command is not accepted if the WEF, WIP, or FS bit in the EzPort status register are set.

### 25.3.1.14 Read FlexRAM at High Speed

The Read FlexRAM at High Speed (FAST\_RDFLEXRAM) is identical to the RDFLEXRAM command, except for the inclusion of a dummy byte following the address bytes and before the first data byte is returned.

This command can be run with an EzPort clock (EZP\_CK) frequency up to and including half the internal system clock frequency of the micro-controller. This command is not accepted if the WEF, WIP, or FS bit in the EzPort status register is set.

# 25.4 Flash Memory Map for EzPort Access

The following table shows the flash memory map for access through EzPort.

#### NOTE

The flash block address map for access through EzPort may not conform to the system memory map. Changes are made to allow the EzPort address width to remain at 24-bits.

| Valid Start Address | Size Flash block Valid Commands            |         | Valid Commands                              |
|---------------------|--------------------------------------------|---------|---------------------------------------------|
| 0x0000_0000         | See device's Chip<br>Configuration details | Flash   | READ, FAST_READ, SP, SE, BE                 |
| 0x0080_0000         | See device's Chip<br>Configuration details | FlexNVM | READ, FAST_READ, SP, SE, BE                 |
| 0x0000_0000         | See device's Chip<br>Configuration details | FlexRAM | RDFLEXRAM, FAST_RDFLEXRAM,<br>WRFLEXRAM, BE |



# **Chapter 26 Cryptographic Acceleration Unit (CAU)**

### 26.1 Introduction

The cryptographic acceleration unit (CAU) is a ColdFire coprocessor implementing a set of specialized operations in hardware to increase the throughput of software-based encryption and hashing functions.

# 26.2 Block Diagram

This simplified block diagram illustrates the CAU.



Figure 26-1. Top Level CAU Block Diagram

### 26.3 Overview

The set of implemented algorithms provides excellent support for network security standards (SSL, IPsec). Additionally, using the CAU efficiently permits the implementation of any higher level functions or modes of operation (HMAC, CBC, etc.) based on the supported algorithms.

The cryptographic algorithms are implemented partially in software with only functions critical to increasing performance implemented in hardware. The CAU allows for efficient, fine-grained partitioning of functions between hardware and software:

- Implement the innermost security kernel functions using the coprocessor instructions
- Implement higher-level functions in software by using the standard processor instructions

This partitioning of functions is key to minimizing size of the CAU while maintaining a high level of throughput. Using software for some functions also simplifies the CAU design. The CAU implements a set of coprocessor commands that operate on a register file of 32-bit registers. It is tightly coupled to the ColdFire core and there is no local memory or external interface.

### 26.4 Features

The CAU includes these distinctive features:

- Supports DES, 3DES, AES, MD5, SHA-1, and SHA-256 algorithms
- Simple, flexible programming model

## 26.5 Register Definition

The CAU contains multiple registers used by each of the supported algorithms. The following table shows which registers are applicable to each supported algorithm, and indicates the corresponding letter designations for each algorithm. For more information on these letter designations, refer to the algorithm specifications.

| Code | Register                               | DES | AES | MD5 | SHA-1 | SHA-256          |
|------|----------------------------------------|-----|-----|-----|-------|------------------|
| 0    | CAU status register (CASR)             | _   | _   | _   | _     | _                |
| 1    | CAU<br>accumulator<br>(CAA)            | _   | _   | а   | Т     | Т                |
| 2    | General<br>purpose register<br>0 (CA0) | С   | W0  | _   | A     | A                |
| 3    | General<br>purpose register<br>1 (CA1) | D   | W1  | b   | В     | В                |
| 4    | General<br>purpose register<br>2 (CA2) | L   | W2  | С   | С     | С                |
| 5    | General<br>purpose register<br>3 (CA3) | R   | W3  | d   | D     | D                |
| 6    | General purpose register 4 (CA4)       | _   | _   | _   | E     | E                |
| 7    | General<br>purpose register<br>5 (CA5) | _   | _   | _   | W     | F                |
| 8    | General<br>purpose register<br>6 (CA6) | _   | _   | _   | _     | G                |
| 9    | General<br>purpose register<br>7 (CA7) | _   | _   | _   | _     | Н                |
| 10   | General<br>purpose register<br>8 (CA8) | _   | _   | _   | _     | W/T <sub>1</sub> |

The CAU only supports 32-bit operations and register accesses. All registers support read, write, and ALU operations. However, only bits 1–0 of the CASR are writeable. Bits 31–2 of the CASR must be written as 0 for compatibility with future versions of the CAU.

#### NOTE

In the following table, the "address" or "offset" refers to the command code value for the CAU registers.

### **CAU** memory map

| Address offset (hex) | Absolute<br>address<br>(hex) | Register name                      | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|----------------------|------------------------------|------------------------------------|--------------------|--------|-------------|------------------|
| 0                    | 0000_0000                    | Status Register (CAU_CASR)         | 32                 | R/W    | 2000_0000h  | 26.5.1/<br>592   |
| 1                    | 0000_0001                    | Accumulator (CAU_CAA)              | 32                 | R/W    | 0000_0000h  | 26.5.2/<br>593   |
| 2                    | 0000_0002                    | General Purpose Register (CAU_CA0) | 32                 | R/W    | 0000_0000h  | 26.5.3/<br>594   |
| 3                    | 0000_0003                    | General Purpose Register (CAU_CA1) | 32                 | R/W    | 0000_0000h  | 26.5.3/<br>594   |
| 4                    | 0000_0004                    | General Purpose Register (CAU_CA2) | 32                 | R/W    | 0000_0000h  | 26.5.3/<br>594   |
| 5                    | 0000_0005                    | General Purpose Register (CAU_CA3) | 32                 | R/W    | 0000_0000h  | 26.5.3/<br>594   |
| 6                    | 0000_0006                    | General Purpose Register (CAU_CA4) | 32                 | R/W    | 0000_0000h  | 26.5.3/<br>594   |
| 7                    | 0000_0007                    | General Purpose Register (CAU_CA5) | 32                 | R/W    | 0000_0000h  | 26.5.3/<br>594   |
| 8                    | 0000_0008                    | General Purpose Register (CAU_CA6) | 32                 | R/W    | 0000_0000h  | 26.5.3/<br>594   |
| 9                    | 0000_0009                    | General Purpose Register (CAU_CA7) | 32                 | R/W    | 0000_0000h  | 26.5.3/<br>594   |
| Α                    | 0000_000A                    | General Purpose Register (CAU_CA8) | 32                 | R/W    | 0000_0000h  | 26.5.3/<br>594   |

# 26.5.1 Status Register (CAU\_CASR)

CASR contains the status and configuration for the CAU.

Address: CAU\_CASR is 0h base + 0h offset = 0000\_0000h



### **CAU\_CASR** field descriptions

| Field        | Description            |
|--------------|------------------------|
| 31–28<br>VER | CAU version            |
|              | Indicates CAU version. |

Table continues on the next page...

### **CAU\_CASR** field descriptions (continued)

| Field            | Description                                                                                   |
|------------------|-----------------------------------------------------------------------------------------------|
|                  | 0x1 Initial CAU version.                                                                      |
|                  | 0x2 Second version, added support for SHA-256 algorithm.(This is the value on this device)    |
| 27–2<br>Reserved | This read-only bitfield is reserved and always has the value zero. Reserved, must be cleared. |
| 1<br>DPE         | DES parity error                                                                              |
| J. 2             | Indicates whether the DES parity error is detected.                                           |
|                  | 0 No error detected.                                                                          |
|                  | 1 DES key parity error detected.                                                              |
| 0                | Illegal command                                                                               |
| IC IC            | Indicates an illegal instruction has been executed.                                           |
|                  | 0 No illegal commands issued.                                                                 |
|                  | 1 Illegal command issued.                                                                     |

### 26.5.2 Accumulator (CAU\_CAA)

Commands use the CAU accumulator for storage of results and as an operand for the cryptographic algorithms.

Address: CAU\_CAA is 0h base + 1h offset = 0000\_0001h



### **CAU\_CAA** field descriptions

| Field       | Description                             |
|-------------|-----------------------------------------|
| 31–0<br>ACC | Accumulator                             |
|             | Stores results of various CAU commands. |

### 26.5.3 General Purpose Register (CAU\_CAn)

The general purpose register is used in the CAU commands for storage of results and as operands for the various cryptographic algorithms.

```
Addresses: CAU_CA0 is 0h base + 2h offset = 0000_0002h
          CAU_CA1 is 0h base + 3h offset = 0000_0003h
          CAU_CA2 is 0h base + 4h offset = 0000_0004h
          CAU_CA3 is 0h base + 5h offset = 0000_0005h
          CAU_CA4 is 0h base + 6h offset = 0000_0006h
          CAU_CA5 is 0h base + 7h offset = 0000_0007h
          CAU_CA6 is 0h base + 8h offset = 0000_0008h
          CAU_CA7 is 0h base + 9h offset = 0000_0009h
          CAU_CA8 is 0h base + Ah offset = 0000_000Ah
 Bit
      30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7
 R
                                                     CAn
 W
                                           0 0 0 0 0 0
Reset 0
          0
              0
                 0 0 0 0 0
                                 0
                                     0
                                        0
                                                              0 0 0 0
                                                                           0 0 0
                                                                                     0
```

### CAU\_CAn field descriptions

| Field       | Description                                                                           |
|-------------|---------------------------------------------------------------------------------------|
| 31–0<br>CAn | General purpose registers                                                             |
| _           | Used by the CAU commands. Some cryptographic operations work with specific registers. |

# 26.6 Functional Description

This section discusses the programming model and operation of the CAU.

### 26.6.1 Programming Model

The CAU is an instruction-level coprocessor. It has a dedicated register file, a specialized ALU, and specialized units for performing cryptographic operations. The CAU design uses a simple, flexible accumulator-based architecture. Most commands, including load and store, can specify any register in the register file. Some cryptographic operations work with specific registers.

### 26.6.2 Coprocessor Instructions

Operation of the CAU is controlled via standard ColdFire coprocessor load (cp0ld) and store (cp0st) instructions. The CAU has a dedicated register file accessed using these instructions. The load instruction loads CAU registers and specifies CAU operations. The store instruction stores CAU registers. The example assembler syntax for the CAU is:

The <ea> field specifies the source operand (operand1) for load instructions and destination (result) for store instructions. The basic ColdFire addressing modes {Rn, (An), -(An), (An)+, (d16,An)} are supported for this field. The <CMD> field is a 9-bit value that specifies the CAU command for an instruction. The CAU Commands table shows how the CAU supports a single command (STR) for store instructions and 21 commands for the load instructions. The CAU only supports longword operations. A CAU command can be issued every clock cycle.

### 26.6.3 CAU Commands

The CAU supports the commands shown in the following table. All other encodings are reserved. The CASR[IC] bit is set if an undefined command is issued. A specific illegal command (ILL) is defined to allow software self-checking. Reserved commands should not be issued to ensure compatibility with future implementations.

The CMD field specifies the 9-bit CAU opcode for the operation command.

See Assembler Equate Values for a set of assembly constants used in the command descriptions here. If supported by the assembler, macros can also be created for each instruction. The value CAx should be interpreted as any CAU register (CASR, CAA, CAn) and the <ea> field as one of the supported ColdFire addressing modes {Rn, (An), -(An), (An)+, (d16,An)}. For example, the instruction to add the value from the core register D1 to the CAU register CA0 is:

cp0ld.l %d1, #ADR+CA0 ; CA0=CA0+d1

Table 26-14. CAU Commands

| Туре   | Command | Description  | CMD  |       |          |     |           |   |              | Operation |   |           |
|--------|---------|--------------|------|-------|----------|-----|-----------|---|--------------|-----------|---|-----------|
| Туре   | Name    | Description  | 8    | 7     | 6        | 5   | 4         | 3 | 2            | 1         | 0 | Operation |
| cp0ld  | CNOP    | No Operation |      | 0x000 |          |     |           | _ |              |           |   |           |
| cp0ld  | LDR     | Load Reg     | 0x01 |       | 0x01 CAx |     | Op1 → CAx |   |              |           |   |           |
| cp0str | STR     | Store Reg    |      | 0x02  |          | CAx |           |   | CAx → Result |           |   |           |

Table continues on the next page...

### **Functional Description**

Table 26-14. CAU Commands (continued)

| _     | Command |                      | CMD   |                |                  |                   |                                   |     |   |        |        |                                                                |
|-------|---------|----------------------|-------|----------------|------------------|-------------------|-----------------------------------|-----|---|--------|--------|----------------------------------------------------------------|
| Туре  | Name    | Description          | 8     | 7              | 6                | 5                 | 4                                 | 3   | 2 | 1      | 0      | Operation                                                      |
| cp0ld | ADR     | Add                  |       |                | 0x03             | -                 |                                   | CAx |   |        |        | CAx + Op1 → CAx                                                |
| cp0ld | RADR    | Reverse and Add      |       | (              | 0x04             |                   |                                   | CAx |   |        |        | CAx + ByteRev(Op1) → CAx                                       |
| cp0ld | ADRA    | Add Reg to Acc       |       | C              | 0x05             |                   |                                   |     | C | Ax     |        | CAx + CAA → CAA                                                |
| cp0ld | XOR     | Exclusive Or         |       | C              | 0x06             |                   |                                   |     | C | Ax     |        | CAx ^ Op1 → CAx                                                |
| cp0ld | ROTL    | Rotate Left          |       | C              | 0x07             |                   |                                   | CAx |   |        |        | (CAx <<< (Op1 % 32))  <br>(CAx >>> (32 - (Op1 % 32)))<br>→ CAx |
| cp0ld | MVRA    | Move Reg to Acc      |       | C              | 80x0             |                   |                                   |     | C | Ax     |        | CAx → CAA                                                      |
| cp0ld | MVAR    | Move Acc to Reg      |       | C              | 0x09             |                   |                                   |     | C | Ax     |        | CAA → CAx                                                      |
| cp0ld | AESS    | AES Sub Bytes        |       | C              | )x0A             |                   |                                   |     | C | Ax     |        | SubBytes(CAx) → CAx                                            |
| cp0ld | AESIS   | AES Inv Sub Bytes    |       | C              | 0x0B             |                   |                                   |     | C | Ax     |        | InvSubBytes(CAx) → CAx                                         |
| cp0ld | AESC    | AES Column Op        |       | C              | )x0C             |                   |                                   |     | C | Ax     |        | MixColumns(CAx)^Op1→<br>CAx                                    |
| cp0ld | AESIC   | AES Inv Column Op    |       | 0x0D CAx       |                  |                   | InvMixColumns(CAx^Op1) → CAx      |     |   |        |        |                                                                |
| cp0ld | AESR    | AES Shift Rows       | 0x0E0 |                |                  |                   | ShiftRows(CA0-CA3) → CA0-CA3      |     |   |        |        |                                                                |
| cp0ld | AESIR   | AES Inv Shift Rows   |       | 0x0F0          |                  |                   | InvShiftRows(CA0-CA3)→<br>CA0-CA3 |     |   |        |        |                                                                |
| cp0ld | DESR    | DES Round            |       | 0x10 IP FP KS[ |                  | [1:0]             | DES Round(CA0-CA3)<br>→CA0-CA3    |     |   |        |        |                                                                |
| cp0ld | DESK    | DES Key Setup        |       | C              | 0x11             |                   |                                   | 0   | 0 | C<br>P | D<br>C | DES Key Op(CA0-CA1)→<br>CA0-CA1                                |
|       |         |                      |       |                |                  |                   |                                   |     |   |        |        | Key Parity Error & CP →<br>CASR[1]                             |
| cp0ld | HASH    | Hash Function        |       | C              | 0x12             |                   |                                   | 0   | F | IF[2:  | 0]     | Hash Func(CA1-<br>CA3)+CAA→ CAA                                |
| cp0ld | SHS     | Secure Hash Shift    |       |                |                  | 0                 | x130                              | )   |   |        |        | CAA <<< 5→ CAA,                                                |
|       |         |                      |       |                |                  |                   |                                   |     |   |        |        | CAA→CA0, CA0→CA1,                                              |
|       |         |                      |       |                |                  |                   |                                   |     |   |        |        | CA1 <<< 30 → CA2,                                              |
|       |         |                      |       |                | CA2→CA3, CA3→CA4 |                   |                                   |     |   |        |        |                                                                |
| cp0ld | MDS     | Message Digest Shift | 0x140 |                |                  | CA3→CAA, CAA→CA1, |                                   |     |   |        |        |                                                                |
|       |         |                      |       |                |                  | CA1→CA2, CA2→CA3, |                                   |     |   |        |        |                                                                |
| cp0ld | SHS2    | Secure Hash Shift 2  | 0x150 |                |                  | CAA→CA0, CA0→CA1, |                                   |     |   |        |        |                                                                |
|       |         |                      |       |                |                  |                   |                                   |     |   |        |        | CA1 → CA2, CA2→CA3,                                            |
|       |         |                      |       |                |                  |                   |                                   |     |   |        |        | CA3 + CA8 →CA4,                                                |
|       |         |                      |       |                |                  |                   |                                   |     |   |        |        | CA4 → CA5, CA5 → CA6,                                          |
|       |         |                      |       |                |                  |                   |                                   |     |   |        |        | CA6 → CA7                                                      |

Table continues on the next page...

### Table 26-14. CAU Commands (continued)

| Туре  | Command     | Description     | CMD |       |   |   |   |              |   | Operation |           |
|-------|-------------|-----------------|-----|-------|---|---|---|--------------|---|-----------|-----------|
| Name  | Description | 8               | 7   | 6     | 5 | 4 | 3 | 2            | 1 | 0         | Operation |
| cp0ld | ILL         | Illegal Command |     | 0x1F0 |   |   |   | 0x1→CASR[IC] |   |           |           |

### 26.6.3.1 Coprocessor No Operation (CNOP)

cp0ld.1 #CNOP

The CNOP command is the coprocessor no-op defined by the ColdFire coprocessor definition for synchronization. It is not actually issued to the coprocessor from the core.

### 26.6.3.2 Load Register (LDR)

cp0ld.l <ea>, #LDR+CAx

The LDR command loads CAx with the source data specified by <ea>.

### 26.6.3.3 Store Register (STR)

cp0st.l <ea>, #STR+CAx

The STR command returns the value of CAx to the destination specified by <ea>.

### 26.6.3.4 Add to Register (ADR)

cp0ld.l <ea>, #ADR+CAx

The ADR command adds the source operand specified by <ea> to CAx and stores the result in CAx.

# 26.6.3.5 Reverse and Add to Register (RADR)

cp0ld.l <ea>, #RADR+CAx

The RADR command performs a byte reverse on the source operand specified by <ea>, adds that value to CAx, and stores the result in CAx. This table shows an example.

#### **Functional Description**

### Table 26-15. RADR Command Example

| Operand     | CAx Before  | CAx After   |
|-------------|-------------|-------------|
| 0x0102_0304 | 0xA0B0_C0D0 | 0xA4B3_C2D1 |

### 26.6.3.6 Add Register to Accumulator (ADRA)

cp0ld.l #ADRA+CAx

The ADRA command adds CAx to CAA and stores the result in CAA.

### **26.6.3.7 Exclusive Or (XOR)**

cp0ld.l <ea>, #XOR+CAx

The XOR command performs an exclusive-or of the source operand specified by <ea> with CAx and stores the result in CAx.

### 26.6.3.8 Rotate Left (ROTL)

cp0ld.l <ea>, #ROTL+CAx

ROTL rotates the CAx bits to the left with the result stored back to CAx. The number of bits to rotate is the value specified by <ea> modulo 32.

# 26.6.3.9 Move Register to Accumulator (MVRA)

cp0ld.l #MVRA+CAx

The MVRA command moves the value from the source register CAx to the destination register CAA.

# 26.6.3.10 Move Accumulator to Register (MVAR)

cp0ld.l #MVAR+CAx

The MVAR command moves the value from source register CAA to the destination register CAx.

598

### 26.6.3.11 AES Substitution (AESS)

cp0ld.l #AESS+CAx

The AESS command performs the AES byte substitution operation on CAx and stores the result back to CAx.

### 26.6.3.12 AES Inverse Substitution (AESIS)

cp0ld.l #AESIS+CAx

The AESIS command performs the AES inverse byte substitution operation on CAx and stores the result back to CAx.

### 26.6.3.13 AES Column Operation (AESC)

cp0ld.l <ea>, #AESC+CAx

The AESC command performs the AES column operation on the contents of CAx then performs an exclusive-or of that result with the source operand specified by <ea> and stores the result in CAx.

### 26.6.3.14 AES Inverse Column Operation (AESIC)

cp0ld.l <ea>, #AESIC+CAx

The AESIC command performs an exclusive-or operation of the source operand specified by <ea> on the contents of CAx followed by the AES inverse mix column operation on that result and stores the result back in CAx.

### **26.6.3.15 AES Shift Rows (AESR)**

cp0ld.l #AESR

The AESR command performs the AES shift rows operation on registers CA0, CA1, CA2, and CA3. This table shows an example.

Table 26-16. AESR Command Example

| Register | Before      | After       |
|----------|-------------|-------------|
| CA0      | 0x0102_0304 | 0x0106_0B00 |

Table continues on the next page...

#### **Functional Description**

Table 26-16. AESR Command Example (continued)

| Register | Before      | After       |
|----------|-------------|-------------|
| CA1      | 0x0506_0708 | 0x050A_0F04 |
| CA2      | 0x090A_0B0C | 0x090E_0308 |
| CA3      | 0x0D0E_0F00 | 0x0D02_070C |

# 26.6.3.16 AES Inverse Shift Rows (AESIR)

cp0ld.l #AESIR

The AESIR command performs the AES inverse shift rows operation on registers CA0, CA1, CA2 and CA3. This table shows an example.

**Table 26-17. AESIR Command Example** 

| Register | Before      | After       |
|----------|-------------|-------------|
| CA0      | 0x0106_0B00 | 0x0102_0304 |
| CA1      | 0x050A_0F04 | 0x0506_0708 |
| CA2      | 0x090E_0308 | 0x090A_0B0C |
| CA3      | 0x0D02_070C | 0x0D0E_0F00 |

### 26.6.3.17 **DES Round (DESR)**

cp0ld.l  $\#DESR+\{IP\}+\{FP\}+\{KSx\}$ 

The DESR command performs a round of the DES algorithm and a key schedule update with the following source and destination designations: CA0=C, CA1=D, CA2=L, CA3=R. If the IP bit is set, DES initial permutation performs on CA2 and CA3 before the round operation. If the FP bit is set, DES final permutation (inverse initial permutation) performs on CA2 and CA3 after the round operation. The round operation uses the source values from registers CA0 and CA1 for the key addition operation. The KSx field specifies the shift for the key schedule operation to update the values in CA0 and CA1. The following table defines the specific shift function performed based on the KSx field.

Table 26-18. Key Shift Function Codes

| KSx Code | KSx<br>Define | Shift Function |
|----------|---------------|----------------|
| 0        | KSL1          | Left 1         |
| 1        | KSL2          | Left 2         |

Table continues on the next page...

Table 26-18. Key Shift Function Codes (continued)

| KSx Code | KSx<br>Define | Shift Function |
|----------|---------------|----------------|
| 2        | KSR1          | Right 1        |
| 3        | KSR2          | Right 2        |

### 26.6.3.18 **DES Key Setup (DESK)**

cp0ld.l  $\#DESK+\{CP\}+\{DC\}$ 

The DESK command performs the initial key transformation (permuted choice 1) defined by the DES algorithm on CA0 and CA1 with CA0 containing bits 1-32 of the key and CA1 containing bits 33-64 of the key<sup>1</sup>. If the DC bit is set, no shift operation performs and the values  $C_0$  and  $D_0$  store back to CA0 and CA1 respectively. The DC bit should be set for decrypt operations. If the DC bit is not set, a left shift by one also occurs and the values  $C_1$  and  $D_1$  store back to CA0 and CA1 respectively. The DC bit should be cleared for encrypt operations. If the CP bit is set and a key parity error is detected, CASR[DPE] bit is set; otherwise, it is cleared.

# 26.6.3.19 Hash Function (HASH)

cp0ld.l #HASH+HFx

The HASH command performs a hashing operation on a set of registers and adds that result to the value in CAA and stores the result in CAA. The specific hash function performed is based on the HFx field as defined in this table.

This table uses the following terms:

- ROTR $^n$ (CAx): rotate CAx register right n times
- SHR<sup>n</sup>(CAx): shift CAx register right n times

Table 26-19. Hash Function Codes

| HFx Code | HFx<br>Define | Hash Function | Hash Logic                            |
|----------|---------------|---------------|---------------------------------------|
| 0        | HFF           | MD5 F()       | (CA1 & CA2)   ( <del>CA1</del> & CA3) |
| 1        | HFG           | MD5 G()       | (CA1 & CA3)   (CA2 & CA3)             |

Table continues on the next page...

<sup>1.</sup> The DES algorithm numbers the most significant bit of a block as bit 1 and the least significant as bit 64.

#### **Functional Description**

**Table 26-19. Hash Function Codes (continued)** 

| HFx Code | HFx    | Hash Function         | Hash Logic                                                                    |  |  |  |  |
|----------|--------|-----------------------|-------------------------------------------------------------------------------|--|--|--|--|
|          | Define |                       |                                                                               |  |  |  |  |
| 2        | HFH    | MD5 H(), SHA Parity() | CA1 ^ CA2 ^ CA3                                                               |  |  |  |  |
| 3        | HFI    | MD5 I()               | CA2 ^ (CA1   <del>CA3</del> )                                                 |  |  |  |  |
| 4        | HFC    | SHA Ch()              | (CA1 & CA2) ^ ( <del>CA1</del> & CA3)                                         |  |  |  |  |
| 5        | HFM    | SHA Maj()             | (CA1 & CA2) ^ (CA1 & CA3) ^ (CA2 & CA3)                                       |  |  |  |  |
| 6        | HF2C   | SHA-256 Ch()          | (CA4 & CA5) ^ ( <del>CA1</del> & CA6)                                         |  |  |  |  |
| 7        | HF2M   | SHA-256 Maj()         | (CA0 & CA1) ^ (CA0 & CA2) ^ (CA1 & CA2)                                       |  |  |  |  |
| 8        | HF2S   | SHA-256 Sigma 0       | ROTR <sup>2</sup> (CA0) ^ ROTR <sup>13</sup> (CA0) ^ ROTR <sup>22</sup> (CA0) |  |  |  |  |
| 9        | HF2T   | SHA-256 Sigma 1       | ROTR <sup>6</sup> (CA4) ^ ROTR <sup>11</sup> (CA4) ^ ROTR <sup>25</sup> (CA4) |  |  |  |  |
| А        | HF2U   | SHA-256 sigma 0       | ROTR <sup>7</sup> (CA8) ^ ROTR <sup>18</sup> (CA8) ^ SHR <sup>3</sup> (CA8)   |  |  |  |  |
| В        | HF2V   | SHA-256 sigma 1       | ROTR <sup>17</sup> (CA8) ^ ROTR <sup>19</sup> (CA8) ^ SHR <sup>10</sup> (CA8) |  |  |  |  |

### 26.6.3.20 Secure Hash Shift (SHS)

cp0ld.l #SHS

The SHS command does a set of parallel register-to-register move and shift operations for implementing SHA-1. The following source and destination assignments are made:

| Register | Value prior to command | Value after command executes |
|----------|------------------------|------------------------------|
| CA4      | CA4                    | CA3                          |
| CA3      | CA3                    | CA2                          |
| CA2      | CA2                    | CA1<<<30                     |
| CA1      | CA1                    | CA0                          |
| CA0      | CA0                    | CAA                          |
| CAA      | CAA                    | CAA<<<5                      |

# 26.6.3.21 Message Digest Shift (MDS)

cp0ld.l #MDS

The MDS command does a set of parallel register-to-register move operations for implementing MD5. The following source and destination assignments are made:

| Register | Value prior to command | Value after command executes |
|----------|------------------------|------------------------------|
| CA3      | CA3                    | CA2                          |

Table continues on the next page...

| Register | Value prior to command | Value after command executes |
|----------|------------------------|------------------------------|
| CA2      | CA2                    | CA1                          |
| CA1      | CA1                    | CAA                          |
| CAA      | CAA                    | CA3                          |

### 26.6.3.22 Secure Hash Shift 2 (SHS2)

cp0ld.l #SHS2

The SHS2 command does an addition and a set of register to register moves in parallel for implementing SHA-256. The following source and destination assignments are made:

| Register | Value prior to command | Value after command executes |  |  |
|----------|------------------------|------------------------------|--|--|
| CA7      | CA7                    | CA6                          |  |  |
| CA6      | CA6                    | CA5                          |  |  |
| CA5      | CA5                    | CA4                          |  |  |
| CA4      | CA4                    | CA3+CA8                      |  |  |
| CA3      | CA3                    | CA2                          |  |  |
| CA2      | CA2                    | CA1                          |  |  |
| CA1      | CA1                    | CA0                          |  |  |
| CA0      | CA0                    | CAA                          |  |  |

### 26.6.3.23 Illegal Command (ILL)

cp0ld.l #ILL

The ILL command is a specific illegal command that sets CASR[IC]. All other illegal commands are reserved for use in future implementations.

# 26.7 Application/Initialization Information

This section discusses how to initialize and use the CAU.

### 26.7.1 Code Example

A code fragment is shown below as an example of how the CAU is used. This example shows the round function of the AES algorithm. Core register A0 is pointing to the key schedule.

#### **Application/Initialization Information**

### 26.7.2 Assembler Equate Values

The following equates ease programming of the CAU.

```
; CAU Registers (CAx)
     .set CASR, 0x0
     .set CAA, 0x1
     .set CA0,0x2
     .set CA1,0x3
     .set CA2,0x4
     .set CA3,0x5
     .set CA4,0x6
     .set CA5,0x7
     .set CA6,0x8
     .set CA7,0x9
     .set CA8,0xA
; CAU Commands
     .set CNOP, 0x000
     .set LDR, 0 \times 010
     .set STR,0x020
     .set ADR, 0 \times 030
     .set RADR, 0x040
     .set ADRA, 0x050
    .set XOR,0x060
     .set ROTL,0x070
     .set MVRA, 0x080
     .set MVAR, 0x090
     .set AESS, 0x0A0
     .set AESIS,0x0B0
     .set AESC, 0x0C0
     .set AESIC,0x0D0
     .set AESR,0x0E0
     .set AESIR, 0x0F0
    .set DESR, 0x100
     .set DESK, 0x110
     .set HASH, 0x120
     .set SHS, 0x130
     .set MDS,0x140
    .set SHS2,0x150
     .set ILL,0x1F0
    ; DESR Fields
                         ; key schedule right 2 bits
; DESK Field
    .set DC,0x01 ; decrypt key schedule .set CP,0x02 ; check -- '
; HASH Functions Codes
    .set HFF,0x0
                          ; MD5 F() CA1&CA2
                                               ~CA1&CA3
                          ; MD5 G() CA1&CA3
     .set HFG,0x1
                                            CA2&~CA3
```

#### Chapter 26 Cryptographic Acceleration Unit (CAU)

```
; MD5 H(), SHA Parity() CA1^CA2^CA3
.set HFH,0x2
                         ; MD5 I() CA2^(CA1 - CA3)
.set HFI,0x3
                         ; SHA Ch() CA1&CA2 ^ ~CA1&CA3
; SHA Maj() CA1&CA2 ^ CA1&CA3 ^ CA2&CA3
                         ; SHA Ch() CA1&CA2
.set HFC,0x4
.set HFM,0x5
                          ; SHA-256 Ch() CA4&CA5 ^ ~CA4&CA6
.set HF2C,0x6
                         ; SHA-256 Maj() CA0&CA1 ^ CA0&CA2 ^ CA1&CA2
.set HF2M,0x7
                         ; SHA-256 Sigma 0 ROTR2(CA0)^ROTR13(CA0)^ROTR22(CA0); SHA-256 Sigma 1 ROTR6(CA4)^ROTR11(CA4)^ROTR25(CA4); SHA-256 sigma 0 ROTR7(CA8)^ROTR18(CA8)^SHR3(CA8)
.set HF2S,0x8
.set HF2T,0x9
.set HF2U,0xA
                          ; SHA-256 sigma 1 ROTR17(CA8) ROTR19(CA8) SHR10(CA8)
.set HF2V,0xB
```



# **Chapter 27 Random Number Generator (RNGB)**

### 27.1 Introduction

The purpose of the RNGB is to generate cryptographically strong random data. It uses a true random number generator (TRNG) and a pseudo-random number generator (PRNG) to achieve true randomness and cryptographic strength. The RNGB generates random numbers for secret keys, per message secrets, random challenges, and other similar quantities used in cryptographic algorithms.

This chapter describes the random number generator (RNGB), including a programming model, functional description, and application information.

# 27.1.1 Block Diagram

The below figure shows the RNGB's three main blocks: PRNG, TRNG, and XSEED generator.



Figure 27-1. RNG Block Diagram

**Modes of Operation** 

### **27.1.2 Features**

The RNG includes these distinctive features:

- National Institute of Standards and Technology (NIST)-approved pseudo-random number generator
  - http://csrc.nist.gov
- Supports the key generation algorithm defined in the Digital Signature Standard
  - http://www.itl.nist.gov/fipspubs/fip186.htm
- Integrated entropy sources capable of providing the PRNG with entropy for its seed.

## 27.2 Modes of Operation

The RNGB operates in the following modes.

### 27.2.1 Self Test Mode

In this mode the RNGB performs a self test of the statistical counters and the PRNG algorithm to verify that the hardware is functioning properly. The self test takes ~29,000 cycles to complete. When self test completes an interrupt may be generated, if there are no outstanding commands in the command register. This mode is entered by setting the RNG\_CMD[ST] bit. When self test mode completes, the RNGB remains idle until seed mode is requested or the RNGB transitions to seed mode if automatic seeding is enabled.

### 27.2.2 Seed Generation Mode

During seed generation, the RNGB adds entropy generated in the TRNG to the 256-bit XKEY register. The PRNG algorithm executes 20,000 times sampling the entropy from the TRNG to create an initial seed for random number generation. At the same time, the TRNG runs simple statistical tests on its output.

When seed generation is complete, the TRNG reports the pass/fail result of the tests through RNG\_ESR. If the new seed passes the statistical tests, RNG\_SR[SDN] is set, signalling that the RNG is ready to compute secure pseudo-random data. The RNG then transitions to random number generation mode.

### 27.2.3 Random Number Generation Mode

When seed generation mode completes and the output FIFO is empty, the RNG enters this mode automatically. Random number generation mode quickly creates computationally random data that is derived by the initial seed produced in seed generation mode.

During random number generation, a new 160-bit random number is generated whenever the five word output FIFO is empty. When the output FIFO contains data, the RNGB automatically enters sleep mode, waiting for the data to be read. When the data is read, the RNGB generates a new 160-bit word and goes back to sleep.

After generating 2<sup>20</sup> words of random data, the RNGB lets the user know that it requires reseeding through RNG\_SR and continues to generate random data until it is directed to reseed. However, if auto-seeding is selected, the RNGB automatically completes seeding whenever it is needed.

# 27.3 Memory Map/Register Definition

The following table shows the address map for the RNGB module. Detailed register descriptions are found in the following sections.

#### RNG memory map

| Absolute address (hex) | Register name                        | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|------------------------|--------------------------------------|--------------------|--------|-------------|------------------|
| FFFF_98C0              | RNGB Version ID Register (RNG_VER)   | 32                 | R      | 1000_0280h  | 27.3.1/<br>610   |
| FFFF_98C4              | RNGB Command Register (RNG_CMD)      | 32                 | R/W    | 0000_0000h  | 27.3.2/<br>610   |
| FFFF_98C8              | RNGB Control Register (RNG_CR)       | 32                 | R/W    | 0000_0000h  | 27.3.3/<br>612   |
| FFFF_98CC              | RNGB Status Register (RNG_SR)        | 32                 | R      | 0000_500Dh  | 27.3.4/<br>613   |
| FFFF_98D0              | RNGB Error Status Register (RNG_ESR) | 32                 | R      | 0000_0000h  | 27.3.5/<br>615   |
| FFFF_98D4              | RNGB Output FIFO (RNG_OUT)           | 32                 | R      | 0000_0000h  | 27.3.6/<br>617   |

### 27.3.1 RNGB Version ID Register (RNG\_VER)

The read-only RNG\_VER register contains the current version of the RNGB. It consists of the RNG type and major and minor revision numbers.

Address: RNG\_VER is FFFF\_98C0h base + 0h offset = FFFF\_98C0h



### RNG\_VER field descriptions

| Field             | Description                                                                                   |
|-------------------|-----------------------------------------------------------------------------------------------|
| 31–28<br>TYPE     | Random number generator type                                                                  |
|                   | 0000 RNGA                                                                                     |
|                   | 0001 RNGB (This is the type used in this module)                                              |
|                   | 0010 RNGC                                                                                     |
|                   | Else Reserved                                                                                 |
| 27–16<br>Reserved | This read-only bitfield is reserved and always has the value zero. Reserved, must be cleared. |
| 15–8<br>MAJOR     | Major version number.                                                                         |
| IVIAJON           | This field is always set to 0x02.                                                             |
| 7–0<br>MINOR      | Minor version number.                                                                         |
|                   | Subjiect to change.                                                                           |

# 27.3.2 RNGB Command Register (RNG\_CMD)

RNG\_CMD controls the RNG's operating modes and interrupt status.

Address: RNG\_CMD is FFFF\_98C0h base + 4h offset = FFFF\_98C4h



### **RNG\_CMD** field descriptions

| Field            | Description                                                                                                                                           |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–7<br>Reserved | This read-only bitfield is reserved and always has the value zero. Reserved, must be cleared.                                                         |
| 6<br>SR          | Software reset.                                                                                                                                       |
| OIT              | Performs a software reset of the RNGB. This bit is self-clearing.                                                                                     |
|                  | <ul><li>0 Do not perform a software reset.</li><li>1 Software reset.</li></ul>                                                                        |
| 5<br>CE          | Clear error.                                                                                                                                          |
| OL .             | Clears the errors in the RNG_ESR register and the RNGB interrupt. This bit is self-clearing.                                                          |
|                  | 0 Do not clear errors and interrupt.                                                                                                                  |
|                  | 1 Clear errors and interrupt.                                                                                                                         |
| 4<br>CI          | Clear interrupt.                                                                                                                                      |
|                  | Clears the RNGB interrupt if an error is not present. This bit is self-clearing.                                                                      |
|                  | 0 Do not clear interrupt.                                                                                                                             |
|                  | 1 Clear interrupt.                                                                                                                                    |
| 3–2<br>Reserved  | This read-only bitfield is reserved and always has the value zero. Reserved, must be cleared.                                                         |
| 1<br>GS          | Generate seed.                                                                                                                                        |
| d3               | Initiates the seed generation process. Seed generation starts                                                                                         |
|                  | <ul><li>When RNG_SR[BUSY] is cleared</li><li>If set simultaneously with ST, after self-test</li></ul>                                                 |
|                  | When the seed generation process completes, this bit automatically clears and an interrupt may be generated if all requested operations are complete. |
|                  | 0 Not in seed generation mode.                                                                                                                        |
|                  | 1 Generate seed mode.                                                                                                                                 |
| 0<br>ST          | Self test.                                                                                                                                            |
| 31               | Initiates a self test of the RNGB's internal logic. The self-test starts                                                                              |
|                  | <ul> <li>When RNG_SR[BUSY] is cleared, or</li> <li>If set simultaneously with GS, self test takes precedence and is completed first.</li> </ul>       |
|                  | When self test completes, this bit automatically clears and an interrupt may be generated if all requested operations are complete.                   |
|                  | 0 Not in self test mode.                                                                                                                              |
|                  | 1 Self test mode.                                                                                                                                     |

# 27.3.3 RNGB Control Register (RNG\_CR)

Through use of this register, the RNGB can be programmed to provide slightly different functionality based on its desired use.





### **RNG\_CR field descriptions**

| Field             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–10<br>Reserved | This read-only bitfield is reserved and always has the value zero. Reserved, must be cleared.                                                                                                                                                                                                                                                                                                                                                                                                         |
| 9–7<br>Reserved   | This read-only bitfield is reserved and always has the value zero. Reserved, must be cleared.                                                                                                                                                                                                                                                                                                                                                                                                         |
| 6<br>MASKERR      | Mask error interrupt.  Masks interrupts generated by errors in the RNGB. These errors can still be viewed in RNG_ESR.  NOTE: Since masked errors do not interrupt the operation of the RNGB and thus hide potentially fatal errors or conditions that could result in corrupted results, it is strongly recommended that errors only be masked while debugging. All errors are considered fatal, requiring the RNGB to be reset. Until the a reset occurs, the RNGB does not service any random data. |
|                   | <ul><li>No mask applied.</li><li>Mask applied to the error interrupt.</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 5<br>MASKDONE     | Mask done interrupt.  Masks interrupts generated upon completion of seed and self test modes. The status of these jobs can be viewed by:  Reading RNG_SR and viewing the seed done and self test done bits (RNG_SR[SDN, STDN])  Viewing RNG_CMD for generate seed or self test bits (RNG_CMD[GS,ST]) being set, indicating that the operation is still taking place.  No mask applied.                                                                                                                |
|                   | 1 Mask applied.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

Table continues on the next page...

## **RNG\_CR field descriptions (continued)**

| Field           | Description                                                                                                                       |  |
|-----------------|-----------------------------------------------------------------------------------------------------------------------------------|--|
| 4<br>AR         | Auto-reseed.  Setting this bit allows the RNGB to automatically generate a new seed whenever one is needed. This                  |  |
|                 | allows software to never use the RNG_CMD[GS], although it is still possible. A new seed is needed whenever the RNG_SR[RS] is set. |  |
|                 | 0 Do not enable automatic reseeding.                                                                                              |  |
|                 | 1 Enable automatic reseeding.                                                                                                     |  |
| 3–2<br>Reserved | This read-only bitfield is reserved and always has the value zero. Reserved, must be cleared.                                     |  |
| 1–0<br>FUFMOD   | FIFO underflow response mode.                                                                                                     |  |
| FUFMOD          | Controls the RNGB's response to a FIFO underflow condition.                                                                       |  |
|                 | 00 Return all zeros and set RNG_ESR[FUFE]                                                                                         |  |
|                 | 01 Return all zeros and set RNG_ESR[FUFE]                                                                                         |  |
|                 | 10 Generate bus transfer error                                                                                                    |  |
|                 | 11 Generate interrupt and return all zeros (Overrides RNG_CR[MASKERR])                                                            |  |

# 27.3.4 RNGB Status Register (RNG\_SR)

The RNGBSR is a read-only register which reflects the internal status of the RNGB.





#### **Memory Map/Register Definition**

## **RNG\_SR** field descriptions

| Field              | Description                                                                                                                                                                                                                                                                                                                                                |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–24<br>STATPF    | Statistics test pass fail.                                                                                                                                                                                                                                                                                                                                 |
| OTAIT!             | Indicates pass or fail status of the various statistics tests on the last seed generated.  • Bit 31 - Long run test (>34)  • Bit 30 - Length 6+ run test  • Bit 29 - Length 5 run test  • Bit 28 - Length 4 run test  • Bit 27 - Length 3 run test  • Bit 26 - Length 2 run test  • Bit 25 - Length 1 run test  • Bit 24 - Monobit test   O Pass.  1 Fail. |
| 23–21<br>ST_PF     | Self Test Pass Fail.  Indicates Pass or Fail status of the TRNG, PRNG, and RESEED self tests,  • Bit 23 - TRNG self test pass/fail  • Bit 22 - PRNG self test pass/fail  • Bit 21 - RESEED self test pass/fail                                                                                                                                             |
|                    | 0 Pass.<br>1 Fail.                                                                                                                                                                                                                                                                                                                                         |
| 20–17<br>Reserved  | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                                                                                                         |
| 16<br>ERR          | Error.  Indicates an error was detected in the RNGB. Read the RNG_ESR register for details.  0 No error.  1 Error detected.                                                                                                                                                                                                                                |
| 15–12<br>FIFO_SIZE | FIFO size.  Size of the FIFO, and maximum possible FIFO level. The bits should be interpreted as an integer. This value is set to five on the default version of RNGB.                                                                                                                                                                                     |
| 11–8<br>FIFO_LVL   | FIFO level.  Indicates the number of random words currently in the output FIFO. The bits should be interpreted as an integer.                                                                                                                                                                                                                              |
| 7<br>Reserved      | This read-only bit is reserved and always has the value zero.                                                                                                                                                                                                                                                                                              |
| 6<br>NSDN          | New seed done.  Indicates that a new seed is ready for use during the next seed generation process.                                                                                                                                                                                                                                                        |
| 5<br>SDN           | Seed done.  Indicates the RNG has generated the first seed.  0 Seed generation process not complete. 1 Completed seed generation since the last reset.                                                                                                                                                                                                     |

Table continues on the next page...

## **RNG\_SR field descriptions (continued)**

| Field         | Description                                                                                                                                                                                                                                                                                                            |
|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4<br>STDN     | Self test done.  Indicates the self test is complete. This bit is cleared by hardware reset or a new self test is initiated by setting RNG_CMD[ST].                                                                                                                                                                    |
|               | 0 Self test not complete.                                                                                                                                                                                                                                                                                              |
|               | 1 Completed a self test since the last reset.                                                                                                                                                                                                                                                                          |
| 3<br>RS       | Reseed needed.  Indicates the RNGB needs to be reseeded. This is done by setting RNG_CMD[GS], or automatically if                                                                                                                                                                                                      |
|               | RNG_CR[AR] is set.  0 RNGB does not need to be reseeded.  1 RNGB needs to be reseeded.                                                                                                                                                                                                                                 |
| 2<br>SLP      | Sleep.  Indicates if the RNGB is in sleep mode. When set, the RNGB is in sleep mode and all internal clocks are disabled. While in this mode, access to the FIFO is allowed. Once the FIFO is empty, the RNGB fills the FIFO and then enters sleep mode again.  O RNGB is not in sleep mode.  1 RNGB is in sleep mode. |
| 1<br>BUSY     | Busy.  Reflects the current state of RNGB. If RNGB is currently seeding, generating the next seed, creating a new random number, or performing a self test, this bit is set.  0 Not busy. 1 Busy.                                                                                                                      |
| 0<br>Reserved | This read-only bit is reserved and always has the value one. Reserved, must be set.                                                                                                                                                                                                                                    |

# 27.3.5 RNGB Error Status Register (RNG\_ESR)

Address: RNG\_ESR is FFFF\_98C0h base + 10h offset = FFFF\_98D0h



## **Memory Map/Register Definition**

## **RNG\_ESR** field descriptions

| Field            | Description                                                                                                                                                                                                       |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–5<br>Reserved | This read-only bitfield is reserved and always has the value zero. Reserved, must be cleared.                                                                                                                     |
| 4<br>FUFE        | FIFO underflow error  Indicates the RNGB has experienced a FIFO underflow condition resulting in the last random data read                                                                                        |
|                  | being unreliable. This bit can be masked by RNG_CR[FUFMOD] and is cleared by hardware or software reset or by writing one to RNG_CMD[CE].                                                                         |
|                  | FIFO underflow has not occurred.     FIFO underflow has occurred                                                                                                                                                  |
| 3<br>SATE        | Statistical test error.                                                                                                                                                                                           |
| SATE             | Indicates if RNGB has failed the statistical tests for the last generated seed. This bit is sticky and is cleared by a hardware or software reset or by writing one to RNG_CMD[CE].                               |
|                  | 0 RNGB has not failed the statistical tests.                                                                                                                                                                      |
|                  | 1 RNGB has failed the statistical tests during initialization.                                                                                                                                                    |
| 2<br>STE         | Self test error.                                                                                                                                                                                                  |
| 0.12             | Indicates the RNGB has failed the most recent self test. This bit is sticky and can only be reset by a hardware reset or by writing one to RNG_CMD[CE].                                                           |
|                  | 0 RNGB has not failed self test.                                                                                                                                                                                  |
|                  | 1 RNGB has failed self test.                                                                                                                                                                                      |
| 1<br>OSCE        | Oscillator error.                                                                                                                                                                                                 |
| OSCE             | Indicates the oscillator in the RNG may be broken. This bit is sticky and can only be cleared by a software or hardware reset.                                                                                    |
|                  | 0 RNG oscillator is working properly.                                                                                                                                                                             |
|                  | 1 Problem detected with the RNG oscillator.                                                                                                                                                                       |
| 0<br>LFE         | Linear feedback shift register (LFSR) error.                                                                                                                                                                      |
|                  | When this bit is set, the interrupt generated was caused by a failure of one of the LFSRs in one of the RNGB's three entropy sources. This bit is sticky and can only be cleared by a software or hardware reset. |
|                  | 0 LFSRs are working properly.                                                                                                                                                                                     |
|                  | 1 LFSR failure has occurred.                                                                                                                                                                                      |

## 27.3.6 RNGB Output FIFO (RNG\_OUT)

The RNGBOUT provides temporary storage for random data generated by the RNGB. This allows the user to read multiple random longwords back-to-back. A read of this address when the FIFO is not empty, returns 32 bits of random data. If the FIFO is read when empty, a FIFO underrun response is returned according to RNG\_CR[FUFMOD]. For optimal system performance, poll RNG\_SR[FIFO\_LVL] to ensure random values are present before reading the FIFO.





#### **RNG\_OUT field descriptions**

| Field           | Description   |
|-----------------|---------------|
| 31–0<br>RANDOUT | Random Output |

# 27.4 Functional Description

The RNGB performs two functional operations, as described in Modes of Operation: seed generation and random number generation. Theses operations are performed with cooperation from the major functional blocks in the RNGB described below.

# 27.4.1 Pseudorandom Number Generator (PRNG)

The PRNG implements the NIST-approved PRNG described in the *Digital Signature Standard*. The 160-bit output of the SHA-1 block is the next five words of random data. The PRNG is designed to generate 2<sup>20</sup> words of random data before requiring reseeding, using the TRNG only during the seeding/initialization process. The initial seed takes approximately two million clock cycles. After this the RNGB can generate five 32-bit words every 112 clock cycles. Reseeding takes place transparently through use of the simultaneous reseed LFSRs. The entropy stored in this 128-bit LFSR and 128-bit shift register is added directly into the XKEY structure via the RNGB XSEED generator whenever reseeding is required.

# 27.4.2 True Random Number Generator (TRNG)

The TRNG is comprised of two entropy sources each providing a single bit of output. Concatenated together, these two output bits are expected to provide one bit of entropy every 100 clock cycles. In addition to generating entropy, the TRNG also performs several statistical tests on its output. The pass/fail status of these tests are reflected in RNG\_ESR.

## **27.4.3** Resets

There are two ways to reset the RNGB: power-on/hardware reset and software reset. The software reset is functionally equivalent to the power-on/hardware reset. The power-on/hardware reset is asynchronous. Software reset is performed by setting the RNG\_CMD[SR] bit. These are summarized in the table below.

**Affect on External** Characteristics Reset Source Internally resets: Signal: Hardware ipg\_hard\_async\_reset\_b Active-low, All interface registers asynchronous, and puts RNGB into minimum 1-cycle the IDLE state Software RNG\_CMD[SR] Active-high All interface registers and puts RNGB into the IDLE state

Table 27-8. Reset Summary

## 27.4.3.1 Power-on/Hardware Reset

Asserting the ipg\_hard\_async\_reset\_b signal sets all interface registers to their default state and puts the state machine into the IDLE mode.

## 27.4.3.2 Software Reset

The software reset is functionally equivalent to the hardware reset, but allows the RNGB to be fully reset by writing to the SW\_RST bit (bit-6) in the RNGB Command Register. This bit is self-resetting. A software reset may be performed at any time.

# 27.4.4 RNG Interrupts

There is a single RNG interrupt generated to the processor's interrupt controller. The source of the interrupt is determined by reading the RNG status register. If an error is the cause of the interrupt, further information is available by reading the RNG error status register. The interrupts can be masked by the RNG\_CR[MASKDONE or MASKERR] bits

It is strongly recommended that the error interrupt is only masked while debugging, since masking the error interrupt could hide potentially fatal errors or conditions that could result in corrupted results. All errors are considered fatal, requiring the RNG to be reset. The RNG does not service any random data until a reset occurs.

The available interrupt sources are described in the following table.

|   | Sources                                  | Status Bit Field | RNG_CR<br>Mask Bit Field | Description                                     |  |
|---|------------------------------------------|------------------|--------------------------|-------------------------------------------------|--|
| S | eed generation done                      | RNG_SR[SDN]      | MASKDONE                 | First seed was generated                        |  |
|   | Self test done                           | RNG_SR[STDN]     | MASKDONE                 | Self test finished                              |  |
|   | Error                                    | RNG_SR[ERR]      | MASKERR                  | Error detected. See RNG_ESR for details.        |  |
|   | Linear feedback<br>shift register (LFSR) | RNG_ESR[LSFRE]   | MASKERR                  | Fault in one of the TRNG's LFSRs                |  |
|   | Oscillator                               | RNG_ESR[OSCE]    | MASKERR                  | TRNG ring oscillator may be malfunctioning      |  |
|   | Self test                                | RNG_ESR[STE]     | MASKERR                  | Self test failed                                |  |
|   | Statistical test                         | RNG_ESR[SATE]    | MASKERR                  | Statistics test for last seed generation failed |  |
|   | FIFO Underflow                           | RNG_ESR[FUFE]    | MASKERR                  | FIFO read while empty                           |  |

**Table 27-9. RNG Interrupt Sources** 

# 27.5 Initialization/Application Information

This section describes the module initialization.

# 27.5.1 Manual Seeding

The intended general operation of the RNGB is as follows:

- 1. Reset/initialize.
- 2. Write to the RNG\_CR to setup the RNGB for the desired functionality.

#### **Initialization/Application Information**

- 3. Write to RNG\_CMD to run self-test or seed generation.
- 4. Wait for interrupt to indicate completion of the requested operation(s).
- 5. Repeat steps 3–4 if seed generation is not complete.
- 6. Poll RNG\_SR for FIFO level.
- 7. Read available random data from output FIFO.
- 8. Repeat steps 6 and 7 as needed, until  $2^{20}$  words have been generated.
- 9. Write to RNG\_CMD to run seed mode.
- 10. Repeat steps 4–9.

# 27.5.2 Automatic Seeding

The intended general operation of the RNGB with automatic seeding enabled is as follows:

- 1. Reset/initialize.
- 2. Write to the RNG\_CR to setup the RNGB for automatic seeding and the desired functionality.
- 3. Wait for interrupt to indicate completion of first seed
- 4. Poll RNG\_SR for FIFO level.
- 5. Read available random data from output FIFO.
- 6. Repeat steps 4 and 5 as needed. Automatic seeding occurs when necessary and is transparent to operation.

# **Chapter 28 Cyclic Redundancy Check (CRC)**

## 28.1 Introduction

The cyclic redundancy check (CRC) module generates 16/32-bit CRC code for error detection.

The CRC module provides a programmable polynomial, SEED, and other parameters required to implement a 16-bit or 32-bit CRC standard.

The 16/32-bit code is calculated for 32 bits of data at a time.

## **28.1.1 Features**

Features of the CRC module include:

- Hardware CRC generator circuit using a 16-bit or 32-bit (programmable) shift register.
- Programmable initial seed value and polynomial.
- Option to transpose input data or output data (the CRC result) bitwise or bytewise. This option is required for certain CRC standards. A bytewise transpose operation is not possible when accessing the CRC data register via 8-bit accesses. In this case, the user's software must perform the bytewise transpose function.
- Option for inversion of final CRC result.
- 32-bit CPU register programming interface.

# 28.1.2 Block diagram

This is a block diagram of the CRC.

#### Memory map and register descriptions



Figure 28-1. Programmable cyclic redundancy check (CRC) block diagram

# 28.1.3 Modes of operation

Various MCU modes affect the CRC module's functionality.

#### 28.1.3.1 Run mode

This is the basic mode of operation.

## 28.1.3.2 Low power modes (wait or stop)

Any CRC calculation in progress stops when the MCU enters a low power mode that disables the module clock. It resumes after the clock is enabled or via the system reset for exiting the low power mode. Clock gating for this module is MCU dependent.

# 28.2 Memory map and register descriptions

## CRC memory map

| Absolute address (hex) | Register name                       | Width<br>(in bits) | Access | Reset value    | Section/<br>page |
|------------------------|-------------------------------------|--------------------|--------|----------------|------------------|
| FFFF_8570              | CRC Data Register (CRC_CRC)         | 32                 | R/W    | FFFF_<br>FFFFh | 28.2.1/<br>623   |
| FFFF_8574              | CRC Polynomial Register (CRC_GPOLY) | 32                 | R/W    | 0000_1021h     | 28.2.2/<br>624   |

Table continues on the next page...

#### **CRC** memory map (continued)

| Absolute address (hex) | Register name                   | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|------------------------|---------------------------------|--------------------|--------|-------------|------------------|
| FFFF_8578              | CRC Control Register (CRC_CTRL) | 16                 | R/W    | 0000h       | 28.2.3/<br>625   |

# 28.2.1 CRC Data Register (CRC\_CRC)

The CRC data register contains the value of the seed, data, and checksum. When the CTRL[WAS] bit is set, any write to the data register is regarded as the seed value. When the CTRL[WAS] bit is cleared, any write to the data register is regarded as data for general CRC computation.

In 16-bit CRC mode, the HU and HL fields are not used for programming the seed value, and reads of these fields return an indeterminate value. In 32-bit CRC mode, all fields are used for programming the seed value.

When programming data values, the values can be written 8 bits, 16 bits, or 32 bits at a time, provided all bytes are contiguous.

After all data values are written, the CRC result can be read from this data register. In 16-bit CRC mode, the CRC result is available in the LU and LL fields. In 32-bit CRC mode, all fields contain the result. Reads of this register at any time return the intermediate CRC value, provided the CRC module is configured.

Address: CRC\_CRC is FFFF\_8570h base + 0h offset = FFFF\_8570h



#### **CRC\_CRC** field descriptions

| Field       | Description                                                                                                                                                                                                                                                                                                                                                            |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–24<br>HU | CRC High Upper Byte                                                                                                                                                                                                                                                                                                                                                    |
|             | In 16-bit CRC mode (the CTRL[TCRC] bit is 0), this field is not used for programming a seed value. In 32-bit CRC mode (the CTRL[TCRC] bit is 1), values written to this field are part of the seed value when the CTRL[WAS] bit is 1. When the CTRL[WAS] bit is 0, data written to this field is used for CRC checksum generation in both 16-bit and 32-bit CRC modes. |
| 23–16<br>HL | CRC High Lower Byte                                                                                                                                                                                                                                                                                                                                                    |
|             | In 16-bit CRC mode (the CTRL[TCRC] bit is 0), this field is not used for programming a seed value. In 32-bit CRC mode (the CTRL[TCRC] bit is 1), values written to this field are part of the seed value when the                                                                                                                                                      |

Table continues on the next page...

#### Memory map and register descriptions

## **CRC\_CRC** field descriptions (continued)

| Field      | Description                                                                                                                                                                        |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | CTRL[WAS] bit is 1. When the CTRL[WAS] bit is 0, data written to this field is used for CRC checksum generation in both 16-bit and 32-bit CRC modes.                               |
| 15–8<br>LU | CRC Low Upper Byte  When the CTRL[WAS] bit is 1, values written to this field are part of the seed value. When the                                                                 |
|            | CTRL[WAS] bit is 0, data written to this field is used for CRC checksum generation.                                                                                                |
| 7–0<br>LL  | CRC Low Lower Byte                                                                                                                                                                 |
|            | When the CTRL[WAS] bit is 1, values written to this field are part of the seed value. When the CTRL[WAS] bit is 0, data written to this field is used for CRC checksum generation. |

# 28.2.2 CRC Polynomial Register (CRC\_GPOLY)

This register contains the value of the polynomial for the CRC calculation. The HIGH field contains the upper 16 bits of the CRC polynomial, which are used only in 32-bit CRC mode. Writes to the HIGH field are ignored in 16-bit CRC mode. The LOW field contains the lower 16 bits of the CRC polynomial, which are used in both 16- and 32-bit CRC modes.

Address: CRC\_GPOLY is FFFF\_8570h base + 4h offset = FFFF\_8574h



#### **CRC\_GPOLY** field descriptions

| Field         | Description                                                                                                                              |
|---------------|------------------------------------------------------------------------------------------------------------------------------------------|
| 31–16<br>HIGH | High polynominal half-word  This field is writable and readable in 32-bit CRC mode (the CTRL[TCRC] bit is 1). This field is not writable |
|               | in 16-bit CRC mode (the CTRL[TCRC] bit is 0).                                                                                            |
| 15–0<br>LOW   | Low polynominal half-word                                                                                                                |
|               | This field is writable and readable in both 32-bit and 16-bit CRC modes.                                                                 |

## 28.2.3 CRC Control Register (CRC\_CTRL)

This register controls the configuration and working of the CRC module. Appropriate bits must be set before starting a new CRC calculation. A new CRC calculation is initialized by asserting the CTRL[WAS] bit and then writing the seed into the CRC data register.

Address: CRC\_CTRL is FFFF\_8570h base + 8h offset = FFFF\_8578h



## CRC\_CTRL field descriptions

| Field          | Description                                                                                                                                                                                                  |
|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15–14<br>TOT   | Type of Transpose for Writes                                                                                                                                                                                 |
|                | These bits define the transpose configuration of the data written to the CRC data register. Refer to the description of the transpose feature for the available transpose options.                           |
|                | 00 No transposition.                                                                                                                                                                                         |
|                | 01 Bits in bytes are transposed; bytes are not transposed.                                                                                                                                                   |
|                | 10 Both bits in bytes and bytes are transposed.                                                                                                                                                              |
|                | 11 Only bytes are transposed; no bits in a byte are transposed.                                                                                                                                              |
| 13–12<br>TOTR  | Type of Transpose for Read                                                                                                                                                                                   |
|                | These bits identify the transpose configuration of the value read from the CRC data register. Refer to the description of the transpose feature for the available transpose options.                         |
|                | 00 No transposition.                                                                                                                                                                                         |
|                | 01 Bits in bytes are transposed; bytes are not transposed.                                                                                                                                                   |
|                | 10 Both bits in bytes and bytes are transposed.                                                                                                                                                              |
|                | 11 Only bytes are transposed; no bits in a byte are transposed.                                                                                                                                              |
| 11<br>Reserved | This read-only bit is reserved and always has the value zero.                                                                                                                                                |
| 10<br>FXOR     | Complement Read of CRC data register                                                                                                                                                                         |
| T XOIT         | Some CRC protocols require the final checksum to be XORed with 0xFFFFFFF or 0xFFFF. Asserting this bit enables "on the fly" complementing of read data.                                                      |
|                | 0 No XOR on reading.                                                                                                                                                                                         |
|                | 1 Invert or complement the read value of the CRC data register.                                                                                                                                              |
| 9<br>WAS       | Write CRC data register as seed                                                                                                                                                                              |
|                | When this bit is asserted, a value written to the CRC data register is considered a seed value. When this bit is de-asserted, a value written to the CRC data register is taken as data for CRC computation. |

Table continues on the next page...

#### **Functional description**

#### CRC\_CTRL field descriptions (continued)

| Field           | Description                                                        |
|-----------------|--------------------------------------------------------------------|
|                 | 0 Writes to the CRC data register are data values.                 |
|                 | 1 Writes to the CRC data register are seed values.                 |
| 8<br>TCRC       | Width of CRC protocol.                                             |
|                 | 0 16-bit CRC protocol.                                             |
|                 | 1 32-bit CRC protocol.                                             |
| 7–0<br>Reserved | This read-only bitfield is reserved and always has the value zero. |

# 28.3 Functional description

## 28.3.1 CRC initialization/re-initialization

To enable the CRC calculation, the user must program the SEED, POLYNOMIAL, and necessary parameters for transpose and CRC result inversion in the applicable registers. Asserting the CTRL[WAS] bit enables the programming of the SEED value into the CRC data register.

After a completed CRC calculation, re-asserting the CTRL[WAS] bit and programming a seed (whether the value is new or a previously used seed value) re-initialize the CRC module for a new CRC computation. All other parameters must be set before programming the seed value and subsequent data values.

## 28.3.2 CRC calculations

In 16-bit and 32-bit CRC modes, data values can be programmed 8 bits, 16 bits, or 32 bits at a time, provided all bytes are contiguous. Non-contiguous bytes can lead to an incorrect CRC computation.

## 28.3.2.1 16-bit CRC

Compute a 16-bit CRC with the following steps:

- 1. Clear the CTRL[TCRC] bit to enable 16-bit CRC mode.
- 2. Program the transpose and complement options in the CTRL register as required for the CRC calculation. See Transpose feature and CRC result complement for details.

- 3. Write a 16-bit polynomial to the GPOLY[LOW] field. The GPOLY[HIGH] field is not usable in 16-bit CRC mode.
- 4. Set the CTRL[WAS] bit to program the seed value.
- 5. Write a 16-bit seed to CRC[LU:LL]. CRC[HU:HL] are not used.
- 6. Clear the CTRL[WAS] bit to start writing data values.
- 7. Write data values into CRC[HU:HL:LU:LL]. A CRC is computed on every data value write, and the intermediate CRC result is stored back into CRC[LU:LL].
- 8. When all values have been written, read the final CRC result from CRC[LU:LL].

Transpose and complement operations are performed "on the fly" while reading or writing values. See Transpose feature and CRC result complement for details.

#### 28.3.2.2 32-bit CRC

Compute a 32-bit CRC with the following steps:

- 1. Set the CTRL[TCRC] bit to enable 32-bit CRC mode.
- 2. Program the transpose and complement options in the CTRL register as required for the CRC calculation. See Transpose feature and CRC result complement for details.
- 3. Write a 32-bit polynomial to GPOLY[HIGH:LOW].
- 4. Set the CTRL[WAS] bit to program the seed value.
- 5. Write a 32-bit seed to CRC[HU:HL:LU:LL].
- 6. Clear the CTRL[WAS] bit to start writing data values.
- 7. Write data values into CRC[HU:HL:LU:LL]. A CRC is computed on every data value write, and the intermediate CRC result is stored back into CRC[HU:HL:LU:LL].
- 8. When all values have been written, read the final CRC result from CRC[HU:HL:LU:LL]. The CRC is calculated bytewise, and two clocks are required to complete one CRC calculation.

Transpose and complement operations are performed "on the fly" while reading or writing values. See Transpose feature and CRC result complement for details.

# 28.3.3 Transpose feature

By default, the transpose feature is not enabled. However, some CRC standards require the input data and/or the final checksum to be transposed. The user software has the option to configure each transpose operation separately, as desired by the CRC standard. The data is transposed "on the fly" while being read or written.

#### **Functional description**

Some protocols use little endian format for the data stream to calculate a CRC. In this case, the transpose feature usefully flips the bits. This transpose option is one of the types supported by the CRC module.

# 28.3.3.1 Types of transpose

The CRC module provides several types of transpose functions to flip the bits and/or bytes (for both writing input data and reading the CRC result, separately using the CTRL[TOT] or CTRL[TOTR] fields) according to the CRC calculation being used.

The following types of transpose functions are available for writing to and reading from the CRC data register.

- CTRL[TOT] or CTRL[TOTR] is 00
   No transposition occurs.
- 2. CTRL[TOT] or CTRL[TOTR] is 01

Bits in a byte are transposed, while bytes are not transposed.

reg[31:0] becomes {reg[24:31], reg[16:23], reg[8:15], reg[0:7]}



Figure 28-5. Transpose type 01

3. CTRL[TOT] or CTRL[TOTR] is 10

Both bits in bytes and bytes are transposed.

reg[31:0] becomes = {reg[0:7], reg[8:15], reg[16:23], reg[24:31]}



Figure 28-6. Transpose type 10

4. CTRL[TOT] or CTRL[TOTR] is 11

Bytes are transposed, but bits are not transposed.

reg[31:0] becomes {reg[7:0], reg[15:8], reg[23:16], reg[31:24]}



Figure 28-7. Transpose type 11

#### **NOTE**

For 8-bit and 16-bit write accesses to the CRC data register, the data is transposed with zeros on the unused byte or bytes (taking 32 bits as a whole), but the CRC is calculated on the valid byte(s) only. When reading the CRC data register for a 16-bit CRC result and using transpose options 10 and 11, the resulting value after transposition resides in the CRC[HU:HL] fields. The user software must account for this situation when reading the 16-bit CRC result, so reading 32 bits is preferred.

# 28.3.4 CRC result complement

When the CTRL[FXOR] bit is set, the checksum is complemented: The CRC result complement function outputs the complement of the checksum value stored in the CRC data register every time the CRC data register is read. When the CTRL[FXOR] bit is cleared, reading the CRC data register accesses the raw checksum value.

**Functional description** 

# Chapter 29 Analog-to-Digital Converter (ADC)

## 29.1 Introduction

The 12-bit analog-to-digital converter (ADC) is a successive approximation ADC designed for operation within an integrated microcontroller system-on-chip.

#### NOTE

For the chip specific modes of operation, refer to the Power Management information for the device.

## **29.1.1 Features**

Features of the ADC module include:

- Linear successive approximation algorithm with up to 12-bit resolution
- Up to 24 single-ended external analog inputs
- Output modes: single-ended 12-bit, 10-bit and 8-bit modes
- Output in right-justified unsigned format for single-ended
- Single or continuous conversion (automatic return to idle after single conversion)
- Configurable sample time and conversion speed/power
- Conversion complete / hardware average complete flag and interrupt
- Input clock selectable from up to four sources
- Operation in low power modes for lower noise operation
- Asynchronous clock source for lower noise operation with option to output the clock
- Selectable hardware conversion trigger with hardware channel select

#### Introduction

- Automatic compare with interrupt for less-than, greater-than or equal-to, within range, or out-of-range, programmable value
- Temperature sensor
- Hardware average function
- Selectable voltage reference: external or alternate
- Self-calibration mode

# 29.1.2 Block diagram

The following figure is the ADC module block diagram.



Figure 29-1. ADC block diagram

# 29.2 ADC Signal Descriptions

The ADC module supports up to 24 single-ended inputs. The ADC also requires four supply/reference/ground connections.

Table 29-1. ADC Signal Descriptions

| Signal             | Description                        | I/O |
|--------------------|------------------------------------|-----|
| AD[23:4]           | Single-ended analog channel inputs | I   |
| V <sub>REFSH</sub> | Voltage reference select high      | I   |

Table continues on the next page...

#### **ADC Signal Descriptions**

Table 29-1. ADC Signal Descriptions (continued)

| Signal             | Description                  | I/O |
|--------------------|------------------------------|-----|
| V <sub>REFSL</sub> | Voltage reference select low | I   |
| $V_{DDA}$          | Analog power supply          | I   |
| V <sub>SSA</sub>   | Analog ground                | I   |

# 29.2.1 Analog power (V<sub>DDA</sub>)

The ADC analog portion uses  $V_{DDA}$  as its power connection. In some packages,  $V_{DDA}$  is connected internally to  $V_{DD}$ . If externally available, connect the  $V_{DDA}$  pin to the same voltage potential as  $V_{DD}$ . External filtering may be necessary to ensure clean  $V_{DDA}$  for good results.

# 29.2.2 Analog ground (V<sub>SSA</sub>)

The ADC analog portion uses  $V_{SSA}$  as its ground connection. In some packages,  $V_{SSA}$  is connected internally to  $V_{SS}$ . If externally available, connect the  $V_{SSA}$  pin to the same voltage potential as  $V_{SS}$ .

# 29.2.3 Voltage reference select

V<sub>REFSH</sub> and V<sub>REFSL</sub> are the high and low reference voltages for the converter.

The ADC can be configured to accept one of two voltage reference pairs for  $V_{REFSH}$  and  $V_{REFSL}$ . Each pair contains a positive reference that must be between the minimum Ref Voltage High and  $V_{DDA}$ , and a ground reference that must be at the same potential as  $V_{SSA}$ . The two pairs are external ( $V_{REFH}$  and  $V_{REFL}$ ) and alternate ( $V_{ALTH}$  and  $V_{ALTL}$ ). These voltage references are selected using the REFSEL bits in the SC2 register. The alternate ( $V_{ALTH}$  and  $V_{ALTL}$ ) voltage reference pair may select additional external pins or internal sources depending on MCU configuration. Refer to the Chip Configuration information on the Voltage References specific to this MCU.

In some packages,  $V_{REFH}$  is connected in the package to  $V_{DDA}$  and  $V_{REFL}$  to  $V_{SSA}$ . If externally available, the positive reference(s) may be connected to the same potential as  $V_{DDA}$  or may be driven by an external source to a level between the minimum Ref Voltage High and the  $V_{DDA}$  potential ( $V_{REFH}$  must never exceed  $V_{DDA}$ ). Connect the ground references to the same voltage potential as  $V_{SSA}$ .

# 29.2.4 Analog channel inputs (ADx)

The ADC module supports up to 24 single-ended analog inputs. A single-ended input is selected for conversion through the ADCH channel select bits.

# 29.3 Register Definition

This section describes the ADC registers.

#### **ADCx** memory map

| Absolute address (hex) | Register name                                                | Width<br>(in bits) | Access         | Reset value    | Section/<br>page |
|------------------------|--------------------------------------------------------------|--------------------|----------------|----------------|------------------|
| FFFF_8600              | ADC status and control registers 1 (ADC0_SC1A)               | 32                 | R/W            | 0000_001Fh     | 29.3.1/<br>637   |
| FFFF_8604              | ADC status and control registers 1 (ADC0_SC1B)               | 32                 | R/W            | 0000_001Fh     | 29.3.1/<br>637   |
| FFFF_8608              | ADC configuration register 1 (ADC0_CFG1)                     | 32                 | R/W            | 0000_0000h     | 29.3.2/<br>639   |
| FFFF_860C              | Configuration register 2 (ADC0_CFG2)                         | 0000_0000h         | 29.3.3/<br>641 |                |                  |
| FFFF_8610              | ADC data result register (ADC0_RA)                           | R                  | 0000_0000h     | 29.3.4/<br>642 |                  |
| FFFF_8614              | ADC data result register (ADC0_RB)                           | R                  | 0000_0000h     | 29.3.4/<br>642 |                  |
| FFFF_8618              | Compare value registers (ADC0_CV1)                           | 32                 | R/W            | 0000_0000h     | 29.3.5/<br>643   |
| FFFF_861C              | Compare value registers (ADC0_CV2)                           | R/W                | 0000_0000h     | 29.3.5/<br>643 |                  |
| FFFF_8620              | Status and control register 2 (ADC0_SC2)                     | 32                 | R/W            | 0000_0000h     | 29.3.6/<br>644   |
| FFFF_8624              | Status and control register 3 (ADC0_SC3)                     | 32                 | R/W            | 0000_0000h     | 29.3.7/<br>646   |
| FFFF_8628              | ADC offset correction register (ADC0_OFS)                    | 32                 | R/W            | 0000_0004h     | 29.3.8/<br>647   |
| FFFF_862C              | ADC plus-side gain register (ADC0_PG)                        | 32                 | R/W            | 0000_8200h     | 29.3.9/<br>648   |
| FFFF_8634              | ADC plus-side general calibration value register (ADC0_CLPD) | 32                 | R/W            | 0000_000Ah     | 29.3.10/<br>648  |

Table continues on the next page...

#### **Register Definition**

# ADCx memory map (continued)

| Absolute<br>address<br>(hex) | Register name                                                | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|------------------------------|--------------------------------------------------------------|--------------------|--------|-------------|------------------|
| FFFF_8638                    | ADC plus-side general calibration value register (ADC0_CLPS) | 32                 | R/W    | 0000_0020h  | 29.3.11/<br>649  |
| FFFF_863C                    | ADC plus-side general calibration value register (ADC0_CLP4) | 32                 | R/W    | 0000_0200h  | 29.3.12/<br>649  |
| FFFF_8640                    | ADC plus-side general calibration value register (ADC0_CLP3) | 32                 | R/W    | 0000_0100h  | 29.3.13/<br>650  |
| FFFF_8644                    | ADC plus-side general calibration value register (ADC0_CLP2) | 32                 | R/W    | 0000_0080h  | 29.3.14/<br>650  |
| FFFF_8648                    | ADC plus-side general calibration value register (ADC0_CLP1) | 32                 | R/W    | 0000_0040h  | 29.3.15/<br>651  |
| FFFF_864C                    | ADC plus-side general calibration value register (ADC0_CLP0) | 32                 | R/W    | 0000_0020h  | 29.3.16/<br>651  |

## 29.3.1 ADC status and control registers 1 (ADCx\_SC1n)

To allow sequential conversions of the ADC to be triggered by internal peripherals, the ADC can have more then one status and control register: one for each conversion. SC1A register is used for both software and hardware trigger modes of operation. SC1B-SC1n indicate potentially multiple SC1 registers for use only in hardware trigger mode. Refer to the Chip Configuration information about the number of SC1n registers specific to this device. The SC1n registers have identical fields, and are used in a "ping-pong" approach to control ADC operation. At any one point in time, only one of the SC1n registers is actively controlling ADC conversions. Updating SC1A while SC1n is actively controlling a conversion is allowed (and vice-versa for any of the SC1n registers specific to this MCU). Writing SC1A while SC1A is actively controlling a conversion aborts the current conversion. In software trigger mode (ADTRG=0), writes to SC1A register subsequently initiate a new conversion (if the ADCH bits are equal to a value other than all 1s). Similarly, writing any of the SC1n registers while that specific SC1n register is actively controlling a conversion aborts the current conversion. None of the SC1B-SC1n registers are used for software trigger operation and therefore writes to the SC1B - SC1n registers do not initiate a new conversion.



#### **Register Definition**

## ADCx\_SC1n field descriptions

| Field         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |  |  |  |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|
| 31–8          | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |  |  |
| Reserved      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |  |  |  |
| 7             | Conversion complete flag                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |  |  |  |
| COCO          | The COCO flag is a read-only bit that is set each time a conversion is completed when the compare function is disabled (ACFE=0) and the hardware average function is disabled (AVGE=0). When the compare function is enabled (ACFE=1), the COCO flag is set upon completion of a conversion only if the compare result is true. When the hardware average function is enabled (AVGE=1), the COCO flag is set upon completion of the selected number of conversions (determined by the AVGS bits). The The COCO flag in SC1A is also set at the completion of a Calibration sequence. The COCO bit is cleared when the respective SC1n register is written or when the respective Rn register is read.                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |  |  |  |
|               | 0 Conversion not completed.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |  |  |  |
|               | 1 Conversion completed.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |  |  |  |
| 6             | Interrupt enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |  |  |  |
| AIEN          | AIEN enables conversion complete interrupts. When COCO becomes set while the respective AIEN is high, an interrupt is asserted.  O Conversion complete interrupt disabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |  |  |  |
|               | 1 Conversion complete interrupt enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |  |  |  |
| 5<br>Reserved | This bit is reserved. This reserved bit should not be changed.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |  |  |  |
| 4–0<br>ADCH   | Input channel select  The ADCH bits form a 5-bit field that selects one of the input channels.  The successive approximation converter subsystem is turned off when the channel select bits are all set (ADCH = 11111). This feature allows for explicit disabling of the ADC and isolation of the input channel from all sources. Terminating continuous conversions this way prevents an additional single conversion from being performed. It is not necessary to set the channel select bits to all ones to place the ADC in a low-power state when continuous conversions are not enabled because the module automatically enters a low-power state when a conversion completes.  O0000 AD0 is selected as input.  O0010 AD1 is selected as input.  O0011 AD3 is selected as input.  O0100 AD4 is selected as input.  O0110 AD6 is selected as input.  O0111 AD7 is selected as input.  O1102 AD8 is selected as input.  O1013 AD9 is selected as input.  O1014 AD10 is selected as input.  O1015 AD10 is selected as input.  O1016 AD10 is selected as input.  O1017 AD11 is selected as input.  O1018 AD12 is selected as input. |  |  |  |  |  |  |  |  |  |
|               | 01101 AD13 is selected as input. 01110 AD14 is selected as input. 01111 AD15 is selected as input.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |  |  |
|               | 10000 AD16 is selected as input.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |  |  |  |

Table continues on the next page...

## ADCx\_SC1n field descriptions (continued)

| Field |       | Description                                                                                                   |
|-------|-------|---------------------------------------------------------------------------------------------------------------|
|       | 10001 | AD17 is selected as input.                                                                                    |
|       | 10010 | AD18 is selected as input.                                                                                    |
|       | 10011 | AD19 is selected as input.                                                                                    |
|       | 10100 | AD20 is selected as input.                                                                                    |
|       | 10101 | AD21 is selected as input.                                                                                    |
|       | 10110 | AD22 is selected as input.                                                                                    |
|       | 10111 | AD23 is selected as input.                                                                                    |
|       | 11000 | Reserved.                                                                                                     |
|       | 11001 | Reserved.                                                                                                     |
|       | 11010 | Temp sensor (single-ended) is selected as input.                                                              |
|       | 11011 | Bandgap (single-ended) is selected as input.                                                                  |
|       | 11100 | Reserved.                                                                                                     |
|       | 11101 | VREFSH is selected as input. Voltage reference selected is determined by the REFSEL bits in the SC2 register. |
|       | 11110 | VREFSL is selected as input. Voltage reference selected is determined by the REFSEL bits in the SC2 register. |
|       | 11111 | Module disabled.                                                                                              |

# 29.3.2 ADC configuration register 1 (ADCx\_CFG1)

CFG1 register selects the mode of operation, clock source, clock divide, and configure for low power or long sample time.

Addresses: ADC0\_CFG1 is FFFF\_8600h base + 8h offset = FFFF\_8608h



## ADCx\_CFG1 field descriptions

| Field            | Description                                                        |  |  |  |  |  |  |  |  |
|------------------|--------------------------------------------------------------------|--|--|--|--|--|--|--|--|
| 31–8<br>Reserved | This read-only bitfield is reserved and always has the value zero. |  |  |  |  |  |  |  |  |

Table continues on the next page...

#### **Register Definition**

## **ADCx\_CFG1** field descriptions (continued)

| Field         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>ADLPC    | Low-power configuration                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 7.52.         | ADLPC controls the power configuration of the successive approximation converter. This optimizes power consumption when higher sample rates are not required.                                                                                                                                                                                                                                                                                                                                                          |
|               | 0 Normal power configuration.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|               | 1 Low power configuration. The power is reduced at the expense of maximum clock speed.                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 6–5           | Clock divide select                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| ADIV          | ADIV selects the divide ratio used by the ADC to generate the internal clock ADCK.                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|               | 00 The divide ratio is 1 and the clock rate is input clock.                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|               | 01 The divide ratio is 2 and the clock rate is (input clock)/2.                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|               | 10 The divide ratio is 4 and the clock rate is (input clock)/4.                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|               | 11 The divide ratio is 8 and the clock rate is (input clock)/8.                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 4<br>ADLSMP   | Sample time configuration                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|               | ADLSMP selects between different sample times based on the conversion mode selected. This bit adjusts the sample period to allow higher impedance inputs to be accurately sampled or to maximize conversion speed for lower impedance inputs. Longer sample times can also be used to lower overall power consumption if continuous conversions are enabled and high conversion rates are not required. When ADLSMP=1, the long sample time select bits, (ADLSTS[1:0]), can select the extent of the long sample time. |
|               | 0 Short sample time.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|               | 1 Long sample time.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 3–2<br>MODE   | Conversion mode selection                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| WODE          | MODE bits are used to select the ADC resolution mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|               | 00 It is single-ended 8-bit conversion.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|               | 01 It is single-ended 12-bit conversion.                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|               | 10 It is single-ended 10-bit conversion.                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|               | 11 Reserved. Do not set the bitfield to this value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 1–0<br>ADICLK | Input clock select                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|               | ADICLK bits select the input clock source to generate the internal clock, ADCK. Note that when the ADACK clock source is selected, it is not required to be active prior to conversion start. When it is selected and it is not active prior to a conversion start (ADACKEN=0), the asynchronous clock is activated at the start of a conversion and shuts off when conversions are terminated. In this case, there is an associated clock startup delay each time the clock source is re-activated.                   |
|               | 00 Bus clock.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|               | 01 Bus clock divided by 2.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|               | 10 Alternate clock (ALTCLK).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|               | 11 Asynchronous clock (ADACK).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

Freescale Semiconductor, Inc.

# 29.3.3 Configuration register 2 (ADCx\_CFG2)

CFG2 register selects the special high speed configuration for very high speed conversions and selects the long sample time duration during long sample mode.





#### ADCx\_CFG2 field descriptions

| Field            | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–8<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 7–5<br>Reserved  | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 4<br>MUXSEL      | ADC Mux select  ADC Mux select bit is used to change the ADC mux setting to select between alternate sets of ADC channels.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                  | ADxxa channels are selected.     ADxxb channels are selected.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 3<br>ADACKEN     | Asynchronous clock output enable  ADACKEN enables the ADC's asynchronous clock source and the clock source output regardless of the conversion and input clock select (ADICLK bits) status of the ADC. Based on MCU configuration, the asynchronous clock may be used by other modules (see Chip Configuration information). Setting this bit allows the clock to be used even while the ADC is idle or operating from a different clock source. Also, latency of initiating a single or first-continuous conversion with the asynchronous clock selected is reduced since the ADACK clock is already operational.  O Asynchronous clock output disabled; Asynchronous clock only enabled if selected by ADICLK and a conversion is active.  1 Asynchronous clock and clock output enabled regardless of the state of the ADC. |
| 2<br>ADHSC       | High speed configuration                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

Table continues on the next page...

#### **Register Definition**

#### ADCx\_CFG2 field descriptions (continued)

| Field         | Description                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |  |  |  |
|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|
|               | ADHSC configures the ADC for very high speed operation. The conversion sequence is altered (2 ADCK cycles added to the conversion time) to allow higher speed conversion clocks.                                                                                                                                                                                                   |  |  |  |  |  |  |  |  |  |
|               | 0 Normal conversion sequence selected.                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |  |  |  |
|               | 1 High speed conversion sequence selected (2 additional ADCK cycles to total conversion time).                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |  |  |  |
| 1-0<br>ADLSTS | Long sample time select                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |  |  |  |
| 7.02070       | ADLSTS selects between the extended sample times when long sample time is selected (ADLSMP=1). This allows higher impedance inputs to be accurately sampled or to maximize conversion speed for lower impedance inputs. Longer sample times can also be used to lower overall power consumption when continuous conversions are enabled if high conversion rates are not required. |  |  |  |  |  |  |  |  |  |
|               | 00 Default longest sample time (20 extra ADCK cycles; 24 ADCK cycles total).                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |  |  |  |
|               | 01 12 extra ADCK cycles; 16 ADCK cycles total sample time.                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |  |  |  |
|               | 10 6 extra ADCK cycles; 10 ADCK cycles total sample time.                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |  |  |  |
|               | 11 2 extra ADCK cycles; 6 ADCK cycles total sample time.                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |  |  |  |

# 29.3.4 ADC data result register (ADCx\_Rn)

The data result registers (Rn) contain the result of an ADC conversion of the channel selected by the corresponding status and channel control register (SC1A:SC1n). For every status and channel control register, there is a corresponding data result register.

Unused bits in the Rn register are cleared in unsigned right justified modes and carry the sign bit (MSB) in sign extended 2's complement modes.

The following table describes the behavior of the data result registers in the different modes of operation.

Table 29-35. Data result register description

| Conversion mode         | D15 | D14 | D13 | D12 | D11 | D10 | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | Format                   |
|-------------------------|-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----|--------------------------|
| 12-bit single-<br>ended | 0   | 0   | 0   | 0   | D   | D   | D  | D  | D  | D  | D  | D  | D  | D  | D  | D  | Unsigned right justified |
| 10-bit single-<br>ended | 0   | 0   | 0   | 0   | 0   | 0   | D  | D  | D  | D  | D  | D  | D  | D  | D  | D  | Unsigned right justified |
| 8-bit single-<br>ended  | 0   | 0   | 0   | 0   | 0   | 0   | 0  | 0  | D  | D  | D  | D  | D  | D  | D  | D  | Unsigned right justified |

#### **NOTE**

S: Sign bit or sign bit extension;

D: Data (2's complement data if indicated)

Addresses: ADC0\_RA is FFFF\_8600h base + 10h offset = FFFF\_8610h

ADC0\_RB is FFFF\_8600h base + 14h offset = FFFF\_8614h



## ADCx Rn field descriptions

| Field             | Description                                                        |
|-------------------|--------------------------------------------------------------------|
| 31–16<br>Reserved | This read-only bitfield is reserved and always has the value zero. |
| 15–0<br>D         | Data result                                                        |

# 29.3.5 Compare value registers (ADCx\_CVn)

The compare value registers (CV1 and CV2) contain a compare value used to compare with the conversion result when the compare function is enabled (ACFE=1). This register is formatted the same for both bit position definition and value format (unsigned or sign-extended 2's complement) as the data result registers (Rn) in the different modes of operation. Therefore, the compare function only uses the compare value register bits that are related to the ADC mode of operation.

The compare value 2 register (CV2) is utilized only when the compare range function is enabled (ACREN=1).

Addresses: ADC0\_CV1 is FFFF\_8600h base + 18h offset = FFFF\_8618h ADC0\_CV2 is FFFF\_8600h base + 1Ch offset = FFFF\_861Ch



#### ADCx\_CVn field descriptions

| Field             | Description                                                        |
|-------------------|--------------------------------------------------------------------|
| 31–16<br>Reserved | This read-only bitfield is reserved and always has the value zero. |
| 15–0<br>CV        | Compare value                                                      |

# 29.3.6 Status and control register 2 (ADCx\_SC2)

The SC2 register contains the conversion active, hardware/software trigger select, compare function and voltage reference select of the ADC module.





## ADCx\_SC2 field descriptions

| Field            | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–8<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                                                                                                                                                                                                                       |
| 7<br>ADACT       | Conversion active  ADACT indicates that a conversion or hardware averaging is in progress. ADACT is set when a conversion is initiated and cleared when a conversion is completed or aborted.  Conversion not in progress.  Conversion in progress.                                                                                                                                                                                                                      |
| 6<br>ADTRG       | Conversion trigger select  ADTRG selects the type of trigger used for initiating a conversion. Two types of trigger are selectable: software trigger and hardware trigger. When software trigger is selected, a conversion is initiated following a write to SC1A. When hardware trigger is selected, a conversion is initiated following the assertion of the ADHWT input after a pulse of the ADHWTSn input.  O Software trigger selected.  Hardware trigger selected. |
| 5<br>ACFE        | Compare function enable  ACFE enables the compare function.                                                                                                                                                                                                                                                                                                                                                                                                              |

Table continues on the next page...

## **ADCx\_SC2** field descriptions (continued)

| Compare function disabled.     Compare function enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                     |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|
| ·                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                     |
| A Common function and the complete                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                     |
| 4 Compare function greater than enable ACFGT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                     |
| ACFGT configures the compare function to check the conversion result relative to the co register(s) (CV1 and CV2) based upon the value of ACREN. The ACFE bit must be set for have any effect.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                     |
| Configures less than threshold, outside range not inclusive and inside range not include and inside range not inclusive and inclusive and inside range not inclusive and inclusive | usive functionality |
| 1 Configures greater than or equal to threshold, outside range inclusive and inside range functionality based on the values placed in the CV1 and CV2 registers.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | ge inclusive        |
| 3 Compare function range enable ACREN                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                     |
| ACREN configures the compare function to check if the conversion result of the input bei either between or outside the range formed by the compare value registers (CV1 and CV the value of ACFGT.{27}The ACFE bit must be set for ACFGT to have any effect.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                     |
| 0 Range function disabled.{27} Only the compare value 1 register (CV1) is compared.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                     |
| 1 Range function enabled.{27} Both compare value registers (CV1 and CV2) are comp                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | pared.              |
| 2 DMA enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                     |
| 0 DMA is disabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                     |
| DMA is enabled and will assert the ADC DMA request during a ADC conversion comby the assertion of any of the ADC COCO flags.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | nplete event noted  |
| 1–0 Voltage reference selection REFSEL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                     |
| REFSEL bits select the voltage reference source used for conversions.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                     |
| 00 Default voltage reference pin pair (External pins V REFH and V REFL )                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                     |
| O1 Alternate reference pair (V ALTH and V ALTL). This pair may be additional externa sources depending on MCU configuration. Consult the module introduction for infor Voltage Reference specific to this MCU.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                     |
| 10 Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                     |
| 11 Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                     |

# 29.3.7 Status and control register 3 (ADCx\_SC3)

The SC3 register controls the calibration, continuous convert, and hardware averaging functions of the ADC module.





## ADCx\_SC3 field descriptions

| Field            | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–8<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                                                                                                                                                                                                                          |
| 7<br>CAL         | Calibration  CAL begins the calibration sequence when set. This bit stays set while the calibration is in progress and is cleared when the calibration sequence is completed. The CALF bit must be checked to determine the result of the calibration sequence. Once started, the calibration routine cannot be interrupted by writes to the ADC registers or the results will be invalid and the CALF bit will set. Setting the CAL bit will abort any current conversion. |
| 6<br>CALF        | Calibration failed flag  CALF displays the result of the calibration sequence. The calibration sequence will fail if ADTRG = 1, any ADC register is written, or any stop mode is entered before the calibration sequence completes. The CALF bit is cleared by writing a 1 to this bit.  0 Calibration completed normally.  1 Calibration failed. ADC accuracy specifications are not guaranteed.                                                                           |
| 5–4<br>Reserved  | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                                                                                                                                                                                                                          |
| 3<br>ADCO        | Continuous conversion enable  ADCO enables continuous conversions.                                                                                                                                                                                                                                                                                                                                                                                                          |

Table continues on the next page...

## ADCx\_SC3 field descriptions (continued)

| Field       | Description                                                                                                                         |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------|
|             | One conversion or one set of conversions if the hardware average function is enabled (AVGE=1) after initiating a conversion.        |
|             | 1 Continuous conversions or sets of conversions if the hardware average function is enabled (AVGE=1) after initiating a conversion. |
| 2<br>AVGE   | Hardware average enable                                                                                                             |
|             | AVGE enables the hardware average function of the ADC.                                                                              |
|             | Hardware average function disabled.                                                                                                 |
|             | 1 Hardware average function enabled.                                                                                                |
| 1–0<br>AVGS | Hardware average select                                                                                                             |
|             | AVGS determines how many ADC conversions will be averaged to create the ADC average result.                                         |
|             | 00 4 samples averaged.                                                                                                              |
|             | 01 8 samples averaged.                                                                                                              |
|             | 10 16 samples averaged.                                                                                                             |
|             | 11 32 samples averaged.                                                                                                             |

# 29.3.8 ADC offset correction register (ADCx\_OFS)

The ADC offset correction register (OFS) contains the user selected or calibration generated offset error correction value. This register is a 2's complement, left justified, 16-bit value. The value in the offset correction registers (OFS) is subtracted from the conversion and the result is transferred into the result registers (Rn). If the result is above the maximum or below the minimum result value, it is forced to the appropriate limit for the current mode of operation.

Addresses: ADC0\_OFS is FFFF\_8600h base + 28h offset = FFFF\_8628h



#### ADCx\_OFS field descriptions

| Field             | Description                                                        |
|-------------------|--------------------------------------------------------------------|
| 31–16<br>Reserved | This read-only bitfield is reserved and always has the value zero. |
| 15–0<br>OFS       | Offset error correction value                                      |

## 29.3.9 ADC plus-side gain register (ADCx\_PG)

The plus-side gain register (PG) contains the gain error correction for the overall conversion in single-ended mode. PG, a 16-bit real number in binary format, is the gain adjustment factor, with the radix point fixed between ADPG15 and ADPG14. This register must be written by the user with the value described in the calibration procedure or the gain error specifications may not be met.





#### ADCx\_PG field descriptions

| Field             | Description                                                        |
|-------------------|--------------------------------------------------------------------|
| 31–16<br>Reserved | This read-only bitfield is reserved and always has the value zero. |
| 15–0<br>PG        | Plus-side gain                                                     |

# 29.3.10 ADC plus-side general calibration value register (ADCx CLPD)

The plus-side general calibration value registers (CLPx) contain calibration information that is generated by the calibration function. These registers contain seven calibration values of varying widths: CLP0[5:0], CLP1[6:0], CLP2[7:0], CLP3[8:0], CLP4[9:0], CLPS[5:0], and CLPD[5:0]. CLPx are automatically set once the self calibration sequence is done (CAL is cleared). If these registers are written by the user after calibration, the linearity error specifications may not be met.

Addresses: ADC0\_CLPD is FFFF\_8600h base + 34h offset = FFFF\_8634h



### ADCx\_CLPD field descriptions

| Field            | Description                                                        |  |
|------------------|--------------------------------------------------------------------|--|
| 31–6<br>Reserved | This read-only bitfield is reserved and always has the value zero. |  |
| 5–0<br>CLPD      | Calibration value                                                  |  |

# 29.3.11 ADC plus-side general calibration value register (ADCx\_CLPS)

For more information, refer to CLPD register description.

Addresses: ADC0\_CLPS is FFFF\_8600h base + 38h offset = FFFF\_8638h



### ADCx\_CLPS field descriptions

| Field            | Description                                                        |
|------------------|--------------------------------------------------------------------|
| 31–6<br>Reserved | This read-only bitfield is reserved and always has the value zero. |
| 5–0<br>CLPS      | Calibration value                                                  |

# 29.3.12 ADC plus-side general calibration value register (ADCx\_CLP4)

For more information, refer to CLPD register description.

Addresses: ADC0\_CLP4 is FFFF\_8600h base + 3Ch offset = FFFF\_863Ch



#### **Register Definition**

### ADCx\_CLP4 field descriptions

| Field             | Description                                                        |  |
|-------------------|--------------------------------------------------------------------|--|
| 31–10<br>Reserved | This read-only bitfield is reserved and always has the value zero. |  |
| 9–0<br>CLP4       | Calibration value                                                  |  |

# 29.3.13 ADC plus-side general calibration value register (ADCx\_CLP3)

For more information, refer to CLPD register description.

Addresses: ADC0\_CLP3 is FFFF\_8600h base + 40h offset = FFFF\_8640h



### ADCx\_CLP3 field descriptions

| Field            | Description                                                        |
|------------------|--------------------------------------------------------------------|
| 31–9<br>Reserved | This read-only bitfield is reserved and always has the value zero. |
| 8–0<br>CLP3      | Calibration value                                                  |

# 29.3.14 ADC plus-side general calibration value register (ADCx\_CLP2)

For more information, refer to CLPD register description.

Addresses: ADC0\_CLP2 is FFFF\_8600h base + 44h offset = FFFF\_8644h



### ADCx\_CLP2 field descriptions

| Field            | Description                                                        |  |  |  |
|------------------|--------------------------------------------------------------------|--|--|--|
| 31–8<br>Reserved | This read-only bitfield is reserved and always has the value zero. |  |  |  |
| 7–0<br>CLP2      | Calibration value                                                  |  |  |  |

# 29.3.15 ADC plus-side general calibration value register (ADCx\_CLP1)

For more information, refer to CLPD register description.

Addresses: ADC0\_CLP1 is FFFF\_8600h base + 48h offset = FFFF\_8648h



### ADCx\_CLP1 field descriptions

| Field            | Description                                                        |  |
|------------------|--------------------------------------------------------------------|--|
| 31–7<br>Reserved | This read-only bitfield is reserved and always has the value zero. |  |
| 6-0<br>CLP1      | Calibration value                                                  |  |

# 29.3.16 ADC plus-side general calibration value register (ADCx\_CLP0)

For more information, refer to CLPD register description.

Addresses: ADC0\_CLP0 is FFFF\_8600h base + 4Ch offset = FFFF\_864Ch



#### **Functional description**

### ADCx\_CLP0 field descriptions

| Field            | Description                                                        |  |  |
|------------------|--------------------------------------------------------------------|--|--|
| 31–6<br>Reserved | This read-only bitfield is reserved and always has the value zero. |  |  |
| 5–0<br>CLP0      | Calibration value                                                  |  |  |

# 29.4 Functional description

The ADC module is disabled during reset, in low power stop mode (refer to the Power Management information for details), or when the ADCH bits in SC1n are all high. The module is idle when a conversion has completed and another conversion has not been initiated. When it is idle and the asynchronous clock output enable is disabled (ADACKEN is 0), the module is in its lowest power state. The ADC can perform an analog-to-digital conversion on any of the software selectable channels. All modes perform conversion by a successive approximation algorithm.

To meet accuracy specifications, the ADC module must be calibrated using the on chip calibration function. See Calibration function for details on how to perform calibration.

When the conversion is completed, the result is placed in the data registers (Rn). The respective conversion complete flag (COCO) is then set and an interrupt is generated if the respective conversion complete interrupt has been enabled (AIEN=1).

The ADC module has the capability of automatically comparing the result of a conversion with the contents of the compare value registers. The compare function is enabled by setting the ACFE bit and operates with any of the conversion modes and configurations.

The ADC module has the capability of automatically averaging the result of multiple conversions. The hardware average function is enabled by setting the AVGE bit and operates with any of the conversion modes and configurations.

#### **NOTE**

For the chip specific modes of operation, refer to the Power Management information of this MCU.

### 29.4.1 Clock select and divide control

One of four clock sources can be selected as the clock source for the ADC module. This clock source is then divided by a configurable value to generate the input clock to the converter (ADCK). The clock is selected from one of the following sources by means of the ADICLK bits.

- The bus clock. This is the default selection following reset.
- The bus clock divided by two. For higher bus clock rates, this allows a maximum divide by 16 of the bus clock with using the ADIV bits.
- ALTCLK, as defined for this MCU. Refer to the Chip Configuration information.
- The asynchronous clock (ADACK). This clock is generated from a clock source within the ADC module. Note that when the ADACK clock source is selected, it is not required to be active prior to conversion start. When it is selected and it is not active prior to a conversion start (ADACKEN=0), the asynchronous clock is activated at the start of a conversion and shuts off when conversions are terminated. In this case, there is an associated clock startup delay each time the clock source is re-activated. To avoid the conversion time variability and latency associated with the ADACK clock startup, set ADACKEN=1 and wait the worst case startup time of 5 µs prior to initiating any conversions using the ADACK clock source. Conversions are possible using ADACK as the input clock source while the MCU is in Normal Stop mode. Refer to Power Control for more information.

Whichever clock is selected, its frequency must fall within the specified frequency range for ADCK. If the available clocks are too slow, the ADC may not perform according to specifications. If the available clocks are too fast, the clock must be divided to the appropriate frequency. This divider is specified by the ADIV bits and can be divide-by 1, 2, 4, or 8.

# 29.4.2 Voltage reference selection

The ADC can be configured to accept one of the two voltage reference pairs as the reference voltage ( $V_{REFSH}$  and  $V_{REFSL}$ ) used for conversions. Each pair contains a positive reference that must be between the minimum Ref Voltage High and  $V_{DDA}$ , and a ground reference that must be at the same potential as  $V_{SSA}$ . The two pairs are external ( $V_{REFH}$  and  $V_{REFL}$ ) and alternate ( $V_{ALTH}$  and  $V_{ALTL}$ ). These voltage references are selected using the REFSEL bits in the SC2 register. The alternate ( $V_{ALTH}$  and  $V_{ALTL}$ ) voltage reference pair may select additional external pins or internal sources depending on MCU configuration. Refer to the Chip Configuration information on the Voltage References specific to this MCU.

# 29.4.3 Hardware trigger and channel selects

The ADC module has a selectable asynchronous hardware conversion trigger, ADHWT, that is enabled when the ADTRG bit is set and a hardware trigger select event (ADHWTSn) has occurred. This source is not available on all MCUs. Refer to the Chip Configuration chapter for information on the ADHWT source and the ADHWTSn configurations specific to this MCU.

When a ADHWT source is available and hardware trigger is enabled (ADTRG=1), a conversion is initiated on the rising edge of ADHWT after a hardware trigger select event (ADHWTSn) has occurred. If a conversion is in progress when a rising edge of a trigger occurs, the rising edge is ignored. In continuous convert configuration, only the initial rising edge to launch continuous conversions is observed, and until conversion gets aborted the ADC continues to do conversions on the same ADC status and control register that initiated the conversion. The hardware trigger function operates in conjunction with any of the conversion modes and configurations.

The hardware trigger select event (ADHWTSn) must be set prior to the receipt of the ADHWT signal. If these conditions are not met, the converter may ignore the trigger or use the incorrect configuration. If a hardware trigger select event gets asserted during a conversion, it must stay asserted until the end of current conversion and remain set until the receipt of the ADHWT signal to trigger a new conversion. The channel and status fields selected for the conversion depend on the active trigger select signal (ADHWTSA active selects SC1A; ADHWTSn active selects SC1n).

#### **Note**

Asserting more than one hardware trigger select signal (ADHWTSn) at the same time results in unknown results. To avoid this, select only one hardware trigger select signal (ADHWTSn) prior to the next intended conversion.

When the conversion is completed, the result is placed in the data registers associated with the ADHWTSn received (ADHWTSA active selects RA register; ADHWTSn active selects Rn register). The conversion complete flag associated with the ADHWTSn received (the COCO bit in SC1n register) is then set and an interrupt is generated if the respective conversion complete interrupt has been enabled (AIEN=1).

### 29.4.4 Conversion control

Conversions can be performed as determined by the CFG1[MODE] bits as shown in the description of CFG1[MODE].

Conversions can be initiated by a software or hardware trigger. In addition, the ADC module can be configured for low power operation, long sample time, continuous conversion, hardware average, and automatic compare of the conversion result to a software determined compare value.

## 29.4.4.1 Initiating conversions

A conversion is initiated:

- Following a write to SC1A register (with ADCH bits not all 1's) if software triggered operation is selected (ADTRG=0).
- Following a hardware trigger (ADHWT) event if hardware triggered operation is selected (ADTRG=1) and a hardware trigger select event (ADHWTSn) has occurred. The channel and status fields selected depend on the active trigger select signal (ADHWTSA active selects SC1A register; ADHWTSn active selects SC1n register; if neither is active, the off condition is selected).

#### **Note**

Selecting more than one hardware trigger select signal (ADHWTSn) prior to a conversion completion will result in unknown results. To avoid this, select only one hardware trigger select signal (ADHWTSn) prior to a conversion completion.

• Following the transfer of the result to the data registers when continuous conversion is enabled (ADCO=1).

If continuous conversions are enabled, a new conversion is automatically initiated after the completion of the current conversion. In software triggered operation (ADTRG=0), continuous conversions begin after SC1A register is written and continue until aborted. In hardware triggered operation (ADTRG=1 and one ADHWTSn event has occurred), continuous conversions begin after a hardware trigger event and continue until aborted.

If hardware averaging is enabled, a new conversion is automatically initiated after the completion of the current conversion until the correct number of conversions is completed. In software triggered operation, conversions begin after SC1A register is

#### **Functional description**

written. In hardware triggered operation, conversions begin after a hardware trigger. If continuous conversions are also enabled, a new set of conversions to be averaged are initiated following the last of the selected number of conversions.

# 29.4.4.2 Completing conversions

A conversion is completed when the result of the conversion is transferred into the data result registers, Rn. If the compare functions are disabled, this is indicated by the setting of the COCO bit in the respective SC1n register. If hardware averaging is enabled, the respective COCO bit sets only if the last of the selected number of conversions is completed. If the compare function is enabled, the respective COCO bit sets and conversion result data is transferred only if the compare condition is true. If both hardware averaging and compare functions are enabled then the respective COCO bit sets only if the last of the selected number of conversions is completed and the compare condition is true. An interrupt is generated if the respective AIEN bit is high at the time that the respective COCO bit is set.

# 29.4.4.3 Aborting conversions

Any conversion in progress is aborted when:

- Writing to SC1A register while it is actively controlling a conversion, aborts the current conversion. In software trigger mode (ADTRG=0), a write to SC1A register initiates a new conversion (if the ADCH field in SC1A is equal to a value other than all 1s). Writing to any of the SC1(B-n) registers while that specific SC1(B-n) register is actively controlling a conversion aborts the current conversion. The SC1(B-n) registers are not used for software trigger operation and therefore writes to the SC1(B-n) registers do not initiate a new conversion.
- A write to any ADC register besides the SC1A:SC1n registers occurs. This indicates a mode of operation change has occurred and the current conversion is therefore invalid.
- The MCU is reset or enters Low Power Stop modes.
- The MCU enters Normal Stop mode with ADACK not enabled.

When a conversion is aborted, the contents of the data registers, Rn, are not altered. The data registers continue to be the values transferred after the completion of the last successful conversion. If the conversion was aborted by a reset or Low Power Stop modes, RA and R n return to their reset states.

### 29.4.4.4 Power control

The ADC module remains in its idle state until a conversion is initiated. If ADACK is selected as the conversion clock source, but the asynchronous clock output is disabled (ADACKEN=0), the ADACK clock generator also remains in its idle state (disabled) until a conversion is initiated. If the asynchronous clock output is enabled (ADACKEN=1), it remains active regardless of the state of the ADC or the MCU power mode.

Power consumption when the ADC is active can be reduced by setting ADLPC. This results in a lower maximum value for  $f_{ADCK}$ .

# 29.4.4.5 Sample time and total conversion time

For short sample (ADLSMP=0), there is a 2-cycle adder for first conversion over the base sample time of 4 ADCK cycles. For high speed conversions (ADHSC=1), there is an additional 2-cycle adder on any conversion. The table below summarizes sample times for the possible ADC configurations.

| ADC Configuration |        |       | Sample time (A  | ADCK cycles) |
|-------------------|--------|-------|-----------------|--------------|
| ADLSMP            | ADLSTS | ADHSC | First or Single | Subsequent   |
| 0                 | Х      | 0     | 6               | 4            |
| 1                 | 00     | 0     | 24              | 4            |
| 1                 | 01     | 0     | 16              | 6            |
| 1                 | 10     | 0     | 10              | )            |
| 1                 | 11     | 0     | 6               |              |
| 0                 | Х      | 1     | 8               | 6            |
| 1                 | 00     | 1     | 26              | 6            |
| 1                 | 01     | 1     | 18              | 3            |
| 1                 | 10     | 1     | 12              | 2            |
| 1                 | 11     | 1     | 8               |              |

The total conversion time depends upon: the sample time (as determined by ADLSMP and ADLSTS bits), the MCU bus frequency, the conversion mode (as determined by MODE bits), the high speed configuration (ADHSC bit), and the frequency of the conversion clock ( $f_{ADCK}$ ).

#### **Functional description**

The ADHSC bit is used to configure a higher clock input frequency. This will allow faster overall conversion times. To meet internal ADC timing requirements, the ADHSC bit adds additional ADCK cycles. Conversions with ADHSC = 1 take two more ADCK cycles. ADHSC should be used when the ADCLK exceeds the limit for ADHSC = 0.

After the module becomes active, sampling of the input begins. ADLSMP and ADLSTS select between sample times based on the conversion mode that is selected. When sampling is completed, the converter is isolated from the input channel and a successive approximation algorithm is performed to determine the digital value of the analog signal. The result of the conversion is transferred to Rn upon completion of the conversion algorithm.

If the bus frequency is less than the  $f_{ADCK}$  frequency, precise sample time for continuous conversions cannot be guaranteed when short sample is enabled (ADLSMP=0).

The maximum total conversion time is determined by the clock source chosen and the divide ratio selected. The clock source is selectable by the ADICLK bits, and the divide ratio is specified by the ADIV bits.

The maximum total conversion time for all configurations is summarized in the equation below. Refer to the following tables for the variables referenced in the equation.

 $ConversionTime = SFCAdder + AverageNum \times (BCT + LSTAdder + HSCAdder)$ 

### Figure 29-46. Conversion time equation

Table 29-54. Single or first continuous time adder (SFCAdder)

| ADLSMP | ADACKE<br>N | ADICLK Single or first continuous time adder (SFC) |                                                 |  |
|--------|-------------|----------------------------------------------------|-------------------------------------------------|--|
| 1      | х           | 0x, 10                                             | 3 ADCK cycles + 5 bus clock cycles              |  |
| 1      | 1           | 11                                                 | 3 ADCK cycles + 5 bus clock cycles <sup>1</sup> |  |
| 1      | 0           | 11                                                 | 5 μs + 3 ADCK cycles + 5 bus clock cycles       |  |
| 0      | х           | 0x, 10                                             | 5 ADCK cycles + 5 bus clock cycl                |  |
| 0      | 1           | 11                                                 | 5 ADCK cycles + 5 bus clock cycles <sup>1</sup> |  |
| 0      | 0           | 11                                                 | 5 μs + 5 ADCK cycles + 5 bus clock cycles       |  |

<sup>1.</sup> To achieve this time, ADACKEN must be 1 for at least 5  $\mu s$  prior to the conversion is initiated.

### Table 29-55. Average number factor (AverageNum)

| AVGE | AVGS[1:0] | Average number factor (AverageNum) |
|------|-----------|------------------------------------|
| 0    | xx        | 1                                  |
| 1    | 00        | 4                                  |
| 1    | 01        | 8                                  |

Table continues on the next page...

### Table 29-55. Average number factor (AverageNum) (continued)

| AVGE | AVGS[1:0] | Average number factor (AverageNum) |
|------|-----------|------------------------------------|
| 1    | 10        | 16                                 |
| 1    | 11        | 32                                 |

### **Table 29-56. Base Conversion Time (BCT)**

| Mode     | Base conversion time (BCT) |
|----------|----------------------------|
| 8b s.e.  | 17 ADCK cycles             |
| 10b s.e. | 20 ADCK cycles             |
| 12b s.e. | 20 ADCK cycles             |

### Table 29-57. Long sample time adder (LSTAdder)

| ADLSMP | ADLSTS | Long sample time adder (LSTAdder) |
|--------|--------|-----------------------------------|
| 0      | xx     | 0 ADCK cycles                     |
| 1      | 00     | 20 ADCK cycles                    |
| 1      | 01     | 12 ADCK cycles                    |
| 1      | 10     | 6 ADCK cycles                     |
| 1      | 11     | 2 ADCK cycles                     |

### Table 29-58. High Speed Conversion time Adder (HSCAdder)

| ADHSC High Speed Conversion Time Adder (HSCAdder) |               |
|---------------------------------------------------|---------------|
| 0                                                 | 0 ADCK cycles |
| 1                                                 | 2 ADCK cycles |

### **Note**

The ADCK frequency must be between  $f_{ADCK}$  minimum and  $f_{ADCK}$  maximum to meet ADC specifications.

## 29.4.4.6 Conversion time examples

The following examples use Figure 29-46 and the information provided in Table 29-54 through Table 29-58.

### 29.4.4.6.1 Typical conversion time configuration

A typical configuration for ADC conversion is: 10-bit mode, with the bus clock selected as the input clock source, the input clock divide-by-1 ratio selected, and a bus frequency of 8 MHz, long sample time disabled and high speed conversion disabled. The conversion time for a single conversion is calculated by using Figure 29-46 and the information provided in Table 29-54 through Table 29-58. The table below list the variables of Figure 29-46.

| Variable   | Time                               |  |
|------------|------------------------------------|--|
| SFCAdder   | 5 ADCK cycles + 5 bus clock cycles |  |
| AverageNum | 1                                  |  |
| BCT        | 20 ADCK cycles                     |  |
| LSTAdder   | 0                                  |  |
| HSCAdder   | 0                                  |  |

Table 29-59. Typical conversion time

The resulting conversion time is generated using the parameters listed in the proceeding table. Therefore, for a bus clock equal to 8 MHz and an ADCK equal to 8 MHz the resulting conversion time is 3.75 µs.

### 29.4.4.6.2 Short conversion time configuration

A configuration for short ADC conversion is: 8-bit single ended mode with the bus clock selected as the input clock source, the input clock divide-by-1 ratio selected, a bus frequency of 20 MHz, long sample time disabled, and high speed conversion enabled. The conversion time for this conversion is calculated by using Figure 29-46 and the information provided in Table 29-54 through Table 29-58. The table below list the variables of Figure 29-46.

| Variable   | Time                               |
|------------|------------------------------------|
| SFCAdder   | 5 ADCK cycles + 5 bus clock cycles |
| AverageNum | 1                                  |
| ВСТ        | 17 ADCK cycles                     |
| LSTAdder   | 0 ADCK cycles                      |
| HSCAdder   | 2                                  |

Table 29-60. Typical conversion time

The resulting conversion time is generated using the parameters listed in in the preceding table. Therefore, for bus clock equal to 20 MHz and ADCK equal to 20 MHz, the resulting conversion time is  $1.45 \, \mu s$ .

## 29.4.4.7 Hardware average function

The hardware average function can be enabled (AVGE=1) to perform a hardware average of multiple conversions. The number of conversions is determined by the AVGS[1:0] bits, which select 4, 8, 16, or 32 conversions to be averaged. While the hardware average function is in progress, the ADACT bit will be set.

After the selected input is sampled and converted, the result is placed in an accumulator from which an average is calculated once the selected number of conversions has been completed. When hardware averaging is selected, the completion of a single conversion will not set the COCO bit.

If the compare function is either disabled or evaluates true, after the selected number of conversions are completed, the average conversion result is transferred into the data result registers, Rn, and the COCO bit is set. An ADC interrupt is generated upon the setting of COCO if the respective ADC interrupt is enabled (AIEN=1).

### **Note**

The hardware average function can perform conversions on a channel while the MCU is in Wait or Normal Stop modes. The ADC interrupt wakes the MCU when the hardware average is completed if SC1n[AIEN] bit was set.

# 29.4.5 Automatic compare function

The compare function can be configured to check if the result is less than or greater-than-or-equal-to a single compare value, or if the result falls within or outside a range determined by two compare values. The compare mode is determined by ACFGT, ACREN, and the values in the compare value registers (CV1 and CV2). After the input is sampled and converted, the compare values (CV1 and CV2) are used as described in the following table. There are six compare modes as shown in the following table.

**ADCCV1** relative to Compare mode **ACFGT ACREN Function** ADCCV2 description 0 0 Less than threshold Compare true if the result is less than the CV1 registers. 1 0 Greater than or equal Compare true if the to threshold result is greater than or equal to CV1 registers.

Table 29-61. Compare modes

Table continues on the next page...

#### **Functional description**

Table 29-61. Compare modes (continued)

| ACFGT | ACREN | ADCCV1 relative to ADCCV2 | Function                     | Compare mode description                                                                                       |
|-------|-------|---------------------------|------------------------------|----------------------------------------------------------------------------------------------------------------|
| 0     | 1     | Less than or equal        | Outside range, not inclusive | Compare true if the result is less than CV1 Or the result is greater than CV2.                                 |
| 0     | 1     | Greater than              | Inside range, not inclusive  | Compare true if the result is less than CV1  And the result is greater than CV2.                               |
| 1     | 1     | Less than or equal        | Inside range, inclusive      | Compare true if the result is greater than or equal to CV1 <b>And</b> the result is less than or equal to CV2. |
| 1     | 1     | Greater than              | Outside range, inclusive     | Compare true if the result is greater than or equal to CV1 <b>Or</b> the result is less than or equal to CV2.  |

With the ADC range enable bit set, ADCREN =1, and if compare value register 1 (CV1 value) is less than or equal to the compare value register 2 (CV2 value), then setting ACFGT will select a trigger-if-inside-compare-range inclusive-of-endpoints function. Clearing ACFGT will select a trigger-if-outside-compare-range, not-inclusive-of-endpoints function.

If CV1 is greater than CV2, setting ACFGT will select a trigger-if-outside-comparerange, inclusive-of-endpoints function. Clearing ACFGT will select a trigger-if-insidecompare-range, not-inclusive-of-endpoints function.

If the condition selected evaluates true, COCO is set.

Upon completion of a conversion while the compare function is enabled, if the compare condition is not true, COCO is not set and the conversion result data will not be transferred to the result register. If the hardware averaging function is enabled, the compare function compares the averaged result to the compare values. The same compare function definitions apply. An ADC interrupt is generated upon the setting of COCO if the respective ADC interrupt is enabled (AIEN=1).

#### **Note**

The compare function can monitor the voltage on a channel while the MCU is in Wait or Normal Stop modes. The ADC interrupt wakes the MCU when the compare condition is met.

### 29.4.6 Calibration function

The ADC contains a self-calibration function that is required to achieve the specified accuracy. Calibration must be run, or valid calibration values written, after any reset and before a conversion is initiated. The calibration function sets the offset calibration value and the plus-side calibration values. The offset calibration value is automatically stored in the ADC offset correction register (OFS), and the plus-side calibration values are automatically stored in the ADC plus-side calibration (CLPx) registers. The user must configure the ADC correctly prior to calibration, and must generate the plus-side gain calibration results and store them in the ADC plus-side gain register (PG) after the calibration function completes.

Prior to calibration, the user must configure the ADC's clock source and frequency, low power configuration, voltage reference selection, sample time, and high speed configuration according to the application's clock source availability and needs. If the application uses the ADC in a wide variety of configurations, the configuration for which the highest accuracy is required should be selected, or multiple calibrations can be done for the different configurations. For best calibration results, it is recommended to set hardware averaging to maximum (AVGE=1, AVGS=11 for average of 32), ADC clock frequency f<sub>ADCK</sub> less than or equal to 4 MHz, V<sub>REFH</sub>=V<sub>DDA</sub>, and to calibrate at nominal voltage and temperature. The input channel, conversion mode continuous function, compare function, resolution mode, and single-ended mode are all ignored during the calibration function.

To initiate calibration, the user sets the CAL bit and the calibration will automatically begin if the ADTRG bit is 0. If ADTRG is 1, the CAL bit will not get set and the calibration fail flag (CALF) will be set. While calibration is active, no ADC register can be written and no stop mode may be entered, or the calibration routine will be aborted causing the CAL bit to clear and the CALF bit to set. At the end of a calibration sequence, the COCO bit of the SC1A register will be set. The AIEN bit can be used to allow an interrupt to occur at the end of a calibration sequence. At the end of the calibration routine, if the CALF bit is not set, the automatic calibration routine completed successfully.

To complete calibration, the user must generate the gain calibration values using the following procedure:

- 1. Initialize (clear) a 16-bit variable in RAM.
- 2. Add the plus-side calibration results CLP0, CLP1, CLP2, CLP3, CLP4, CLPS, and CLPD to the variable.

#### **Functional description**

- 3. Divide the variable by two.
- 4. Set the MSB of the variable.
- 5. The previous two steps can be achieved by setting the carry bit, rotating to the right through the carry bit on the high byte and again on the low byte.
- 6. Store the value in the plus-side gain calibration register (PG).

When calibration is complete, the user may reconfigure and use the ADC as desired. A second calibration may also be performed if desired by clearing and again setting the CAL bit.

Overall, the calibration routine may take as many as 14k ADCK cycles and 100 bus cycles, depending on the results and the clock source chosen. For an 8 MHz clock source, this length amounts to about 1.7 ms. To reduce this latency, the calibration values (offset, plus-side gain, and plus-side calibration values) may be stored in flash memory after an initial calibration and recovered prior to the first ADC conversion. This method should reduce the calibration latency to 20 register store operations on all subsequent power, reset, or Low Power Stop mode recoveries.

### 29.4.7 User defined offset function

The ADC offset correction register (OFS) contains the user selected or calibration generated offset error correction value. This register is a 2's complement, left justified. The value in the offset correction register (OFS) is subtracted from the conversion and the result is transferred into the result registers (Rn). If the result is above the maximum or below the minimum result value, it is forced to the appropriate limit for the current mode of operation.

The formatting of the ADC offset correction register is different from the data result register (Rn) to preserve the resolution of the calibration value regardless of the conversion mode selected. Lower order bits are ignored in lower resolution modes. For example, in 8-bit single-ended mode, the bits OFS[14:7] are subtracted from D[7:0]; bit OFS[15] indicates the sign (negative numbers are effectively added to the result) and bits OFS[6:0] are ignored.

OFS is automatically set according to calibration requirements once the self calibration sequence is done (CAL is cleared). The user may write to OFS to override the calibration result if desired. If the offset correction register is written by the user to a value that is different from the calibration value, the ADC error specifications may not be met. It is recommended that the value generated by the calibration function be stored in memory before overwriting with a user specified value.

#### **Note**

There is an effective limit to the values of offset that can be set by the user. If the magnitude of the offset is too great, the results of the conversions will cap off at the limits.

The offset calibration function may be employed by the user to remove application offsets or DC bias values. The offset correction register, OFS may be written with a number in 2's complement format and this offset will be subtracted from the result (or hardware averaged value). To add an offset, store the negative offset in 2's complement format and the effect will be an addition. An offset correction that results in an out-of-range value will be forced to the minimum or maximum value (the minimum value for single-ended conversions is 0x0000).

To preserve accuracy, the calibrated offset value initially stored in the OFS register must be added to the user defined offset. For applications that may change the offset repeatedly during operation, it is recommended to store the initial offset calibration value in flash so it can be recovered and added to any user offset adjustment value and the sum stored in the OFS register.

# 29.4.8 Temperature sensor

The ADC module includes a temperature sensor whose output is connected to one of the ADC analog channel inputs. The following equation provides an approximate transfer function of the temperature sensor.

$$Temp = 25 - \left(\left(V_{TEMP} - V_{TEMP25}\right) \div m\right)$$

Figure 29-47. Approximate transfer function of the temperature sensor

#### where:

- $\bullet$  V<sub>TEMP</sub> is the voltage of the temperature sensor channel at the ambient temperature.
- $V_{TEMP25}$  is the voltage of the temperature sensor channel at 25 °C.
- m is the hot or cold voltage versus temperature slope in V/°C.

For temperature calculations, use the  $V_{TEMP25}$  and m values from the ADC Electricals table.

#### **Functional description**

In application code, the user reads the temperature sensor channel, calculates  $V_{TEMP}$ , and compares to  $V_{TEMP25}$ . If  $V_{TEMP}$  is greater than  $V_{TEMP25}$  the cold slope value is applied in the preceding equation. If  $V_{TEMP}$  is less than  $V_{TEMP25}$ , the hot slope value is applied in the preceding equation.

For more information on using the temperature sensor, see the application note titled *Temperature Sensor for the HCS08 Microcontroller Family* (document AN3031).

# 29.4.9 MCU wait mode operation

Wait mode is a lower power-consumption standby mode from which recovery is fast because the clock sources remain active. If a conversion is in progress when the MCU enters Wait mode, it continues until completion. Conversions can be initiated while the MCU is in Wait mode by means of the hardware trigger or if continuous conversions are enabled.

The bus clock, bus clock divided by two, and ADACK are available as conversion clock sources while in Wait mode. The use of ALTCLK as the conversion clock source in Wait is dependent on the definition of ALTCLK for this MCU. Refer to the Chip Configuration information on ALTCLK specific to this MCU.

If the compare and hardware averaging functions are disabled, a conversion complete event sets the COCO and generates an ADC interrupt to wake the MCU from Wait mode if the respective ADC interrupt is enabled (AIEN=1). If the hardware averaging function is enabled, the COCO will set (and generate an interrupt if enabled) when the selected number of conversions are completed. If the compare function is enabled, the COCO will set (and generate an interrupt if enabled) only if the compare conditions are met. If a single conversion is selected and the compare trigger is not met, the ADC will return to its idle state and cannot wake the MCU from Wait mode unless a new conversion is initiated by the hardware trigger.

# 29.4.10 MCU Normal Stop mode operation

Stop mode is a low power-consumption standby mode during which most or all clock sources on the MCU are disabled.

## 29.4.10.1 Normal Stop mode with ADACK disabled

If the asynchronous clock, ADACK, is not selected as the conversion clock, executing a stop instruction aborts the current conversion and places the ADC in its idle state. The contents of the ADC registers, including Rn, are unaffected by Normal Stop mode. After exiting from Normal Stop mode, a software or hardware trigger is required to resume conversions.

## 29.4.10.2 Normal Stop mode with ADACK enabled

If ADACK is selected as the conversion clock, the ADC continues operation during Normal Stop mode. Refer to the Chip Configuration chapter for configuration information for this MCU.

If a conversion is in progress when the MCU enters Normal Stop mode, it continues until completion. Conversions can be initiated while the MCU is in Normal Stop mode by means of the hardware trigger or if continuous conversions are enabled.

If the compare and hardware averaging functions are disabled, a conversion complete event sets the COCO and generates an ADC interrupt to wake the MCU from Normal Stop mode if the respective ADC interrupt is enabled (AIEN = 1). The result register will contain the data from the first completed conversion that occurred during Normal Stop mode. If the hardware averaging function is enabled, the COCO will set (and generate an interrupt if enabled) when the selected number of conversions are completed. If the compare function is enabled, the COCO will set (and generate an interrupt if enabled) only if the compare conditions are met. If a single conversion is selected and the compare is not true, the ADC will return to its idle state and cannot wake the MCU from Normal Stop mode unless a new conversion is initiated by another hardware trigger.

# 29.4.11 MCU Low Power Stop mode operation

The ADC module is automatically disabled when the MCU enters Low Power Stop mode. All module registers contain their reset values following exit from Low Power Stop mode. Therefore, the module must be re-enabled and re-configured following exit from Low Power Stop mode.

#### NOTE

For the chip specific modes of operation, refer to the Power Management information for the device.

### 29.5 Initialization information

This section gives an example that provides some basic direction on how to initialize and configure the ADC module. You can configure the module for 12-bit, 10-bit, or 8-bit single-ended resolution, single or continuous conversion, and a polled or interrupt approach, among many other options. Refer to Table 29-57, Table 29-58, and Table 29-59 for information used in this example.

#### **Note**

Hexadecimal values are designated by a preceding 0x, binary values designated by a preceding %, and decimal values have no preceding character.

# 29.5.1 ADC module initialization example

This section provides details about the ADC module initialization.

# 29.5.1.1 Initialization sequence

Before the ADC module can be used to complete conversions, an initialization procedure must be performed. A typical sequence is as follows:

- 1. Calibrate the ADC by following the calibration instructions in Calibration function.
- 2. Update the configuration register (CFG) to select the input clock source and the divide ratio used to generate the internal clock, ADCK. This register is also used for selecting sample time and low-power configuration.
- 3. Update status and control register 2 (SC2) to select the conversion trigger (hardware or software) and compare function options, if enabled.
- 4. Update status and control register 3 (SC3) to select whether conversions will be continuous or completed only once (ADCO) and to select whether to perform hardware averaging.
- 5. Update the status and control register (SC1:SC1n) to enable or disable conversion complete interrupts. Also, select the input channel on which to perform conversions.

## 29.5.1.2 Pseudo-code example

In this example, the ADC module is set up with interrupts enabled to perform a single 10-bit conversion at low power with a long sample time on input channel 1, where the internal ADCK clock is derived from the bus clock divided by 1.

### CFG1 = 0x98 (%10011000)

```
Bit 7
                ADLPC
                                Configures for low power (lowers maximum clock speed.
                                Sets the ADCK to the input clock ÷ 1.
        Bit 6:5 ADIV
                        00
        Bit 4
               ADLSMP 1
                                Configures for long sample time.
               ACREN 0
        Bit 3
                                Compare range disabled.
        Bit 2
                DMAEN
                        0
                                DMA request disabled.
        Bit 1:0 REFSEL 00
                                Selects default voltage reference pin pair (External pins V_{\text{REFH}}
and V_{\text{REFL}}).
```

### SC2 = 0x00 (%00000000)

```
Bit 7
        ADACT
                        Flag indicates if a conversion is in progress.
                0
Bit 6
        ADTRG
                0
                        Software trigger selected.
                        Compare function disabled.
Bit 5
       ACFE
                0
                        Not used in this example.
Bit 4
       ACFGT
Bit 3:2
                0.0
                        Reserved, always reads zero.
                        Reserved for Freescale's internal use; always write zero.
Bit 1:0
```

### SC1A = 0x41 (%01000001)

```
Bit 7 COCO 0 Read-only flag which is set when a conversion completes. Bit 6 AIEN 1 Conversion complete interrupt enabled. Bit 5 DIFF 0 Single-ended conversion selected. Bit 4:0 ADCH 00001 Input channel 1 selected as ADC input channel.
```

#### RA = 0xxx

Holds results of conversion.

#### CV = 0xxx

Holds compare value when compare function enabled.



Figure 29-48. Initialization Flowchart for Example

# 29.6 Application information

This section contains information for using the ADC module in applications. The ADC has been designed to be integrated into a microcontroller for use in embedded control applications requiring an ADC.

# 29.6.1 External pins and routing

The following sections discuss the external pins associated with the ADC module and how they should be used for best results.

# 29.6.1.1 Analog supply pins

The ADC module has analog power and ground supplies ( $V_{DDA}$  and  $V_{SSA}$ ) available as separate pins on some devices.  $V_{SSA}$  is shared on the same pin as the MCU digital VSS on some devices. On other devices,  $V_{SSA}$  and  $V_{DDA}$  are shared with the MCU digital

supply pins. In these cases, there are separate pads for the analog supplies bonded to the same pin as the corresponding digital supply so that some degree of isolation between the supplies is maintained.

When available on a separate pin, both  $V_{DDA}$  and  $V_{SSA}$  must be connected to the same voltage potential as their corresponding MCU digital supply ( $V_{DD}$  and  $V_{SS}$ ) and must be routed carefully for maximum noise immunity and bypass capacitors placed as near as possible to the package.

If separate power supplies are used for analog and digital power, the ground connection between these supplies must be at the  $V_{SSA}$  pin. This should be the only ground connection between these supplies if possible. The  $V_{SSA}$  pin makes a good single point ground location.

## 29.6.1.2 Analog voltage reference pins

In addition to the analog supplies, the ADC module has connections for two reference voltage inputs used by the converter,  $V_{REFSH}$  and  $V_{REFSL}$ .  $V_{REFSH}$  is the high reference voltage for the converter.  $V_{REFSL}$  is the low reference voltage for the converter.

The ADC can be configured to accept one of two voltage reference pairs for  $V_{REFSH}$  and  $V_{REFSL}$ . Each pair contains a positive reference and a ground reference. The two pairs are external ( $V_{REFH}$  and  $V_{REFL}$ ) and alternate ( $V_{ALTH}$  and  $V_{ALTL}$ ). These voltage references are selected using the REFSEL bits in the SC2 register. The alternate ( $V_{ALTH}$  and  $V_{ALTL}$ ) voltage reference pair may select additional external pins or internal sources depending on MCU configuration. Refer to the Chip Configuration information on the Voltage References specific to this MCU.

In some packages, the external or alternate pairs are connected in the package to  $V_{DDA}$  and  $V_{SSA}$ , respectively. One of these positive references may be shared on the same pin as  $V_{DDA}$  on some devices. One of these ground references may be shared on the same pin as  $V_{SSA}$  on some devices.

If externally available, the positive reference may be connected to the same potential as  $V_{DDA}$  or may be driven by an external source to a level between the minimum Ref Voltage High and the  $V_{DDA}$  potential (the positive reference must never exceed  $V_{DDA}$ ). If externally available, the ground reference must be connected to the same voltage potential as  $V_{SSA}$ . The voltage reference pairs must be routed carefully for maximum noise immunity and bypass capacitors placed as near as possible to the package.

AC current in the form of current spikes required to supply charge to the capacitor array at each successive approximation step is drawn through the  $V_{REFH}$  and  $V_{REFL}$  loop. The best external component to meet this current demand is a 0.1  $\mu F$  capacitor with good high

#### **Application information**

frequency characteristics. This capacitor is connected between  $V_{REFH}$  and  $V_{REFL}$  and must be placed as near as possible to the package pins. Resistance in the path is not recommended because the current causes a voltage drop that could result in conversion errors. Inductance in this path must be minimum (parasitic only).

## 29.6.1.3 Analog input pins

The external analog inputs are typically shared with digital I/O pins on MCU devices.

Empirical data shows that capacitors on the analog inputs improve performance in the presence of noise or when the source impedance is high. Use of 0.01  $\mu$ F capacitors with good high-frequency characteristics is sufficient. These capacitors are not necessary in all cases, but when used they must be placed as near as possible to the package pins and be referenced to  $V_{SSA}$ .

For proper conversion, the input voltage must fall between  $V_{REFH}$  and  $V_{REFL}$ . If the input is equal to or exceeds  $V_{REFH}$ , the converter circuit converts the signal to 0xFFF (full scale 12-bit representation), 0x3FF (full scale 10-bit representation) or 0xFF (full scale 8-bit representation). If the input is equal to or less than  $V_{REFL}$ , the converter circuit converts it to 0x000. Input voltages between  $V_{REFH}$  and  $V_{REFL}$  are straight-line linear conversions. There is a brief current associated with  $V_{REFL}$  when the sampling capacitor is charging.

For minimal loss of accuracy due to current injection, pins adjacent to the analog input pins should not be transitioning during conversions.

## 29.6.2 Sources of error

Several sources of error exist for A/D conversions. These are discussed in the following sections.

# 29.6.2.1 Sampling error

For proper conversions, the input must be sampled long enough to achieve the proper accuracy.

RAS + RADIN =SC / (FMAX \* NUMTAU \* CADIN)

Figure 29-49. Sampling equation

Where:

RAS = External analog source resistance

SC = Number of ADCK cycles used during sample window

CADIN = Internal ADC input capacitance

 $NUMTAU = -ln(LSBERR / 2^{N})$ 

LSBERR = value of acceptable sampling error in LSBs

N = 8 in 8-bit mode, 10 in 10-bit mode, 12 in 12-bit mode

Higher source resistances or higher-accuracy sampling is possible by setting ADLSMP and changing the ADLSTS bits (to increase the sample window) or decreasing ADCK frequency to increase sample time.

## 29.6.2.2 Pin leakage error

Leakage on the I/O pins can cause conversion error if the external analog source resistance ( $R_{AS}$ ) is high. If this error cannot be tolerated by the application, keep  $R_{AS}$  lower than  $V_{REFH}$  / ( $4 \times I_{LEAK} \times 2^N$ ) for less than 1/4 LSB leakage error (N = 8 in 8-bit mode, 10 in 10-bit mode, 12 in 12-bit mode).

### 29.6.2.3 Noise-induced errors

System noise that occurs during the sample or conversion process can affect the accuracy of the conversion. The ADC accuracy numbers are guaranteed as specified only if the following conditions are met:

- There is a 0.1  $\mu$ F low-ESR capacitor from  $V_{REFH}$  to  $V_{REFL}$ .
- There is a 0.1  $\mu$ F low-ESR capacitor from  $V_{DDA}$  to  $V_{SSA}$ .
- If inductive isolation is used from the primary supply, an additional 1  $\mu F$  capacitor is placed from  $V_{DDA}$  to  $V_{SSA}$ .
- V<sub>SSA</sub> (and V<sub>REFL</sub>, if connected) is connected to V<sub>SS</sub> at a quiet point in the ground plane.
- Operate the MCU in Wait or Normal Stop mode before initiating (hardware triggered conversions) or immediately after initiating (hardware or software triggered conversions) the ADC conversion.

#### **Application information**

- For software triggered conversions, immediately follow the write to the SC1 register with a wait instruction or stop instruction.
- For Normal Stop mode operation, select ADACK as the clock source. Operation
  in Normal Stop reduces V<sub>DD</sub> noise but increases effective conversion time due to
  stop recovery.
- There is no I/O switching, input or output, on the MCU during the conversion.

There are some situations where external system activity causes radiated or conducted noise emissions or excessive  $V_{DD}$  noise is coupled into the ADC. In these situations, or when the MCU cannot be placed in Wait or Normal Stop or I/O activity cannot be halted, these recommended actions may reduce the effect of noise on the accuracy:

- Place a 0.01 µF capacitor (C<sub>AS</sub>) on the selected input channel to V<sub>REFL</sub> or V<sub>SSA</sub> (this improves noise issues, but affects the sample rate based on the external analog source resistance).
- Average the result by converting the analog input many times in succession and dividing the sum of the results. Four samples are required to eliminate the effect of a 1 LSB, one-time error.
- Reduce the effect of synchronous noise by operating off the asynchronous clock (ADACK) and averaging. Noise that is synchronous to ADCK cannot be averaged out.

## 29.6.2.4 Code width and quantization error

The ADC quantizes the ideal straight-line transfer function into 4096 steps (in 12-bit mode). Each step ideally has the same height (1 code) and width. The width is defined as the delta between the transition points to one code and the next. The ideal code width for an N bit converter (in this case N can be 12, 10, or 8), defined as 1 LSB, is:

$$1LSB=(V_{REFH})/2^N$$

### Figure 29-50. Ideal code width for an N bit converter

There is an inherent quantization error due to the digitization of the result. For 8-bit, 10-bit, or 12-bit conversions, the code transitions when the voltage is at the midpoint between the points where the straight line transfer function is exactly represented by the

actual transfer function. Therefore, the quantization error will be  $\pm$  1/2 LSB in 8-bit, 10-bit, or 12-bit modes. As a consequence, however, the code width of the first (0x000) conversion is only 1/2 LSB and the code width of the last (0xFF or 0x3FF) is 1.5 LSB.

# 29.6.2.5 Linearity errors

The ADC may also exhibit non-linearity of several forms. Every effort has been made to reduce these errors, but the system designers should be aware of them because they affect overall accuracy. These errors are:

- Zero-scale error (E<sub>ZS</sub>) (sometimes called offset): This error is defined as the difference between the actual code width of the first conversion and the ideal code width (1/2 LSB in 8-bit, 10-bit, or 12-bit modes). If the first conversion is 0x001, the difference between the actual 0x001 code width and its ideal (1 LSB) is used.
- Full-scale error (E<sub>FS</sub>): This error is defined as the difference between the actual code width of the last conversion and the ideal code width (1.5 LSB in 8-bit, 10-bit, or 12-bit modes). If the last conversion is 0x3FE, the difference between the actual 0x3FE code width and its ideal (1 LSB) is used.
- Differential non-linearity (DNL): This error is defined as the worst-case difference between the actual code width and the ideal code width for all conversions.
- Integral non-linearity (INL): This error is defined as the highest-value the (absolute value of the) running sum of DNL achieves. More simply, this is the worst-case difference of the actual transition voltage to a given code and its corresponding ideal transition voltage, for all codes.
- Total unadjusted error (TUE): This error is defined as the difference between the actual transfer function and the ideal straight-line transfer function and includes all forms of error.

## 29.6.2.6 Code jitter, non-monotonicity, and missing codes

Analog-to-digital converters are susceptible to three special forms of error. These are code jitter, non-monotonicity, and missing codes.

Code jitter is when, at certain points, a given input voltage converts to one of two values when sampled repeatedly. Ideally, when the input voltage is infinitesimally smaller than the transition voltage, the converter yields the lower code (and vice-versa). However, even small amounts of system noise can cause the converter to be indeterminate (between two codes) for a range of input voltages around the transition voltage.

#### **Application information**

This error may be reduced by repeatedly sampling the input and averaging the result. Additionally, the techniques discussed in Noise-induced errors reduces this error.

Non-monotonicity is defined as when, except for code jitter, the converter converts to a lower code for a higher input voltage. Missing codes are those values never converted for any input value.

In 8-bit or 10-bit mode, the ADC is guaranteed to be monotonic and have no missing codes.

# Chapter 30 Comparator (CMP)

### 30.1 Introduction

The Comparator module (CMP) provides a circuit for comparing two analog input voltages. The comparator circuit is designed to operate across the full range of the supply voltage (rail to rail operation).

The Analog MUX (ANMUX) provides a circuit for selecting an analog input signal from eight channels. One signal provided by the 6-bit DAC. The mux circuit is designed to operate across the full range of the supply voltage.

The 6-bit DAC is 64-tap resistor ladder network which provides a selectable voltage reference for applications where voltage reference is needed. The 64-tap resistor ladder network divides the supply reference Vin into 64 voltage level. A 6-bit digital signal input selects output voltage level, which varies from Vin to Vin/64. Vin can be selected from two voltage sources,  $V_{in1}$  and  $V_{in2}$ . The 6-bit DAC from a comparator is available as an on-chip internal signal only and is not available externally to a pin.

# 30.2 CMP Features

The CMP has the following features:

- Operates over the entire supply range
- Inputs may range from rail to rail
- Programmable hysteresis control
- Selectable interrupt on rising edge, falling edge, or both rising or falling edges of comparator output
- Selectable inversion on comparator output
- Comparator output may be:

#### 6-bit DAC Key Features

- Sampled
- Windowed (ideal for certain PWM zero-crossing-detection applications)
- Digitally Filtered
  - Filter can be bypassed
  - Can be clocked via external SAMPLE signal or scaled bus clock
- External hysteresis can be used at the same time that the output filter is used for internal functions.
- Two software selectable performance levels:
  - Shorter propagation delay at the expense of higher power
  - Low power, with longer propagation delay
- Support DMA transfer
  - A comparison event can be selected to trigger a DMA transfer.
- Functional in all modes of operation.
- The window and filter functions are not available in Stop, VLPS, LLS and VLLSx modes.

# 30.3 6-bit DAC Key Features

- 6-bit resolution
- Selectable supply reference source
- Power down mode to conserve power when it is not being used
- Output can be routed to internal comparator input

# 30.4 ANMUX Key Features

- Two 8 to 1 channel mux
- Operates the entire supply range

# 30.5 CMP, DAC, and ANMUX Diagram

The following figure shows the block diagram for the High Speed Comparator, Digital to Analog Converter, and Analog MUX modules.



Figure 30-1. CMP, DAC and ANMUX Blocks Diagram

# 30.6 CMP Block Diagram

The following figure shows the block diagram for the Comparator module.



Figure 30-2. Comparator Module Block Diagram

In the CMP block diagram:

- The Window Control block is bypassed when CR1[WE] = 0
- If CR1[WE] = 1, the comparator output will be sampled on every bus clock when WINDOW=1 to generate COUTA. Sampling does NOT occur when WINDOW = 0.
- The Filter Block is bypassed when not in use.
- The Filter Block acts as a simple sampler if the filter is bypassed and CR0[FILTER\_CNT] is set to 0x01.
- The Filter Block filters based on multiple samples when the filter is bypassed and CR0[FILTER\_CNT] is set greater than 0x01.

- If CR1[SE] = 1, the external SAMPLE input is used as sampling clock
- IF CR1[SE] = 0, the divided bus clock is used as sampling clock
- If enabled, the Filter Block will incur up to 1 bus clock additional latency penalty on COUT due to the fact that COUT (which is crossing clock domain boundaries) must be resynchronized to the bus clock.
- CR1[WE] and CR1[SE] are mutually exclusive.

# 30.7 Memory Map/Register Definitions

Address offsets are in terms of bytes for the ColdFire V1 architecture.

The ColdFire V1 IP Bus interface is designed such that a single 16-bit access by the MCU is serialized into two 8-bit accesses onto the bus. Similarly, a single 32-bit access by the MCU is serialized into four 8-bit accesses onto the bus. The register order defined above is such that a single 32-bit access by the ColdFire MCU could (in this order):

- 1. Initialize the mux and delay block settings
- 2. Configure and enable the analog comparator
- 3. Configure filtering
- 4. Clear edge detection status and enable interrupts

### **CMPx** memory map

| Absolute address (hex) | Register name                              | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|------------------------|--------------------------------------------|--------------------|--------|-------------|------------------|
| FFFF_8530              | CMP Control Register 0 (CMP0_CR0)          | 8                  | R/W    | 00h         | 30.7.1/<br>682   |
| FFFF_8531              | CMP Control Register 1 (CMP0_CR1)          | 8                  | R/W    | 00h         | 30.7.2/<br>683   |
| FFFF_8532              | CMP Filter Period Register (CMP0_FPR)      | 8                  | R/W    | 00h         | 30.7.3/<br>684   |
| FFFF_8533              | CMP Status and Control Register (CMP0_SCR) | 8                  | R/W    | 00h         | 30.7.4/<br>684   |
| FFFF_8534              | DAC Control Register (CMP0_DACCR)          | 8                  | R/W    | 00h         | 30.7.5/<br>686   |
| FFFF_8535              | MUX Control Register (CMP0_MUXCR)          | 8                  | R/W    | 00h         | 30.7.6/<br>687   |

# 30.7.1 CMP Control Register 0 (CMPx\_CR0)

Addresses: CMP0\_CR0 is FFFF\_8530h base + 0h offset = FFFF\_8530h



### CMPx\_CR0 field descriptions

| Field             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>Reserved     | This read-only bit is reserved and always has the value zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 6–4<br>FILTER_CNT | Filter Sample Count  These bits represent the number of consecutive samples that must agree prior to the comparator ouput filter accepting a new output state. For information regarding filter programming and latency reference the Functional Description.  000 Filter is disabled. If SE = 1, then COUT is a logic zero (this is not a legal state, and is not recommended). If SE = 0, COUT = COUTA.  001 1 consecutive sample must agree (comparator output is simply sampled).  010 2 consecutive samples must agree.  011 3 consecutive samples must agree.  100 4 consecutive samples must agree.  101 5 consecutive samples must agree.  101 6 consecutive samples must agree.  110 7 consecutive samples must agree. |
| 3<br>Reserved     | This read-only bit is reserved and always has the value zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 2<br>Reserved     | This read-only bit is reserved and always has the value zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 1-0<br>HYSTCTR    | Comparator hard block hysteresis control  Defines the programmable hysteresis level. The hysteresis values associated with each level is device-specific. See the device's data sheet for the exact values.  00 Level 0 01 Level 1 10 Level 2 11 Level 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

# 30.7.2 CMP Control Register 1 (CMPx\_CR1)

Addresses: CMP0\_CR1 is FFFF\_8530h base + 1h offset = FFFF\_8531h



### CMPx\_CR1 field descriptions

| Field         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>SE       | Sample Enable  At any given time, either SE or WE can be set. If a write to this register attempts to set both, then SE is set and WE is cleared. However, avoid writing ones to both bit locations because this "11" case is reserved and may change in future implementations.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|               | <ul><li>0 Sampling mode not selected.</li><li>1 Sampling mode selected.</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 6<br>WE       | Windowing Enable  At any given time, either SE or WE can be set. If a write to this register attempts to set both, then SE is set and WE is cleared. However, avoid writing ones to both bit locations because this "11" case is reserved and may change in future implementations.  0 Windowing mode not selected.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|               | 1 Windowing mode selected.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 5<br>Reserved | This read-only bit is reserved and always has the value zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 4<br>PMODE    | Power Mode Select  Under Mode Se |
| 3<br>INV      | Comparator INVERT  This bit allows you to select the polarity of the analog comparator function. It is also driven to the COUT output (on both the device pin and as SCR[COUT]) when CR1[OPE]=0.  Does not invert the comparator output.  Inverts the comparator output.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 2<br>COS      | Comparator Output Select  0 Set CMPO to equal COUT (filtered comparator output).  1 Set CMPO to equal COUTA (unfiltered comparator output).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 1<br>OPE      | Comparator Output Pin Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

Table continues on the next page...

### **Memory Map/Register Definitions**

### CMPx\_CR1 field descriptions (continued)

| Field   | Description                                                                                                                                                                                                                                                                                                                                             |  |  |
|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|         | O The comparator output (CMPO) is not available on the associated CMPO output pin. Instead, the INV bit is driven if the comparator owns the pin (usually a result of properly setting pin mux controls at the SoC level). If the comparator does not own the pin, this bit has no effect.                                                              |  |  |
|         | 1 The comparator output (CMPO) is available on the associated CMPO output pin. The comparator output (CMPO) is driven out on the associated CMPO output pin if the comparator owns the pin. If the comparator does not own the pin, this bit has no effect.                                                                                             |  |  |
| 0<br>EN | Comparator Module Enable  The EN bit enables the Analog Comparator Module. When the module is not enabled, it remains in the off state, and consumes no power. When you select the same input from analog mux to the positive and negative port, the comparator is disabled automatically.  O Analog Comparator disabled.  1 Analog Comparator enabled. |  |  |

## 30.7.3 CMP Filter Period Register (CMPx\_FPR)

Addresses: CMP0\_FPR is FFFF\_8530h base + 2h offset = FFFF\_8532h



### CMPx\_FPR field descriptions

| Field           | Description                                                                                                                                                                                                                                                                    |
|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–0<br>FILT_PER | Filter Sample Period  When CR1[SE] is equal to zero, this field specifies the sampling period, in bus clock cycles, of the comparator output filter. Setting FILT_PER to 0x0 disables the filter. Filter programming and latency details appear in the Functional Description. |
|                 | This field has no effect when CR1[SE] is equal to one. In that case, the external SAMPLE signal is used to determine the sampling period.                                                                                                                                      |

# 30.7.4 CMP Status and Control Register (CMPx\_SCR)

Addresses: CMP0\_SCR is FFFF\_8530h base + 3h offset = FFFF\_8533h



## CMPx\_SCR field descriptions

| Field         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>Reserved | This read-only bit is reserved and always has the value zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 6<br>DMAEN    | DMA Enable Control  The DMAEN bit enables the DMA transfer triggered from the CMP module. When this bit is set, a DMA request is asserted when the CFR or CFF bit is set.                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|               | <ul><li>0 DMA disabled.</li><li>1 DMA enabled.</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 5<br>SMELB    | Stop Mode Edge/Level Interrupt Control  This bit controls whether the CFR and CFF bits are edge sensitive or level sensitive in Stop mode.  NOTE: This bit should always be programmed to 0 to keep the comparator working and to wake up the MCU.                                                                                                                                                                                                                                                                                                                                                                                    |
|               | <ul> <li>CFR/CFF are level sensitive in Stop mode. CFR will be asserted when COUT is high. CFF will be asserted when COUT is low.</li> <li>CFR/CFF are edge sensitive in Stop mode. An active low-to-high transition must be seen on COUT to assert CFR, and an active high-to-low transition must be seen on COUT to assert CFF.</li> </ul>                                                                                                                                                                                                                                                                                          |
| 4<br>IER      | Comparator Interrupt Enable Rising  The IER bit enables the CFR interrupt from the CMP. When this bit is set, an interrupt will be asserted when the CFR bit is set.  0 Interrupt disabled.                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 3<br>IEF      | 1 Interrupt enabled.  Comparator Interrupt Enable Falling  The IEF bit enables the CFF interrupt from the CMP. When this bit is set, an interrupt will be asserted when the CFF bit is set.  0 Interrupt disabled. 1 Interrupt enabled.                                                                                                                                                                                                                                                                                                                                                                                               |
| 2<br>CFR      | Analog Comparator Flag Rising  During normal operation, the CFR bit is set when a rising edge on COUT has been detected. The CFR bit is cleared by writing a logic one to the bit. During Stop modes, CFR can be programmed as either edge or level sensitive via the SMELB bit.  NOTE: Edge detection during Stop mode is only supported on platforms that allow peripherals to be clocked during Stop modes. If the CFR flag is active during Stop mode, then SMELB must be set to 0 for cases where it is not receiving a clock during Stop mode.  O Rising edge on COUT has not been detected.  Rising edge on COUT has occurred. |
| 1<br>CFF      | Analog Comparator Flag Falling  During normal operation, the CFF bit is set when a falling edge on COUT has been detected. The CFF bit is cleared by writing a logic one to the bit. During Stop modes, CFF can be programmed as either edge or level sensitive via the SMELB bit.                                                                                                                                                                                                                                                                                                                                                    |

Table continues on the next page...

#### **Memory Map/Register Definitions**

## CMPx\_SCR field descriptions (continued)

| Field     | Description                                                                                                                                                                                                                                                                                                       |
|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|           | NOTE: Edge detection during Stop mode is only supported on platforms that allow peripherals to be clocked during Stop modes. If the CFF flag is active during Stop mode, then SMELB must be set to 0 for cases where it is not receiving a clock during Stop mode.  O Falling edge on COUT has not been detected. |
|           | 1 Falling edge on COUT has occurred.                                                                                                                                                                                                                                                                              |
| 0<br>COUT | Analog Comparator Output                                                                                                                                                                                                                                                                                          |
|           | Reading the COUT bit will return the current value of the analog comparator output. The register bit is reset to zero and will read as CR1[INV] when the Analog Comparator module is disabled (CR1[EN] = 0). Writes to this bit are ignored.                                                                      |

# 30.7.5 DAC Control Register (CMPx\_DACCR)

Addresses: CMP0\_DACCR is FFFF\_8530h base + 4h offset = FFFF\_8534h



## CMPx\_DACCR field descriptions

| Field      | Description                                                                                                             |
|------------|-------------------------------------------------------------------------------------------------------------------------|
| 7<br>DACEN | DAC Enable                                                                                                              |
|            | This bit is used to enable the DAC. When the DAC is disabled, it is powered down to conserve power.  0 DAC is disabled. |
|            | 1 DAC is enabled.                                                                                                       |
| 6<br>VRSEL | Supply Voltage Reference Source Select                                                                                  |
|            | 0 Vin1 is selected as resistor ladder network supply reference Vin.                                                     |
|            | 1 Vin2 is selected as resistor ladder network supply reference Vin.                                                     |
| 5-0        | DAC Output Voltage Select                                                                                               |
| VOSEL      | This bit selects an output voltage from one of 64 distinct levels.                                                      |
|            | DACO = (Vin/64) * (VOSEL[5:0] + 1), so the DACO range is from Vin/64 to Vin.                                            |

# 30.7.6 MUX Control Register (CMPx\_MUXCR)

PEN and MEN bits should be enabled or disabled together with CR1[EN] bit.

Addresses: CMP0\_MUXCR is FFFF\_8530h base + 5h offset = FFFF\_8535h



## CMPx\_MUXCR field descriptions

| Field       | Description                                                                                                                                                                                                                                                                                                                                                                                            |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>PEN    | PMUX Enable  This bit is used to enable positive MUX. When the PMUX is disabled, the PMUX output is in a high impedance state. When software selects the same input for plus and minus inputs of the comparator, both PMUX and MMUX are disabled automatically.  0 PMUX is disabled. 1 PMUX is enabled.                                                                                                |
| 6<br>MEN    | MMUX Enable  This bit is used to enable negative MUX. When the MMUX is disabled, the MMUX output is in a high impedance state. When software selects the same input for plus and minus inputs of the comparator, both PMUX and MMUX are disabled automatically.  0 MMUX is disabled. 1 MMUX is enabled.                                                                                                |
| 5–3<br>PSEL | Plus Input MUX Control  Determines which input is selected for the plus input of the comparator. For INx inputs, refer to CMP, DAC and ANMUX Blocks Diagram.  NOTE: When an inappropriate operation selects the same input for both MUXes, the comparator automatically shuts down to prevent itself from becoming a noise generator.  000 IN0 001 IN1 010 IN2 011 IN3 100 IN4 101 IN5 110 IN6 111 IN7 |
| 2–0<br>MSEL | Minus Input MUX Control  Determines which input is selected for the minus input of the comparator. For INx inputs, refer to CMP, DAC and ANMUX Blocks Diagram.                                                                                                                                                                                                                                         |

Table continues on the next page...

#### CMPx\_MUXCR field descriptions (continued)

| Field | Description                                                                                                                                                             |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | NOTE: When an inappropriate operation selects the same input for both MUXes, the comparator automatically shuts down to prevent itself from becoming a noise generator. |
|       | 000 IN0                                                                                                                                                                 |
|       | 001 IN1                                                                                                                                                                 |
|       | 010 IN2                                                                                                                                                                 |
|       | 011 IN3                                                                                                                                                                 |
|       | 100 IN4                                                                                                                                                                 |
|       | 101 IN5                                                                                                                                                                 |
|       | 110 IN6                                                                                                                                                                 |
|       | 111 IN7                                                                                                                                                                 |

# 30.8 CMP Functional Description

The Comparator can be used to compare two analog input voltages applied to INP and INM. The analog comparator output (CMPO) is high when the non-inverting input is greater than the inverting input, and is low when the non-inverting input is less than the inverting input. This signal can be selectively inverted by setting CR1[INV] = 1.

The SCR[IER], SCR[IEF], and SCR[SMELB] bits are used to select the condition which will cause the comparator module to assert an interrupt to the processor. SCR[CFF] is set on a falling edge and SCR[CFR] is set on rising edge of the comparator output. The (optionally filtered) comparator output can be read directly through the SCR[COUT] bit.

## 30.8.1 CMP Functional Modes

There are three main sub-blocks to the comparator module: the comparator itself, the window function and the filter function. The filter, CR0[FILTER\_CNT] can be clocked from an internally or external clock source. Additionally, the filter is programmable with respect to how many samples must agree before a change on the output is registered. In the simplest case, only 1 sample must agree. In this case, the filter acts as a simple sampler.

The external sample input is enabled using CR1[SE]. When set, the output of the comparator is sampled only on rising edges of the sample input.

The "windowing mode" is enabled by setting CR1[WE]. When set, the comparator output is sampled only when the WINDOW input signal is equal to one. This feature can be used to ignore the comparator output during time periods in which the input voltages are not valid. This is especially useful when implementing zero-crossing-detection for certain PWM applications.

The comparator filter and sampling features can be combined as shown in the following table. Individual modes are discussed below.

Table 30-15. Comparator Sample/Filter Controls

| Mode # | CR1[EN] | CR1[WE] | CR1[SE] | CR0[FILTER_C<br>NT] | FPR[FILT_PER] | Operation                                                                                                                                                                                      |
|--------|---------|---------|---------|---------------------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1      | 0       | Х       | Х       | Х                   | Х             | Disabled                                                                                                                                                                                       |
|        |         |         |         |                     |               | Refer to the Disabled Mode (# 1).                                                                                                                                                              |
| 2A     | 1       | 0       | 0       | 0x00                | X             | Continuous Mode                                                                                                                                                                                |
| 2B     | 1       | 0       | 0       | Х                   | 0x00          | Refer to the Continuous Mode (#s 2A & 2B).                                                                                                                                                     |
| ЗА     | 1       | 0       | 1       | 0x01                | Х             | Sampled, Non-Filtered mode                                                                                                                                                                     |
| 3B     | 1       | 0       | 0       | 0x01                | > 0x00        | Refer to the Sampled, Non-Filtered Mode (#s 3A & 3B).                                                                                                                                          |
| 4A     | 1       | 0       | 1       | > 0x01              | Х             | Sampled, Filtered mode                                                                                                                                                                         |
| 4B     | 1       | 0       | 0       | > 0x01              | > 0x00        | Refer to the Sampled, Filtered Mode (#s 4A & 4B).                                                                                                                                              |
| 5A     | 1       | 1       | 0       | 0x00                | Х             | Windowed mode                                                                                                                                                                                  |
| 5B     | 1       | 1       | 0       | Х                   | 0x00          | Comparator output is sampled on every rising bus clock edge when SAMPLE=1 to generate COUTA                                                                                                    |
|        |         |         |         |                     |               | Refer to the Windowed Mode (#s 5A & 5B).                                                                                                                                                       |
| 6      | 1       | 1       | 0       | 0x01                | 0x01 - 0xFF   | Windowed/Resampled mode                                                                                                                                                                        |
|        |         |         |         |                     |               | Comparator output is sampled on every rising bus clock edge when SAMPLE=1 to generate COUTA, which is then resampled on an interval determined by FILT_PER to generate COUT.                   |
|        |         |         |         |                     |               | Refer to the Windowed/Resampled Mode (# 6).                                                                                                                                                    |
| 7      | 1       | 1       | 0       | > 0x01              | 0x01 - 0xFF   | Windowed/Filtered mode                                                                                                                                                                         |
|        |         |         |         |                     |               | Comparator output is sampled on every rising bus clock edge when SAMPLE=1 to generate COUTA, which is then resampled and filtered to generate COUT.  Refer to the Windowed/Filtered Mode (#7). |

Table continues on the next page...

#### **CMP Functional Description**

#### Table 30-15. Comparator Sample/Filter Controls (continued)

| Mode #                                                                                               | CR1[EN] | CR1[WE] | CR1[SE] | CR0[FILTER_C<br>NT] | FPR[FILT_PER] | Operation |
|------------------------------------------------------------------------------------------------------|---------|---------|---------|---------------------|---------------|-----------|
| All other combinations of CR1[EN], CR1[WE], CR1[SE], CR0[FILTER_CNT], and FPR[FILT_PER] are illegal. |         |         |         |                     |               |           |

For cases where a comparator is used to drive a fault input (for example, for a motor-control module such as FTM), it should generally be configured to operate in continuous mode, so that an external fault can immediately pass through the comparator to the target fault circuitry.

#### Note

Filtering and sampling settings should be changed only after setting CR1[SE]=0 and CR0[FILTER\_CNT]=0x00. This has the effect of resetting the filter to a known state.

# 30.8.1.1 Disabled Mode (# 1)

In disabled mode, the analog comparator is non-functional and consumes no power. The output of the analog comparator block (CMPO) is zero in this mode.

# 30.8.1.2 Continuous Mode (#s 2A & 2B)



Figure 30-15. Comparator Operation in Continuous Mode

#### **NOTE**

Refer to the chip configuration section for the source of sample/ window input.

The analog comparator block is powered and active. CMPO may be optionally inverted, but is not subject to external sampling or filtering. Both Window Control and Filter Blocks are completely bypassed. SCR[COUT] is updated continuously. The path from comparator inputs pins to output pin is operating in combinational (unclocked) mode. COUT and COUTA are identical.

For control configurations which result in disabling the Filter Block, refer to Filter Block Bypass Logic diagram.

# 30.8.1.3 Sampled, Non-Filtered Mode (#s 3A & 3B)



Figure 30-16. Sampled, Non-Filtered (# 3A): Sampling point externally driven

In Sampled, Non-Filtered mode, the analog comparator block is powered and active. The path from analog inputs to COUTA is combinational (unclocked). Windowing Control is completely bypassed. COUTA is sampled whenever a rising edge is detected on the Filter Block clock input.

The only difference in operation between Sampled, Non-Filtered (# 3A) and Sampled, Non-Filtered (# 3B) is in how the clock to the Filter Block is derived. In #3A, the clock to filter block is externally derived while in #3B, the clock to filter block is internally derived.

The comparator filter has no other function than sample/hold of the comparator output in this mode (# 3B).



Figure 30-17. Sampled, Non-Filtered (# 3B): Sampling interval internally derived

# 30.8.1.4 Sampled, Filtered Mode (#s 4A & 4B)

In Sampled, Filtered mode, the analog comparator block is powered and active. The path from analog inputs to COUTA is combinational (unclocked). Windowing Control is completely bypassed. COUTA is sampled whenever a rising edge is detected on the Filter Block clock input.

The only difference in operation between Sampled, Non-Filtered (# 3A) and Sampled, Filtered (# 4A) is that CR0[FILTER\_CNT] is now greater than 1, which activates filter operation.

#### **CMP Functional Description**



Figure 30-18. Sampled, Filtered (# 4A): Sampling point externally driven



Figure 30-19. Sampled, Filtered (# 4B): Sampling point internally derived

The only difference in operation between Sampled, Non-Filtered (# 3B) and Sampled, Filtered (# 4B) is that CR0[FILTER\_CNT] is now greater than 1, which activates filter operation.

# 30.8.1.5 Windowed Mode (#s 5A & 5B)

The following figure illustrates comparator operation in the windowed mode, ignoring latency of the analog comparator, polarity select and Window Control block. It also assumes that the Polarity Select is set to "non-inverting". Note that the analog comparator output is passed to COUTA only when the WINDOW signal is high.

In actual operation, COUTA may lag the analog inputs by up to one bus clock cycle plus the combinational path delay through the comparator and polarity select logic.

#### **CMP Functional Description**



Figure 30-20. Windowed Mode Operation



Figure 30-21. Windowed Mode

For control configurations which result in disabling the Filter Block, refer to Filter Block Bypass Logic diagram.

When any windowed mode is active, COUTA is clocked by the bus clock whenever WINDOW = 1. The last latched value is held when WINDOW = 0.

## 30.8.1.6 Windowed/Resampled Mode (# 6)

The following figure uses the same input stimulus shown in Figure 30-20, and adds resampling of COUTA to generate COUT. Samples are taken at the time points indicated by the arrows. Again, prop delays and latency is ignored for clarity's sake. This example was generated solely to demonstrate operation of the comparator in windowing / resampled mode, and does not reflect any specific application. Depending upon the sampling rate and window placement, COUT may not see zero-crossing events detected by the analog comparator. Sampling period and/or window placement must be carefully considered for a given application.



Figure 30-22. Windowed / Resampled Mode Operation

This mode of operation results in an unfiltered string of comparator samples where the interval between the samples is determined by FPR[FILT\_PER] and the bus clock rate. Configuration for this mode is virtually identical to that for the Windowed/Filtered Mode shown in the next section. The only difference is that the value of CR0[FILTER\_CNT] must be exactly one.

## 30.8.1.7 Windowed/Filtered Mode (#7)

This is the most complex mode of operation for the comparator block, as it utilizes both windowing and filtering features. It also has the highest latency of any of the modes. This can be approximated: up to 1 bus clock synchronization in the window function + ((CR0[FILTER\_CNT] X FPR[FILT\_PER]) + 1) X bus clock for the filter function.

When any windowed mode is active, COUTA is clocked by the bus clock whenever WINDOW = 1. The last latched value is held when WINDOW = 0.



Figure 30-23. Windowed/Filtered Mode

## 30.8.2 Power Modes

# 30.8.2.1 Wait Mode Operation

During Wait and VLPW modes and if enabled, the CMP continues to operate normally. Also, if enabled, a CMP interrupt can wake the MCU.

## 30.8.2.2 Stop Mode Operation

Subject to platform-specific clock restrictions, the MCU is brought out of stop when a compare event occurs and the corresponding interrupt is enabled. Similarly, if CR1[OPE] is enabled, the comparator output operates as in the normal operating mode and comparator output is placed onto the external pin. In stop modes, the comparator can be operational in both high speed (HS) comparison mode (CR1[PMODE] = 1) and low speed (LS) comparison mode (CR1[PMODE] = 0), but it is recommended to use the low speed mode to minimize power consumption.

If stop is exited with a reset, all comparator registers are put into their reset state.

# 30.8.2.3 Low-Leakage Mode Operation

During low-leakage modes, the CMP module is partially functional and is limited to low speed mode (regardless of the CR1[PMODE] bit setting. Windowed, sampled, and filtered modes are not supported. The CMP output pin is latched and does not reflect the compare output state.

The positive- and negative-input voltage can be from external pins or the DAC output. The MCU can be brought out of the low-leakage mode if a compare event occurs and the CMP interrupt is enabled. After wake-up from low-leakage modes, the CMP module is in the reset state except for the SCR[CFF] and SCR[CFR] flags.

# 30.8.2.4 Background Debug Mode Operation

When the microcontroller is in active background debug mode, the CMP continues to operate normally.

## 30.8.3 Startup and Operation

A typical startup sequence is as follows.

The time required to stabilize COUT will be the power-on delay of the comparators plus the largest propagation delay from a selected analog source through the analog comparator, windowing function and filter. Power on delay of the comparators are available from data sheets. The windowing function has a maximum of 1 bus clock period delay. Filter delay is specified in Low Pass Filter.

#### **CMP Functional Description**

During operation, the propagation delay of the selected data paths must always be considered. It can take many bus clock cycles for COUT and the CFR/CFF status bits to reflect an input change or a configuration change to one of the components involved in the data path.

When programmed for filtering modes, COUT will initially be equal to zero until sufficient clock cycles have elapsed to fill all stages of the filter. This occurs even if COUTA is at a logic one.

## 30.8.4 Low Pass Filter

The low-pass filter operates on the unfiltered and unsynchronized and optionally inverted comparator output COUTA and generates the filtered and synchronized output COUT. Both COUTA and COUT can be configured as module outputs and are used for different purposes within the system.

Synchronization and edge detection are always used to determine status register bit values. They also apply to COUT for all sampling and windowed modes. Filtering can be performed using an internal timebase defined by FPR[FILT\_PER], or using an external SAMPLE input to determine sample time.

The need for digital filtering and the amount of filtering is dependent on user requirements. Filtering can become more useful in the absence of an external hysteresis circuit. Without external hysteresis, high frequency oscillations can be generated at COUTA when the selected INM and INP input voltages differ by less than the offset voltage of the differential comparator.

# 30.8.4.1 Enabling Filter Modes

Filter Modes are enabled by setting CR0[FILTER\_CNT] greater than 0x01 and (setting FPR[FILT\_PER] to a non-zero value OR setting CR1[SE]=1). If using the divided bus clock to drive the filter, it will take samples of COUTA every FPR[FILT\_PER] bus clock cycles.

The filter output will be at logic zero when first initalized, and will subsequently change when CR0[FILTER\_CNT] consecutive samples all agree that the output value has changed. Said another way, SCR[COUT] will be zero for some initial period, even when COUTA is at logic one.

Setting both CR1[SE] and FPR[FILT\_PER] to 0 disables the filter and eliminates switching current associated with the filtering process.

#### **Note**

Always switch to this setting prior to making any changes in filter parameters. This resets the filter to a known state. Switching CR0[FILTER\_CNT] on the fly without this intermediate step can result in unexpected behavior.

If CR1[SE]=1, the filter takes samples of COUTA on each positive transition of the sample input. The output state of the filter changes when CR0[FILTER\_CNT] consecutive samples all agree that the output value has changed.

## 30.8.4.2 Latency Issues

The FPR[FILT\_PER] value (or SAMPLE period) should be set such that the sampling period is just larger than the period of the expected noise. This way a noise spike will only corrupt one sample. The CR0[FILTER\_CNT] value should be chosen to reduce the probability of noisy samples causing an incorrect transition to be recognized. The probability of an incorrect transition is defined as the probability of an incorrect sample raised to the CR0[FILTER\_CNT] power.

The following table summarizes maximum latency values for the various modes of operation *in the absence of noise*. Filtering latency is restarted each time an actual output transition is masked by noise.

The values of FPR[FILT\_PER] (or SAMPLE period) and CR0[FILTER\_CNT] must also be traded off against the desire for minimal latency in recognizing actual comparator output transitions. The probability of detecting an actual output change within the nominal latency is the probability of a correct sample raised to the CR0[FILTER\_CNT] power.

| Mode # | CR1[<br>EN] | CR1[<br>WE] | CR1[<br>SE] | CR0[FILTER<br>_CNT] | FPR[FILT_P<br>ER] | Operation                  | Maximum Latency <sup>1</sup>                             |
|--------|-------------|-------------|-------------|---------------------|-------------------|----------------------------|----------------------------------------------------------|
| 1      | 0           | Х           | Х           | Х                   | Х                 | Disabled                   | N/A                                                      |
| 2A     | 1           | 0           | 0           | 0x00                | Х                 | Continuous Mode            | $T_PD$                                                   |
| 2B     | 1           | 0           | 0           | Х                   | 0x00              |                            |                                                          |
| ЗА     | 1           | 0           | 1           | 0x01                | Х                 | Sampled, Non-Filtered mode | T <sub>PD</sub> + T <sub>SAMPLE</sub> + T <sub>per</sub> |
| ЗВ     | 1           | 0           | 0           | 0x01                | > 0x00            |                            | $T_{PD}$ + (FPR[FILT_PER] x<br>$T_{per}$ ) + $T_{per}$   |

Table 30-16. Comparator Sample/Filter Maximum Latencies

Table continues on the next page...

#### **CMP Interrupts**

Table 30-16. Comparator Sample/Filter Maximum Latencies (continued)

| Mode # | CR1[<br>EN] | CR1[<br>WE] | CR1[<br>SE] | CR0[FILTER _CNT] | FPR[FILT_P<br>ER] | Operation                 | Maximum Latency <sup>1</sup>                                                                      |
|--------|-------------|-------------|-------------|------------------|-------------------|---------------------------|---------------------------------------------------------------------------------------------------|
| 4A     | 1           | 0           | 1           | > 0x01           | Х                 | Sampled, Filtered mode    | T <sub>PD</sub> + (CR0[FILTER_CNT] x<br>T <sub>SAMPLE</sub> ) + T <sub>per</sub>                  |
| 4B     | 1           | 0           | 0           | > 0x01           | > 0x00            |                           | T <sub>PD</sub> + (CR0[FILTER_CNT] x<br>FPR[FILT_PER] x T <sub>per</sub> ) +<br>T <sub>per</sub>  |
| 5A     | 1           | 1           | 0           | 0x00             | Х                 | Windowed mode             | T <sub>PD</sub> + T <sub>per</sub>                                                                |
| 5B     | 1           | 1           | 0           | Х                | 0x00              |                           | T <sub>PD</sub> + T <sub>per</sub>                                                                |
| 6      | 1           | 1           | 0           | 0x01             | 0x01 - 0xFF       | Windowed / Resampled mode | T <sub>PD</sub> + (FPR[FILT_PER] x<br>T <sub>per</sub> ) + 2T <sub>per</sub>                      |
| 7      | 1           | 1           | 0           | > 0x01           | 0x01 - 0xFF       | Windowed / Filtered mode  | T <sub>PD</sub> + (CR0[FILTER_CNT] x<br>FPR[FILT_PER] x T <sub>per</sub> ) +<br>2T <sub>per</sub> |

<sup>1.</sup> T<sub>PD</sub> represents the intrinsic delay of the analog component plus the polarity select logic. T<sub>SAMPLE</sub> is the clock period of the external sample clock. T<sub>per</sub> is the period of the bus clock.

# 30.9 CMP Interrupts

The CMP module is capable of generating an interrupt on either the rising or falling edge of the comparator output (or both). The interrupt request is asserted when both SCR[IER] bit and SCR[CFR] are set. It is also asserted when both SCR[IEF] bit and SCR[CFF] are set. The interrupt is de-asserted by clearing either SCR[IER] or SCR[CFR] for a rising edge interrupt, or SCR[IEF] and SCR[CFF] for a falling edge interrupt.

# 30.10 CMP DMA Support

Normally, the CMP generates a CPU interrupt if there is a change on the COUT. When DMA support (set SCR[DMAEN]) enables and the interrupt enables (set SCR[IER] or SCR[IEF] or both), the corresponding change on COUT forces a DMA transfer request rather than a CPU interrupt instead. When the DMA has completed the transfer, it sends a dma\_done signal that de-asserts the dma\_request and clears the flag to allow a subsequent change on comparator output to occur and force another DMA request.

# 30.11 Digital to Analog Converter Block Diagram

The following figure shows the block diagram of the DAC module. It contains a 64-tap resistor ladder network and a 64-to-1 multiplexer, which selects an output voltage from one of 64 distinct levels that outputs from DACO. It is controlled through DAC Control register (DACCR). Its supply reference source can be selected from two sources  $V_{in1}$  and  $V_{in2}$ . The module can be powered down (disabled) when it is not used. When in disable mode, DACO is connected to the analog ground.



Figure 30-24. 6-bit DAC Block Diagram

# 30.12 DAC Functional Description

This section provides DAC functional description.

# 30.12.1 Voltage Reference Source Select

- V<sub>in1</sub> should be used to connect to the primary voltage source as supply reference of 64 tap resistor ladder
- V<sub>in2</sub> should be used to connect to alternate voltage source (or primary source if alternate voltage source is not available)

# 30.13 DAC Resets

This module has a single reset input, corresponding to the chip-wide peripheral reset.

# 30.14 DAC Clocks

This module has a single clock input, the bus clock.

# 30.15 DAC Interrupts

This module has no interrupts.

# Chapter 31 12-bit Digital-to-Analog Converter (DAC)

## 31.1 Introduction

The 12-bit digital-to-analog converter (DAC) is a low power general purpose DAC. The output of this DAC can be placed on an external pin or set as one of the inputs to the analog comparator, ADC, or other peripherals.

## 31.2 Features

The DAC module features include:

- On-chip programmable reference generator output (voltage output from 1/4096 Vin to Vin, step is 1/4096 Vin)
- Vin can be selected from two reference sources
- Static operation in Normal Stop mode
- 16-word data buffer supported with configurable watermark and multiple operation modes
- DMA support

# 31.3 Block Diagram

The block diagram of the DAC module is as follows:



Figure 31-1. DAC Block Diagram

# 31.4 Memory Map/Register Definition

The DAC has registers to control analog comparator and programmable voltage divider to perform the digital-to-analog functions.

The address of a register is the sum of a base address and an address offset. The base address is defined at the chip level. The address offset is defined at the module level.

#### Chapter 31 12-bit Digital-to-Analog Converter (DAC)

# **DACx** memory map

| Absolute address (hex) | Register name                       | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|------------------------|-------------------------------------|--------------------|--------|-------------|------------------|
| FFFF_8500              | DAC Data High Register (DAC0_DAT0H) | 8                  | R/W    | 00h         | 31.4.2/<br>708   |
| FFFF_8501              | DAC Data Low Register (DAC0_DAT0L)  | 8                  | R/W    | 00h         | 31.4.1/<br>709   |
| FFFF_8502              | DAC Data High Register (DAC0_DAT1H) | 8                  | R/W    | 00h         | 31.4.2/<br>708   |
| FFFF_8503              | DAC Data Low Register (DAC0_DAT1L)  | 8                  | R/W    | 00h         | 31.4.1/<br>709   |
| FFFF_8504              | DAC Data High Register (DAC0_DAT2H) | 8                  | R/W    | 00h         | 31.4.2/<br>708   |
| FFFF_8505              | DAC Data Low Register (DAC0_DAT2L)  | 8                  | R/W    | 00h         | 31.4.1/<br>709   |
| FFFF_8506              | DAC Data High Register (DAC0_DAT3H) | 8                  | R/W    | 00h         | 31.4.2/<br>708   |
| FFFF_8507              | DAC Data Low Register (DAC0_DAT3L)  | 8                  | R/W    | 00h         | 31.4.1/<br>709   |
| FFFF_8508              | DAC Data High Register (DAC0_DAT4H) | 8                  | R/W    | 00h         | 31.4.2/<br>708   |
| FFFF_8509              | DAC Data Low Register (DAC0_DAT4L)  | 8                  | R/W    | 00h         | 31.4.1/<br>709   |
| FFFF_850A              | DAC Data High Register (DAC0_DAT5H) | 8                  | R/W    | 00h         | 31.4.2/<br>708   |
| FFFF_850B              | DAC Data Low Register (DAC0_DAT5L)  | 8                  | R/W    | 00h         | 31.4.1/<br>709   |
| FFFF_850C              | DAC Data High Register (DAC0_DAT6H) | 8                  | R/W    | 00h         | 31.4.2/<br>708   |
| FFFF_850D              | DAC Data Low Register (DAC0_DAT6L)  | 8                  | R/W    | 00h         | 31.4.1/<br>709   |
| FFFF_850E              | DAC Data High Register (DAC0_DAT7H) | 8                  | R/W    | 00h         | 31.4.2/<br>708   |
| FFFF_850F              | DAC Data Low Register (DAC0_DAT7L)  | 8                  | R/W    | 00h         | 31.4.1/<br>709   |
| FFFF_8510              | DAC Data High Register (DAC0_DAT8H) | 8                  | R/W    | 00h         | 31.4.2/<br>708   |
| FFFF_8511              | DAC Data Low Register (DAC0_DAT8L)  | 8                  | R/W    | 00h         | 31.4.1/<br>709   |
| FFFF_8512              | DAC Data High Register (DAC0_DAT9H) | 8                  | R/W    | 00h         | 31.4.2/<br>708   |
| FFFF_8513              | DAC Data Low Register (DAC0_DAT9L)  | 8                  | R/W    | 00h         | 31.4.1/<br>709   |

Table continues on the next page...

#### **Memory Map/Register Definition**

## DACx memory map (continued)

| Absolute<br>address<br>(hex) | Register name                        | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|------------------------------|--------------------------------------|--------------------|--------|-------------|------------------|
| FFFF_8514                    | DAC Data High Register (DAC0_DAT10H) | 8                  | R/W    | 00h         | 31.4.2/<br>708   |
| FFFF_8515                    | DAC Data Low Register (DAC0_DAT10L)  | 8                  | R/W    | 00h         | 31.4.1/<br>709   |
| FFFF_8516                    | DAC Data High Register (DAC0_DAT11H) | 8                  | R/W    | 00h         | 31.4.2/<br>708   |
| FFFF_8517                    | DAC Data Low Register (DAC0_DAT11L)  | 8                  | R/W    | 00h         | 31.4.1/<br>709   |
| FFFF_8518                    | DAC Data High Register (DAC0_DAT12H) | 8                  | R/W    | 00h         | 31.4.2/<br>708   |
| FFFF_8519                    | DAC Data Low Register (DAC0_DAT12L)  | 8                  | R/W    | 00h         | 31.4.1/<br>709   |
| FFFF_851A                    | DAC Data High Register (DAC0_DAT13H) | 8                  | R/W    | 00h         | 31.4.2/<br>708   |
| FFFF_851B                    | DAC Data Low Register (DAC0_DAT13L)  | 8                  | R/W    | 00h         | 31.4.1/<br>709   |
| FFFF_851C                    | DAC Data High Register (DAC0_DAT14H) | 8                  | R/W    | 00h         | 31.4.2/<br>708   |
| FFFF_851D                    | DAC Data Low Register (DAC0_DAT14L)  | 8                  | R/W    | 00h         | 31.4.1/<br>709   |
| FFFF_851E                    | DAC Data High Register (DAC0_DAT15H) | 8                  | R/W    | 00h         | 31.4.2/<br>708   |
| FFFF_851F                    | DAC Data Low Register (DAC0_DAT15L)  | 8                  | R/W    | 00h         | 31.4.1/<br>709   |
| FFFF_8520                    | DAC Status Register (DAC0_SR)        | 8                  | R      | 02h         | 31.4.3/<br>709   |
| FFFF_8521                    | DAC Control Register (DAC0_C0)       | 8                  | R/W    | 00h         | 31.4.4/<br>710   |
| FFFF_8522                    | DAC Control Register 1 (DAC0_C1)     | 8                  | R/W    | 00h         | 31.4.5/<br>711   |
| FFFF_8523                    | DAC Control Register 2 (DAC0_C2)     | 8                  | R/W    | 0Fh         | 31.4.6/<br>712   |

# 31.4.2 DAC Data High Register (DACx\_DATnH)

Addresses: FFFF\_8500h base + 0h offset +  $(2d \times n)$ , where n = 0d to 15d



## DACx\_DATnH field descriptions

| Field             | Description                                                                                                                                      |
|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–4<br>Reserved   | This read-only bitfield is reserved and always has the value zero.                                                                               |
| 3–0<br>DATA[11:8] | When the DAC Buffer is not enabled, DATA[11:0] controls the output voltage based on the following formula. Vout = Vin * (1 + DACDAT0[11:0])/4096 |
|                   | When the DAC Buffer is enabled, DATA[11:0] is mapped to the 16-word buffer.                                                                      |

## 31.4.1 DAC Data Low Register (DACx\_DATnL)





#### DACx\_DATnL field descriptions

| Field            | Description                                                                                                                                      |  |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 7–0<br>DATA[7:0] | When the DAC Buffer is not enabled, DATA[11:0] controls the output voltage based on the following formula. Vout = Vin * (1 + DACDAT0[11:0])/4096 |  |
|                  | When the DAC Buffer is enabled, DATA is mapped to the 16-word buffer.                                                                            |  |

# 31.4.3 DAC Status Register (DACx\_SR)

If DMA is enabled, the flags can be cleared automatically by DMA when the DMA request is done. Write zero to a bit to clear it. Writing one has no effect. After reset DACBFRPTF is set and can be cleared by software, if needed. The flags are set only when the data buffer status is changed.

Addresses: DAC0\_SR is FFFF\_8500h base + 20h offset = FFFF\_8520h



#### **Memory Map/Register Definition**

## DACx\_SR field descriptions

| Field           | Description                                                                                 |
|-----------------|---------------------------------------------------------------------------------------------|
| 7–3<br>Reserved | This read-only bitfield is reserved and always has the value zero. Reserved                 |
| 2<br>DACBFWMF   | DAC buffer watermark flag  The DAC buffer read pointer has not reached the watermark level. |
|                 | The DAC buffer read pointer has reached the watermark level.                                |
| 1<br>DACBFRPTF  | DAC buffer read pointer top position flag                                                   |
|                 | 0 The DAC buffer read pointer is not zero.                                                  |
|                 | 1 The DAC buffer read pointer is zero.                                                      |
| 0<br>DACBFRPBF  | DAC buffer read pointer bottom position flag                                                |
|                 | 0 The DAC buffer read pointer is not equal to the DACBFUP.                                  |
|                 | 1 The DAC buffer read pointer is equal to the DACBFUP.                                      |

# 31.4.4 DAC Control Register (DACx\_C0)

Addresses: DACO\_C0 is FFFF\_8500h base + 21h offset = FFFF\_8521h



## DACx\_C0 field descriptions

| Field          | Description                                                          |
|----------------|----------------------------------------------------------------------|
| 7              | DAC enable                                                           |
| DACEN          | The DACEN bit starts the Programmable Reference Generator operation. |
|                | 0 The DAC system is disabled.                                        |
|                | 1 The DAC system is enabled.                                         |
| 6<br>DACRFS    | DAC Reference Select                                                 |
|                | 0 The DAC selets DACREF_1 as the reference voltage.                  |
|                | 1 The DAC selets DACREF_2 as the reference voltage.                  |
| 5<br>DACTRGSEL | DAC trigger select                                                   |
| 27101110022    | 0 The DAC hardware trigger is selected.                              |
|                | 1 The DAC software trigger is selected.                              |
| 4<br>DACSWTRG  | DAC software trigger                                                 |

Table continues on the next page...

## DACx\_C0 field descriptions (continued)

| Field                                                                                                                                                                   | Description                                                      |  |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------|--|--|
| Active high. This is a write-only bit, read it always be 0. If DAC software trigger is selected enabled, write 1 to this bit will advance the buffer read pointer once. |                                                                  |  |  |
|                                                                                                                                                                         | 0 The DAC soft trigger is not valid.                             |  |  |
|                                                                                                                                                                         | 1 The DAC soft trigger is valid.                                 |  |  |
| 3<br>LPEN                                                                                                                                                               | DAC low power control                                            |  |  |
|                                                                                                                                                                         | 0 high power mode.                                               |  |  |
|                                                                                                                                                                         | 1 low power mode.                                                |  |  |
| 2<br>DACBWIEN                                                                                                                                                           | DAC buffer watermark interrupt enable                            |  |  |
|                                                                                                                                                                         | 0 The DAC buffer watermark interrupt is disabled.                |  |  |
|                                                                                                                                                                         | 1 The DAC buffer watermark interrupt is enabled.                 |  |  |
| 1<br>DACBTIEN                                                                                                                                                           | DAC buffer read pointer top flag interrupt enable                |  |  |
|                                                                                                                                                                         | 0 The DAC buffer read pointer top flag interrupt is disabled.    |  |  |
|                                                                                                                                                                         | 1 The DAC buffer read pointer top flag interrupt is enabled.     |  |  |
| 0<br>DACBBIEN                                                                                                                                                           | DAC buffer read pointer bottom flag interrupt enable             |  |  |
|                                                                                                                                                                         | 0 The DAC buffer read pointer bottom flag interrupt is disabled. |  |  |
|                                                                                                                                                                         | 1 The DAC buffer read pointer bottom flag interrupt is enabled.  |  |  |

# 31.4.5 DAC Control Register 1 (DACx\_C1)

Addresses: DAC0\_C1 is FFFF\_8500h base + 22h offset = FFFF\_8522h



## DACx\_C1 field descriptions

| Field           | Description                                                                                                                                                                                                                      |  |  |  |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 7<br>DMAEN      | <ul> <li>DMA enable select</li> <li>DMA disabled.</li> <li>DMA enabled. When DMA enabled, DMA request will be generated by original interrupts. And interrupts will not be presented on this module at the same time.</li> </ul> |  |  |  |
| 6–5<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                               |  |  |  |
| 4–3<br>DACBFWM  | DAC buffer watermark select                                                                                                                                                                                                      |  |  |  |

Table continues on the next page...

#### **Memory Map/Register Definition**

# DACx\_C1 field descriptions (continued)

| Field          | Description                                                                                                                                                                                                                                                                                                |  |  |  |
|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
|                | This bitfield controls when the DAC buffer watermark flag will be set. When the DAC buffer read pointed reaches the word defined by this bitfield, from 1 to 4 words away from the upper limit (DACBUP), the Duffer watermark flag will be set. This allows user configuration of the watermark interrupt. |  |  |  |
|                | 00 1 word                                                                                                                                                                                                                                                                                                  |  |  |  |
|                | 01 2 words                                                                                                                                                                                                                                                                                                 |  |  |  |
|                | 10 3 words                                                                                                                                                                                                                                                                                                 |  |  |  |
|                | 11 4 words                                                                                                                                                                                                                                                                                                 |  |  |  |
| 2–1<br>DACBFMD | DAC buffer work mode select                                                                                                                                                                                                                                                                                |  |  |  |
|                | 00 Normal Mode                                                                                                                                                                                                                                                                                             |  |  |  |
|                | 01 Swing Mode                                                                                                                                                                                                                                                                                              |  |  |  |
|                | 10 One-Time Scan Mode                                                                                                                                                                                                                                                                                      |  |  |  |
|                | 11 Reserved                                                                                                                                                                                                                                                                                                |  |  |  |
| 0<br>DACBFEN   | DAC buffer enable                                                                                                                                                                                                                                                                                          |  |  |  |
|                | <ul> <li>Buffer read pointer disabled. The converted data is always the first word of the buffer.</li> <li>Buffer read pointer enabled. The converted data is the word that the read pointer points to. It means converted data can be from any word of the buffer.</li> </ul>                             |  |  |  |

# 31.4.6 DAC Control Register 2 (DACx\_C2)

Addresses: DAC0\_C2 is FFFF\_8500h base + 23h offset = FFFF\_8523h



## DACx\_C2 field descriptions

| Field          | Description                                                                             |
|----------------|-----------------------------------------------------------------------------------------|
| 7–4<br>DACBFRP | DAC buffer read pointer                                                                 |
|                | These 4 bits keep the current value of the buffer read pointer.                         |
| 3–0<br>DACBFUP | DAC buffer upper limit                                                                  |
| 27.001.01      | These 4 bits select the buffer's upper limit. The buffer read pointer cannot exceed it. |

# 31.5 Functional Description

The 12-bit DAC module can select one of the two reference inputs — DACREF\_1 and DACREF\_2 as the DAC reference voltage ( $V_{in}$ ) by DACRFS bit of DACC0 register. Refer to the module introduction for information on the source for DACREF\_1 and DACREF\_2. When the DAC is enabled, it converts the data in DACDAT0[11:0] or the data from the DAC data buffer to a stepped analog output voltage. The output voltage range is from  $V_{in}/4096$  to  $V_{in}$ , and the step is  $V_{in}/4096$ .

# 31.5.1 DAC Data Buffer Operation

When the DAC is enabled and the buffer is not enabled, the DAC module always converts the data in DAT0 to analog output voltage.

When both the DAC and the buffer are enabled, the DAC converts the data in the data buffer to analog output voltage. The data buffer read pointer advances to the next word in the event the hardware trigger or the software trigger occurs. Refer to the PDB Module Interconnections section in Chip Configuration chapter for the hardware trigger connection.

The data buffer can be configured to operate in normal mode, swing mode or one-time scan mode. When the buffer operation is switched from one mode to another, the read pointer does not change. The read pointer can be set to any value between "0" and DACBFUP by writing DACBFRP in C2 register.

# 31.5.1.1 DAC Data Buffer Interrupts

There are several interrupts and associated flags that can be configured for the DAC buffer. The DAC read pointer bottom position flag is set when the DAC buffer read pointer reaches the DAC buffer upper limit. (DACBFRP = DACBFUP). The DAC read pointer top position flag is set when the DAC read pointer is equal to the start position, 0. Finally, the DAC buffer watermark flag is set when the DAC buffer read pointer has reached the position defined by the DAC watermark select bit field. The DAC watermark select (DACBFWM) can be used to generate an interrupt when the DAC buffer Read pointer is between 1 to 4 words from the DAC buffer upper limit.

**Functional Description** 

#### 31.5.1.2 Buffer Normal Mode

This is the default mode. The buffer works as a circular buffer. The read pointer increases by one, every time when the trigger occurs. When the read pointer reaches the upper limit, it goes to the zero directly in the next trigger event.

# 31.5.1.3 Buffer Swing Mode

This mode is similar to the normal mode. But when the read pointer reaches the upper limit, it does not go to the zero. It will descend by one in the next trigger events until zero is reached.

#### 31.5.1.4 Buffer One-time Scan Mode

The read pointer increases by one every time when the trigger occurs. When it reaches the upper limit, it stops at there. If read pointer is reset to the address other than the upper limit, it will increase to the upper address and stop at there again.

#### **Note**

If the software set the read pointer to the upper limit, the read pointer will not advance in this mode.

# 31.5.2 DMA Operation

When DMA is enabled, interrupt requests are not generated. DMA requests are generated instead. DMA done signal clears the DMA request.

The status register flags are still set and are cleared automatically when the DMA completes.

## 31.5.3 Resets

During reset the DAC is configured in the default mode. DAC is disabled.

## 31.5.4 Low Power Mode Operation

This section describes the wait mode and the stop mode operation of the DAC module.

# 31.5.4.1 Wait Mode Operation

In wait mode, the DAC will operate normally if enabled.

# 31.5.4.2 Stop Mode Operation

The DAC continues to operate in Normal Stop mode if enabled, the output voltage will hold the value before stop.

In Low Power Stop modes, the DAC is fully shut-down.

#### **NOTE**

The assignment of module modes to core modes is chipspecific. For module-to-core mode assignments, see the chapter that describes how modules are configured.

# 31.5.5 Background Mode Operation

When the MCU is in active background mode, the DAC will operate normally.

**Functional Description** 

# Chapter 32 Voltage Reference (VREF)

## 32.1 Introduction

The VREFV1 Voltage Reference is intended to supply an accurate voltage output that is trimmable with the TRM register's TRIM[5:0] bitfield in 0.5 mV steps. The VREFV1 can be used in medical applications such as glucose meters to provide a reference voltage to biosensors or as a reference to analog peripherals such as the ADC, DAC, or CMP. The voltage reference has three operating modes that provide different levels of load regulation and power consumption.

The following figure is a block diagram of the Voltage Reference.



Figure 32-1. Voltage reference block diagram

#### 32.1.1 Overview

The Voltage Reference optimizes the existing bandgap and bandgap buffer system. Unity gain amplifiers ease the design and keep power consumption low. The TRM register's TRIM[5:0] bitfield is user accessible so the Voltage Reference can be trimmed in an application.

The Voltage Reference contains trim resolution of 0.5 mV per step. The buffer has high power mode with high output current. In addition, the buffer is available for use with ADCs and DACs in low power mode. The voltage can be output on a dedicated output pin.<sup>1</sup>

## **32.1.2 Features**

The Voltage Reference has the following features:

- Programmable trim register with 0.5 mV steps, automatically loaded with factory trimmed value upon reset
- Programmable buffer mode selection:
  - Off
  - Bandgap out
  - Low-power buffer mode
  - Tight-regulation buffer mode
- 1.2 V output at room temperature
- Dedicated output pin, VREF\_OUT
- Load regulation in tight-regulation mode of 100 μV/mA max
- Power supply rejection (PSR) of 0±0.1 mV DC and -60 dB AC
- High power output mode

<sup>1.</sup> In the Tight-Regulation buffer mode (when SC[MODE\_LV]=10), a 100 nF capacitor is required to be connected between the VREF\_OUT pad and the ground.

# 32.1.3 Modes of Operation

The Voltage Reference continues normal operation in Run, Wait, and Stop modes. The Voltage Reference can also run in Very Low Power Run (VLPR) and Very Low Power Stop (VLPS). It is suggested to disable the VREF module in these modes when the accuracy of the output voltage will be reduced by an unspecified amount (as much as several mVs).

#### NOTE

The assignment of module modes to core modes is chipspecific. For module-to-core mode assignments, see the chapter that describes how modules are configured.

# 32.1.4 VREF Signal Descriptions

The following table shows the Voltage Reference signals properties.

Table 32-1. VREF Signal Descriptions

| Signal   | Description                                   | I/O |
|----------|-----------------------------------------------|-----|
| VREF_OUT | Internally-generated Voltage Reference output | 0   |

#### NOTE

- In Low Power buffer mode, the VREF\_OUT signal is used as an internal reference without external capacitors.
- In Disable mode, the status of the VREF\_OUT signal is high-impedence.

# 32.2 Memory Map and Register Definition

#### **VREF** memory map

| Absolute address (hex) | Register name                              | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|------------------------|--------------------------------------------|--------------------|--------|-------------|------------------|
| FFFF_8670              | VREF Trim Register (VREF_TRM)              | 8                  | R/W    | 00h         | 32.2.1/<br>720   |
| FFFF_8671              | VREF Status and Control Register (VREF_SC) | 8                  | R/W    | 00h         | 32.2.2/<br>720   |

# 32.2.1 VREF Trim Register (VREF\_TRM)

This register contains bits that contain the trim data for the Voltage Reference.

Address: VREF\_TRM is FFFF\_8670h base + 0h offset = FFFF\_8670h



## **VREF\_TRM** field descriptions

| Field         | Description                                                                                                                                                                                                                                                                      |  |  |
|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 7<br>Reserved | This read-only bit is reserved and always has the value zero.                                                                                                                                                                                                                    |  |  |
| 6<br>Reserved | This read-only bit is reserved and always has the value zero.                                                                                                                                                                                                                    |  |  |
| 5–0<br>TRIM   | Trim bits  These bits change the resulting VREF by approximately ± 0.5 mV for each step.  NOTE: Min = minimum and max = maximum voltage reference output. For minimum and maximum voltage reference output values, refer to the Data Sheet for this chip.  000000 Min 111111 Max |  |  |

## 32.2.2 VREF Status and Control Register (VREF\_SC)

This register contains the control bits used to enable the internal voltage reference and to select the buffer mode to be used.

Address: VREF\_SC is FFFF\_8670h base + 1h offset = FFFF\_8671h



#### **VREF\_SC** field descriptions

| Field         | Description                                                                                                                                                                               |
|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7             | Internal Voltage Reference enable                                                                                                                                                         |
| VREFEN        | This bit is used to enable the bandgap Voltage Reference module.                                                                                                                          |
|               | NOTE: After the VREF is enabled, turning off the clock to the VREF module via the corresponding clock gate register will not disable the VREF. VREF must be disabled via this VREFEN bit. |
|               | <ul><li>The module is disabled.</li><li>The module is enabled.</li></ul>                                                                                                                  |
| 6<br>REGEN    | Regulator enable                                                                                                                                                                          |
| REGEN         | This bit is used to enable the internal 1.75 V regulator to produce a stable voltage reference in order to reduce the supply variation.                                                   |
|               | 0 Internal 1.75 V regulator is disabled.                                                                                                                                                  |
|               | 1 Internal 1.75 V regulator is enabled.                                                                                                                                                   |
| 5<br>Reserved | This read-only bit is reserved and always has the value zero.                                                                                                                             |
| 4<br>Reserved | This read-only bit is reserved and always has the value zero.                                                                                                                             |
| 3<br>Reserved | This read-only bit is reserved and always has the value zero.                                                                                                                             |
| 2             | Internal Voltage Reference stable                                                                                                                                                         |
| VREFST        | This bit indicates that the Voltage Reference module has completed its startup and stabilization.                                                                                         |
|               | 0 The module is disabled or not stable.                                                                                                                                                   |
|               | 1 The module is stable.                                                                                                                                                                   |
| 1-0           | Buffer Mode selection                                                                                                                                                                     |
| MODE_LV       | These bits select the buffer modes for the Voltage Reference module.                                                                                                                      |
|               | 00 Bandgap on only, for stabilization and startup                                                                                                                                         |
|               | 01 Low-power buffer enabled                                                                                                                                                               |
|               | 10 Tight-regulation buffer enabled                                                                                                                                                        |
|               | 11 Reserved                                                                                                                                                                               |

# 32.3 Functional Description

The Voltage Reference is a bandgap buffer system. Unity gain amplifiers are used.

The VREF\_OUT signal is used as an internal reference when it is used in low power mode and is used for internal peripherals only. If it used in high power mode, a 100 nF capacitor is required.

The following table shows all possible function configurations of the Voltage Reference.

#### **Functional Description**

Table 32-5. Voltage Reference function configurations

| SC[VREFEN] | SC[MODE_LV] | Configuration Functionality                                     |                                                                                    |
|------------|-------------|-----------------------------------------------------------------|------------------------------------------------------------------------------------|
| 0          | X           | Voltage Reference disabled Off                                  |                                                                                    |
| 1          | 00          | Voltage Reference enabled, bandgap on only                      |                                                                                    |
| 1          | 01          | Voltage Reference enabled,<br>low-power buffer on               | Can be used for internal peripherals only, VREF pin will not output the reference. |
| 1          | 10          | Voltage Reference enabled, tight-regulation buffer on required. |                                                                                    |
| 1          | 11          | Reserved                                                        | Reserved                                                                           |

# 32.3.1 Voltage Reference Disabled, SC[VREFEN] = 0

When SC[VREFEN] = 0, the Voltage Reference is disabled, all bandgap and buffers are disabled. The Voltage Reference is in off mode.

## 32.3.2 Voltage Reference Enabled, SC[VREFEN] = 1

When SC[VREFEN] = 1, the Voltage Reference is enabled, and different modes should be set by the SC[MODE\_LV] bits.

## 32.3.2.1 SC[MODE\_LV]=00

The internal bandgap is on to generate an accurate 1.2 V voltage output that can be trimmed with the TRM register's TRIM[5:0] bitfield in 0.5 mV steps. The bandgap requires some time for startup and stabilization. SC[VREFST] can be monitored to determine if the stabilization and startup is completed.

Both low-power buffer and tight-regulation buffer are disabled under this mode, and there is no buffered voltage output. The Voltage Reference is in standby mode.

# 32.3.2.2 SC[MODE\_LV] = 01

The internal bandgap is on.

The low-power buffer is enabled to generate a buffered internal 1.2 V voltage. It can be used as a reference to internal analog peripherals such as an ADC channel or analog comparator input.

## 32.3.2.3 SC[MODE\_LV] = 10

The tight regulation buffer is enabled to generate a buffered 1.2 V voltage to VREF\_OUT with load regulation less than 100  $\mu$ V/mA. VREF\_OUT can be loaded with a 100 nF capacitor and has a maximum 1.1 mA drive strength.

## 32.3.2.4 SC[MODE\_LV] = 11

Reserved

#### 32.4 Initialization Information

The Voltage Reference requires some time for startup and stabilization. After SC[VREFEN] = 1, SC[VREFST] can be monitored to determine if the stabilization and startup is completed.

When the Voltage Reference is already enabled and stabilized, changing SC[MODE\_LV] will not clear SC[VREFST], but there will be some startup time before the output voltage is stabilized when the low-power buffer or tight-regulation buffer is enabled. Also, there will be some setting time when a step change of the load current occurs.

**Initialization Information** 

# **Chapter 33**Programmable Delay Block (PDB)

#### 33.1 Introduction

The programmable delay block (PDB) provides controllable delays from either an internal or an external trigger, or a programmable interval tick, to the hardware trigger inputs of ADCs and/or generates the interval triggers to DACs, so that the precise timing between ADC conversions and/or DAC updates can be achieved. The PDB can optionally provides pulse outputs (Pulse-Out's) that are used as the sample window in the CMP block.

#### **33.1.1 Features**

- Up to 15 trigger input sources and software trigger source
- Up to eight configurable PDB channels for ADC hardware trigger
  - One PDB channel is associated with one ADC.
  - One trigger output for ADC hardware trigger and up to eight pre-trigger outputs for ADC trigger select per PDB channel
  - Trigger outputs can be enabled or disabled independently.
  - One 16-bit delay register per pre-trigger output
  - Optional bypass of the delay registers of the pre-trigger outputs
  - Operation in One-Shot or Continuous modes
  - Optional back-to-back mode operation, which enables the ADC conversions complete to trigger the next PDB channel
  - One programmable delay interrupt
  - One sequence error interrupt

#### Introduction

- One channel flag and one sequence error flag per pre-trigger
- DMA support
- Up to eight DAC interval triggers
  - One interval trigger output per DAC
  - One 16-bit delay interval register per DAC trigger output
  - Optional bypass the delay interval trigger registers
  - Optional external triggers
- Up to eight pulse outputs (pulse-out's)
  - Pulse-out's can be enabled or disabled independently.
  - Programmable pulse width

#### **NOTE**

The number of PDB input and output triggers are chip-specific. Refer to the Chip Configuration information for details.

# 33.1.2 Implementation

In this chapter, the following letters refers to the number of output triggers.

- *N* Total available number of PDB channels.
- *n* PDB channel number, valid from 0 to *N*-1.
- *M* Total available pre-trigger per PDB channel.
- *m* Pre-trigger number, valid from 0 to *M*-1.
- *X* Total number of DAC interval triggers.
- x DAC interval trigger output number, valid from 0 to X-1.
- *Y* Total number of Pulse-Out's.
- y Pulse-Out number, valid value is 0 to Y-1.

#### **NOTE**

The number of module output triggers to core are chip-specific. For module to core output triggers implementation, refer to the Chip Configuration information.

## 33.1.3 Back-to-back Acknowledgement Connections

PDB back-to-back operation acknowledgment connections are chip-specific. For implementation, refer to the Chip Configuration information.

## 33.1.4 DAC External Trigger Input Connections

The implementation of DAC external trigger inputs is chip-specific. Refer to the Chip Configuration information for details.

## 33.1.5 Block Diagram

This diagram illustrates the major components of the PDB.

#### Introduction



Figure 33-1. PDB Block Diagram

In this diagram, only one PDB channel *n*, one DAC interval trigger *x*, and one Pulse-Out *y* is shown. The PDB enable control logic and the sequence error interrupt logic is not shown.

## 33.1.6 Modes of Operation

PDB ADC trigger operates in the following modes.

**Disabled**: Counter is off and all pre-trigger and trigger outputs are low.

**Enabled One-Shot**: Counter is enabled and restarted at count zero upon receiving a positive edge on the selected trigger input source or software trigger is selected and SC[SWTRIG] is written with 1. In each PDB channel, an enabled pre-trigger asserts once per trigger input event; the trigger output asserts whenever any of pre-triggers is asserted.

**Enabled Continuous**: Counter is enabled and restarted at count zero. The counter is rolled over to zero again when the count reaches the value specified in the modulus register, and the counting is restarted. This enables a continuous stream of pre-triggers/trigger outputs as a result of a single trigger input event.

**Enabled Bypassed**: The pre-trigger and trigger outputs assert immediately after a positive edge on the selected trigger input source or software trigger is selected and SC[SWTRIG] is written with 1, that is the delay registers are bypassed. It is possible to bypass any one or more of the delay registers; therefore this mode can be used in conjunction with One-Shot or Continuous mode.

# 33.2 PDB Signal Descriptions

This table shows the detailed description of the external signal.

Table 33-1. PDB Signal Descriptions

| Signal | Description                                                                                                                                                            | I/O |
|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| EXTRG  | External trigger input source. If the PDB is enabled and external trigger input source is selected, a positive edge on the EXTRG signal resets and starts the counter. | I   |

# 33.3 Memory Map and Register Definition

#### **Memory Map and Register Definition**

## PDBx memory map

| Absolute address (hex) | Register name                                           | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|------------------------|---------------------------------------------------------|--------------------|--------|-------------|------------------|
| FFFF_8540              | Status and Control Register (PDB0_SC)                   | 32                 | R/W    | 0000_0000h  | 33.3.1/<br>731   |
| FFFF_8544              | Modulus Register (PDB0_MOD)                             | 32                 | R/W    | 0000_FFFFh  | 33.3.2/<br>733   |
| FFFF_8548              | Counter Register (PDB0_CNT)                             | 32                 | R      | 0000_0000h  | 33.3.3/<br>734   |
| FFFF_854C              | Interrupt Delay Register (PDB0_IDLY)                    | 32                 | R/W    | 0000_FFFFh  | 33.3.4/<br>734   |
| FFFF_8550              | Channel n Control Register 1 (PDB0_CH0C1)               | 32                 | R/W    | 0000_0000h  | 33.3.5/<br>735   |
| FFFF_8554              | Channel n Status Register (PDB0_CH0S)                   | 32                 | w1c    | 0000_0000h  | 33.3.6/<br>736   |
| FFFF_8558              | Channel n Delay 0 Register (PDB0_CH0DLY0)               | 32                 | R/W    | 0000_0000h  | 33.3.7/<br>737   |
| FFFF_855C              | Channel n Delay 1 Register (PDB0_CH0DLY1)               | 32                 | R/W    | 0000_0000h  | 33.3.8/<br>737   |
| FFFF_8560              | DAC Interval Trigger n Control Register (PDB0_DACINTC0) | 32                 | R/W    | 0000_0000h  | 33.3.9/<br>738   |
| FFFF_8564              | DAC Interval n Register (PDB0_DACINT0)                  | 32                 | R/W    | 0000_0000h  | 33.3.10/<br>738  |
| FFFF_8568              | Pulse-Out n Enable Register (PDB0_PO0EN)                | 32                 | R/W    | 0000_0000h  | 33.3.11/<br>739  |
| FFFF_856C              | Pulse-Out n Delay Register (PDB0_PO0DLY)                | 32                 | R/W    | 0000_0000h  | 33.3.12/<br>739  |

# 33.3.1 Status and Control Register (PDBx\_SC)

Addresses: PDB0\_SC is FFFF\_8540h base + 0h offset = FFFF\_8540h



#### PDBx\_SC field descriptions

| Field             | Description                                                                                                                                                                                       |
|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–20<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                                                                |
| 19–18<br>LDMOD    | Load Mode Select  Selects the mode to load the MOD, IDLY, CHnDLYm, INTx, and POyDLY registers, after 1 is written to LDOK.                                                                        |
|                   | On The internal registers are loaded with the values from their buffers immediately after 1 is written to LDOK.                                                                                   |
|                   | O1 The internal registers are loaded with the values from their buffers when the PDB counter reaches the MOD register value after 1 is written to LDOK.                                           |
|                   | 10 The internal registers are loaded with the values from their buffers when a trigger input event is detected after 1 is written to LDOK.                                                        |
|                   | The internal registers are loaded with the values from their buffers when either the PDB counter reaches the MOD register value or a trigger input event is detected, after 1 is written to LDOK. |
| 17<br>PDBEIE      | PDB Sequence Error Interrupt Enable                                                                                                                                                               |
|                   | This bit enables the PDB sequence error interrupt. When this bit is set, any of the PDB channel sequence error flags generates a PDB sequence error interrupt.                                    |
|                   | 0 PDB sequence error interrupt disabled.                                                                                                                                                          |
|                   | 1 PDB sequence error interrupt enabled.                                                                                                                                                           |
| 16<br>SWTRIG      | Software Trigger                                                                                                                                                                                  |

Table continues on the next page...

#### Memory Map and Register Definition

## PDBx\_SC field descriptions (continued)

| Field          | Description                                                                                                                                                                                                         |
|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                | When PDB is enabled and the software trigger is selected as the trigger input source, writing 1 to this bit reset and restarts the counter. Writing 0 to this bit has no effect. Reading this bit results 0.        |
| 15<br>DMAEN    | DMA Enable                                                                                                                                                                                                          |
|                | When DMA is enabled, the PDBIF flag generates a DMA request instead of an interrupt.                                                                                                                                |
|                | DMA disabled     DMA enabled                                                                                                                                                                                        |
| 14–12          | Prescaler Divider Select                                                                                                                                                                                            |
| PRESCALER      |                                                                                                                                                                                                                     |
|                | O00 Counting uses the peripheral clock divided by multiplication factor selected by MULT.  O01 Counting uses the peripheral clock divided by twice of the multiplication factor selected by MULT.                   |
|                | O01 Counting uses the peripheral clock divided by twice of the multiplication factor selected by MULT.  O10 Counting uses the peripheral clock divided by four times of the multiplication factor selected by MULT. |
|                | 011 Counting uses the peripheral clock divided by eight times of the multiplication factor selected by MULT.                                                                                                        |
|                | 100 Counting uses the peripheral clock divided by 16 times of the multiplication factor selected by MULT.                                                                                                           |
|                | 101 Counting uses the peripheral clock divided by 32 times of the multiplication factor selected by MULT.                                                                                                           |
|                | 110 Counting uses the peripheral clock divided by 64 times of the multiplication factor selected by MULT.                                                                                                           |
|                | 111 Counting uses the peripheral clock divided by 128 times of the multiplication factor selected by MULT.                                                                                                          |
| 11–8<br>TRGSEL | Trigger Input Source Select                                                                                                                                                                                         |
|                | Selects the trigger input source for the PDB. The trigger input source can be internal or external (EXTRG pin), or the software trigger.                                                                            |
|                | 0000 Trigger-In 0 is selected                                                                                                                                                                                       |
|                | 0001 Trigger-In 1 is selected                                                                                                                                                                                       |
|                | 0010 Trigger-In 2 is selected                                                                                                                                                                                       |
|                | 0011 Trigger-In 3 is selected<br>0100 Trigger-In 4 is selected                                                                                                                                                      |
|                | 0101 Trigger-In 5 is selected                                                                                                                                                                                       |
|                | 0110 Trigger-In 6 is selected                                                                                                                                                                                       |
|                | 0111 Trigger-In 7 is selected                                                                                                                                                                                       |
|                | 1000 Trigger-In 8 is selected                                                                                                                                                                                       |
|                | 1001 Trigger-In 9 is selected                                                                                                                                                                                       |
|                | 1010 Trigger-In 10 is selected                                                                                                                                                                                      |
|                | 1011 Trigger-In 11 is selected                                                                                                                                                                                      |
|                | 1100 Trigger-In 12 is selected                                                                                                                                                                                      |
|                | 1110 Trigger In 14 is selected                                                                                                                                                                                      |
|                | <ul><li>1110 Trigger-In 14 is selected</li><li>1111 Software trigger is selected</li></ul>                                                                                                                          |
| 7              | PDB Enable                                                                                                                                                                                                          |
| PDBEN          | PDB disabled. Counter is off and all pre-trigger and trigger outputs are low.                                                                                                                                       |
|                | 1 PDB enabled                                                                                                                                                                                                       |

Table continues on the next page...

#### PDBx\_SC field descriptions (continued)

| Field         | Description                                                                                                                                                                                                                                                           |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6<br>PDBIF    | PDB Interrupt Flag                                                                                                                                                                                                                                                    |
|               | This bit is set when the counter value is equal to the IDLY register. Writing zero clears this bit.                                                                                                                                                                   |
| 5<br>PDBIE    | PDB Interrupt Enable.                                                                                                                                                                                                                                                 |
|               | This bit enables the PDB interrupt. When this bit is set and DMAEN is cleared, PDBIF generates a PDB interrupt.                                                                                                                                                       |
|               | <ul><li>0 PDB interrupt disabled</li><li>1 PDB interrupt enabled</li></ul>                                                                                                                                                                                            |
| 4<br>Reserved | This read-only bit is reserved and always has the value zero.                                                                                                                                                                                                         |
| 3–2<br>MULT   | Multiplication Factor Select for Prescaler                                                                                                                                                                                                                            |
| WIGET         | This bit selects the multiplication factor of the prescaler divider for the counter clock.                                                                                                                                                                            |
|               | 00 Multiplication factor is 1                                                                                                                                                                                                                                         |
|               | 01 Multiplication factor is 10                                                                                                                                                                                                                                        |
|               | 10 Multiplication factor is 20                                                                                                                                                                                                                                        |
|               | 11 Multiplication factor is 40                                                                                                                                                                                                                                        |
| 1<br>CONT     | Continuous Mode Enable                                                                                                                                                                                                                                                |
| OON           | This bit enables the PDB operation in Continuous mode.                                                                                                                                                                                                                |
|               | 0 PDB operation in One-Shot mode                                                                                                                                                                                                                                      |
|               | 1 PDB operation in Continuous mode                                                                                                                                                                                                                                    |
| 0<br>LDOK     | Load OK                                                                                                                                                                                                                                                               |
| LDOK          | Writing 1 to this bit updates the internal registers of MOD, IDLY, CHnDLYm, DACINTx, and POyDLY with the values written to their buffers. The MOD, IDLY, CHnDLYm, DACINTx, and POyDLY will take effect according to the LDMOD.                                        |
|               | After 1 is written to LDOK bit, the values in the buffers of above registers are not effective and the buffers cannot be written until the values in buffers are loaded into their internal registers.                                                                |
|               | LDOK can be written only when PDBEN is set or it can be written at the same time with PDBEN being written to 1. It is automatically cleared when the values in buffers are loaded into the internal registers or the PDBEN is cleared. Writing 0 to it has no effect. |

## 33.3.2 Modulus Register (PDBx\_MOD)

Addresses: PDB0\_MOD is FFFF\_8540h base + 4h offset = FFFF\_8544h



#### **Memory Map and Register Definition**

#### PDBx\_MOD field descriptions

| Field             | Description                                                                                                                                                                                                                                                                                        |
|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–16<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                                                 |
| 15–0<br>MOD       | PDB Modulus.  These bits specify the period of the counter. When the counter reaches this value, it will be reset back to zero. If the PDB is in Continuous mode, the count begins anew. Reading these bits returns the value of internal register that is effective for the current cycle of PDB. |

## 33.3.3 Counter Register (PDBx\_CNT)

Addresses: PDB0\_CNT is FFFF\_8540h base + 8h offset = FFFF\_8548h



#### PDBx\_CNT field descriptions

| Field             | Description                                                                 |
|-------------------|-----------------------------------------------------------------------------|
| 31–16<br>Reserved | This read-only bitfield is reserved and always has the value zero.          |
| 15–0<br>CNT       | PDB Counter  These read-only bits contain the current value of the counter. |

## 33.3.4 Interrupt Delay Register (PDBx\_IDLY)

Addresses: PDB0\_IDLY is FFFF\_8540h base + Ch offset = FFFF\_854Ch



#### PDBx\_IDLY field descriptions

| Field             | Description                                                        |
|-------------------|--------------------------------------------------------------------|
| 31–16<br>Reserved | This read-only bitfield is reserved and always has the value zero. |

Table continues on the next page...

#### PDBx\_IDLY field descriptions (continued)

| Field        | Description                                                                                                                                                                                                                                                                                                                                                               |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15–0<br>IDLY | PDB Interrupt Delay  These bits specify the delay value to schedule the PDB interrupt. It can be used to schedule an independent interrupt at some point in the PDB cycle. If enabled, a PDB interrupt is generated, when the counter is equal to the IDLY. Reading these bits returns the value of internal register that is effective for the current cycle of the PDB. |

## 33.3.5 Channel n Control Register 1 (PDBx\_CHnC1)

Each PDB channel has one Control Register, CHnC1. The bits in this register control the functionality of each PDB channel operation.

Addresses: PDB0\_CH0C1 is FFFF\_8540h base + 10h offset = FFFF\_8550h



#### PDBx\_CHnC1 field descriptions

| Field             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |
|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 31–24<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |
| 23–16<br>BB       | PDB Channel Pre-Trigger Back-to-Back Operation Enable  These bits enable the PDB ADC pre-trigger operation as back-to-back mode. Only lower M pre-trigger bits are implemented in this MCU. Back-to-back operation enables the ADC conversions complete to trigger he next PDB channel pre-trigger and trigger output, so that the ADC conversions can be triggered on next set of configuration and results registers. Application code must only enable the back-to-back operation of the PDB pre-triggers at the leading of the back-to-back connection chain.  PDB channel's corresponding pre-trigger back-to-back operation disabled.  PDB channel's corresponding pre-trigger back-to-back operation enabled. |  |  |
| 15-8<br>TOS       | PDB Channel Pre-Trigger Output Select  These bits select the PDB ADC pre-trigger outputs. Only lower M pre-trigger bits are implemented in this MCU.  O PDB channel's corresponding pre-trigger is in bypassed mode. The pre-trigger asserts one peripheral clock cycle after a rising edge is detected on selected trigger input source or software trigger is selected and SWTRIG is written with 1.  PDB channel's corresponding pre-trigger asserts when the counter reaches the channel delay register plus one peripheral clock cycle after a rising edge is detected on selected trigger input source or software trigger is selected and SETRIG is written with 1.                                           |  |  |

Table continues on the next page...

#### **Memory Map and Register Definition**

#### PDBx\_CHnC1 field descriptions (continued)

| Field     | Description                                                                                                   |  |  |  |
|-----------|---------------------------------------------------------------------------------------------------------------|--|--|--|
| 7–0<br>EN | PDB Channel Pre-Trigger Enable                                                                                |  |  |  |
|           | These bits enable the PDB ADC pre-trigger outputs. Only lower M pre-trigger bits are implemented in this MCU. |  |  |  |
|           | 0 PDB channel's corresponding pre-trigger disabled.                                                           |  |  |  |
|           | 1 PDB channel's corresponding pre-trigger enabled.                                                            |  |  |  |

## 33.3.6 Channel n Status Register (PDBx\_CHnS)

Addresses: PDB0\_CH0S is FFFF\_8540h base + 14h offset = FFFF\_8554h



#### PDBx\_CHnS field descriptions

| Field             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |
|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 31–24<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |
| 23–16<br>CF       | PDB Channel Flags  The CF[ <i>m</i> ] bit is set when the PDB counter matches the CH <i>n</i> DLY <i>m</i> . Write 0 to clear these bits.                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |
| 15–8<br>Reserved  | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |
| 7–0<br>ERR        | PDB Channel Sequence Error Flags  Only the lower M bits are implemented in this MCU.  Sequence error not detected on PDB channel's corresponding pre-trigger.  Sequence error detected on PDB channel's corresponding pre-trigger. ADCn block can be triggered for a conversion by one pre-trigger from PDB channel n. When one conversion, which is triggered by one of the pre-triggers from PDB channel n, is in progress, new trigger from PDB channel's corresponding pre-trigger m cannot be accepted by ADCn, and ERR[m] is set. Writing 1's to clear the sequence error flags. |  |  |  |  |

## 33.3.7 Channel n Delay 0 Register (PDBx\_CHnDLY0)

Addresses: PDB0\_CH0DLY0 is FFFF\_8540h base + 18h offset = FFFF\_8558h



#### PDBx\_CHnDLY0 field descriptions

| Field             | Description                                                                                                                                                                                                                                                         |  |  |  |
|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 31–16<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                  |  |  |  |
| 15–0<br>DLY       | PDB Channel Delay  These bits specify the delay value for the channel's corresponding pre-trigger. The pre-trigger asserts when the counter is equal to DLY. Reading these bits returns the value of internal register that is effective for the current PDB cycle. |  |  |  |

## 33.3.8 Channel n Delay 1 Register (PDBx\_CHnDLY1)

Addresses: PDB0\_CH0DLY1 is FFFF\_8540h base + 1Ch offset = FFFF\_855Ch



## PDBx\_CHnDLY1 field descriptions

| Field             | Description                                                                                                                                                                                                                                                         |  |  |  |
|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 31–16<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                  |  |  |  |
| 15–0<br>DLY       | PDB Channel Delay  These bits specify the delay value for the channel's corresponding pre-trigger. The pre-trigger asserts when the counter is equal to DLY. Reading these bits returns the value of internal register that is effective for the current PDB cycle. |  |  |  |

## 33.3.9 DAC Interval Trigger n Control Register (PDBx\_DACINTCn)

Addresses: PDB0\_DACINTC0 is FFFF\_8540h base + 20h offset = FFFF\_8560h



#### PDBx\_DACINTCn field descriptions

| Field            | Description                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 31–2<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |
| 1<br>EXT         | DAC External Trigger Input Enable  This bit enables the external trigger for DAC interval counter.                                                                                                                                                                                                                                                                                        |  |  |  |  |  |
|                  | <ul> <li>DAC external trigger input disabled. DAC interval counter is reset and started counting when a rising edge is detected on selected trigger input source or software trigger is selected and SWTRIG is written with 1.</li> <li>DAC external trigger input enabled. DAC interval counter is bypassed and DAC external trigger input triggers the DAC interval trigger.</li> </ul> |  |  |  |  |  |
| 0<br>TOE         | DAC Interval Trigger Enable This bit enables the DAC interval trigger.                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |
|                  | <ul><li>DAC interval trigger disabled.</li><li>DAC interval trigger enabled.</li></ul>                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |

## 33.3.10 DAC Interval n Register (PDBx\_DACINTn)

Addresses: PDB0\_DACINT0 is FFFF\_8540h base + 24h offset = FFFF\_8564h



#### PDBx\_DACINTn field descriptions

| Field             | Description                                                        |  |  |  |
|-------------------|--------------------------------------------------------------------|--|--|--|
| 31–16<br>Reserved | This read-only bitfield is reserved and always has the value zero. |  |  |  |

Table continues on the next page...

#### PDBx\_DACINTn field descriptions (continued)

| Field       | Description                                                                                                                                                                                                                                                                              |  |  |  |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 15–0<br>INT | DAC Interval  These bits specify the interval value for DAC interval trigger. DAC interval trigger triggers DAC[1:0] update when the DAC interval counter is equal to the DACINT. Reading these bits returns the value of internal register that is effective for the current PDB cycle. |  |  |  |

## 33.3.11 Pulse-Out n Enable Register (PDBx\_POnEN)

Addresses: PDB0\_PO0EN is FFFF\_8540h base + 28h offset = FFFF\_8568h



#### PDBx\_POnEN field descriptions

| Field            | Description                                                                                              |  |  |  |
|------------------|----------------------------------------------------------------------------------------------------------|--|--|--|
| 31–8<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                       |  |  |  |
| 7–0<br>POEN      | PDB Pulse-Out Enable  These bits enable the pulse output. Only lower Y bits are implemented in this MCU. |  |  |  |
|                  | PDB Pulse-Out disabled     PDB Pulse-Out enabled                                                         |  |  |  |

## 33.3.12 Pulse-Out n Delay Register (PDBx\_POnDLY)

Addresses: PDB0\_PO0DLY is FFFF\_8540h base + 2Ch offset = FFFF\_856Ch



#### PDBx\_POnDLY field descriptions

| Field         | Description           |  |  |  |  |
|---------------|-----------------------|--|--|--|--|
| 31–16<br>DLY1 | PDB Pulse-Out Delay 1 |  |  |  |  |

Table continues on the next page...

#### **Functional Description**

#### PDBx\_POnDLY field descriptions (continued)

| Field        | Description                                                                                                                                                                                                                                             |  |  |  |  |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
|              | These bits specify the delay 1 value for the PDB Pulse-Out. Pulse-Out goes high when the PDB counter is equal to the DLY1. Reading these bits returns the value of internal register that is effective for the current PDB cycle.                       |  |  |  |  |
| 15–0<br>DLY2 | PDB Pulse-Out Delay 2  These bits specify the delay 2 value for the PDB Pulse-Out. Pulse-Out goes low when the PDB counter is equal to the DLY2. Reading these bits returns the value of internal register that is effective for the current PDB cycle. |  |  |  |  |

## 33.4 Functional Description

## 33.4.1 PDB Pre-trigger and Trigger Outputs

The PDB contains a counter whose output is compared against several different digital values. If the PDB is enabled, a trigger input event will reset the counter and make it start to count. A trigger input event is defined as a rising edge being detected on selected trigger input source or software trigger being selected and SC[SWTRIG] is written with 1. For each channel, delay *m* determines the time between assertion of the trigger input event to the point at which changes in the pre-trigger *m* output signal is initiated. The time is defined as:

- Trigger input event to pre-trigger m = (prescaler X multiplication factor X delay <math>m) + 2 peripheral clock cycles
- Add one additional peripheral clock cycle to determine the time at which the channel trigger output change.

Each channel is associated with one ADC block. PDB channel n pre-trigger outputs 0 to M and trigger output is connected to ADC hardware trigger select and hardware trigger inputs. The pre-triggers are used to precondition the ADC block prior to the actual trigger. The ADC contains M sets of configuration and result registers, allowing it to operate in a ping-pong fashion, alternating conversions between M different analog sources. The pre-trigger outputs are used to specify which signal will be sampled next. When pre-trigger m is asserted, the ADC conversion is triggered with set m of the configuration and result registers.

The waveforms shown in the following diagram illuminate the pre-trigger and trigger outputs of PDB channel n. The delays can be independently set via the CHnDLYm registers. And the pre-triggers can be enabled or disabled in CHnC1[EN[m]].



Figure 33-42. Pre-trigger and Trigger Outputs

The delay in CHnDLYm register can be optionally bypassed, if CHnC1[TOS[m]] is cleared. In this case, when the trigger input event occurs, the pre-trigger m is asserted after two peripheral clock cycles.

The PDB can be configured in back-to-back (B2B) operation. B2B operation enables the ADC conversions complete to trigger the next PDB channel pre-trigger and trigger outputs, so that the ADC conversions can be triggered on next set of configuration and results registers. When B2B is enabled by setting CHnC1[BB[m]], the delay m is ignored and the pre-trigger m is asserted two peripheral cycles after the acknowledgment m is received. The acknowledgment connections in this MCU is described in Back-to-back Acknowledgement Connections.

When an ADC conversion, which is triggered by one of the pre-triggers from PDB channel n, is in progress and ADCnSC1[COCO] is not set, a new trigger from PDB channel n pre-trigger m cannot be accepted by ADCn. Therefore every time when one PDB channel n pre-trigger and trigger output starts an ADC conversion, an internal lock associated with the corresponding pre-trigger is activated. The lock becomes inactive when the corresponding ADCnSC1[COCO] is set, or the corresponding PDB pre-trigger is disabled, or the PDB is disabled. The channel n trigger output is suppressed when any of the locks of the pre-triggers in channel n is active. If a new pre-trigger m asserts when there is active lock in the PDB channel n, a register flag bit, CHnS[ERR[m]], associated with the pre-trigger m is set. If SC[PDBEIE] is set, the sequence error interrupt is generated. Sequence error is typically happened because the delay m is set too short and the pre-trigger m asserts before the previous triggered ADC conversion is completed.

When the PDB counter reaches the value set in IDLY register, the SC[PDBIF] flag is set. A PDB interrupt can be generated if SC[PDBIE] is set and SC[DMAEN] is cleared. If SC[DMAEN] is set, PDB requests a DMA transfer when SC[PDBIF] is set.

The modulus value in MOD register, is used to reset the counter back to zero at the end of the count. If SC[CONT] bit is set, the counter will then resume a new count. Otherwise, the counter operation will cease until the next trigger input event occurs.

## 33.4.2 PDB Trigger Input Source Selection

The PDB has up to 15 trigger input sources, namely Trigger-In 0 to 14. They are connected to on-chip or off-chip event sources. The PDB can be triggered by software through the SC[SWTRIG]. SC[TRIGSEL] bits select the active trigger input source or software trigger.

For the trigger input sources implemented in this MCU, refer to Chip Configuration information.

## 33.4.3 DAC Interval Trigger Outputs

PDB can generate the interval triggers for DACs to update their outputs periodically. DAC interval counter x is reset and started when a trigger input event occurs if DACINTCx[EXT] is cleared. When the interval counter x is equal to the value set in DACINTx register, the DAC interval trigger x output generates a pulse of one peripheral clock cycle width to update the DACx. If DACINTCx[EXT] is set, the DAC interval counter is bypassed and the interval trigger output x generates a pulse following the detection of a rising edge on the DAC external trigger input. The counter and interval trigger can be disabled by clearing the DACINTCx[TOE].

DAC interval counters are also reset when the PDB counter reaches the MOD register value, therefore when the PDB counter rolls over to zero, the DAC interval counters starts anew.

Together, the DAC interval trigger pulse and the ADC pre-trigger/trigger pulses allow precise timing of DAC updates and ADC measurements. This is outlined in the typical use case described in the following diagram.



Figure 33-43. PDB ADC Triggers and DAC Interval Triggers Use Case

#### **NOTE**

Because the DAC interval counters share the prescaler with PDB counter, PDB must be enabled if the DAC interval trigger outputs are used in the applications.

#### 33.4.4 Pulse-Out's

PDB can generate pulse outputs of configurable width. When PDB counter reaches the value set in POyDLY[DLY1], the Pulse-Out goes high; when the counter reaches POyDLY[DLY2], it goes low. POyDLY[DLY2] can be set either greater or less than POyDLY[DLY1].

Because the PDB counter is shared by both ADC pre-trigger/trigger outputs and Pulse-Out generation, they have the same time base.

The pulse-out connections implemented in this MCU are described in the device's Chip Configuration details.

## 33.4.5 Updating the Delay Registers

The following registers control the timing of the PDB operation; and in some of the applications, they may need to become effective at the same time.

#### **Functional Description**

- PDB Modulus Register (MOD)
- PDB Interrupt Delay Register (IDLY)
- PDB Channel *n* Delay *m* Register (CH*n*DLY*m*)
- DAC Interval x Register (DACINTx)
- PDB Pulse-Out y Delay Register (POyDLY)

The internal registers of them are buffered and any values written to them are written first to their buffers. The circumstances that cause their internal registers to be updated with the values from the buffers are summarized as below table.

SC[LDMOD]

Update to the Delay Registers

The internal registers are loaded with the values from their buffers immediately after 1 is written to SC[LDOK].

The PDB counter reaches the MOD register value after 1 is written to SC[LDOK].

A trigger input event is detected after 1 is written to SC[LDOK].

A trigger input event is detected after 1 is written to SC[LDOK].

Either the PDB counter reaches the MOD register value, or a trigger input event is detected, after 1 is written to SC[LDOK].

Table 33-44. Circumstances of Update to the Delay Registers

After 1 is written to SC[LDOK], the buffers cannot be written until the values in buffers are loaded into their internal registers. SC[LDOK] is self-cleared when the internal registers are loaded, so the application code can read it to determine the updates of the internal registers.

The following diagrams show the cases of the internal registers being updated with SC[LDMOD] is 00 and x1.



Figure 33-44. Registers Update with SC[LDMOD] = 00



Figure 33-45. Registers Update with SC[LDMOD] = x1

## 33.4.6 Interrupts

PDB can generate two interrupts, PDB interrupt and PDB sequence error interrupt. The following table summarizes the interrupts.

 Interrupt
 Flags
 Enable Bit

 PDB Interrupt
 SC[PDBIF]
 SC[PDBIE] = 1 and SC[DMAEN] = 0

 PDB Sequence Error Interrupt
 CHnS[ERRm]
 SC[PDBEIE] = 1

**Table 33-45. PDB Interrupt Summary** 

## 33.4.7 DMA

If SC[DMAEN] is set, PDB can generate DMA transfer request when SC[PDBIF] is set. When DMA is enabled, the PDB interrupt will not be issued.

# 33.5 Application Information

## 33.5.1 Impact of Using the Prescaler and Multiplication Factor on Timing Resolution

Use of prescaler and multiplication factor greater than 1 limits the count/delay accuracy in terms of peripheral clock cycles (to the modulus of the prescaler X multiplication factor). If the multiplication factor is set to 1 and the prescaler is set to 2 then the only

#### **Application Information**

values of total peripheral clocks that can be detected are even values; if prescaler is set to 4 then the only values of total peripheral clocks that can be decoded as detected are mod(4) and so forth. If the applications need a really long delay value and use 128, then the resolution would be limited to 128 peripheral clock cycles.

Therefore, use the lowest possible prescaler and multiplication factor for a given application.

# **Chapter 34 Modulo Timer (MTIM)**

#### 34.1 Introduction

The MTIM (or MTIM16) module is a simple 16-bit timer with several software selectable clock sources and a programmable interrupt.

## 34.2 Features

Timer system features include:

- 16-bit up-counter
  - Free-running or 16-bit modulo limit
  - Software controllable interrupt on overflow
  - Counter reset bit (TRST)
  - Counter stop bit (TSTP)
- Four software selectable clock sources for input to prescaler:
  - System bus clock rising edge
  - Fixed frequency clock (XCLK) rising edge
  - External clock source on the TCLK pin rising edge
  - External clock source on the TCLK pin falling edge
- Nine selectable clock prescale values:

#### **Features**

- Clock source divide by 1, 2, 4, 8, 16, 32, 64, 128, or 256
- Modulo compare matched can be an output

## 34.2.1 Block Diagram

The block diagram for the modulo timer module is shown in the following figure.



Figure 34-1. Modulo Timer (S08MTIM16) Block Diagram

## 34.2.2 Modes of Operation

This section defines MTIM16 operation in stop, wait, and background debug modes.

#### 34.2.2.1 MTIM16 in Wait Mode

The MTIM16 continues to run in wait mode if enabled prior to the execution of the WAIT instruction. The timer overflow interrupt brings the MCU out of wait mode if it is enabled. For lowest possible current consumption, the MTIM16 should be stopped by software if it is not needed as an interrupt source during wait mode.

## **34.2.2.2 MTIM16 in Stop Modes**

The MTIM16 is disabled in all stop modes, regardless of the settings before executing the STOP instruction. Therefore, the MTIM16 cannot be used as a wakeup source from any stop mode.

Upon waking from very low-power stop modes, the MTIM16 enters its reset state.

For low-power stop modes:

- If the device exits any of these modes with a reset, the MTIM16 module enters its reset state.
- If the device exits any of these modes with an interrupt, the MTIM16 module continues from its state in the low-power stop mode.
- If the counter was active upon entering any of these modes, the count resumes from the current value.

## 34.2.2.3 MTIM16 in Active Background Mode

The MTIM16 stops all counting until the microcontroller returns to normal user operating mode. Counting resumes from the suspended value as long as an MTIM16 reset did not occur (TRST written to a 1).

# 34.3 External Signal Description

This section describes the module external signals.

## 34.3.1 TCLK — External Clock Source Input into MTIM16

The MTIM16 includes one external signal, TCLK, used to input an external clock when selected as the MTIM16 clock source. The signal properties of TCLK are shown in the following table.

Table 34-1. Signal Properties

| Signal | Function                                | I/O |
|--------|-----------------------------------------|-----|
| TCLK   | External clock source input into MTIM16 | I   |

The TCLK input must be synchronized by the bus clock. Also, variations in duty cycle and clock jitter must be accommodated. As a result, the TCLK signal must be limited to one-fourth of the bus frequency.

The TCLK pin can be muxed with a general-purpose port pin. Refer to the chip-level signal multiplexing and pin assignment details for more information.

# 34.4 Memory Map and Register Descriptions

Each MTIM16 module includes six registers.

If a chip has more than one MTIM16 module, register names include placeholder characters.

#### MTIMx memory map

| Absolute address (hex) | Register name                                   | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|------------------------|-------------------------------------------------|--------------------|--------|-------------|------------------|
| FFFF_8410              | MTIM16 status and control register (MTIM0_SC)   | 8                  | R/W    | 10h         | 34.4.1/<br>750   |
| FFFF_8411              | MTIM16 clock configuration register (MTIM0_CLK) | 8                  | R/W    | 00h         | 34.4.2/<br>751   |
| FFFF_8412              | MTIM16 counter register high (MTIM0_CNTH)       | 8                  | R      | 00h         | 34.4.3/<br>752   |
| FFFF_8413              | MTIM16 counter register low (MTIM0_CNTL)        | 8                  | R      | 00h         | 34.4.4/<br>753   |
| FFFF_8414              | MTIM16 modulo register high (MTIM0_MODH)        | 8                  | R/W    | 00h         | 34.4.5/<br>754   |
| FFFF_8415              | MTIM16 modulo register low (MTIM0_MODL)         | 8                  | R/W    | 00h         | 34.4.6/<br>755   |

## 34.4.1 MTIM16 status and control register (MTIMx\_SC)

This register contains the overflow status flag and control bits. Use them to configure the interrupt enable, reset the counter, and stop the counter.

Addresses: MTIM0\_SC is FFFF\_8410h base + 0h offset = FFFF\_8410h



#### MTIM0\_SC field descriptions

| Field | Description          |
|-------|----------------------|
|       | MTIM16 overflow flag |
| TOF   |                      |

Table continues on the next page...

## MTIM0\_SC field descriptions (continued)

| Field           | Description                                                                                                                                                                                                                                                                              |
|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                 | This bit is set when the MTIM16 counter register overflows to 0x0000 after reaching the value in the MTIM16 modulo register. Clear TOF by reading the SC register while TOF is set and then by writing 0 to TOF. Writing 1 has no effect. TOF is also cleared when 1 is written to TRST. |
|                 | <ul> <li>MTIM16 counter has not reached the overflow value in the MTIM16 modulo register.</li> <li>MTIM16 counter has reached the overflow value in the MTIM16 modulo register.</li> </ul>                                                                                               |
| 6               | MTIM16 overflow interrupt enable                                                                                                                                                                                                                                                         |
| TOIE            | This read/write bit enables MTIM16 overflow interrupts. If TOIE is set, then an interrupt is generated when TOF = 1. Reset clears TOIE. Do not set TOIE if TOF = 1; instead, clear TOF first, and then set TOIE.                                                                         |
|                 | 0 TOF interrupts are disabled. Use software polling.                                                                                                                                                                                                                                     |
|                 | 1 TOF interrupts are enabled.                                                                                                                                                                                                                                                            |
| 5               | MTIM16 counter reset                                                                                                                                                                                                                                                                     |
| TRST            | When 1 is written to this write-only bit, the MTIM16 counter register resets to 0x0000 and TOF is cleared. Writing 1 to this bit also causes the modulo value to take effect at once. Reading this bit always returns 0.                                                                 |
|                 | 0 No effect. MTIM16 counter remains in its current state.                                                                                                                                                                                                                                |
|                 | 1 MTIM16 counter is reset to 0x0000.                                                                                                                                                                                                                                                     |
| 4               | MTIM16 counter stop                                                                                                                                                                                                                                                                      |
| TSTP            | When set, this read/write bit stops the MTIM16 counter at its current value. Counting resumes from the current value when TSTP is cleared. Reset sets TSTP to prevent the MTIM16 from counting.                                                                                          |
|                 | 0 MTIM16 counter is active.                                                                                                                                                                                                                                                              |
|                 | 1 MTIM16 counter is stopped.                                                                                                                                                                                                                                                             |
| 3–0<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                                       |

# 34.4.2 MTIM16 clock configuration register (MTIMx\_CLK)

This register contains the clock select bits (CLKS) and the prescaler select bits (PS).

Addresses: MTIM0\_CLK is FFFF\_8410h base + 1h offset = FFFF\_8411h



#### MTIM0\_CLK field descriptions

| Field           | Description                                                        |
|-----------------|--------------------------------------------------------------------|
| 7–6<br>Reserved | This read-only bitfield is reserved and always has the value zero. |

Table continues on the next page...

#### **Memory Map and Register Descriptions**

#### MTIM0\_CLK field descriptions (continued)

| Field       | Description                                                                                                                                                                                                                                                             |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5–4<br>CLKS | Clock source select                                                                                                                                                                                                                                                     |
|             | These two read/write bits select one of four different clock sources as the input to the MTIM16 prescaler. Changing the clock source while the counter is active does not clear the counter. The count continues with the new clock source. Reset clears CLKS to 00.    |
|             | 00 Encoding 0. Bus clock (BUSCLK)                                                                                                                                                                                                                                       |
|             | 01 Encoding 1. Fixed-frequency clock (XCLK)                                                                                                                                                                                                                             |
|             | 10 Encoding 3. External source (TCLK pin), falling edge                                                                                                                                                                                                                 |
|             | 11 Encoding 4. External source (TCLK pin), rising edge                                                                                                                                                                                                                  |
| 3–0<br>PS   | Clock source prescaler  These four read/write bits select one of nine outputs from the 8-bit prescaler. Changing the prescaler value while the counter is active does not clear the counter. The count continues with the new prescaler value. Reset clears PS to 0000. |
|             | 0000 Encoding 0. MTIM16 clock source / 1                                                                                                                                                                                                                                |
|             | 0001 Encoding 1. MTIM16 clock source / 2                                                                                                                                                                                                                                |
|             | 0010 Encoding 2. MTIM16 clock source / 4                                                                                                                                                                                                                                |
|             | 0011 Encoding 3. MTIM16 clock source / 8                                                                                                                                                                                                                                |
|             | 0100 Encoding 4. MTIM16 clock source / 16                                                                                                                                                                                                                               |
|             | 0101 Encoding 5. MTIM16 clock source / 32                                                                                                                                                                                                                               |
|             | 0110 Encoding 6. MTIM16 clock source / 64                                                                                                                                                                                                                               |
|             | 0111 Encoding 7. MTIM16 clock source / 128                                                                                                                                                                                                                              |
|             | 1xxx Encoding 8+. MTIM16 clock source / 256                                                                                                                                                                                                                             |

## 34.4.3 MTIM16 counter register high (MTIMx\_CNTH)

This register is the read-only value of the high byte of the current MTIM16 16-bit counter.

When either the CNTH or CNTL register is read, the content of the two registers is latched into a buffer where they remain latched until the other register is read. This allows the coherent 16-bit value to be read in both big-endian and little-endian compile environments and ensures the 16-bit counter is unaffected by the read operation. The coherency mechanism is automatically restarted by an MCU reset or by setting the TRST bit of the SC register (whether BDM mode is active or not).

When BDM is active, the coherency mechanism is frozen such that the buffer latches remain in the state they were in when BDM became active, even if one or both halves of the counter register are read while BDM is active. This assures that if the user was in the middle of reading a 16-bit register when BDM became active, the appropriate value from the other half of the 16-bit value is read after returning to normal execution. The value read from the CNTH and CNTL registers in BDM mode is the value of these registers and not the value of their read buffer.

Addresses: MTIM0\_CNTH is FFFF\_8410h base + 2h offset = FFFF\_8412h



#### MTIM0\_CNTH field descriptions

| Field       | Description                                                                                                                                                                            |
|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–0<br>CNTH | MTIM16 count (high byte)  These 8 read-only bits contain the current high byte value of the 16-bit counter. Writing has no effect on this register. Reset clears the register to 0x00. |

## 34.4.4 MTIM16 counter register low (MTIMx\_CNTL)

This register is the read-only value of the low byte of the current MTIM16 16-bit counter.

When either the CNTH or CNTL register is read, the content of the two registers is latched into a buffer where they remain latched until the other register is read. This allows the coherent 16-bit value to be read in both big-endian and little-endian compile environments and ensures the 16-bit counter is unaffected by the read operation. The coherency mechanism is automatically restarted by an MCU reset or by setting the TRST bit of the SC register (whether BDM mode is active or not).

When BDM is active, the coherency mechanism is frozen such that the buffer latches remain in the state they were in when BDM became active, even if one or both halves of the counter register are read while BDM is active. This assures that if the user was in the middle of reading a 16-bit register when BDM became active, the appropriate value from the other half of the 16-bit value is read after returning to normal execution. The value read from the CNTH and CNTL registers in BDM mode is the value of these registers and not the value of their read buffer.

Addresses: MTIMO\_CNTL is FFFF\_8410h base + 3h offset = FFFF\_8413h



#### **Memory Map and Register Descriptions**

#### MTIM0\_CNTL field descriptions

| Field       | Description                                                                                                                                                                          |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–0<br>CNTL | MTIM16 count (low byte)  These 8 read-only bits contain the current low byte value of the 16-bit counter. Writing has no effect on this register. Reset clears the register to 0x00. |

## 34.4.5 MTIM16 modulo register high (MTIMx\_MODH)

A value of 0x0000 in MODH:MODL puts the MTIM16 in free-running mode. Writing to either MODH or MODL latches the value into a buffer and the latched buffers are updated after the second byte writing. The updated values take effect and reload to the MODH:MODL registers in the next MTIM16 counter cycle, except for the first writing of modulo after a chip reset or in BDM mode. However, after a software reset, the MODH:MODL takes effect at once even if it did not take effect before the reset. On the first writing of MODH:MODL after chip reset, the counter is reset and the modulo takes effect immediately. The latching mechanism may be manually reset by setting the TRST bit of the SC register (whether BDM is active or not).

When BDM is active, the coherency mechanism is frozen so that the buffer latches remain in the state they were in when the BDM became active, even if one or both halves of the modulo register are written while BDM is active. Any writing to the modulo registers bypasses the buffer latches and writes directly to the modulo register while BDM is active, and also the counter is cleared at the same time.

Reading MODH:MODL returns the modulo values that are taking effect whenever in normal run mode or in BDM mode.

Addresses: MTIM0\_MODH is FFFF\_8410h base + 4h offset = FFFF\_8414h



#### MTIM0 MODH field descriptions

| Field       | Description                                                                                                                                                   |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–0<br>MODH | MTIM16 modulo (high byte)  These 8 read/write bits contain the modulo high byte value used to reset the counter and set TOF. Reset sets the register to 0x00. |

## 34.4.6 MTIM16 modulo register low (MTIMx\_MODL)

A value of 0x0000 in MODH:MODL puts the MTIM16 in free-running mode. Writing to either MODH or MODL latches the value into a buffer and the latched buffers are updated after the second byte writing. The updated values take effect and reload to the MODH:MODL registers in the next MITIM16 counter cycle, except for the first writing of modulo after a chip reset or in BDM mode. However, after a software reset, the MODH:MODL takes effect at once even if it did not take effect before the reset. On the first writing of MODH:MODL after chip reset, the counter is reset and the modulo takes effect immediately. The latching mechanism may be manually reset by setting the TRST bit of the SC register (whether BDM is active or not).

When BDM is active, the coherency mechanism is frozen so that the buffer latches remain in the state they were in when the BDM became active, even if one or both halves of the modulo register are written while BDM is active. Any writing to the modulo registers bypasses the buffer latches and writes directly to the modulo register while BDM is active, and also the counter is cleared at the same time.

Reading MODH:MODL returns the modulo values that are taking effect whenever in normal run mode or in BDM mode.





#### MTIM0\_MODL field descriptions

| Field       | Description                                                                                                                                                 |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–0<br>MODL | MTIM16 modulo (low byte)  These 8 read/write bits contain the modulo low byte value used to reset the counter and set TOF. Reset sets the register to 0x00. |

## 34.5 Functional Description

The MTIM16 is composed of a main 16-bit up-counter with 16-bit modulo register, a clock source selector, and a prescaler block with nine selectable values. The module also contains software selectable interrupt logic.

#### **Functional Description**

The MTIM16 counter (CNTH:CNTL registers) has three modes of operation: stopped, free-running, and modulo. The counter is stopped out of reset. If the counter starts without writing a new value to the modulo registers, it will be in free-running mode. The counter is in modulo mode when a value other than 0x0000 is in the modulo registers.

After an MCU reset, the counter stops and resets to 0x0000, and the modulo also resets to 0x0000. The bus clock functions as the default clock source, and the prescale value is divided by 1. To start the MTIM16 in free-running mode, write to the MTIM16 status and control (SC) register and clear the MTIM16 stop (TSTP) bit.

Four clock sources are software selectable: the internal bus clock, the fixed frequency clock (XCLK), and an external clock on the TCLK pin that is selectable as incrementing on either rising or falling edges. The MTIM16 clock select (CLKS) field in the CLK register selects the desired clock source. If the counter is active (the TSTP bit is 0) when a new clock source is selected, the counter continues counting from the previous value using the new clock source.

Nine prescale values are software selectable: clock source divided by 1, 2, 4, 8, 16, 32, 64, 128, or 256. The prescaler select bits (PS[3:0]) in the CLK register select the desired prescale value. If the counter is active (TSTP = 0) when a new prescaler value is selected, the counter continues counting from the previous value using the new prescaler value.

The MTIM16 modulo register (MODH:MODL) allows the overflow compare value to be set to any value from 0x0001 to 0xFFFF. Reset clears the modulo value to 0x0000, which results in a free-running counter.

When the counter is active (the TSTP bit is 0), it increases at the selected rate until the count matches the modulo value. When these values match, the counter overflows to 0x0000 and continues counting. The MTIM16 overflow flag (TOF) is set whenever the counter overflows. The flag sets on the transition from the modulo value to 0x0000.

Clearing TOF is a two-step process. The first step is to read the SC register while TOF is set. The second step is to write a 0 to TOF. If another overflow occurs between the first and second steps, the clearing process is reset and TOF stays set after the second step is performed. This will prevent the second occurrence from being missed. TOF is also cleared when a 1 is written to TRST.

The MTIM16 module allows for an optional interrupt to be generated whenever TOF is set. To enable the MTIM16 overflow interrupt, set the MTIM16 overflow interrupt enable (TOIE) bit in the SC register. The TOIE bit should never be written to be 1 while TOF is 1. Instead, TOF should be cleared first, and then the TOIE bit can be set to 1.

# 34.5.1 MTIM16 Operation Example

This section shows an example of the MTIM16 module's operation as the counter reaches a matching value from the modulo register.



Figure 34-14. MTIM16 Counter Overflow Example

In this figure, the selected clock source could be any of the four possible choices. The prescaler is set to divide-by-4 (the PS field is 0010). The modulo value in the MODH:MODL register is set to 01AAh. When the counter (CNTH:CNTL registers) reaches the modulo value of 01AAh, the counter overflows to 0000h and continues counting. The timer overflow flag, TOF, sets when the counter value changes from 01AAh to 0000h. An MTIM16 overflow interrupt is generated when TOF is set, if the TOIE bit is 1.

**Functional Description** 

# **Chapter 35 Low Power Timer (LPTMR)**

### 35.1 Introduction

The low power timer (LPTMR) can be configured to operate as a time counter (with optional prescaler) or as a pulse counter (with optional glitch filter) across all power modes, including the low leakage modes. It can also continue operating through most system reset events, allowing it to be used as a time of day counter.

### **35.1.1 Features**

The LPTMR module's features include:

- 16-bit time counter or pulse counter with compare
  - Optional interrupt can generate asynchronous wakeup from any low power mode
  - Hardware trigger output
  - Counter supports free-running mode or reset on compare
- Configurable clock source for prescaler/glitch filter
- Configurable input source for pulse counter
  - Rising edge or falling edge

# 35.1.2 Modes of operation

### 35.1.2.1 Run mode

In run mode, the LPTMR operates normally.

LPTMR signal descriptions

### 35.1.2.2 Wait mode

In wait mode, the LPTMR continues to operate normally and may be configured to exit the low power mode by generating an interrupt request.

# 35.1.2.3 Stop mode

In stop mode, the LPTMR continues to operate normally and may be configured to exit the low power mode by generating an interrupt request.

## 35.1.2.4 Low leakage modes

In low leakage modes, the LPTMR continues to operate normally and may be configured to exit the low power mode by generating an interrupt request.

## **35.1.2.5 Debug modes**

In debug mode, the LPTMR operates normally.

# 35.2 LPTMR signal descriptions

Table 35-1. LPTMR signal descriptions

| Signal             | Description             | I/O |
|--------------------|-------------------------|-----|
| LPTMR_ALT <i>n</i> | Pulse counter input pin | I   |

# 35.2.1 Detailed signal descriptions

Table 35-2. LPTMR interface-detailed signal descriptions

| Signal     | I/O | Description              |                                                                                                                                      |  |
|------------|-----|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------|--|
| LPTMR_ALTn | I   | Pulse counter input.     |                                                                                                                                      |  |
|            |     | The LPTMR can select one | of the input pins to be used in pulse counter mode.                                                                                  |  |
|            |     | State meaning            | Assertion-If configured for pulse counter mode with active high input then assertion causes the LPTMR counter register to increment. |  |
|            |     |                          | Negation-If configured for pulse counter mode with active low input then negation cause the LPTMR counter register to increment.     |  |
|            |     | Timing                   | Assertion or negation may occur at any time; input may assert asynchronously to the bus clock.                                       |  |

# 35.3 Memory map and register definition

### **NOTE**

All LPTMR registers are reset by the Chip POR not VLLS reset type and by POR Only, which triggers Chip POR not VLLS. Each register's displayed reset value represents this subset of reset types. LPTMR registers are unaffected by other reset types. For more information about the types of reset on this chip, refer to the Reset details.

#### LPTMRx memory map

| Absolute address (hex) | Register name                                        | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|------------------------|------------------------------------------------------|--------------------|--------|-------------|------------------|
| FFFF_84C0              | Low Power Timer Control Status Register (LPTMR0_CSR) | 32                 | R/W    | 0000_0000h  | 35.3.1/<br>762   |
| FFFF_84C4              | Low Power Timer Prescale Register (LPTMR0_PSR)       | 32                 | R/W    | 0000_0000h  | 35.3.2/<br>764   |
| FFFF_84C8              | Low Power Timer Compare Register (LPTMR0_CMR)        | 32                 | R/W    | 0000_0000h  | 35.3.3/<br>765   |
| FFFF_84CC              | Low Power Timer Counter Register (LPTMR0_CNR)        | 32                 | R      | 0000_0000h  | 35.3.4/<br>766   |
| FFFF_84D0              | Low Power Timer Control Status Register (LPTMR1_CSR) | 32                 | R/W    | 0000_0000h  | 35.3.1/<br>762   |
| FFFF_84D4              | Low Power Timer Prescale Register (LPTMR1_PSR)       | 32                 | R/W    | 0000_0000h  | 35.3.2/<br>764   |

Table continues on the next page...

#### Memory map and register definition

### LPTMRx memory map (continued)

| Absolute<br>address<br>(hex) | Register name                                 | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|------------------------------|-----------------------------------------------|--------------------|--------|-------------|------------------|
| FFFF_84D8                    | Low Power Timer Compare Register (LPTMR1_CMR) | 32                 | R/W    | 0000_0000h  | 35.3.3/<br>765   |
| FFFF_84DC                    | Low Power Timer Counter Register (LPTMR1_CNR) | 32                 | R      | 0000_0000h  | 35.3.4/<br>766   |

# 35.3.1 Low Power Timer Control Status Register (LPTMRx\_CSR)

Addresses: LPTMR0\_CSR is FFFF\_84C0h base + 0h offset = FFFF\_84C0h LPTMR1\_CSR is FFFF\_84D0h base + 0h offset = FFFF\_84D0h



### LPTMRx\_CSR field descriptions

| Field            | Description                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–8<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                                                                                                                                                                                                 |
| 7<br>TCF         | Timer Compare Flag  The timer compare flag is set when the LPTMR is enabled and the LPTMR Counter Register equals the LPTMR Compare Register and increments. This Timer Compare Flag is cleared when the LPTMR is disabled or a logic one is written to the Timer Compare Flag.  1 LPTMR Counter Register has not equaled the LPTMR Compare Register and incremented LPTMR Counter Register has equaled the LPTMR Compare Register and incremented |
| 6<br>TIE         | Timer Interrupt Enable  When the Timer Interrupt Enable is set, the LPTMR Interrupt is generated whenever the Timer Compare Flag is also set.  O Timer Interrupt Disabled.  1 Timer Interrupt Enabled.                                                                                                                                                                                                                                             |

Table continues on the next page...

# LPTMRx\_CSR field descriptions (continued)

| Field      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5–4<br>TPS | Timer Pin Select  The Timer Pin Select configures the input source to be used in Pulse Counter mode. The Timer Pin Select should only be altered when the LPTMR is disabled. The input connections vary by device. See the Chip Configuration details for information on the connections to these inputs.  On Pulse counter input 0 is selected.  Description:                                                                                                                 |
|            | 10 Pulse counter input 2 is selected.  11 Pulse counter input 3 is selected.                                                                                                                                                                                                                                                                                                                                                                                                   |
| 3<br>TPP   | Timer Pin Polarity  The Timer Pin Polarity configures the polarity of the input source in Pulse Counter mode. The Timer Pin Polarity should only be changed when the LPTMR is disabled.  O Pulse Counter input source is active high, and LPTMR Counter Register will increment on the rising edge.  Pulse Counter input source is active low, and LPTMR Counter Register will increment on the falling edge.                                                                  |
| 2<br>TFC   | Timer Free Running Counter  When clear the Timer Free Running Counter configures the LPTMR Counter Register to reset whenever the Timer Compare Flag is set. When set, the Timer Free Running Counter configures the LPTMR Counter Register to reset on overflow. The Timer Free Running Counter should only be altered when the LPTMR is disabled.  0 LPTMR Counter Register is reset whenever the Timer Compare Flag is set.  1 LPTMR Counter Register is reset on overflow. |
| 1<br>TMS   | Timer Mode Select The Timer Mode Select configures the mode of the LPTMR. The Timer Mode Select should only be altered when the LPTMR is disabled.  O Time Counter mode.  1 Pulse Counter mode.                                                                                                                                                                                                                                                                                |
| 0<br>TEN   | Timer Enable  When the Timer Enable bit is clear, it resets the LPTMR internal logic (including the LPTMR Counter Register and Timer Compare Flag). When the Timer Enable bit is set, the LPTMR is enabled. When writing 1 to this bit, bits LPTMR_CSR[5:1] should not be altered.  0 LPTMR is disabled and internal logic is reset.  1 LPTMR is enabled.                                                                                                                      |

# 35.3.2 Low Power Timer Prescale Register (LPTMRx\_PSR)

Addresses: LPTMR0\_PSR is FFFF\_84C0h base + 4h offset = FFFF\_84C4h LPTMR1\_PSR is FFFF\_84D0h base + 4h offset = FFFF\_84D4h



### LPTMRx\_PSR field descriptions

| Field            | Description                                                                                                                                                                                                                 |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–7<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                          |
| 6–3<br>PRESCALE  | Prescale Value                                                                                                                                                                                                              |
|                  | The Prescaler Value register field configures the size of the Prescaler (in Time Counter mode) or width of the Glitch Filter (in Pulse Counter mode). The Prescale Value should only be altered when the LPTMR is disabled. |
|                  | 0000 Prescaler divides the prescaler clock by 2; Glitch Filter does not support this configuration.                                                                                                                         |
|                  | O001 Prescaler divides the prescaler clock by 4; Glitch Filter recognizes change on input pin after 2 rising clock edges.                                                                                                   |
|                  | 0010 Prescaler divides the prescaler clock by 8; Glitch Filter recognizes change on input pin after 4 rising clock edges.                                                                                                   |
|                  | O011 Prescaler divides the prescaler clock by 16; Glitch Filter recognizes change on input pin after 8 rising clock edges.                                                                                                  |
|                  | O100 Prescaler divides the prescaler clock by 32; Glitch Filter recognizes change on input pin after 16 rising clock edges.                                                                                                 |
|                  | O101 Prescaler divides the prescaler clock by 64; Glitch Filter recognizes change on input pin after 32 rising clock edges.                                                                                                 |
|                  | O110 Prescaler divides the prescaler clock by 128; Glitch Filter recognizes change on input pin after 64 rising clock edges.                                                                                                |
|                  | O111 Prescaler divides the prescaler clock by 256; Glitch Filter recognizes change on input pin after 128 rising clock edges.                                                                                               |
|                  | 1000 Prescaler divides the prescaler clock by 512; Glitch Filter recognizes change on input pin after 256 rising clock edges.                                                                                               |
|                  | 1001 Prescaler divides the prescaler clock by 1024; Glitch Filter recognizes change on input pin after 512 rising clock edges.                                                                                              |
|                  | 1010 Prescaler divides the prescaler clock by 2048; Glitch Filter recognizes change on input pin after 1024 rising clock edges.                                                                                             |
|                  | 1011 Prescaler divides the prescaler clock by 4096; Glitch Filter recognizes change on input pin after 2048 rising clock edges.                                                                                             |
|                  | 1100 Prescaler divides the prescaler clock by 8192; Glitch Filter recognizes change on input pin after 4096 rising clock edges.                                                                                             |
|                  | Prescaler divides the prescaler clock by 16384; Glitch Filter recognizes change on input pin after 8192 rising clock edges.                                                                                                 |

Table continues on the next page...

### LPTMRx\_PSR field descriptions (continued)

| Field      | Description                                                                                                                                                                                                                                                                                                                                                                       |
|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | 1110 Prescaler divides the prescaler clock by 32768; Glitch Filter recognizes change on input pin after 16384 rising clock edges.                                                                                                                                                                                                                                                 |
|            | Prescaler divides the prescaler clock by 65536; Glitch Filter recognizes change on input pin after 32768 rising clock edges.                                                                                                                                                                                                                                                      |
| 2<br>PBYP  | Prescaler Bypass                                                                                                                                                                                                                                                                                                                                                                  |
|            | When the Prescaler Bypass is set the selected prescaler clock (in Time Counter mode) or selected input source (in Pulse Counter mode) directly clocks the LPTMR Counter Register. When the Prescaler Bypass is clear, the LPTMR Counter Register is clocked by the output of the prescaler/glitch filter. The Prescaler Bypass should only be altered when the LPTMR is disabled. |
|            | 0 Prescaler/Glitch Filter is enabled.                                                                                                                                                                                                                                                                                                                                             |
|            | 1 Prescaler/Glitch Filter is bypassed.                                                                                                                                                                                                                                                                                                                                            |
| 1–0<br>PCS | Prescaler Clock Select                                                                                                                                                                                                                                                                                                                                                            |
| PC5        | The Prescaler Clock Select selects the clock to be used by the LPTMR prescaler/glitch filter. The Prescaler Clock Select should only be altered when the LPTMR is disabled. The clock connections vary by device. See the Chip Configuration details for information on the connections to these inputs.                                                                          |
|            | 00 Prescaler/glitch filter clock 0 selected                                                                                                                                                                                                                                                                                                                                       |
|            | 01 Prescaler/glitch filter clock 1 selected                                                                                                                                                                                                                                                                                                                                       |
|            | 10 Prescaler/glitch filter clock 2 selected                                                                                                                                                                                                                                                                                                                                       |
|            | 11 Prescaler/glitch filter clock 3 selected                                                                                                                                                                                                                                                                                                                                       |

# 35.3.3 Low Power Timer Compare Register (LPTMRx\_CMR)

Addresses: LPTMR0\_CMR is FFFF\_84C0h base + 8h offset = FFFF\_84C8h LPTMR1\_CMR is FFFF\_84D0h base + 8h offset = FFFF\_84D8h



### LPTMRx\_CMR field descriptions

| Field             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–16<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 15–0<br>COMPARE   | Compare Value  When the LPTMR is enabled and the LPTMR Counter Register equals the value in the LPTMR Compare Register and increments, the Timer Compare Flag is set and the Hardware Trigger asserts until the next time the LPTMR Counter Register increments. If the LPTMR Compare Register is zero, the Hardware Trigger will remain asserted until the LPTMR is disabled. If the LPTMR is enabled, the LPTMR Compare Register should only be altered when the Timer Compare Flag is set. |

## 35.3.4 Low Power Timer Counter Register (LPTMRx\_CNR)

Addresses: LPTMR0\_CNR is FFFF\_84C0h base + Ch offset = FFFF\_84CCh LPTMR1\_CNR is FFFF\_84D0h base + Ch offset = FFFF\_84DCh



### LPTMRx CNR field descriptions

| Field             | Description                                                                                                                  |
|-------------------|------------------------------------------------------------------------------------------------------------------------------|
| 31–16<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                           |
| 15–0<br>COUNTER   | Counter Value  The LPTMR Counter Register returns the value of the LPTMR counter at the time this register was last written. |

# 35.4 Functional description

# 35.4.1 LPTMR power and reset

The LPTMR remains powered in all power modes, including low leakage modes. If the LPTMR is not required to remain operating during a low power mode, then it should be disabled before entering the mode.

The LPTMR is reset only on global POR or LVD. When configuring the LPTMR registers, the control status register should be initially written with the timer disabled, before configuring the LPTMR prescale register and compare register. The timer enable should then be set as the last step in the initialization. This ensures the LPTMR is configured correctly and the LPTMR counter is reset to zero following a warm reset.

# 35.4.2 LPTMR clocking

The LPTMR prescaler/glitch filter can be clocked by one of four clocks. The clock source should be enabled before the LPTMR is enabled.

#### NOTE

The clock source selected may need to be configured to remain enabled in low power modes, otherwise the LPTMR will not operate during low power modes.

In pulse counter mode with the prescaler/glitch filter bypassed, the selected input source directly clocks the LPTMR counter register and no other clock source is required. To minimize power in this case, configure the prescaler clock source for a clock that is not toggling.

# 35.4.3 LPTMR prescaler/glitch filter

The LPTMR prescaler and glitch filter share the same logic which operates as a prescaler in time counter mode and as a glitch filter in pulse counter mode.

The prescaler/glitch filter configuration must not be altered when the LPTMR is enabled.

### 35.4.3.1 Prescaler enabled

In time counter mode when the prescaler is enabled, the output of the prescaler directly clocks the LPTMR counter register. When the LPTMR is enabled, the LPTMR counter register will increment every  $2^2$  to  $2^{16}$  prescaler clock cycles. After the LPTMR is enabled, the first increment of the LPTMR counter register will take an additional one or two prescaler clock cycles due to synchronization logic.

# 35.4.3.2 Prescaler bypassed

In time counter mode when the prescaler is bypassed, the selected prescaler clock increments the LPTMR counter register on every clock cycle. When the LPTMR is enabled, the first increment will take an additional one or two prescaler clock cycles due to synchronization logic.

### 35.4.3.3 Glitch filter

In pulse counter mode when the glitch filter is enabled, the output of the glitch filter directly clocks the LPTMR counter register. When the LPTMR is first enabled, the output of the glitch filter is asserted (logic one for active high and logic zero for active low). If the selected input source remains negated for at least 2<sup>1</sup> to 2<sup>15</sup> consecutive prescaler clock rising edges, then the glitch filter output will also negate. If the selected

#### **Functional description**

input source remains asserted for at least  $2^1$  to  $2^{15}$  consecutive prescaler clock rising edges, then the glitch filter output will also assert. Note that the input is only sampled on the rising clock edge.

The LPTMR counter register will increment each time the glitch filter output asserts. In pulse counter mode, the maximum rate at which the LPTMR counter register can increment is once every 2<sup>2</sup> to 2<sup>16</sup> prescaler clock edges. When first enabled, the glitch filter will wait an additional one or two prescaler clock edges due to synchronization logic.

## 35.4.3.4 Glitch filter bypassed

In pulse counter mode when the glitch filter is bypassed, the selected input source increments the LPTMR counter register every time it asserts. Before the LPTMR is first enabled, the selected input source is forced to asserted. This is to prevent the LPTMR counter register from incrementing if the selected input source is already asserted when the LPTMR is first enabled.

# 35.4.4 LPTMR compare

When the LPTMR counter register equals the value of the LPTMR compare register and increments, the following events occur:

- Timer compare flag is set
- LPTMR interrupt is generated if Timer Interrupt Enable is also set
- LPTMR hardware trigger is generated
- LPTMR counter register is reset if the free running counter bit is clear

When the LPTMR is enabled, the LPTMR compare register can only be altered when the timer compare flag is set. When updating the LPTMR compare register, the LPTMR compare register must be written and the timer compare flag must be cleared before the LPTMR counter has incremented past the new LPTMR compare value.

## 35.4.5 LPTMR counter

The LPTMR counter register increments by one on every:

- prescaler clock (time counter mode with prescaler bypassed)
- prescaler output (time counter mode with prescaler enabled)
- input source assertion (pulse counter mode with glitch filter bypassed)
- glitch filter output (pulse counter mode with glitch filter enabled).

The LPTMR counter register is reset when the LPTMR is disabled or if the counter register overflows. If the CSR[TFC] control bit is set then the LPTMR counter register is also reset whenever the CSR[TCF] status flag is set.

The LPTMR counter register continues incrementing when the core is halted in debug mode.

The LPTMR counter register cannot be initialized, but can be read at any time. On each read of the LPTMR counter register, software must first write to the LPTMR counter register with any value. This will synchronize and register the current value of the LPTMR counter register into a temporary register. The contents of the temporary register are returned on each read of the LPTMR counter register.

When reading the LPTMR counter register, the bus clock must be at least two times faster than the rate at which the LPTMR counter is incrementing, otherwise incorrect data may be returned.

# 35.4.6 LPTMR hardware trigger

The LPTMR hardware trigger asserts at the same time the timer compare flag is set and can be used to trigger hardware events in other peripherals without software intervention. The hardware trigger is always enabled.

When the LPTMR compare register is set to zero with the free running counter bit clear, the LPTMR hardware trigger will assert on the first compare and does not negate. When the LPTMR compare register is set to a non-zero value (or if the free running counter bit is set) the LPTMR hardware trigger will assert on each compare and negate on the following increment of the LPTMR counter register.

# 35.4.7 LPTMR interrupt

The LPTMR interrupt is generated whenever the CSR[TIE] and CSR[TCF] are set. The CSR[TCF] is cleared by disabling the LPTMR or by writing a logic one to it.

The CSR[TIE] can be altered and the CSR[TCF] can be cleared while the LPTMR is enabled.

The LPTMR interrupt is generated asynchronously to the system clock and can be used to generate a wakeup from any low power mode, including the low leakage modes (provided the LPTMR is enabled as a wakeup source).

**Functional description** 

# **Chapter 36 Carrier Modulator Transmitter (CMT)**

### 36.1 Introduction

The carrier modulator transmitter (CMT) module provides means to generate the protocol timing and carrier signals for a wide variety of encoding schemes. The CMT incorporates hardware to off-load the critical and/or lengthy timing requirements associated with signal generation from the CPU, releasing much of its bandwidth to handle other tasks such as code data generation, data decompression, or keyboard scanning. The CMT does not include dedicated hardware configurations for specific protocols but is intended to be sufficiently programmable in its function to handle the timing requirements of most protocols with minimal CPU intervention. When the modulator is disabled, certain CMT registers can be used to change the state of the infrared output (CMT\_IRO) signal directly. This feature allows for the generation of future protocol timing signals not readily producible by the current architecture.

# 36.2 Features

The features of this module include:

- Four modes of operation
  - Time; with independent control of high and low times
  - Baseband
  - Frequency shift key (FSK)
  - Direct software control of CMT\_IRO signal
- Extended space operation in time, baseband, and FSK modes

#### **Block Diagram**

- Selectable input clock divider
- Interrupt on end of cycle
  - Ability to disable CMT\_IRO signal and use as timer interrupt

# 36.3 Block Diagram

The following figure is the CMT block diagram.



Figure 36-1. CMT Module Block Diagram

CMT\_IRO signal.

# 36.4 Modes of Operation

The CMT module operates in the following modes.

- Time—When operating in time mode, the user independently defines the high and low times of the carrier signal to determine both period and duty cycle.
- Baseband—When MSC[BASE] bit is set, the carrier output  $(f_{cg})$  to the modulator is held high continuously to allow for the generation of baseband protocols.
- Frequency shift key (FSK)—This mode allows the carrier generator to alternate between two sets of high and low times. When operating in FSK mode, the generator will toggle between the two sets when instructed by the modulator, allowing the user to dynamically switch between two carrier frequencies without CPU intervention.

The following table summarizes the CMT's modes.

Mode MSC[MCGEN]1 MSC[BASE]2 MSC[FSK]<sup>2</sup> MSC[EXSPC] Comment f<sub>ca</sub> controlled by primary high and low registers. 1 0 0 0 Time f<sub>cq</sub> transmitted to CMT\_IRO signal when modulator gate is open. f<sub>cq</sub> is always high. CMT\_IRO signal Baseband 1 1 Х 0 high when modulator gate is open. f<sub>ca</sub> control alternates between primary high/low registers and secondary high/low registers. **FSK** 0 0 f<sub>cq</sub> transmitted to CMT\_IRO signal when modulator gate is open. Setting MSC[EXSPC] bit causes subsequent modulator cycles to be Extended 1 Χ Х 1 spaces (modulator out not asserted) Space for the duration of the modulator period (mark and space times). OC[IROL] bit controls state of **IRO** Latch 0 Х Χ Χ

**Table 36-1. CMT Modes of Operation** 

<sup>1.</sup> To prevent spurious operation, initialize all data and control registers before beginning a transmission (MSC[MCGEN]=1).

<sup>2.</sup> These bits are not double buffered and should not be changed during a transmission (while MSC[MCGEN]=1).

#### **NOTE**

The assignment of module modes to core modes is chipspecific. For module-to-core mode assignments, see the chapter that describes how modules are configured.

# 36.4.1 Wait Mode Operation

During wait mode, the CMT if enabled, will continue to operate normally. However, there is no change in operating modes of CMT while in wait mode, because the CPU is not operating.

# 36.4.2 Stop Mode Operation

This section describes the CMT stop mode operations.

# 36.4.2.1 Normal Stop Mode Operation

During Normal Stop mode, clocks to the CMT module are halted. No registers are affected.

Because the clocks are halted, the CMT will resume upon exit from Normal Stop. Software should ensure that the Normal Stop mode is not entered while the modulator is still in operation to prevent the CMT\_IRO signal from being asserted while in Normal Stop mode. This may require a time-out period from the time that MSC[MCGEN] bit is cleared to allow the last modulator cycle to complete.

## 36.4.2.2 Low Power Stop Mode Operation

During Low Power Stop mode, the CMT module is completely powered off internally and the CMT\_IRO signal state at the time that Low Power Stop mode is entered is latched and held. To prevent the CMT\_IRO signal from being asserted while in Low Power Stop mode, software should assure that the signal is not active when entering Low Power Stop mode. Upon wake-up from Low Power Stop mode, the CMT module will be in the reset state.

# 36.4.3 Background Debug Mode Operation

When the microcontroller is in active background debug mode, the CMT temporarily suspends all counting until the microcontroller returns to normal user mode.

# 36.5 CMT External Signal Descriptions

This table shows the description of the external signal.

Table 36-2. CMT Signal Descriptions

| Signal  | Description     | I/O |
|---------|-----------------|-----|
| CMT_IRO | Infrared Output | 0   |

# 36.5.1 CMT\_IRO — Infrared Output

This output signal is driven by the modulator output when MSC[MCGEN] is set and OC[IROPEN] is set. The CMT\_IRO signal starts a valid transmission with a delay, after MSC[MCGEN] bit be asserted to high, that can be calculated based on two register bits. The following table shows how to calculate this delay.

If MSC[MCGEN] bit is cleared and OC[IROPEN] bit is set, the signal is driven by OC[IROL] bit. This enables user software to directly control the state of the CMT\_IRO signal by writing to OC[IROL] bit. If OC[IROPEN] bit is cleared, the signal is disabled and is not driven by the CMT module. Therefore, CMT can be configured as a modulo timer for generating periodic interrupts without causing signal activity.

Table 36-3. CMT\_IRO signal delay calculation

| Condition       | Delay (bus clock cycles) |
|-----------------|--------------------------|
| MSC[CMTDIV] = 0 | PPS[PPSDIV] + 2          |
| MSC[CMTDIV] > 0 | (PPS{PPSDIV] × 2) + 3    |

# 36.6 Memory Map/Register Definition

The following registers control and monitor CMT operation.

The address of a register is the sum of a base address and an address offset. The base address is defined at the chip level. The address offset is defined at the module level.

#### **Memory Map/Register Definition**

### **CMT** memory map

| Absolute address (hex) | Register name                                         | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|------------------------|-------------------------------------------------------|--------------------|--------|-------------|------------------|
| FFFF_8420              | CMT Carrier Generator High Data Register 1 (CMT_CGH1) | 8                  | R/W    | See section | 36.6.1/<br>776   |
| FFFF_8421              | CMT Carrier Generator Low Data Register 1 (CMT_CGL1)  | 8                  | R/W    | See section | 36.6.2/<br>777   |
| FFFF_8422              | CMT Carrier Generator High Data Register 2 (CMT_CGH2) | 8                  | R/W    | See section | 36.6.3/<br>777   |
| FFFF_8423              | CMT Carrier Generator Low Data Register 2 (CMT_CGL2)  | 8                  | R/W    | See section | 36.6.4/<br>778   |
| FFFF_8424              | CMT Output Control Register (CMT_OC)                  | 8                  | R/W    | 00h         | 36.6.5/<br>778   |
| FFFF_8425              | CMT Modulator Status and Control Register (CMT_MSC)   | 8                  | R/W    | 00h         | 36.6.6/<br>779   |
| FFFF_8426              | CMT Modulator Data Register Mark High (CMT_CMD1)      | 8                  | R/W    | See section | 36.6.7/<br>781   |
| FFFF_8427              | CMT Modulator Data Register Mark Low (CMT_CMD2)       | 8                  | R/W    | See section | 36.6.8/<br>781   |
| FFFF_8428              | CMT Modulator Data Register Space High (CMT_CMD3)     | 8                  | R/W    | See section | 36.6.9/<br>782   |
| FFFF_8429              | CMT Modulator Data Register Space Low (CMT_CMD4)      | 8                  | R/W    | See section | 36.6.10/<br>782  |
| FFFF_842A              | CMT Primary Prescaler Register (CMT_PPS)              | 8                  | R/W    | 00h         | 36.6.11/<br>783  |
| FFFF_842B              | CMT Direct Memory Access (CMT_DMA)                    | 8                  | R/W    | 00h         | 36.6.12/<br>784  |

# 36.6.1 CMT Carrier Generator High Data Register 1 (CMT\_CGH1)

This data register contain the primary high value for generating the carrier output.

Address: CMT\_CGH1 is FFFF\_8420h base + 0h offset = FFFF\_8420h



<sup>\*</sup> Notes:

<sup>•</sup> x = Undefined at reset.

### **CMT\_CGH1** field descriptions

| Field     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–0<br>PH | Primary Carrier High Time Data Value  When selected, these bits contain the number of input clocks required to generate the carrier high time period. When operating in Time mode, this register is always selected. When operating in FSK mode, this register and the secondary register pair are alternately selected under control of the modulator. The primary carrier high time value is undefined out of reset. These bits must be written to non-zero values before the carrier generator is enabled to avoid spurious results. |

# 36.6.2 CMT Carrier Generator Low Data Register 1 (CMT\_CGL1)

This data register contain the primary low value for generating the carrier output.

Address: CMT\_CGL1 is FFFF\_8420h base + 1h offset = FFFF\_8421h



<sup>\*</sup> Notes:

### CMT\_CGL1 field descriptions

| Field     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–0<br>PL | Primary Carrier Low Time Data Value  When selected, these bits contain the number of input clocks required to generate the carrier low time period. When operating in Time mode, this register is always selected. When operating in FSK mode, this register and the secondary register pair are alternately selected under control of the modulator. The primary carrier low time value is undefined out of reset. These bits must be written to non-zero values before the carrier generator is enabled to avoid spurious results. |

# 36.6.3 CMT Carrier Generator High Data Register 2 (CMT\_CGH2)

This data register contain the secondary high value for generating the carrier output.

Address: CMT\_CGH2 is FFFF\_8420h base + 2h offset = FFFF\_8422h



<sup>\*</sup> Notes:

<sup>•</sup> x = Undefined at reset.

x = Undefined at reset.

#### **Memory Map/Register Definition**

### **CMT\_CGH2** field descriptions

| Field     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–0<br>SH | Secondary Carrier High Time Data Value  When selected, these bits contain the number of input clocks required to generate the carrier high time period. When operating in Time mode, this register is never selected. When operating in FSK mode, this register and the primary register pair are alternately selected under control of the modulator. The secondary carrier high time value is undefined out of reset. These bits must be written to nonzero values before the carrier generator is enabled when operating in FSK mode. |

# 36.6.4 CMT Carrier Generator Low Data Register 2 (CMT\_CGL2)

This data register contain the secondary low value for generating the carrier output.

Address: CMT\_CGL2 is FFFF\_8420h base + 3h offset = FFFF\_8423h



<sup>\*</sup> Notes:

### CMT\_CGL2 field descriptions

| Field     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–0<br>SL | Secondary Carrier Low Time Data Value  When selected, these bits contain the number of input clocks required to generate the carrier low time period. When operating in Time mode, this register is never selected. When operating in FSK mode, this register and the primary register pair are alternately selected under control of the modulator. The secondary carrier low time value is undefined out of reset. These bits must be written to nonzero values before the carrier generator is enabled when operating in FSK mode. |

# 36.6.5 CMT Output Control Register (CMT\_OC)

This register is used to control the IRO signal of the CMT module.

Address: CMT\_OC is FFFF\_8420h base + 4h offset = FFFF\_8424h



#### MCF51JF128 Reference Manual, Rev. 2, 03/2011

778

<sup>•</sup> x = Undefined at reset.

### **CMT\_OC** field descriptions

| Field           | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>IROL       | IRO Latch Control  Reading IROL reads the state of the IRO latch. Writing to IROL changes the state of the CMT_IRO signal when MSC[MCGEN] bit is cleared and the IROPEN bit is set.                                                                                                                                                                                                                                                                                                                                                                                      |
| 6<br>CMTPOL     | CMT Output Polarity The CMTPOL bit controls the polarity of the CMT_IRO signal of the CMT.  0 CMT_IRO signal is active low 1 CMT_IRO signal is active high                                                                                                                                                                                                                                                                                                                                                                                                               |
| 5<br>IROPEN     | IRO Pin Enable  The IROPEN bit is used to enable and disable the CMT_IRO signal. When CMT_IRO signal is enabled, it is an output that drives out either the CMT transmitter output or the state of the IROL bit depending on whether MSC[MCGEN] bit is set or not. Also, the state of the output is either inverted or not depending on the state of the CMTPOL bit. When CMT_IRO signal is disabled, it is in a high impedance state so as not to draw any current. This signal is disabled during reset.  0 CMT_IRO signal disabled 1 CMT_IRO signal enabled as output |
| 4–0<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

# 36.6.6 CMT Modulator Status and Control Register (CMT\_MSC)

The MSC register contains the modulator and carrier generator enable (MCGEN), end of cycle interrupt enable (EOCIE), FSK mode select (FSK), baseband enable (BASE), extended space (EXSPC), prescaler (CMTDIV) bits, and the end of cycle (EOCF) status bit.

Address: CMT\_MSC is FFFF\_8420h base + 5h offset = FFFF\_8425h



### **CMT\_MSC** field descriptions

| Field     | Description               |
|-----------|---------------------------|
| 7<br>EOCF | End Of Cycle Status Flag  |
|           | The EOCF bit is set when: |

Table continues on the next page...

### **Memory Map/Register Definition**

# **CMT\_MSC** field descriptions (continued)

| Field      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | The modulator is not currently active and the MCGEN bit is set to begin the initial CMT                                                                                                                                                                                                                                                                                                                                                                    |
|            | <ul> <li>At the end of each modulation cycle while the MCGEN bit is set. This is recognized when a match occurs between the contents of the space period register and the down counter. At this time, the counter is initialized with the (possibly new) contents of the mark period buffer, CMT_CMD1 and CMT_CMD2, and the space period register is loaded with the (possibly new) contents of the space period buffer, CMT_CMD3 and CMT_CMD4.</li> </ul> |
|            | This flag is cleared by a read of the MSC register followed by an access of CMD2 or CMD4 or by the DMA transfer.                                                                                                                                                                                                                                                                                                                                           |
|            | 0 No end of modulation cycle occurrence since flag last cleared                                                                                                                                                                                                                                                                                                                                                                                            |
|            | 1 End of modulator cycle has occurred                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 6–5        | CMT Clock Divide Prescaler                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| CMTDIV     | The Secondary Prescaler causes the CMT to be clocked at the IF signal frequency, or the IF frequency divided by 2 ,4, or 8. Since these bits are not double buffered, they should not be changed during a transmission.                                                                                                                                                                                                                                    |
|            | 00 IF ÷ 1                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|            | 01 IF ÷ 2                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|            | 10 IF ÷ 4                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|            | 11 IF÷8                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 4<br>EXSPC | Extended Space Enable                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|            | The EXSPC bit enables extended space operation.                                                                                                                                                                                                                                                                                                                                                                                                            |
|            | 0 Extended space disabled                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|            | 1 Extended space enabled                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 3          | Baseband Enable                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| BASE       | When set, the BASE bit disables the carrier generator and forces the carrier output high for generation of baseband protocols. When BASE is cleared, the carrier generator is enabled and the carrier output toggles at the frequency determined by values stored in the carrier data registers. This bit is cleared by reset. This bit is not double buffered and should not be written to during a transmission.                                         |
|            | 0 Baseband mode disabled                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|            | 1 Baseband mode enabled                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 2          | FSK Mode Select                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| FSK        | The FSK bit enables FSK operation.                                                                                                                                                                                                                                                                                                                                                                                                                         |
|            | 0 CMT operates in Time or Baseband mode                                                                                                                                                                                                                                                                                                                                                                                                                    |
|            | 1 CMT operates in FSK mode                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 1          | End of Cycle Interrupt Enable                                                                                                                                                                                                                                                                                                                                                                                                                              |
| EOCIE      | A CPU interrupt will be requested when EOCF is set if EOCIE is high.                                                                                                                                                                                                                                                                                                                                                                                       |
|            | 0 CPU interrupt disabled                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|            | 1 CPU interrupt enabled                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 0<br>MCGEN | Modulator and Carrier Generator Enable                                                                                                                                                                                                                                                                                                                                                                                                                     |

Table continues on the next page...

### **CMT\_MSC** field descriptions (continued)

| Field | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | Setting MCGEN will initialize the carrier generator and modulator and will enable all clocks. Once enabled, the carrier generator and modulator will function continuously. When MCGEN is cleared, the current modulator cycle will be allowed to expire before all carrier and modulator clocks are disabled (to save power) and the modulator output is forced low. To prevent spurious operation, the user should initialize all data and control registers before enabling the system. |
|       | Modulator and carrier generator disabled     Modulator and carrier generator enabled                                                                                                                                                                                                                                                                                                                                                                                                       |

# 36.6.7 CMT Modulator Data Register Mark High (CMT\_CMD1)

The contents of this register are transferred to the modulator down counter upon the completion of a modulation period.

Address: CMT\_CMD1 is FFFF\_8420h base + 6h offset = FFFF\_8426h



<sup>\*</sup> Notes:

### CMT\_CMD1 field descriptions

| Field           | Description                                                               |
|-----------------|---------------------------------------------------------------------------|
| 7–0<br>MB[15:8] | These bits control the upper mark periods of the modulator for all modes. |

# 36.6.8 CMT Modulator Data Register Mark Low (CMT\_CMD2)

The contents of this register are transferred to the modulator down counter upon the completion of a modulation period.

Address: CMT\_CMD2 is FFFF\_8420h base + 7h offset = FFFF\_8427h



<sup>\*</sup> Notes:

<sup>•</sup> x = Undefined at reset.

x = Undefined at reset.

#### **Memory Map/Register Definition**

### **CMT\_CMD2** field descriptions

| Field          | Description                                                               |
|----------------|---------------------------------------------------------------------------|
| 7–0<br>MB[7:0] | These bits control the lower mark periods of the modulator for all modes. |

# 36.6.9 CMT Modulator Data Register Space High (CMT\_CMD3)

The contents of this register are transferred to the space period register upon the completion of a modulation period.

Address: CMT\_CMD3 is FFFF\_8420h base + 8h offset = FFFF\_8428h



<sup>\*</sup> Notes:

### CMT\_CMD3 field descriptions

| Field           | Description                                                                |
|-----------------|----------------------------------------------------------------------------|
| 7–0<br>SB[15:8] | These bits control the upper space periods of the modulator for all modes. |

# 36.6.10 CMT Modulator Data Register Space Low (CMT\_CMD4)

The contents of this register are transferred to the space period register upon the completion of a modulation period.

Address: CMT\_CMD4 is FFFF\_8420h base + 9h offset = FFFF\_8429h



<sup>\*</sup> Notes:

<sup>•</sup> x = Undefined at reset.

x = Undefined at reset.

### **CMT\_CMD4** field descriptions

| Field          | Description                                                                |
|----------------|----------------------------------------------------------------------------|
| 7–0<br>SB[7:0] | These bits control the lower space periods of the modulator for all modes. |

# 36.6.11 CMT Primary Prescaler Register (CMT\_PPS)

This register is used to set the primary prescaler bits (PPSDIV).

Address: CMT\_PPS is FFFF\_8420h base + Ah offset = FFFF\_842Ah



### **CMT\_PPS** field descriptions

| Field           | Description                                                                                                                                                                                                                                                                      |  |  |  |  |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 7–4<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                               |  |  |  |  |
| 3–0<br>PPSDIV   | Primary Prescaler Divider  The primary prescaler divides the CMT clock to generate the Intermediate Frequency clock enable to the secondary prescaler.  0000 Bus Clock ÷ 1  0001 Bus Clock ÷ 2  0010 Bus Clock ÷ 3                                                               |  |  |  |  |
|                 | 0010 Bus Clock ÷ 3 0011 Bus Clock ÷ 4 0100 Bus Clock ÷ 5 0101 Bus Clock ÷ 6 0110 Bus Clock ÷ 7 0111 Bus Clock ÷ 8 1000 Bus Clock ÷ 9 1001 Bus Clock ÷ 10 1010 Bus Clock ÷ 11 1011 Bus Clock ÷ 12 1100 Bus Clock ÷ 13 1101 Bus Clock ÷ 14 1110 Bus Clock ÷ 15 1111 Bus Clock ÷ 16 |  |  |  |  |

# 36.6.12 CMT Direct Memory Access (CMT\_DMA)

This register is used to enable/disable direct memory access (DMA).

Address: CMT\_DMA is FFFF\_8420h base + Bh offset = FFFF\_842Bh



### CMT\_DMA field descriptions

| Field           | Description                                                                                                                              |  |
|-----------------|------------------------------------------------------------------------------------------------------------------------------------------|--|
| 7–1<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                       |  |
| 0<br>DMA        | DMA Enable  This bit enables the DMA protocol.  0 DMA transfer request and done are disabled 1 DMA transfer request and done are enabled |  |

# 36.7 Functional Description

The CMT module consists primarily of clock divider, carrier generator and modulator.

## 36.7.1 Clock Divider

The CMT was originally designed to be based on 8 MHz bus clock that could be divided by 1, 2, 4 or 8 times accordingly with the specification. To be compatible with higher bus frequency, the Primary Prescaler (PPS) was developed to receive a higher frequency and generate a clock enable signal called Intermediate Frequency (IF). This IF should be approximately equal to 8 MHz and will work as a clock enable to the Secondary Prescaler. The following figure shows the clock divider block diagram.

Figure 36-14. Clock Divider Block Diagram

For compatibility with previous versions of CMT, when bus clock = 8 MHz, the PPS should be configured to zero. The PPS counter is selected according to the bus clock to generate an intermediate frequency approximately equal to 8 MHz.

### 36.7.2 Carrier Generator

The carrier generator resolution is 125 ns when operating with an 8 MHz intermediate frequency signal and the Secondary Prescaler is set to divide by 1 (MSC[CMTDIV] = 00). The carrier generator can generate signals with periods between 250 ns (4 MHz) and 127.5 µs (7.84 kHz) in steps of 125 ns. The following table shows the relationship between the clock divide bits and the carrier generator resolution, minimum carrier generator period, and minimum modulator period.

| Bus<br>Clock<br>(MHz) | MSC[CMTDIV] | Carrier Generator<br>Resolution (µs) | Min. Carrier<br>Generator Period<br>(μs) | Min.<br>Modulator Period<br>(μs) |
|-----------------------|-------------|--------------------------------------|------------------------------------------|----------------------------------|
| 8                     | 00          | 0.125                                | 0.25                                     | 1.0                              |
| 8                     | 01          | 0.25                                 | 0.5                                      | 2.0                              |
| 8                     | 10          | 0.5                                  | 1.0                                      | 4.0                              |
| 8                     | 11          | 1.0                                  | 2.0                                      | 8.0                              |

Table 36-17. Clock Divider

The possible duty cycle options depend upon the number of counts required to complete the carrier period. For example, 1.6 MHz signal has a period of 625 ns and will therefore require 5 x 125 ns counts to generate. These counts may be split between high and low times, so the duty cycles available will be 20% (one high, four low), 40% (two high, three low), 60% (three high, two low) and 80% (four high, one low).

For lower frequency signals with larger periods, higher resolution (as a percentage of the total period) duty cycles are possible.

#### **Functional Description**

The carrier signal is generated by counting a register-selected number of input clocks (125 ns for an 8 MHz bus) for both the carrier high time and the carrier low time. The period is determined by the total number of clocks counted. The duty cycle is determined by the ratio of high time clocks to total clocks counted. The high and low time values are user programmable and are held in two registers.

An alternate set of high/low count values is held in another set of registers to allow the generation of dual frequency FSK (frequency shift keying) protocols without CPU intervention.

#### **Note**

Only non-zero data values are allowed. The carrier generator will not work if any of the count values are equal to zero.

MSC[MCGEN] bit must be set and MSC[BASE] bit must be cleared to enable carrier generator clocks. When MSC[BASE] bit is set, the carrier output to the modulator is held high continuously. Following figure represents the block diagram of the clock generator.



Figure 36-15. Carrier Generator Block Diagram

The high/low time counter is an 8-bit up counter. After each increment, the contents of the counter are compared with the appropriate high or low count value register. When the compare value is reached, the counter is reset to a value of 0x01, and the compare is redirected to the other count value register.

Assuming that the high time count compare register is currently active, a valid compare will cause the carrier output to be driven low. The counter will continue to increment (starting at reset value of 0x01). When the value stored in the selected low count value register is reached, the counter will again be reset and the carrier output will be driven high.

The cycle repeats, automatically generating a periodic signal which is directed to the modulator. The lowest frequency (maximum period) and highest frequency (minimum period) which can be generated are defined as:

$$f_{\text{max}} = f_{\text{CMTCLK}} \div (2 \text{ x } 1) \text{ Hz}$$

$$f_{min} = f_{CMTCLK} \div (2 \times (2^8 - 1)) Hz$$

In the general case, the carrier generator output frequency is:

$$f_{cg} = f_{CMTCLK} \div (Highcount + Lowcount) Hz$$

Where: 0 < Highcount < 256 and

0 < Lowcount < 256

The duty cycle of the carrier signal is controlled by varying the ratio of high time to low + high time. As the input clock period is fixed, the duty cycle resolution will be proportional to the number of counts required to generate the desired carrier period.

$$DutyCycle = \frac{Highcount}{Highcount+Lowcount}$$

## 36.7.3 Modulator

The modulator block controls the state of the infrared out signal (IRO). The modulator output is gated on to the IRO signal when the modulator/carrier generator is enabled. When the modulator/carrier generator is disabled, the IRO signal is controlled by the state of the IRO latch. OC[CMTPOL] enables the IRO signal to be active high or active low.

In CMT modes, the modulator functions as given below:

- In Time mode, the modulator can gate the carrier onto the modulator output.
- In Baseband mode, the modulator can control the logic level of the modulator output.
- In FSK mode, the modulator can count carrier periods and instruct the carrier generator to alternate between two carrier frequencies whenever a modulation period (mark + space counts) expires.

#### **Functional Description**

The modulator provides a simple method to control protocol timing. The modulator has a minimum resolution of 1.0  $\mu$ s with an 8 MHz . It can count bus clocks (to provide real-time control) or it can count carrier clocks (for self-clocked protocols).

The modulator includes a 17-bit down counter with underflow detection. The counter is loaded from the 16-bit modulation mark period buffer registers, CMD1 and CMD2. The most significant bit is loaded with a logic zero and serves as a sign bit. When the counter holds a positive value, the modulator gate is open and the carrier signal is driven to the transmitter block.

When the counter underflows, the modulator gate is closed and a 16-bit comparator is enabled which compares the logical complement of the value of the down counter with the contents of the modulation space period register which has been loaded from the registers, CMD3 and CMD4.

When a match is obtained, the cycle repeats by opening the modulator gate, reloading the counter with the contents of CMD1 and CMD2, and reloading the modulation space period register with the contents of CMD3 and CMD4.

The activation of modulation space period is done when the carrier signal is low to prohibit cutting off the high pulse of a carrier signal. If the carrier signal is high, the modulator extends the mark period until the carrier signal become low. To de-assert the space period and assert the mark period, the carrier signal must have gone low to assure that a space period is not erroneously shortened.

Should the contents of the modulation space period register be all zeroes, the match will be immediate and no space period will be generated (for instance, for FSK protocols that require successive bursts of different frequencies).

MSC[MCGEN] must be set to enable the modulator timer.



Figure 36-16. Modulator Block Diagram

#### 36.7.3.1 Time Mode

When the modulator operates in time mode (MSC[MCGEN] bit is set, MSC[BASE] and MSC[FSK] bits are cleared), the modulation mark period consists of an integer number of CMTCLK  $\div$  8 clock periods. The modulation space period consists of zero or an integer number of CMTCLK  $\div$  8 clock periods. With an 8 MHz IF and MSC[CMTDIV] = 00, the modulator resolution is 1  $\mu$ s and has a maximum mark and space period of about 65.535 ms each . See the following figure for an example of the time mode and baseband mode outputs.

The mark and space time equations for time and baseband mode are:

$$t_{\text{mark}} = (\text{CMD1:CMD2} + 1) \div (f_{\text{CMTCLK}} \div 8)$$

$$t_{\text{space}} = \text{CMD3:CMD4} \div (f_{\text{CMTCLK}} \div 8)$$

where CMD1:CMD2 and CMD3:CMD4 are the decimal values of the concatenated registers.



Figure 36-17. Example: CMT Output in Time and Baseband Modes with OC[CMTPOL]=0

### 36.7.3.2 Baseband Mode

Baseband mode (MSC[MCGEN] and MSC[BASE] bits are set) is a derivative of time mode, where the mark and space period is based on (CMTCLK  $\div$  8) counts. The mark and space calculations are the same as in time mode. In this mode, the modulator output will be at a logic 1 for the duration of the mark period and at a logic 0 for the duration of a space period. See Figure 36-17 for an example of the output for both baseband and time modes. In the example, the carrier out frequency ( $f_{cg}$ ) is generated with a high count of 0x01 and a low count of 0x02 that results in a divide of 3 of CMTCLK with a 33% duty cycle. The modulator down counter was loaded with the value 0x0003 and the space period register with 0x0002.

#### **Note**

The waveforms in Figure 36-17 and Figure 36-18 are for the purpose of conceptual illustration and are not meant to represent precise timing relationships between the signals shown.

### 36.7.3.3 FSK Mode

When the modulator operates in FSK mode (MSC[MCGEN] and MSC[FSK] bits are set, and MSC[BASE] bit is cleared), the modulation mark and space periods consist of an integer number of carrier clocks (space period can be zero). When the mark period expires, the space period is transparently started (as in time mode). The carrier generator toggles between primary and secondary data register values whenever the modulator space period expires.

The space period provides an interpulse gap (no carrier). If CMD3:CMD4 = 0x0000, then the modulator and carrier generator will switch between carrier frequencies without a gap or any carrier glitches (zero space).

Using timing data for carrier burst and interpulse gap length calculated by the CPU, FSK mode can automatically generate a phase-coherent, dual-frequency FSK signal with programmable burst and interburst gaps.

The mark and space time equations for FSK mode are:

$$t_{\text{mark}} = (\text{CMD1:CMD2} + 1) \div f_{\text{cg}}$$

$$t_{\text{space}} = \text{CMD3:CMD4} \div f_{\text{cg}}$$

Where  $f_{cg}$  is the frequency output from the carrier generator. The example in figure below shows what the IRO signal looks like in FSK mode with the following values: CMD1:CMD2 = 0x0003, CMD3:CMD4 = 0x0002, primary carrier high count = 0x01, primary carrier low count = 0x02, secondary carrier high count = 0x03, and secondary carrier low count = 0x01.



Figure 36-18. Example: CMT Output in FSK Mode

# 36.7.4 Extended Space Operation

In either time, baseband or FSK mode, the space period can be made longer than the maximum possible value of the space period register. Setting MSC[EXSPC] bit will force the modulator to treat the next modulation period (beginning with the next load of the counter and space period register) as a space period equal in length to the mark and space counts combined. Subsequent modulation periods will consist entirely of these extended space periods with no mark periods. Clearing MSC[EXSPC] will return the modulator to standard operation at the beginning of the next modulation period.

## 36.7.4.1 EXSPC Operation in Time Mode

To calculate the length of an extended space in time or baseband mode, add the mark and space times and multiply by the number of modulation periods when MSC[EXSPC] is set.

 $t_{exspace} = (t_{mark} + t_{space}) x$ (number of modulation periods)

For an example of extended space operation, see the following figure.

#### **Note**

The extended space enable feature can be used to emulate a zero mark event.



Figure 36-19. Extended Space Operation

## 36.7.4.2 EXSPC Operation in FSK Mode

In FSK mode, the modulator continues to count carrier out clocks, alternating between the primary and secondary registers at the end of each modulation period.

To calculate the length of an extended space in FSK mode, one needs to know whether MSC[EXSPC] bit was set on a primary or secondary modulation period, as well as the total number of both primary and secondary modulation periods completed while MSC[EXSPC] bit is high. A status bit for the current modulation is not accessible to the

CPU. If necessary, software should maintain tracking of the current modulation cycle (primary or secondary). The extended space period ends at the completion of the space period time of the modulation period during which MSC[EXSPC] bit is cleared.

If MSC[EXSPC] bit was set during a primary modulation cycle, use the equation:

$$t_{\text{exspace}} = (t_{\text{space}})_{\text{p}} + (t_{\text{mark}} + t_{\text{space}})_{\text{s}} + (t_{\text{mark}} + t_{\text{space}})_{\text{p}} + \dots$$

Where the subscripts p and s refer to mark and space times for the primary and secondary modulation cycles.

If MSC[EXSPC] bit was set during a secondary modulation cycle, use the equation:

$$t_{\text{exspace}} = (t_{\text{space}})_{\text{s}} + (t_{\text{mark}} + t_{\text{space}})_{\text{p}} + (t_{\text{mark}} + t_{\text{space}})_{\text{s}} + \dots$$

# 36.8 CMT Interrupts and DMA

The CMT generates an Interrupt request or a DMA transfer request according to MSC[EOCIE], MSC[EOCF], DMA[DMA] bits.

| MSC[EOCF] | DMA[DMA] | MSC[EOCIE] | DMA transfer request | CMT interrupt request |
|-----------|----------|------------|----------------------|-----------------------|
| 0         | X        | X          | 0                    | 0                     |
| 1         | X        | 0          | 0                    | 0                     |
| 1         | 0        | 1          | 0                    | 1                     |
| 1         | 1        | 1          | 1                    | 0                     |

Table 36-18. DMA Transfer Request x CMT Interrupt Request

### MSC[EOCF] is set when:

- The modulator is not currently active and MSC[MCGEN] bit is set to begin the initial CMT transmission
- At the end of each modulation cycle (when the counter is reloaded from CMD1:CMD2) while MSC[MCGEN] bit is set

In the case where MSC[MCGEN] bit is cleared and then set before the end of the modulation cycle, MSC[EOCF] bit will not be set when MSC[MCGEN] is set, but will become set at the end of the current modulation cycle.

When MSC[MCGEN] becomes disabled, the CMT module does not set the EOC flag at the end of the last modulation cycle.

#### **CMT Interrupts and DMA**

If MSC[EOCIE] bit is high when MSC[EOCF] bit is set, the CMT module will generate an interrupt request or a DMA transfer request.

MSC[EOCF] bit must be cleared to prevent from being generated another event (interrupt or DMA request) after exiting the service routine. See following table.

Table 36-19. How to clear MSC[EOCF] bit

| DMA[DM<br>A] | MSC[EOCIE] | Description                                                                                                                  |
|--------------|------------|------------------------------------------------------------------------------------------------------------------------------|
| 0            | Х          | MSC[EOCF] bit is cleared by reading the CMT modulator status and control register MSC followed by an access of CMD2 or CMD4. |
| 1            | Х          | MSC[EOCF] bit is cleared by the CMT DMA transfer done.                                                                       |

The EOC interrupt is coincident with loading the down-counter with the contents of CMD1:CMD2 and loading the space period register with the contents of CMD3:CMD4. The EOC interrupt provides a means for the user to reload new mark/space values into the modulator data registers. Modulator data register updates will take effect at the end of the current modulation cycle. Note that the down-counter and space period register are updated at the end of every modulation cycle, irrespective of interrupt handling and the state of the EOCF flag.

# Chapter 37 FlexTimer (FTM)

### 37.1 Introduction

The FlexTimer module is a two to eight channel timer which supports input capture, output compare, and the generation of PWM signals to control electric motor and power management applications. The FTM time reference is a 16-bit counter that can be used as an unsigned or signed counter.

# 37.1.1 FlexTimer Philosophy

The FlexTimer is built upon a very simple timer (HCS08 Timer PWM Module – TPM) used for many years on Freescales 8 bit microcontrollers. The FlexTimer extends the functionality to meet the demands of motor control, digital lighting solutions and power conversion yet providing low cost and backwards compatibility with the TPM module.

Several key enhancements are made: signed up-counter, dead time insertion hardware, fault control inputs, enhanced triggering functionality and initialization and polarity control.

All the features common with the TPM module have fully backwards compatible register assignments and the FlexTimer can use code on the same core platform without change to perform the same functions. A small exception to this is when the FlexTimer clock frequency is twice bus clock frequency to provide extra resolution for high speed PWM applications.

Motor control and power conversion features have been added through a dedicated set of registers and defaults turn off all new features. The new features such as hardware dead time insertion, polarity, fault control and masking greatly reduce loading on the execution software and are usually each controlled by a group of registers.

#### Introduction

FlexTimer input triggers can be from comparators, ADC or other sub modules to initiate timer functions automatically. These triggers can be linked in a variety of ways during integration of the sub modules so please note carefully the options available for used FlexTimer configuration.

All main user access registers are buffered to ease the load on the executing software. A number of trigger options exist to determine which registers are updated with this user defined data.

### **37.1.2 Features**

The FTM features include:

- FTM source clock is selectable
  - Source clock can be the system clock, the fixed frequency clock, or an external clock
  - Fixed frequency clock is an additional clock input to allow the selection of an on chip clock source other than the system clock
  - Selecting external clock connects FTM clock to a chip level input pin therefore allowing to synchronize the FTM counter with an off chip clock source
- Prescaler divide-by 1, 2, 4, 8, 16, 32, 64, or 128
- FTM has a 16-bit counter
  - It can be a free-running counter or a counter with initial and final value
  - The counting can be up or up-down
- Each channel can be configured for input capture, output compare, or edge-aligned PWM mode
- In input capture mode
  - the capture can occur on rising edges, falling edges or both edges
  - an input filter can be selected for some channels
- In output compare mode the output signal can be set, cleared, or toggled on match
- All channels can be configured for center-aligned PWM mode

- Each pair of channels can be combined to generate a PWM signal (with independent control of both edges of PWM signal)
- The FTM channels can operate as pairs with equal outputs, pairs with complementary outputs, or independent channels (with independent outputs)
- The deadtime insertion is available for each complementary pair
- Generation of triggers (match trigger)
- Software control of PWM outputs
- Up to 4 fault inputs for global fault control
- The polarity of each channel is configurable
- The generation of an interrupt per channel
- The generation of an interrupt when the counter overflows
- The generation of an interrupt when the fault condition is detected
- Synchronized loading of write buffered FTM registers
- Write protection for critical registers
- Backwards compatible with TPM
- Testing of input captures for a stuck at zero and one conditions
- Dual edge capture for pulse and period width measurement
- For instances of the module that support it: Quadrature decoder with input filters, relative position counting and interrupt on position count or capture of position count on external event

# 37.1.3 Modes of Operation

When the MCU is in active BDM background or BDM foreground mode, the FTM temporarily suspends all counting until the MCU returns to normal user operating mode. During stop mode, all FTM input clocks are stopped, so the FTM is effectively disabled until clocks resume. During wait mode, the FTM continues to operate normally. If the FTM does not need to produce a real time reference or provide the interrupt sources needed to wake the MCU from wait mode, the power can then be saved by disabling FTM functions before entering wait mode.

# 37.1.4 Block Diagram

The FTM uses one input/output (I/O) pin per channel, CHn (FTM channel (n)) where n is the channel number (0–7).

The following figure shows the FTM structure. The central component of the FTM is the 16-bit counter with programmable initial and final values and its counting can be up or up-down.



Figure 37-1. FTM Block Diagram

# 37.2 Signal Description

The following table shows the user-accessible signals for the FTM.

#### **NOTE**

The PHA and PHB signals are user accessible if the quadrature decoder feature is supported.

| Name                | Function                                                                                 |
|---------------------|------------------------------------------------------------------------------------------|
| EXTCLK              | external clock - FTM external clock can be selected to drive the FTM counter.            |
| CHn <sup>1</sup>    | channel (n) - I/O pin associated with FTM channel (n).                                   |
| FAULTj <sup>2</sup> | fault input (j) - input pin associated with fault input (j).                             |
| PHA                 | quadrature decoder phase A input – input pin associated with quadrature decoder phase A. |
| PHB                 | quadrature decoder phase B input – input pin associated with quadrature decoder phase B. |

Table 37-1. Signal Properties

### 37.2.1 EXTCLK — FTM External Clock

The external clock input signal is used as the FTM counter clock if selected by CLKS[1:0] bits in the SC register. This clock signal must not exceed 1/4 of system clock frequency. The FTM counter prescaler selection and settings are also used when an external clock is selected.

# 37.2.2 CHn — FTM Channel (n) I/O Pin

Each FTM channel can be configured to operate either as input or output. The direction associated with each channel, input or output, is selected according to the mode assigned for that channel.

# 37.2.3 FAULTj — FTM Fault Input

The fault input signals are used to control the CHn channel output state. If a fault is detected, the FAULTj signal is asserted and the channel output is put in a safe state. The behavior of the fault logic is defined by the FAULTM[1:0] control bits in the MODE register and FAULTEN bit in the COMBINEm register. Note that each FAULTj input

<sup>1.</sup> n = channel number (0 to 7)

j = fault input (0 to 3)

may affect all channels selectively since FAULTM[1:0] and FAULTEN control bits are defined for each pair of channels. Since there are several FAULTj inputs, maximum of 4 for the FTM module, each one of these inputs is activated by the FAULTjEN bit in the FLTCTRL register.

# 37.2.4 PHA — FTM Quadrature Decoder Phase A Input

The quadrature decoder phase A input is used when the quadrature decoder mode is selected (if the quadrature decoder feature is supported). The phase A input signal is one of the signals that control the FTM counter increment or decrement in the quadrature decoder mode (Quadrature Decoder Mode).

# 37.2.5 PHB — FTM Quadrature Decoder Phase B Input

The quadrature decoder phase B input is used when the quadrature decoder mode is selected (if the quadrature decoder feature is supported). The phase B input signal is one of the signals that control the FTM counter increment or decrement in the quadrature decoder mode (Quadrature Decoder Mode).

# 37.3 Memory Map and Register Definition

This section provides a detailed description of all FTM registers.

# 37.3.1 Module Memory Map

This section presents a high-level summary of the FTM registers and how they are mapped.

The FTM memory map can be split into two sets of registers. The first set has the original TPM registers.

The second set has the FTM specific registers. Any second set registers (or bits within these registers) that are used by an unavailable function in the FTM configuration remain in the memory map and in the reset value, so they have no active function.

#### Note

Do not write to the FTM specific registers (second set registers) when FTMEN = 0.

# 37.3.2 Register Descriptions

This section consists of register descriptions in address order.

### FTMx memory map

| Absolute address (hex) | Register name                          | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|------------------------|----------------------------------------|--------------------|--------|-------------|------------------|
| FFFF_8440              | Status and Control (FTM0_SC)           | 8                  | R/W    | 00h         | 37.3.3/<br>806   |
| FFFF_8441              | Counter High (FTM0_CNTH)               | 8                  | R/W    | 00h         | 37.3.4/<br>807   |
| FFFF_8442              | Counter Low (FTM0_CNTL)                | 8                  | R/W    | 00h         | 37.3.5/<br>808   |
| FFFF_8443              | Modulo High (FTM0_MODH)                | 8                  | R/W    | 00h         | 37.3.6/<br>809   |
| FFFF_8444              | Modulo Low (FTM0_MODL)                 | 8                  | R/W    | 00h         | 37.3.7/<br>810   |
| FFFF_8445              | Channel Status and Control (FTM0_C0SC) | 8                  | R/W    | 00h         | 37.3.8/<br>810   |
| FFFF_8446              | Channel Value High (FTM0_C0VH)         | 8                  | R/W    | 00h         | 37.3.9/<br>813   |
| FFFF_8447              | Channel Value Low (FTM0_C0VL)          | 8                  | R/W    | 00h         | 37.3.10/<br>814  |
| FFFF_8448              | Channel Status and Control (FTM0_C1SC) | 8                  | R/W    | 00h         | 37.3.8/<br>810   |
| FFFF_8449              | Channel Value High (FTM0_C1VH)         | 8                  | R/W    | 00h         | 37.3.9/<br>813   |
| FFFF_844A              | Channel Value Low (FTM0_C1VL)          | 8                  | R/W    | 00h         | 37.3.10/<br>814  |
| FFFF_844B              | Reserved                               | 8                  |        |             |                  |
| FFFF_844C              | Reserved                               | 8                  |        |             |                  |
| FFFF_844D              | Reserved                               | 8                  |        |             |                  |
| FFFF_844E              | Reserved                               | 8                  |        |             |                  |
| FFFF_844F              | Reserved                               | 8                  |        |             |                  |
| FFFF_8450              | Reserved                               | 8                  |        |             |                  |

# FTMx memory map (continued)

| Absolute address (hex) | Register name                                   | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|------------------------|-------------------------------------------------|--------------------|--------|-------------|------------------|
| FFFF_8451              | Reserved                                        | 8                  |        |             |                  |
| FFFF_8452              | Reserved                                        | 8                  |        |             |                  |
| FFFF_8453              | Reserved                                        | 8                  |        |             |                  |
| FFFF_8454              | Reserved                                        | 8                  |        |             |                  |
| FFFF_8455              | Reserved                                        | 8                  |        |             |                  |
| FFFF_8456              | Reserved                                        | 8                  |        |             |                  |
| FFFF_845D              | Counter Initial Value High (FTM0_CNTINH)        | 8                  | R/W    | 00h         | 37.3.11/<br>815  |
| FFFF_845E              | Counter Initial Value Low (FTM0_CNTINL)         | 8                  | R/W    | 00h         | 37.3.12/<br>816  |
| FFFF_845F              | Capture and Compare Status (FTM0_STATUS)        | 8                  | R/W    | 00h         | 37.3.13/<br>816  |
| FFFF_8460              | Features Mode Selection (FTM0_MODE)             | 8                  | R/W    | 04h         | 37.3.14/<br>818  |
| FFFF_8461              | Synchronization (FTM0_SYNC)                     | 8                  | R/W    | 00h         | 37.3.15/<br>819  |
| FFFF_8462              | Initial State for Channel Output (FTM0_OUTINIT) | 8                  | R/W    | 00h         | 37.3.16/<br>822  |
| FFFF_8463              | Output Mask (FTM0_OUTMASK)                      | 8                  | R/W    | 00h         | 37.3.17/<br>823  |
| FFFF_8464              | Function for Linked Channels (FTM0_COMBINE0)    | 8                  | R/W    | 00h         | 37.3.18/<br>825  |
| FFFF_8465              | Reserved                                        | 8                  |        |             |                  |
| FFFF_8466              | Reserved                                        | 8                  |        |             |                  |
| FFFF_8468              | Deadtime Insertion Control (FTM0_DEADTIME)      | 8                  | R/W    | 00h         | 37.3.19/<br>827  |
| FFFF_8469              | External Trigger (FTM0_EXTTRIG)                 | 8                  | R/W    | 00h         | 37.3.20/<br>827  |
| FFFF_846A              | Channels Polarity (FTM0_POL)                    | 8                  | R/W    | 00h         | 37.3.21/<br>829  |
| FFFF_846B              | Fault Mode Status (FTM0_FMS)                    | 8                  | R/W    | 00h         | 37.3.22/<br>831  |

# FTMx memory map (continued)

| Absolute address (hex) | Register name                                       | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|------------------------|-----------------------------------------------------|--------------------|--------|-------------|------------------|
| FFFF_846C              | Input Capture Filter Control (FTM0_FILTER0)         | 8                  | R/W    | 00h         | 37.3.23/<br>833  |
| FFFF_846D              | Input Capture Filter Control (FTM0_FILTER1)         | 8                  | R/W    | 00h         | 37.3.23/<br>833  |
| FFFF_846E              | Fault Input Filter Control (FTM0_FLTFILTER)         | 8                  | R/W    | 00h         | 37.3.24/<br>834  |
| FFFF_846F              | Fault Input Control (FTM0_FLTCTRL)                  | 8                  | R/W    | 00h         | 37.3.25/<br>834  |
| FFFF_8470              | Quadrature Decoder Control and Status (FTM0_QDCTRL) | 8                  | R/W    | 00h         | 37.3.26/<br>836  |
| FFFF_8480              | Status and Control (FTM1_SC)                        | 8                  | R/W    | 00h         | 37.3.3/<br>806   |
| FFFF_8481              | Counter High (FTM1_CNTH)                            | 8                  | R/W    | 00h         | 37.3.4/<br>807   |
| FFFF_8482              | Counter Low (FTM1_CNTL)                             | 8                  | R/W    | 00h         | 37.3.5/<br>808   |
| FFFF_8483              | Modulo High (FTM1_MODH)                             | 8                  | R/W    | 00h         | 37.3.6/<br>809   |
| FFFF_8484              | Modulo Low (FTM1_MODL)                              | 8                  | R/W    | 00h         | 37.3.7/<br>810   |
| FFFF_8485              | Channel Status and Control (FTM1_C0SC)              | 8                  | R/W    | 00h         | 37.3.8/<br>810   |
| FFFF_8486              | Channel Value High (FTM1_C0VH)                      | 8                  | R/W    | 00h         | 37.3.9/<br>813   |
| FFFF_8487              | Channel Value Low (FTM1_C0VL)                       | 8                  | R/W    | 00h         | 37.3.10/<br>814  |
| FFFF_8488              | Channel Status and Control (FTM1_C1SC)              | 8                  | R/W    | 00h         | 37.3.8/<br>810   |
| FFFF_8489              | Channel Value High (FTM1_C1VH)                      | 8                  | R/W    | 00h         | 37.3.9/<br>813   |
| FFFF_848A              | Channel Value Low (FTM1_C1VL)                       | 8                  | R/W    | 00h         | 37.3.10/<br>814  |
| FFFF_848B              | Channel Status and Control (FTM1_C2SC)              | 8                  | R/W    | 00h         | 37.3.8/<br>810   |
| FFFF_848C              | Channel Value High (FTM1_C2VH)                      | 8                  | R/W    | 00h         | 37.3.9/<br>813   |
| FFFF_848D              | Channel Value Low (FTM1_C2VL)                       | 8                  | R/W    | 00h         | 37.3.10/<br>814  |
| FFFF_848E              | Channel Status and Control (FTM1_C3SC)              | 8                  | R/W    | 00h         | 37.3.8/<br>810   |

# FTMx memory map (continued)

| Absolute<br>address<br>(hex) | Register name                                   | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|------------------------------|-------------------------------------------------|--------------------|--------|-------------|------------------|
| FFFF_848F                    | Channel Value High (FTM1_C3VH)                  | 8                  | R/W    | 00h         | 37.3.9/<br>813   |
| FFFF_8490                    | Channel Value Low (FTM1_C3VL)                   | 8                  | R/W    | 00h         | 37.3.10/<br>814  |
| FFFF_8491                    | Channel Status and Control (FTM1_C4SC)          | 8                  | R/W    | 00h         | 37.3.8/<br>810   |
| FFFF_8492                    | Channel Value High (FTM1_C4VH)                  | 8                  | R/W    | 00h         | 37.3.9/<br>813   |
| FFFF_8493                    | Channel Value Low (FTM1_C4VL)                   | 8                  | R/W    | 00h         | 37.3.10/<br>814  |
| FFFF_8494                    | Channel Status and Control (FTM1_C5SC)          | 8                  | R/W    | 00h         | 37.3.8/<br>810   |
| FFFF_8495                    | Channel Value High (FTM1_C5VH)                  | 8                  | R/W    | 00h         | 37.3.9/<br>813   |
| FFFF_8496                    | Channel Value Low (FTM1_C5VL)                   | 8                  | R/W    | 00h         | 37.3.10/<br>814  |
| FFFF_849D                    | Counter Initial Value High (FTM1_CNTINH)        | 8                  | R/W    | 00h         | 37.3.11/<br>815  |
| FFFF_849E                    | Counter Initial Value Low (FTM1_CNTINL)         | 8                  | R/W    | 00h         | 37.3.12/<br>816  |
| FFFF_849F                    | Capture and Compare Status (FTM1_STATUS)        | 8                  | R/W    | 00h         | 37.3.13/<br>816  |
| FFFF_84A0                    | Features Mode Selection (FTM1_MODE)             | 8                  | R/W    | 04h         | 37.3.14/<br>818  |
| FFFF_84A1                    | Synchronization (FTM1_SYNC)                     | 8                  | R/W    | 00h         | 37.3.15/<br>819  |
| FFFF_84A2                    | Initial State for Channel Output (FTM1_OUTINIT) | 8                  | R/W    | 00h         | 37.3.16/<br>822  |
| FFFF_84A3                    | Output Mask (FTM1_OUTMASK)                      | 8                  | R/W    | 00h         | 37.3.17/<br>823  |
| FFFF_84A4                    | Function for Linked Channels (FTM1_COMBINE0)    | 8                  | R/W    | 00h         | 37.3.18/<br>825  |
| FFFF_84A5                    | Function for Linked Channels (FTM1_COMBINE1)    | 8                  | R/W    | 00h         | 37.3.18/<br>825  |
| FFFF_84A6                    | Function for Linked Channels (FTM1_COMBINE2)    | 8                  | R/W    | 00h         | 37.3.18/<br>825  |
| FFFF_84A8                    | Deadtime Insertion Control (FTM1_DEADTIME)      | 8                  | R/W    | 00h         | 37.3.19/<br>827  |
| FFFF_84A9                    | External Trigger (FTM1_EXTTRIG)                 | 8                  | R/W    | 00h         | 37.3.20/<br>827  |

Table continues on the next page...

### FTMx memory map (continued)

| Absolute<br>address<br>(hex) | Register name                               | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|------------------------------|---------------------------------------------|--------------------|--------|-------------|------------------|
| FFFF_84AA                    | Channels Polarity (FTM1_POL)                | 8                  | R/W    | 00h         | 37.3.21/<br>829  |
| FFFF_84AB                    | Fault Mode Status (FTM1_FMS)                | 8                  | R/W    | 00h         | 37.3.22/<br>831  |
| FFFF_84AC                    | Input Capture Filter Control (FTM1_FILTER0) | 8                  | R/W    | 00h         | 37.3.23/<br>833  |
| FFFF_84AD                    | Input Capture Filter Control (FTM1_FILTER1) | 8                  | R/W    | 00h         | 37.3.23/<br>833  |
| FFFF_84AE                    | Fault Input Filter Control (FTM1_FLTFILTER) | 8                  | R/W    | 00h         | 37.3.24/<br>834  |
| FFFF_84AF                    | Fault Input Control (FTM1_FLTCTRL)          | 8                  | R/W    | 00h         | 37.3.25/<br>834  |
| FFFF_84B0                    | Reserved                                    | 8                  |        |             |                  |

# 37.3.3 Status and Control (FTMx\_SC)

SC contains the overflow status flag and control bits used to configure the interrupt enable, FTM configuration, clock source, and prescaler factor. These controls relate to all channels within this module.

Addresses: FTM0\_SC is FFFF\_8440h base + 0h offset = FFFF\_8440h FTM1\_SC is FFFF\_8480h base + 0h offset = FFFF\_8480h



### FTMx\_SC field descriptions

| Field | Description                                                                                                                                                                                                                                                                |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7     | Timer Overflow Flag                                                                                                                                                                                                                                                        |
| TOF   | Set by hardware when the FTM counter passes the value in the Counter Modulo registers. The TOF bit is cleared by reading the SC register while TOF is set and then writing a 0 to TOF bit. Writing a 1 to TOF has no effect.                                               |
|       | If another FTM overflow occurs between the read and write operations, the write operation has no effect; therefore, TOF remains set indicating an overflow has occurred. In this case a TOF interrupt request is not lost due to the clearing sequence for a previous TOF. |
|       | <ul><li>0 FTM counter has not overflowed.</li><li>1 FTM counter has overflowed.</li></ul>                                                                                                                                                                                  |

Table continues on the next page...

### FTMx\_SC field descriptions (continued)

| Field       | Description                                                                                                                                                                                                      |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6<br>TOIE   | Timer Overflow Interrupt Enable                                                                                                                                                                                  |
| TOIL        | Enables FTM overflow interrupts.                                                                                                                                                                                 |
|             | 0 Disable TOF interrupts. Use software polling.                                                                                                                                                                  |
|             | 1 Enable TOF interrupts. An interrupt is generated when TOF equals one.                                                                                                                                          |
| 5<br>CPWMS  | Center-aligned PWM Select                                                                                                                                                                                        |
| CEVVIVIS    | Selects CPWM mode. This mode configures the FTM to operate in up-down counting mode.                                                                                                                             |
|             | CPWMS is write protected. It can be written only when MODE[WPDIS] = 1.                                                                                                                                           |
|             | 0 FTM counter operates in up counting mode.                                                                                                                                                                      |
|             | 1 FTM counter operates in up-down counting mode.                                                                                                                                                                 |
| 4–3<br>CLKS | Clock Source Selection                                                                                                                                                                                           |
| CLKS        | Selects one of the three FTM counter clock sources.                                                                                                                                                              |
|             | CLKS is write protected. It can be written only when MODE[WPDIS] = 1.                                                                                                                                            |
|             | 00 No clock selected (this in effect disables the FTM counter).                                                                                                                                                  |
|             | 01 If MODE[FTMEN] = 0, the System clock divided by 2 is selected. If MODE[FTMEN] = 1, the System clock is selected.                                                                                              |
|             | 10 Fixed frequency clock                                                                                                                                                                                         |
|             | 11 External clock                                                                                                                                                                                                |
| 2–0         | Prescale Factor Selection                                                                                                                                                                                        |
| PS          | Selects one of 8 division factors for the clock source selected by CLKS. The new prescaler factor affects the clock source on the next system clock cycle after the new value is updated into the register bits. |
|             | PS is write protected. It can be written only when MODE[WPDIS] = 1.                                                                                                                                              |
|             | 000 Divide by 1                                                                                                                                                                                                  |
|             | 001 Divide by 2                                                                                                                                                                                                  |
|             | 010 Divide by 4                                                                                                                                                                                                  |
|             | 011 Divide by 8                                                                                                                                                                                                  |
|             | 100 Divide by 16                                                                                                                                                                                                 |
|             | 101 Divide by 32                                                                                                                                                                                                 |
|             | 110 Divide by 64<br>111 Divide by 128                                                                                                                                                                            |
|             | 111 Divide by 120                                                                                                                                                                                                |

### 37.3.4 Counter High (FTMx\_CNTH)

The Counter registers contain the high and low bytes of the counter value. Reading either byte latches the contents of both bytes into a buffer where they remain latched until the other half is read. This allows coherent 16-bit reads in either big-endian or little-endian order which makes this more friendly to various compiler implementations. The coherency mechanism is automatically restarted by an MCU reset or any write to the Status and Control register.

Writing any value to COUNT\_H or COUNT\_L updates the FTM counter with its initial 16-bit value (contained in the Counter Initial Value registers) and resets the read coherency mechanism, regardless of the data involved in the write.

When BDM is active, the FTM counter is frozen (this is the value that you may read); the read coherency mechanism is frozen such that the buffer latches remain in the state they were in when the BDM became active, even if one or both counter bytes are read while BDM is active. This assures that if you were in the middle of reading a 16-bit register when BDM became active, it reads the appropriate value from the other half of the 16-bit value after returning to normal execution.





### FTMx\_CNTH field descriptions

| Field          | Description             |
|----------------|-------------------------|
| 7–0<br>COUNT_H | Counter value high byte |

# 37.3.5 Counter Low (FTMx\_CNTL)

See the description for the Counter High register.

Addresses: FTM0\_CNTL is FFFF\_8440h base + 2h offset = FFFF\_8442h
FTM1\_CNTL is FFFF\_8480h base + 2h offset = FFFF\_8482h



### FTMx\_CNTL field descriptions

| Field          | Description            |
|----------------|------------------------|
| 7–0<br>COUNT_L | Counter value low byte |

# 37.3.6 Modulo High (FTMx\_MODH)

The Modulo registers contain the high and low bytes of the modulo value for the FTM counter. After the FTM counter reaches the modulo value, the overflow flag (TOF) becomes set at the next clock, and the next value of FTM counter depends on the selected counting method (Counter).

Writing to either byte latches the value into a buffer. The register is updated with the value of their write buffer according to Update of the Registers With Write Buffers.

If MODE[FTMEN] = 0, this write coherency mechanism may be manually reset by writing to the SC register (whether BDM is active or not).

When BDM is active, this write coherency mechanism is frozen such that the buffer latches remain in the state they were in when the BDM became active, even if one or both bytes of the modulo register are written while BDM is active. Any write to the modulo register bypasses the buffer latches and directly writes to the modulo register while BDM is active.

It is recommended to initialize the FTM counter (write to CNTH or CNTL) before writing to the FTM modulo register to avoid confusion about when the first counter overflow will occur.



0

### FTMx MODH field descriptions

0

0

0

0

| Field        | Description                   |
|--------------|-------------------------------|
| 7–0<br>MOD_H | High byte of the modulo value |

Reset

0

0

# 37.3.7 Modulo Low (FTMx\_MODL)

See the description for the Modulo High register.

Addresses: FTM0\_MODL is FFFF\_8440h base + 4h offset = FFFF\_8444h FTM1\_MODL is FFFF\_8480h base + 4h offset = FFFF\_8484h



### FTMx\_MODL field descriptions

| Field        | Description                  |
|--------------|------------------------------|
| 7–0<br>MOD_L | Low byte of the modulo value |

# 37.3.8 Channel Status and Control (FTMx\_CnSC)

CnSC contains the channel-interrupt-status flag and control bits used to configure the interrupt enable, channel configuration, and pin function.

Table 37-71. Mode, Edge, and Level Selection

| DECAPEN | COMBINE | CPWMS | MSnB:MSnA | ELSnB:ELSnA | Mode | Configuration        |
|---------|---------|-------|-----------|-------------|------|----------------------|
| Х       | Х       | Х     | XX        | 00          | None | Pin not used for FTM |

Table 37-71. Mode, Edge, and Level Selection (continued)

| DECAPEN | COMBINE | CPWMS | MSnB:MSnA | ELSnB:ELSnA              | Mode                      | Configuration                                                                                   |                                                      |
|---------|---------|-------|-----------|--------------------------|---------------------------|-------------------------------------------------------------------------------------------------|------------------------------------------------------|
| 0       | 0       | 0     | 00        | 01 Input capture         | Input capture             | Capture on<br>Rising Edge<br>Only                                                               |                                                      |
|         |         |       |           | 10                       |                           | Capture on<br>Falling Edge<br>Only                                                              |                                                      |
|         |         |       |           | 11                       |                           | Capture on<br>Rising or Falling<br>Edge                                                         |                                                      |
|         |         |       | 01        | 01                       | Output compare            | Toggle Output on match                                                                          |                                                      |
|         |         |       |           | 10                       |                           | Clear Output on match                                                                           |                                                      |
|         |         |       |           | 11                       |                           | Set Output on match                                                                             |                                                      |
|         |         |       | 1X        | 10                       | Edge-aligned<br>PWM       | High-true<br>pulses (clear<br>Output on<br>match)                                               |                                                      |
|         | 1       |       |           | X1                       |                           | Low-true pulses<br>(set Output on<br>match)                                                     |                                                      |
|         |         |       | 1         | xx                       | 10                        | Center-aligned<br>PWM                                                                           | High-true<br>pulses (clear<br>Output on<br>match-up) |
|         |         |       |           | X1                       |                           | Low-true pulses<br>(set Output on<br>match-up)                                                  |                                                      |
|         |         | 1 0   | xx        | 10                       | Combine PWM               | High-true<br>pulses (set on<br>channel (n)<br>match, and<br>clear on<br>channel (n+1)<br>match) |                                                      |
|         |         |       |           | X1                       |                           | Low-true pulses<br>(clear on<br>channel (n)<br>match, and set<br>on channel (n<br>+1) match)    |                                                      |
| 1       | 0       | 0     | X0        | See the following table. | Dual Edge<br>Capture Mode | One-shot capture mode                                                                           |                                                      |
|         |         |       | X1        |                          |                           | Continuous capture mode                                                                         |                                                      |

Table 37-72. Dual Edge Capture Mode — Edge Polarity Selection

| ELSnB | ELSnB ELSnA       |                           | Detected Edges |  |
|-------|-------------------|---------------------------|----------------|--|
| 0     | 0                 | Disabled                  | No edge        |  |
| 0     | 1                 | Enabled                   | Rising edge    |  |
| 1     | 0 Enabled Falling |                           | Falling edge   |  |
| 1     | 1                 | 1 Enabled Rising and fall |                |  |

Addresses: FTM0\_COSC is FFFF\_8440h base + 5h offset = FFFF\_8445h (refer to FTMx memory map for additional registers)



### FTMx\_CnSC field descriptions

| Field    | Description                                                                                                                                                                                                                                                      |
|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7        | Channel Flag                                                                                                                                                                                                                                                     |
| CHF      | Set by hardware when an event occurs on the channel. CHF is cleared by reading the CnSC register while CHnF is set and then writing a 0 to the CHF bit. Writing a 1 to CHF has no effect.                                                                        |
|          | If another event occurs between the read and write operations, the write operation has no effect; therefore, CHF remains set indicating an event has occurred. In this case a CHF interrupt request is not lost due to the clearing sequence for a previous CHF. |
|          | No channel event has occurred.                                                                                                                                                                                                                                   |
|          | 1 A channel event has occurred.                                                                                                                                                                                                                                  |
| 6        | Channel Interrupt Enable                                                                                                                                                                                                                                         |
| CHIE     | Enables channel interrupts.                                                                                                                                                                                                                                      |
|          | 0 Disable channel interrupts. Use software polling.                                                                                                                                                                                                              |
|          | 1 Enable channel interrupts.                                                                                                                                                                                                                                     |
| 5<br>MSB | Channel Mode Select                                                                                                                                                                                                                                              |
| MSB      | Used for further selections in the channel logic. Its functionality is dependent on the channel mode. See the table in the register description.                                                                                                                 |
|          | MSB is write protected. It can be written only when MODE[WPDIS] = 1.                                                                                                                                                                                             |
| 4        | Channel Mode Select                                                                                                                                                                                                                                              |
| MSA      | Used for further selections in the channel logic. Its functionality is dependent on the channel mode. See the table in the register description.                                                                                                                 |
|          | MSA is write protected. It can be written only when MODE[WPDIS] = 1.                                                                                                                                                                                             |
| 3        | Edge or Level Select                                                                                                                                                                                                                                             |
| ELSB     | The functionality of ELSB and ELSA depends on the channel mode. See the table in the register description.                                                                                                                                                       |

Table continues on the next page...

### FTMx\_CnSC field descriptions (continued)

| Field         | Description                                                                                                                      |
|---------------|----------------------------------------------------------------------------------------------------------------------------------|
|               | ELSB is write protected. It can be written only when MODE[WPDIS] = 1.                                                            |
| 2<br>ELSA     | Edge or Level Select  The functionality of ELSB and ELSA depends on the channel mode. See the table in the register description. |
|               | ELSA is write protected. It can be written only when MODE[WPDIS] = 1.                                                            |
| 1<br>Reserved | This read-only bit is reserved and always has the value zero.                                                                    |
| 0<br>DMA      | DMA Enable Enables DMA transfers for the channel.                                                                                |
|               | <ul><li>0 Disable DMA transfers.</li><li>1 Enable DMA transfers.</li></ul>                                                       |

### 37.3.9 Channel Value High (FTMx\_CnVH)

These registers contain the captured FTM counter value of the input capture function or the match value for the output modes.

In input capture, capture test and dual edge capture modes, reading a single byte in CnV latches the contents into a buffer where they remain latched until the other byte is read. This latching mechanism also resets (becomes unlatched) when the CnSC register is written (whether BDM mode is active or not). Any write to the channel registers is ignored during these input modes.

When BDM is active, the read coherency mechanism is frozen such that the buffer latches remain in the state they were in when the BDM became active, even if one or both bytes of the channel value register are read while BDM is active. This assures that if you were in the middle of reading a 16-bit register when BDM became active, it reads the appropriate value from the other half of the 16-bit value after returning to normal execution. Any read of the CnV registers in BDM mode bypasses the buffer latches and returns the value of these registers and not the value of their read buffer.

In output modes, writing to CnV latches the value into a buffer. The registers are updated with the value of their write buffer according to Update of the Registers With Write Buffers.

If MODE[FTMEN] = 0, this write coherency mechanism may be manually reset by writing to the CnSC register (whether BDM mode is active or not). This latching mechanism allows coherent 16-bit writes in either big-endian or little-endian order which is friendly to various compiler implementations.

When BDM is active, the write coherency mechanism is frozen such that the buffer latches remain in the state they were in when the BDM became active even if one or both bytes of the channel value register are written while BDM is active. Any write to the CnV registers bypasses the buffer latches and writes directly to the register while BDM is active are used in output modes operation once normal execution resumes. Writes to the channel value registers while BDM is active do not interfere with the partial completion of a coherency sequence. After the write coherency mechanism has been fully exercised, the channel value registers are updated using the buffered values (while BDM was not active).





### FTMx\_CnVH field descriptions

| Field        | Description                                                                                      |
|--------------|--------------------------------------------------------------------------------------------------|
| 7–0<br>VAL H | Channel Value High Byte                                                                          |
|              | Captured FTM counter value of the input capture function or the match value for the output modes |

### 37.3.10 Channel Value Low (FTMx\_CnVL)

See the description for the Channel Value High register.

Addresses: FTM0\_C0VL is FFFF\_8440h base + 7h offset = FFFF\_8447h (refer to FTMx memory map for additional registers)



#### FTMx CnVL field descriptions

| Field        | Description                                                                                      |
|--------------|--------------------------------------------------------------------------------------------------|
| 7–0<br>VAL_L | Channel Value Low Byte                                                                           |
|              | Captured FTM counter value of the input capture function or the match value for the output modes |

814

### 37.3.11 Counter Initial Value High (FTMx\_CNTINH)

The Counter Initial Value registers contain the high and low bytes of the initial value for the FTM counter.

Writing to either byte latches the value into a buffer. The register is updated with the value of their write buffer.

When BDM is active, the write coherency mechanism is frozen such that the buffer latches remain in the state they were in when the BDM became active, even if one or both bytes of the counter initial value register are written while BDM is active. Any write to the counter initial value registers bypasses the buffer latches and writes directly to the counter initial value register while BDM is active.

The first time that the FTM clock is selected (first write to change the CLKS bits to a non-zero value), FTM counter starts with the value 0x0000. To avoid this behavior, before the first write to select the FTM clock, write the new value to the Counter Initial Value registers and then initialize the FTM counter (write any value to CNT).





### FTMx\_CNTINH field descriptions

| Field         | Description                     |
|---------------|---------------------------------|
| 7–0<br>INIT_H | Counter Initial Value High Byte |

### 37.3.12 Counter Initial Value Low (FTMx\_CNTINL)

See the description for the Counter Initial Value High register.

Addresses: FTM0\_CNTINL is FFFF\_8440h base + 1Eh offset = FFFF\_845Eh FTM1\_CNTINL is FFFF\_8480h base + 1Eh offset = FFFF\_849Eh



### FTMx\_CNTINL field descriptions

| Field         | Description                    |
|---------------|--------------------------------|
| 7–0<br>INIT_L | Counter Initial Value Low Byte |

# 37.3.13 Capture and Compare Status (FTMx\_STATUS)

STATUS contains a copy of the status flag CHnF bit (in CnSC) for each FTM channel for software convenience.

Each CHnF bit in STATUS is a mirror of CHnF bit in CnSC. All CHnF bits can be checked using only one read of STATUS. All CHnF bits can be cleared by reading STATUS followed by writing 0x00 to STATUS.

Hardware sets the individual channel flags when an event occurs on the channel. CHF is cleared by reading STATUS while CHnF is set and then writing a 0 to the CHF bit. Writing a 1 to CHF has no effect.

If another event occurs between the read and write operations, the write operation has no effect; therefore, CHF remains set indicating an event has occurred. In this case a CHF interrupt request is not lost due to the clearing sequence for a previous CHF.

#### **NOTE**

The use of STATUS register is available only when (MODE[FTMEN] = 1), (COMBINE = 1), and (CPWMS = 0). The use of this register with (MODE[FTMEN] = 0), (COMBINE = 0), or (CPWMS = 1) is not recommended and its results are not guaranteed.

Addresses: FTM0\_STATUS is FFFF\_8440h base + 1Fh offset = FFFF\_845Fh FTM1\_STATUS is FFFF\_8480h base + 1Fh offset = FFFF\_849Fh

| Bit   | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
|-------|------|------|------|------|------|------|------|------|
| Read  | CH7F | CH6F | CH5F | CH4F | CH3F | CH2F | CH1F | CH0F |
| Write | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    |
| Reset | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    |

# FTMx\_STATUS field descriptions

| Field     | Description                      |
|-----------|----------------------------------|
| 7<br>CH7F | Channel 7 Flag                   |
|           | See the register description.    |
|           | 0 No channel event has occurred. |
|           | 1 A channel event has occurred.  |
| 6<br>CH6F | Channel 6 Flag                   |
|           | See the register description.    |
|           | 0 No channel event has occurred. |
|           | 1 A channel event has occurred.  |
| 5<br>CH5F | Channel 5 Flag                   |
|           | See the register description.    |
|           | 0 No channel event has occurred. |
|           | 1 A channel event has occurred.  |
| 4<br>CH4F | Channel 4 Flag                   |
|           | See the register description.    |
|           | 0 No channel event has occurred. |
|           | 1 A channel event has occurred.  |
| 3<br>CH3F | Channel 3 Flag                   |
| 0.101     | See the register description.    |
|           | No channel event has occurred.   |
|           | 1 A channel event has occurred.  |
| 2<br>CH2F | Channel 2 Flag                   |
| 0.121     | See the register description.    |
|           | 0 No channel event has occurred. |
|           | 1 A channel event has occurred.  |
| 1<br>CH1F | Channel 1 Flag                   |
|           | See the register description.    |

### FTMx\_STATUS field descriptions (continued)

| Field     | Description                                                                                |
|-----------|--------------------------------------------------------------------------------------------|
|           | <ul><li>No channel event has occurred.</li><li>A channel event has occurred.</li></ul>     |
| 0<br>CH0F | Channel 0 Flag                                                                             |
| 01101     | See the register description.                                                              |
|           | <ul><li>0 No channel event has occurred.</li><li>1 A channel event has occurred.</li></ul> |

# 37.3.14 Features Mode Selection (FTMx\_MODE)

This register contains the control bits used to configure the fault interrupt and fault control, capture test mode, PWM synchronization, write protection, channel output initialization, and enable the enhanced features of the FTM. These controls relate to all channels within this module.

Addresses: FTM0\_MODE is FFFF\_8440h base + 20h offset = FFFF\_8460h FTM1\_MODE is FFFF\_8480h base + 20h offset = FFFF\_84A0h



### FTMx\_MODE field descriptions

| Field        | Description                                                                                                                       |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 7<br>FAULTIE | Fault Interrupt Enable                                                                                                            |
| TAGETIE      | Enables the generation of an interrupt when a fault is detected by FTM and the FTM fault control is enabled.                      |
|              | 0 Fault control interrupt is disabled.                                                                                            |
|              | 1 Fault control interrupt is enabled.                                                                                             |
| 6–5          | Fault Control Mode                                                                                                                |
| FAULTM       | Defines the FTM fault control mode.                                                                                               |
|              | FAULTM is write protected, these bits can only be written if MODE[WPDIS] = 1.                                                     |
|              | 00 Fault control is disabled for all channels.                                                                                    |
|              | 01 Fault control is enabled for even channels only (channels 0, 2, 4, and 6), and the selected mode is the manual fault clearing. |
|              | 10 Fault control is enabled for all channels, and the selected mode is the manual fault clearing.                                 |
|              | 11 Fault control is enabled for all channels, and the selected mode is the automatic fault clearing.                              |

Table continues on the next page...

### FTMx\_MODE field descriptions (continued)

| Field        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4<br>CAPTEST | Capture Test Mode Enable  Enables the capture test mode.CAPTEST bit is write protected, this bit can only be written if WPDIS = 1.  O Capture test mode is disabled.  1 Capture test mode is enabled.                                                                                                                                                                                                                                                                                    |
| 3<br>PWMSYNC | PWM Synchronization Mode  Selects which triggers can be used by MOD, CV, CHnOM, and FTM counter synchronization (PWM Synchronization).  0 No restrictions. Software and hardware triggers can be used by MOD, CV, CHnOM, and FTM counter synchronization.  1 Software trigger can only be used by MOD and CV synchronization, and hardware triggers can only be used by CHnOM and FTM counter synchronization.                                                                           |
| 2<br>WPDIS   | Write Protection Disable  When write protection is enabled (MODE[WPDIS] = 0), write protected bits can not be written. When write protection is disabled (MODE[WPDIS] = 1), write protected bits can be written. The WPDIS bit is the negation of the WPEN bit. WPDIS is cleared when 1 is written to WPEN. WPDIS is set when WPEN bit is read as a 1 and then 1 is written to WPDIS. Writing 0 to WPDIS has no effect.  0 Write protection is enabled.  1 Write protection is disabled. |
| 1<br>INIT    | Initialize the Output Channels  When a 1 is written to INIT bit the output channels are initialized according to the state of their corresponding bit in the OUTINIT register. Writing a 0 to INIT bit has no effect.  The INIT bit is always read as 0.                                                                                                                                                                                                                                 |
| 0<br>FTMEN   | <ul> <li>FTM Enable</li> <li>Only the TPM-compatible registers (first set of registers) can be used without any restriction. Do not use the FTM-specific registers.</li> <li>All registers including the FTM-specific registers (second set of registers) are available for use with no restrictions.</li> </ul>                                                                                                                                                                         |

# 37.3.15 Synchronization (FTMx\_SYNC)

This register configures the PWM synchronization.

A synchronization event can perform the synchronized update of MOD, CV, and OUTMASK registers with the value of their write buffer and the FTM counter initialization.

#### **NOTE**

The software trigger (SWSYNC bit) and hardware triggers (TRIG0, TRIG1, and TRIG2 bits) have a potential conflict if used together. It is recommended using only hardware or software triggers but not both at the same time, otherwise unpredictable behavior is likely to happen.

The selection of the boundary cycle (CNTMAX and CNTMIN bits) is intended to provide the update of MOD, CNTIN, and CV across all enabled channels simultaneously. The use of the boundary cycle selection together with TRIG0, TRIG1, or TRIG2 bits is likely to result in an unpredictable behavior.

The MODE[PWMSYNC] bit determines which type of trigger event controls the functions enabled by the SYNC register.

Addresses: FTM0\_SYNC is FFFF\_8440h base + 21h offset = FFFF\_8461h FTM1\_SYNC is FFFF\_8480h base + 21h offset = FFFF\_84A1h



#### FTMx SYNC field descriptions

| Field       | Description                                                                                                                                                 |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>SWSYNC | PWM Synchronization Software Trigger                                                                                                                        |
|             | Selects the software trigger as the PWM synchronization trigger. The software trigger happens when a 1 is written to SWSYNC bit.                            |
|             | 0 Software trigger is not selected.                                                                                                                         |
|             | 1 Software trigger is selected.                                                                                                                             |
| 6<br>TRIG2  | PWM Synchronization External Trigger 2                                                                                                                      |
|             | Selects external trigger 2 as the PWM synchronization trigger. External trigger 2 happens when the FTM detects a rising edge in the trigger 2 input signal. |
|             | 0 External trigger 2 is not selected.                                                                                                                       |
|             | 1 External trigger 2 is selected.                                                                                                                           |
| 5<br>TRIG1  | PWM Synchronization External Trigger 1                                                                                                                      |
|             | Selects external trigger 1 as the PWM synchronization trigger. External trigger 1 happens when the FTM detects a rising edge in the trigger 1 input signal. |

Table continues on the next page...

# FTMx\_SYNC field descriptions (continued)

| Field        | Description                                                                                                                                                                                                                              |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|              | 0 External trigger 1 is not selected.                                                                                                                                                                                                    |
|              | 1 External trigger 1 is selected.                                                                                                                                                                                                        |
| 4            | PWM Synchronization External Trigger 0                                                                                                                                                                                                   |
| TRIG0        | Selects external trigger 0 as the PWM synchronization trigger. External trigger 0 happens when the FTM detects a rising edge in the trigger 0 input signal.                                                                              |
|              | 0 External trigger 0 is not selected.                                                                                                                                                                                                    |
|              | 1 External trigger 0 is selected.                                                                                                                                                                                                        |
| 3<br>SYNCHOM | Output Mask Synchronization                                                                                                                                                                                                              |
| STNOTION     | Selects when the CHnOM bits in register OUTMASK are updated with the value of their write buffer.                                                                                                                                        |
|              | O CHnOM bits are updated with the value of the OUTMASK write buffer in all rising edges of the system clock.                                                                                                                             |
|              | CHnOM bits are updated with the value of the OUTMASK write buffer only by the PWM synchronization.                                                                                                                                       |
| 2<br>REINIT  | FTM Counter Reinitialization by Synchronization (See "FTM Counter Synchronization")                                                                                                                                                      |
| REINIT       | Determines if the FTM counter is reinitialized when the selected trigger for the synchronization is detected.                                                                                                                            |
|              | 0 FTM counter continues to count normally.                                                                                                                                                                                               |
|              | 1 FTM counter is updated with its initial value when the selected trigger is detected.                                                                                                                                                   |
| 1            | Maximum Boundary Cycle Enable                                                                                                                                                                                                            |
| CNTMAX       | Determines when the MOD, CNTIN, and CV registers are updated with their write buffer contents following a PWM synchronization event. If CNTMAX is enabled, the registers are updated when the FTM counter reaches its maximum value MOD. |
|              | 0 The maximum boundary cycle is disabled.                                                                                                                                                                                                |
|              | 1 The maximum boundary cycle is enabled.                                                                                                                                                                                                 |
| 0<br>CNTMIN  | Minimum Boundary Cycle Enable                                                                                                                                                                                                            |
| CINTIMIIN    | Determines when the MOD and CV registers are updated with their write buffer contents following a PWM synchronization event. If CNTMIN is enabled, the registers are updated when the FTM counter reaches its minimum value CNTIN.       |
|              | 0 The minimum boundary cycle is disabled.                                                                                                                                                                                                |
|              | 1 The minimum boundary cycle is enabled.                                                                                                                                                                                                 |

# 37.3.16 Initial State for Channel Output (FTMx\_OUTINIT)

Addresses: FTM0\_OUTINIT is FFFF\_8440h base + 22h offset = FFFF\_8462h FTM1\_OUTINIT is FFFF\_8480h base + 22h offset = FFFF\_84A2h



### FTMx\_OUTINIT field descriptions

Table continues on the next page...

### FTMx\_OUTINIT field descriptions (continued)

| Field | Description                                                                              |
|-------|------------------------------------------------------------------------------------------|
| 1     | Channel 1 Output Initialization Value                                                    |
| CH1OI | Selects the value that is forced into the channel output when the initialization occurs. |
|       | 0 The initialization value is 0.                                                         |
|       | 1 The initialization value is 1.                                                         |
| 0     | Channel 0 Output Initialization Value                                                    |
| CH0OI | Selects the value that is forced into the channel output when the initialization occurs. |
|       | 0 The initialization value is 0.                                                         |
|       | 1 The initialization value is 1.                                                         |

# 37.3.17 Output Mask (FTMx\_OUTMASK)

This register provides a mask for each FTM channel. The mask of a channel determines if its output responds (that is, it is masked or not) when a match occurs. This feature is used for BLDC control where the PWM signal is presented to an electric motor at specific times to provide electronic commutation.

Any write to the OUTMASK register, stores the value into a write buffer. The register is updated with the value of its write buffer according to PWM Synchronization.

Addresses: FTM0\_OUTMASK is FFFF\_8440h base + 23h offset = FFFF\_8463h FTM1\_OUTMASK is FFFF\_8480h base + 23h offset = FFFF\_84A3h



### FTMx\_OUTMASK field descriptions

| Field      | Description                                                                                                            |
|------------|------------------------------------------------------------------------------------------------------------------------|
| 7<br>CH7OM | Channel 7 Output Mask                                                                                                  |
|            | Defines if the channel output is masked (forced to its inactive state) or unmasked (it continues to operate normally). |
|            | 0 Channel output is not masked. It continues to operate normally.                                                      |
|            | 1 Channel output is masked. It is forced to its inactive state.                                                        |
| 6<br>CH6OM | Channel 6 Output Mask                                                                                                  |

# FTMx\_OUTMASK field descriptions (continued)

| ontinues to operate |
|---------------------|
|                     |
|                     |
|                     |
|                     |
| ontinues to operate |
|                     |
|                     |
|                     |
| ontinues to operate |
|                     |
|                     |
|                     |
| ontinues to operate |
|                     |
|                     |
|                     |
| ontinues to operate |
|                     |
|                     |
|                     |
| ontinues to operate |
|                     |
|                     |
|                     |
| ontinues to operate |
|                     |
|                     |
|                     |

# 37.3.18 Function for Linked Channels (FTMx\_COMBINEn)

This register contains the control bits used to configure the fault control, synchronization, deadtime, dual edge capture mode, complementary, and combine features of channels (n) and (n+1).

### **NOTE**

The COMBINE0 register configures the control bits for channels 0 and 1; COMBINE1 for channels 2 and 3; COMBINE2 for channels 4 and 5.

The channel (n) is the even channel and the channel (n+1) is the odd channel of a pair of channels.

Addresses: FTM0\_COMBINE0 is FFFF\_8440h base + 24h offset = FFFF\_8464h
FTM1\_COMBINE0 is FFFF\_8480h base + 24h offset = FFFF\_84A4h
FTM1\_COMBINE1 is FFFF\_8480h base + 25h offset = FFFF\_84A5h
FTM1\_COMBINE2 is FFFF\_8480h base + 26h offset = FFFF\_84A6h



#### FTMx\_COMBINEn field descriptions

| Field         | Description                                                                                                                                                                                                                                                                  |
|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>Reserved | This read-only bit is reserved and always has the value zero.                                                                                                                                                                                                                |
| 6<br>FAULTEN  | Fault Control Enable  Enables the fault control in channels (n) and (n+1).  This field is write protected. It can be written only when MODE[WPDIS] = 1.  0 The fault control in this pair of channels is disabled.  1 The fault control in this pair of channels is enabled. |
| 5<br>SYNCEN   | Synchronization Enable  Enables PWM synchronization of registers C(n)V and C(n+1)V.  The PWM synchronization in this pair of channels is disabled.  The PWM synchronization in this pair of channels is enabled.                                                             |

Downloaded from Elcodis.com electronic components distributor

# FTMx\_COMBINEn field descriptions (continued)

| Field        | Description                                                                                                                                                                                                                                                                      |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4<br>DTEN    | Deadtime Enable                                                                                                                                                                                                                                                                  |
|              | Enables the deadtime insertion in the channels (n) and (n+1).                                                                                                                                                                                                                    |
|              | This field is write protected. It can be written only when MODE[WPDIS] = 1.                                                                                                                                                                                                      |
|              | <ul> <li>The deadtime insertion in this pair of channels is disabled.</li> <li>The deadtime insertion in this pair of channels is enabled.</li> </ul>                                                                                                                            |
| 3            | Dual Edge Capture Mode Captures                                                                                                                                                                                                                                                  |
| DECAP        | Enables the capture of the FTM counter value according to the channel (n) input event and the configuration of the dual edge capture bits.                                                                                                                                       |
|              | This field applies only when MODE[FTMEN] = 1 and DECAPEN = 1.                                                                                                                                                                                                                    |
|              | DECAP bit is cleared automatically by hardware if dual edge capture – one-shot mode is selected and when the capture of channel (n+1) event is made.                                                                                                                             |
|              | 0 The dual edge captures are inactive.                                                                                                                                                                                                                                           |
|              | 1 The dual edge captures are active.                                                                                                                                                                                                                                             |
| 2<br>DECAPEN | Dual Edge Capture Mode Enable                                                                                                                                                                                                                                                    |
| DECAPEN      | Enables the dual edge capture mode in the channels (n) and (n+1). This bit reconfigures the function of MSnA, ELSnB:ELSnA and ELS(n+1)B:ELS(n+1)A bits in dual edge capture mode according to the table Mode, Edge, and Level Selection in the description of the CnSC register. |
|              | This field applies only when MODE[FTMEN] = 1.                                                                                                                                                                                                                                    |
|              | DECAPEN is write protected, this bit can only be written if MODE[WPDIS] = 1.                                                                                                                                                                                                     |
|              | 0 The dual edge capture mode in this pair of channels is disabled.                                                                                                                                                                                                               |
|              | 1 The dual edge capture mode in this pair of channels is enabled.                                                                                                                                                                                                                |
| 1            | Complement of Channel (n)                                                                                                                                                                                                                                                        |
| COMP         | Enables complementary mode for the combined channels. In complementary mode the channel (n+1) output is the inverse of the channel (n) output.                                                                                                                                   |
|              | This field is write protected. It can be written only when MODE[WPDIS] = 1.                                                                                                                                                                                                      |
|              | <ul> <li>The channel (n+1) output is the same as the channel (n) output.</li> <li>The channel (n+1) output is the complement of the channel (n) output.</li> </ul>                                                                                                               |
| 0            | Combine Channels                                                                                                                                                                                                                                                                 |
| COMBINE      | Enables the combine feature for channels (n) and (n+1).                                                                                                                                                                                                                          |
|              | This field is write protected. It can be written only when MODE[WPDIS] = 1.                                                                                                                                                                                                      |
|              | 0 Channels (n) and (n+1) are independent.                                                                                                                                                                                                                                        |
|              | 1 Channels (n) and (n+1) are combined.                                                                                                                                                                                                                                           |

### 37.3.19 Deadtime Insertion Control (FTMx\_DEADTIME)

This register selects the deadtime prescaler factor and deadtime value. All FTM channels use this clock prescaler and this deadtime value for the deadtime insertion.

Addresses: FTM0\_DEADTIME is FFFF\_8440h base + 28h offset = FFFF\_8468h FTM1\_DEADTIME is FFFF\_8480h base + 28h offset = FFFF\_84A8h



### FTMx\_DEADTIME field descriptions

| Field        | Description                                                                                                                                                                                             |  |  |  |  |  |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 7–6<br>DTPS  | Deadtime Prescaler Value  Selects the division factor of the system clock. This prescaled clock is used by the deadtime counter.  DTPS is write protected. It can be written only when MODE[WPDIS] = 1. |  |  |  |  |  |
|              | 0x Divide the system clock by 1. 10 Divide the system clock by 4. 11 Divide the system clock by 16.                                                                                                     |  |  |  |  |  |
| 5–0<br>DTVAL | Deadtime Value  Selects the deadtime insertion value for the deadtime counter. The deadtime counter is clocked by a scaled version of the system clock. See the description of DTPS.                    |  |  |  |  |  |
|              | Deadtime insert value = (DTPS $\times$ DPVAT).                                                                                                                                                          |  |  |  |  |  |
|              | DTVAL selects the number of deadtime counts inserted as follows:                                                                                                                                        |  |  |  |  |  |
|              | When DTVAL is 0, no counts are inserted.                                                                                                                                                                |  |  |  |  |  |
|              | When DTVAL is 1, 1 count is inserted.                                                                                                                                                                   |  |  |  |  |  |
|              | When DTVAL is 2, 2 counts are inserted.                                                                                                                                                                 |  |  |  |  |  |
|              | This pattern continues up to a possible 63 counts.                                                                                                                                                      |  |  |  |  |  |
|              | DTVAL is write protected. It can be written only when MODE[WPDIS] = 1.                                                                                                                                  |  |  |  |  |  |

### 37.3.20 External Trigger (FTMx\_EXTTRIG)

This register indicates when a channel trigger was generated, enables the generation of a trigger when the FTM counter is equal to its initial value, and selects which channels are used in the generation of the channel triggers. Several FTM channels can be selected to generate multiple triggers in one PWM period.

Channels 6 and 7 are not used to generate channel triggers.

Addresses: FTM0\_EXTTRIG is FFFF\_8440h base + 29h offset = FFFF\_8469h FTM1\_EXTTRIG is FFFF\_8480h base + 29h offset = FFFF\_84A9h

| Bit   | 7     | 6          | 5       | 4        | 3       | 2       | 1        | 0       |
|-------|-------|------------|---------|----------|---------|---------|----------|---------|
| Read  |       |            |         | 01107710 | 0       | 0111    | 01107710 |         |
| Write | TRIGF | INITTRIGEN | CH1TRIG | CH0TRIG  | CH5TRIG | CH4TRIG | CH3TRIG  | CH2TRIG |
| Reset | 0     | 0          | 0       | 0        | 0       | 0       | 0        | 0       |

### FTMx\_EXTTRIG field descriptions

| Field           | Description                                                                                                                                                                                |  |  |  |  |  |
|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 7               | Channel Trigger Flag                                                                                                                                                                       |  |  |  |  |  |
| TRIGF           | Set by hardware when a channel trigger is generated. Clear TRIGF by reading EXTTRIG while TRIGF is set and then writing a 0 to TRIGF. Writing a 1 to TRIGF has no effect.                  |  |  |  |  |  |
|                 | If another channel trigger is generated before the clearing sequence is completed, the sequence is reset so TRIGF remains set after the clear sequence is completed for the earlier TRIGF. |  |  |  |  |  |
|                 | <ul><li>0 No channel trigger was generated.</li><li>1 A channel trigger was generated.</li></ul>                                                                                           |  |  |  |  |  |
| 6<br>INITTRIGEN | Initialization Trigger Enable                                                                                                                                                              |  |  |  |  |  |
| INITIAIGEN      | Enables the generation of the trigger when the FTM counter is equal to its initial value.                                                                                                  |  |  |  |  |  |
|                 | 0 The generation of initialization trigger is disabled.                                                                                                                                    |  |  |  |  |  |
|                 | The generation of initialization trigger is enabled.                                                                                                                                       |  |  |  |  |  |
| 5<br>CH1TRIG    | Channel 1 Trigger Enable                                                                                                                                                                   |  |  |  |  |  |
| OITI III G      | Enable the generation of the channel trigger when the FTM counter is equal to the CV register.                                                                                             |  |  |  |  |  |
|                 | 0 The generation of the channel trigger is disabled.                                                                                                                                       |  |  |  |  |  |
|                 | 1 The generation of the channel trigger is enabled.                                                                                                                                        |  |  |  |  |  |
| 4<br>CH0TRIG    | Channel 0 Trigger Enable                                                                                                                                                                   |  |  |  |  |  |
| Onomia          | Enable the generation of the channel trigger when the FTM counter is equal to the CV register.                                                                                             |  |  |  |  |  |
|                 | 0 The generation of the channel trigger is disabled.                                                                                                                                       |  |  |  |  |  |
|                 | 1 The generation of the channel trigger is enabled.                                                                                                                                        |  |  |  |  |  |
| 3<br>CH5TRIG    | Channel 5 Trigger Enable                                                                                                                                                                   |  |  |  |  |  |
| Onomia          | Enable the generation of the channel trigger when the FTM counter is equal to the CV register.                                                                                             |  |  |  |  |  |
|                 | 0 The generation of the channel trigger is disabled.                                                                                                                                       |  |  |  |  |  |
|                 | 1 The generation of the channel trigger is enabled.                                                                                                                                        |  |  |  |  |  |
| 2<br>CH4TRIG    | Channel 4 Trigger Enable                                                                                                                                                                   |  |  |  |  |  |
| OHITAIG         | Enable the generation of the channel trigger when the FTM counter is equal to the CV register.                                                                                             |  |  |  |  |  |
|                 | 0 The generation of the channel trigger is disabled.                                                                                                                                       |  |  |  |  |  |
|                 | 1 The generation of the channel trigger is enabled.                                                                                                                                        |  |  |  |  |  |
| 1<br>CH3TRIG    | Channel 3 Trigger Enable                                                                                                                                                                   |  |  |  |  |  |

Table continues on the next page...

### FTMx\_EXTTRIG field descriptions (continued)

| Field        | Description                                                                                                                    |
|--------------|--------------------------------------------------------------------------------------------------------------------------------|
|              | Enable the generation of the channel trigger when the FTM counter is equal to the CV register.                                 |
|              | 0 The generation of the channel trigger is disabled.                                                                           |
|              | 1 The generation of the channel trigger is enabled.                                                                            |
| 0<br>CH2TRIG | Channel 2 Trigger Enable                                                                                                       |
| G. 1211G     | Enable the generation of the channel trigger when the FTM counter is equal to the CV register.                                 |
|              | <ul><li>The generation of the channel trigger is disabled.</li><li>The generation of the channel trigger is enabled.</li></ul> |

## 37.3.21 Channels Polarity (FTMx\_POL)

This register defines the output polarity of the FTM channels.

### **NOTE**

The safe value that is driven in a channel output when the fault control is enabled and a fault condition is detected is the inactive state of the channel. That is, the safe value of a channel is the value of its POL bit.

Addresses: FTM0\_POL is FFFF\_8440h base + 2Ah offset = FFFF\_846Ah FTM1\_POL is FFFF\_8480h base + 2Ah offset = FFFF\_84AAh



### FTMx\_POL field descriptions

| Field     | Description                                                                                        |
|-----------|----------------------------------------------------------------------------------------------------|
| 7         | Channel 7 Polarity                                                                                 |
| POL7      | Defines the polarity of the channel output.                                                        |
|           | This field is write protected. It can be written only when MODE[WPDIS] = 1.                        |
|           | <ul><li>The channel polarity is active high.</li><li>The channel polarity is active low.</li></ul> |
| 6<br>POL6 | Channel 6 Polarity                                                                                 |
|           | Defines the polarity of the channel output.                                                        |
|           | This field is write protected. It can be written only when MODE[WPDIS] = 1.                        |

Table continues on the next page...

## **Memory Map and Register Definition**

Downloaded from **Elcodis.com** electronic components distributor

## FTMx\_POL field descriptions (continued)

| Field     | Description                                                                 |
|-----------|-----------------------------------------------------------------------------|
|           | 0 The channel polarity is active high.                                      |
|           | 1 The channel polarity is active low.                                       |
| 5<br>POL5 | Channel 5 Polarity                                                          |
| . 020     | Defines the polarity of the channel output.                                 |
|           | This field is write protected. It can be written only when MODE[WPDIS] = 1. |
|           | 0 The channel polarity is active high.                                      |
|           | 1 The channel polarity is active low.                                       |
| 4<br>POL4 | Channel 4 Polarity                                                          |
| POL4      | Defines the polarity of the channel output.                                 |
|           | This field is write protected. It can be written only when MODE[WPDIS] = 1. |
|           | 0 The channel polarity is active high.                                      |
|           | 1 The channel polarity is active low.                                       |
| 3         | Channel 3 Polarity                                                          |
| POL3      | Defines the polarity of the channel output.                                 |
|           | This field is write protected. It can be written only when MODE[WPDIS] = 1. |
|           | 0 The channel polarity is active high.                                      |
|           | 1 The channel polarity is active low.                                       |
| 2         | Channel 2 Polarity                                                          |
| POL2      | Defines the polarity of the channel output.                                 |
|           | This field is write protected. It can be written only when MODE[WPDIS] = 1. |
|           | 0 The channel polarity is active high.                                      |
|           | 1 The channel polarity is active low.                                       |
| 1         | Channel 1 Polarity                                                          |
| POL1      | Defines the polarity of the channel output.                                 |
|           | This field is write protected. It can be written only when MODE[WPDIS] = 1. |
|           | 0 The channel polarity is active high.                                      |
|           | 1 The channel polarity is active low.                                       |
| 0         | Channel 0 Polarity                                                          |
| POL0      | Defines the polarity of the channel output.                                 |
|           | This field is write protected. It can be written only when MODE[WPDIS] = 1. |
|           | 0 The channel polarity is active high.                                      |
|           | 1 The channel polarity is active low.                                       |

## 37.3.22 Fault Mode Status (FTMx\_FMS)

This register contains the fault detection flags, write protection enable bit, and the logic OR of the enable fault inputs.

Addresses: FTM0\_FMS is FFFF\_8440h base + 2Bh offset = FFFF\_846Bh FTM1\_FMS is FFFF\_8480h base + 2Bh offset = FFFF\_84ABh



### FTMx\_FMS field descriptions

| Field         | Description                                                                                                                                                                                                                                                                                          |
|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7             | Fault Detection Flag                                                                                                                                                                                                                                                                                 |
| FAULTF        | Represents the logic OR of the individual FAULTFn bits. Clear FAULTF by reading the FMS register while FAULTF is set and then writing a 0 to FAULTF while there is no existing fault condition at the enabled fault inputs. Writing a 1 to FAULTF has no effect.                                     |
|               | If another fault condition is detected in an enabled fault input before the clearing sequence is completed, the sequence is reset so FAULTF remains set after the clearing sequence is completed for the earlier fault condition. FAULTF is also cleared when FAULTFn bits are cleared individually. |
|               | <ul><li>0 No fault condition was detected.</li><li>1 A fault condition was detected.</li></ul>                                                                                                                                                                                                       |
| 6             | Write Protection Enable                                                                                                                                                                                                                                                                              |
| WPEN          | The WPEN bit is the negation of the WPDIS bit. WPEN is set when 1 is written to it. WPEN is cleared when WPEN bit is read as a 1 and then 1 is written to WPDIS. Writing 0 to WPEN has no effect.                                                                                                    |
|               | 0 Write protection is disabled. Write protected bits can be written.                                                                                                                                                                                                                                 |
|               | 1 Write protection is enabled. Write protected bits cannot be written.                                                                                                                                                                                                                               |
| 5             | Fault Inputs                                                                                                                                                                                                                                                                                         |
| FAULTIN       | Represents the logic OR of the enabled fault input after its filter (if its filter is enabled) when fault control is enabled.                                                                                                                                                                        |
|               | 0 The value of the fault input is 0.                                                                                                                                                                                                                                                                 |
|               | 1 The value of the fault input is 1.                                                                                                                                                                                                                                                                 |
| 4<br>Reserved | This read-only bit is reserved and always has the value zero.                                                                                                                                                                                                                                        |
| 3             | Fault Detection Flag 3                                                                                                                                                                                                                                                                               |
| FAULTF3       | Set by hardware when fault control is enabled, the corresponding fault input is enabled and a fault condition is detected in the fault input.                                                                                                                                                        |

Table continues on the next page...

## **Memory Map and Register Definition**

## FTMx\_FMS field descriptions (continued)

| Field        | Description                                                                                                                                                                                                                                                         |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|              | Clear FAULTF by reading the FMS register while FAULTFn is set and then writing a 0 to FAULTFn FAULTF while there is no existing fault condition at the fault input n. Writing a 1 to FAULTFn has no effect. FAULTFn bit is also cleared when FAULTF bit is cleared. |
|              | If another fault condition is detected at fault input n before the clearing sequence is completed, the sequence is reset so FAULTFn remains set after the clearing sequence is completed for the earlier fault condition.                                           |
|              | <ul><li>No fault condition was detected in the fault input.</li><li>A fault condition was detected in the fault input.</li></ul>                                                                                                                                    |
| 2<br>FAULTF2 | Fault Detection Flag 2  Set by hardware when fault control is enabled, the corresponding fault input is enabled and a fault condition is detected in the fault input.                                                                                               |
|              | Clear FAULTF by reading the FMS register while FAULTFn is set and then writing a 0 to FAULTFn FAULTF while there is no existing fault condition at the fault input n. Writing a 1 to FAULTFn has no effect. FAULTFn bit is also cleared when FAULTF bit is cleared. |
|              | If another fault condition is detected at fault input n before the clearing sequence is completed, the sequence is reset so FAULTFn remains set after the clearing sequence is completed for the earlier fault condition.                                           |
|              | <ul><li>No fault condition was detected in the fault input.</li><li>A fault condition was detected in the fault input.</li></ul>                                                                                                                                    |
| 1            | Fault Detection Flag 1                                                                                                                                                                                                                                              |
| FAULTF1      | Set by hardware when fault control is enabled, the corresponding fault input is enabled and a fault condition is detected in the fault input.                                                                                                                       |
|              | Clear FAULTF by reading the FMS register while FAULTFn is set and then writing a 0 to FAULTFn FAULTF while there is no existing fault condition at the fault input n. Writing a 1 to FAULTFn has no effect. FAULTFn bit is also cleared when FAULTF bit is cleared. |
|              | If another fault condition is detected at fault input n before the clearing sequence is completed, the sequence is reset so FAULTFn remains set after the clearing sequence is completed for the earlier fault condition.                                           |
|              | <ul><li>No fault condition was detected in the fault input.</li><li>A fault condition was detected in the fault input.</li></ul>                                                                                                                                    |
| 0            | Fault Detection Flag 0                                                                                                                                                                                                                                              |
| FAULTF0      | Set by hardware when fault control is enabled, the corresponding fault input is enabled and a fault condition is detected in the fault input.                                                                                                                       |
|              | Clear FAULTF by reading the FMS register while FAULTFn is set and then writing a 0 to FAULTFn FAULTF while there is no existing fault condition at the fault input n. Writing a 1 to FAULTFn has no effect. FAULTFn bit is also cleared when FAULTF bit is cleared. |
|              | If another fault condition is detected at fault input n before the clearing sequence is completed, the sequence is reset so FAULTFn remains set after the clearing sequence is completed for the earlier fault condition.                                           |
|              | <ul><li>No fault condition was detected in the fault input.</li><li>A fault condition was detected in the fault input.</li></ul>                                                                                                                                    |

## 37.3.23 Input Capture Filter Control (FTMx\_FILTERn)

This register selects the filter value for the inputs of channels.

FILTER0 supports Channels 0 and 1. FILTER1 supports Channels 2 and 3.

Channels 4 and 5 do not have an input filter.

### **NOTE**

Writing to this register has immediate effect and must be done only when the input capture modes of the effected channels are disabled. Failure to do this could result in a missing valid signal.



### FTMx\_FILTERn field descriptions

| Field      | Description                                                   |
|------------|---------------------------------------------------------------|
| 7–4        | Input Filter for Odd Channel                                  |
| CHoddFVAL  | Selects the filter value for the odd-numbered channel input.  |
|            | The filter is disabled when the value is zero.                |
| 3–0        | Input Filter for Even Channel                                 |
| CHevenFVAL | Selects the filter value for the even-numbered channel input. |
|            | The filter is disabled when the value is zero.                |

## 37.3.24 Fault Input Filter Control (FTMx\_FLTFILTER)

This register selects the fault inputs and enables the fault input filter.

Addresses: FTM0\_FLTFILTER is FFFF\_8440h base + 2Eh offset = FFFF\_846Eh FTM1\_FLTFILTER is FFFF\_8480h base + 2Eh offset = FFFF\_84AEh



### FTMx\_FLTFILTER field descriptions

| Field           | Description                                                                                                                                                                               |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–4<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                                                        |
| 3–0<br>FFVAL    | Fault Input Filter Selects the filter value for the fault inputs.                                                                                                                         |
|                 | The fault filter is disabled when the value is zero.                                                                                                                                      |
|                 | NOTE: Writing to this field has immediate effect and must be done only when the fault control or the fault input is disabled. Failure to do so could result in a missing fault detection. |

# 37.3.25 Fault Input Control (FTMx\_FLTCTRL)

This register selects the fault inputs and enables the fault input filter.

Addresses: FTM0\_FLTCTRL is FFFF\_8440h base + 2Fh offset = FFFF\_846Fh FTM1\_FLTCTRL is FFFF\_8480h base + 2Fh offset = FFFF\_84AFh



### FTMx\_FLTCTRL field descriptions

| Field    | Description                                                                 |
|----------|-----------------------------------------------------------------------------|
| 7        | Fault Input 3 Filter Enable                                                 |
| FFLTR3EN | Enables the filter for the fault input.                                     |
|          | This field is write protected. It can be written only when MODE[WPDIS] = 1. |

Table continues on the next page...

## FTMx\_FLTCTRL field descriptions (continued)

| Field         | Description                                                                              |
|---------------|------------------------------------------------------------------------------------------|
|               | Fault input filter is disabled.                                                          |
|               | 1 Fault input filter is enabled.                                                         |
| 6<br>FFLTR2EN | Fault Input 2 Filter Enable                                                              |
| TT ETTIZETY   | Enables the filter for the fault input.                                                  |
|               | This field is write protected. It can be written only when MODE[WPDIS] = 1.              |
|               | <ul><li>Fault input filter is disabled.</li><li>Fault input filter is enabled.</li></ul> |
| 5             | Fault Input 1 Filter Enable                                                              |
| FFLTR1EN      | Enables the filter for the fault input.                                                  |
|               | This field is write protected. It can be written only when MODE[WPDIS] = 1.              |
|               | 0 Fault input filter is disabled.                                                        |
|               | 1 Fault input filter is enabled.                                                         |
| 4<br>FFLTR0EN | Fault Input 0 Filter Enable                                                              |
| FFLINUEN      | Enables the filter for the fault input.                                                  |
|               | This field is write protected. It can be written only when MODE[WPDIS] = 1.              |
|               | 0 Fault input filter is disabled.                                                        |
|               | 1 Fault input filter is enabled.                                                         |
| 3<br>FAULT3EN | Fault Input 3 Enable                                                                     |
| PAULISEN      | Enables the fault input.                                                                 |
|               | This field is write protected. It can be written only when MODE[WPDIS] = 1.              |
|               | 0 Fault input is disabled.                                                               |
|               | 1 Fault input is enabled.                                                                |
| 2<br>FAULT2EN | Fault Input 2 Enable                                                                     |
| FAULTZEN      | Enables the fault input.                                                                 |
|               | This field is write protected. It can be written only when MODE[WPDIS] = 1.              |
|               | 0 Fault input is disabled.                                                               |
|               | 1 Fault input is enabled.                                                                |
| 1<br>FAULT1EN | Fault Input 1 Enable                                                                     |
| FAULITEN      | Enables the fault input.                                                                 |
|               | This field is write protected. It can be written only when MODE[WPDIS] = 1.              |
|               | 0 Fault input is disabled.                                                               |
|               | 1 Fault input is enabled.                                                                |
| 0<br>FAULT0EN | Fault Input 0 Enable                                                                     |
| FAULTUEN      | Enables the fault input.                                                                 |
|               | This field is write protected. It can be written only when MODE[WPDIS] = 1.              |

Table continues on the next page...

#### **Memory Map and Register Definition**

### FTMx\_FLTCTRL field descriptions (continued)

| Field | Description                |
|-------|----------------------------|
|       | 0 Fault input is disabled. |
|       | 1 Fault input is enabled.  |

## 37.3.26 Quadrature Decoder Control and Status (FTMx\_QDCTRL)

This register has the control and status bits for the quadrature decoder mode.

### **NOTE**

Do not write to this register when the quadrature decoder feature is not supported.

Addresses: FTM0\_QDCTRL is FFFF\_8440h base + 30h offset = FFFF\_8470h



### FTMx\_QDCTRL field descriptions

| Field          | Description                                                                                                                                                                                                                                                                           |
|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>PHAFLTREN | Phase A Input Filter Enable  Enables the filter for the quadrature decoder phase A input. The filter value for the phase A input is defined by the CH(n)FVAL field of FTMFILTER. The phase A filter is also disabled when CH(n)FVAL is zero.  O Phase A input filter is disabled.     |
|                | 1 Phase A input filter is enabled.                                                                                                                                                                                                                                                    |
| 6<br>PHBFLTREN | Phase B Input Filter Enable  Enables the filter for the quadrature decoder phase B input. The filter value for the phase B input is defined by the CH(n+1)FVAL field of FTMFILTER. The phase B filter is also disabled when CH(n+1)FVAL is zero.  O Phase B input filter is disabled. |
|                | 1 Phase B input filter is enabled.                                                                                                                                                                                                                                                    |
| 5<br>PHAPOL    | Phase A Input Polarity                                                                                                                                                                                                                                                                |
|                | Selects the polarity for the quadrature decoder phase A input.                                                                                                                                                                                                                        |
|                | 0 Normal polarity. Phase A input signal is not inverted in FTM.                                                                                                                                                                                                                       |
|                | 1 Inverted polarity. Phase A input signal is inverted in FTM.                                                                                                                                                                                                                         |

Table continues on the next page...

## FTMx\_QDCTRL field descriptions (continued)

| Field         | Description                                                                                                                                                                                                                                                                     |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4<br>PHBPOL   | Phase B Input Polarity                                                                                                                                                                                                                                                          |
|               | Selects the polarity for the quadrature decoder phase B input.                                                                                                                                                                                                                  |
|               | 0 Normal polarity. Phase B input signal is not inverted in FTM.                                                                                                                                                                                                                 |
|               | 1 Inverted polarity. Phase B input signal is inverted in FTM.                                                                                                                                                                                                                   |
| 3<br>QUADMODE | Quadrature Decoder Mode                                                                                                                                                                                                                                                         |
| QONDINOBE     | Selects the encoding mode used in the quadrature decoder mode.                                                                                                                                                                                                                  |
|               | 0 Phase A and phase B encoding mode.                                                                                                                                                                                                                                            |
|               | 1 Count and direction encoding mode.                                                                                                                                                                                                                                            |
| 2<br>QUADIR   | FTM Counter Direction in Quadrature Decoder Mode                                                                                                                                                                                                                                |
|               | Indicates the counting direction and it is updated according to selected encoding mode.                                                                                                                                                                                         |
|               | 0 Counting direction is decreasing. FTM counter decrement.                                                                                                                                                                                                                      |
|               | 1 Counting direction is increasing. FTM counter increment.                                                                                                                                                                                                                      |
| 1<br>TOFDIR   | Timer Overflow Direction in Quadrature Decoder Mode                                                                                                                                                                                                                             |
|               | Indicates if the TOF bit was set on the top or the bottom of counting.                                                                                                                                                                                                          |
|               | TOF bit was set on the bottom of counting. There was an FTM counter decrement and FTM counter changes from its minimum value to its maximum value.                                                                                                                              |
|               | TOF bit was set on the top of counting. There was an FTM counter increment and FTM counter changes from its maximum value to its minimum value.                                                                                                                                 |
| 0             | Quadrature Decoder Mode Enable                                                                                                                                                                                                                                                  |
| QUADEN        | Enables the quadrature decoder mode. In this mode, the phase A and B input signals control the FTM counter direction. The quadrature decoder mode has precedence over the other modes. (See the table Mode, Edge, and Level Selection in the description of the CnSC register.) |
|               | This field is write protected. It can be written only when MODE[WPDIS] = 1.                                                                                                                                                                                                     |
|               | <ul><li>Quadrature decoder mode is disabled.</li><li>Quadrature decoder mode is enabled.</li></ul>                                                                                                                                                                              |

# 37.4 Functional Description

The following sections describe the FTM features.

The notation used in this document to represent the counters and the generation of the signals is shown in the following figure.

Channel (n) - high-true EPWM PS[2:0] = 001 CNTINH:L = 0x0000 MODH:L = 0x0004 CnVH:L = 0x0002



Figure 37-143. Notation Used

### 37.4.1 Clock Source

FTM module has only one clock domain that is the system clock.

### 37.4.1.1 Counter Clock Source

The CLKS[1:0] bits in the SC register select one of three possible clock sources for the FTM counter or disable the FTM counter. After any MCU reset, CLKS[1:0] = 0:0 so no clock source is selected.

The CLKS[1:0] bits may be read or written at any time. Disabling the FTM counter by writing 0:0 to the CLKS[1:0] bits does not affect the FTM counter value or other registers.

The fixed frequency clock is an alternative clock source for the FTM counter that allows the selection of a clock other than the system clock or an external clock. This clock input is defined by chip integration. Refer the chip specific documentation for further information. Due to FTM hardware implementation limitations, the frequency of the fixed frequency clock must not exceed the system clock frequency.

838

The external clock passes through a synchronizer clocked by the system clock to assure that counter transitions are properly aligned to system clock transitions. Therefore, to meet Nyquist criteria considering also jitter, the frequency of the external clock source must not exceed 1/4 of the system clock frequency.

### 37.4.2 Prescaler

The selected counter clock source passes through a prescaler that is a 7-bit counter. The value of the prescaler is selected by the PS[2:0] bits. The following figure shows an example of the prescaler counter and FTM counter.



Figure 37-144. Example of the Prescaler Counter

## **37.4.3** Counter

The FTM has a 16-bit counter that is used by the channels either for input or output modes. The FTM counter clock is the selected clock divided by the prescaler (Prescaler).

The FTM counter has these modes of operation:

- up counting (see Up Counting)
- up-down counting (see Up-Down Counting)
- quadrature mode, if it is supported (see Quadrature Decoder Mode)

## **37.4.3.1 Up Counting**

Up counting is selected when (CPWMS = 0) and, if the quadrature decoder feature is supported, when (QUADEN = 0).

CNTINH:L defines the starting value of the count and MODH:L defines the final value of the count (see the following figure). The value of CNTINH:L is loaded into the FTM counter, and the counter increments until the value of MODH:L is reached, at which point the counter is reloaded with the contents of CNTINH:L.

The FTM period when using up counting is (MODH:L – CNTINH:L + 0x0001) × period of the FTM counter clock.

The TOF bit is set when the FTM counter changes from MODH:L to CNTINH:L.

FTM counting is up CNTINH:L = 0xFFFC (in two's complement is equal to -4) MODH:L = 0x0004



Figure 37-145. Example of FTM Up and Signed Counting

If (CNTINH:L = 0x0000), the FTM counting is equivalent to TPM up counting (that is, up and unsigned counting) (see the following figure). If (CNTINH[7] = 1), then the initial value of the FTM counter is a negative number in two's complement, so the FTM counting is up and signed. Conversely if (CNTINH[7] = 0 and CNTINH:L  $\neq$  0x0000), then the initial value of the FTM counter is a positive number, so the FTM counting is up and unsigned.

FTM counting is up CNTINH:L = 0x0000 MODH:L = 0x0004



Figure 37-146. Example of FTM Up Counting with CNTIN = 0x0000

### **Note**

- FTM operation is only valid when the value of the CNTINH:L registers is less than the value of the MODH:L registers (either in the unsigned counting or signed counting). It is the responsibility of the software to ensure that the values in the CNTINH:L and MODH:L registers meet this requirement. Any values of CNTINH:L and MODH:L that do not satisfy this criteria can result in unpredictable behavior.
- MODH:L = CNTINH:L is a redundant condition. In this
  case, the FTM counter is always equal to MODH:L and the
  TOF bit is set in each rising edge of the FTM counter
  clock.
- When MODH:L = 0x0000, CNTINH:L = 0x0000 (for example after reset), and FTMEN = 1, the FTM counter remains stopped at 0x0000 until a non-zero value is written into the MODH:L or CNTINH:L registers.
- Setting CNTINH:L to be greater than the value of MODH:L is not recommended as this unusual setting may make the FTM operation difficult to comprehend. However, there is no restriction on this configuration, and an example is shown in the following figure.

FTM counting is up MODH:L = 0x0005 CNTINH:L = 0x0015



Figure 37-147. Example of Up Counting When the Value of CNTIN Registers Is Greater Than the Value of MOD Registers

## 37.4.3.2 Up-Down Counting

Up-down counting is selected when (CPWMS = 1) and, if the quadrature decoder feature is supported, when (QUADEN = 0).

CNTINH:L defines the starting value of the count and MODH:L defines the final value of the count. The value of CNTINH:L is loaded into the FTM counter, and the counter increments until the value of MODH:L is reached, at which point the counter is decremented until it returns to the value of CNTINH:L and the up-down counting restarts.

The FTM period when using up-down counting is  $2 \times (MODH:L - CNTINH:L) \times period of the FTM counter clock.$ 

The TOF bit is set when the FTM counter changes from MODH:L to (MODH:L-1).

If (CNTINH:L = 0x0000), the FTM counting is equivalent to TPM up-down counting (that is, up-down and unsigned counting) (see the following figure).

#### FTM counting is up-down



Figure 37-148. Example of Up-Down Counting When CNTIN = 0x0000

### **Note**

- The up-down counting is only available when (CNTINH:L = 0x0000).
- The configuration with (CNTINH:L ≠ 0x0000) when (CPWMS = 1) is not recommended and its results are not guaranteed.

## 37.4.3.3 Free Running Counter

If (FTMEN = 0) and (MODH:L = 0x0000 or MODH:L = 0xFFFF), the FTM counter is a free running counter. In this case, the FTM counter runs free from 0x0000 through 0xFFFF and the TOF bit is set when the FTM counter changes from 0xFFFF to 0x0000 (see the following figure).



Figure 37-149. Example When the FTM Counter Is a Free Running

The FTM counter is a free running counter when all of the following apply:

• (FTMEN = 1)

- (CPWMS = 0)
- (CNTINH:L = 0x0000)
- (MODH:L = 0xFFFF)
- (QUADEN = 0) if the quadrature decoder feature is supported

In this case, the FTM counter runs free from 0x0000 through 0xFFFF and the TOF bit is set when the FTM counter changes from 0xFFFF to 0x0000.

### 37.4.3.4 Counter Reset

Any write to CNTH or CNTL register resets the FTM counter to the value in the CNTINH:CNTINL registers and the channels output to its initial value (except for channels in output compare mode).

The FTM counter synchronization (see "FTM Counter Synchronization") can also be used to force the value of CNTINH:CNTINL into the FTM counter and the channels output to its initial value (except for channels in output compare mode).

## 37.4.4 Input Capture Mode

The input capture mode is selected when (DECAPEN = 0), (COMBINE = 0), (CPWMS = 0), (MSnB:MSnA = 0:0), and (ELSnB:ELSnA  $\neq$  0:0).

When a selected edge occurs on the channel input, the current value of the FTM counter is captured into the CnVH:L registers, at the same time the CHnF bit is set and the channel interrupt is generated if enabled by CHnIE = 1 (see the following figure).

When a channel is configured for input capture, the CHn pin is an edge-sensitive input. ELSnB:ELSnA control bits determine which edge, falling or rising, triggers input-capture event. Note that the maximum frequency for the channel input signal to be detected correctly is system clock divided by 4, which is required to meet Nyquist criteria for signal sampling.

When either half of the 16-bit capture register (CnVH:L) is read, the other half is latched into a buffer to support coherent 16-bit access in big-endian or little-endian order. This read coherency mechanism can be manually reset by writing to CnSC register.

Writes to the CnVH:L registers are ignored in input capture mode.

While in BDM, the input capture function works as configured. When a selected edge event occurs, the FTM counter value (which is frozen because of BDM) is captured into the CnVH:L registers and the CHnF bit is set.

Downloaded from **Elcodis.com** electronic components distributor



Figure 37-150. Input Capture Mode

If the channel input does not have a filter enabled, then the input signal is always delayed 3 rising edges of the system clock (two rising edges to the synchronizer plus one more rising edge to the edge detector). In other words, the CHnF bit is set on the third rising edge of the system clock after a valid edge occurs on the channel input.

### **Note**

- Input capture mode is only available with (CNTINH:L = 0x0000).
- Input capture mode with (CNTINH:L ≠ 0x0000) is not recommended and its results are not guaranteed.

## 37.4.4.1 Filter for Input Capture Mode

The filter function is only available on channels 0, 1, 2, and 3.

Firstly the input signal is synchronized by the system clock. Following synchronization, the input signal enters the filter block (see the following figure). When there is a state change in the input signal, the 5-bit counter is reset and starts counting up. As long as the new state is stable on the input, the counter continues to increment. If the 5-bit counter overflows (the counter exceeds the value of the CHnFVAL[3:0] bits), the state change of the input signal is validated. It is then transmitted as a pulse edge to the edge detector.



Figure 37-151. Channel Input Filter

If the opposite edge appears on the input signal before validation (counter overflow), the counter is reset. At the next input transition, the counter starts counting again. Any pulse that is shorter than the minimum value selected by CHnFVAL[3:0] bits (× 4 system clocks) is regarded as a glitch and is not passed on to the edge detector. A timing diagram of the input filter is shown in the following figure.

The filter function is disabled when CHnFVAL[3:0] bits are zero. In this case, the input signal is delayed 3 rising edges of the system clock. If (CHnFVAL[3:0]  $\neq$  0000), then the input signal is delayed by the minimum pulse width (CHnFVAL[3:0]  $\times$  4 system clocks) plus a further 4 rising edges of the system clock (two rising edges to the synchronizer, one rising edge to the filter output plus one more to the edge detector). In other words, CHnF is set (4 + 4  $\times$  CHnFVAL[3:0]) system clock periods after a valid edge occurs on the channel input.

The clock for the 5-bit counter in the channel input filter is the system clock divided by 4.



Figure 37-152. Channel Input Filter Example

## 37.4.5 Output Compare Mode

The output compare mode is selected when (DECAPEN = 0), (COMBINE = 0), (CPWMS = 0), and (MSnB:MSnA = 0:1).

In output compare mode, the FTM can generate timed pulses with programmable position, polarity, duration, and frequency. When the counter matches the value in the CnVH:CnVL registers of an output compare channel, the channel (n) output can be set, cleared, or toggled.

When a channel is initially configured to toggle mode, the previous value of the channel output is held until the first output compare event occurs.

The CHnF bit is set and the channel (n) interrupt is generated (if CHnIE = 1) at the channel (n) match (FTM counter = CnVH:CnVL).



Figure 37-153. Example of the Output Compare Mode when the Match Toggles the Channel Output



Figure 37-154. Example of the Output Compare Mode when the Match Clears the Channel Output



Figure 37-155. Example of the Output Compare Mode when the Match Sets the Channel Output

It is possible to use the output compare mode with (ELSnB:ELSnA = 0:0). In this case, when the counter reaches the value in the CnVH:CnVL registers, the CHnF bit is set and the channel (n) interrupt is generated (if CHnIE = 1), however the channel (n) output is not modified and controlled by FTM.

### **Note**

- Output compare mode is only available with (CNTINH:CNTINL = 0x0000).
- Output compare mode with (CNTINH:CNTINL ≠ 0x0000) is not recommended and its results are not guaranteed.

## 37.4.6 Edge-Aligned PWM (EPWM) Mode

The edge-aligned mode is selected when all of the following apply:

- (DECAPEN = 0)
- (COMBINE = 0)
- (CPWMS = 0)
- (MSnB = 1)
- (QUADEN = 0) if the quadrature decoder feature is supported

The EPWM period is determined by (MODH:L – CNTINH:L + 0x0001) and the pulse width (duty cycle) is determined by (CnVH:L – CNTINH:L).

The CHnF bit is set and the channel (n) interrupt is generated (if CHnIE = 1) at the channel (n) match (FTM counter = CnVH:L), that is, at the end of the pulse width.

This type of PWM signal is called edge-aligned because the leading edges of all PWM signals are aligned with the beginning of the period, which is the same for all channels within an FTM.



Figure 37-156. EPWM Period and Pulse Width with ELSnB:ELSnA = 1:0

If (ELSnB:ELSnA = 0:0) when the counter reaches the value in the CnVH:L registers, the CHnF bit is set and the channel (n) interrupt is generated (if CHnIE = 1), however the channel (n) output is not controlled by FTM.

848

If (ELSnB:ELSnA = 1:0), then the channel (n) output is forced high at the counter overflow (when the CNTINH:L register contents are loaded into the FTM counter), and it is forced low at the channel (n) match (when the FTM counter = CnVH:L) (see the following figure).



Figure 37-157. EPWM Signal with ELSnB:ELSnA = 1:0

If (ELSnB:ELSnA = X:1), then the channel (n) output is forced low at the counter overflow (when the CNTINH:L register contents are loaded into the FTM counter), and it is forced high at the channel (n) match (when the FTM counter = CnVH:L) (see the following figure).



Figure 37-158. EPWM Signal with ELSnB:ELSnA = X:1

If (CnVH:L = 0x0000), then the channel (n) output is a 0% duty cycle EPWM signal and CHnF bit is not set even when there is the channel (n) match. If (CnVH:L > MODH:L), then the channel (n) output is a 100% duty cycle EPWM signal and CHnF bit is not set even when there is the channel (n) match. Therefore, MODH:MODL must be less than 0xFFFF in order to get a 100% duty cycle EPWM signal.

#### Note

- EPWM mode is only available with (CNTINH:L = 0x0000).
- EPWM mode with (CNTINH:CNTINL ≠ 0x0000) is not recommended and its results are not guaranteed.

## 37.4.7 Center-Aligned PWM (CPWM) Mode

The center-aligned mode is selected when all of the following apply:

- (QUADEN = 0) if the quadrature decoder feature is supported
- (DECAPEN = 0)
- (COMBINE = 0)
- (CPWMS = 1)

The CPWM pulse width (duty cycle) is determined by  $2 \times (CnVH:L - CNTINH:L)$  and the period is determined by  $2 \times (MODH:L - CNTINH:L)$  (see the following figure). MODH:L must be kept in the range of 0x0001 to 0x7FFF because values outside this range can produce ambiguous results.

In the CPWM mode, the FTM counter counts up until it reaches MODH:L and then counts down until it reaches CNTINH:L.

The CHnF bit is set and channel (n) interrupt is generated (if CHnIE = 1) at the channel (n) match (FTM counter = CnVH:L) when the FTM counting is down (at the begin of the pulse width) and when the FTM counting is up (at the end of the pulse width).

This type of PWM signal is called center-aligned because the pulse width centers for all channels are aligned with the value of CNTINH:L.

The other channel modes are not compatible with the up-down counter (CPWMS = 1). Therefore, all FTM channels must be used in CPWM mode when (CPWMS = 1).



Figure 37-159. CPWM Period and Pulse Width with ELSnB:ELSnA = 1:0

If (ELSnB:ELSnA = 0:0) when the counter reaches the value in the CnVH:L registers, the CHnF bit is set and the channel (n) interrupt is generated (if CHnIE = 1), however the channel (n) output is not controlled by FTM.

If (ELSnB:ELSnA = 1:0), then the channel (n) output is forced high at the channel (n) match (FTM counter = CnVH:L) when counting down, and it is forced low at the channel (n) match when counting up (see the following figure).



Figure 37-160. CPWM Signal with ELSnB:ELSnA = 1:0

If (ELSnB:ELSnA = X:1), then the channel (n) output is forced low at the channel (n) match (FTM counter = CnVH:L) when counting down, and it is forced high at the channel (n) match when counting up (see the following figure).



Figure 37-161. CPWM Signal with ELSnB:ELSnA = X:1

If (CnVH:L = 0x0000) or (CnVH:L) is a negative value, that is, CnVH[7] = 1) then the channel (n) output is a 0% duty cycle CPWM signal and CHnF bit is not set even when there is the channel (n) match.

If (CnVH:L is a positive value, that is, CnVH[7] = 0), (CnVH:L  $\geq$  MODH:L), and (MODH:L  $\neq$  0x0000), then the channel (n) output is a 100% duty cycle CPWM signal and CHnF bit is not set even when there is the channel (n) match. This implies that the usable range of periods set by MODH:L is 0x0001 through 0x7FFE (0x7FFF if you do not need to generate a 100% duty cycle CPWM signal). This is not a significant limitation because the resulting period is much longer than required for normal applications.

The CPWM mode must not be used when the FTM counter is a free running counter.

### **Note**

- CPWM mode is only available with (CNTINH:L = 0x0000).
- CPWM mode with (CNTINH:L ≠ 0x0000) is not recommended and its results are not guaranteed.

### 37.4.8 Combine Mode

The combine mode is selected when all of the following apply:

- (FTMEN = 1)
- (QUADEN = 0) if the quadrature decoder feature is supported
- (DECAPEN = 0)
- (COMBINE = 1)
- (CPWMS = 0)

In combine mode, the channel (n) (an even channel) and channel (n+1) (the adjacent odd channel) are combined to generate a PWM signal in the channel (n) output.

In the combine mode, the PWM period is determined by (MODH:L – CNTINH:L + 0x0001) and the PWM pulse width (duty cycle) is determined by (IC(n+1)VH:L - C(n)VH:LI).

The CHnF bit is set and the channel (n) interrupt is generated (if CHnIE = 1) at the channel (n) match (FTM counter = C(n)VH:L). The CH(n+1)F bit is set and the channel (n+1) interrupt is generated (if CH(n+1)IE = 1) at the channel (n+1) match (FTM counter = C(n+1)VH:C(n+1)VL).

If (ELSnB:ELSnA = 1:0), then the channel (n) output is forced low at the beginning of the period (FTM counter = CNTINH:L) and at the channel (n+1) match (FTM counter = C(n+1)VH:L). It is forced high at the channel (n) match (FTM counter = C(n)VH:L) (see the following figure).

If (ELSnB:ELSnA = X:1), then the channel (n) output is forced high at the beginning of the period (FTM counter = CNTINH:L) and at the channel (n+1) match (FTM counter = C(n+1)VH:L). It is forced low at the channel (n) match (FTM counter = C(n)VH:L) (see the following figure).

In combine mode, the ELS(n+1)B and ELS(n+1)A bits are not used in the generation of the channels (n) and (n+1) output.



Figure 37-162. Combine Mode

The following figures illustrate the generation of PWM signals using combine mode.



Figure 37-163. Channel (n) Output If (CNTIN < C(n)V < MOD) and (CNTIN < C(n+1)V < MOD) and (C(n)V < C(n+1)V)



Figure 37-164. Channel (n) Output If (CNTIN < C(n)V < MOD) and (C(n+1)V = MOD)



Figure 37-165. Channel (n) Output If (C(n)V = CNTIN) and (CNTIN < C(n+1)V < MOD)



Figure 37-166. Channel (n) Output If (CNTIN < C(n)V < MOD) and (C(n)V is Almost Equal to CNTIN) and (C(n+1)V = MOD)



Figure 37-167. Channel (n) Output If (C(n)V = CNTIN) and (CNTIN < C(n+1)V < MOD) and (C(n+1)V) is Almost Equal to MOD)



Figure 37-168. Channel (n) Output If C(n)V and C(n+1)V Are Not Between CNTIN and MOD



Figure 37-169. Channel (n) Output If (CNTIN < C(n)V < MOD) and (CNTIN < C(n+1)V < MOD) and (CnV = C(n+1)V)



Figure 37-170. Channel (n) Output If (C(n)V = C(n+1)V = CNTIN)



Figure 37-171. Channel (n) Output If (C(n)V = C(n+1)V = MOD)



Figure 37-172. Channel (n) Output If (CNTIN < C(n)V < MOD) and (CNTIN < C(n+1)V < MOD) and (C(n)V > C(n+1)V)



Figure 37-173. Channel (n) Output If (C(n)V < CNTIN) and (CNTIN < C(n+1)V < MOD)



Figure 37-174. Channel (n) Output If (C(n+1)V < CNTIN) and (CNTIN < C(n)V < MOD)



Figure 37-175. Channel (n) Output If (C(n)V > MOD) and (CNTIN < C(n+1)V < MOD)



Figure 37-176. Channel (n) Output If (C(n+1)V > MOD) and (CNTIN < C(n)V < MOD)



Figure 37-177. Channel (n) Output If (C(n+1)V > MOD) and (CNTIN < C(n)V = MOD)

## 37.4.8.1 Asymmetrical PWM

In the combine mode, the control of the PWM signal first edge (when the channel (n) match occurs, that is, FTM counter = C(n)VH:L) is independent of the control of the PWM signal second edge (when the channel (n+1) match occurs, that is, FTM counter = C(n+1)VH:L). So, the combine mode allows to generate asymmetrical PWM signals.

## 37.4.9 Complementary Mode

The complementary mode is selected when all of the following apply:

- (FTMEN = 1)
- (QUADEN = 0) if the quadrature decoder feature is supported
- (DECAPEN = 0)
- (COMBINE = 1)
- (CPWMS = 0)
- (COMP = 1)

In complementary mode the channel (n+1) output is the inverse of the channel (n) output.

The channel (n+1) output is the same as the channel (n) output if all of the following apply:

- (FTMEN = 1)
- (QUADEN = 0) if the quadrature decoder feature is supported
- (DECAPEN = 0)
- (COMBINE = 1)

- (CPWMS = 0)
- (COMP = 0)



Figure 37-178. Channel (n+1) Output in Complementary Mode with (ELSnB:ELSnA = 1:0)



Figure 37-179. Channel (n+1) Output in Complementary Mode with (ELSnB:ELSnA = X:1)

## 37.4.10 Update of the Registers With Write Buffers

This section describes the updating of registers that have write buffers.

## 37.4.10.1 CNTINH:L Registers

CNTINH:L registers are always updated with their write buffer after both bytes have been written.

## 37.4.10.2 MODH:L Registers

If (CLKS[1:0] = 0:0), then MODH:L registers are updated when their second byte is written (independent of FTMEN bit).

If  $(CLKS[1:0] \neq 0:0$  and FTMEN = 0), then MODH:L registers are updated according to the CPWMS bit, that is:

- If the selected mode is not CPWM mode, then MODH:L registers are updated after both bytes have been written and the FTM counter changes from (MODH:L) to (CNTINH:L). If the FTM counter is a free-running counter, then this update is made when the FTM counter changes from 0xFFFF to 0x0000.
- If the selected mode is CPWM mode, then MODH:L registers are updated after both bytes have been written and the FTM counter changes from MODH:L to (MODH:L - 0x0001).

If  $(CLKS[1:0] \neq 0:0$  and FTMEN = 1), then MODH:L registers are updated by PWM synchronization (see "MODH:L Registers Synchronization").

## 37.4.10.3 CnVH:L Registers

If (CLKS[1:0] = 0:0), then CnVH:L registers are updated when their second byte is written (independent of FTMEN bit).

If  $(CLKS[1:0] \neq 0:0$  and FTMEN = 0), then CnVH:L registers are updated according to the selected mode, that is:

- If the selected mode is output compare mode, then CnVH:L registers are updated after their second byte is written and on the next change of the FTM counter (end of the prescaler counting).
- If the selected mode is EPWM mode, the CnVH:L registers are updated after both bytes have been written and the FTM counter changes from MODH:L to CNTINH:L. If the FTM counter is a free running counter, then this update is made when the FTM counter changes from 0xFFFF to 0x0000.
- If the selected mode is CPWM mode, then CnVH:L registers are updated after both bytes have been written and the FTM counter changes from MODH:L to (MODH:L - 0x0001).

If  $(CLKS[1:0] \neq 0:0$  and FTMEN = 1), then CnVH:L registers are updated according to the selected mode, that is:

- If the selected mode is output compare mode, then CnVH:L registers are updated according to the SYNCEN bit. If (SYNCEN = 0), then CnVH:L registers are updated after their second byte is written and on the next change of the FTM counter (end of the prescaler counting). If (SYNCEN = 1), then CnVH:L registers are updated by PWM synchronization (see "CnVH:L Registers Synchronization").
- If the selected mode is not output compare mode and (SYNCEN = 1), then CnVH:L registers are updated by PWM synchronization (see "CnVH:L Registers Synchronization").

## 37.4.11 PWM Synchronization

PWM synchronization provides an opportunity to update registers with the contents of their write buffers. It can also be used to synchronize two or more FlexTimer modules on the same MCU.

PWM synchronization updates the MODH:L and CnVH:L registers with their write buffers. It is also possible to force the FTM counter to its initial value and update the CHnOM bits in OUTMASK using PWM synchronization.

### **Note**

• PWM synchronization is only available in combine mode.

## 37.4.11.1 Hardware Trigger

Each hardware trigger (input signals: trigger\_0, trigger\_1, and trigger\_2) is synchronized by the system clock.

A rising edge on the selected hardware trigger input (trigger n event) initiates PWM synchronization. A hardware trigger is selected when its enable bit is set (TRIGn = 1 where n = 0, 1, or 2). The TRIGn bit is cleared when 0 is written to it or when the trigger n event is detected.

If two or more hardware triggers are enabled (TRIG0 and TRIG1 = 1) and only the trigger 1 event occurs, then only the TRIG1 bit is cleared.

If a trigger n event occurs together with a write to set the TRIGn bit, then the synchronization is made, but the TRIGn bit remains set because of the last write.



#### Notes

- All hardware trigger (input signals: trigger\_0, trigger\_1, and trigger\_2) have this same behavior

Figure 37-180. Hardware Trigger Event

## 37.4.11.2 Software Trigger

A software trigger event occurs when 1 is written to the SWSYNC bit. The SWSYNC bit is cleared when 0 is written to it or when the PWM synchronization (initiated by the software event) is completed.

If the software trigger event occurs together with the event that clears the SWSYNC bit, then the synchronization is made using this trigger event and the SWSYNC bit remains set because of the last write.

For example, if PWMSYNC = 0 and REINIT = 0 and there is a software trigger event, then the load of MODH:L and CnVH:L registers is only made at the boundary cycle (CNTMIN and CNTMAX). In this case, the SWSYNC bit is cleared only at the boundary cycle, so you do not know when this bit is cleared. Therefore, it is possible a new write to set SWSYNC happens when FTM is clearing the SWSYNC because it is the selected boundary cycle of PWM synchronization that was started previously by the software trigger event.



Figure 37-181. Software Trigger Event

## 37.4.11.3 Boundary Cycle

The CNTMAX and CNTMIN bits select the boundary cycle when the MODH:L and CnVH:L registers are updated with the value of their write buffer by PWM synchronization, except if (PWMSYNC = 0 and REINIT = 1).

If CNTMIN = 1, then the boundary cycle is the CNTINH:L value. MODH:L and CnVH:L registers are updated when the FTM counter reaches the CNTINH:L value. If CPWMS = 0, then CNTINH:L is reached when the FTM counter changes from MODH:L to CNTINH:L. If CPWMS = 1, then CNTINH:L is reached when the FTM counter changes from (CNTINH:L + 0x0001) to CNTINH:L.

If CNTMAX = 1, then the boundary cycle is the MODH:L value. MODH:L and CnVH:L registers are updated when the FTM counter reaches the MODH:L value. MODH:L is reached when the FTM counter changes from (MODH:L - 0x0001) to MODH:L, regardless of the CPWMS configuration.

If no boundary cycle was selected (that is, CNTMAX = 0 and CNTMIN = 0), then the update of the MODH:L and CnVH:L registers is not made, except if (PWMSYNC = 0) and REINIT = 1).

If both boundary cycles were selected (that is, CNTMAX = 1 and CNTMIN = 1), then the update of the MODH:L and CnVH:L registers is made in the first boundary cycle that occurs with valid conditions for MODH:L or CnVH:L synchronization, except if (PWMSYNC = 0 and REINIT = 1).

The CNTMAX and CNTMIN bits are cleared only by software.

### **Note**

- PWM synchronization boundary cycle is only available when (CNTMIN = 1).
- PWM synchronization with (CNTMAX = 1) is not recommended and its results are not guaranteed.

# 37.4.11.4 MODH:L Registers Synchronization

The MODH:L synchronization occurs when the MODH:L registers are updated with the value of their write buffer.

The synchronization requires both bytes of MODH:L to have been written in one of the following situations.

• If PWMSYNC = 0 and REINIT = 0, then the synchronization is made on the next selected boundary cycle after an enabled trigger event takes place. If the trigger event was a software trigger, then the SWSYNC bit is cleared on the next selected boundary cycle (refer to the following figure).



Figure 37-182. MODH:L Synchronization when (PWMSYNC = 0), (REINIT = 0), and (Software Trigger Was Used)

If the trigger event was a hardware trigger, then the trigger enable bit (TRIGn) is cleared when the trigger n event is detected (refer to the following figure).



Figure 37-183. MODH:L Synchronization when (PWMSYNC = 0), (REINIT = 0), and (a Hardware Trigger Was Used)

• If PWMSYNC = 0 and REINIT = 1, then the synchronization is made on the next enabled trigger event. If the trigger event was a software trigger, then the SWSYNC bit is cleared (refer to the following figure).



Figure 37-184. MODH:L Synchronization when (PWMSYNC = 0), (REINIT = 1), and (Software Trigger Was Used)

If the trigger event was a hardware trigger, then the TRIGn bit is cleared (refer to the following figure).

866



Figure 37-185. MODH:L Synchronization when (PWMSYNC = 0), (REINIT = 1), and (a Hardware Trigger Was Used)

• If PWMSYNC = 1, then the synchronization is made on the next selected boundary cycle after the enabled software trigger event takes place. The SWSYNC bit is cleared on the next selected boundary cycle (refer to the following figure).



Figure 37-186. MODH:L Synchronization when (PWMSYNC = 1)

## 37.4.11.5 CnVH:L Registers Synchronization

The CnVH:L synchronization occurs when the CnVH:L registers are updated with the value of their write buffer.

The synchronization requires both bytes of CnVH:L to have been written, SYNCEN = 1 and either a hardware or software trigger event as per MODH:L synchronization (MODH:L Registers Synchronization).

# 37.4.11.6 OUTMASK Register Synchronization

Any write to a CHnOM bit updates the OUTMASK write buffer. The CHnOM bit is updated with the value of its corresponding bit in the OUTMASK write buffer according to SYNCHOM and PWMSYNC bits.

• If SYNCHOM = 0, then the CHnOM bit is updated with the value of its write buffer equivalent in all rising edges of the system clock.



Figure 37-187. CHnOM Synchronization when (SYNCHOM = 0)

• If SYNCHOM = 1 and PWMSYNC = 0, then this synchronization is made on the next enabled trigger event. If the trigger event was a software trigger, then the SWSYNC bit is cleared on the next selected boundary cycle (refer to the following figure).



Figure 37-188. CHnOM Synchronization when (SYNCHOM = 1), (PWMSYNC = 0) and (Software Trigger Was Used)

If the trigger event was a hardware trigger, then the trigger enable bit (TRIGn) is cleared when the trigger n event is detected (refer to the following figure).



Figure 37-189. CHnOM Synchronization when (SYNCHOM = 1), (PWMSYNC = 0), and (a Hardware Trigger Was Used)

• If SYNCHOM = 1 and PWMSYNC = 1, then this synchronization is made on the next enabled hardware trigger event. The trigger enable bit (TRIGn) is cleared when the enabled hardware trigger n event is detected (refer to the following figure).



Figure 37-190. CHnOM Synchronization when (SYNCHOM = 1), (PWMSYNC = 1), and (a Hardware Trigger Was Used)

# 37.4.11.7 FTM Counter Synchronization

The FTM counter synchronization occurs when the FTM counter is updated with the value of the CNTINH:L registers and the channel outputs are forced to their initial value as defined by the channel configuration.

- If REINIT = 0, then this synchronization is made when the FTM counter changes from MODH:L to CNTINH:L.
- If REINIT = 1 and PWMSYNC = 0, then this synchronization is made on the next enabled trigger event. If the trigger event was a software trigger, then the SWSYNC bit is cleared (refer to the following figure).



Figure 37-191. FTM Counter Synchronization when (REINIT = 1), (PWMSYNC = 0), and (Software Trigger Was Used)

If the trigger event was a hardware trigger, then the TRIGn bit is cleared (refer to the following figure).



Figure 37-192. FTM Counter Synchronization when (REINIT = 1), (PWMSYNC = 0), and (a Hardware Trigger Was Used)

• If REINIT = 1 and PWMSYNC = 1, then this synchronization is made on the next enabled hardware trigger event. The trigger enable bit (TRIGn) is cleared when the enabled hardware trigger n event is detected (refer to the following figure).



Figure 37-193. FTM Counter Synchronization when (REINIT = 1), (PWMSYNC = 1), and (a Hardware Trigger Was Used)

# 37.4.11.8 Summary of PWM Synchronization

The following table shows the summary of PWM synchronization.

Table 37-188. Summary of PWM Synchronization

| Register or bit | PWMSYN<br>C | REINIT | SYNCH<br>OM | CNTMA<br>X | CNTMI<br>N | SYNCE<br>N | Description                                                                                                                                                   |
|-----------------|-------------|--------|-------------|------------|------------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CNTINH:L        | Х           | Х      | Х           | Х          | Χ          | Х          | Changes take effect after the second byte is written.                                                                                                         |
|                 |             |        |             |            |            |            | Effect is seen after the next TOF or PWM synchronization.                                                                                                     |
| MODH:L          | 0           | 0      | Х           | 1          | 0          | Х          | MODH:L are updated with their write buffer contents when the counter reaches its maximum value after the enabled (hardware or software) trigger has occurred. |
|                 | 0           | 0      | Х           | 0          | 1          | Х          | MODH:L are updated with their write buffer contents when the counter reaches its minimum value after the enabled (hardware or software) trigger has occurred. |
|                 | 0           | 1      | Х           | Х          | Х          | Х          | MODH:L are updated with their write buffer contents when the enabled (hardware or software) trigger occurs.                                                   |
|                 | 1           | Х      | Х           | 1          | 0          | Х          | MODH:L are updated with their write buffer contents when the counter reaches its maximum value after the enabled software trigger has occurred.               |
|                 | 1           | Х      | Х           | 0          | 1          | Х          | MODH:L are updated with their write buffer contents when the counter reaches its minimum value after the enabled software trigger has occurred.               |

Table continues on the next page...

Table 37-188. Summary of PWM Synchronization (continued)

| Register or bit | PWMSYN<br>C | REINIT | SYNCH<br>OM | CNTMA<br>X | CNTMI<br>N | SYNCE<br>N | Description                                                                                                                                                               |
|-----------------|-------------|--------|-------------|------------|------------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CnVH:L          | 0           | 0      | Х           | 1          | 0          | 1          | CnVH:L are updated with their write<br>buffer contents when the counter<br>reaches its maximum value after the<br>enabled (hardware or software)<br>trigger has occurred. |
|                 | 0           | 0      | X           | 0          | 1          | 1          | CnVH:L are updated with their write<br>buffer contents when the counter<br>reaches its minimum value after the<br>enabled (hardware or software)<br>trigger has occurred. |
|                 | 0           | 1      | Х           | Х          | Х          | 1          | CnVH:L are updated with their write buffer contents when the enabled (hardware or software) trigger occurs.                                                               |
|                 | 1           | X      | Х           | 1          | 0          | 1          | CnVH:L are updated with their write<br>buffer contents when the counter<br>reaches its maximum value after the<br>enabled software trigger has<br>occurred.               |
|                 | 1           | X      | Х           | 0          | 1          | 1          | CnVH:L are updated with their write<br>buffer contents when the counter<br>reaches its minimum value after the<br>enabled software trigger has<br>occurred.               |
| CNTH:L          | 0           | 1      | Х           | Х          | Х          | Х          | CNTH:L are forced to the FTM counter initial value when the enabled (hardware or software) trigger occurs.                                                                |
|                 | 1           | 1      | х           | Х          | Х          | Х          | CNTH:L are forced to the FTM counter initial value when the enabled hardware trigger occurs.                                                                              |
| OUTMASK         | Х           | Х      | 0           | Х          | Х          | Х          | Changes to OUTMASK take effect on the next rising edge of the system clock.                                                                                               |
|                 | 0           | Х      | 1           | Х          | Х          | Х          | OUTMASK is updated with its write<br>buffer contents when the enabled<br>(hardware or software) trigger<br>occurs.                                                        |
|                 | 1           | Х      | 1           | Х          | Х          | Х          | OUTMASK is updated with its write buffer contents when the enabled hardware trigger occurs.                                                                               |

Table continues on the next page...

Table 37-188. Summary of PWM Synchronization (continued)

| Register or bit | PWMSYN<br>C | REINIT | SYNCH<br>OM | CNTMA<br>X | CNTMI<br>N | SYNCE<br>N | Description                                                                                                       |
|-----------------|-------------|--------|-------------|------------|------------|------------|-------------------------------------------------------------------------------------------------------------------|
| SWSYNC bit      | 0           | 0      | х           | 1          | 0          | Х          | SWSYNC bit is cleared when the counter reaches its maximum value after the enabled software trigger has occurred. |
|                 | 0           | 0      | Х           | 0          | 1          | Х          | SWSYNC bit is cleared when the counter reaches its minimum value after the enabled software trigger has occurred. |
|                 | 0           | 1      | Х           | Х          | Х          | Х          | SWSYNC bit is cleared when the enabled software trigger occurs.                                                   |
|                 | 1           | Х      | Х           | 1          | 0          | Х          | SWSYNC bit is cleared when the counter reaches its maximum value after the enabled software trigger has occurred. |
|                 | 1           | Х      | Х           | 0          | 1          | Х          | SWSYNC bit is cleared when the counter reaches its minimum value after the enabled software trigger has occurred. |
| TRIGn bit       | Х           | Х      | Х           | Х          | Х          | Х          | TRIGn bit is cleared when the enabled hardware trigger has occurred.                                              |

## 37.4.12 Deadtime Insertion

The deadtime insertion is enabled when (DTEN = 1) and (DTVAL[5:0] is non-zero).

DEADTIME register defines the deadtime delay that can be used for all FTM channels. The DTPS[1:0] bits define the prescaler for the system clock and the DTVAL[5:0] bits define the deadtime modulo (number of the deadtime prescaler clocks).

The deadtime delay insertion ensures that no two complementary signals (channel (n) and (n+1)) drive the active state at the same time.

For POL(n) = 0, POL(n+1) = 0, and deadtime enabled, a rising edge on the output of channel (n) remains low for the duration of the deadtime delay, after which the rising edge appears on the output. Similarly, when a falling edge is due on the output of channel (n), the channel (n+1) output remains low for the duration of the deadtime delay, after which the channel (n+1) output will have a rising edge.

For POL(n) = 1, POL(n+1) = 1, and deadtime enabled, a falling edge on the output of channel (n) remains high for the duration of the deadtime delay, after which the falling edge appears on the output. Similarly, when a rising edge is due on the output of channel (n), the channel (n+1) output remains high for the duration of the deadtime delay, after which the channel (n+1) output will have a falling edge.



Figure 37-194. Deadtime Insertion with ELSnB:ELSnA = 1:0, POL(n) = 0, and POL(n+1) = 0



Figure 37-195. Deadtime Insertion with ELSnB:ELSnA = X:1, POL(n) = 0, and POL(n+1) = 0

### NOTE

Deadtime feature is only available in combine and complementary modes.

### 37.4.12.1 Deadtime Insertion Corner Cases

If (PS[2:0] bits are cleared), (DTPS[1:0] = 0:0 or DTPS[1:0] = 0:1):

- and the deadtime delay is greater than or equal to the channel (n) duty cycle ((C(n +1)VH:L C(n)VH:L) × system clock), then the channel (n) output is always the inactive value (POL(n) bit value).
- and the deadtime delay is greater than or equal to the channel (n+1) duty cycle ((MODH:L CNTINH:L + 1 (C(n+1)VH:L C(n)VH:L)) × system clock), then the channel (n+1) output is always the inactive value (POL(n+1) bit value).

Although, in most cases the deadtime delay is not comparable to channels (n) and (n+1) duty cycle, the following figures show examples where the deadtime delay is comparable to the duty cycle.



Figure 37-196. Example of the Deadtime Insertion (ELSnB:ELSnA = 1:0, POL(n) = 0, and POL(n+1) = 0) when the Deadtime Delay Is Comparable To Channel (n+1) Duty Cycle



Figure 37-197. Example of the Deadtime Insertion (ELSnB:ELSnA = 1:0, POL(n) = 0, and POL(n+1) = 0) when the Deadtime Delay Is Comparable To Channels (n) and (n+1) Duty Cycle

# 37.4.13 Output Mask

The output mask register OUTMASK can be used to force channel outputs to their inactive state through software (for example: to control a BLDC motor).

Any write to a CHnOM bits updates the OUTMASK write buffer. The CHnOM bit is updated with the value of its corresponding bit in the OUTMASK write buffer according to OUTMASK Register Synchronization.

If CHnOM = 1, then the channel (n) output is forced to its inactive state, defined by the POLn bit in register POL. If CHnOM = 0, then the channel (n) output is unaffected by the output mask function.

When a CHnOM bit is cleared, the channel (n) output is enabled (see the following figure).



Figure 37-198. Output Mask

The following table shows the output mask result before the polarity control.

Table 37-189. Output Mask Result for Channel (n) (Before the Polarity Control)

| CHnOM | Output Mask Input | Output Mask Result |
|-------|-------------------|--------------------|
| 0     | inactive state    | inactive state     |
|       | active state      | active state       |
| 1     | inactive state    | inactive state     |
|       | active state      |                    |

### **Note**

Output mask is only available in combine mode.

## 37.4.14 Fault Control

The fault control is enabled if (FTMEN = 1) and (FAULTM[1:0]  $\neq$  0:0).

FTM can have up to four fault inputs. FAULTnEN bit (where n = 0, 1, 2, 3) enables the fault input n and FFLTRnEN bit enables the fault input n filter. FFVAL[3:0] bits select the value of the enabled filter in each enabled fault input.

First each fault input signal is synchronized by the system clock (see the synchronizer block in the following figure). Following synchronization, the fault input n signal enters the filter block. When there is a state change in the fault input n signal, the 5-bit counter

is reset and starts counting up. As long as the new state is stable on the fault input n, the counter continues to increment. If the 5-bit counter overflows (the counter exceeds the value of the FFVAL[3:0] bits), the new fault input n value is validated. It is then transmitted as a pulse edge to the edge detector.

If the opposite edge appears on the fault input n signal before validation (counter overflow), the counter is reset. At the next input transition, the counter starts counting again. Any pulse that is shorter than the minimum value selected by FFVAL[3:0] bits (× system clock) is regarded as a glitch and is not passed on to the edge detector.

The fault input n filter is disabled when the FFVAL[3:0] bits are zero or when FAULTnEN = 0. In this case the fault input n signal is delayed 2 rising edges of the system clock and the FAULTFn bit is set on 3th rising edge of the system clock after a rising edge occurs on the fault input n.

If FFVAL[3:0] ≠ 0000 and FAULTnEN = 1, then the fault input n signal is delayed (3 + FFVAL[3:0]) rising edges of the system clock, that is, the FAULTFn bit is set (4 + FFVAL[3:0]) rising edges of the system clock after a rising edge occurs on the fault input n.



\* where n = 3, 2, 1, 0

Figure 37-199. Fault Input n Control Block Diagram

If the fault control and fault input n are enabled and a rising edge at the fault input n signal is detected, then the FAULTFn bit is set. The FAULTF bit is the logic OR of FAULTFn[3:0] bits (see the following figure).



Figure 37-200. FAULTF and FAULTIN Bits and Fault Interrupt

MCF51JF128 Reference Manual, Rev. 2, 03/2011

Freescale Semiconductor, Inc.

878

If the fault control is enabled (FAULTM[1:0]  $\neq$  0:0), a fault condition has occurred (rising edge at the logic OR of the enabled fault input) and (FAULTEN = 1), then channel (n) and (n+1) outputs are forced to their safe value (that is, the channel (n) output is forced to the value of POL(n) and the channel (n+1) is forced to the value of POL(n+1)).

The fault interrupt is generated when (FAULTF = 1) and (FAULTIE = 1). This interrupt request remains set until:

- Software clears the FAULTF bit (by reading FAULTF bit as 1 and writing 0 to it)
- Software clears the FAULTIE bit
- A reset occurs

### **Note**

Fault control is only available in combine mode.

## 37.4.14.1 Automatic Fault Clearing

If the automatic fault clearing is selected (FAULTM[1:0] = 1:1), then the disabled channel outputs are enabled when the fault input signal (FAULTIN) returns to zero and a new PWM cycle begins (see the following figure).



Figure 37-201. Fault Control with Automatic Fault Clearing

## 37.4.14.2 Manual Fault Clearing

If the manual fault clearing is selected (FAULTM[1:0] = 0:1 or 1:0), then disabled channel outputs are enabled when the FAULTF bit is cleared and a new PWM cycle begins (see the following figure).

It is possible to manually clear a fault, by clearing the FAULTF bit, and enable disabled channels regardless of the fault input signal (FAULTIN) (the filter output if the filter is enabled or the synchronizer output if the filter is disabled). However, it is recommended to verify the value of the fault input signal (value of the FAULTIN bit) before clearing the FAULTF bit to avoid unpredictable results.



Figure 37-202. Fault Control with Manual Fault Clearing

# 37.4.15 Polarity Control

The POLn bit selects the channel (n) output polarity.

- If (POLn = 0), the channel (n) output polarity is active-high: one is the active state; zero is the inactive state.
- If (POLn = 1), the channel (n) output polarity is active-low: zero is the active state; one is the inactive state.

### **Note**

Polarity control is only available in combine mode.

### 37.4.16 Initialization

The initialization forces the CHnOI bit value to the channel (n) output when a one is written to the INIT bit.

#### Note

- It is recommended using the initialization only when the FTM counter is disabled (CLKS[1:0] = 0:0).
- Initialization is only available in combine mode.

# 37.4.17 Features Priority

The following figure shows the priority of the features that can be combined to generate channel (n) and (n+1) outputs.



Figure 37-203. FTM Features Priority

# 37.4.18 Channel Trigger Output

The channel trigger output is generated if (FTMEN = 1) and (one or more channels were selected by the CHjTRIG bit, where j = 0, 1, 2, 3, 4, or 5). The CHjTRIG bit defines if the channel (j) match (that is, FTM counter = C(j)VH:L) generates the trigger.

The channel trigger output provides a trigger signal that is used for on-chip modules.

The FTM is able to generate multiple triggers in one PWM period. Since each trigger is generated for a specific channel several channels are required to implement this functionality. This behavior is described in the following figure.



Figure 37-204. Match Triggers

### **Note**

Match trigger is only available in combine mode.

# 37.4.19 Initialization Trigger

If INITTRIGEN = 1, the FTM generates a trigger when the FTM counter is updated with the CNTINH:L registers value in the following cases:

• The FTM counter is automatically updated with the CNTINH:L registers value by selected counting mode.



Figure 37-205. Initialization Trigger Is Generated When the FTM Counter Achieves the Value of CNTINH:L

• When there is a write to CNTH or CNTL register



Figure 37-206. Initialization Trigger Is Generated When There Is a Write to CNTH or CNTI

• When there is the FTM counter synchronization (see "FTM Counter Synchronization")



Figure 37-207. Initialization Trigger Is Generated When There Is the FTM Counter Synchronization

• If (CNTH:L = CNTINH:L), (CLKS[1:0] = 0:0), and a value different from zero is written to CLKS[1:0] bits



Figure 37-208. Initialization Trigger Is Generated If (CNTH:L = CNTINH:L) and (CLKS[1:0] = 0:0) and a Value Different From Zero Is Written to CLKS[1:0] Bits

The initialization trigger output provides a trigger signal that is used for on-chip modules.

### **Note**

Initialization trigger is only available in combine mode.

# 37.4.20 Capture Test Mode

The capture test mode allows the testing of the CnVH:L registers, the FTM counter and the interconnection logic between the FTM counter and CnVH:L registers.

In this test mode, all channels must be configured for input capture mode (see Input Capture Mode) and FTM counter must be configured for up-counting (see Up Counting).

When the capture test mode is enabled (CAPTEST = 1), the FTM counter is frozen and any write to CNTH and CNTL updates directly the FTM counter (see the following figure). After both bytes were written (independent of the order), all CnVH:L registers are updated with the value that was written to CNTH:L registers and CHnF bits are set. Therefore, the FTM counter is updated with its next value according to its configuration (its next value depends on CNTINH:L, MODH:L, and the value that was written to FTM counter).

The next reads of CnVH:L registers return the value that was written to FTM counter and the next reads of CNTH:L register return the next value of the FTM counter.

The read coherency mechanism of CNTH:L and CnVH:L registers remains enabled.



#### Notes

- FTM counter configuration: (FTMEN = 1), (QUADEN = 0) if the quadrature decoder feature is supported, (CAPTEST = 1), (CPWMS = 0), (CNTINH:L = 0x0000), and (MODH:L = 0xFFFF)
- FTM channel n configuration: input capture mode (DECAPEN = 0), (COMBINE = 0), and (MSnB:MSnA = 0:0)

Figure 37-209. Capture Test Mode

### 37.4.21 DMA

The channel generates a DMA transfer request according to DMA and CHnIE bits (see the following table).

**DMA CHnIE Channel DMA Transfer Request Channel Interrupt** 0 0 The channel DMA transfer request is not generated. The channel interrupt is not generated. 0 The channel DMA transfer request is not generated. The channel interrupt is generated if (CHnF = 1). 0 1 The channel DMA transfer request is not generated. The channel interrupt is not generated. 1 1 The channel DMA transfer request is generated if The channel interrupt is not generated.

Table 37-190. Channel DMA Transfer Request

If DMA = 1, the CHnF bit is cleared either by channel DMA transfer done or reading CnSC while CHnF is set and then writing a logic 0 to CHnF bit according to CHnIE bit (see the following table).

(CHnF = 1).

Table 37-191. Clear CHnF Bit when DMA = 1

| CHnIE | How CHnF Bit Can Be Cleared                                                                                                           |
|-------|---------------------------------------------------------------------------------------------------------------------------------------|
| 0     | CHnF bit is cleared either by the channel DMA transfer done or reading CnSC while CHnF is set and then writing a logic 0 to CHnF bit. |
| 1     | CHnF bit is cleared by the channel DMA transfer done.                                                                                 |

# 37.4.22 Dual Edge Capture Mode

The dual edge capture mode is selected if FTMEN = 1 and DECAPEN = 1. This mode allows to measure a pulse width or period of the signal on the input of channel (n) of a channel pair. The channel (n) filter can be active in this mode when n is the channels 0 or 2.



<sup>\*</sup> Filtering function for dual edge capture mode is only available in the channels 0 and 2

Figure 37-210. Dual Edge Capture Mode Block Diagram

The MS(n)A bit defines if the dual edge capture mode is one-shot or continuous according to table "Mode, Edge, and Level Selection".

The ELS(n)B:ELS(n)A bits select the edge that is captured by channel (n), and ELS(n+1)B:ELS(n+1)A bits select the edge that is captured by channel (n+1) as described in table "Dual Edge Capture Mode — Edge Polarity Selection". If both ELS(n)B:ELS(n)A and ELS(n+1)B:ELS(n+1)A bits select the same edge, then it is the period measurement. If these bits select different edges, then it is a pulse width measurement.

In the dual edge capture mode, only channel (n) input is used and channel (n+1) input is ignored.

886

If the selected edge by channel (n) bits is detected at channel (n) input, then CH(n)F bit is set and the channel (n) interrupt is generated (if CH(n)IE = 1). If the selected edge by channel (n+1) bits is detected at channel (n) input and (CH(n)F = 1), then CH(n+1)F bit is set and the channel (n+1) interrupt is generated (if CH(n+1)IE = 1).

The C(n)VH:L registers store the value of FTM counter when the selected edge by channel (n) is detected at channel (n) input. The C(n+1)VH:L registers store the value of FTM counter when the selected edge by channel (n+1) is detected at channel (n) input.

In this mode, the coherency mechanism of the pair of channels allows to access coherent data when the C(n)VH:L and C(n+1)VH:L registers are read. The only requirement is that C(n)VH:L registers must be read first than C(n+1)VH:L registers.

### **Note**

- The CH(n)F, CH(n)IE, MS(n)A, ELS(n)B, and ELS(n)A bits are channel (n) bits.
- The CH(n+1)F, CH(n+1)IE, MS(n+1)A, ELS(n+1)B, and ELS(n+1)A bits are channel (n+1) bits.
- It is expected that the dual edge capture mode be used with ELS(n)B:ELS(n)A = 0:1 or 1:0, ELS(n+1)B:ELS(n+1)A = 0:1 or 1:0 and the FTM counter in free running counter mode (see Free Running Counter).

# 37.4.22.1 One-Shot Capture Mode

The one-shot capture mode is selected when (FTMEN = 1), (DECAPEN = 1), and (MS(n)A = 0). In this capture mode, only one pair of edges at the channel (n) input is captured. The ELS(n)B:ELS(n)A bits select the first edge to be captured, and ELS(n+1)B:ELS(n+1)A bits select the second edge to be captured.

The edge captures are enabled while DECAP bit is set. For each new measurement in one-shot capture mode, first the CH(n)F and CH(n+1) bits must be cleared, and then the DECAP bit must be set.

In this mode, the DECAP bit is automatically cleared by FTM when the edge selected by channel (n+1) is captured. Therefore, while DECAP bit is set, the one-shot capture is in process. When this bit is cleared, both edges were captured and the captured values are ready for reading in the C(n)VH:L and C(n+1)VH:L registers.

Similarly, when the CH(n+1)F bit is set, both edges were captured and the captured values are ready for reading in the C(n)VH:L and C(n+1)VH:L registers.

## 37.4.22.2 Continuous Capture Mode

The continuous capture mode is selected when (FTMEN = 1), (DECAPEN = 1), and (MS(n)A = 1). In this capture mode, the edges at the channel (n) input are captured continuously. The ELS(n)B:ELS(n)A bits select the initial edge to be captured, and ELS(n+1)B:ELS(n+1)A bits select the final edge to be captured.

The edge captures are enabled while DECAP bit is set. For the initial use, first the CH(n)F and CH(n+1)F bits must be cleared, and then DECAP bit must be set to start the continuous measurements.

When the CH(n+1)F bit is set, both edges were captured and the captured values are ready for reading in the C(n)VH:L and C(n+1)VH:L registers. The latest captured values are always available in these registers even after the DECAP bit is cleared.

In this mode, it is possible to clear only the CH(n+1)F bit. Therefore, when the CH(n+1)F bit is set again, the latest captured values are available in C(n)VH:L and C(n+1)VH:L registers.

For a new sequence of the measurements in the dual edge capture – continuous mode, it is recommended to clear the CH(n)F and CH(n+1) bits to start new measurements.

### 37.4.22.3 Pulse Width Measurement

If the channel (n) is configured to capture rising edges (ELS(n)B:ELS(n)A = 0:1) and the channel (n+1) to capture falling edges (ELS(n+1)B:ELS(n+1)A = 1:0), then the positive polarity pulse width is measured. If the channel (n) is configured to capture falling edges (ELS(n)B:ELS(n)A = 1:0) and the channel (n+1) to capture rising edges (ELS(n+1)B:ELS(n+1)A = 0:1), then the negative polarity pulse width is measured.

The pulse width measurement can be made in one-shot capture mode (One-Shot Capture Mode) or continuous capture mode (Continuous Capture Mode).

The following figure shows an example of the dual edge capture – one-shot mode used to measure the positive polarity pulse width. The DECAPEN bit selects the dual edge capture mode, so it keeps set in all operation mode. The DECAP bit is set to enable the measurement of next positive polarity pulse width. The CH(n)F bit is set when the first edge of this pulse is detected, that is, the edge selected by ELS(n)B:ELS(n)A bits. The CH(n+1)F bit is set and DECAP bit is cleared when the second edge of this pulse is detected, that is, the edge selected by ELS(n+1)B:ELS(n+1)A bits. Both DECAP and CH(n+1)F bits indicate when two edges of the pulse were captured and the C(n)VH:L and C(n+1)VH:L registers are ready for reading.



#### Note:

- The commands set DECAPEN, set DECAP, clear CH(n)F, and clear CH(n+1)F are made by the user.
- Problem 1: channel (n) input = 1, set DECAP, not clear CH(n)F, and clear CH(n+1)F.
- Problem 2: channel (n) input = 1, set DECAP, not clear CH(n)F, and not clear CH(n+1)F.

Figure 37-211. Dual Edge Capture – One-Shot Mode for Positive Polarity Pulse Width Measurement

The following figure shows an example of the dual edge capture – continuous mode used to measure the positive polarity pulse width. The DECAPEN bit selects the dual edge capture mode, so it keeps set in all operation mode. While the DECAP bit is set the configured measurements are made. The CH(n)F bit is set when the first edge of the positive polarity pulse is detected, that is, the edge selected by ELS(n)B:ELS(n)A bits. The CH(n+1)F bit is set when the second edge of this pulse is detected, that is, the edge selected by ELS(n+1)B:ELS(n+1)A bits. The CH(n+1)F bit indicates when two edges of the pulse were captured and the C(n)VH:L and C(n+1)VH:L registers are ready for reading.



Note

Figure 37-212. Dual Edge Capture – Continuous Mode for Positive Polarity Pulse Width Measurement

### 37.4.22.4 Period Measurement

If the channels (n) and (n+1) are configured to capture consecutive edges of the same polarity, then the period of the channel (n) input signal is measured. If both channels (n) and (n+1) are configured to capture rising edges (ELS(n)B:ELS(n)A = 0:1 and ELS(n +1)B:ELS(n+1)A = 0:1), then the period between two consecutive rising edges is measured. If both channels (n) and (n+1) are configured to capture falling edges (ELS(n)B:ELS(n)A = 1:0 and ELS(n+1)B:ELS(n+1)A = 1:0), then the period between two consecutive rising edges is measured.

The period measurement can be made in one-shot capture mode (One-Shot Capture Mode) or continuous capture mode (Continuous Capture Mode).

The following figure shows an example of the dual edge capture – one-shot mode used to measure the period between two consecutive rising edges. The DECAPEN bit selects the dual edge capture mode, so it keeps set in all operation mode. The DECAP bit is set to

<sup>-</sup> The commands set DECAPEN, set DECAP, clear CH(n)F, and clear CH(n+1)F are made by the user.

enable the measurement of next period. The CH(n)F bit is set when the first rising edge is detected, that is, the edge selected by ELS(n)B:ELS(n)A bits. The CH(n+1)F bit is set and DECAP bit is cleared when the second rising edge is detected, that is, the edge selected by ELS(n+1)B:ELS(n+1)A bits. Both DECAP and CH(n+1)F bits indicate when two selected edges were captured and the C(n)VH:L and C(n+1)VH:L registers are ready for reading.



#### Note

- The commands set DECAPEN, set DECAP, clear CH(n)F, and clear CH(n+1)F are made by the user.
- Problem 1: channel (n) input = 0, set DECAP, not clear CH(n)F, and not clear CH(n+1)F.
- Problem 2: channel (n) input = 1, set DECAP, not clear CH(n)F, and clear CH(n+1)F.
- Problem 3: channel (n) input = 1, set DECAP, not clear CH(n)F, and not clear CH(n+1)F.

Figure 37-213. Dual Edge Capture – One-Shot Mode to Measure of the Period Between Two Consecutive Rising Edges

The following figure shows an example of the dual edge capture – continuous mode used to measure the period between two consecutive rising edges. The DECAPEN bit selects the dual edge capture mode, so it keeps set in all operation mode. While the DECAP bit is set the configured measurements are made. The CH(n)F bit is set when the first rising edge is detected, that is, the edge selected by ELS(n)B:ELS(n)A bits. The CH(n+1)F bit

is set when the second rising edge is detected, that is, the edge selected by ELS(n+1)B:ELS(n+1)A bits. The CH(n+1)F bit indicates when two edges of the period were captured and the C(n)VH:L and C(n+1)VH:L registers are ready for reading.



Note:

Figure 37-214. Dual Edge Capture – Continuous Mode to Measure of the Period Between Two Consecutive Rising Edges

# 37.4.22.5 Read Coherency Mechanism

The dual edge capture mode implements a read coherency mechanism between the FTM counter value captured in C(n)VH:L and C(n+1)VH:L registers. The read coherency mechanism is illustrated in the following figure. In this example, the channels (n) and (n +1) are in dual edge capture – continuous mode for positive polarity pulse width measurement. Thus, the channel (n) is configured to capture the FTM counter value when there is a rising edge at channel (n) input signal, and channel (n+1) to capture the FTM counter value when there is a falling edge at channel (n) input signal.

892

<sup>-</sup> The commands set DECAPEN, set DECAP, clear CH(n)F, and clear CH(n+1)F are made by the user.

When a rising edge occurs in the channel (n) input signal, the FTM counter value is captured into channel (n) capture buffer. The channel (n) capture buffer value is transferred to C(n)VH:L registers when a falling edge occurs in the channel (n) input signal. C(n)VH:L registers have the FTM counter value when the previous rising edge occurred, and the channel (n) capture buffer has the FTM counter value when the last rising edge occurred.

When a negative edge occurs in the channel (n) input signal, the FTM counter value is captured into channel (n+1) capture buffer. The channel (n+1) capture buffer value is transferred to C(n+1)VH:L registers when the first byte of C(n)VH:L registers is read.

In the following figure, the read of C(n)VH returns the FTM counter high byte value when the event 1 occurred, and the read of C(n+1)VL returns the FTM counter low byte value when the event 1 occurred. The read of C(n+1)VL returns the FTM counter low byte value when the event 2 occurred, and the read of C(n+1)VH returns the FTM counter high byte value when the event 2 occurred.

C(n)VH:L registers must be read prior to C(n+1)VH:L registers in dual edge capture one-shot and continuous modes for the read coherency mechanism works properly.



Figure 37-215. Dual Edge Capture Mode Read Coherency Mechanism

Either high or low bytes of C(n)VH:L and C(n+1)VH:L registers can be accessed at first that this read coherency mechanism works properly.

### 37.4.23 Quadrature Decoder Mode

The quadrature decoder mode is selected if FTMEN = 1 and QUADEN = 1 (when the quadrature decoder feature is supported). The quadrature decoder mode uses the input signals phase A and B to control the FTM counter increment and decrement. The following figure is the quadrature decoder block diagram.

Each one of input signals phase A and B has a filter that is equivalent to the filter used in the channels input (Filter for Input Capture Mode). The phase A input filter is enabled by PHAFLTREN bit and this filter's value is defined by CH0FVAL[3:0] bits (CH(n)FVAL[3:0] bits of FILTER0 register). The phase B input filter is enabled by PHBFLTREN bit and this filter's value is defined by CH1FVAL[3:0] bits (CH(n+1)FVAL[3:0] bits of FILTER0 register).

Except for CH0FVAL[3:0] and CH1FVAL[3:0] bits, no channel logic is used in quadrature decoder mode.



Figure 37-216. Quadrature Decoder Block Diagram

### **Note**

It is important to notice that the FTM counter is clocked by the phase A and B input signals when quadrature decoder mode is selected. Therefore it is expected that the quadrature decoder be used only with the FTM channels in input capture or output compare modes.

The PHAPOL bit selects the polarity of the phase A input, and the PHBPOL bit selects the polarity of the phase B input.

The QUADMODE selects the encoding mode used in the quadrature decoder mode. If QUADMODE = 1, then the count and direction encoding mode (refer to the following figure) is enabled. In this mode, the phase B input value indicates the counting direction (FTM counter increment or decrement), and the phase A input defines the counting rate (FTM counter is updated when there is a rising edge at phase A input signal).



Figure 37-217. Quadrature Decoder – Count and Direction Encoding Mode

If QUADMODE = 0, then the phase A and phase B encoding mode (refer to the following figure) is enabled. In this mode, the relationship between phase A and B signals indicates the counting direction, and phase A and B signals define the counting rate (FTM counter is updated when there is an edge either at the phase A or phase B signals).

If PHAPOL = 0 and PHBPOL = 0, then the FTM counter increment happens when:

- there is a rising edge at phase A signal and phase B signal is at logic zero;
- there is a rising edge at phase B signal and phase A signal is at logic one;
- there is a falling edge at phase B signal and phase A signal is at logic zero;
- there is a falling edge at phase A signal and phase B signal is at logic one;

and the FTM counter decrement happens when:

- there is a falling edge at phase A signal and phase B signal is at logic zero;
- there is a falling edge at phase B signal and phase A signal is at logic one;
- there is a rising edge at phase B signal and phase A signal is at logic zero;
- there is a rising edge at phase A signal and phase B signal is at logic one.



Figure 37-218. Quadrature Decoder – Phase A and Phase B Encoding Mode

The following figure shows the FTM counter overflow in up counting. In this case, when the FTM counter changes from MODH:L to CNTINH:L, the TOF and TOFDIR bits are set. The TOF bit indicates the FTM counter overflow occurred. TOFDIR indicates the counting was up when the FTM counter overflow occurred.



Figure 37-219. FTM Counter Overflow in Up Counting for Quadrature Decoder Mode

The following figure shows the FTM counter overflow in down counting. In this case, when the FTM counter changes from CNTINH:L to MODH:L, the TOF bit is set and the TOFDIR bit is cleared. The TOF bit indicates the FTM counter overflow occurred. TOFDIR indicates the counting was down when the FTM counter overflow occurred.



Figure 37-220. FTM Counter Overflow in Down Counting for Quadrature Decoder Mode

# 37.4.23.1 Quadrature Decoder Boundary Conditions

The following two figures illustrate examples of motor jittering that cause FTM counter transitions. Motor position control applications are expected to observe these behaviors.



Figure 37-221. Motor Position Jittering in a Mid Count Value

The following figure shows motor jittering produced by the phase B and A pulses, respectively. The first highlighted transition causes a jitter on the FTM counter value near the maximum count value (MODH:L). The second indicated transition occurs on phase A and causes the FTM counter transition between the maximum and minimum count values, which are defined by the MODH:L and CNTINH:L registers.



Figure 37-222. Motor Position Jittering Near Maximum and Minimum Count Value

The appropriate settings of the phase A and phase B input filters are important to avoid glitches that may cause oscillation on the FTM counter value. The two preceding figures show examples of oscillations that can be caused by poor input filter setup. To avoid these oscillations, guarantee a minimum pulse width.

## 37.4.24 TPM Emulation

This section describe the FTM features that are selected according to the FTMEN bit.

# 37.4.24.1 MODH:L and CnVH:L Synchronization

If (FTMEN = 0), then the MODH:L and CnVH:L registers are updated according to the Update of the Registers With Write Buffers and they are not updated by PWM synchronization.

If (FTMEN = 1), then the MODH:L and CnVH:L registers are updated only by PWM synchronization (PWM Synchronization).

## 37.4.24.2 Free Running Counter

If (FTMEN = 0), then the FTM counter is a free running counter when (MODH:L = 0x0000) or (MODH:L = 0xFFFF) (Free Running Counter).

If (FTMEN = 1), then the FTM counter is a free running counter when (CPWMS = 0), (CNTINH:L = 0x0000), and (MODH:L = 0xFFFF).

### 37.4.24.3 Write to SC

If (FTMEN = 0), then a write to the SC register resets the write coherency mechanism of MODH:L registers.

If (FTMEN = 1), then a write to the SC register does not reset the write coherency mechanism of MODH:L registers.

## 37.4.24.4 Write to CnSC

If (FTMEN = 0), then a write to the CnSC register resets the write coherency mechanism of CnVH:L registers.

If (FTMEN = 1), then a write to the CnSC register does not reset the write coherency mechanism of CnVH:L registers.

## 37.4.25 BDM Mode

When BDM mode is active, the FlexTimer counter and the channels output are frozen.

However, the value of FlexTimer counter or the channels output are modified in BDM mode in the following cases.

- Write any value to CNTH or CNTL registers (Counter Reset) resets the FTM counter to the value of CNTINH:L registers and the channels output to their initial value (except for channels in output compare mode).
- The PWM synchronization with REINIT = 1 (see "FTM Counter Synchronization") resets the FTM counter to the value of CNTINH:L registers and the channels output to their initial value (except for channels in output compare mode).
- The initialization (Initialization) forces the value of the CHnOI bit to the channel (n) output.

### **Note**

It is not recommended to use the above cases together the fault control (Fault Control). If the fault control is enabled and there is the fault condition at the enabled fault input, these cases reset the FTM counter to the CNTINH:L value and the channels output to their initial value.

## 37.5 Reset Overview

The FTM is reset whenever any chip reset occurs.

When the FTM exits from reset:

- the FTM counter and the prescaler counter are zero and are stopped (CLKS[1:0] = 0b00);
- the timer overflow interrupt is zero (Timer Overflow Interrupt);
- the channels interrupts are zero (Channel (n) Interrupt);
- the fault interrupt is zero (Fault Interrupt);
- the channels are in input capture mode (Input Capture Mode);
- the channels outputs are zero;
- the channels pins are not controlled by FTM (ELS(n)B:ELS(n)A = 0b00). See table "Mode, Edge, and Level Selection."

The following figure shows the FTM behavior after the reset. At the reset (item 1), the FTM counter is disabled (see table "FTM Clock Source Selection"), its value is updated to zero and the pins are not controlled by FTM (table "Mode, Edge, and Level Selection").

After the reset, the FTM should be configured (item 2). It is necessary to define the FTM counter mode, the FTM counting limits (MODH:L and CNTINH:L registers value), the channels mode and CnVH:L registers value according to the channels mode.

Thus, it is recommended to write any value to CNTH or CNTL registers (item 3). This write updates the FTM counter with the CNTINH:L registers value and the channels output with its initial value (except for channels in output compare mode) (Counter Reset).

The next step is to select the FTM counter clock by the CLKS[1:0] bits (item 4). It is important to highlight that the pins are only controlled by FTM when CLKS[1:0] bits are different from zero (table "Mode, Edge, and Level Selection").



- Note
  - -CNTINH:L = 0x0010
  - Channel (n) is in low-true combine mode with CNTINH:L < C(n)VH:L < C(n+1)VH:L < MODH:L
  - -C(n)VH:L = 0x0015

Figure 37-223. FTM Behavior After the Reset When the Channel (n) Is in Combine Mode

The following figure shows an example when the channel (n) is in output compare mode and the channel (n) output is toggled when there is a match. In the output compare mode, the channel output is not updated to its initial value when there is a write to CNTH or CNTL registers (item 3). In this case, it is recommended to use the initialization (Initialization) to update the channel output to the selected value (item 4).



- Note
  - CNTINH:L = 0x0010
  - Channel (n) is in output compare and the channel (n) output is toggled when there is a match
  - -C(n)VH:L = 0x0014

Figure 37-224. FTM Behavior After the Reset When the Channel (n) Is in Output Compare Mode

# 37.6 FTM Interrupts

# 37.6.1 Timer Overflow Interrupt

The timer overflow interrupt is generated when (TOIE = 1) and (TOF = 1).

# 37.6.2 Channel (n) Interrupt

The channel (n) interrupt is generated when (CHnIE = 1) and (CHnF = 1).

# 37.6.3 Fault Interrupt

The fault interrupt is generated when (FAULTIE = 1) and (FAULTF = 1).

# **Chapter 38 Serial Peripheral Interface (SPI)**

## 38.1 Introduction

The serial peripheral interface (SPI) module provides for full-duplex, synchronous, serial communication between the MCU and peripheral devices. These peripheral devices can include other microcontrollers, analog-to-digital converters, shift registers, sensors, and memories, among others.

The SPI runs at a baud rate up to the bus clock divided by two in master mode and up to the bus clock divided by four in slave mode. Software can poll the status flags, or SPI operation can be interrupt driven.

#### NOTE

For the actual maximum SPI baud rate, refer to the Chip Configuration details and to the device's Data Sheet.

The SPI also supports a data length of 8 or 16 bits and includes a hardware match feature for the receive data buffer.

The SPI includes an internal DMA interface to support continuous SPI transmission through an on-chip DMA controller instead of through the CPU. This feature decreases CPU loading, allowing CPU time to be used for other work.

## 38.1.1 Features

The SPI includes these distinctive features:

- Master mode or slave mode operation
- Full-duplex or single-wire bidirectional mode
- Programmable transmit bit rate
- Double-buffered transmit and receive data register

#### Introduction

- Serial clock phase and polarity options
- Slave select output
- Mode fault error flag with CPU interrupt capability
- Control of SPI operation during wait mode
- Selectable MSB-first or LSB-first shifting
- Programmable 8- or 16-bit data transmission length
- Receive data buffer hardware match feature
- 64-bit FIFO mode for high speed/large amounts of data transfers
- Support transmission of both Transmit and Receive by DMA

# 38.1.2 Modes of Operation

The SPI functions in three modes, run, wait, and stop.

• Run Mode

This is the basic mode of operation.

Wait Mode

SPI operation in wait mode is a configurable low power mode, controlled by the SPISWAI bit located in the SPIx\_C2 register. In wait mode, if the SPISWAI bit is clear, the SPI operates like in Run Mode. If the SPISWAI bit is set, the SPI goes into a power conservative state, with the SPI clock generation turned off. If the SPI is configured as a master, any transmission in progress stops, but is resumed after CPU enters run mode. If the SPI is configured as a slave, reception and transmission of a byte continues, so that the slave stays synchronized to the master.

## Stop Mode

To reduce power consumption, the SPI is inactive in stop modes where the peripheral bus clock is stopped but internal logic states are retained. If the SPI is configured as a master, any transmission in progress stops, but is resumed after the CPU enters run mode. If the SPI is configured as a slave, reception and transmission of a data continues, so that the slave stays synchronized to the master.

The SPI is completely disabled in stop modes where the peripheral bus clock is stopped and internal logic states are not retained. When the CPU wakes from these stop modes, all SPI register content is reset.

Detailed descriptions of operating modes appear in Low Power Mode Options.

# 38.1.3 Block Diagrams

This section includes block diagrams showing SPI system connections, the internal organization of the SPI module, and the SPI clock dividers that control the master mode bit rate.

# 38.1.3.1 SPI System Block Diagram

The following figure shows the SPI modules of two MCUs connected in a master-slave arrangement. The master device initiates all SPI data transfers. During a transfer, the master shifts data out (on the MOSI pin) to the slave while simultaneously shifting data in (on the MISO pin) from the slave. The transfer effectively exchanges the data that was in the SPI shift registers of the two SPI systems. The SPSCK signal is a clock output from the master and an input to the slave. The slave device must be selected by a low level on the slave select input ( $\overline{SS}$  pin). In this system, the master device has configured its  $\overline{SS}$  pin as an optional slave select output.



Figure 38-1. SPI System Connections

Introduction

## 38.1.3.2 SPI Module Block Diagram

The following is a block diagram of the SPI module. The central element of the SPI is the SPI shift register. Data is written to the double-buffered transmitter (write to SPIx\_DH:SPIx\_DL) and gets transferred to the SPI shift register at the start of a data transfer. After shifting in 8 bits or 16 bits (as determined by the SPIMODE bit) of data, the data is transferred into the double-buffered receiver where it can be read from SPIx\_DH:SPIx\_DL. Pin multiplexing logic controls connections between MCU pins and the SPI module.

When the FIFO feature is supported: Additionally there is an 8-byte receive FIFO and an 8-byte transmit FIFO that (once enabled) provide features to allow fewer CPU interrupts to occur when transmitting/receiving high volume/high speed data. When FIFO mode is enabled, the SPI can still function in either 8-bit or 16-bit mode (as per SPIMODE bit) and three additional flags help monitor the FIFO status. Two of these flags can provide CPU interrupts.

When the SPI is configured as a master, the clock output is routed to the SPSCK pin, the shifter output is routed to MOSI, and the shifter input is routed from the MISO pin.

When the SPI is configured as a slave, the SPSCK pin is routed to the clock input of the SPI, the shifter output is routed to MISO, and the shifter input is routed from the MOSI pin.

In the external SPI system, simply connect all SPSCK pins to each other, all MISO pins together, and all MOSI pins together. Peripheral devices often use slightly different names for these pins.

#### **Chapter 38 Serial Peripheral Interface (SPI)**



Figure 38-2. SPI Module Block Diagram without FIFO

#### **External Signal Description**



Figure 38-3. SPI Module Block Diagram with FIFO

# 38.2 External Signal Description

The SPI optionally shares four port pins. The function of these pins depends on the settings of SPI control bits. When the SPI is disabled (SPE = 0), these four pins revert to other functions that are not controlled by the SPI (based on chip configuration).

Freescale Semiconductor, Inc.

## 38.2.1 SPSCK — SPI Serial Clock

When the SPI is enabled as a slave, this pin is the serial clock input. When the SPI is enabled as a master, this pin is the serial clock output.

## 38.2.2 MOSI — Master Data Out, Slave Data In

When the SPI is enabled as a master and SPI pin control zero (SPC0) is 0 (not bidirectional mode), this pin is the serial data output. When the SPI is enabled as a slave and SPC0 is 0, this pin is the serial data input. If SPC0 is 1 to select single-wire bidirectional mode, and master mode is selected, this pin becomes the bidirectional data I/O pin (MOMI). Also, the bidirectional mode output enable bit determines whether the pin acts as an input (BIDIROE is 0) or an output (BIDIROE is 1). If SPC0 is 1 and slave mode is selected, this pin is not used by the SPI and reverts to other functions (based on chip configuration).

# 38.2.3 MISO — Master Data In, Slave Data Out

When the SPI is enabled as a master and SPI pin control zero (SPC0) is 0 (not bidirectional mode), this pin is the serial data input. When the SPI is enabled as a slave and SPC0 is 0, this pin is the serial data output. If SPC0 is 1 to select single-wire bidirectional mode, and slave mode is selected, this pin becomes the bidirectional data I/O pin (SISO), and the bidirectional mode output enable bit determines whether the pin acts as an input (BIDIROE is 0) or an output (BIDIROE is 1). If SPC0 is 1 and master mode is selected, this pin is not used by the SPI and reverts to other functions (based on chip configuration).

# 38.2.4 SS — Slave Select

When the SPI is enabled as a slave, this pin is the low-true slave select input. When the SPI is enabled as a master and mode fault enable is off (MODFEN is 0), this pin is not used by the SPI and reverts to other functions (based on chip configuration). When the SPI is enabled as a master and MODFEN is 1, the slave select output enable bit determines whether this pin acts as the mode fault input (SSOE is 0) or as the slave select output (SSOE is 1).

# 38.3 Register Definition

The SPI has 8-bit registers to select SPI options, to control baud rate, to report SPI status, to hold an SPI data match value, and for transmit/receive data.

## **SPIx** memory map

| Absolute address (hex) | Register name                          | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|------------------------|----------------------------------------|--------------------|--------|-------------|------------------|
| FFFF_81A0              | SPI control register 1 (SPI0_C1)       | 8                  | R/W    | 04h         | 38.3.1/<br>911   |
| FFFF_81A1              | SPI control register 2 (SPI0_C2)       | 8                  | R/W    | 00h         | 38.3.2/<br>913   |
| FFFF_81A2              | SPI baud rate register (SPI0_BR)       | 8                  | R/W    | 00h         | 38.3.3/<br>914   |
| FFFF_81A3              | SPI status register (SPI0_S)           | 8                  | R      | 20h         | 38.3.4/<br>915   |
| FFFF_81A4              | SPI data register high (SPI0_DH)       | 8                  | R/W    | 00h         | 38.3.5/<br>919   |
| FFFF_81A5              | SPI data register low (SPI0_DL)        | 8                  | R/W    | 00h         | 38.3.6/<br>919   |
| FFFF_81A6              | SPI match register high (SPI0_MH)      | 8                  | R/W    | 00h         | 38.3.7/<br>920   |
| FFFF_81A7              | SPI match register low (SPI0_ML)       | 8                  | R/W    | 00h         | 38.3.8/<br>920   |
| FFFF_81A8              | SPI control register 3 (SPI0_C3)       | 8                  | R/W    | 00h         | 38.3.9/<br>921   |
| FFFF_81A9              | SPI clear interrupt register (SPI0_CI) | 8                  | R/W    | 00h         | 38.3.10/<br>923  |
| FFFF_81B0              | SPI control register 1 (SPI1_C1)       | 8                  | R/W    | 04h         | 38.3.1/<br>911   |
| FFFF_81B1              | SPI control register 2 (SPI1_C2)       | 8                  | R/W    | 00h         | 38.3.2/<br>913   |
| FFFF_81B2              | SPI baud rate register (SPI1_BR)       | 8                  | R/W    | 00h         | 38.3.3/<br>914   |
| FFFF_81B3              | SPI status register (SPI1_S)           | 8                  | R      | 20h         | 38.3.4/<br>915   |
| FFFF_81B4              | SPI data register high (SPI1_DH)       | 8                  | R/W    | 00h         | 38.3.5/<br>919   |
| FFFF_81B5              | SPI data register low (SPI1_DL)        | 8                  | R/W    | 00h         | 38.3.6/<br>919   |

Table continues on the next page...

## SPIx memory map (continued)

| Absolute<br>address<br>(hex) | Register name                     | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|------------------------------|-----------------------------------|--------------------|--------|-------------|------------------|
| FFFF_81B6                    | SPI match register high (SPI1_MH) | 8                  | R/W    | 00h         | 38.3.7/<br>920   |
| FFFF_81B7                    | SPI match register low (SPI1_ML)  | 8                  | R/W    | 00h         | 38.3.8/<br>920   |
| FFFF_81B8                    | Reserved                          |                    |        |             |                  |
| FFFF_81B9                    | Reserved                          |                    |        |             |                  |

# 38.3.1 SPI control register 1 (SPIx\_C1)

This read/write register includes the SPI enable control, interrupt enables, and configuration options.

Addresses: SPI0\_C1 is FFFF\_81A0h base + 0h offset = FFFF\_81A0h, SPI1\_C1 is FFFF\_81B0h base + 0h offset = FFFF\_81B0h



## SPI0\_C1 field descriptions

| Field      | Description                                                                                                                                                                                                                                                                     |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>SPIE  | SPI interrupt enable: for SPRF and MODF (when FIFO is not supported or not enabled) or for read FIFO (when FIFO is supported and enabled)                                                                                                                                       |
|            | When the FIFO is not supported or not enabled (FIFOMODE is not present or is 0): This bit enables the interrupt for SPI receive buffer full (SPRF) and mode fault (MODF) events.                                                                                                |
|            | When the FIFO is supported and enabled (FIFOMODE is 1): This bit enables the SPI to interrupt the CPU when the receive FIFO is full. An interrupt occurs when the SPRF bit is set or the MODF bit is set.                                                                       |
|            | 0 Interrupts from SPRF and MODF are inhibited—use polling (when FIFOMODE is not present or is 0) or Read FIFO Full Interrupts are disabled (when FIFOMODE is 1)                                                                                                                 |
|            | 1 Request a hardware interrupt when SPRF or MODF is 1 (when FIFOMODE is not present or is 0) or Read FIFO Full Interrupts are enabled (when FIFOMODE is 1)                                                                                                                      |
| 6<br>SPE   | SPI system enable  This bit enables the SPI system and dedicates the SPI port pins to SPI system functions. If SPE is cleared, the SPI is disabled and forced into an idle state, and all status bits in the S register are reset.  O SPI system inactive  1 SPI system enabled |
| 5<br>SPTIE | SPI transmit interrupt enable                                                                                                                                                                                                                                                   |

Table continues on the next page...

## **Register Definition**

## SPI0\_C1 field descriptions (continued)

| Field     | Description                                                                                                                                                                                                                                                                     |
|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|           | When the FIFO is not supported or not enabled (FIFOMODE is not present or is 0): This is the interrupt enable bit for SPI transmit buffer empty (SPTEF). An interrupt occurs when the SPI transmit buffer is empty (SPTEF is set).                                              |
|           | When the FIFO is supported and enabled (FIFOMODE is 1): This is the interrupt enable bit for SPI transmit FIFO empty (SPTEF). An interrupt occurs when the SPI transmit FIFO is empty (SPTEF is set).                                                                           |
|           | <ul> <li>Interrupts from SPTEF inhibited (use polling)</li> <li>When SPTEF is 1, hardware interrupt requested</li> </ul>                                                                                                                                                        |
| 4<br>MSTR | Master/slave mode select  This bit selects master or slave mode operation.                                                                                                                                                                                                      |
|           | O SPI module configured as a slave SPI device  SPI module configured as a master SPI device                                                                                                                                                                                     |
| 3         | Clock polarity                                                                                                                                                                                                                                                                  |
| CPOL      | This bit selects an inverted or non-inverted SPI clock. To transmit data between SPI modules, the SPI modules must have identical CPOL values.                                                                                                                                  |
|           | This bit effectively places an inverter in series with the clock signal either from a master SPI device or to a slave SPI device. Refer to the description of "SPI Clock Formats" for details.                                                                                  |
|           | O Active-high SPI clock (idles low)  Active-low SPI clock (idles high)                                                                                                                                                                                                          |
| 2<br>CPHA | Clock phase                                                                                                                                                                                                                                                                     |
| CPHA      | This bit selects one of two clock formats for different kinds of synchronous serial peripheral devices. Refer to the description of "SPI Clock Formats" for details.                                                                                                            |
|           | 0 First edge on SPSCK occurs at the middle of the first cycle of a data transfer                                                                                                                                                                                                |
|           | 1 First edge on SPSCK occurs at the start of the first cycle of a data transfer                                                                                                                                                                                                 |
| 1<br>SSOE | Slave select output enable                                                                                                                                                                                                                                                      |
|           | This bit is used in combination with the mode fault enable (MODFEN) bit in the C2 register and the master/slave (MSTR) control bit to determine the function of the SS pin.                                                                                                     |
|           | 0 When MODFEN is 0: In master mode, SS pin function is general-purpose I/O (not SPI). In slave mode, SS pin function is slave select input. When MODFEN is 1: In master mode, SS pin function is SS input for mode fault. In slave mode, SS pin function is slave select input. |
|           | 1 When MODFEN is 0: In master mode, SS pin function is general-purpose I/O (not SPI). In slave mode, SS pin function is slave select input. When MODFEN is 1: In master mode, SS pin function is automatic SS output. In slave mode: SS pin function is slave select input.     |
| 0         | LSB first (shifter direction)                                                                                                                                                                                                                                                   |
| LSBFE     | This bit does not affect the position of the MSB and LSB in the data register. Reads and writes of the data register always have the MSB in bit 7 (or bit 15 in 16-bit mode).                                                                                                   |
|           | SPI serial data transfers start with most significant bit     SPI serial data transfers start with least significant bit                                                                                                                                                        |

# 38.3.2 SPI control register 2 (SPIx\_C2)

This read/write register is used to control optional features of the SPI system.

Addresses: SPI0\_C2 is FFFF\_81A0h base + 1h offset = FFFF\_81A1h, SPI1\_C2 is FFFF\_81B0h base + 1h offset = FFFF\_81B1h



## SPI0\_C2 field descriptions

| Field        | Description                                                                                                                                                                                                                                                                                                                                                                                                       |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>SPMIE   | SPI match interrupt enable                                                                                                                                                                                                                                                                                                                                                                                        |
|              | This is the interrupt enable bit for the SPI receive data buffer hardware match (SPMF) function.                                                                                                                                                                                                                                                                                                                  |
|              | 0 Interrupts from SPMF inhibited (use polling)                                                                                                                                                                                                                                                                                                                                                                    |
|              | 1 When SPMF is 1, requests a hardware interrupt                                                                                                                                                                                                                                                                                                                                                                   |
| 6<br>SPIMODE | SPI 8-bit or 16-bit mode                                                                                                                                                                                                                                                                                                                                                                                          |
| SPIMODE      | This bit allows the user to select either an 8-bit or 16-bit SPI data transmission length. In master mode, a change of this bit aborts a transmission in progress, forces the SPI system into an idle state, and resets all status bits in the S register. Refer to the description of "Data Transmission Length" for details.                                                                                    |
|              | 0 8-bit SPI shift register, match register, and buffers                                                                                                                                                                                                                                                                                                                                                           |
|              | 1 16-bit SPI shift register, match register, and buffers                                                                                                                                                                                                                                                                                                                                                          |
| 5            | Transmit DMA enable                                                                                                                                                                                                                                                                                                                                                                                               |
| TXDMAE       | This is the enable bit for a transmit DMA request. When this bit is set to 1, a transmit DMA request is asserted when both SPTEF and SPE are set, and the interrupt from SPTEF is disabled.                                                                                                                                                                                                                       |
|              | 0 DMA request for transmit is disabled and interrupt from SPTEF is allowed                                                                                                                                                                                                                                                                                                                                        |
|              | 1 DMA request for transmit is enabled and interrupt from SPTEF is disabled                                                                                                                                                                                                                                                                                                                                        |
| 4            | Master mode-fault function enable                                                                                                                                                                                                                                                                                                                                                                                 |
| MODFEN       | When the SPI is configured for slave mode, this bit has no meaning or effect. (The $\overline{SS}$ pin is the slave select input.) In master mode, this bit determines how the $\overline{SS}$ pin is used. For details, refer to the description of the SSOE bit in the C1 register.                                                                                                                             |
|              | 0 Mode fault function disabled, master SS pin reverts to general-purpose I/O not controlled by SPI 1 Mode fault function enabled, master SS pin acts as the mode fault input or the slave select output                                                                                                                                                                                                           |
| 3            | Bidirectional mode output enable                                                                                                                                                                                                                                                                                                                                                                                  |
| BIDIROE      | When bidirectional mode is enabled because SPI pin control 0 (SPC0) is set to 1, the BIDIROE bit determines whether the SPI data output driver is enabled to the single bidirectional SPI I/O pin. Depending on whether the SPI is configured as a master or a slave, it uses the MOSI (MOMI) or MISO (SISO) pin, respectively, as the single SPI data I/O pin. When SPC0 is 0, BIDIROE has no meaning or effect. |

Table continues on the next page...

#### **Register Definition**

## SPI0\_C2 field descriptions (continued)

| Field       | Description                                                                                                                                                                                                                                                                                                                             |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             | 0 Output driver disabled so SPI data I/O pin acts as an input                                                                                                                                                                                                                                                                           |
|             | 1 SPI I/O pin enabled as an output                                                                                                                                                                                                                                                                                                      |
| 2<br>RXDMAE | Receive DMA enable                                                                                                                                                                                                                                                                                                                      |
| TIXBIVIAL   | This is the enable bit for a receive DMA request. When this bit is set to 1, a receive DMA request is asserted when both SPRF and SPE are set, and the interrupt from SPRF is disabled.                                                                                                                                                 |
|             | DMA request for receive is disabled and interrupt from SPRF is allowed                                                                                                                                                                                                                                                                  |
|             | 1 DMA request for receive is enabled and interrupt from SPRF is disabled                                                                                                                                                                                                                                                                |
| 1           | SPI stop in wait mode                                                                                                                                                                                                                                                                                                                   |
| SPISWAI     | This bit is used for power conservation while the device is in wait mode.                                                                                                                                                                                                                                                               |
|             | 0 SPI clocks continue to operate in wait mode                                                                                                                                                                                                                                                                                           |
|             | 1 SPI clocks stop when the MCU enters wait mode                                                                                                                                                                                                                                                                                         |
| 0           | SPI pin control 0                                                                                                                                                                                                                                                                                                                       |
| SPC0        | This bit enables bidirectional pin configurations.                                                                                                                                                                                                                                                                                      |
|             | O SPI uses separate pins for data input and data output (pin mode is normal). In master mode of operation: MISO is master in and MOSI is master out. In slave mode of operation: MISO is slave out and MOSI is slave in.                                                                                                                |
|             | 1 SPI configured for single-wire bidirectional operation (pin mode is bidirectional). In master mode of operation: MISO is not used by SPI; MOSI is master in when BIDIROE is 0 or master I/O when BIDIROE is 1.In slave mode of operation: MISO is slave in when BIDIROE is 0 or slave I/O when BIDIROE is 1; MOSI is not used by SPI. |

## 38.3.3 SPI baud rate register (SPIx\_BR)

Use this register to set the prescaler and bit rate divisor for an SPI master. This register may be read or written at any time.

 $Addresses: SPI0\_BR is FFFF\_81A0h \ base + 2h \ offset = FFFF\_81A2h, SPI1\_BR is FFFF\_81B0h \ base + 2h \ offset = FFFF\_81B2h$ 



## SPI0\_BR field descriptions

| Field            | Description                                                   |
|------------------|---------------------------------------------------------------|
| 7<br>Reserved    | This read-only bit is reserved and always has the value zero. |
| 6–4<br>SPPR[2:0] | SPI baud rate prescale divisor                                |

Table continues on the next page...

## SPI0\_BR field descriptions (continued)

| Field           | Description                                                                                                                                                                                                                                                                                 |
|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                 | This 3-bit field selects one of eight divisors for the SPI baud rate prescaler. The input to this prescaler is the bus rate clock (BUSCLK). The output of this prescaler drives the input of the SPI baud rate divider. Refer to the description of "SPI Baud Rate Generation" for details. |
|                 | 000 Baud rate prescaler divisor is 1                                                                                                                                                                                                                                                        |
|                 | 001 Baud rate prescaler divisor is 2                                                                                                                                                                                                                                                        |
|                 | 010 Baud rate prescaler divisor is 3                                                                                                                                                                                                                                                        |
|                 | 011 Baud rate prescaler divisor is 4                                                                                                                                                                                                                                                        |
|                 | 100 Baud rate prescaler divisor is 5                                                                                                                                                                                                                                                        |
|                 | 101 Baud rate prescaler divisor is 6                                                                                                                                                                                                                                                        |
|                 | 110 Baud rate prescaler divisor is 7                                                                                                                                                                                                                                                        |
|                 | 111 Baud rate prescaler divisor is 8                                                                                                                                                                                                                                                        |
| 3–0<br>SPR[3:0] | SPI baud rate divisor                                                                                                                                                                                                                                                                       |
| 31 Ti[3.0]      | This 4-bit field selects one of nine divisors for the SPI baud rate divider. The input to this divider comes from the SPI baud rate prescaler. Refer to the description of "SPI Baud Rate Generation" for details.                                                                          |
|                 | 0000 Baud rate divisor is 2                                                                                                                                                                                                                                                                 |
|                 | 0001 Baud rate divisor is 4                                                                                                                                                                                                                                                                 |
|                 | 0010 Baud rate divisor is 8                                                                                                                                                                                                                                                                 |
|                 | 0011 Baud rate divisor is 16                                                                                                                                                                                                                                                                |
|                 | 0100 Baud rate divisor is 32                                                                                                                                                                                                                                                                |
|                 | 0101 Baud rate divisor is 64                                                                                                                                                                                                                                                                |
|                 | 0110 Baud rate divisor is 128                                                                                                                                                                                                                                                               |
|                 | 0111 Baud rate divisor is 256                                                                                                                                                                                                                                                               |
|                 | 1000 Baud rate divisor is 512                                                                                                                                                                                                                                                               |
|                 | All others Reserved                                                                                                                                                                                                                                                                         |

# 38.3.4 SPI status register (SPIx\_S)

This register contains read-only status bits. Writes have no meaning or effect.

#### NOTE

When the FIFO is not supported or not enabled (FIFOMODE is not present or is 0): Bits 3 through 0 are not implemented and always read 0.

When the FIFO is supported and enabled (FIFOMODE is 1): This register has four flags that provide mechanisms to support an 8-byte FIFO mode: RNFULLF, TNEARF, TXFULLF, and RFIFOEF. When the SPI is in 8-byte FIFO mode, the function of SPRF and SPTEF differs slightly from their function in the normal buffered modes, mainly regarding how these flags are cleared by the amount available in the transmit and receive FIFOs.

#### **Register Definition**

- The RNFULLF and TNEAREF help improve the efficiency of FIFO operation when transfering large amounts of data. These flags provide a "watermark" feature of the FIFOs to allow continuous transmissions of data when running at high speed.
- The RNFULLF can generate an interrupt if the RNFULLIEN bit in the C3 register is set, which allows the CPU to start emptying the receive FIFO without delaying the reception of subsequent bytes. The user can also determine if all data in the receive FIFO has been read by monitoring the RFIFOEF.
- The TNEAREF can generate an interrupt if the TNEARIEN bit in the C3 register is set, which allows the CPU to start filling the transmit FIFO before it is empty and thus to prevent breaks in SPI transmission.

#### **NOTE**

At an initial POR, the values of TNEAREF and RFIFOEF are 0. However, the status (S) register and both TX and RX FIFOs are reset due to a change of SPIMODE, FIFOMODE or SPE. If this type of reset occurs and FIFOMODE is 0, TNEAREF and RFIFOEF continue to reset to 0. If this type of reset occurs and FIFOMODE is 1, TNEAREF and RFIFOEF reset to 1.

Addresses: SPI0\_S is FFFF\_81A0h base + 3h offset = FFFF\_81A3h, SPI1\_S is FFFF\_81B0h base + 3h offset = FFFF\_81B3h



## SPI0\_S field descriptions

| Field     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>SPRF | SPI read buffer full flag (when FIFO is not supported or not enabled) or SPI read FIFO FULL flag (when FIFO is supported and enabled)                                                                                                                                                                                                                                                                                                                                                                                                           |
|           | When the FIFO is not supported or not enabled (FIFOMODE is not present or is 0): This bit enables the interrupt for SPI receive buffer full (SPRF) and mode fault (MODF) events.                                                                                                                                                                                                                                                                                                                                                                |
|           | When the FIFO is supported and enabled (FIFOMODE is 1): This bit enables the SPI to interrupt the CPU when the receive FIFO is full. An interrupt occurs when the SPRF bit is set or the MODF bit is set.                                                                                                                                                                                                                                                                                                                                       |
|           | When the FIFO is not supported or not enabled (FIFOMODE is not present or is 0): SPRF is set at the completion of an SPI transfer to indicate that received data may be read from the SPI data (DH:DL) register. When the receive DMA request is disabled (RXDMAE is 0), SPRF is cleared by reading SPRF while it is set and then reading the SPI data register. When the receive DMA request is enabled (RXDMAE is 1), SPRF is automatically cleared when the DMA transfer for the receive DMA request is completed (RX DMA Done is asserted). |
|           | When FIFOMODE is 1: This bit indicates the status of the read FIFO when FIFOMODE is enabled. The SPRF is set when the read FIFO has received 64 bits (4 words or 8 bytes) of data from the shifter and there have been no CPU reads of the SPI data (DH:DL) register. When the receive DMA request is disabled (RXDMAE is 0), SPRF is cleared by reading the SPI data register, which empties the FIFO                                                                                                                                          |

Table continues on the next page...

## SPI0\_S field descriptions (continued)

| Field      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | assuming another SPI message is not received. When the receive DMA request is enabled (RXDMAE is 1), SPRF is automatically cleared when the DMA transfer for the receive DMA request is completed (RX DMA Done is asserted).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|            | 0 No data available in the receive data buffer (when FIFOMODE is not present or is 0) or Read FIFO is not full (when FIFOMODE is 1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|            | 1 Data available in the receive data buffer (when FIFOMODE is not present or is 0) or Read FIFO is full (when FIFOMODE is 1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 6          | SPI match flag                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| SPMF       | SPMF is set after SPRF is 1 when the value in the receive data buffer matches the value in the MH:ML registers. To clear the flag, read SPMF when it is set and then write a 1 to it.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|            | 0 Value in the receive data buffer does not match the value in the MH:ML registers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|            | 1 Value in the receive data buffer matches the value in the MH:ML registers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 5<br>SPTEF | SPI transmit buffer empty flag (when FIFO is not supported or not enabled) or SPI transmit FIFO empty flag (when FIFO is supported and enabled)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|            | When the FIFO is not supported or not enabled (FIFOMODE is not present or is 0): This bit is set when the transmit data buffer is empty. When the transmit DMA request is disabled (TXDMAE is 0), SPTEF is cleared by reading the S register with SPTEF set and then writing a data value to the transmit buffer at DH:DL. The S register must be read with SPTEF set to 1 before writing data to the DH:DL register; otherwise, the DH:DL write is ignored. When the transmit DMA request is enabled (TXDMAE is 1), SPTEF is automatically cleared when the DMA transfer for the transmit DMA request is completed (TX DMA Done is asserted). SPTEF is automatically set when all data from the transmit buffer transfers into the transmit shift register. For an idle SPI, data written to DH:DL is transferred to the shifter almost immediately so that SPTEF is set within two bus cycles, allowing a second set of data to be queued into the transmit buffer. After completion of the transfer of the data in the shift register, the queued data from the transmit buffer automatically moves to the shifter, and SPTEF is set to indicate that room exists for new data in the transmit buffer. If no new data is waiting in the transmit buffer, SPTEF simply remains set and no data moves from the buffer to the shifter. |
|            | When the FIFO is not supported or not enabled (FIFOMODE is not present or is 0): If a transfer does not stop, the last data that was transmitted is sent out again.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|            | When the FIFO is supported and enabled (FIFOMODE is 1): This bit provides the status of the FIFO rather than of an 8-bit or a 16-bit buffer. This bit is set when the transmit FIFO is empty. When the transmit DMA request is disabled (TXDMAE is 0), SPTEF is cleared by writing a data value to the transmit FIFO at DH:DL. When the transmit DMA request is enabled (TXDMAE is 1), SPTEF is automatically cleared when the DMA transfer for the transmit DMA request is completed (TX DMA Done is asserted). SPTEF is automatically set when all data from the transmit FIFO transfers into the transmit shift register. For an idle SPI, data written to the DH:DL register is transferred to the shifter almost immediately, so that SPTEF is set within two bus cycles. A second write of data to the DH:DL register clears this SPTEF flag. After completion of the transfer of the data in the shift register, the queued data from the transmit FIFO automatically moves to the shifter, and SPTEF will be set only when all data written to the transmit FIFO has been transfered to the shifter. If no new data is waiting in the transmit FIFO, SPTEF simply remains set and no data moves from the buffer to the shifter.                                                                                                |
|            | 0 SPI transmit buffer not empty (when FIFOMODE is not present or is 0) or SPI FIFO not empty (when FIFOMODE is 1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|            | 1 SPI transmit buffer empty (when FIFOMODE is not present or is 0) or SPI FIFO empty (when FIFOMODE is 1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 4<br>MODF  | Master mode fault flag                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

Table continues on the next page...

## **Register Definition**

## SPI0\_S field descriptions (continued)

| Field        | Description                                                                                                                                                                                                                                                                                                                                                                               |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|              | MODF is set if the SPI is configured as a master and the slave select input goes low, indicating some other SPI device is also configured as a master. The SS pin acts as a mode fault error input only when MSTR is 1, MODFEN is 1, and SSOE is 0; otherwise, MODF will never be set. MODF is cleared by reading MODF while it is 1 and then writing to the SPI control register 1 (C1). |
|              | <ul><li>0 No mode fault error</li><li>1 Mode fault error detected</li></ul>                                                                                                                                                                                                                                                                                                               |
| 3<br>RNFULLF | Receive FIFO nearly full flag  This flag is set when more than three 16-bit words or six 8-bit bytes of data remain in the receive FIFO, provided C3[4] is 0, or when more than two 16-bit words or four 8-bit bytes of data remain in the receive FIFO, provided C3[4] is 1. It has no function if FIFOMODE is not present or is 0.                                                      |
|              | <ul> <li>Receive FIFO has received less than 48 bits (when C3[4] is 0) or less than 32 bits (when C3[4] is 1)</li> <li>Receive FIFO has received data of an amount equal to or greater than 48 bits (when C3[4] is 0) or 32 bits (when C3[4] is 1)</li> </ul>                                                                                                                             |
| 2            | Transmit FIFO nearly empty flag                                                                                                                                                                                                                                                                                                                                                           |
| TNEAREF      | This flag is set when only one 16-bit word or two 8-bit bytes of data remain in the transmit FIFO, provided C3[5] is 0, or when only two 16-bit words or four 8-bit bytes of data remain in the transmit FIFO, provided C3[5] is 1. If FIFOMODE is not enabled, ignore this bit.                                                                                                          |
|              | NOTE: At an initial POR, the values of TNEAREF and RFIFOEF are 0. However, the status (S) register and both TX and RX FIFOs are reset due to a change of SPIMODE, FIFOMODE or SPE. If this type of reset occurs and FIFOMODE is 0, TNEAREF and RFIFOEF continue to reset to 0. If this type of reset occurs and FIFOMODE is 1, TNEAREF and RFIFOEF reset to 1.                            |
|              | <ul> <li>Transmit FIFO has more than 16 bits (when C3[5] is 0) or more than 32 bits (when C3[5] is 1) remaining to transmit</li> <li>Transmit FIFO has an amount of data equal to or less than 16 bits (when C3[5] is 0) or 32 bits (when C3[5] is 1) remaining to transmit</li> </ul>                                                                                                    |
| 1            | Transmit FIFO full flag                                                                                                                                                                                                                                                                                                                                                                   |
| TXFULLF      | This bit indicates the status of the transmit FIFO when FIFOMODE is enabled. This flag is set when there are 8 bytes in the transmit FIFO. If FIFOMODE is not enabled, ignore this bit.                                                                                                                                                                                                   |
|              | <ul> <li>Transmit FIFO has less than 8 bytes</li> <li>Transmit FIFO has 8 bytes of data</li> </ul>                                                                                                                                                                                                                                                                                        |
| 0            | SPI read FIFO empty flag                                                                                                                                                                                                                                                                                                                                                                  |
| RFIFOEF      | This bit indicates the status of the read FIFO when FIFOMODE is enabled. If FIFOMODE is not enabled, ignore this bit.                                                                                                                                                                                                                                                                     |
|              | NOTE: At an initial POR, the values of TNEAREF and RFIFOEF are 0. However, the status (S) register and both TX and RX FIFOs are reset due to a change of SPIMODE, FIFOMODE or SPE. If this type of reset occurs and FIFOMODE is 0, TNEAREF and RFIFOEF continue to reset to 0. If this type of reset occurs and FIFOMODE is 1, TNEAREF and RFIFOEF reset to 1.                            |
|              | <ul> <li>Read FIFO has data. Reads of the DH:DL registers in 16-bit mode or the DL register in 8-bit mode will empty the read FIFO.</li> <li>Read FIFO is empty.</li> </ul>                                                                                                                                                                                                               |

## 38.3.5 SPI data register high (SPIx\_DH)

Refer to the description of the DL register.

Addresses: SPI0\_DH is FFFF\_81A0h base + 4h offset = FFFF\_81A4h, SPI1\_DH is FFFF\_81B0h base + 4h offset = FFFF\_81B4h



## SPI0\_DH field descriptions

| Field             | Description      |
|-------------------|------------------|
| 7–0<br>Bits[15:8] | Data (high byte) |

# 38.3.6 SPI data register low (SPIx\_DL)

This register, together with the DH register, is both the input and output register for SPI data. A write to the registers writes to the transmit data buffer, allowing data to be queued and transmitted.

When the SPI is configured as a master, data queued in the transmit data buffer is transmitted immediately after the previous transmission has completed.

The SPTEF bit in the S register indicates when the transmit data buffer is ready to accept new data. When the transmit DMA request is disabled (TXDMAE is 0), the S register must be read when SPTEF is set before writing to the SPI data registers; otherwise, the write is ignored. When the transmit DMA request is enabled (TXDMAE is 1) when SPTEF is set, the SPI data registers can be written automatically by DMA without reading the S register first.

Data may be read from the SPI data registers any time after SPRF is set and before another transfer is finished. Failure to read the data out of the receive data buffer before a new transfer ends causes a receive overrun condition, and the data from the new transfer is lost. The new data is lost because the receive buffer still held the previous character and was not ready to accept the new data. There is no indication for a receive overrun condition, so the application system designer must ensure that previous data has been read from the receive buffer before a new transfer is initiated.

In 8-bit mode, only the DL register is available. Reads of the DH register return all zeros. Writes to the DH register are ignored.

#### **Register Definition**

In 16-bit mode, reading either byte (the DH or DL register) latches the contents of both bytes into a buffer where they remain latched until the other byte is read. Writing to either byte (the DH or DL register) latches the value into a buffer. When both bytes have been written, they are transferred as a coherent 16-bit value into the transmit data buffer.





## SPI0\_DL field descriptions

| Field            | Description     |
|------------------|-----------------|
| 7–0<br>Bits[7:0] | Data (low byte) |

## 38.3.7 SPI match register high (SPIx\_MH)

Refer to the description of the ML register.

Addresses: SPI0\_MH is FFFF\_81A0h base + 6h offset = FFFF\_81A6h, SPI1\_MH is FFFF\_81B0h base + 6h offset = FFFF\_81B6h



#### **SPIO MH field descriptions**

| Field             | Description                        |
|-------------------|------------------------------------|
| 7–0<br>Bits[15:8] | Hardware compare value (high byte) |

# 38.3.8 SPI match register low (SPIx\_ML)

This register, together with the MH register, contains the hardware compare value. When the value received in the SPI receive data buffer equals this hardware compare value, the SPI match flag (SPMF) sets.

In 8-bit mode, only the ML register is available. Reads of the MH register return all zeros. Writes to the MH register are ignored.

#### MCF51JF128 Reference Manual, Rev. 2, 03/2011

920

In 16-bit mode, reading either byte (the MH or ML register) latches the contents of both bytes into a buffer where they remain latched until the other byte is read. Writing to either byte (the MH or ML register) latches the value into a buffer. When both bytes have been written, they are transferred as a coherent value into the SPI match registers.

Addresses: SPI0\_ML is FFFF\_81A0h base + 7h offset = FFFF\_81A7h, SPI1\_ML is FFFF\_81B0h base + 7h offset = FFFF\_81B7h



## SPI0\_ML field descriptions

| Field            | Description                       |
|------------------|-----------------------------------|
| 7–0<br>Bits[7:0] | Hardware compare value (low byte) |

# 38.3.9 SPI control register 3 (SPIx\_C3)

This register introduces a 64-bit FIFO function on both transmit and receive buffers. It applies only for an instance of the SPI module that supports the FIFO feature.

FIFO mode is enabled by setting the FIFOMODE bit to 1. A write to this register occurs only when it sets the FIFOMODE bit to 1.

Using this FIFO feature allows the SPI to provide high speed transfers of large amounts of data without consuming large amounts of the CPU bandwidth.

Enabling this FIFO function affects the behavior of some of the read/write buffer flags in the S register as follows:

- The SPRF of the S register is 1 when the receive FIFO is filled. As a result:
  - If the RXDMAE bit in the C2 register is 1, SPRF generates a receive DMA request.
  - If the RXDMAE bit in the C2 register is 0 and the SPIE bit in the C1 register is 1, SPRF interrupts the CPU.
- The SPTEF of the S register is 1 when the transmit FIFO is empty. As a result:
  - If the TXDMAE bit in the C2 register is 1, SPTEF generates a transmit DMA request.
  - If the TXDMAE bit in the C2 register is 0 and the SPTIE bit in the C1 register is 1, SPTEF interrupts the CPU.

#### **Register Definition**

Two interrupt enable bits, TNEARIEN and RNFULLIEN, provide CPU interrupts based on the "watermark" feature of the TNEARF and RNFULLF flags of the S register.

Addresses: SPI0\_C3 is FFFF\_81A0h base + 8h offset = FFFF\_81A8h



## SPI0\_C3 field descriptions

| Field            | Description                                                                                                                                                |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–6<br>Reserved  | This read-only bitfield is reserved and always has the value zero.                                                                                         |
| 5                | Transmit FIFO nearly empty watermark                                                                                                                       |
| TNEAREF_<br>MARK | This bit selects the mark after which the TNEAREF flag is asserted.                                                                                        |
|                  | 0 TNEAREF is set when the transmit FIFO has 16 bits or less                                                                                                |
|                  | 1 TNEAREF is set when the transmit FIFO has 32 bits or less                                                                                                |
| 4                | Receive FIFO nearly full watermark                                                                                                                         |
| RNFULLF_<br>MARK | This bit selects the mark after which the RNFULLF flag is asserted.                                                                                        |
|                  | 0 RNFULLF is set when the receive FIFO has 48 bits or more                                                                                                 |
|                  | 1 RNFULLF is set when the receive FIFO has 32 bits or more                                                                                                 |
| 3                | Interrupt clearing mechanism select                                                                                                                        |
| INTCLR           | This bit selects the mechanism by which the SPRF, SPTEF, TNEAREF, and RNFULLF interrupts are cleared.                                                      |
|                  | 0 These interrupts are cleared when the corresponding flags are cleared depending on the state of the FIFOs                                                |
|                  | 1 These interrupts are cleared by writing the corresponding bits in the CI register                                                                        |
| 2                | Transmit FIFO nearly empty interrupt enable                                                                                                                |
| TNEARIEN         | Writing 1 to this bit enables the SPI to interrupt the CPU when the TNEAREF flag is set. This bit is ignored and has no function if the FIFOMODE bit is 0. |
|                  | 0 No interrupt upon TNEAREF being set                                                                                                                      |
|                  | 1 Enable interrupts upon TNEAREF being set                                                                                                                 |
| 1                | Receive FIFO nearly full interrupt enable                                                                                                                  |
| RNFULLIEN        | Writing 1 to this bit enables the SPI to interrupt the CPU when the RNEARFF flag is set. This bit is                                                       |
|                  | ignored and has no function if the FIFOMODE bit is 0.                                                                                                      |
|                  | 0 No interrupt upon RNEARFF being set                                                                                                                      |
|                  | 1 Enable interrupts upon RNEARFF being set                                                                                                                 |
| 0<br>FIFOMODE    | FIFO mode enable                                                                                                                                           |

Table continues on the next page...

## SPI0\_C3 field descriptions (continued)

| Fi | eld | Description                                                                                                         |
|----|-----|---------------------------------------------------------------------------------------------------------------------|
|    |     | This bit enables the SPI to use a 64-bit FIFO (8 bytes or four 16-bit words) for both transmit and receive buffers. |
|    |     | 0 Buffer mode disabled                                                                                              |
|    |     | 1 Data available in the receive data buffer                                                                         |

# 38.3.10 SPI clear interrupt register (SPIx\_CI)

This register applies only for an instance of the SPI module that supports the FIFO feature.

The register has four bits dedicated to clearing the interrupts. Writing 1 to these bits clears the corresponding interrupts if the INTCLR bit in the C3 register is 1. Reading these bits always returns 0.

This register also has two read-only bits to indicate the transmit FIFO and receive FIFO overrun conditions. When the receive FIFO is full and data is received, RXFOF is set. Similarly, when the transmit FIFO is full and a write to the data register occurs, TXFOF is set. These flags are cleared when the CI register is read while the flags are set.

The register has two more read-only bits to indicate the error flags. These flags are set when, due to some spurious reason, entries in the FIFO become greater than 8. At this point, all the flags in the status register are reset, and entries in the FIFO are flushed with the corresponding error flags set. These flags are cleared when the CI register is read while the flags are set.

Addresses: SPI0\_CI is FFFF\_81A0h base + 9h offset = FFFF\_81A9h



#### SPI0\_CI field descriptions

| Field       | Description                                                                                                             |
|-------------|-------------------------------------------------------------------------------------------------------------------------|
| 7<br>TXFERR | Transmit FIFO error flag  This flag indicates that a transmit FIFO error occurred because entries in the FIFO exceed 8. |
|             | No transmit FIFO error occurred     A transmit FIFO error occurred                                                      |

Table continues on the next page...

#### **Functional Description**

## SPI0\_CI field descriptions (continued)

| Field          | Description                                                                                                                    |
|----------------|--------------------------------------------------------------------------------------------------------------------------------|
| 6<br>RXFERR    | Receive FIFO error flag  This flag indicates that a receive FIFO error occurred because entries in the FIFO exceed 8.          |
|                | No receive FIFO error occurred     A receive FIFO error occurred                                                               |
| 5<br>TXFOF     | Transmit FIFO overflow flag  This flag indicates that a transmit FIFO overflow condition has occurred.                         |
|                | Transmit FIFO overflow condition has not occurred     Transmit FIFO overflow condition occurred                                |
| 4<br>RXFOF     | Receive FIFO overflow flag  This flag indicates that a receive FIFO overflow condition has occurred.                           |
|                | Receive FIFO overflow condition has not occurred     Receive FIFO overflow condition occurred                                  |
| 3<br>TNEAREFCI | Transmit FIFO nearly empty flag clear interrupt Writing 1 to this bit clears the TNEAREF interrupt provided that C3[3] is set. |
| 2<br>RNFULLFCI | Receive FIFO nearly full flag clear interrupt Writing 1 to this bit clears the RNFULLF interrupt provided that C3[3] is set.   |
| 1<br>SPTEFCI   | Transmit FIFO empty flag clear interrupt Writing 1 to this bit clears the SPTEF interrupt provided that C3[3] is set.          |
| 0<br>SPRFCI    | Receive FIFO full flag clear interrupt Writing 1 to this bit clears the SPRF interrupt provided that C3[3] is set.             |

# 38.4 Functional Description

This section provides the functional description of the module.

## **38.4.1** General

The SPI system is enabled by setting the SPI enable (SPE) bit in SPI Control Register 1. While the SPE bit is set, the four associated SPI port pins are dedicated to the SPI function as:

- Slave select  $(\overline{SS})$
- Serial clock (SPSCK)

- Master out/slave in (MOSI)
- Master in/slave out (MISO)

An SPI transfer is initiated in the master SPI device by reading the SPI status register (SPIx\_S) when SPTEF = 1 and then writing data to the transmit data buffer (write to SPIx\_DH:SPIx\_DL). When a transfer is complete, received data is moved into the receive data buffer. The SPIx\_DH:SPIx\_DL registers act as the SPI receive data buffer for reads and as the SPI transmit data buffer for writes.

The clock phase control bit (CPHA) and a clock polarity control bit (CPOL) in the SPI Control Register 1 (SPIx\_C1) select one of four possible clock formats to be used by the SPI system. The CPOL bit simply selects a non-inverted or inverted clock. The CPHA bit is used to accommodate two fundamentally different protocols by sampling data on odd numbered SPSCK edges or on even numbered SPSCK edges.

The SPI can be configured to operate as a master or as a slave. When the MSTR bit in SPI control register 1 is set, master mode is selected, when the MSTR bit is clear, slave mode is selected.

## 38.4.2 Master Mode

The SPI operates in master mode when the MSTR bit is set. Only a master SPI module can initiate transmissions. A transmission begins by reading the SPIx\_S register while SPTEF = 1 and writing to the master SPI data registers. If the shift register is empty, the byte immediately transfers to the shift register. The data begins shifting out on the MOSI pin under the control of the serial clock.

#### SPSCK

• The SPR3, SPR2, SPR1, and SPR0 baud rate selection bits in conjunction with the SPPR2, SPPR1, and SPPR0 baud rate preselection bits in the SPI Baud Rate register control the baud rate generator and determine the speed of the transmission. The SPSCK pin is the SPI clock output. Through the SPSCK pin, the baud rate generator of the master controls the shift register of the slave peripheral.

## • MOSI, MISO pin

- In master mode, the function of the serial data output pin (MOSI) and the serial data input pin (MISO) is determined by the SPC0 and BIDIROE control bits.
- $\overline{SS}$  pin

#### **Functional Description**

• If MODFEN and SSOE bit are set, the  $\overline{SS}$  pin is configured as slave select output. The  $\overline{SS}$  output becomes low during each transmission and is high when the SPI is in idle state. If MODFEN is set and SSOE is cleared, the  $\overline{SS}$  pin is configured as input for detecting mode fault error. If the SS input becomes low this indicates a mode fault error where another master tries to drive the MOSI and SPSCK lines. In this case, the SPI immediately switches to slave mode by clearing the MSTR bit and also disables the slave output buffer MISO (or SISO in bidirectional mode). As a result, all outputs are disabled, and SPSCK, MOSI and MISO are inputs. If a transmission is in progress when the mode fault occurs, the transmission is aborted and the SPI is forced into idle state. This mode fault error also sets the mode fault (MODF) flag in the SPI Status Register (SPIx\_S). If the SPI interrupt enable bit (SPIE) is set when the MODF flag gets set, then an SPI interrupt sequence is also requested. When a write to the SPI Data Register in the master occurs, there is a half SPSCK-cycle delay. After the delay, SPSCK is started within the master. The rest of the transfer operation differs slightly, depending on the clock format specified by the SPI clock phase bit, CPHA, in SPI Control Register 1 (see SPI Clock Formats).

#### **Note**

A change of the bits CPOL, CPHA, SSOE, LSBFE, MODFEN, SPC0, BIDIROE with SPC0 set, SPIMODE, FIFOMODE, SPPR2-SPPR0 and SPR3-SPR0 in master mode abort a transmission in progress and force the SPI into idle state. The remote slave cannot detect this, therefore the master has to ensure that the remote slave is set back to idle state.

## 38.4.3 Slave Mode

The SPI operates in slave mode when the MSTR bit in SPI Control Register1 is clear.

SPSCK

In slave mode, SPSCK is the SPI clock input from the master.

• MISO, MOSI pin

In slave mode, the function of the serial data output pin (MISO) and serial data input pin (MOSI) is determined by the SPC0 bit and BIDIROE bit in SPI Control Register 2.

•  $\overline{SS}$  pin

The  $\overline{SS}$  pin is the slave select input. Before a data transmission occurs, the  $\overline{SS}$  pin of the slave SPI must be low.  $\overline{SS}$  must remain low until the transmission is complete. If  $\overline{SS}$  goes high, the SPI is forced into idle state.

The  $\overline{SS}$  input also controls the serial data output pin, if  $\overline{SS}$  is high (not selected), the serial data output pin is high impedance, and, if  $\overline{SS}$  is low the first bit in the SPI Data Register is driven out of the serial data output pin. Also, if the slave is not selected ( $\overline{SS}$  is high), then the SPSCK input is ignored and no internal shifting of the SPI shift register takes place.

Although the SPI is capable of duplex operation, some SPI peripherals are capable of only receiving SPI data in a slave mode. For these simpler devices, there is no serial data out pin.

#### **Note**

When peripherals with duplex capability are used, take care not to simultaneously enable two receivers whose serial outputs drive the same system slave's serial data output line.

As long as no more than one slave device drives the system slave's serial data output line, it is possible for several slaves to receive the same transmission from a master, although the master would not receive return information from all of the receiving slaves.

If the CPHA bit in SPI Control Register 1 is clear, odd numbered edges on the SPSCK input cause the data at the serial data input pin to be latched. Even numbered edges cause the value previously latched from the serial data input pin to shift into the LSB or MSB of the SPI shift register, depending on the LSBFE bit.

If the CPHA bit is set, even numbered edges on the SPSCK input cause the data at the serial data input pin to be latched. Odd numbered edges cause the value previously latched from the serial data input pin to shift into the LSB or MSB of the SPI shift register, depending on the LSBFE bit.

When CPHA is set, the first edge is used to get the first data bit onto the serial data output pin. When CPHA is clear and the  $\overline{SS}$  input is low (slave selected), the first bit of the SPI data is driven out of the serial data output pin. After the eighth (SPIMODE = 0) or sixteenth (SPIMODE = 1) shift, the transfer is considered complete and the received data is transferred into the SPI data registers. To indicate transfer is complete, the SPRF flag in the SPI Status Register is set.

#### **Note**

A change of the bits CPOL, CPHA, SSOE, LSBFE, MODFEN, SPC0 and BIDIROE with SPC0 set FIFOMODE and SPIMODE in slave mode will corrupt a transmission in progress and has to be avoided.

## 38.4.4 SPI FIFO Mode

When the FIFO feature is supported: The SPI works in FIFO mode when the C3[FIFOMODE] bit is set. When the module is in FIFO mode, the SPI RX buffer and SPI TX buffer are replaced by an 8-byte-deep FIFO, as the following figures show.



Figure 38-34. SPIH:L read side structural overview in FIFO mode

#### **Chapter 38 Serial Peripheral Interface (SPI)**



Figure 38-35. SPIH:L write side structural overview in FIFO mode

# 38.4.5 SPI Transmission by DMA

SPI supports both Transmit and Receive by DMA. The basic flow of SPI transmission by DMA is as below.



Figure 38-36. Basic Flow of SPI Transmission by DMA

## 38.4.5.1 Transmit by DMA

Transmit by DMA is supported only when TXDMAE is set. A transmit DMA request is asserted when both SPE and SPTEF are set. Then the on-chip DMA controller detects this request and transfers data from memory into the SPI data register. After that, TX DMA DONE is asserted to clear SPTEF automatically. This process repeats until all data for transmission (the number is decided by the configuration register[s] of the DMA controller) is sent.

When the FIFO feature is supported: In FIFO mode (FIFOMODE=1) and when a data length of 8 bits is selected (SPIMODE=0), the DMA transfer for one transmit DMA request can write more than 1 byte (up to 8 bytes) to the DL register because the TX FIFO can store 8 bytes of transmit data. In FIFO mode (FIFOMODE=1) and when a data length of 16 bits is selected (SPIMODE=1), the DMA transfer for one transmit DMA request can write more than 1 word (up to 4 words) to the DH:DL registers because the TX FIFO can store 4 words of transmit data. A larger number of bytes or words transferred from memory to the SPI data register for each transmit DMA request results in a lower total number of transmit DMA requests.

When the FIFO feature is supported and FIFOMODE is 0: After DMA transfers the first byte to the SPI data register, the SPI pushes this data into the shifter, thereby making SPTEF high again. This generates another DMA request immediately, but the CPU lacks enough time to service the first DMA interrupt service request (ISR). The subsequent DMA request is paced at the SPI transfer rate. Manage this behavior during the first byte transfer through the DMA channel. Write the first byte to the SPI data register via the CPU. The other bytes are transmitted by the DMA.



Figure 38-37. Recommended startup of SPI transmit by DMA

# **38.4.5.2** Receive by DMA

Receive by DMA is supported only when RXDMAE is set. A receive DMA request is asserted when both SPE and SPRF are set. Then the on-chip DMA controller detects this request and transfers data from the SPI data register into memory. After that, RX DMA DONE is asserted to clear SPRF automatically. This process repeats until all data to be received (the number is decided by configuration register[s] of the DMA controller) is received or no receive DMA request is generated again because the SPI transmission is finished.

When the FIFO feature is supported: In FIFO mode (FIFOMODE=1) and when a data length of 8 bits is selected (SPIMODE=0), the DMA transfer for one receive DMA request can read more than 1 byte (up to 8 bytes) from the SPI data register because the RX FIFO is full with 8 bytes. In FIFO mode (FIFOMODE=1) and when a data length of 16 bits is selected (SPIMODE=1), the DMA transfer for one receive DMA request can read more than 1 word (up to 4 words) from the DH:DL registers because the RX FIFO is

#### **Functional Description**

full with 4 words. A larger number of bytes or words transferred from the SPI data register to memory for one receive DMA request results in a lower total number of receive DMA requests.

# 38.4.6 Data Transmission Length

The SPI can support data lengths of 8 or 16 bits. The length can be configured with the SPIMODE bit in the SPIx\_C2 register.

In 8-bit mode (SPIMODE = 0), the SPI Data Register is comprised of one byte: SPIx\_DL. The SPI Match Register is also comprised of only one byte: SPIx\_ML. Reads of SPIx\_DH and SPIx\_MH will return zero. Writes to SPIx\_DH and SPIx\_MH will be ignored.

In 16-bit mode (SPIMODE = 1), the SPI Data Register is comprised of two bytes: SPIx\_DH and SPIx\_DL. Reading either byte (SPIx\_DH or SPIx\_DL) latches the contents of both bytes into a buffer where they remain latched until the other byte is read. Writing to either byte (SPIx\_DH or SPIx\_DL) latches the value into a buffer. When both bytes have been written, they are transferred as a coherent 16-bit value into the transmit data buffer.

In 16-bit mode, the SPI Match Register is also comprised of two bytes: SPIx\_MH and SPIx\_ML. There is no buffer mechanism for the reading of SPIxMH and SPIxML since they can only be changed by writing at CPU side. Writing to either byte (SPIx\_MH or SPIx\_ML) latches the value into a buffer. When both bytes have been written, they are transferred as a coherent 16-bit value into the SPI Match Register.

Any switching between 8- and 16-bit data transmission length (controlled by SPIMODE bit) in master mode will abort a transmission in progress, force the SPI system into idle state, and reset all status bits in the SPIx\_S register. To initiate a transfer after writing to SPIMODE, the SPIx\_S register must be read with SPTEF = 1, and data must be written to SPIx\_DH:SPIx\_DL in 16-bit mode (SPIMODE = 1) or SPIx\_DL in 8-bit mode (SPIMODE = 0).

In slave mode, user software should write to SPIMODE only once to prevent corrupting a transmission in progress.

#### Note

Data can be lost if the data length is not the same for both master and slave devices.

## 38.4.7 SPI Clock Formats

To accommodate a wide variety of synchronous serial peripherals from different manufacturers, the SPI system has a clock polarity (CPOL) bit and a clock phase (CPHA) control bit to select one of four clock formats for data transfers. CPOL selectively inserts an inverter in series with the clock. CPHA chooses between two different clock phase relationships between the clock and data.

The following figure shows the clock formats when SPIMODE = 0 (8-bit mode) and CPHA = 1. At the top of the figure, the eight bit times are shown for reference with bit 1 starting at the first SPSCK edge and bit 8 ending one-half SPSCK cycle after the eighth SPSCK edge. The MSB first and LSB first lines show the order of SPI data bits depending on the setting in LSBFE. Both variations of SPSCK polarity are shown, but only one of these waveforms applies for a specific transfer, depending on the value in CPOL. The SAMPLE IN waveform applies to the MOSI input of a slave or the MISO input of a master. The MOSI waveform applies to the MOSI output pin from a master and the MISO waveform applies to the MISO output from a slave. The  $\overline{SS}$  OUT waveform applies to the slave select output from a master (provided MODFEN and SSOE = 1). The master  $\overline{SS}$  output goes to active low one-half SPSCK cycle before the start of the transfer and goes back high at the end of the eighth bit time of the transfer. The  $\overline{SS}$  IN waveform applies to the slave select input of a slave.





Figure 38-38. SPI Clock Formats (CPHA = 1)

When CPHA = 1, the slave begins to drive its MISO output when  $\overline{SS}$  goes to active low, but the data is not defined until the first SPSCK edge. The first SPSCK edge shifts the first bit of data from the shifter onto the MOSI output of the master and the MISO output of the slave. The next SPSCK edge causes both the master and the slave to sample the data bit values on their MISO and MOSI inputs, respectively. At the third SPSCK edge, the SPI shifter shifts one bit position which shifts in the bit value that was just sampled, and shifts the second data bit value out the other end of the shifter to the MOSI and MISO outputs of the master and slave, respectively. When CPHA = 1, the slave's  $\overline{SS}$  input is not required to go to its inactive high level between transfers.

The following figure shows the clock formats when SPIMODE = 0 and CPHA = 0. At the top of the figure, the eight bit times are shown for reference with bit 1 starting as the slave is selected ( $\overline{SS}$  IN goes low), and bit 8 ends at the last SPSCK edge. The MSB first and LSB first lines show the order of SPI data bits depending on the setting in LSBFE. Both variations of SPSCK polarity are shown, but only one of these waveforms applies for a specific transfer, depending on the value in CPOL. The SAMPLE IN waveform applies to the MOSI input of a slave or the MISO input of a master. The MOSI waveform

applies to the MOSI output pin from a master and the MISO waveform applies to the MISO output from a slave. The  $\overline{SS}$  OUT waveform applies to the slave select output from a master (provided MODFEN and SSOE = 1). The master  $\overline{SS}$  output goes to active low at the start of the first bit time of the transfer and goes back high one-half SPSCK cycle after the end of the eighth bit time of the transfer. The  $\overline{SS}$  IN waveform applies to the slave select input of a slave.



Figure 38-39. SPI Clock Formats (CPHA = 0)

When CPHA = 0, the slave begins to drive its MISO output with the first data bit value (MSB or LSB depending on LSBFE) when  $\overline{SS}$  goes to active low. The first SPSCK edge causes both the master and the slave to sample the data bit values on their MISO and MOSI inputs, respectively. At the second SPSCK edge, the SPI shifter shifts one bit position which shifts in the bit value that was just sampled and shifts the second data bit value out the other end of the shifter to the MOSI and MISO outputs of the master and slave, respectively. When CPHA = 0, the slave's  $\overline{SS}$  input must go to its inactive high level between transfers.

## 38.4.8 SPI Baud Rate Generation

As shown in the following figure, the clock source for the SPI baud rate generator is the bus clock. The three prescale bits (SPPR2:SPPR1:SPPR0) choose a prescale divisor of 1, 2, 3, 4, 5, 6, 7, or 8. The three rate select bits (SPR3:SPR2:SPR1:SPR0) divide the output of the prescaler stage by 2, 4, 8, 16, 32, 64, 128, 256, or 512 to get the internal SPI master mode bit-rate clock.

The baud rate generator is activated only when the SPI is in the master mode and a serial transfer is taking place. In the other cases, the divider is disabled to decrease I<sub>DD</sub> current.

The baud rate divisor equation is as follows (except those reserved combinations in the SPI Baud Rate Divisor table).

```
BaudRateDivisor = (SPPR + 1) \times 2 (SPR + 1)
```

The baud rate can be calculated with the following equation:

BaudRate = BusClock / BaudRateDivisor



Figure 38-40. SPI Baud Rate Generation

# 38.4.9 Special Features

The following section shows the module special features.

# 38.4.9.1 **SS** Output

The  $\overline{SS}$  output feature automatically drives the  $\overline{SS}$  pin low during transmission to select external devices and drives the  $\overline{SS}$  pin high during idle to deselect external devices. When the  $\overline{SS}$  output is selected, the  $\overline{SS}$  output pin is connected to the  $\overline{SS}$  input pin of the external device.

The  $\overline{SS}$  output is available only in master mode during normal SPI operation by asserting the SSOE and MODFEN bits as shown in the description of the C1[SSOE] bit.

The mode fault feature is disabled while  $\overline{SS}$  output is enabled.

#### **Note**

Be careful when using the  $\overline{SS}$  output feature in a multimaster system because the mode fault feature is not available for detecting system errors between masters.

## 38.4.9.2 Bidirectional Mode (MOMI or SISO)

The bidirectional mode is selected when the SPC0 bit is set in SPI Control Register 2 (see the following table). In this mode, the SPI uses only one serial data pin for the interface with one or more external devices. The MSTR bit decides which pin to use. The MOSI pin becomes the serial data I/O (MOMI) pin for the master mode, and the MISO pin becomes serial data I/O (SISO) pin for the slave mode. The MISO pin in master mode and MOSI pin in slave mode are not used by the SPI.



Table 38-34. Normal Mode and Bidirectional Mode

The direction of each serial I/O pin depends on the BIDIROE bit. If the pin is configured as an output, serial data from the shift register is driven out on the pin. The same pin is also the serial input to the shift register.

The SPSCK is an output for the master mode and an input for the slave mode.

 $\overline{SS}$  is the input or output for the master mode, and it is always the input for the slave mode.

The bidirectional mode does not affect SPSCK and  $\overline{SS}$  functions.

#### **Note**

In bidirectional master mode, with the mode fault feature enabled, both data pins MISO and MOSI can be occupied by the SPI, though MOSI is normally used for transmissions in bidirectional mode and MISO is not used by the SPI. If a mode

#### **Functional Description**

fault occurs, the SPI is automatically switched to slave mode. In this case, MISO becomes occupied by the SPI and MOSI is not used. Consider this scenario if the MISO pin is used for another purpose.

## 38.4.10 Error Conditions

The SPI module has one error condition: the mode fault error.

#### 38.4.10.1 Mode Fault Error

If the  $\overline{SS}$  input becomes low while the SPI is configured as a master, it indicates a system error where more than one master may be trying to drive the MOSI and SPSCK lines simultaneously. This condition is not permitted in normal operation, and it sets the MODF bit in the SPI status register automatically provided that the MODFEN bit is set.

In the special case where the SPI is in master mode and the MODFEN bit is cleared, the  $\overline{SS}$  pin is not used by the SPI. In this special case, the mode fault error function is inhibited and MODF remains cleared. If the SPI system is configured as a slave, the  $\overline{SS}$  pin is a dedicated input pin. A mode fault error does not occur in slave mode.

If a mode fault error occurs, the SPI is switched to slave mode, with the exception that the slave output buffer is disabled. So the SPSCK, MISO and MOSI pins are forced to be high impedance inputs to avoid any possibility of conflict with another output driver. A transmission in progress is aborted and the SPI is forced into idle state.

If the mode fault error occurs in the bidirectional mode for an SPI system configured in master mode, the output enable of MOMI (MOSI in bidirectional mode) is cleared if it was set. No mode fault error occurs in the bidirectional mode for the SPI system configured in slave mode.

The mode fault flag is cleared automatically by a read of the SPI Status Register (with MODF set) followed by a write to SPI Control Register 1. If the mode fault flag is cleared, the SPI becomes a normal master or slave again.

## 38.4.11 Low Power Mode Options

This section describes the low power mode options.

## 38.4.11.1 SPI in Run Mode

In run mode with the SPI system enable (SPE) bit in the SPI control register clear, the SPI system is in a low-power, disabled state. SPI registers can still be accessed, but clocks to the core of this module are disabled.

#### 38.4.11.2 SPI in Wait Mode

SPI operation in wait mode depends upon the state of the SPISWAI bit in SPI Control Register 2.

- If SPISWAI is clear, the SPI operates normally when the CPU is in wait mode.
- If SPISWAI is set, SPI clock generation ceases and the SPI module enters a power conservation state when the CPU is in wait mode.
  - If SPISWAI is set and the SPI is configured for master, any transmission and reception in progress stops at wait mode entry. The transmission and reception resumes when the SPI exits wait mode.
  - If SPISWAI is set and the SPI is configured as a slave, any transmission and reception in progress continues if the SPSCK continues to be driven from the master. This keeps the slave synchronized to the master and the SPSCK.

If the master transmits data while the slave is in wait mode, the slave continues to send data consistent with the operation mode at the start of wait mode (that is, if the slave is currently sending its SPIx\_DH:SPIx\_DL to the master, it continues to send the same byte. Otherwise, if the slave is currently sending the last data received byte from the master, it continues to send each previously received data from the master byte).

#### **Note**

Care must be taken when expecting data from a master while the slave is in a wait mode or a stop mode where the peripheral bus clock is stopped but internal logic states are retained. Even though the shift register continues to operate, the rest of the SPI is shut down (that is, an SPRF interrupt is not generated until an exit from stop or wait mode). Also, the data from the shift register is not copied into the SPIx\_DH:SPIx\_DL registers until after the slave SPI has exited wait or stop mode. An SPRF flag and SPIx\_DH:SPIx\_DL copy is only generated if wait mode is

#### **Functional Description**

entered or exited during a transmission. If the slave enters wait mode in idle mode and exits wait mode in idle mode, neither an SPRF nor a SPIx\_DH:SPIx\_DL copy occurs.

# 38.4.11.3 SPI in Stop Mode

Operation in a stop mode where the peripheral bus clock is stopped but internal logic states are retained depends on the SPI system. The stop mode does not depend on the SPISWAI bit. Upon entry to this type of stop mode, the SPI module clock is disabled (held high or low).

- If the SPI is in master mode and exchanging data when the CPU enters the stop mode, the transmission is frozen until the CPU exits stop mode. After the exit from stop mode, data to and from the external SPI is exchanged correctly.
- In slave mode, the SPI remains synchronized with the master.

The SPI is completely disabled in a stop mode where the peripheral bus clock is stopped and internal logic states are not retained. After an exit from this type of stop mode, all registers are reset to their default values, and the SPI module must be re-initialized.

## 38.4.12 Reset

The reset values of registers and signals are described in Register Definition, which details the registers and their bitfields.

- If a data transmission occurs in slave mode after a reset without a write to SPIx\_DH:SPIx\_DL, the transmission consists of "garbage" or the data last received from the master before the reset.
- Reading from SPIx\_DH:SPIx\_DL after reset always returns zeros.

# **38.4.13 Interrupts**

The SPI originates interrupt requests only when the SPI is enabled (the SPE bit in the SPIx\_C1 register is set). The following is a description of how the SPI makes a request and how the MCU should acknowledge that request. The interrupt vector offset and interrupt priority are chip dependent.

Four flag bits, three interrupt mask bits, and one interrupt vector are associated with the SPI system. The SPI interrupt enable mask (SPIE) enables interrupts from the SPI receiver full flag (SPRF) and mode fault flag (MODF). The SPI transmit interrupt enable

mask (SPTIE) enables interrupts from the SPI transmit buffer empty flag (SPTEF). The SPI match interrupt enable mask bit (SPIMIE) enables interrupts from the SPI match flag (SPMF). When one of the flag bits is set, and the associated interrupt mask bit is set, a hardware interrupt request is sent to the CPU. If the interrupt mask bits are cleared, software can poll the associated flag bits instead of using interrupts. The SPI interrupt service routine (ISR) should check the flag bits to determine which event caused the interrupt. The service routine should also clear the flag bit(s) before returning from the ISR (usually near the beginning of the ISR).

### 38.4.13.1 MODF

MODF occurs when the master detects an error on the SS pin. The master SPI must be configured for the MODF feature (see the description of the C1[SSOE] bit). Once MODF is set, the current transfer is aborted and the master (MSTR) bit in the SPIx\_C1 register resets to 0.

The MODF interrupt is reflected in the status register's MODF flag. Clearing the flag also clears the interrupt. This interrupt stays active while the MODF flag is set. MODF has an automatic clearing process that is described in the SPI Status Register.

## 38.4.13.2 SPRF

SPRF occurs when new data has been received and copied to the SPI receive data buffer. In 8-bit mode, SPRF is set only after all 8 bits have been shifted out of the shift register and into SPIx\_DL. In 16-bit mode, SPRF is set only after all 16 bits have been shifted out of the shift register and into SPIx\_DH:SPIx\_DL.

Once SPRF is set, it does not clear until it is serviced. SPRF has an automatic clearing process which is described in the SPI Status Register (SPIxS). In the event that the SPRF is not serviced before the end of the next transfer (i.e. SPRF remains active throughout another transfer), the latter transfers will be ignored and no new data will be copied into the SPIx\_DH:SPIx\_DL.

## 38.4.13.3 SPTEF

SPTEF occurs when the SPI transmit buffer is ready to accept new data. In 8-bit mode, SPTEF is set only after all 8 bits have been moved from SPIx\_DL into the shifter. In 16-bit mode, SPTEF is set only after all 16 bits have been moved from SPIx\_DH:SPIx\_DL into the shifter.

#### **Initialization/Application Information**

Once SPTEF is set, it does not clear until it is serviced. SPTEF has an automatic clearing process which is described in the SPI Status Register (SPIxS).

### 38.4.13.4 SPMF

SPMF occurs when the data in the receive data buffer is equal to the data in the SPI match register. In 8-bit mode, SPMF is set only after bits 7–0 in the receive data buffer are determined to be equivalent to the value in SPIx\_ML. In 16-bit mode, SPMF is set after bits 15–0 in the receive data buffer are determined to be equivalent to the value in SPIx\_MH:SPIx\_ML.

#### 38.4.13.5 TNEAREF

The TNEAREF bit applies when the FIFO feature is supported.

The TNEAREF flag is set when only one 16-bit word or two 8-bit bytes of data remain in the transmit FIFO provided C3[5] = 0 or when only two 16-bit words or four 8-bit bytes of data remain in the transmit FIFO provided C3[5] = 1. If FIFOMODE is not enabled, ignore this bit.

Clearing this interrupt depends on the state of C3[3] and the status of TNEAREF. Refer to the description of the SPI status (S) register.

## 38.4.13.6 RNFULLF

The RNFULLF bit applies when the FIFO feature is supported.

RNFULLF is set when more than three 16-bit words or six 8-bit bytes of data remain in the receive FIFO provided C3[4] = 0 or when more than two 16-bit words or four 8-bit bytes of data remain in the receive FIFO provided C3[4] = 1.

Clearing this interrupt depends on the state of C3[3] and the status of RNFULLF. Refer to the description of the SPI status (S) register.

# 38.5 Initialization/Application Information

This section discusses an example of how to initialize and use the SPI.

# 38.5.1 Initialization Sequence

Before the SPI module can be used for communication, an initialization procedure must be carried out, as follows:

- 1. Update control register 1 (SPIx\_C1) to enable the SPI and to control interrupt enables. This register also sets the SPI as master or slave, determines clock phase and polarity, and configures the main SPI options.
- 2. Update control register 2 (SPIx\_C2) to enable additional SPI functions such as the SPI match interrupt feature, the master mode-fault function, and bidirectional mode output. 8- or 16-bit mode select and other optional features are controlled here as well.
- 3. Update the baud rate register (SPIx\_BR) to set the prescaler and bit rate divisor for an SPI master.
- 4. Update the hardware match register (SPIx\_MH:SPIx\_ML) with the value to be compared to the receive data register for triggering an interrupt if hardware match interrupts are enabled.
- 5. In the master, read SPIx\_S while SPTEF = 1, and then write to the transmit data register (SPIx\_DH:SPIx\_DL) to begin transfer.

## 38.5.2 Pseudo-Code Example

In this example, the SPI module will be set up for master mode with only hardware match interrupts enabled. The SPI will run in 16-bit mode at a maximum baud rate of bus clock divided by 2. Clock phase and polarity will be set for an active-high SPI clock where the first edge on SPSCK occurs at the start of the first cycle of a data transfer.

| SPIx_C1=0x54(%010101 | 100)  |   |   |                                                           |
|----------------------|-------|---|---|-----------------------------------------------------------|
| Bit 7                | SPIE  | = | 0 | Disables receive and mode fault interrupts                |
| Bit 6                | SPE   | = | 1 | Enables the SPI system                                    |
| Bit 5                | SPTIE | = | 0 | Disables SPI transmit interrupts                          |
| Bit 4                | MSTR  | = | 1 | Sets the SPI module as a master SPI device                |
| Bit 3                | CPOL  | = | 0 | Configures SPI clock as active-high                       |
| Bit 2                | СРНА  | = | 1 | First edge on SPSCK at start of first data transfer cycle |
| Bit 1                | SSOE  | = | 0 | Determines SS pin function when mode fault enabled        |
| Bit 0                | LSBFE | = | 0 | SPI serial data transfers start with most significant bit |

#### Initialization/Application Information

| SPIx_C2 = 0xC0(%11000 | 0000)   |   |   |                                              |
|-----------------------|---------|---|---|----------------------------------------------|
| Bit 7                 | SPMIE   | = | 1 | SPI hardware match interrupt enabled         |
| Bit 6                 | SPIMODE | = | 1 | Configures SPI for 16-bit mode               |
| Bit 5                 | TXDMAE  | = | 0 | DMA request disabled                         |
| Bit 4                 | MODFEN  | = | 0 | Disables mode fault function                 |
| Bit 3                 | BIDIROE | = | 0 | SPI data I/O pin acts as input               |
| Bit 2                 | RXDMAE  | = | 0 | DMA request disabled                         |
| Bit 1                 | SPISWAI | = | 0 | SPI clocks operate in wait mode              |
| Bit 0                 | SPC0    | = | 0 | uses separate pins for data input and output |

| SPIx_BR = 0x00(%00000000) |   |          |                             |
|---------------------------|---|----------|-----------------------------|
| Bit 7                     | = | 0        | Reserved                    |
| Bit 6:4                   | = | 000      | Sets prescale divisor to 1  |
| Bit 3:0                   | = | 000<br>0 | Sets baud rate divisor to 2 |

| SPIx_S = 0x00(%00000000) |                                                |   |   |                                                                                    |
|--------------------------|------------------------------------------------|---|---|------------------------------------------------------------------------------------|
| Bit 7                    | SPRF                                           | = | 0 | Flag is set when receive data buffer is full                                       |
| Bit 6                    | SPMF                                           | = | 0 | Flag is set when SPIMH/L = receive data buffer                                     |
| Bit 5                    | SPTEF                                          | = | 0 | Flag is set when transmit data buffer is empty                                     |
| Bit 4                    | MODF                                           | = | 0 | Mode fault flag for master mode                                                    |
| Bit 3:0                  | RNFULLF,<br>TNEARF,<br>TXFULLF, and<br>RFIFOEF | = | 0 | Reserved (when FIFOMODE is not present or is 0) or FIFO flags (when FIFOMODE is 1) |
| Bit 3:0                  |                                                | = | 0 | FIFOMODE is not enabled                                                            |

#### $SPIx\_MH = 0xXX$

In 16-bit mode, this register holds bits 8–15 of the hardware match buffer. In 8-bit mode, writes to this register will be ignored.

#### $SPIx_ML = 0xXX$

Holds bits 0-7 of the hardware match buffer.

#### $SPIx_DH = 0xxx$

In 16-bit mode, this register holds bits 8–15 of the data to be transmitted by the transmit buffer and received by the receive buffer.

#### $SPIx_DL = 0xxx$

Holds bits 0-7 of the data to be transmitted by the transmit buffer and received by the receive buffer.



Figure 38-41. Initialization Flowchart Example for SPI Master Device in 16-bit Mode for FIFOMODE = 0



Figure 38-42. Initialization Flowchart Example for SPI Master Device in 16-bit Mode for FIFOMODE=1

# Chapter 39 Universal Serial Bus (USB) Controller

## 39.1 Introduction

This section describes the USB. The OTG implementation in this module provides limited host functionality as well as device solutions for implementing a USB 2.0 full-speed/low-speed compliant peripheral. The OTG implementation supports the On-The-Go (OTG) addendum to the USB 2.0 Specification. Only one protocol can be active at any time. A negotiation protocol must be used to switch to a USB host functionality from a USB device. This is known as the Master Negotiation Protocol (MNP).

## 39.1.1 USB

The USB is a cable bus that supports data exchange between a host computer and a wide range of simultaneously accessible peripherals. The attached peripherals share USB bandwidth through a host-scheduled, token-based protocol. The bus allows peripherals to be attached, configured, used, and detached while the host and other peripherals are in operation.

USB software provides a uniform view of the system for all application software, hiding implementation details making application software more portable. It manages the dynamic attach and detach of peripherals.

There is only one host in any USB system. The USB interface to the host computer system is referred to as the Host Controller.

There may be multiple USB devices in any system such as joysticks, speakers, printers, etc. USB devices present a standard USB interface in terms of comprehension, response, and standard capability.

#### Introduction

The host initiates transactions to specific peripherals, while the device responds to control transactions. The device sends and receives data to and from the host using a standard USB data format. USB 2.0 full-speed /low-speed peripherals operate at 12Mb/s or 1.5 Mb/s.

For additional information, refer to the USB 2.0 specification.



Figure 39-1. Example USB 2.0 System Configuration

# 39.1.2 USB On-The-Go

USB (Universal Serial Bus) is a popular standard for connecting peripherals and portable consumer electronic devices such as digital cameras and hand-held computers to host PCs. The On-The-Go (OTG) Supplement to the USB Specification extends USB to peer-to-peer application. Using USB OTG technology consumer electronics, peripherals and portable devices can connect to each other (for example, a digital camera can connect directly to a printer, or a keyboard can connect to a Personal Digital Assistant) to exchange data.

With the USB On-The-Go product, you can develop a fully USB-compliant peripheral device that can also assume the role of a USB host. Software determines the role of the device based on hardware signals, and then initializes the device in the appropriate mode of operation (host or peripheral) based on how it is connected. After connecting the devices can negotiate using the OTG protocols to assume the role of host or peripheral based on the task to be accomplished.

For additional information, refer to the *On-The-Go Supplement to the USB 2.0 Specification*.



Figure 39-2. Example USB 2.0 On-The-Go Configurations

## 39.1.3 USB-FS Features

- USB 1.1 and 2.0 compliant full-speed device controller
- 16-Bidirectional end points
- DMA or FIFO data stream interfaces
- Low-power consumption
- On-The-Go protocol logic

# 39.2 Functional Description

The USB-FS 2.0 full-speed/low-speed module communicates with the processor core through status registers, control registers, and data structures in memory.

**Programmers Interface** 

## 39.2.1 Data Structures

The function of the device operation is to transfer a request in the memory image to and from the Universal Serial Bus. To efficiently manage USB endpoint communications the USB-FS implements a Buffer Descriptor Table (BDT) in system memory. See Figure 39-3.

# 39.3 Programmers Interface

This section discusses the major components of the programming model for the USB module.

# 39.3.1 Buffer Descriptor Table

To efficiently manage USB endpoint communications the USB-FS implements a Buffer Descriptor Table (BDT) in system memory. The BDT resides on a 512 byte boundary in system memory and is pointed to by the BDT Page Registers. Every endpoint direction requires two eight-byte Buffer Descriptor entries. Therefore, a system with 16 fully bidirectional endpoints would require 512 bytes of system memory to implement the BDT. The two Buffer Descriptor (BD) entries allows for an EVEN BD and ODD BD entry for each endpoint direction. This allows the microprocessor to process one BD while the USB-FS is processing the other BD. Double buffering BDs in this way allows the USB-FS to easily transfer data at the maximum throughput provided by USB.

The software API intelligently manages buffers for the USB-FS by updating the BDT when needed. This allows the USB-FS to efficiently manage data transmission and reception, while the microprocessor performs communication overhead processing and other function dependent applications. Because the buffers are shared between the microprocessor and the USB-FS a simple semaphore mechanism is used to distinguish who is allowed to update the BDT and buffers in system memory. A semaphore bit, the OWN bit, is cleared to 0 when the BD entry is owned by the microprocessor. The microprocessor is allowed read and write access to the BD entry and the buffer in system memory when the OWN bit is 0. When the OWN bit is set to 1, the BD entry and the buffer in system memory are owned by the USB-FS. The USB-FS now has full read and write access and the microprocessor should not modify the BD or its corresponding data buffer. The BD also contains indirect address pointers to where the actual buffer resides in system memory. This indirect address mechanism is shown in the following diagram.



Figure 39-3. Buffer Descriptor Table

# 39.3.2 Rx vs. Tx as a USB Target Device or USB Host

The USB-FS core uses software control to switch between two modes of operation:

- USB target device
- USB hosts

In either mode, USB host or USB target device, the same data paths and buffer descriptors are used for the transmission and reception of data. For this reason, a USB-FS core centric nomenclature is used to describe the direction of the data transfer between the USB-FS core and the USB:

#### Rx (or receive)

describes transfers that move data from the USB to memory.

#### Tx (or transmit)

describes transfers that move data from memory to the USB.

The following table shows how the data direction corresponds to the USB token type in host and target device applications.

Table 39-1. Data Direction for USB Host or USB Target

|        | Rx           | Тх |
|--------|--------------|----|
| Device | OUT or Setup | IN |

Table continues on the next page...

#### **Programmers Interface**

Table 39-1. Data Direction for USB Host or USB Target (continued)

|      | Rx | Tx           |
|------|----|--------------|
| Host | IN | Out or Setup |

# 39.3.3 Addressing Buffer Descriptor Table Entries

An understanding of the addressing mechanism of the Buffer Descriptor Table is useful when accessing endpoint data via the USB-FS or microprocessor. Some points of interest are:

- The Buffer Descriptor Table occupies up to 512 bytes of system memory.
- 16 bidirectional endpoints can be supported with a full BDT of 512 bytes.
- 16 bytes are needed for each USB endpoint direction.
- Applications with less than 16 endpoints require less RAM to implement the BDT.
- The BDT Page Registers point to the starting location of the BDT.
- The BDT must be located on a 512-byte boundary in system memory.
- All enabled TX and RX endpoint BD entries are indexed into the BDT to allow easy access via the USB-FS or MCU core.

When a USB token on an enabled endpoint is received, the USB-FS uses its integrated DMA controller to interrogate the BDT. The USB-FS reads the corresponding endpoint BD entry to determine if it owns the BD and corresponding buffer in system memory.

To compute the entry point in to the BDT, the BDT\_PAGE registers is concatenated with the current endpoint and the TX and ODD fields to form a 32-bit address. This address mechanism is shown in the following diagrams:

Table 39-2. BDT Address Calculation Fields

| Field     | Description                                                                                                                               |
|-----------|-------------------------------------------------------------------------------------------------------------------------------------------|
| BDT_PAGE  | BDT_PAGE registers in the Control Register Block                                                                                          |
| END_POINT | END POINT field from the USB TOKEN                                                                                                        |
| TX        | 1 for an TX transmit transfers and 0 for an RX receive transfers                                                                          |
| ODD       | This bit is maintained within the USB-FS SIE. It corresponds to the buffer currently in use. The buffers are used in a ping-pong fashion. |

# 39.3.4 Buffer Descriptor Formats

The Buffer Descriptors (BD) provide endpoint buffer control information for the USB-FS and microprocessor. The Buffer Descriptors have different meaning based on whether it is the USB-FS or microprocessor reading the BD in memory.

The USB-FS Controller uses the data stored in the BDs to determine:

- Who owns the buffer in system memory
- Data0 or Data1 PID
- Release Own upon packet completion
- No address increment (FIFO Mode)
- Data toggle synchronization enable
- How much data is to be transmitted or received
- Where the buffer resides in system memory

While the microprocessor uses the data stored in the BDs to determine:

- Who owns the buffer in system memory
- Data0 or Data1 PID
- The received TOKEN PID
- · How much data was transmitted or received
- Where the buffer resides in system memory

The format for the BD is shown in the following figure.

**Table 39-3. Buffer Descriptor Byte Format** 

| 31:26                    | 25:16     | 15:8 | 7     | 6       | 5          | 4          | 3          | 2          | 1 | 0 |
|--------------------------|-----------|------|-------|---------|------------|------------|------------|------------|---|---|
| RSVD                     | ВС        | RSVD | OWN   | DATA0/1 | KEEP/      | NINC/      | DTS/       | BDT_STALL/ | 0 |   |
| NOVD                     | (10 bits) | NOVD | OVVIN | DATAU/T | TOK_PID[3] | TOK_PID[2] | TOK_PID[1] | TOK_PID[0] | 0 |   |
| Buffer Address (32-Bits) |           |      |       |         |            |            |            |            |   |   |

Table 39-4. Buffer Descriptor Byte Fields

| Field   | Description                                                                                     |
|---------|-------------------------------------------------------------------------------------------------|
| 31 –26  | Reserved                                                                                        |
| RSVD    |                                                                                                 |
| 25 –16  | The Byte Count bits represent the 10-bit Byte Count. The USB-FS SIE changes this field upon the |
| BC[9:0] | completion of a RX transfer with the byte count of the data received.                           |
| 15 –8   | Reserved                                                                                        |
| RSVD    |                                                                                                 |

Table continues on the next page...

#### **Programmers Interface**

Downloaded from **Elcodis.com** electronic components distributor

Table 39-4. Buffer Descriptor Byte Fields (continued)

| Field                    | Description                                                                                                                                                                                                                                                                                                                                             |
|--------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>OWN                 | The OWN bit determines whether the microprocessor or the USB-FS currently owns the buffer. Except when KEEP=1, the SIE writes a 0 to this bit when it has completed a token. This byte of the BD should always be the last byte the microprocessor updates when it initializes a BD.                                                                    |
|                          | <ul> <li>The microprocessor has exclusive access to the BD. The USB-FS ignores all other fields in the BD.</li> <li>USB-FS has exclusive access to the BD. After the BD has been assigned to the USB-FS, the microprocessor should not change it in any way.</li> </ul>                                                                                 |
| 6<br>DATA0/1             | This bit defines if a DATA0 field (DATA0/1=0) or a DATA1 (DATA0/1=1) field was transmitted or received. It is unchanged by the USB-FS.                                                                                                                                                                                                                  |
| 5<br>KEEP/<br>TOK_PID[3] | Typically this bit is set (that is, 1) with ISO endpoints feeding a FIFO. The microprocessor is not informed that a token has been processed, the data is simply transferred to or from the FIFO. If KEEP is set, normally the NINC bit is also set to prevent address increment.  0                                                                    |
|                          | Bit 3 of the current token PID is written back in to the BD by the USB-FS. Allows the USB-FS to release the BD when a token has been processed.                                                                                                                                                                                                         |
|                          | This bit is unchanged by the USB-FS. If the OWN bit also is set, the BD remains owned by the USB-FS forever.                                                                                                                                                                                                                                            |
| 4<br>NINC/<br>TOK_PID[2] | The No Increment (NINC) bit disables the DMA engine address increment. This forces the DMA engine to read or write from the same address. This is useful for endpoints when data needs to be read from or written to a single location such as a FIFO. Typically this bit is set with the KEEP bit for ISO endpoints that are interfacing to a FIFO.  0 |
|                          | the USB-FS writes bit 2 of the current token PID to the BD.  1 This bit is unchanged by the USB-FS.                                                                                                                                                                                                                                                     |
| 3<br>DTS/<br>TOK_PID[1]  | Setting this bit enables the USB-FS to perform Data Toggle Synchronization.  • If KEEP=0, bit 1 of the current token PID is written back to the BD.  • If KEEP=1, this bit is unchanged by the USB-FS.                                                                                                                                                  |
|                          | Data Toggle Synchronization is disabled.  1                                                                                                                                                                                                                                                                                                             |
|                          | Enables the USB-FS to perform Data Toggle Synchronization.                                                                                                                                                                                                                                                                                              |

Table continues on the next page...

Table 39-4. Buffer Descriptor Byte Fields (continued)

| Field                        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2<br>BDT_STALL<br>TOK_PID[0] | Setting this bit causes the USB-FS to issue a STALL handshake if a token is received by the SIE that would use the BDT in this location. The BDT is not consumed by the SIE (the owns bit remains set and the rest of the BDT is unchanged) when a BDT-STALL bit is set.  • If KEEP=0, bit 0 of the current token PID is written back to the BD.  • If KEEP=1, this bit is unchanged by the USB-FS.   No stall issued.  1  The BDT is not consumed by the SIE (the OWN bit remains set and the rest of the BDT is unchanged).                   |
| TOK_PID[n]                   | Bits [5:2] can also represent the current token PID. The current token PID is written back in to the BD by the USB-FS when a transfer completes. The values written back are the token PID values from the USB specification:  • 0x1 for an OUT token.  • 0x9 for an IN token.  • 0xd for a SETUP token.  In host mode, this field is used to report the last returned PID or a transfer status indication. The possible values returned are:  • 0x3 DATA0  • 0xb DATA1  • 0x2 ACK  • 0xe STALL  • 0xa NAK  • 0x0 Bus Timeout  • 0xf Data Error |
| 1–0                          | Reserved, should read as zeroes.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Reserved                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| ADDR[31:0]                   | The Address bits represent the 32 -bit buffer address in system memory. These bits are unchanged by the USB-FS.                                                                                                                                                                                                                                                                                                                                                                                                                                 |

## 39.3.5 USB Transaction

When the USB-FS transmits or receives data, it computes the BDT address using the address generation shown in "Addressing Buffer Descriptor Entries" table.

If OWN =1, the following process occurs:

- 1. The USB-FS reads the BDT.
- 2. The SIE transfers the data via the DMA to or from the buffer pointed to by the ADDR field of the BD.
- 3. When the TOKEN is complete, the USB-FS updates the BDT and, if KEEP=0, changes the OWN bit to 0.
- 4. The STAT register is updated and the TOK\_DNE interrupt is set.

#### **Programmers Interface**

- 5. When the microprocessor processes the TOK\_DNE interrupt, it reads from the status register all the information needed to process the endpoint.
- 6. At this point, the microprocessor allocates a new BD so additional USB data can be transmitted or received for that endpoint, and then processes the last BD.

The following figure shows a timeline of how a typical USB token is processed after the BDT is read and OWN=1.



Figure 39-4. USB Token Transaction

The USB has two sources for the DMA overrun error:

#### **Memory Latency**

The memory latency on the BVCI initiator interface may be too high and cause the receive FIFO to overflow. This is predominantly a hardware performance issue, usually caused by transient memory access issues.

#### **Oversized Packets**

The packet received may be larger than the negotiated *MaxPacket* size. Typically, this is caused by a software bug. For DMA overrun errors due to oversized data packets, the USB specification is ambiguous. It assumes correct software drivers on both sides. NAKing the packet can result in retransmission of the already oversized packet data. Therefore, in response to oversized packets, the USB core continues ACKing the packet for non-isochronous transfers.

Table 39-5. USB Responses to DMA Overrun Errors

| Errors due to Memory Latency                                                                                                                           | Errors due to Oversized Packets                                            |
|--------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------|
| Non-Acknowledgment (NAK) or Bus Timeout (BTO) — See bit 4 in "Error Interrupt Status Register (ERR_STAT)" as appropriate for the class of transaction. | Continues acknowledging (ACKing) the packet for non-isochronous transfers. |

Table continues on the next page...

Table 39-5. USB Responses to DMA Overrun Errors (continued)

| Errors due to Memory Latency                                                                                                                                                                                                                                                                                                                                                                        | Errors due to Oversized Packets                                                                                                                                                                                |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| _                                                                                                                                                                                                                                                                                                                                                                                                   | The data written to memory is clipped to the MaxPacket size so as not to corrupt system memory.                                                                                                                |
| The DMA_ERR bit is set in the ERR_STAT register for host and device modes of operation. Depending on the values of the INT_ENB and ERR_ENB register, the core may assert an interrupt to notify the processor of the DMA error.                                                                                                                                                                     | Asserts the DMA_ERR bit of the ERR_STAT register (which could trigger an interrupt) and a TOK_DNE interrupt fires. (Note: The TOK_PID field of the BDT is not 1111 because the DMA_ERR is not due to latency). |
| <ul> <li>For host mode, the TOK_DNE interrupt fires and the TOK_PID field of the BDT is 1111 to indicate the DMA latency error. Host mode software can decide to retry or move to next scheduled item.</li> <li>In device mode, the BDT is not written back nor is the TOK_DNE interrupt triggered because it is assumed that a second attempt is queued and will succeed in the future.</li> </ul> | The packet length field written back to the BDT is the MaxPacket value that represents the length of the clipped data actually written to memory.                                                              |

From here, the software can decide an appropriate course of action for future transactions such as stalling the endpoint, canceling the transfer, disabling the endpoint, etc.

# 39.4 Memory Map/Register Definitions

This section provides the memory map and detailed descriptions of all USB interface registers.

#### **USBx** memory map

| Absolute address (hex) | Register name                                      | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|------------------------|----------------------------------------------------|--------------------|--------|-------------|------------------|
| FFFF_9000              | Peripheral ID Register (USB0_PERID)                | 8                  | R      | 04h         | 39.4.1/<br>960   |
| FFFF_9004              | Peripheral ID Complement Register (USB0_IDCOMP)    | 8                  | R      | FBh         | 39.4.2/<br>960   |
| FFFF_9008              | Peripheral Revision Register (USB0_REV)            | 8                  | R      | 33h         | 39.4.3/<br>961   |
| FFFF_900C              | Peripheral Additional Info Register (USB0_ADDINFO) | 8                  | R      | 01h         | 39.4.4/<br>961   |
| FFFF_9010              | OTG Interrupt Status Register (USB0_OTGISTAT)      | 8                  | R/W    | 00h         | 39.4.5/<br>962   |
| FFFF_9014              | OTG Interrupt Control Register (USB0_OTGICR)       | 8                  | R/W    | 00h         | 39.4.6/<br>963   |
| FFFF_9018              | OTG Status Register (USB0_OTGSTAT)                 | 8                  | R/W    | 00h         | 39.4.7/<br>964   |

Table continues on the next page...

#### **Memory Map/Register Definitions**

# **USBx** memory map (continued)

| Absolute<br>address<br>(hex) | Register name                                  | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|------------------------------|------------------------------------------------|--------------------|--------|-------------|------------------|
| FFFF_901C                    | OTG Control Register (USB0_OTGCTL)             | 8                  | R/W    | 00h         | 39.4.8/<br>965   |
| FFFF_9080                    | Interrupt Status Register (USB0_ISTAT)         | 8                  | R/W    | 00h         | 39.4.9/<br>966   |
| FFFF_9084                    | Interrupt Enable Register (USB0_INTEN)         | 8                  | R/W    | 00h         | 39.4.10/<br>967  |
| FFFF_9088                    | Error Interrupt Status Register (USB0_ERRSTAT) | 8                  | R/W    | 00h         | 39.4.11/<br>968  |
| FFFF_908C                    | Error Interrupt Enable Register (USB0_ERREN)   | 8                  | R/W    | 00h         | 39.4.12/<br>969  |
| FFFF_9090                    | Status Register (USB0_STAT)                    | 8                  | R      | 00h         | 39.4.13/<br>970  |
| FFFF_9094                    | Control Register (USB0_CTL)                    | 8                  | R/W    | 00h         | 39.4.14/<br>971  |
| FFFF_9098                    | Address Register (USB0_ADDR)                   | 8                  | R/W    | 00h         | 39.4.15/<br>972  |
| FFFF_909C                    | BDT Page Register 1 (USB0_BDTPAGE1)            | 8                  | R/W    | 00h         | 39.4.16/<br>973  |
| FFFF_90A0                    | Frame Number Register Low (USB0_FRMNUML)       | 8                  | R/W    | 00h         | 39.4.17/<br>973  |
| FFFF_90A4                    | Frame Number Register High (USB0_FRMNUMH)      | 8                  | R/W    | 00h         | 39.4.18/<br>974  |
| FFFF_90A8                    | Token Register (USB0_TOKEN)                    | 8                  | R/W    | 00h         | 39.4.19/<br>975  |
| FFFF_90AC                    | SOF Threshold Register (USB0_SOFTHLD)          | 8                  | R/W    | 00h         | 39.4.20/<br>976  |
| FFFF_90B0                    | BDT Page Register 2 (USB0_BDTPAGE2)            | 8                  | R/W    | 00h         | 39.4.21/<br>976  |
| FFFF_90B4                    | BDT Page Register 3 (USB0_BDTPAGE3)            | 8                  | R/W    | 00h         | 39.4.22/<br>977  |
| FFFF_90C0                    | Endpoint Control Register (USB0_ENDPT0)        | 8                  | R/W    | 00h         | 39.4.23/<br>977  |
| FFFF_90C4                    | Endpoint Control Register (USB0_ENDPT1)        | 8                  | R/W    | 00h         | 39.4.23/<br>977  |
| FFFF_90C8                    | Endpoint Control Register (USB0_ENDPT2)        | 8                  | R/W    | 00h         | 39.4.23/<br>977  |
| FFFF_90CC                    | Endpoint Control Register (USB0_ENDPT3)        | 8                  | R/W    | 00h         | 39.4.23/<br>977  |
| FFFF_90D0                    | Endpoint Control Register (USB0_ENDPT4)        | 8                  | R/W    | 00h         | 39.4.23/<br>977  |

Table continues on the next page...

#### Chapter 39 Universal Serial Bus (USB) Controller

# **USBx** memory map (continued)

| Absolute<br>address<br>(hex) | Register name                                     | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|------------------------------|---------------------------------------------------|--------------------|--------|-------------|------------------|
| FFFF_90D4                    | Endpoint Control Register (USB0_ENDPT5)           | 8                  | R/W    | 00h         | 39.4.23/<br>977  |
| FFFF_90D8                    | Endpoint Control Register (USB0_ENDPT6)           | 8                  | R/W    | 00h         | 39.4.23/<br>977  |
| FFFF_90DC                    | Endpoint Control Register (USB0_ENDPT7)           | 8                  | R/W    | 00h         | 39.4.23/<br>977  |
| FFFF_90E0                    | Endpoint Control Register (USB0_ENDPT8)           | 8                  | R/W    | 00h         | 39.4.23/<br>977  |
| FFFF_90E4                    | Endpoint Control Register (USB0_ENDPT9)           | 8                  | R/W    | 00h         | 39.4.23/<br>977  |
| FFFF_90E8                    | Endpoint Control Register (USB0_ENDPT10)          | 8                  | R/W    | 00h         | 39.4.23/<br>977  |
| FFFF_90EC                    | Endpoint Control Register (USB0_ENDPT11)          | 8                  | R/W    | 00h         | 39.4.23/<br>977  |
| FFFF_90F0                    | Endpoint Control Register (USB0_ENDPT12)          | 8                  | R/W    | 00h         | 39.4.23/<br>977  |
| FFFF_90F4                    | Endpoint Control Register (USB0_ENDPT13)          | 8                  | R/W    | 00h         | 39.4.23/<br>977  |
| FFFF_90F8                    | Endpoint Control Register (USB0_ENDPT14)          | 8                  | R/W    | 00h         | 39.4.23/<br>977  |
| FFFF_90FC                    | Endpoint Control Register (USB0_ENDPT15)          | 8                  | R/W    | 00h         | 39.4.23/<br>977  |
| FFFF_9100                    | USB Control Register (USB0_USBCTRL)               | 8                  | R/W    | C0h         | 39.4.24/<br>978  |
| FFFF_9104                    | USB OTG Observe Register (USB0_OBSERVE)           | 8                  | R      | 50h         | 39.4.25/<br>979  |
| FFFF_9108                    | USB OTG Control Register (USB0_CONTROL)           | 8                  | R/W    | 00h         | 39.4.26/<br>980  |
| FFFF_910C                    | USB Transceiver Control Register 0 (USB0_USBTRC0) | 8                  | R/W    | 00h         | 39.4.27/<br>980  |
| FFFF_9114                    | Frame Adjust Register (USB0_USBFRMADJUST)         | 8                  | R/W    | 00h         | 39.4.28/<br>981  |

# 39.4.1 Peripheral ID Register (USBx\_PERID)

The Peripheral ID Register reads back the value of 0x04. This value is defined for the USB Peripheral.

Addresses: USB0\_PERID is FFFF\_9000h base + 0h offset = FFFF\_9000h



### **USBx\_PERID** field descriptions

| Field           | Description                                                           |
|-----------------|-----------------------------------------------------------------------|
| 7–6<br>Reserved | This read-only bitfield is reserved and always has the value zero.    |
| 5–0<br>ID       | Peripheral identification bits  These bits always read 0x04 (00_0100) |

# 39.4.2 Peripheral ID Complement Register (USBx\_IDCOMP)

The Peripheral ID Complement Register reads back the complement of the Peripheral ID Register. For the USB Peripheral, this is the value 0xFB.

Addresses: USB0\_IDCOMP is FFFF\_9000h base + 4h offset = FFFF\_9004h



## USBx\_IDCOMP field descriptions

| Field           | Description                                                                                   |
|-----------------|-----------------------------------------------------------------------------------------------|
| 7–6<br>Reserved | This read-only bitfield is reserved and always has the value one. These bits always read ones |
| 5–0<br>NID      | Ones complement of peripheral identification bits.                                            |

# 39.4.3 Peripheral Revision Register (USBx\_REV)

This register contains the revision number of the USB Module.

Addresses: USB0 REV is FFFF 9000h base + 8h offset = FFFF 9008h



## **USBx\_REV** field descriptions

| Field      | Description                                   |
|------------|-----------------------------------------------|
| 7–0<br>REV | Revision                                      |
|            | Indicate the revision number of the USB Core. |

# 39.4.4 Peripheral Additional Info Register (USBx\_ADDINFO)

The Peripheral Additional info Register reads back the value of the fixed Interrupt Request Level (IRQNUM) along with the Host Enable bit. If set to 1, the Host Enable bit indicates the USB peripheral is operating in host mode.

Addresses: USB0\_ADDINFO is FFFF\_9000h base + Ch offset = FFFF\_900Ch



#### **USBx\_ADDINFO** field descriptions

| Field           | Description                                                        |
|-----------------|--------------------------------------------------------------------|
| 7–3<br>IRQNUM   | Assigned Interrupt Request Number                                  |
| 2–1<br>Reserved | This read-only bitfield is reserved and always has the value zero. |
| 0<br>IEHOST     | This bit is set if host mode is enabled.                           |

# 39.4.5 OTG Interrupt Status Register (USBx\_OTGISTAT)

The OTG Interrupt Status Register records changes of the ID sense and VBUS signals. Software can read this register to determine which event has caused an interrupt. Only bits that have changed since the last software read are set. Writing a one to a bit clears the associated interrupt.

Addresses: USB0\_OTGISTAT is FFFF\_9000h base + 10h offset = FFFF\_9010h



## USBx\_OTGISTAT field descriptions

| Field                   | Description                                                                                                                                                                             |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>IDCHG              | This bit is set when a change in the ID Signal from the USB connector is sensed.                                                                                                        |
| 6<br>ONEMSEC            | This bit is set when the 1 millisecond timer expires. This bit stays asserted until cleared by software. The interrupt must be serviced every millisecond to avoid losing 1msec counts. |
| 5<br>LINE_STATE_<br>CHG | This bit is set when the USB line state changes. The interrupt associated with this bit can be used to detect Reset, Resume, Connect, and Data Line Pulse signals.                      |
| 4<br>Reserved           | This read-only bit is reserved and always has the value zero.                                                                                                                           |
| 3<br>SESSVLDCHG         | This bit is set when a change in VBUS is detected indicating a session valid or a session no longer valid.                                                                              |
| 2<br>B_SESS_CHG         | This bit is set when a change in VBUS is detected on a B device.                                                                                                                        |
| 1<br>Reserved           | This read-only bit is reserved and always has the value zero.                                                                                                                           |
| 0<br>AVBUSCHG           | This bit is set when a change in VBUS is detected on an A device.                                                                                                                       |

# 39.4.6 OTG Interrupt Control Register (USBx\_OTGICR)

The OTG Interrupt Control Register enables the corresponding interrupt status bits defined in the OTG Interrupt Status Register.

Addresses: USB0\_OTGICR is FFFF\_9000h base + 14h offset = FFFF\_9014h



## USBx\_OTGICR field descriptions

| Field            | Description                                                   |
|------------------|---------------------------------------------------------------|
| 7<br>IDEN        | ID interrupt enable                                           |
|                  | 0 The ID interrupt is disabled                                |
|                  | 1 The ID interrupt is enabled                                 |
| 6<br>ONEMSECEN   | 1 millisecond interrupt enable                                |
|                  | 0 The 1msec timer interrupt is disabled.                      |
|                  | 1 The 1msec timer interrupt is enabled.                       |
| 5<br>LINESTATEEN | Line State change interrupt enable                            |
|                  | 0 The LINE_STAT_CHG interrupt is disabled.                    |
|                  | 1 The LINE_STAT_CHG interrupt is enabled                      |
| 4<br>Reserved    | This read-only bit is reserved and always has the value zero. |
| 3<br>SESSVLDEN   | Session valid interrupt enable                                |
|                  | 0 The SESSVLDCHG interrupt is disabled.                       |
|                  | 1 The SESSVLDCHG interrupt is enabled.                        |
| 2<br>BSESSEN     | B Session END interrupt enable                                |
|                  | 0 The B_SESS_CHG interrupt is disabled                        |
|                  | 1 The B_SESS_CHG interrupt is enabled                         |
| 1<br>Reserved    | This read-only bit is reserved and always has the value zero. |
| 0<br>AVBUSEN     | A VBUS Valid interrupt enable                                 |
|                  | 0 The AVBUSCHG interrupt is disabled                          |
|                  | 1 The AVBUSCHG interrupt is enabled                           |

# 39.4.7 OTG Status Register (USBx\_OTGSTAT)

The OTG Status Register displays the actual value from the external comparator outputs of the ID pin and VBUS.

Addresses: USB0\_OTGSTAT is FFFF\_9000h base + 18h offset = FFFF\_9018h



# **USBx\_OTGSTAT** field descriptions

| Field                | Description                                                                                                                                                                                                                                                                                                  |
|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>ID              | Indicates the current state of the ID pin on the USB connector                                                                                                                                                                                                                                               |
|                      | 0 Indicates a Type A cable has been plugged into the USB connector                                                                                                                                                                                                                                           |
|                      | 1 Indicates no cable is attached or a Type B cable has been plugged into the USB connector                                                                                                                                                                                                                   |
| 6<br>ONEMSECEN       | This bit is reserved for the 1msec count, but it is not useful to software.                                                                                                                                                                                                                                  |
| 5<br>LINESTATESTABLE | This bit indicates that the internal signals that control the LINE_STATE_CHG bit (bit 5) of the OTGISTAT register have been stable for at least 1 millisecond. First read the LINE_STATE_CHG bit, and then read this bit. If this bit reads as 1, then the value of LINE_STATE_CHG can be considered stable. |
|                      | 0 The LINE_STAT_CHG bit is not yet stable.                                                                                                                                                                                                                                                                   |
|                      | 1 The LINE_STAT_CHG bit has been debounced and is stable.                                                                                                                                                                                                                                                    |
| 4<br>Reserved        | This read-only bit is reserved and always has the value zero.                                                                                                                                                                                                                                                |
| 3                    | Session valid                                                                                                                                                                                                                                                                                                |
| SESS_VLD             | The VBUS voltage is below the B session Valid threshold                                                                                                                                                                                                                                                      |
|                      | The VBUS voltage is above the B session Valid threshold.                                                                                                                                                                                                                                                     |
| 2<br>BSESSEND        | B Session END                                                                                                                                                                                                                                                                                                |
| BOLOGEND             | 0 The VBUS voltage is above the B session End threshold.                                                                                                                                                                                                                                                     |
|                      | 1 The VBUS voltage is below the B session End threshold.                                                                                                                                                                                                                                                     |
| 1<br>Reserved        | This read-only bit is reserved and always has the value zero.                                                                                                                                                                                                                                                |
| 0<br>AVBUSVLD        | A VBUS Valid                                                                                                                                                                                                                                                                                                 |
|                      | 0 The VBUS voltage is below the A VBUS Valid threshold.                                                                                                                                                                                                                                                      |
|                      | 1 The VBUS voltage is above the A VBUS Valid threshold.                                                                                                                                                                                                                                                      |

# 39.4.8 OTG Control Register (USBx\_OTGCTL)

The OTG Control Register controls the operation of VBUS and Data Line termination resistors.

Addresses: USB0\_OTGCTL is FFFF\_9000h base + 1Ch offset = FFFF\_901Ch



## USBx\_OTGCTL field descriptions

| Field           | Description                                                                                                                                                                                                |
|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>DPHIGH     | D+ Data Line pullup resistor enable                                                                                                                                                                        |
|                 | 0 D+ pullup resistor is not enabled                                                                                                                                                                        |
|                 | 1 D+ pullup resistor is enabled                                                                                                                                                                            |
| 6<br>Reserved   | This read-only bit is reserved and always has the value zero.                                                                                                                                              |
| 5<br>DPLOW      | D+ Data Line pull-down resistor enable                                                                                                                                                                     |
| Bi Lovi         | This bit should always be enabled together with bit 4 (DMLOW)                                                                                                                                              |
|                 | 0 D+ pulldown resistor is not enabled.                                                                                                                                                                     |
|                 | 1 D+ pulldown resistor is enabled.                                                                                                                                                                         |
| 4<br>DMLOW      | D- Data Line pull-down resistor enable                                                                                                                                                                     |
|                 | 0 D- pulldown resistor is not enabled.                                                                                                                                                                     |
|                 | 1 D- pulldown resistor is enabled.                                                                                                                                                                         |
| 3<br>Reserved   | This read-only bit is reserved and always has the value zero.                                                                                                                                              |
| 2<br>OTGEN      | On-The-Go pullup/pulldown resistor enable                                                                                                                                                                  |
| O TOLIN         | 0 If USB_EN is set and HOST_MODE is clear in the Control Register (CTL), then the D+ Data Line pull-up resistors are enabled. If HOST_MODE is set the D+ and D- Data Line pull-down resistors are engaged. |
|                 | 1 The pull-up and pull-down controls in this register are used.                                                                                                                                            |
| 1–0<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                                                                         |

## 39.4.9 Interrupt Status Register (USBx\_ISTAT)

The Interrupt Status Register contains bits for each of the interrupt sources within the USB Module. Each of these bits are qualified with their respective interrupt enable bits. All bits of this register are logically OR'd together along with the OTG Interrupt Status Register (OTGSTAT) to form a single interrupt source for the processor's interrupt controller. After an interrupt bit has been set it may only be cleared by writing a one to the respective interrupt bit. This register contains the value of 0x00 after a reset.

Addresses: USB0\_ISTAT is FFFF\_9000h base + 80h offset = FFFF\_9080h

| Bit   | 7     | 6      | 5      | 4     | 3      | 2      | 1     | 0      |
|-------|-------|--------|--------|-------|--------|--------|-------|--------|
| Read  | STALL | ATTACH | RESUME | SLEEP | TOKDNE | SOFTOK | ERROR | USBRST |
| Write | w1c   | w1c    | w1c    | w1c   | w1c    | w1c    | w1c   | w1c    |
| Reset | 0     | 0      | 0      | 0     | 0      | 0      | 0     | 0      |

## **USBx\_ISTAT** field descriptions

| Field       | Description                                                                                                                                                                                                                                                                                                                                        |
|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7           | Stall Interrupt                                                                                                                                                                                                                                                                                                                                    |
| STALL       | In Target mode this bit is asserted when a STALL handshake is sent by the SIE.                                                                                                                                                                                                                                                                     |
|             | In Host mode this bit is set when the USB Module detects a STALL acknowledge during the handshake phase of a USB transaction. This interrupt can be use to determine is the last USB transaction was completed successfully or if it stalled.                                                                                                      |
| 6<br>ATTACH | Attach Interrupt                                                                                                                                                                                                                                                                                                                                   |
| ATTAOT      | This bit is set when the USB Module detects an attach of a USB device. This signal is only valid if HOSTMODEEN is true. This interrupt signifies that a peripheral is now present and must be configured.                                                                                                                                          |
| 5<br>RESUME | This bit is set depending upon the DP/DM signals, and can be used to signal remote wake-up signaling on the USB bus. When not in suspend mode this interrupt should be disabled.                                                                                                                                                                   |
| 4<br>SLEEP  | This bit is set when the USB Module detects a constant idle on the USB bus for 3 milliseconds. The sleep timer is reset by activity on the USB bus.                                                                                                                                                                                                |
| 3<br>TOKDNE | This bit is set when the current token being processed has completed. The processor should immediately read the STAT register to determine the EndPoint and BD used for this token. Clearing this bit (by writing a one) causes the STAT register to be cleared or the STAT holding register to be loaded into the STAT register.                  |
| 2           | This bit is set when the USB Module receives a Start Of Frame (SOF) token.                                                                                                                                                                                                                                                                         |
| SOFTOK      | In Host mode this bit is set when the SOF threshold is reached, so that software can prepare for the next SOF.                                                                                                                                                                                                                                     |
| 1<br>ERROR  | This bit is set when any of the error conditions within the ERRSTAT register occur. The processor must then read the ERRSTAT register to determine the source of the error.                                                                                                                                                                        |
| 0<br>USBRST | This bit is set when the USB Module has decoded a valid USB reset. This informs the Microprocessor that it should write 0x00 into the address register and enable endpoint 0. USBRST is set after a USB reset has been detected for 2.5 microseconds. It is not asserted again until the USB reset condition has been removed and then reasserted. |

# 39.4.10 Interrupt Enable Register (USBx\_INTEN)

The Interrupt Enable Register contains enable bits for each of the interrupt sources within the USB Module. Setting any of these bits enables the respective interrupt source in the ISTAT register. This register contains the value of 0x00 after a reset.

Addresses: USB0\_INTEN is FFFF\_9000h base + 84h offset = FFFF\_9084h



## **USBx\_INTEN** field descriptions

| Field         | Description                                                                                         |
|---------------|-----------------------------------------------------------------------------------------------------|
| 7<br>STALLEN  | STALL Interrupt Enable  0 The STALL interrupt is not enabled.  1 The STALL interrupt is enabled.    |
| 6<br>ATTACHEN | ATTACH Interrupt Enable  The ATTACH interrupt is not enabled.  The ATTACH interrupt is enabled.     |
| 5<br>RESUMEEN | RESUME Interrupt Enable  0 The RESUME interrupt is not enabled.  1 The RESUME interrupt is enabled. |
| 4<br>SLEEPEN  | SLEEP Interrupt Enable  0 The SLEEP interrupt is not enabled.  1 The SLEEP interrupt is enabled.    |
| 3<br>TOKDNEEN | TOKDNE Interrupt Enable  0 The TOKDNE interrupt is not enabled.  1 The TOKDNE interrupt is enabled. |
| 2<br>SOFTOKEN | SOFTOK Interrupt Enable  The SOFTOK interrupt is not enabled.  The SOFTOK interrupt is enabled.     |
| 1<br>ERROREN  | ERROR Interrupt Enable  0 The ERROR interrupt is not enabled.  1 The ERROR interrupt is enabled.    |
| 0<br>USBRSTEN | USBRST Interrupt Enable  0 The USBRST interrupt is not enabled.  1 The USBRST interrupt is enabled. |

## 39.4.11 Error Interrupt Status Register (USBx\_ERRSTAT)

The Error Interrupt Status Register contains enable bits for each of the error sources within the USB Module. Each of these bits are qualified with their respective error enable bits. All bits of this Register are logically OR'd together and the result placed in the ERROR bit of the ISTAT register. After an interrupt bit has been set it may only be cleared by writing a one to the respective interrupt bit. Each bit is set as soon as the error conditions is detected. Therefore, the interrupt does not typically correspond with the end of a token being processed. This register contains the value of 0x00 after a reset.

Addresses: USB0\_ERRSTAT is FFFF\_9000h base + 88h offset = FFFF\_9088h



#### **USBx\_ERRSTAT** field descriptions

| Field         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>BTSERR   | This bit is set when a bit stuff error is detected. If set, the corresponding packet is rejected due to the error.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 6<br>Reserved | This read-only bit is reserved and always has the value zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 5<br>DMAERR   | This bit is set if the USB Module has requested a DMA access to read a new BDT but has not been given the bus before it needs to receive or transmit data. If processing a TX transfer this would cause a transmit data underflow condition. If processing a RX transfer this would cause a receive data overflow condition. This interrupt is useful when developing device arbitration hardware for the microprocessor and the USB Module to minimize bus request and bus grant latency. This bit is also set if a data packet to or from the host is larger than the buffer size allocated in the BDT. In this case the data packet is truncated as it is put into buffer memory. |
| 4<br>BTOERR   | This bit is set when a bus turnaround timeout error occurs. The USB Module contains a bus turnaround timer that keeps track of the amount of time elapsed between the token and data phases of a SETUP or OUT TOKEN or the data and handshake phases of a IN TOKEN. If more than 16 bit times are counted from the previous EOP before a transition from IDLE, a bus turnaround timeout error occurs.                                                                                                                                                                                                                                                                                |
| 3<br>DFN8     | This bit is set if the data field received was not 8 bits in length. USB Specification 1.0 requires that data fields be an integral number of bytes. If the data field was not an integral number of bytes, this bit is set.                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 2<br>CRC16    | This bit is set when a data packet is rejected due to a CRC16 error.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 1<br>CRC5EOF  | This error interrupt has two functions. When the USB Module is operating in peripheral mode (HOSTMODEEN=0), this interrupt detects CRC5 errors in the token packets generated by the host. If set the token packet was rejected due to a CRC5 error.                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|               | When the USB Module is operating in host mode (HOSTMODEEN=1), this interrupt detects End Of Frame (EOF) error conditions. This occurs when the USB Module is transmitting or receiving data and the SOF counter reaches zero. This interrupt is useful when developing USB packet scheduling software to ensure that no USB transactions cross the start of the next frame.                                                                                                                                                                                                                                                                                                          |

Table continues on the next page...

## **USBx\_ERRSTAT** field descriptions (continued)

| Field       |                                                 | Description |
|-------------|-------------------------------------------------|-------------|
| 0<br>PIDERR | This bit is set when the PID check field fails. |             |

# 39.4.12 Error Interrupt Enable Register (USBx\_ERREN)

The Error Interrupt Enable Register contains enable bits for each of the error interrupt sources within the USB Module. Setting any of these bits enables the respective interrupt source in the ERRSTAT register. Each bit is set as soon as the error conditions is detected. Therefore, the interrupt does not typically correspond with the end of a token being processed. This register contains the value of 0x00 after a reset.





## **USBx\_ERREN** field descriptions

| Field         | Description                                                   |
|---------------|---------------------------------------------------------------|
| 7<br>BTSERREN | BTSERR Interrupt Enable                                       |
|               | 0 The BTSERR interrupt is not enabled.                        |
|               | 1 The BTSERR interrupt is enabled.                            |
| 6<br>Reserved | This read-only bit is reserved and always has the value zero. |
| 5<br>DMAERREN | DMAERR Interrupt Enable                                       |
|               | 0 The DMAERR interrupt is not enabled.                        |
|               | 1 The DMAERR interrupt is enabled.                            |
| 4<br>BTOERREN | BTOERR Interrupt Enable                                       |
|               | 0 The BTOERR interrupt is not enabled.                        |
|               | 1 The BTOERR interrupt is enabled.                            |
| 3<br>DFN8EN   | DFN8 Interrupt Enable                                         |
|               | 0 The DFN8 interrupt is not enabled.                          |
|               | 1 The DFN8 interrupt is enabled.                              |
| 2<br>CRC16EN  | CRC16 Interrupt Enable                                        |
|               | 0 The CRC16 interrupt is not enabled.                         |
|               | 1 The CRC16 interrupt is enabled.                             |

Table continues on the next page...

#### **Memory Map/Register Definitions**

## **USBx\_ERREN** field descriptions (continued)

| Field          | Description                                                                   |
|----------------|-------------------------------------------------------------------------------|
| 1<br>CRC5EOFEN | CRC5/EOF Interrupt Enable                                                     |
|                | The CRC5/EOF interrupt is not enabled.     The CRC5/EOF interrupt is enabled. |
| 0<br>PIDERREN  | PIDERR Interrupt Enable                                                       |
|                | The PIDERR interrupt is not enabled.     The PIDERR interrupt is enabled.     |

## 39.4.13 Status Register (USBx\_STAT)

The Status Register reports the transaction status within the USB Module. When the processor's interrupt controller has received a TOKDNE interrupt the Status Register should be read to determine the status of the previous endpoint communication. The data in the status register is valid when the TOKDNE interrupt bit is asserted. The STAT register is actually a read window into a status FIFO maintained by the USB Module. When the USB Module uses a BD, it updates the Status Register. If another USB transaction is performed before the TOKDNE interrupt is serviced, the USB Module stores the status of the next transaction in the STAT FIFO. Thus the STAT register is actually a four byte FIFO that allows the processor core to process one transaction while the SIE is processing the next transaction. Clearing the TOKDNE bit in the ISTAT register causes the SIE to update the STAT register with the contents of the next STAT value. If the data in the STAT holding register is valid, the SIE immediately reasserts to TOKDNE interrupt.

Addresses: USB0\_STAT is FFFF\_9000h base + 90h offset = FFFF\_9090h



#### **USBx\_STAT** field descriptions

| Field       | Description                                                                                                                                                                                            |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–4<br>ENDP | This four-bit field encodes the endpoint address that received or transmitted the previous token. This allows the processor core to determine which BDT entry was updated by the last USB transaction. |
| 3<br>TX     | Transmit Indicator  0 The most recent transaction was a Receive operation.  1 The most recent transaction was a Transmit operation.                                                                    |

Table continues on the next page...

## **USBx\_STAT** field descriptions (continued)

| Field           | Description                                                                           |
|-----------------|---------------------------------------------------------------------------------------|
| 2<br>ODD        | this bit is set if the last Buffer Descriptor updated was in the odd bank of the BDT. |
| 1–0<br>Reserved | This read-only bitfield is reserved and always has the value zero.                    |

# 39.4.14 Control Register (USBx\_CTL)

The Control Register provides various control and configuration information for the USB Module.

Addresses: USB0\_CTL is FFFF\_9000h base + 94h offset = FFFF\_9094h



## **USBx\_CTL** field descriptions

| Field                   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>JSTATE             | Live USB differential receiver JSTATE signal                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                         | The polarity of this signal is affected by the current state of LSEN.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 6<br>SE0                | Live USB Single Ended Zero signal                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 5<br>TXSUSPENDTOKENBUSY | When the USB Module is in Host mode TOKEN_BUSY is set when the USB Module is busy executing a USB token and no more token commands should be written to the Token Register. Software should check this bit before writing any tokens to the Token Register to ensure that token commands are not lost. In Target mode TXD_SUSPEND is set when the SIE has disabled packet transmission and reception. Clearing this bit allows the SIE to continue token processing. This bit is set by the SIE when a Setup Token is received allowing software to dequeue any pending packet transactions in the BDT before resuming token processing. |
| 4<br>RESET              | Setting this bit enables the USB Module to generate USB reset signaling. This allows the USB Module to reset USB peripherals. This control signal is only valid in Host mode (HOSTMODEEN=1). Software must set RESET to 1 for the required amount of time and then clear it to 0 to end reset signaling. For more information on RESET signaling see Section 7.1.4.3 of the USB specification version 1.0.                                                                                                                                                                                                                               |

Table continues on the next page...

#### **Memory Map/Register Definitions**

## **USBx\_CTL** field descriptions (continued)

| Field           | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3<br>HOSTMODEEN | When set to 1, this bit enables the USB Module to operate in Host mode. In host mode, the USB module performs USB transactions under the programmed control of the host processor.                                                                                                                                                                                                                                                                               |
| 2<br>RESUME     | When set to 1 this bit enables the USB Module to execute resume signaling. This allows the USB Module to perform remote wake-up. Software must set RESUME to 1 for the required amount of time and then clear it to 0. If the HOSTMODEEN bit is set, the USB module appends a Low Speed End of Packet to the Resume signaling when the RESUME bit is cleared. For more information on RESUME signaling see Section 7.1.4.5 of the USB specification version 1.0. |
| 1<br>ODDRST     | Setting this bit to 1 resets all the BDT ODD ping/pong bits to 0, which then specifies the EVEN BDT bank.                                                                                                                                                                                                                                                                                                                                                        |
| 0<br>USBENSOFEN | USB Enable  Setting this bit causes the SIE to reset all of its ODD bits to the BDTs. Therefore, setting this bit resets much of the logic in the SIE. When host mode is enabled, clearing this bit causes the SIE to stop sending SOF tokens.  O The USB Module is disabled.  The USB Module is enabled.                                                                                                                                                        |

# 39.4.15 Address Register (USBx\_ADDR)

The Address Register holds the unique USB address that the USB Module decodes when in Peripheral mode (HOSTMODEEN=0). When operating in Host mode (HOSTMODEEN=1) the USB Module transmits this address with a TOKEN packet. This enables the USB Module to uniquely address an USB peripheral. In either mode, the USB\_EN bit within the control register must be set. The Address Register is reset to 0x00 after the reset input becomes active or the USB Module decodes a USB reset signal. This action initializes the Address Register to decode address 0x00 as required by the USB specification.

Addresses: USB0\_ADDR is FFFF\_9000h base + 98h offset = FFFF\_9098h



#### **USBx ADDR field descriptions**

| Field     | Description          |
|-----------|----------------------|
| 7<br>LSEN | Low Speed Enable bit |

Table continues on the next page...

#### **USBx\_ADDR** field descriptions (continued)

| Field       | Description                                                                                                                                                                                                                        |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             | This bit informs the USB Module that the next token command written to the token register must be performed at low speed. This enables the USB Module to perform the necessary preamble required for low-speed data transmissions. |
| 6–0<br>ADDR | USB address                                                                                                                                                                                                                        |
|             | This 7-bit value defines the USB address that the USB Module decodes in peripheral mode, or transmit when in host mode.                                                                                                            |

## 39.4.16 BDT Page Register 1 (USBx\_BDTPAGE1)

The Buffer Descriptor Table Page Register 1 provides address bits 15 through 9 of the base address where the current Buffer Descriptor Table (BDT) resides in system memory. The 32-bit BDT Base Address is always aligned on 512-byte boundaries, so bits 8 through 0 of the base address are always taken as zero.

Addresses: USB0\_BDTPAGE1 is FFFF\_9000h base + 9Ch offset = FFFF\_909Ch



#### **USBx\_BDTPAGE1** field descriptions

| Field         | Description                                                            |
|---------------|------------------------------------------------------------------------|
| 7–1<br>BDTBA  | This field provides address bits 15 through 9 of the BDT base address. |
| 0<br>Reserved | This read-only bit is reserved and always has the value zero.          |

## 39.4.17 Frame Number Register Low (USBx\_FRMNUML)

The Frame Number Register (Low and High) contains an 11-bit value used to compute the address where the current Buffer Descriptor Table (BDT) resides in system memory.

Addresses: USB0\_FRMNUML is FFFF\_9000h base + A0h offset = FFFF\_90A0h



#### **Memory Map/Register Definitions**

## **USBx\_FRMNUML** field descriptions

| Field           | Description                                                                                                                                                                      |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–0<br>FRM[7:0] | This 8-bit field and the 3-bit field in the Frame Number Register High are used to compute the address where the current Buffer Descriptor Table (BDT) resides in system memory. |

## 39.4.18 Frame Number Register High (USBx\_FRMNUMH)

The Frame Number Register (Low and High) contains an 11-bit value used to compute the address where the current Buffer Descriptor Table (BDT) resides in system memory.

Addresses: USB0\_FRMNUMH is FFFF\_9000h base + A4h offset = FFFF\_90A4h



#### **USBx\_FRMNUMH** field descriptions

| Field            | Description                                                                                                                                                                     |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–3<br>Reserved  | This read-only bitfield is reserved and always has the value zero.                                                                                                              |
| 2–0<br>FRM[10:8] | This 3-bit field and the 8-bit field in the Frame Number Register Low are used to compute the address where the current Buffer Descriptor Table (BDT) resides in system memory. |

## 39.4.19 Token Register (USBx\_TOKEN)

The Token Register is used to perform USB transactions when in host mode (HOSTMODEEN=1). When the processor core wishes to execute a USB transaction to a peripheral, it writes the TOKEN type and endpoint to this register. After this register has been written, the USB module begins the specified USB transaction to the address contained in the address register. The processor core should always check that the TOKEN\_BUSY bit in the control register is not set before performing a write to the Token Register. This ensures token commands are not overwritten before they can be executed. The address register and endpoint control register 0 are also used when performing a token command and therefore must also be written before the Token Register. The address register is used to correctly select the USB peripheral address transmitted by the token command. The endpoint control register determines the handshake and retry policies used during the transfer.





#### **USBx** TOKEN field descriptions

| Field             | Description                                                                                                             |
|-------------------|-------------------------------------------------------------------------------------------------------------------------|
| 7–4<br>TOKENPID   | This 4-bit field contains the token type executed by the USB Module.                                                    |
|                   | 0001 OUT Token. USB Module performs an OUT (TX) transaction.                                                            |
|                   | 1001 IN Token. USB Module performs an In (RX) transaction.                                                              |
|                   | 1101 SETUP Token. USB Module performs a SETUP (TX) transaction                                                          |
| 3–0<br>TOKENENDPT | This 4 bit field holds the Endpoint address for the token command. The four bit value written must be a valid endpoint. |

## 39.4.20 SOF Threshold Register (USBx\_SOFTHLD)

The SOF Threshold Register is used only in Hosts mode (HOSTMODEEN=1). When in Host mode, the 14-bit SOF counter counts the interval between SOF frames. The SOF must be transmitted every 1msec so the SOF counter is loaded with a value of 12000. When the SOF counter reaches zero, a Start Of Frame (SOF) token is transmitted. The SOF threshold register is used to program the number of USB byte times before the SOF to stop initiating token packet transactions. This register must be set to a value that ensures that other packets are not actively being transmitted when the SOF time counts to zero. When the SOF counter reaches the threshold value, no more tokens are transmitted until after the SOF ha been transmitted. The value programmed into the threshold register must reserve enough time to ensure the worst case transaction completes. In general the worst case transaction is a IN token followed by a data packet from the target followed by the response from the host. The actual time required is a function of the maximum packet size on the bus. Typical values for the SOF threshold are: 64-byte packets=74; 32-byte packets=42; 16-byte packets=26; 8-byte packets=18.





#### USBx\_SOFTHLD field descriptions

| Field      | Description                                                        |
|------------|--------------------------------------------------------------------|
| 7–0<br>CNT | This 8-bit field represents the SOF count threshold in byte times. |

# 39.4.21 BDT Page Register 2 (USBx\_BDTPAGE2)

The Buffer Descriptor Table Page Register 2 contains an 8-bit value used to compute the address where the current Buffer Descriptor Table (BDT) resides in system memory.

Addresses: USB0\_BDTPAGE2 is FFFF\_9000h base + B0h offset = FFFF\_90B0h



#### **USBx\_BDTPAGE2** field descriptions

| Field        | Description                                                                                                                                             |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–0<br>BDTBA | This 8 bit field provides address bits 23 through 16 of the BDT base address, which defines where the Buffer Descriptor Table resides in system memory. |

## 39.4.22 BDT Page Register 3 (USBx\_BDTPAGE3)

The Buffer Descriptor Table Page Register 3 contains an 8-bit value used to compute the address where the current Buffer Descriptor Table (BDT) resides in system memory.

Addresses: USB0\_BDTPAGE3 is FFFF\_9000h base + B4h offset = FFFF\_90B4h



#### **USBx\_BDTPAGE3** field descriptions

| Field        | Description                                                                                                                                             |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–0<br>BDTBA | This 8 bit field provides address bits 31 through 24 of the BDT base address, which defines where the Buffer Descriptor Table resides in system memory. |

## 39.4.23 Endpoint Control Register (USBx\_ENDPTn)

The Endpoint Control Registers contain the endpoint control bits for each of the 16 endpoints available within the USB Module for a decoded address. The format for these registers is shown in the following figure. Endpoint 0 (ENDPT0) is associated with control pipe 0, which is required for all USB functions. Therefore, after a USBRST interrupt occurs the processor core should set the ENDPT0 register to contain 0x0D.

In Host mode ENDPT0 is used to determine the handshake, retry and low speed characteristics of the host transfer. For Host mode control, bulk and interrupt transfers the EPHSHK bit should be set to 1. For Isochronous transfers it should be set to 0. Common values to use for ENDPT0 in host mode are 0x4D for Control, Bulk, and Interrupt transfers, and 0x4C for Isochronous transfers.

#### **Memory Map/Register Definitions**

Addresses: FFFF\_9000h base + C0h offset +  $(4d \times n)$ , where n = 0d to 15d



## USBx\_ENDPTn field descriptions

| Field          | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>HOSTWOHUB | This is a Host mode only bit and is only present in the control register for endpoint 0 (ENDPT0). When set this bit allows the host to communicate to a directly connected low speed device. When cleared, the host produces the PRE_PID then switch to low speed signaling when sending a token to a low speed device as required to communicate with a low speed device through a hub.                                                                             |
| 6<br>RETRYDIS  | This is a Host mode only bit and is only present in the control register for endpoint 0 (ENDPT0). When set this bit causes the host to not retry NAK'ed (Negative Acknowledgement) transactions. When a transaction is NAKed, the BDT PID field is updated with the NAK PID, and the TOKEN_DNE interrupt is set. When this bit is cleared NAKed transactions is retried in hardware. This bit must be set when the host is attempting to poll an interrupt endpoint. |
| 5<br>Reserved  | This read-only bit is reserved and always has the value zero.                                                                                                                                                                                                                                                                                                                                                                                                        |
| 4<br>EPCTLDIS  | This bit, when set, disables control (SETUP) transfers. When cleared, control transfers are enabled. This applies if and only if the EPRXEN and EPTXEN bits are also set.                                                                                                                                                                                                                                                                                            |
| 3<br>EPRXEN    | This bit, when set, enables the endpoint for RX transfers.                                                                                                                                                                                                                                                                                                                                                                                                           |
| 2<br>EPTXEN    | This bit, when set, enables the endpoint for TX transfers.                                                                                                                                                                                                                                                                                                                                                                                                           |
| 1<br>EPSTALL   | When set this bit indicates that the endpoint is called. This bit has priority over all other control bits in the EndPoint Enable Register, but it is only valid if EPTXEN=1 or EPRXEN=1. Any access to this endpoint causes the USB Module to return a STALL handshake. After an endpoint is stalled it requires intervention from the Host Controller.                                                                                                             |
| 0<br>EPHSHK    | When set this bet enables an endpoint to perform handshaking during a transaction to this endpoint. This bit is generally set unless the endpoint is Isochronous.                                                                                                                                                                                                                                                                                                    |

# 39.4.24 USB Control Register (USBx\_USBCTRL)

Addresses: USB0\_USBCTRL is FFFF\_9000h base + 100h offset = FFFF\_9100h



978

## USBx\_USBCTRL field descriptions

| Field           | Description                                                        |
|-----------------|--------------------------------------------------------------------|
| 7<br>SUSP       | Places the USB transceiver into the suspend state.                 |
|                 | 0 USB transceiver is not in suspend state.                         |
|                 | 1 USB transceiver is in suspend state.                             |
| 6<br>PDE        | Enables the weak pulldowns on the USB transceiver.                 |
|                 | 0 Weak pulldowns are disabled on D+ and D-                         |
|                 | 1 Weak pulldowns are enabled on D+ and D                           |
| 5–0<br>Reserved | This read-only bitfield is reserved and always has the value zero. |

## 39.4.25 USB OTG Observe Register (USBx\_OBSERVE)

Provides visibility on the state of the pull-ups and pull-downs at the transceiver. Useful when interfacing to an external OTG control module via a serial interface.

Addresses: USB0\_OBSERVE is FFFF\_9000h base + 104h offset = FFFF\_9104h



#### **USBx\_OBSERVE** field descriptions

| Field           | Description                                                               |
|-----------------|---------------------------------------------------------------------------|
| 7<br>DPPU       | Provides observability of the D+ Pull Up enable at the USB transceiver.   |
|                 | 0 D+ pullup disabled.                                                     |
|                 | 1 D+ pullup enabled.                                                      |
| 6<br>DPPD       | Provides observability of the D+ Pull Down enable at the USB transceiver. |
|                 | 0 D+ pulldown disabled.                                                   |
|                 | 1 D+ pulldown enabled.                                                    |
| 5<br>Reserved   | This read-only bit is reserved and always has the value zero.             |
| 4<br>DMPD       | Provides observability of the D- Pull Down enable at the USB transceiver. |
|                 | 0 D- pulldown disabled.                                                   |
|                 | 1 D- pulldown enabled.                                                    |
| 3–1<br>Reserved | This read-only bitfield is reserved and always has the value zero.        |
| 0<br>Reserved   | This read-only bit is reserved and always has the value zero.             |

# 39.4.26 USB OTG Control Register (USBx\_CONTROL)

Addresses: USB0\_CONTROL is FFFF\_9000h base + 108h offset = FFFF\_9108h



## USBx\_CONTROL field descriptions

| Field               | Description                                                                                           |
|---------------------|-------------------------------------------------------------------------------------------------------|
| 7–5<br>Reserved     | This read-only bitfield is reserved and always has the value zero.                                    |
| 4<br>DPPULLUPNONOTG | Provides control of the DP PULLUP in the USB OTG module, if USB is configured in non-OTG device mode. |
|                     | DP Pull up in non-OTG device mode is not enabled.      DP Pull up in non-OTG device mode is enabled.  |
|                     | DE Full up in non-ord device mode is enabled.                                                         |
| 3–0<br>Reserved     | This read-only bitfield is reserved and always has the value zero.                                    |

## 39.4.27 USB Transceiver Control Register 0 (USBx\_USBTRC0)

Addresses: USB0\_USBTRC0 is FFFF\_9000h base + 10Ch offset = FFFF\_910Ch



#### USBx\_USBTRC0 field descriptions

| Field    | Description                                                                                                                  |  |  |
|----------|------------------------------------------------------------------------------------------------------------------------------|--|--|
| 7        | USB reset                                                                                                                    |  |  |
| USBRESET | Generates a hard reset to the USB_OTG module. After this bit is set and the reset occurs, this bit is automatically cleared. |  |  |

Table continues on the next page...

#### MCF51JF128 Reference Manual, Rev. 2, 03/2011

980 Preliminary Freescale Semiconductor, Inc.

## **USBx\_USBTRC0** field descriptions (continued)

| Field                   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |
|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
|                         | NOTE: It is always read as zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |
|                         | <ul> <li>Normal USB module operation.</li> <li>Returns the USB module to its reset state.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |
| 6<br>Reserved           | This read-only bit is reserved and always has the value zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |
| 5<br>USBRESMEN          | Asynchronous Resume Interrupt Enable  This bit, when set, allows the USB module to send an asynchronous wakeup event to the MCU upon detection of resume signaling on the USB bus. The MCU then re-enables clocks to the USB module. It is used for low-power suspend mode when USB module clocks are stopped or the USB transceiver is in Suspend mode. Async wakeup only works in device mode.  USB asynchronous wakeup from suspend mode disabled.  USB asynchronous wakeup from suspend mode enabled. The asynchronous resume interrupt differs from the synchronous resume interrupt in that it asynchronously detects K-state using the unfiltered state of the D+ and D- pins. This interupt should only be enabled when the Transceiver is suspended. |  |  |  |
| 4–2<br>Reserved         | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |
| 1<br>SYNC_DET           | Synchronous USB Interrupt Detect  O Synchronous interrupt has not been detected.  Synchronous interrupt has been detected.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |
| 0<br>USB_RESUME_<br>INT | USB Asynchronous Interrupt  O No interrupt was generated.  Interrupt was generated because of the USB asynchronous interrupt.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |

# 39.4.28 Frame Adjust Register (USBx\_USBFRMADJUST)

Addresses: USB0\_USBFRMADJUST is FFFF\_9000h base + 114h offset = FFFF\_9114h



## USBx\_USBFRMADJUST field descriptions

| Field | Description                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | Frame Adjustment  In Host mode, the frame adjustment is a twos complement number that adjusts the period of each USB frame in 12-MHz clock periods. A SOF is normally generated every 12,000 12-MHz clock cycles. The Frame Adjust Register can adjust this by -128 to +127 to compensate for inaccuracies in the USB 48-MHz clock. Changes to the ADJ bit take effect at the next start of the next frame. |

#### USBx\_USBFRMADJUST field descriptions (continued)

| Field | Description |
|-------|-------------|
|-------|-------------|

# 39.5 OTG and Host Mode Operation

The Host Mode logic allows devices such as digital cameras and palmtop computers to function as a USB Host Controller. The OTG logic adds an interface to allow the OTG Host Negotiation and Session Request Protocols (HNP and SRP) to be implemented in software. Host Mode allows a peripheral such as a digital camera to be connected directly to a USB compliant printer. Digital photos can then be easily printed without having to upload them to a PC. In the palmtop computer application, a USB compliant keyboard/ mouse can be connected to the palmtop computer with the obvious advantages of easier interaction.

Host mode is intended for use in handheld-portable devices to allow easy connection to simple HID class devices such as printers and keyboards. It is NOT intended to perform the functions of a full OHCI or UHCI compatible host controller found on PC motherboards. The USB-FS is not supported by Windows 98 as a USB host controller. Host mode allows bulk, Isochronous, interrupt and control transfers. Bulk data transfers are performed at nearly the full USB bus bandwidth. Support is provided for ISO transfers, but the number of ISO streams that can be practically supported is affected by the interrupt latency of the processor servicing the token during interrupts from the SIE. Custom drivers must be written to support Host mode operation.

Setting the HOST\_MODE\_EN bit in the CTL register enables host Mode. The USB-FS core can only operate as a peripheral device or in Host Mode. It cannot operate in both modes simultaneously. When HOST\_MODE is enabled, only endpoint zero is used. All other endpoints should be disabled by software.

# 39.6 Host Mode Operation Examples

The following sections illustrate the steps required to perform USB host functions using the USB-FS core. While it is useful to understand the interaction of the hardware and the software at a detailed level, an understanding of the interactions at this level is not required to write host applications using the API software.

To enable host mode and discover a connected device:

- 1. Enable Host Mode (CTL[HOST\_MODE\_EN]=1). The pull-down resistors are enabled, and pull-up disabled. Start of Frame (SOF) generation begins. SOF counter loaded with 12,000. Disable SOF packet generation to eliminate noise on the USB by writing the USB enable bit to 0 (CTL[USB\_EN]=0).
- 2. Enable the ATTACH interrupt (INT\_ENB[ATTACH]=1).
- 3. Wait for ATTACH interrupt (INT\_STAT[ATTACH]). Signaled by USB Target pull-up resistor changing the state of DPLUS or DMINUS from 0 to 1 (SE0 to J or K state).
- 4. Check the state of the JSTATE and SE0 bits in the control register. If the connecting device is low speed (JSTATE bit is 0), set the low-speed bit in the address registers (ADDR[LS\_EN]=1) and the host without hub bit in endpoint 0 register control (EP\_CTL0[HOST\_WO\_HUB]=1).
- 5. Enable RESET (CTL[RESET]=1) for 10 ms.
- 6. Enable SOF packet to keep the connected device from going to suspend (CTL[USB\_EN=1]).
- 7. Start enumeration by sending a sequence of device framework commands, device frame work packets to the default control pipe of the connected device. Refer to the *Universal Serial Bus Revision 2.0 specification*, "Chapter 9 USB Device Framework" (http://www.usb.org/developers/docs).

## To complete a control transaction to a connected device:

- 1. Complete all steps discover a connected device
- 2. Set up the endpoint control register for bidirectional control transfers EP\_CTL0[4:0] = 0x0d.
- 3. Place a copy of the device framework setup command in a memory buffer. Refer to the *Universal Serial Bus Revision 2.0 specification*, "Chapter 9 USB Device Framework" (http://www.usb.org/developers/docs).
- 4. Initialize current (even or odd) TX EP0 BDT to transfer the 8 bytes of command data for a device framework command (for example, a GET DEVICE DESCRIPTOR).
  - Set the BDT command word to 0x00080080 –Byte count to 8, own bit to 1.
  - Set the BDT buffer address field to the start address of the 8 byte command buffer.

#### **Host Mode Operation Examples**

- 5. Set the USB device address of the target device in the address register (ADDR[6:0]). After the USB bus reset, the device USB address is zero. It is set to some other value (usually 1) by the Set Address device framework command.
- 6. Write the token register with a SETUP to Endpoint 0 the target device default control pipe (TOKEN=0xD0). This initiates a setup token on the bus followed by a data packet. The device handshake is returned in the BDT PID field after the packets complete. When the BDT is written a token done (INT\_STAT[TOK\_DNE]) interrupt is asserted. This completes the setup phase of the setup transaction. Refer to the *Universal Serial Bus Revision 2.0 specification*, "Chapter 9 USB Device Framework" (http://www.usb.org/developers/docs).
- 7. To initiate the data phase of the setup transaction (for example, get the data for the GET DEVICE descriptor command) set up a buffer in memory for the data to be transferred.
- 8. Initialize the current (even or odd) TX EP0 BDT to transfer the data.
  - Set the BDT command word to 0x004000C0 –Byte count to the length of the data buffer in this case 64, own bit to 1, Data toggle to Data1.
  - Set the BDT buffer address field to the start address of the data buffer
- 9. Write the token register with a IN or OUT token to Endpoint 0 the target device default control pipe, an IN token for a GET DEVICE DESCRIPTOR command (TOKEN=0x90). This initiates an IN token on the bus followed by a data packet from the device to the host. When the data packet completes the BDT is written and a token done (INT\_STAT[TOK\_DNE]) interrupt is asserted. For control transfers with a single packet data phase this completes the data phase of the setup transaction. Refer to the *Universal Serial Bus Revision 2.0 specification*, "Chapter 9 USB Device Framework" (http://www.usb.org/developers/docs).
- 10. To initiate the Status phase of the setup transaction set up a buffer in memory to receive or send the zero length status phase data packet.
- 11. Initialize the current (even or odd) TX EP0 BDT to transfer the status data.
  - Set the BDT command word to 0x00000080 –Byte count to the length of the data buffer in this case 0, own bit to 1, Data toggle to Data0.
  - Set the BDT buffer address field to the start address of the data buffer
- 12. Write the token register with a IN or OUT token to Endpoint 0 the target device default control pipe, an OUT token for a GET DEVICE DESCRIPTOR command (TOKEN=0x10). This initiates an OUT token on the bus followed by a zero length

984

data packet from the host to the device. When the data packet completes the BDT is written with the handshake form the device and a token done (INT\_STAT[TOK\_DNE]) interrupt is asserted. This completes the data phase of the setup transaction. Refer to the *Universal Serial Bus Revision 2.0 specification*, "Chapter 9 USB Device Framework" (http://www.usb.org/developers/docs).

#### To send a Full speed bulk data transfer to a target device:

- 1. Complete all steps discover a connected device and to configure a connected device. Write the ADDR register with the address of the target device. Typically, there is only one other device on the USB bus in host mode so it is expected that the address is 0x01 and should remain constant.
- 2. Write the ENDPT0 to 0x1D register to enable transmit and receive transfers with handshaking enabled.
- 3. Setup the Even TX EP0 BDT to transfer up to 64 bytes.
- 4. Set the USB device address of the target device in the address register (ADDR[6:0]).
- 5. Write the TOKEN register with an OUT token to the desired endpoint. The write to this register triggers the USB-FS transmit state machines to begin transmitting the TOKEN and the data.
- 6. Setup the Odd TX EP0 BDT to transfer up to 64 bytes.
- 7. Write the TOKEN register with an OUT token as in step 4. Two Tokens can be queued at a time to allow the packets to be double buffered to achieve maximum throughput.
- 8. Wait for the TOK\_DNE interrupt. This indicates one of the BDTs has been released back to the microprocessor and that the transfer has completed. If the target device asserts NAKs, the USB-FS continues to retry the transfer indefinitely without processor intervention unless the RETRY\_DIS retry disable bit is set in the EPO control register. If the retry disable bit is set, the handshake (ACK, NAK, STALL, or ERROR (0xf)) is returned in the BDT PID field. If a stall interrupt occurs, the pending packet must be dequeued and the error condition in the target device cleared. If a RESET interrupt occurs (SEO for more than 2.5us), the target has detached.
- 9. After the TOK\_DNE interrupt occurs, the BDTs can be examined and the next data packet queued by returning to step 2.

# 39.7 On-The-Go Operation

The USB-OTG core provides sensors and controls to enable On-The-Go (OTG) operation. These sensors are used by the OTG API software to implement the Host Negotiation Protocol (HNP) and Session Request Protocol (SRP). API calls are provided to give access the OTG protocol control signals, and include the OTG capabilities in the device application. The following state machines show the OTG operations involved with HNP and SRP protocols from either end of the USB cable.

## 39.7.1 OTG Dual Role A Device Operation

A device is considered the A device because of the type of cable attached. If the USB Type A connector or the USB Type Mini A connector is plugged into the device, he is considered the A device.

A dual role A device operates as the following flow diagram and state description table illustrates.



Figure 39-93. Dual Role A Device Flow Diagram

Table 39-96. State Descriptions for the Dual Role A Device Flow

| State        | Action                                                                                                                           | Response           |
|--------------|----------------------------------------------------------------------------------------------------------------------------------|--------------------|
| A_IDLE       | If ID Interrupt.                                                                                                                 | Go to B_IDLE       |
|              | The cable has been un-plugged or a Type B cable has been attached. The device now acts as a Type B device.                       |                    |
|              | If the A application wants to use the bus or if the B device is doing                                                            | Go to A_WAIT_VRISE |
|              | an SRP as indicated by an A_SESS_VLD Interrupt or Attach or Port Status Change Interrupt check data line for 5 –10 msec pulsing. | Turn on DRV_VBUS   |
| A_WAIT_VRISE | If ID Interrupt or if A_VBUS_VLD is false after 100 msec                                                                         | Go to A_WAIT_VFALL |
|              | The cable has been changed or the A device cannot support the current required from the B device.                                | Turn off DRV_VBUS  |
|              | If A_VBUS_VLD interrupt                                                                                                          | Go to A_WAIT_BCON  |
| A_WAIT_BCON  | After 200 msec without Attach or ID Interrupt. (This could wait                                                                  | Go to A_WAIT_FALL  |
|              | forever if desired.)                                                                                                             | Turn off DRV_VBUS  |
|              | A_VBUS_VLD Interrupt and B device attaches                                                                                       | Go to A_HOST       |
|              |                                                                                                                                  | Turn on Host Mode  |
| A_HOST       | Enumerate Device determine OTG Support.                                                                                          |                    |
|              |                                                                                                                                  | Go to A_WAIT_VFALL |
|              | wants to do something soon or the B device disconnects                                                                           | Turn off Host Mode |
|              |                                                                                                                                  | Turn off DRV_VBUS  |
|              | If the A device is finished with session or if the A device wants to allow the B device to take bus.                             | Go to A_SUSPEND    |
|              | ID Interrupt or the B device disconnects                                                                                         | Go to A_WAIT_BCON  |
| A_SUSPEND    | If ID Interrupt, or if 150 msec B disconnect timeout (This timeout                                                               | Go to A_WAIT_VFALL |
|              | value could be longer) or if A_VBUS_VLD\ Interrupt                                                                               | Turn off DRV_VBUS  |
|              | If HNP enabled, and B disconnects in 150 msec then B device is                                                                   | Go to A_PERIPHERAL |
|              | becoming the host.                                                                                                               | Turn off Host Mode |
|              | If A wants to start another session                                                                                              | Go to A_HOST       |
| A_PERIPHERAL | If ID Interrupt or if A_VBUS_VLD interrupt                                                                                       | Go to A_WAIT_VFALL |
|              |                                                                                                                                  | Turn off DRV_VBUS. |
|              | If 3 –200 msec of Bus Idle                                                                                                       | Go to A_WAIT_BCON  |
|              |                                                                                                                                  | Turn on Host Mode  |
| A_WAIT_VFALL | If ID Interrupt or (A_SESS_VLD/ & b_conn/)                                                                                       | Go to A_IDLE       |

# 39.7.2 OTG Dual Role B Device Operation

A device is considered a B device if it connected to the bus with a USB Type B cable or a USB Type Mini B cable.

#### On-The-Go Operation

A dual role B device operates as the following flow diagram and state description table illustrates.



Figure 39-94. Dual Role B Device Flow Diagram

Table 39-97. State Descriptions for the Dual Role B Device Flow

| State        | Action                                                                                   | Response                                    |
|--------------|------------------------------------------------------------------------------------------|---------------------------------------------|
| B_IDLE       | If ID\ Interrupt.                                                                        | Go to A_IDLE                                |
|              | A Type A cable has been plugged in and the device should now respond as a Type A device. |                                             |
|              | If B_SESS_VLD Interrupt.                                                                 | Go to B_PERIPHERAL                          |
|              | The A device has turned on VBUS and begins a session.                                    | Turn on DP_HIGH                             |
|              | If B application wants the bus and Bus is Idle for 2 ms and the                          | Go to B_SRP_INIT                            |
|              | B_SESS_END bit is set, the B device can perform an SRP.                                  | Pulse CHRG_VBUS<br>Pulse DP_HIGH 5-10<br>ms |
| B_SRP_INIT   | If ID\ Interrupt or SRP Done (SRP must be done in less than 100 msecs.)                  | Go to B_IDLE                                |
| B_PERIPHERAL | If HNP enabled and the bus is suspended and B wants the bus, the                         | Go to B_WAIT_ACON                           |
|              | B device can become the host.                                                            | Turn off DP_HIGH                            |
| B_WAIT_ACON  | If A connects, an attach interrupt is received                                           | Go to B_HOST                                |
|              |                                                                                          | Turn on Host Mode                           |
|              | If ID\ Interrupt or B_SESS_VLD/ Interrupt                                                | Go to B_IDLE                                |
|              | If the cable changes or if VBUS goes away, the host doesn't support us.                  |                                             |
|              | Go to B_IDLE                                                                             |                                             |
|              | If 3.125 ms expires or if a Resume occurs                                                | Go to B_PERIPHERAL                          |
| B_HOST       | If ID\ Interrupt or B_SESS_VLD\ Interrupt                                                | Go to B_IDLE                                |
|              | If the cable changes or if VBUS goes away, the host doesn't support us.                  |                                             |
|              | If B application is done or A disconnects                                                | Go to B_PERIPHERAL                          |

# **Chapter 40 USB Device Charger Detection Module (USBDCD)**

## 40.1 Preface

## 40.1.1 References

The following publications are referenced in this document. For updates to these specifications, see http://www.usb.org.

- USB Battery Charging Specification Revision 1.1, USB Implementers Forum
- Universal Serial Bus Specification Revision 2.0, USB Implementers Forum

## 40.1.2 Acronyms and Abbreviations

The following table contains acronyms and abbreviations used in this document.

Table 40-1. Acronyms and Abbreviated Terms

| Term                      | Meaning                                                                     |
|---------------------------|-----------------------------------------------------------------------------|
| FS                        | Full Speed (12 Mbps)                                                        |
| HS                        | High Speed (480 Mbps)                                                       |
| I <sub>DEV_DCHG</sub>     | Current drawn when the USB device is connected to a dedicated charging port |
| I <sub>DEV_HCHG_LFS</sub> | Current drawn when the USB device is connected to an FS charging host port  |
| I <sub>DM_SINK</sub>      | Current sink for the D- line                                                |
| I <sub>DP_SRC</sub>       | Current source for the D+ line                                              |
| I <sub>SUSP</sub>         | Current drawn when the USB device is suspended                              |
| LDO                       | Low dropout                                                                 |
| LS                        | Low Speed (1.5 Mbps)                                                        |
| N/A                       | Not applicable                                                              |

Table continues on the next page...

#### Introduction

Table 40-1. Acronyms and Abbreviated Terms (continued)

| Term                 | Meaning                                                  |  |
|----------------------|----------------------------------------------------------|--|
| OTG                  | On-The-Go                                                |  |
| R <sub>DM_DWN</sub>  | 0- pulldown resistance for data pin contact detect       |  |
| V <sub>DAT_REF</sub> | Data detect reference voltage for the voltage comparator |  |
| V <sub>DP_SRC</sub>  | Voltage source for the D+ line                           |  |
| V <sub>LGC</sub>     | Threshold voltage for logic high                         |  |

# 40.1.3 Glossary

The following table shows a glossary of terms used in this document.

Table 40-2. Glossary of Terms

| Term        | Definition                                                                                     |  |
|-------------|------------------------------------------------------------------------------------------------|--|
| Transceiver | Module that implements the physical layer of the USB standard (FS or LS only)                  |  |
| PHY         | Module that implements the physical layer of the USB standard (HS capable)                     |  |
| Attached    | Device is physically plugged into USB port but has not enabled either D+ or D- pullup resistor |  |
| Connected   | Device is physically plugged into USB port and has enabled either D+ or D- pullup resistor     |  |
| Suspended   | After 3 ms of no bus activity the USB device enters suspend mode.                              |  |
| Component   | The hardware and software that make up a subsystem.                                            |  |

## 40.2 Introduction

The USBDCD module works with the USB transceiver to detect if the USB device is attached to a charging port (either a dedicated charging port or a charging host). System software coordinates the detection activities of the module and controls an off-chip integrated circuit that performs the battery charging.

# 40.2.1 Block Diagram

The following figure is a high level block diagram of the module.



Figure 40-1. Block Diagram

The USBDCD module consists of 2 main blocks:

- A digital block provides the programming interface (memory-mapped registers) and includes the timer unit and the analog control unit.
- An analog block provides the circuitry for the physical detection of the charger, including the voltage source, current source, current sink, and voltage comparator circuitry.

## 40.2.2 Features

The USBDCD module offers the following features:

- Compliant with the latest industry standard specification: *USB Battery Charging Specification, Revision 1.1*
- Programmable timing parameters default to values required by the industry standards:
  - Having standard default values allows for minimal configuration: Set the clock frequency before enabling the module.
  - Programmability allows for flexibility to meet future udpates to the standards.

## 40.2.3 Modes of Operation

The USBDCD module operating modes are shown in the following table.

#### **Module Signal Description**

Table 40-3. Module Modes and Their Conditions

| Module Mode | Description                                                                                                        | Conditions When Used                                                                              |
|-------------|--------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------|
| Enabled     | The module performs the charger detection sequence.                                                                | System software should enable the module only when all of the following conditions are true:      |
|             |                                                                                                                    | The system uses a rechargeable battery.                                                           |
|             |                                                                                                                    | The device is being used in an FS USB device application.                                         |
|             |                                                                                                                    | The device has detected that it is attached to the USB cable.                                     |
| Disabled    | The module is not active and is held in a low power state.                                                         | System software should disable the module when <i>either</i> of the following conditions is true: |
|             |                                                                                                                    | The charger detect sequence is complete.                                                          |
|             |                                                                                                                    | The conditions for being enabled are not met.                                                     |
| Powered Off | The digital supply voltage dvdd is removed.                                                                        | Low system performance requirements allow putting the device into a very low-power stop mode.     |
|             | Optionally, the analog supply voltage avdd33 also may be reduced to as low as 1.7v without causing excess leakage. |                                                                                                   |

Operating mode transitions are shown in the following table.

Table 40-4. Entering and Exiting Module Modes

| Module<br>Mode | Entering                                                                                                                                                                             | Exiting                                                                                                              | Mode<br>after<br>Exiting |
|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------|--------------------------|
| Enabled        | Set the CONTROL[START] bit.                                                                                                                                                          | Set the CONTROL[SR] bit.1                                                                                            | Disabled                 |
| Disabled       | <ul> <li>Take either of the following actions:</li> <li>Set the CONTROL[SR] bit.<sup>1</sup></li> <li>Reset the module. (The module is disabled out of reset by default.)</li> </ul> | Set the CONTROL[START] bit.                                                                                          | Enabled                  |
| Powered<br>Off | Perform the following actions:  1. Put the device into very low-power stop mode.  2. Adjust the supply voltages.                                                                     | Perform the following actions:  1. Restore the supply voltages.  2. Take the device out of very low-power stop mode. | Disabled                 |

<sup>1.</sup> The effect of setting the SR bit is immediate; that is, the module is disabled even if the sequence has not completed.

# 40.3 Module Signal Description

This section describes the module signals.

# 40.3.1 USB Signal Descriptions

The following table shows a summary of module signals that interface with the device's pins.

Table 40-5. USB Signal Descriptions

| Signal              | Description                                                                                      | I/O |
|---------------------|--------------------------------------------------------------------------------------------------|-----|
| usb_dm              | USB D- analog data signal. The analog block interfaces directly to the D-signal on the USB bus.  | I/O |
| usb_dp              | USB D+ analog data signal. The analog block interfaces directly to the D+ signal on the USB bus. | I/O |
| avdd33 <sup>1</sup> | 3.3v regulated analog supply                                                                     | I   |
| avss                | Analog ground                                                                                    | I   |
| dvss                | Digital ground                                                                                   | I   |
| dvdd                | 1.2 V digital supply                                                                             | I   |

<sup>1.</sup> Voltage must be 3.3v +/- 10% for full functionality of the module. That is, the charger detection function does not work when this voltage is below 3.0v, and the CONTROL[START] bit should not be set.

#### NOTE

The transceiver module also interfaces to usb\_dm and usb\_dp. Both modules and the USB host/hub use these signal as bidirectional, tri-state signals.

Information about the signal integrity aspects of the lines including shielding, isolated return paths, input or output impedance, packaging, suggested external components, ESD, and other protections can be found in the USB 2.0 specification and in Application Information.

# 40.4 Memory Map/Register Definition

This section describes the memory map and registers for the USBDCD module.

#### **USBDCD** memory map

| Absolute address (hex) | Register name                 | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|------------------------|-------------------------------|--------------------|--------|-------------|------------------|
| FFFF_8680              | USBDCD_CONTROL                | 32                 | R/W    | 0001_0000h  | 40.4.1/<br>994   |
| FFFF_8684              | Clock Register (USBDCD_CLOCK) | 32                 | R/W    | 0000_00C1h  | 40.4.2/<br>996   |

Table continues on the next page...

#### **Memory Map/Register Definition**

## **USBDCD** memory map (continued)

| Absolute<br>address<br>(hex) | Register name                   | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|------------------------------|---------------------------------|--------------------|--------|-------------|------------------|
| FFFF_8688                    | Status Register (USBDCD_STATUS) | 32                 | R      | 0000_0000h  | 40.4.3/<br>997   |
| FFFF_8690                    | TIMER0 Register (USBDCD_TIMER0) | 32                 | R/W    | 0010_0000h  | 40.4.4/<br>998   |
| FFFF_8694                    | USBDCD_TIMER1                   | 32                 | R/W    | 000A_0028h  | 40.4.5/<br>999   |
| FFFF_8698                    | USBDCD_TIMER2                   | 32                 | R/W    | 0028_0001h  | 40.4.6/<br>1000  |

# 40.4.1 Control Register (USBDCD\_CONTROL)

Contains the control and interrupt bit fields.

Address: USBDCD\_CONTROL is FFFF\_8680h base + 0h offset = FFFF\_8680h



## **USBDCD\_CONTROL** field descriptions

| Field             | Description                                                                                                                        |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31–26<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                 |
| 25<br>SR          | Software Reset  Determines whether a software reset is performed.  0 Do not perform a software reset.  1 Perform a software reset. |

Table continues on the next page...

#### **Chapter 40 USB Device Charger Detection Module (USBDCD)**

## **USBDCD\_CONTROL** field descriptions (continued)

| Field             | Description                                                                                                           |  |
|-------------------|-----------------------------------------------------------------------------------------------------------------------|--|
| 24<br>START       | Start Change Detection Sequence                                                                                       |  |
|                   | Determines whether the charger detection sequence is initiated.                                                       |  |
|                   | 0b0 Do not start the sequence. Writes of this value have no effect.                                                   |  |
|                   | Ob1 Initiate the charger detection sequence. If the sequence is already running, writes of this value have no effect. |  |
| 23–17<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                    |  |
| 16                | Interrupt Enable                                                                                                      |  |
| IE                | Enables/disables interrupts to the system.                                                                            |  |
|                   | 0b0 Disable interrupts to the system.                                                                                 |  |
|                   | 0b1 Enable interrupts to the system.                                                                                  |  |
| 15–9<br>Reserved  | This bitfield is reserved.                                                                                            |  |
| 8<br>IF           | Interrupt Flag                                                                                                        |  |
| II.               | Determines whether an interrupt is pending                                                                            |  |
|                   | 0b0 No interrupt is pending.                                                                                          |  |
|                   | 0b1 An interrupt is pending.                                                                                          |  |
| 7–1<br>Reserved   | This read-only bitfield is reserved and always has the value zero.                                                    |  |
| 0                 | Interrupt Acknowledge                                                                                                 |  |
| IACK              | Determines whether the interrupt is cleared.                                                                          |  |
|                   | 0b0 Do not clear the interrupt.                                                                                       |  |
|                   | 0b1 Clear the IF bit (interrupt flag).                                                                                |  |

# 40.4.2 Clock Register (USBDCD\_CLOCK)

Address: USBDCD\_CLOCK is FFFF\_8680h base + 4h offset = FFFF\_8684h



## **USBDCD\_CLOCK** field descriptions

| Field               | Description                                                                                                                                                                                                                                                                                                                                                                                                      |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–12<br>Reserved   | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                                                                                                                                                               |
| 11–2<br>CLOCK_SPEED | Numerical Value of Clock Speed in Binary  The unit of measure is programmed in CLOCK_UNIT. The valid range is from 1 to 1023 when clock unit is MHz and 4 to 1023 when clock unit is KHz. Examples with CLOCK_UNIT = 1:  • For 48 MHz: 0b00_0011_0000 (48) (Default)  • For 24 MHz: 0b00_0001_1000 (24)  Examples with CLOCK_UNIT = 0:  • For 100 kHz: 0b00_0110_0100 (100)  • For 500 kHz: 0b01_1111_0100 (500) |
| 1<br>Reserved       | This read-only bit is reserved and always has the value zero.                                                                                                                                                                                                                                                                                                                                                    |
| 0<br>CLOCK_UNIT     | Unit of measurement encoding for Clock Speed  Specifies the unit of measure for the clock speed.  0b0 kHz Speed (between 1 kHz and 1023 kHz)  0b1 MHz Speed (between 1 MHz and 1023 MHz)                                                                                                                                                                                                                         |

# 40.4.3 Status Register (USBDCD\_STATUS)

The status register provides the current state of the module for system software monitoring.





## **USBDCD\_STATUS** field descriptions

| Field             | Description                                                                                                     |  |
|-------------------|-----------------------------------------------------------------------------------------------------------------|--|
| 31–23<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                              |  |
| 22<br>ACTIVE      | Active Status Indicator                                                                                         |  |
|                   | Indicates whether the sequence is running.                                                                      |  |
|                   | 0b0 The sequence is not running.                                                                                |  |
|                   | 0b1 The sequence is running.                                                                                    |  |
| 21<br>TO          | Timeout Flag                                                                                                    |  |
|                   | Indicates whether the detection sequence has passed the timeout threshhold.                                     |  |
|                   | 0b0 The detection sequence has not been running for over 1 s.                                                   |  |
|                   | 0b1 It has been over 1 s since the data pin contact was detected and debounced.{                                |  |
| 20<br>ERR         | Error Flag                                                                                                      |  |
|                   | Indicates whether there is an error in the detection sequence.                                                  |  |
|                   | 0b0 No sequence errors.                                                                                         |  |
|                   | 0b1 Error in the detection sequence. See the SEQ_STAT field to determine the phase in which the error occurred. |  |

Table continues on the next page...

#### **Memory Map/Register Definition**

#### USBDCD\_STATUS field descriptions (continued)

| Field             | Description                                                                                                                                                                                                                                                    |  |  |
|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 19-18<br>SEQ_STAT | Charger Detection Sequence Status                                                                                                                                                                                                                              |  |  |
|                   | Indicates the status of the charger detection sequence.                                                                                                                                                                                                        |  |  |
|                   | Ob00 The module is either not enabled, or the module is enabled but the data pins have not yet been detected.                                                                                                                                                  |  |  |
|                   | 0b01 Data pin contact detection is complete.                                                                                                                                                                                                                   |  |  |
|                   | 0b10 Charger detection is complete.                                                                                                                                                                                                                            |  |  |
|                   | 0b11 Charger type detection is complete.                                                                                                                                                                                                                       |  |  |
| 17-16<br>SEQ_RES  | Charger Detection Sequence Results                                                                                                                                                                                                                             |  |  |
|                   | Reports how charger detection is attached.                                                                                                                                                                                                                     |  |  |
|                   | 0b00 No results to report.                                                                                                                                                                                                                                     |  |  |
|                   | 0b01 Attached to a standard host. Must comply with USB Spec 2.0 by drawing only 2.5mA (max) until connected.                                                                                                                                                   |  |  |
|                   | 0b10 Attached to a charging port. The exact meaning depends on bit 18: 0: Attached to either a charging host or a dedicated charger (The charger type detection has not completed.) 1: Attached to a charging host (The charger type detection has completed.) |  |  |
|                   | 0b11 Attached to a dedicated charger.                                                                                                                                                                                                                          |  |  |
| 15–0<br>Reserved  | This bitfield is reserved.                                                                                                                                                                                                                                     |  |  |
|                   | NOTE: Bits do not always read as 0.                                                                                                                                                                                                                            |  |  |

## 40.4.4 TIMERO Register (USBDCD\_TIMERO)

TIMER0 has an TSEQ\_INIT field that represents the system latency (in ms) measured from the time VBUS goes active to the time system software initiates the charger detection sequence in the USBDCD module. When software sets the CONTROL[START] bit, the Unit Connection Timer (TUNITCON) is initialized with the value of TSEQ\_INIT. Valid values are 0-1023, however the USB Battery Charging Specification requires the entire sequence, including TSEQ\_INIT, to be completed in 1s or less.

Address: USBDCD\_TIMER0 is FFFF\_8680h base + 10h offset = FFFF\_8690h



#### **USBDCD\_TIMER0** field descriptions

| Field              | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–26<br>Reserved  | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 25–16<br>TSEQ_INIT | Sequence Initiation Time  TSEQ_INIT represents the system latency (in ms) measured from the time VBUS goes active to the time system software initiates the charger detection sequence in the USBDCD module. When software sets the CONTROL[START] bit, the Unit Connection Timer (TUNITCON) is initialized with the value of TSEQ_INIT. Valid values are 0-1023, but the USB Battery Charging Specification requires the entire sequence, including TSEQ_INIT, to be completed in 1s or less.                                                                                                                                                                                                                                                                                                                            |
| 15–12<br>Reserved  | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 11-0<br>TUNITCON   | Unit Connection Timer Elapse (in ms)  Displays the current elapsed time since software set the CONTROL[START] bit plus the value of TSEQ_INIT. The timer is initially loaded with the value of TSEQ_INIT before starting to count.  This timer enables compliance with the maximum time allowed to connect (TUNIT_CON) under the USB Battery Charging Specification, v1.1.If the timer reaches the TUNIT_CON one second limit, the module triggers an interrupt and sets the error flag STATUS[ERR].  The timer continues counting throughout the charger detection sequence, even when control has been passed to software. As long as the module is active, the timer continues to count until it reaches the maximum value of 0xFFF (4095 ms). The timer does not rollover to zero. A software reset clears the timer. |

## 40.4.5 USBDCD\_TIMER1

Address: USBDCD\_TIMER1 is FFFF\_8680h base + 14h offset = FFFF\_8694h



## **USBDCD\_TIMER1** field descriptions

| Field              | Description                                                                                                                                                                                                                                                                              |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–26<br>Reserved  | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                                       |
| 25–16<br>TDCD_DBNC | Time Period to Debounce D+ Signal  Sets the amount of time (in ms) to debounce the D+ signal during the data pin contact detection phase (while IDP_SRC and RDM_DWN are enabled). Valid values are 1-1023, but the USB Battery Charging Specification requires a minimum value of 10 ms. |
| 15–10<br>Reserved  | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                                       |

Table continues on the next page...

#### **Memory Map/Register Definition**

#### **USBDCD\_TIMER1** field descriptions (continued)

| Field             | Description                                                                                                                                                                                                                                                                                          |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9–0<br>TVDPSRC_ON | Time Period Comparator Enabled                                                                                                                                                                                                                                                                       |
|                   | Sets the amount of time (in ms) that VDP_SRC, IDM_SINK, and the D-/VDAT_REF comparator are enabled and connected to the D+/D- lines during the charging port detection phase of the sequence. Valid values are 1-1023, but the USB Battery Charging Specification requires a minimum value of 40 ms. |

## 40.4.6 USBDCD TIMER2

TIMER2 contains timing parameters. Note that register values can be written that are not compliant with the USB Battery Charging Specification v1.1, so care should be taken when overwriting the default values.

Address: USBDCD\_TIMER2 is FFFF\_8680h base + 18h offset = FFFF\_8698h



#### **USBDCD\_TIMER2** field descriptions

| Field                | Description                                                                                                                                                                                                                                                                                                      |
|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–26<br>Reserved    | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                                                               |
| 25–16<br>TVDPSRC_CON | Time Period Before Enabling D+ Pullup  Sets the amount of time (in ms) that the module waits after charging port detection before system software should enable the D+ pullup to connect to the USB host. Valid values are 1-1023, but the USB Battery Charging Specification requires a minimum value of 40 ms. |
| 15–4<br>Reserved     | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                                                               |
| 3-0<br>CHECK_DM      | Time Before Check of D- Line  Sets the amount of time (in ms) that the module waits after the device connects to the USB bus (software enables the D+ pullup) until checking the state of the D- line to determine the type of charging port. Valid values are 1-15ms.                                           |

# 40.5 Functional Description

The sequence of detecting the presence of and type of charging port involves several hardware components, coordinated by system software. This collection of interacting hardware and software is called the USB Battery Charging Subsystem. The following figure shows the USBDCD module as a component of the subsystem. The following table describes the components.



Figure 40-8. The USB Battery Charging Subsystem

Table 40-13. USB Battery Charger Subsystem Components

| Component          | Description                                                                                                                                                                                                                                                                                                 |                                                                                                              |  |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------|--|
| Battery Charger IC | The external battery charger IC regulates the charge rate to the rechargable battery. System software is responsible for communicating the appropriate charge rates.                                                                                                                                        |                                                                                                              |  |
|                    | Charger                                                                                                                                                                                                                                                                                                     | Maximum Current Drawn <sup>1</sup>                                                                           |  |
|                    | Standard host port                                                                                                                                                                                                                                                                                          | up to 500 mA                                                                                                 |  |
|                    | Charging host port                                                                                                                                                                                                                                                                                          | up to 1500 mA                                                                                                |  |
|                    | Dedicated charging port                                                                                                                                                                                                                                                                                     | up to 1800 mA                                                                                                |  |
|                    | If the USB host has suspended the USB device, system software must configure the system to limit the current drawn from the USB bus to 2.5 mA or less.                                                                                                                                                      |                                                                                                              |  |
| Comm Module        | A communications module on the device can be used to control the charge rate of the battery charger IC.                                                                                                                                                                                                     |                                                                                                              |  |
| System software    | Coordinates the detection activities of the subsystem.                                                                                                                                                                                                                                                      |                                                                                                              |  |
| USB Controller     | USB Controller  The D+ pullup enable control signal plays a role during the charger type detection possible System software must issue a command to the USB controller to assert this signal. pullup is enabled, the device is considered to be connected to the USB bus. The hot attempts to enumerate it. |                                                                                                              |  |
|                    |                                                                                                                                                                                                                                                                                                             | e used only for USB <i>device</i> applications when using the plications the USBDCD module must be disabled. |  |

Table continues on the next page...

#### **Functional Description**

Table 40-13. USB Battery Charger Subsystem Components (continued)

| Component       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| USB Transceiver | The USB transceiver contains the pullup resistor for the USB D+ signal and the pulldown resistors for the USB D+ and D- signals. The D+ pullup and the D- pulldown are both used during the charger detection sequence. The USB transceiver also outputs the digital state of the D+ and D- signals from the USB bus.                                                                                                                                         |
|                 | The pullup and pulldown enable signals are controlled by other modules during the charger detection sequence: The D+ pullup enable is physically output from the USB controller but is under software control. The USBDCD module controls the D- pulldown enable.                                                                                                                                                                                             |
| USBDCD Module   | Detects if the device has been plugged into either a standard host port, a charging host port, or a dedicated charger.                                                                                                                                                                                                                                                                                                                                        |
| VBUS_detect     | This interrupt pin connected to the USB VBUS signal detects when the device has been plugged into or unplugged from the USB bus. If the system requires waking up from a low power mode upon being plugged into the USB port, this interrupt should also be a low power wake up source. If this pin multiplexes other functions, such as GPIO, the pin should be configured as an interrupt whenever the USB plug or unplug event is required to be detected. |

<sup>1.</sup> If the USB host has suspended the USB device, system software must configure the system to limit the current drawn from the USB bus to 2.5 mA or less.

# 40.5.1 The Charger Detection Sequence

The following figure illustrates the charger detection sequence in a simplified timing diagram based on the USB Battery Charging Specification v1.1.



Figure 40-9. Full Speed Charger Detection Timing

The following table provides an overview description of the charger detection sequence shown in the preceding figure.

#### **Functional Description**

Table 40-14. Overview of the Charger Detection Sequence

| Phase |                               | Overview Description                                                                                                                                 | Full Description                            |
|-------|-------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------|
| 1     | Initial Conditions            | Initial system conditions that need to be met before initiating the detection sequence                                                               | Initial System<br>Conditions                |
| 2     | VBUS Detection                | System software detects contact of the VBUS signal with the system interrupt pin VBUS_detect.  VBUS Detect                                           |                                             |
| 3     | Data Pin Contact<br>Detection | The USBDCD module detects that the USB data pins D+ and D- have made contact with the USB port.                                                      | Data Pin Contact<br>Detection               |
| 4     | Charging Port<br>Detection    | The USBDCD module detects if the port is a standard host or either type of charging port (charging host or dedicated charger).  Charging F Detection |                                             |
| 5     | Charger Type<br>Detection     | If attached to a charging port, detect which type.                                                                                                   | Charger Type<br>Detection                   |
| 6     | Sequence<br>Timeout           | The USBDCD module did not finish the detection sequence within the timeout interval. The sequence will continue until halted by software.            | Charger<br>Detection<br>Sequence<br>Timeout |

Timing parameter values used in this module are listed in the following table.

Table 40-15. Timing Parameters for the Charger Detection Sequence

| Parameter                    | <b>USB Battery Charging Spec</b> | Module Default    | Module Programmable Range |
|------------------------------|----------------------------------|-------------------|---------------------------|
| T <sub>DCD_DBNC</sub> 1      | 10 ms min (no max)               | 10 ms             | 0 - 1023 ms               |
| T <sub>VDPSRC_ON</sub> 1     | 40 ms min (no max)               | 40 ms             | 0 - 1023 ms               |
| T <sub>VDPSRC_CON</sub> 1    | 40 ms min (no max)               | 40 ms             | 0 - 1023 ms               |
| CHECK_DM                     | N/A                              | 1 ms              | 0 - 15 ms                 |
| T <sub>SEQ_INIT</sub>        | N/A                              | 16 ms             | 0 - 1023 ms               |
| T <sub>UNIT_CON</sub> 1      | 1 s                              | N/A               | N/A                       |
| T <sub>VDMSRC_EN</sub> 1     | 1 - 20 ms                        | From the USB host | N/A                       |
| T <sub>VDMSRC_DIS</sub> 1    | 0 - 20 ms                        | From the USB host | N/A                       |
| T <sub>CON_IDPSINK_DIS</sub> | 0 - 20 ms                        | From the USB host | N/A                       |

<sup>1.</sup> This parameter is defined by the USB Battery Charging Specification, v1.1.

## 40.5.1.1 Initial System Conditions

Before starting the USBDCD module's charger detection sequence, the system must be:

- using a rechargable battery,
- for a FS USB device application (cannot be HS, LS, host, or OTG),
- powered-up and in run mode,

- recently plugged into a USB port, and
- drawing no more than 2.5 mA total system current from the USB bus.

There are many allowable precursors to this set of initial conditions. For example, the device could have been powered down and subsequently powered up upon being plugged into the USB bus. Alternatively, the device could have been in a low power state that was exited due to the plugin event. Or, the device could have been operating in normal run mode, powered by a separate supply or non-rechargable battery.

#### 40.5.1.2 VBUS Contact Detection

Once the device is plugged into a USB port, the VBUS\_detect system interrupt is triggered. System software should do the following to initialize the module and start the charger detection sequence:

- 1. Restore power if the module is powered-off.
- 2. Set the CONTROL[SR] bit to initiate a software reset.
- 3. Configure the USBDCD module: Program the CLOCK register and the timing parameters as needed.
- 4. Set the CONTROL[IE] bit to enable interrupts (by default), or clear the bit if using a software polling method.
- 5. Set the CONTROL[START] bit to start the charger detection sequence.

## 40.5.1.3 Data Pin Contact Detection

Because the detection sequence depends upon the state of the USB D+, the module must ensure that the data pins have made contact. USB plugs and receptables are designed such that when the plug is inserted into the receptable, the power pins make contact before the data pins make contact. See the following figure.

#### **Functional Description**



Figure 40-10. Relative Pin Positions in USB Plugs and Receptacles

As a result, when a portable USB device is attached to an upstream port, the portable USB device detects VBUS before the data pins have made contact. The time between power pins and data pins making contact depends on how fast the plug is inserted into the receptable. Delays of several hundred milliseconds are possible.

## 40.5.1.3.1 Debouncing the Data Pin Contact

When system software has initiated the charger detection sequence, as described in Initial System Conditions the USBDCD module turns on the  $I_{DP\_SRC}$  current source and enables the  $R_{DM\_DWN}$  pulldown resistor. If the data pins have not made contact, the D+ line remains high. Once the data pins make contact, the D+ line goes low and debouncing begins.

Once the D+ line goes low, the module continuously samples the D+ line over the duration of the  $T_{DCD\_DBNC}$  debounce time interval.  $T_{DCD\_DBNC}$  defaults to 10 ms but can be programmed in the TIMER0[TDCD\_DBNC] field. See the description of the TIMER0 Register for register information.

When it has remained low for the entire interval, the debouncing is complete. However, if the D+ line returns high during the debounce interval, the module waits until the D+ line goes low again to restart the debouncing. This cycle repeats until either:

- the data pin contact has been successfully debounced (see Success in Detecting Data Pin Contact (Phase Completion)), or
- a timeout occurs (see Charger Detection Sequence Timeout).

## 40.5.1.3.2 Success in Detecting Data Pin Contact (Phase Completion)

After successfully debouncing the D+ state, the module does the following:

- updates the STATUS register to reflect phase completion (See Table 40-18 for field values.)
- directly proceeds to the next step in the sequence: detection of a charging port See Charging Port Detection.

## 40.5.1.4 Charging Port Detection

Once it is known that the data pins have made contact, the module waits for a fixed delay of 1 ms, and then attempts to detect if it has been plugged into a charging port. The module connects the following analog units to the USB D+ or D- lines during this phase (when the usbdcd\_en and usbdcd\_chg\_det\_en signals are asserted high):

- The voltage source V<sub>DP</sub> <sub>SRC</sub> connects to the D+ line
- The current sink I<sub>DM</sub> SINK connects to the D- line
- $\bullet$  The voltage comparator connects to the USB D- line, comparing it to the voltage  $V_{DAT\ REF}$  .

After a time of  $T_{VDPSRC\_ON}$ , the module samples the D- line. The  $T_{VDPSRC\_ON}$  parameter is programmable and defaults to 40 ms. After sampling the D- line, the module disconnects the voltage source, current sink, and comparator.

The next steps in the sequence depend on the voltage on the D- line as determined by the voltage comparator. See the following table.

 If the voltage on D- is...
 Then...
 See...

 Below V<sub>DAT\_REF</sub>
 The port is a standard host that does not support the USB Battery Charging Specification v1.1.
 Standard Host Port

 Above V<sub>DAT\_REF</sub> but below V<sub>LGC</sub>
 The port is a charging port.
 Charging Port

 Above V<sub>LGC</sub>
 This is an error condition..
 Error in Charging Port Detection

Table 40-16. Sampling D- in the Charging Port Detection Phase

#### 40.5.1.4.1 Standard Host Port

As part of the charger detection handshake with a standard USB host, the module does the following (without waiting for the T<sub>VDPSRC CON</sub> interval to elapse):

• Updates the STATUS register to reflect that a standard host has been detected with SEQ\_RES = 01. (See Table 40-18 for field values.)

#### **Functional Description**

- Sets the CONTROL[IF] bit.
- Generates an interrupt if enabled (the CONTROL[IE] bit is set).

At this point, control has been passed to system software via the interrupt. The rest of the sequence (detecting the type of charging port) is not applicable, so software should:

- 1. Read the STATUS register.
- 2. Set the CONTROL[IACK] bit to acknowledge the interrupt.
- 3. Set the CONTROL[SR] bit to issue a software reset to the module.
- 4. Disable the module.
- 5. Communicate the appropriate charge rate to the external battery charger IC; see Table 40-13.

## **40.5.1.4.2 Charging Port**

As part of the charger detection handshake with any type of USB host, the module waits until the T<sub>VDPSRC CON</sub> interval has elapsed before doing the following:

- Updates the STATUS register to reflect that a charging port has been detected with SEQ\_RES = 10. (See Table 40-18 for field values.)
- Sets the CONTROL[IF] bit.
- Generates an interrupt if enabled (the CONTROL[IE] bit is set).

At this point, control has passed to system software via the interrupt. Software should:

- 1. Read the STATUS register.
- 2. Set the CONTROL[IACK] bit to acknowledge the interrupt.
- 3. Issue a command to the USB controller to pullup the USB D+ line.
- 4. Wait for the module to complete the final phase of the sequence. See Charger Type Detection.

## 40.5.1.4.3 Error in Charging Port Detection

For this error condition, the module does the following:

- Updates the STATUS register to reflect the error with SEQ\_RES = 00. (See Table 40-18 for field values.)
- Sets the CONTROL[IF] bit.
- Generates an interrupt if enabled (the CONTROL[IE] bit is set).

Note that in this case the module does not wait for the T<sub>VDPSRC</sub> CON interval to elapse.

At this point, control has been passed to system software via the interrupt. The rest of the sequence (detecting the type of charging port) is not applicable, so software should:

- 1. Read the STATUS register.
- 2. Set the CONTROL[IACK] bit to acknowledge the interrupt.
- 3. Set the CONTROL[SR] bit to issue a software reset to the module.
- 4. Disable the module.

# 40.5.1.5 Charger Type Detection

After software enables the D+ pullup resistor, the module is notified automatically (via internal signaling; the module waits until the ipp\_pue\_pullup\_dp input goes high) to start the CHECK\_DM timer counting down the time interval programmed into the TIMER2[CHECK\_DM] field.

Once the CHECK\_DM time has elapsed, the module samples the USB D- line to determine the type of charger. See the following table.

Table 40-17. Sampling D- in the Charger Type Detection Phase

| If the voltage on D- is | Then                                    | See                        |
|-------------------------|-----------------------------------------|----------------------------|
| High                    | The port is a dedicated charging port.1 | Dedicated<br>Charging Port |
| Low                     | The port is a charging host port.2      | Charging Host<br>Port      |

- 1. In a dedicated charger, the D+ and D- lines are shorted together through a small resistor.
- 2. In a charging host port, the D+ and D- lines are not shorted.

# 40.5.1.5.1 Dedicated Charging Port

For a dedicated charger, the module does the following:

#### **Functional Description**

- Updates the STATUS register to reflect that a dedicated charger has been detected with SEQ\_RES = 11. (See Table 40-18 for field values.)
- Sets the CONTROL[IF] bit.
- Generates an interrupt if enabled (the CONTROL[IE] bit is set).

At this point, control has been passed to system software via the interrupt. Software should:

- 1. Read the STATUS register.
- 2. Disable the USB controller to prevent transitions on the USB D+ or D- lines from causing spurious interrupt or wake-up events to the system.
- 3. Set the CONTROL[IACK] bit to acknowledge the interrupt.
- 4. Set the CONTROL[SR] bit to issue a software reset to the module.
- 5. Disable the module.
- 6. Communicate the appropriate charge rate to the external battery charger IC; see Table 40-13.

# 40.5.1.5.2 Charging Host Port

For a charging host port, the module does the following:

- Updates the STATUS register to reflect that a charging host port has been detected with SEQ\_RES = 10. (See Table 40-18 for field values.)
- Sets the CONTROL[IF] bit.
- Generates an interrupt if enabled (the CONTROL[IE] bit is set).

At this point, control has been passed to system software via the interrupt. Software should:

- 1. Read the STATUS register.
- 2. Set the CONTROL[IACK] bit to acknowledge the interrupt.
- 3. Set the CONTROL[SR] bit to issue a software reset to the module.
- 4. Disable the module.
- 5. Communicate the appropriate charge rate to the external battery charger IC; see Table 40-13.

# 40.5.1.6 Charger Detection Sequence Timeout

The maximum time to connect allowed under the *USB Battery Charging Specification*, v1.1 is one second. If the Unit Connection Timer reaches the one second limit and the sequence is still running (indicated by the STATUS[ACTIVE] bit still being set), the module does the following:

- Updates the STATUS register to reflect that a timeout error has occured. (See Table 40-18 for field values.)
- Sets the CONTROL[IF] bit.
- Generates an interrupt if enabled (the CONTROL[IE] bit is set).
- The detection sequence continues until explicitly halted by software setting the CONTROL[SR] bit.
- The Unit Connection Timer continues counting. See the description of the TIMER0 Register.

At this point, control has been passed to system software via the interrupt, which has two options: ignore the interrupt and allow more time for the sequence to complete, or halt the sequence. To halt the sequence, software should:

- 1. Read the STATUS register.
- 2. Set the CONTROL[IACK] bit to acknowledge the interrupt.
- 3. Set the CONTROL[SR] bit to issue a software reset to the module.
- 4. Disable the module.

This timeout function is also useful in case software does not realize that the user unplugged the USB device from the USB port during the charger detection sequence. If the interrupt occurs but the  $V_{BUS\_DETECT}$  input is low, software can disable and reset the module.

System software might allow the sequence to run past the timeout interrupt under these conditions:

- 1. the USB Battery Charging Spec is amended to allow more time. In this case, software should poll the T<sub>UNITCON</sub> register field (see the description of the TIMER0 Register) periodically to track elapsed time after 1s; or
- 2. for debug purposes.

#### **Functional Description**

Note that the  $T_{UNITCON}$  register field will stop incrementing when it reaches its maximum value so it will not rollover to zero and start counting up again.

# 40.5.2 Interrupts and Events

The USBDCD module has an interrupt to alert system software of certain events, which are listed in the following table. All events except the Phase Complete event for the Data Pin Detection phase can trigger an interrupt.

Table 40-18. Events Triggering an Interrupt by Sequence Phase

| Sequence<br>Phase | Event    | Event Description                                                         | STATUS Fields <sup>1</sup>         | Phase<br>Description  |
|-------------------|----------|---------------------------------------------------------------------------|------------------------------------|-----------------------|
| Data Pin          | Phase    | The module has detected data pin contact.                                 | ERR = 0                            | VBUS Contact          |
| Detection         | Complete | No interrupt occurs: CONTROL[IF] = 0.                                     | SEQ_STAT = 01                      | Detection             |
|                   |          |                                                                           | SEQ_RES = 00                       |                       |
|                   |          |                                                                           | TO = 0                             |                       |
| Charging Port     | Phase    | The module has completed the process of                                   | ERR = 0                            | Charging Port         |
| Detection         | Complete | identifying if the USB port is a charging port or not.                    | SEQ_STAT = 10                      | Detection             |
|                   |          |                                                                           | SEQ_RES = 01 or 10                 |                       |
|                   |          |                                                                           | TO = 0                             |                       |
|                   | Error    | The module cannot identify the type of port                               | ERR = 1                            | Error in Charging     |
|                   |          | because the D- line is above the USB's VLGC threshold.                    | SEQ_STAT = 10                      | Port Detection        |
|                   |          | a moonora.                                                                | SEQ_RES = 00                       |                       |
|                   |          |                                                                           | TO = 0                             |                       |
| Charger Type      | Phase    | The module has completed the process of                                   | ERR = 0                            | Charger Type          |
| Detection         | Complete | identifying the charger type detection.                                   | SEQ_STAT = 11                      | Detection             |
|                   |          | Note: The ERR flag always reads as zero because no known error conditions | SEQ_RES = 11 or 10                 |                       |
|                   |          | are checked during this phase.                                            | TO = 0                             |                       |
| Sequence          | Error    | The timeout interval from the time the USB                                | ERR = 1                            | Charger               |
| Timeout           |          | device attaches to a USB port until it connects has elapsed               | SEQ_STAT = last value <sup>2</sup> | Detection<br>Sequence |
|                   |          |                                                                           | SEQ_RES = last value <sup>2</sup>  | Timeout.              |
|                   |          |                                                                           | TO = 1                             |                       |

<sup>1.</sup> See the description of the Status Register for register information.

# 40.5.2.1 Interrupt Handling

Software can read which event caused the interrupt from the STATUS register during the interrupt service routine.

<sup>2.</sup> The SEQ\_STAT and SEQ\_RES fields retain the values held at the time of the timeout error.

An interrupt is generated only if the CONTROL[IE] bit is set. The CONTROL[IF] bit is always set under interrupt conditions, even if the IE bit is cleared. In this case, software can poll the IF flag to determine if an interrupt condition is pending.

Writes to the IF bit are ignored. To reset the IF bit, set the CONTROL[IACK] bit to acknowledge the interrupt. Writing to the IACK bit while the IF bit is cleared has no effect.

#### 40.5.3 Resets

There are two ways to reset various register contents in this module: hardware resets and a software reset.

#### 40.5.3.1 Hardware Resets

Hardware resets originate at the system or device level and propagate down to the individual module level. They include power-on reset, low-voltage reset, and all other hardware reset sources.

Hardware resets cause the register contents to be restored to their default state as listed in the register descriptions.

## 40.5.3.2 Software Reset

A software reset re-initializes the module's status information but leaves configuration information unchanged. The software reset allows software to prepare the module without needing to reprogram the same configuration each time the USB device is plugged into a USB port.

Setting the CONTROL[SR] bit initiates a software reset. The following table shows what register fields are reset to their default values by a software reset.

| Register             | Fields Affected | Fields Not Affected |
|----------------------|-----------------|---------------------|
| CONTROL <sup>1</sup> | [IF]            | [IE, START]         |
| STATUS               | All             | None                |
| CLOCK                | None            | All                 |
| TIMER <i>n</i>       | TUNITCON        | All other           |

Table 40-19. Software Reset and Register Fields Affected

1. The CONTROL[SR, IACK] bits are self-clearing.

#### **Initialization Information**

A software reset also returns all internal logic, timers, and counters to their reset states. State Machines return to IDLE. If the module is already active (STATUS[ACTIVE] = 1), a software reset stops the sequence.

#### **Note**

Software should always initiate a software reset before starting the sequence (setting the CONTROL[START] bit) to ensure the module is in a known state.

### 40.6 Initialization Information

This module has been designed for minimal configuration while retaining significant programmability. The CLOCK register needs to be initialized to the actual system clock frequency (unless the default value already matches the system requirements).

The other registers generally do not need to be modified because they default to values that comply with the USB Battery Charging Specification v1.1. However, several timing parameters can be changed for a great deal of flexibility if a particular system requires it.

All module configuration must occur *before* initiating the charger detection sequence. Configuration changes made *after* setting the CONTROL[START] bit result in undefined behavior.

# 40.7 Application Information

This section provides application information.

# 40.7.1 External Pullups

Any external pullups applied to the USB D+ or D- data lines must be capable of being disabled to prevent incorrect pullup values or incorrect operation of the USB subsystem.

# 40.7.2 Dead or Weak Battery

According to the USB Battery Charging Specification v1.1, a USB device with a dead, weak, or missing battery that is attached to a charging port can remain attached indefinitely drawing up to 1.5A until the battery is charged to the point that the USB device can connect.

The USBDCD module is compatible with systems that do not check the strength of the battery. Therefore, this module assumes that the battery is good, so the USB device must immediately connect to the USB bus by pulling the D+ line high after the USBDCD module has determined that the device is attached to a charging port. The module is also compatible with systems that do check the strength of the battery. In these systems, if it is known that the battery is weak or dead, software can delay connecting to the USB while charging at 1.5A. Once the battery is charged to the good battery threshold, software can then connect to the USB host by pulling the D+ line high.

# 40.7.3 Handling Unplug Events

If the device is unplugged from the USB bus during the charger detection sequence, the contents of the STATUS register should be ignored and the USBDCD module should get a Sotware Reset, as described in Software Reset.



# **Chapter 41 USB Voltage Regulator (VREG)**

## 41.1 Introduction

The USB Voltage Regulator module is a LDO linear voltage regulator to provide 3.3V power from an input power supply varying from 2.7 V to 5.5 V. It consists of one 3.3 V power channel. When the input power supply is below 3.6 V, the regulator goes to pass-through mode. The following figure shows the ideal relation between the regulator output and input power supply.



Figure 41-1. Ideal Relation Between the Regulator Output and Input Power Supply

## 41.1.1 Overview

A simplified block diagram for the USB Voltage Regulator module is shown below.

#### Introduction



Figure 41-2. USB Voltage Regulator Block Diagram

This module uses 2 regulators in parallel. In run mode, the RUN regulator with the bandgap voltage reference is enabled and can provide up to 120 mA load current. In run mode, the STANDBY regulator and the low power reference are also enabled, but a switch disconnects its output from the external pin. In STANDBY mode, the RUN regulator is disabled and the STANDBY regulator output is connected to the external pin supplying up to 3 mA load current.

Internal power mode signals control whether the module is in RUN or STANDBY mode.

## 41.1.2 Features

- Low drop-out linear voltage regulator with one power channel (3.3V).
- Low drop-out voltage: 300 mV.
- Output current: 120 mA.
- Three different power modes: RUN, STANDBY and SHUTDOWN.
- Low quiescent current in RUN mode.
  - Typical value is around 120 uA (one thousand times smaller than the maximum load current).
- Very low quiescent current in STANDBY mode.
  - Typical value is around 1 uA.
- Automatic current limiting if the load current is greater than 290 mA.
- Automatic power-up once some voltage is applied to the regulator input.

- Pass-through mode for regulator input voltages less than 3.6 V
- Small output capacitor: 2.2 uF
- Stable with aluminum, tantalum or ceramic capacitors.

# 41.1.3 Modes of Operation

The regulator has these power modes:

- RUN—The regulating loop of the RUN regulator and the STANDBY regulator are active, but the switch connecting the STANDBY regulator output to the external pin is open.
- STANDBY—The regulating loop of the RUN regulator is disabled and the standby regulator is active. The switch connecting the STANDBY regulator output to the external pin is closed.
- SHUTDOWN—The module is disabled.

The regulator is enabled by default. This means that once the power supply is provided, the module power-up sequence to RUN mode starts.

# 41.2 USB Voltage Regulator Module Signal Descriptions

The following table shows the external signals for the regulator.

Table 41-1. USB Voltage Regulator Module Signal Descriptions

| Signal    | Description              | I/O |
|-----------|--------------------------|-----|
| reg33_in  | Unregulated power supply | I   |
| reg33_out | Regulator output voltage | 0   |



# **Chapter 42 Inter-Integrated Circuit (I2C)**

## 42.1 Introduction

The inter-integrated circuit (I<sup>2</sup>C, I2C, or IIC) module provides a method of communication between a number of devices. The interface is designed to operate up to 100 kbit/s with maximum bus loading and timing. The device is capable of operating at higher baud rates, up to a maximum of clock/20, with reduced bus loading. The maximum communication length and the number of devices that can be connected are limited by a maximum bus capacitance of 400 pF. The I2C module also complies with the *System Management Bus (SMBus) Specification, version 2*.

# 42.1.1 Features

The I2C module has these distinctive features:

- Compatible with *The I<sup>2</sup>C-Bus Specification*
- Multimaster operation
- Software programmable for one of 64 different serial clock frequencies
- Software-selectable acknowledge bit
- Interrupt-driven byte-by-byte data transfer
- Arbitration-lost interrupt with automatic mode switching from master to slave
- Calling address identification interrupt
- START and STOP signal generation and detection
- Repeated START signal generation and detection
- Acknowledge bit generation and detection
- Bus busy detection
- General call recognition
- 10-bit address extension
- Support for System Management Bus (SMBus) Specification, version 2
- Programmable glitch input filter
- Low power mode wakeup on slave address match

#### Introduction

- Range slave address support
- DMA support

# 42.1.2 Modes of Operation

To summarize the I2C module's operation in various low power modes:

- Run mode: This is the basic mode of operation. To conserve power in this mode, disable the module.
- Wait mode: The module continues to operate when the core is in wait mode and can provide a wakeup interrupt.
- Stop mode: The module is inactive in stop mode for reduced power consumption, except that address matching is enabled in stop mode. The STOP instruction does not affect the I2C module's register states. In any VLLSx mode, the register contents are reset.

# 42.1.3 Block Diagram

The following figure is a block diagram of the I2C module.



Figure 42-1. I2C Functional Block Diagram

# 42.2 I<sup>2</sup>C Signal Descriptions

The signal properties of I<sup>2</sup>C are shown in the following table.

Table 42-1. I<sup>2</sup>C Signal Descriptions

| Signal | Description                                                     | I/O |
|--------|-----------------------------------------------------------------|-----|
| SCL    | Bidirectional serial clock line of the I <sup>2</sup> C system. | I/O |
| SDA    | Bidirectional serial data line of the I <sup>2</sup> C system.  | I/O |

# 42.3 Memory Map and Registers

This section describes in detail all I2C registers accessible to the end user.

## **Memory Map and Registers**

# I2Cx memory map

| Absolute<br>address<br>(hex) | Register name                                            | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|------------------------------|----------------------------------------------------------|--------------------|--------|-------------|------------------|
| FFFF_81C0                    | I2C Address Register 1 (I2C0_A1)                         | 8                  | R/W    | 00h         | 42.3.1/<br>1026  |
| FFFF_81C1                    | I2C Frequency Divider register (I2C0_F)                  | 8                  | R/W    | 00h         | 42.3.2/<br>1027  |
| FFFF_81C2                    | I2C Control Register 1 (I2C0_C1)                         | 8                  | R/W    | 00h         | 42.3.3/<br>1028  |
| FFFF_81C3                    | I2C Status Register (I2C0_S)                             | 8                  | R/W    | 80h         | 42.3.4/<br>1029  |
| FFFF_81C4                    | I2C Data I/O register (I2C0_D)                           | 8                  | R/W    | 00h         | 42.3.5/<br>1031  |
| FFFF_81C5                    | I2C Control Register 2 (I2C0_C2)                         | 8                  | R/W    | 00h         | 42.3.6/<br>1032  |
| FFFF_81C6                    | I2C Programmable Input Glitch Filter register (I2C0_FLT) | 8                  | R/W    | 00h         | 42.3.7/<br>1033  |
| FFFF_81C7                    | I2C Range Address register (I2C0_RA)                     | 8                  | R/W    | 00h         | 42.3.8/<br>1034  |
| FFFF_81C8                    | I2C SMBus Control and Status register (I2C0_SMB)         | 8                  | R/W    | 00h         | 42.3.9/<br>1034  |
| FFFF_81C9                    | I2C Address Register 2 (I2C0_A2)                         | 8                  | R/W    | C2h         | 42.3.10/<br>1036 |
| FFFF_81CA                    | I2C SCL Low Timeout Register High (I2C0_SLTH)            | 8                  | R/W    | 00h         | 42.3.11/<br>1037 |
| FFFF_81CB                    | I2C SCL Low Timeout Register Low (I2C0_SLTL)             | 8                  | R/W    | 00h         | 42.3.12/<br>1037 |
| FFFF_81D0                    | I2C Address Register 1 (I2C1_A1)                         | 8                  | R/W    | 00h         | 42.3.1/<br>1026  |
| FFFF_81D1                    | I2C Frequency Divider register (I2C1_F)                  | 8                  | R/W    | 00h         | 42.3.2/<br>1027  |
| FFFF_81D2                    | I2C Control Register 1 (I2C1_C1)                         | 8                  | R/W    | 00h         | 42.3.3/<br>1028  |
| FFFF_81D3                    | I2C Status Register (I2C1_S)                             | 8                  | R/W    | 80h         | 42.3.4/<br>1029  |
| FFFF_81D4                    | I2C Data I/O register (I2C1_D)                           | 8                  | R/W    | 00h         | 42.3.5/<br>1031  |
| FFFF_81D5                    | I2C Control Register 2 (I2C1_C2)                         | 8                  | R/W    | 00h         | 42.3.6/<br>1032  |
| FFFF_81D6                    | I2C Programmable Input Glitch Filter register (I2C1_FLT) | 8                  | R/W    | 00h         | 42.3.7/<br>1033  |
| FFFF_81D7                    | I2C Range Address register (I2C1_RA)                     | 8                  | R/W    | 00h         | 42.3.8/<br>1034  |

Table continues on the next page...

# I2Cx memory map (continued)

| Absolute address (hex) | Register name                                            | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|------------------------|----------------------------------------------------------|--------------------|--------|-------------|------------------|
| FFFF_81D8              | I2C SMBus Control and Status register (I2C1_SMB)         | 8                  | R/W    | 00h         | 42.3.9/<br>1034  |
| FFFF_81D9              | I2C Address Register 2 (I2C1_A2)                         | 8                  | R/W    | C2h         | 42.3.10/<br>1036 |
| FFFF_81DA              | I2C SCL Low Timeout Register High (I2C1_SLTH)            | 8                  | R/W    | 00h         | 42.3.11/<br>1037 |
| FFFF_81DB              | I2C SCL Low Timeout Register Low (I2C1_SLTL)             | 8                  | R/W    | 00h         | 42.3.12/<br>1037 |
| FFFF_81E0              | I2C Address Register 1 (I2C2_A1)                         | 8                  | R/W    | 00h         | 42.3.1/<br>1026  |
| FFFF_81E1              | I2C Frequency Divider register (I2C2_F)                  | 8                  | R/W    | 00h         | 42.3.2/<br>1027  |
| FFFF_81E2              | I2C Control Register 1 (I2C2_C1)                         | 8                  | R/W    | 00h         | 42.3.3/<br>1028  |
| FFFF_81E3              | I2C Status Register (I2C2_S)                             | 8                  | R/W    | 80h         | 42.3.4/<br>1029  |
| FFFF_81E4              | I2C Data I/O register (I2C2_D)                           | 8                  | R/W    | 00h         | 42.3.5/<br>1031  |
| FFFF_81E5              | I2C Control Register 2 (I2C2_C2)                         | 8                  | R/W    | 00h         | 42.3.6/<br>1032  |
| FFFF_81E6              | I2C Programmable Input Glitch Filter register (I2C2_FLT) | 8                  | R/W    | 00h         | 42.3.7/<br>1033  |
| FFFF_81E7              | I2C Range Address register (I2C2_RA)                     | 8                  | R/W    | 00h         | 42.3.8/<br>1034  |
| FFFF_81E8              | I2C SMBus Control and Status register (I2C2_SMB)         | 8                  | R/W    | 00h         | 42.3.9/<br>1034  |
| FFFF_81E9              | I2C Address Register 2 (I2C2_A2)                         | 8                  | R/W    | C2h         | 42.3.10/<br>1036 |
| FFFF_81EA              | I2C SCL Low Timeout Register High (I2C2_SLTH)            | 8                  | R/W    | 00h         | 42.3.11/<br>1037 |
| FFFF_81EB              | I2C SCL Low Timeout Register Low (I2C2_SLTL)             | 8                  | R/W    | 00h         | 42.3.12/<br>1037 |
| FFFF_81F0              | I2C Address Register 1 (I2C3_A1)                         | 8                  | R/W    | 00h         | 42.3.1/<br>1026  |
| FFFF_81F1              | I2C Frequency Divider register (I2C3_F)                  | 8                  | R/W    | 00h         | 42.3.2/<br>1027  |
| FFFF_81F2              | I2C Control Register 1 (I2C3_C1)                         | 8                  | R/W    | 00h         | 42.3.3/<br>1028  |
| FFFF_81F3              | I2C Status Register (I2C3_S)                             | 8                  | R/W    | 80h         | 42.3.4/<br>1029  |

Table continues on the next page...

#### **Memory Map and Registers**

## I2Cx memory map (continued)

| Absolute address (hex) | Register name                                            | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|------------------------|----------------------------------------------------------|--------------------|--------|-------------|------------------|
| FFFF_81F4              | I2C Data I/O register (I2C3_D)                           | 8                  | R/W    | 00h         | 42.3.5/<br>1031  |
| FFFF_81F5              | I2C Control Register 2 (I2C3_C2)                         | 8                  | R/W    | 00h         | 42.3.6/<br>1032  |
| FFFF_81F6              | I2C Programmable Input Glitch Filter register (I2C3_FLT) | 8                  | R/W    | 00h         | 42.3.7/<br>1033  |
| FFFF_81F7              | I2C Range Address register (I2C3_RA)                     | 8                  | R/W    | 00h         | 42.3.8/<br>1034  |
| FFFF_81F8              | I2C SMBus Control and Status register (I2C3_SMB)         | 8                  | R/W    | 00h         | 42.3.9/<br>1034  |
| FFFF_81F9              | I2C Address Register 2 (I2C3_A2)                         | 8                  | R/W    | C2h         | 42.3.10/<br>1036 |
| FFFF_81FA              | I2C SCL Low Timeout Register High (I2C3_SLTH)            | 8                  | R/W    | 00h         | 42.3.11/<br>1037 |
| FFFF_81FB              | I2C SCL Low Timeout Register Low (I2C3_SLTL)             | 8                  | R/W    | 00h         | 42.3.12/<br>1037 |

# 42.3.1 I2C Address Register 1 (I2Cx\_A1)

This register contains the slave address to be used by the I2C module.

Addresses: I2C0\_A1 is FFFF\_81C0h base + 0h offset = FFFF\_81C0h I2C1\_A1 is FFFF\_81D0h base + 0h offset = FFFF\_81D0h I2C2\_A1 is FFFF\_81E0h base + 0h offset = FFFF\_81E0h I2C3\_A1 is FFFF\_81F0h base + 0h offset = FFFF\_81F0h



## I2Cx\_A1 field descriptions

| Field          | Description                                                                                                                                                                                      |
|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–1<br>AD[7:1] | Address                                                                                                                                                                                          |
|                | Contains the primary slave address used by the I2C module when it is addressed as a slave. This field is used in the 7-bit address scheme and the lower seven bits in the 10-bit address scheme. |
| 0<br>Reserved  | This read-only bit is reserved and always has the value zero.                                                                                                                                    |

# 42.3.2 I2C Frequency Divider register (I2Cx\_F)

Addresses: I2C0\_F is FFFF\_81C0h base + 1h offset = FFFF\_81C1h
I2C1\_F is FFFF\_81D0h base + 1h offset = FFFF\_81D1h
I2C2\_F is FFFF\_81E0h base + 1h offset = FFFF\_81E1h
I2C3\_F is FFFF\_81F0h base + 1h offset = FFFF\_81F1h

Bit 7 6 5 4 3 2



## I2Cx\_F field descriptions

| Field       | Description                                                                                                                                                                                                                                                                 |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–6<br>MULT | The MULT bits define the multiplier factor mul. This factor is used along with the SCL divider to generate the I2C baud rate.                                                                                                                                               |
|             | 00 mul = 1                                                                                                                                                                                                                                                                  |
|             | 01 mul = 2                                                                                                                                                                                                                                                                  |
|             | 10 mul = 4                                                                                                                                                                                                                                                                  |
|             | 11 Reserved                                                                                                                                                                                                                                                                 |
| 5–0         | Clock rate                                                                                                                                                                                                                                                                  |
| ICR         | Prescales the bus clock for bit rate selection. This field and the MULT field determine the I2C baud rate, the SDA hold time, the SCL start hold time, and the SCL stop hold time. For a list of values corresponding to each ICR setting, see I2C Divider and Hold Values. |
|             | The SCL divider multiplied by multiplier factor (mul) determines the I2C baud rate.                                                                                                                                                                                         |
|             | I2C baud rate = bus speed (Hz)/(mul x SCL divider)                                                                                                                                                                                                                          |
|             | The SDA hold time is the delay from the falling edge of SCL (I2C clock) to the changing of SDA (I2C data).                                                                                                                                                                  |
|             | SDA hold time = bus period (s) × mul × SDA hold value                                                                                                                                                                                                                       |
|             | The SCL start hold time is the delay from the falling edge of SDA (I2C data) while SCL is high (start condition) to the falling edge of SCL (I2C clock).                                                                                                                    |
|             | SCL start hold time = bus period (s) × mul × SCL start hold value                                                                                                                                                                                                           |
|             | The SCL stop hold time is the delay from the rising edge of SCL (I2C clock) to the rising edge of SDA (I2C data) while SCL is high (stop condition).                                                                                                                        |
|             | SCL stop hold time = bus period (s) × mul × SCL stop hold value                                                                                                                                                                                                             |

# 42.3.3 I2C Control Register 1 (I2Cx\_C1)

Addresses: I2C0\_C1 is FFFF\_81C0h base + 2h offset = FFFF\_81C2h I2C1\_C1 is FFFF\_81D0h base + 2h offset = FFFF\_81D2h I2C2\_C1 is FFFF\_81E0h base + 2h offset = FFFF\_81E2h I2C3\_C1 is FFFF\_81F0h base + 2h offset = FFFF\_81F2h



## I2Cx\_C1 field descriptions

| Field      | Description                                                                                                                                                                                                                                                                                                                                          |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>IICEN | I2C enable Enables I2C module operation.                                                                                                                                                                                                                                                                                                             |
|            | <ul><li>0 Disabled</li><li>1 Enabled</li></ul>                                                                                                                                                                                                                                                                                                       |
| 6<br>IICIE | I2C interrupt enable Enables I2C interrupt requests.  0 Disabled 1 Enabled                                                                                                                                                                                                                                                                           |
| 5<br>MST   | Master mode select  When the MST bit is changed from a 0 to a 1, a START signal is generated on the bus and master mode is selected. When this bit changes from a 1 to a 0, a STOP signal is generated and the mode of operation changes from master to slave.  0 Slave mode  1 Master mode                                                          |
| 4<br>TX    | Transmit mode select  Selects the direction of master and slave transfers. In master mode this bit must be set according to the type of transfer required. Therefore, for address cycles, this bit is always set. When addressed as a slave this bit must be set by software according to the SRW bit in the status register.  O Receive  1 Transmit |
| 3<br>TXAK  | Transmit acknowledge enable  Specifies the value driven onto the SDA during data acknowledge cycles for both master and slave receivers. The value of the FACK bit affects NACK/ACK generation.                                                                                                                                                      |

Table continues on the next page...

# I2Cx\_C1 field descriptions (continued)

| Field      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | O An acknowledge signal is sent to the bus on the following (if FACK is cleared) or current (if FACK is set) receiving byte.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|            | 1 No acknowledge signal is sent to the bus on the following (if FACK is cleared) or current (if FACK is set) receiving data byte.NOTE:SCL is held low until TXAK is written.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 2<br>RSTA  | Repeat START                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|            | Writing a one to this bit generates a repeated START condition provided it is the current master. This bit will always be read as zero. Attempting a repeat at the wrong time results in loss of arbitration.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 1<br>WUEN  | Wakeup enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| WOLK       | The I2C module can wake the MCU from low power mode with no peripheral bus running when slave address matching occurs.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|            | <ul> <li>Normal operation. No interrupt generated when address matching in low power mode.</li> <li>Enables the wakeup function in low power mode.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 0<br>DMAFN | DMA enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| DIVIALIN   | The DMAEN bit enables or disables the DMA function.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|            | 0 All DMA signalling disabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|            | DMA transfer is enabled and the following conditions trigger the DMA request:•While FACK = 0, a data byte is received, either address or data is transmitted. (ACK/NACK automatic)•While FACK = 0, the first byte received matches the A1 register or is general call address. If any address matching occurs, IAAS and TCF are set. If the direction of transfer is known from master to slave, then it is not required to check the SRW. With this assumption, DMA can also be used in this case. In other cases, if the master reads data from the slave, then it is required to rewrite the C1 register operation. With this assumption, DMA cannot be used.When FACK = 1, an address or a data byte is transmitted. |

# 42.3.4 I2C Status Register (I2Cx\_S)

Addresses: I2C0\_S is FFFF\_81C0h base + 3h offset = FFFF\_81C3h I2C1\_S is FFFF\_81D0h base + 3h offset = FFFF\_81D3h I2C2\_S is FFFF\_81E0h base + 3h offset = FFFF\_81E3h I2C3\_S is FFFF\_81F0h base + 3h offset = FFFF\_81F3h



## I2Cx\_S field descriptions

| Field    | Description            |
|----------|------------------------|
| 7<br>TCF | Transfer complete flag |

Table continues on the next page...

## **Memory Map and Registers**

# I2Cx\_S field descriptions (continued)

| Field     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|           | This bit sets on the completion of a byte and acknowledge bit transfer. This bit is only valid during or immediately following a transfer to or from the I2C module. The TCF bit is cleared by reading the I2C data register in receive mode or by writing to the I2C data register in transmit mode.  O Transfer in progress                                                                                                                                                                                                                                                                                                                                                                                                |
|           | Transfer in progress     Transfer complete                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 6<br>IAAS | Addressed as a slave  This bit is set by one of the following conditions:  • The calling address matches the programmed slave primary address in the A1 register or range address in the RA register (which must be set to a nonzero value).  • GCAEN is set and a general call is received.  • SIICAEN is set and the calling address matches the second programmed slave address.  • ALERTEN is set and an SMBus alert response address is received  • RMEN is set and an address is received that is within the range between the values of the A1 and RA registers.  This bit sets before the ACK bit. The CPU must check the SRW bit and set TX/RX accordingly. Writing the C1 register with any value clears this bit. |
|           | Not addressed     Addressed as a slave                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 5<br>BUSY | Bus busy  Indicates the status of the bus regardless of slave or master mode. This bit is set when a START signal is detected and cleared when a STOP signal is detected.  0 Bus is idle 1 Bus is busy                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 4<br>ARBL | Arbitration lost  This bit is set by hardware when the arbitration procedure is lost. The ARBL bit must be cleared by software, by writing a one to it.  O Standard bus operation.  Loss of arbitration.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 3<br>RAM  | Range address match  This bit is set by any of the following conditions:  • Any nonzero calling address is received that matches the address in the RA register.  • The RMEN bit is set and the calling address is within the range of values of the A1 and RA registers.  Writing the C1 register with any value clears this bit.  0 Not addressed  1 Addressed as a slave                                                                                                                                                                                                                                                                                                                                                  |
| 2<br>SRW  | Slave read/write  When addressed as a slave, SRW indicates the value of the R/W command bit of the calling address sent to the master.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

Table continues on the next page...

## I2Cx\_S field descriptions (continued)

| Field      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | 0 Slave receive, master writing to slave                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|            | 1 Slave transmit, master reading from slave                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 1<br>IICIF | Interrupt flag                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|            | <ul> <li>This bit sets when an interrupt is pending. This bit must be cleared by software or by writing a 1 to it in the interrupt routine. One of the following events can set this bit:</li> <li>One byte transfer including ACK/NACK bit completes if FACK = 0</li> <li>One byte transfer excluding ACK/NACK bit completes if FACK = 1. An ACK or NACK is sent on the bus by writing 0 or 1 to TXAK after this bit is set in receive mode</li> <li>Match of slave address to calling address including primary slave address, range slave address, alert response address, second slave address, or general call address.</li> <li>Arbitration lost</li> <li>In SMBus mode, any timeouts except SCL and SDA high timeouts</li> </ul> |
|            | 0 No interrupt pending                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|            | 1 Interrupt pending                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 0<br>RXAK  | Receive acknowledge                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|            | <ul> <li>Acknowledge signal was received after the completion of one byte of data transmission on the bus</li> <li>No acknowledge signal detected</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

# 42.3.5 I2C Data I/O register (I2Cx\_D)

Addresses: I2C0\_D is FFFF\_81C0h base + 4h offset = FFFF\_81C4h I2C1\_D is FFFF\_81D0h base + 4h offset = FFFF\_81D4h I2C2\_D is FFFF\_81E0h base + 4h offset = FFFF\_81E4h I2C3\_D is FFFF\_81F0h base + 4h offset = FFFF\_81F4h Bit Read DATA Write Reset 0 0 0 0 0 0 0 0

## I2Cx\_D field descriptions

| Field       | Description                                                                                                                                                                                                                                                               |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–0<br>DATA | Data In master transmit mode, when data is written to this register, a data transfer is initiated. The most significant bit is sent first. In master receive mode, reading this register initiates receiving of the next byte of data.                                    |
|             | NOTE: When making the transition out of master receive mode, switch the I2C mode before reading the Data register to prevent an inadvertent initiation of a master receive data transfer.  In slave mode, the same functions are available after an address match occurs. |

#### **Memory Map and Registers**

# I2Cx\_D field descriptions (continued)

| Field | Description                                                                                                                                                                                                                                                                                                                            |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | The C1[TX] bit must correctly reflect the desired direction of transfer in master and slave modes for the transmission to begin. For example, if the I2C module is configured for master transmit but a master receive is desired, reading the Data register does not initiate the receive.                                            |
|       | Reading the Data register returns the last byte received while the I2C module is configured in master receive or slave receive mode. The Data register does not reflect every byte that is transmitted on the I2C bus, and neither can software verify that a byte has been written to the Data register correctly by reading it back. |
|       | In master transmit mode, the first byte of data written to the Data register following assertion of MST (start bit) or assertion of RSTA (repeated start bit) is used for the address transfer and must consist of the calling address (in bits 7-1) concatenated with the required R/W bit (in position bit 0).                       |

# 42.3.6 I2C Control Register 2 (I2Cx\_C2)

Addresses: I2C0\_C2 is FFFF\_81C0h base + 5h offset = FFFF\_81C5h I2C1\_C2 is FFFF\_81D0h base + 5h offset = FFFF\_81D5h I2C2\_C2 is FFFF\_81E0h base + 5h offset = FFFF\_81E5h I2C3\_C2 is FFFF\_81F0h base + 5h offset = FFFF\_81F5h



## I2Cx\_C2 field descriptions

| Field         | Description                                             |
|---------------|---------------------------------------------------------|
| 7<br>GCAEN    | General call address enable                             |
| GOMEN         | Enables general call address.                           |
|               | 0 Disabled                                              |
|               | 1 Enabled                                               |
| 6<br>ADEXT    | Address extension                                       |
|               | Controls the number of bits used for the slave address. |
|               | 0 7-bit address scheme                                  |
|               | 1 10-bit address scheme                                 |
| 5<br>HDRS     | High drive select                                       |
| , institution | Controls the drive capability of the I2C pads.          |
|               | 0 Normal drive mode                                     |
|               | 1 High drive mode                                       |

Table continues on the next page...

## I2Cx\_C2 field descriptions (continued)

| Field           | Description                                                                                                                                                                                                                                                                |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4<br>SBRC       | Slave baud rate control                                                                                                                                                                                                                                                    |
|                 | Enables independent slave mode baud rate at max frequency. This forces clock stretching on SCL in very fast I2C modes.                                                                                                                                                     |
|                 | 0 The slave baud rate follows the master baud rate and clock stretching may occur                                                                                                                                                                                          |
|                 | 1 Slave baud rate is independent of the master baud rate                                                                                                                                                                                                                   |
| 3<br>RMEN       | Range address matching enable                                                                                                                                                                                                                                              |
| THYLLIN         | This bit controls slave address matching for addresses between the values of the A1 and RA registers. When this bit is set, a slave address match occurs for any address greater than the value of the A1 register and less than or equal to the value of the RA register. |
|                 | O Range mode disabled. No address match occurs for an address within the range of values of the A1 and RA registers.                                                                                                                                                       |
|                 | 1 Range mode enabled. Address matching occurs when a slave receives an address within the range of values of the A1 and RA registers.                                                                                                                                      |
| 2–0<br>AD[10:8] | Slave address                                                                                                                                                                                                                                                              |
|                 | Contains the upper three bits of the slave address in the 10-bit address scheme. This field is only valid when the ADEXT bit is set.                                                                                                                                       |

# 42.3.7 I2C Programmable Input Glitch Filter register (I2Cx\_FLT)

Addresses: I2C0\_FLT is FFFF\_81C0h base + 6h offset = FFFF\_81C6h
I2C1\_FLT is FFFF\_81D0h base + 6h offset = FFFF\_81D6h
I2C2\_FLT is FFFF\_81E0h base + 6h offset = FFFF\_81E6h
I2C3\_FLT is FFFF\_81F0h base + 6h offset = FFFF\_81F6h



# I2Cx\_FLT field descriptions

| Field           | Description                                                                                                                                                                                                                                                       |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–4<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                |
| 3–0<br>FLT      | I2C programmable filter factor  Controls the width of the glitch (in terms of bus clock cycles) the filter must absorb. In other words, the filter does not allow to pass any glitch whose size is less than or equal to this width setting.  Oh No filter/bypass |
|                 | 1-Fh Filter glitches up to width of n bus clock cycles, where n=1-15d                                                                                                                                                                                             |

# 42.3.8 I2C Range Address register (I2Cx\_RA)





#### I2Cx\_RA field descriptions

| Field         | Description                                                                                                                                                                                                                                                                                                                                    |
|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–1<br>RAD    | Range slave address  This field contains the slave address to be used by the I2C module. The field is used in the 7-bit address scheme. Any nonzero value written enables this register. This register's use is similar to that of the A1 register, but in addition this register can be considered a maximum boundary in range matching mode. |
| 0<br>Reserved | This read-only bit is reserved and always has the value zero.                                                                                                                                                                                                                                                                                  |

# 42.3.9 I2C SMBus Control and Status register (I2Cx\_SMB)

#### NOTE

A master assumes that the bus is free when detecting the clock and data signals being high for greater than high time out period. However, SHTF1 rises in bus transmission process with idle bus state.

#### NOTE

When TCKSEL is set, there is no meaning to monitor SHTF1 since the bus speed is too high to match the protocol of SMBus.

Addresses: I2C0\_SMB is FFFF\_81C0h base + 8h offset = FFFF\_81C8h

I2C1\_SMB is FFFF\_81D0h base + 8h offset = FFFF\_81D8h

I2C2\_SMB is FFFF\_81E0h base + 8h offset = FFFF\_81E8h

I2C3\_SMB is FFFF\_81F0h base + 8h offset = FFFF\_81F8h



## I2Cx\_SMB field descriptions

| Field        | Description                                                                                                                                                                                                     |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>FACK    | Fast NACK/ACK enable                                                                                                                                                                                            |
|              | For SMBus packet error checking, the CPU must be able to issue an ACK or NACK according to the result of receiving data byte.                                                                                   |
|              | 0 An ACK or NACK is sent on the following receiving data byte                                                                                                                                                   |
|              | 1 Writing 0 to TXAK after receiving a data byte generates an ACK. Writing 1 to TXAK after receiving a data byte generates a NACK.                                                                               |
| 6<br>ALERTEN | SMBus alert response address enable                                                                                                                                                                             |
| ALERTEN      | Enables SMBus alert response address.                                                                                                                                                                           |
|              | 0 Disabled                                                                                                                                                                                                      |
|              | 1 Enabled                                                                                                                                                                                                       |
| 5<br>SIICAEN | Second I2C address enable                                                                                                                                                                                       |
|              | Enables or disables SMBus device default address                                                                                                                                                                |
|              | 0 Disabled                                                                                                                                                                                                      |
|              | 1 Enabled                                                                                                                                                                                                       |
| 4<br>TCKSEL  | Timeout counter clock select                                                                                                                                                                                    |
|              | Selects the clock source of the timeout counter                                                                                                                                                                 |
|              | 0 Bus clock / 64 frequency                                                                                                                                                                                      |
|              | 1 Bus clock frequency                                                                                                                                                                                           |
| 3<br>SLTF    | SCL low timeout flag                                                                                                                                                                                            |
| 52           | This bit is set when the SLT register (consisting of the SLTH and SLTL registers) is loaded with a non-zero value (LoValue) and an SCL low timeout occurs. Software clears this bit by writing a logic 1 to it. |
|              | NOTE: The low timeout function is disabled when the SLT register's value is zero.                                                                                                                               |
|              | 0 No low timeout occurs                                                                                                                                                                                         |
|              | 1 Low timeout occurs                                                                                                                                                                                            |
| 2<br>SHTF1   | SCL high timeout flag 1                                                                                                                                                                                         |
|              | This read-only bit sets when SCL and SDA are held high more than clock $\times$ LoValue / 512, which indicates the bus is free. This bit is cleared automatically.                                              |

Table continues on the next page...

#### **Memory Map and Registers**

## I2Cx\_SMB field descriptions (continued)

| Field        | Description                                                                                                                           |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------|
|              | 0 No SCL high and SDA high timeout occurs                                                                                             |
|              | 1 SCL high and SDA high timeout occurs                                                                                                |
| 1<br>SHTF2   | SCL high timeout flag 2                                                                                                               |
|              | This bit sets when SCL is held high and SDA is held low more than clock × LoValue/512. Software clears this bit by writing a 1 to it. |
|              | 0 No SCL high and SDA low TIMEOUT occurs                                                                                              |
|              | 1 SCL high and SDA low TIMEOUT occurs                                                                                                 |
| 0<br>SHTF2IE | SHTF2 interrupt enable                                                                                                                |
|              | Enables SCL high and SDA low timeout interrupt.                                                                                       |
|              | 0 Disabled                                                                                                                            |
|              | 1 Enabled                                                                                                                             |

# 42.3.10 I2C Address Register 2 (I2Cx\_A2)

Addresses: I2C0\_A2 is FFFF\_81C0h base + 9h offset = FFFF\_81C9h I2C1\_A2 is FFFF\_81D0h base + 9h offset = FFFF\_81D9h I2C2\_A2 is FFFF\_81E0h base + 9h offset = FFFF\_81E9h I2C3\_A2 is FFFF\_81F0h base + 9h offset = FFFF\_81F9h



## I2Cx\_A2 field descriptions

| Field         | Description                                                                                                                               |
|---------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| 7–1<br>SAD    | SMBus address  Contains the slave address used by the SMBus. This field is used on the device default address or other related addresses. |
| 0<br>Reserved | This read-only bit is reserved and always has the value zero.                                                                             |

# 42.3.11 I2C SCL Low Timeout Register High (I2Cx\_SLTH)



#### I2Cx\_SLTH field descriptions

|   | Field             | Description                                                                                   |
|---|-------------------|-----------------------------------------------------------------------------------------------|
| Ī | 7-0<br>SSLT[15:8] | Most significant byte of SCL low timeout value that determines the timeout period of SCL low. |

# 42.3.12 I2C SCL Low Timeout Register Low (I2Cx\_SLTL)



### I2Cx\_SLTL field descriptions

| Field            | Description                                                                                    |
|------------------|------------------------------------------------------------------------------------------------|
| 7–0<br>SSLT[7:0] | Least significant byte of SCL low timeout value that determines the timeout period of SCL low. |

# 42.4 Functional Description

This section provides a comprehensive functional description of the I2C module.

#### 42.4.1 I2C Protocol

The I2C bus system uses a serial data line (SDA) and a serial clock line (SCL) for data transfers. All devices connected to it must have open drain or open collector outputs. A logic AND function is exercised on both lines with external pull-up resistors. The value of these resistors depends on the system.

Normally, a standard instance of communication is composed of four parts:

- 1. START signal
- 2. Slave address transmission
- 3. Data transfer
- 4. STOP signal

The STOP signal should not be confused with the CPU STOP instruction. The following figure illustrates I2C bus system communication.



Figure 42-62. I2C Bus Transmission Signals

# **42.4.1.1 START Signal**

The bus is free when no master device is engaging the bus (both SCL and SDA are high). When the bus is free, a master may initiate communication by sending a START signal. A START signal is defined as a high-to-low transition of SDA while SCL is high. This signal denotes the beginning of a new data transfer (each data transfer might contain several bytes of data) and brings all slaves out of their idle states.

### 42.4.1.2 Slave Address Transmission

Immediately after the START signal, the first byte of a data transfer is the slave address transmitted by the master. This address is a 7-bit calling address followed by an  $R/\overline{W}$  bit. The  $R/\overline{W}$  bit tells the slave the desired direction of data transfer.

- 1 = Read transfer: The slave transmits data to the master
- 0 = Write transfer: The master transmits data to the slave

Only the slave with a calling address that matches the one transmitted by the master responds by sending an acknowledge bit. The slave sends the acknowledge bit by pulling SDA low at the ninth clock.

No two slaves in the system may have the same address. If the I2C module is the master, it must not transmit an address that is equal to its own slave address. The I2C module cannot be master and slave at the same time. However, if arbitration is lost during an address cycle, the I2C module reverts to slave mode and operates correctly even if it is being addressed by another master.

## 42.4.1.3 Data Transfers

When successful slave addressing is achieved, data transfer can proceed on a byte-by-byte basis in the direction specified by the  $R/\overline{W}$  bit sent by the calling master.

All transfers that follow an address cycle are referred to as data transfers, even if they carry subaddress information for the slave device.

Each data byte is 8 bits long. Data may be changed only while SCL is low. Data must be held stable while SCL is high. There is one clock pulse on SCL for each data bit, and the MSB is transferred first. Each data byte is followed by a ninth (acknowledge) bit, which is signaled from the receiving device by pulling SDA low at the ninth clock. In summary, one complete data transfer needs nine clock pulses.

#### **Functional Description**

If the slave receiver does not acknowledge the master in the ninth bit, the slave must leave SDA high. The master interprets the failed acknowledgement as an unsuccessful data transfer.

If the master receiver does not acknowledge the slave transmitter after a data byte transmission, the slave interprets it as an end to data transfer and releases the SDA line.

In the case of a failed acknowledgement by either the slave or master, the data transfer is aborted and the master does one of two things:

- Relinquishes the bus by generating a STOP signal.
- Commences a new call by generating a repeated START signal.

# 42.4.1.4 STOP Signal

The master can terminate the communication by generating a STOP signal to free the bus. A STOP signal is defined as a low-to-high transition of SDA while SCL is asserted.

The master can generate a STOP signal even if the slave has generated an acknowledgement, at which point the slave must release the bus.

# 42.4.1.5 Repeated START Signal

The master may generate a START signal followed by a calling command without generating a STOP signal first. This action is called a repeated START. The master uses a repeated START to communicate with another slave or with the same slave in a different mode (transmit/receive mode) without releasing the bus.

## 42.4.1.6 Arbitration Procedure

The I2C bus is a true multimaster bus that allows more than one master to be connected on it.

If two or more masters try to control the bus at the same time, a clock synchronization procedure determines the bus clock. The bus clock's low period is equal to the longest clock low period, and the high period is equal to the shortest one among the masters.

The relative priority of the contending masters is determined by a data arbitration procedure. A bus master loses arbitration if it transmits logic level 1 while another master transmits logic level 0. The losing masters immediately switch to slave receive mode and

stop driving SDA output. In this case, the transition from master to slave mode does not generate a STOP condition. Meanwhile, hardware sets a status bit to indicate the loss of arbitration.

# 42.4.1.7 Clock Synchronization

Because wire AND logic is performed on SCL, a high-to-low transition on SCL affects all devices connected on the bus. The devices start counting their low period and, after a device's clock has gone low, that device holds SCL low until the clock reaches its high state. However, the change of low to high in this device clock might not change the state of SCL if another device clock is still within its low period. Therefore, the synchronized clock SCL is held low by the device with the longest low period. Devices with shorter low periods enter a high wait state during this time (see the following diagram). When all applicable devices have counted off their low period, the synchronized clock SCL is released and pulled high. Afterward there is no difference between the device clocks and the state of SCL, and all devices start counting their high periods. The first device to complete its high period pulls SCL low again.



Figure 42-63. I2C Clock Synchronization

# 42.4.1.8 Handshaking

The clock synchronization mechanism can be used as a handshake in data transfers. A slave device may hold SCL low after completing a single byte transfer (9 bits). In this case, it halts the bus clock and forces the master clock into wait states until the slave releases SCL.

# 42.4.1.9 Clock Stretching

The clock synchronization mechanism can be used by slaves to slow down the bit rate of a transfer. After the master drives SCL low, a slave can drive SCL low for the required period and then release it. If the slave's SCL low period is greater than the master's SCL low period, the resulting SCL bus signal's low period is stretched.

#### 42.4.1.10 I2C Divider and Hold Values

Table 42-67. I2C Divider and Hold Values

| ICR<br>(hex) | SCL<br>Divider | SDA<br>Hold<br>Value | SCL<br>Hold<br>(Start)<br>Value | SCL<br>Hold<br>(Stop)<br>Value | ICR<br>(hex) | SCL<br>Divider<br>(clocks) | SDA<br>Hold<br>(clocks) | SCL<br>Hold<br>(Start)<br>Value | SCL<br>Hold<br>(Stop)<br>Value |
|--------------|----------------|----------------------|---------------------------------|--------------------------------|--------------|----------------------------|-------------------------|---------------------------------|--------------------------------|
| 00           | 20             | 7                    | 6                               | 11                             | 20           | 160                        | 17                      | 78                              | 81                             |
| 01           | 22             | 7                    | 7                               | 12                             | 21           | 192                        | 17                      | 94                              | 97                             |
| 02           | 24             | 8                    | 8                               | 13                             | 22           | 224                        | 33                      | 110                             | 113                            |
| 03           | 26             | 8                    | 9                               | 14                             | 23           | 256                        | 33                      | 126                             | 129                            |
| 04           | 28             | 9                    | 10                              | 15                             | 24           | 288                        | 49                      | 142                             | 145                            |
| 05           | 30             | 9                    | 11                              | 16                             | 25           | 320                        | 49                      | 158                             | 161                            |
| 06           | 34             | 10                   | 13                              | 18                             | 26           | 384                        | 65                      | 190                             | 193                            |
| 07           | 40             | 10                   | 16                              | 21                             | 27           | 480                        | 65                      | 238                             | 241                            |
| 08           | 28             | 7                    | 10                              | 15                             | 28           | 320                        | 33                      | 158                             | 161                            |
| 09           | 32             | 7                    | 12                              | 17                             | 29           | 384                        | 33                      | 190                             | 193                            |
| 0A           | 36             | 9                    | 14                              | 19                             | 2A           | 448                        | 65                      | 222                             | 225                            |
| 0B           | 40             | 9                    | 16                              | 21                             | 2B           | 512                        | 65                      | 254                             | 257                            |
| 0C           | 44             | 11                   | 18                              | 23                             | 2C           | 576                        | 97                      | 286                             | 289                            |
| 0D           | 48             | 11                   | 20                              | 25                             | 2D           | 640                        | 97                      | 318                             | 321                            |
| 0E           | 56             | 13                   | 24                              | 29                             | 2E           | 768                        | 129                     | 382                             | 385                            |
| 0F           | 68             | 13                   | 30                              | 35                             | 2F           | 960                        | 129                     | 478                             | 481                            |
| 10           | 48             | 9                    | 18                              | 25                             | 30           | 640                        | 65                      | 318                             | 321                            |
| 11           | 56             | 9                    | 22                              | 29                             | 31           | 768                        | 65                      | 382                             | 385                            |
| 12           | 64             | 13                   | 26                              | 33                             | 32           | 896                        | 129                     | 446                             | 449                            |
| 13           | 72             | 13                   | 30                              | 37                             | 33           | 1024                       | 129                     | 510                             | 513                            |
| 14           | 80             | 17                   | 34                              | 41                             | 34           | 1152                       | 193                     | 574                             | 577                            |
| 15           | 88             | 17                   | 38                              | 45                             | 35           | 1280                       | 193                     | 638                             | 641                            |
| 16           | 104            | 21                   | 46                              | 53                             | 36           | 1536                       | 257                     | 766                             | 769                            |
| 17           | 128            | 21                   | 58                              | 65                             | 37           | 1920                       | 257                     | 958                             | 961                            |
| 18           | 80             | 9                    | 38                              | 41                             | 38           | 1280                       | 129                     | 638                             | 641                            |

Table continues on the next page...

Table 42-67. I2C Divider and Hold Values (continued)

| ICR<br>(hex) | SCL<br>Divider | SDA<br>Hold<br>Value | SCL<br>Hold<br>(Start)<br>Value | SCL<br>Hold<br>(Stop)<br>Value | ICR<br>(hex) | SCL<br>Divider<br>(clocks) | SDA<br>Hold<br>(clocks) | SCL<br>Hold<br>(Start)<br>Value | SCL<br>Hold<br>(Stop)<br>Value |
|--------------|----------------|----------------------|---------------------------------|--------------------------------|--------------|----------------------------|-------------------------|---------------------------------|--------------------------------|
| 19           | 96             | 9                    | 46                              | 49                             | 39           | 1536                       | 129                     | 766                             | 769                            |
| 1A           | 112            | 17                   | 54                              | 57                             | 3A           | 1792                       | 257                     | 894                             | 897                            |
| 1B           | 128            | 17                   | 62                              | 65                             | 3B           | 2048                       | 257                     | 1022                            | 1025                           |
| 1C           | 144            | 25                   | 70                              | 73                             | 3C           | 2304                       | 385                     | 1150                            | 1153                           |
| 1D           | 160            | 25                   | 78                              | 81                             | 3D           | 2560                       | 385                     | 1278                            | 1281                           |
| 1E           | 192            | 33                   | 94                              | 97                             | 3E           | 3072                       | 513                     | 1534                            | 1537                           |
| 1F           | 240            | 33                   | 118                             | 121                            | 3F           | 3840                       | 513                     | 1918                            | 1921                           |

### 42.4.2 10-bit Address

For 10-bit addressing, 0x11110 is used for the first 5 bits of the first address byte. Various combinations of read/write formats are possible within a transfer that includes 10-bit addressing.

## 42.4.2.1 Master-Transmitter Addresses a Slave-Receiver

The transfer direction is not changed. When a 10-bit address follows a START condition, each slave compares the first seven bits of the first byte of the slave address (11110XX) with its own address and tests whether the eighth bit ( $R/\overline{W}$  direction bit) is 0. It is possible that more than one device finds a match and generates an acknowledge (A1). Each slave that finds a match compares the eight bits of the second byte of the slave address with its own address, but only one slave finds a match and generate an acknowledge (A2). The matching slave remains addressed by the master until it receives a STOP condition (P) or a repeated START condition (Sr) followed by a different slave address.

Table 42-68. Master-Transmitter Addresses Slave-Receiver with a 10-bit Address

| S | Slave<br>addres<br>s first 7<br>bits<br>11110<br>+<br>AD10<br>+ AD9 | R/W<br>0 | A1 | Slave<br>addres<br>s<br>second<br>byte<br>AD[8:1] | A2 | Data | А |  | Data | A/A | Р |  |
|---|---------------------------------------------------------------------|----------|----|---------------------------------------------------|----|------|---|--|------|-----|---|--|
|---|---------------------------------------------------------------------|----------|----|---------------------------------------------------|----|------|---|--|------|-----|---|--|

#### **Functional Description**

After the master-transmitter has sent the first byte of the 10-bit address, the slave-receiver sees an I2C interrupt. User software must ensure that for this interrupt, the contents of the Data register are ignored and not treated as valid data.

#### 42.4.2.2 Master-Receiver Addresses a Slave-Transmitter

The transfer direction is changed after the second  $R/\overline{W}$  bit. Up to and including acknowledge bit A2, the procedure is the same as that described for a master-transmitter addressing a slave-receiver. After the repeated START condition (Sr), a matching slave remembers that it was addressed before. This slave then checks whether the first seven bits of the first byte of the slave address following Sr are the same as they were after the START condition (S), and it tests whether the eighth  $(R/\overline{W})$  bit is 1. If there is a match, the slave considers that it has been addressed as a transmitter and generates acknowledge A3. The slave-transmitter remains addressed until it receives a STOP condition (P) or a repeated START condition (Sr) followed by a different slave address.

After a repeated START condition (Sr), all other slave devices also compare the first seven bits of the first byte of the slave address with their own addresses and test the eighth  $(R/\overline{W})$  bit. However, none of them are addressed because  $R/\overline{W} = 1$  (for 10-bit devices), or the 11110XX slave address (for 7-bit devices) does not match.

Table 42-69. Master-Receiver Addresses a Slave-Transmitter with a 10-bit Address

| S | Slave<br>address<br>first 7<br>bits<br>11110<br>+ AD10 | R/W<br>0 | A1 | Slave<br>address<br>second<br>byte<br>AD[8:1] | A2 | Sr | Slave<br>address<br>first 7<br>bits<br>11110<br>+ AD10 | R/W<br>1 | А3 | Data | A | <br>Data | Α | Р |
|---|--------------------------------------------------------|----------|----|-----------------------------------------------|----|----|--------------------------------------------------------|----------|----|------|---|----------|---|---|
|   | + AD10<br>+ AD9                                        |          |    |                                               |    |    | + AD10<br>+ AD9                                        |          |    |      |   |          |   |   |

After the master-receiver has sent the first byte of the 10-bit address, the slave-transmitter sees an I2C interrupt. User software must ensure that for this interrupt, the contents of the Data register are ignored and not treated as valid data.

# 42.4.3 Address Matching

All received addresses can be requested in 7-bit or 10-bit address format. The Address Register 1, which contains the I2C primary slave address, always participates in the address matching process. If the GCAEN bit is set, general call participates the address matching process. If the ALERTEN bit is set, alert response participates the address matching process. If the SIICAEN bit is set, the Address Register 2 participates in the

address matching process. If the Range Address register is programmed to a nonzero value, the range address itself participates in the address matching process. If the RMEN bit is set, any address within the range of values of the Address Register 1 and the Range Address register participates in the address matching process. The Range Address register must be programmed to a value greater than the value of the Address Register 1.

When the I2C module responds to one of these addresses, it acts as a slave-receiver and the IAAS bit is set after the address cycle. Software must read the Data register after the first byte transfer to determine that the address is matched.

# 42.4.4 System Management Bus Specification

SMBus provides a control bus for system and power management related tasks. A system may use SMBus to pass messages to and from devices instead of tripping individual control lines. Removing the individual control lines reduces pin count. Accepting messages ensures future expandability.with system management bus, a device can provide manufacturer information, tell the system what its model/part number is, save its state for a suspend event, report different types of errors, accept control parameters, and return its status.

## 42.4.4.1 Timeouts

The  $T_{TIMEOUT,MIN}$  parameter allows a master or slave to conclude that a defective device is holding the clock low indefinitely or a master is intentionally trying to drive devices off the bus. It is highly recommended that a slave device release the bus (stop driving the bus and let SCL and SDA float high) when it detects any single clock held low longer than  $T_{TIMEOUT,MIN}$ . Devices that have detected this condition must reset their communication and be able to receive a new START condition within the timeframe of  $T_{TIMEOUT,MAX}$ .

SMBus defines a clock low timeout,  $T_{TIMEOUT}$ , of 35 ms, specifies  $T_{LOW:SEXT}$  as the cumulative clock low extend time for a slave device, and specifies  $T_{LOW:MEXT}$  as the cumulative clock low extend time for a master device.

#### 42.4.4.1.1 SCL Low Timeout

If the SCL line is held low by a slave device on the bus, no further communication is possible. Furthermore, the master cannot force the SCL line high to correct the error condition. To solve this problem, the SMBus protocol specifies that devices participating in a transfer must detect any clock cycle held low longer than a timeout value condition. Devices that have detected the timeout condition must reset the communication. When

#### **Functional Description**

the I2C module is an active master, if it detects that SMBCLK low has exceeded the value of  $T_{TIMEOUT,MIN}$ , it must generate a stop condition within or after the current data byte in the transfer process. When the I2C module is a slave, if it detects the  $T_{TIMEOUT,MIN}$  condition, it resets its communication and is then able to receive a new START condition.

## 42.4.4.1.2 SCL High Timeout

When the I2C module has determined that the SMBCLK and SMBDAT signals have been high for at least  $T_{HIGH:MAX}$ , it assumes that the bus is idle. A HIGH timeout can occur in two ways:

- 1. HIGH timeout detected after a STOP condition appears on the bus
- 2. HIGH timeout detected after a START condition, but before a STOP condition appears on the bus

Any master detecting either scenario can assume the bus is free when SHTF1 rises. A HIGH timeout occurs in scenario 2 if a master ever detects that both the BUSY bit is high and SHTF1 is high.

When the SMBDAT signal is low and the SMBCLK signal is high for a period of time, the other kind of timeout occurs. The time period must be defined in software. SHTF2 is used as the flag when the time limit is reached. This flag is also an interrupt resource, so it also triggers IICIF.

#### 42.4.4.1.3 CSMBCLK TIMEOUT MEXT and CSMBCLK TIMEOUT SEXT

The following figure illustrates the definition of the timeout intervals  $T_{LOW:SEXT}$  and  $T_{LOW:MEXT}$ . When in master mode, the I2C module must not cumulatively extend its clock cycles for a period greater than  $T_{LOW:MEXT}$  within a byte, where each byte is defined as START-to-ACK, ACK-to-ACK, or ACK-to-STOP. When CSMBCLK TIMEOUT MEXT occurs, SMBus MEXT rises and also triggers the SLTF.



Figure 42-64. Timeout measurement intervals

A master is allowed to abort the transaction in progress to any slave that violates the  $T_{LOW:SEXT}$  or  $T_{TIMEOUT,MIN}$  specifications. To abort the transaction, the master issues a STOP condition at the conclusion of the byte transfer in progress. When a slave, the I2C module must not cumulatively extend its clock cycles for a period greater than  $T_{LOW:SEXT}$  during any message from the initial START to the STOP. When CSMBCLK TIMEOUT SEXT occurs, SEXT rises and also triggers SLTF.

#### NOTE

CSMBCLK TIMEOUT SEXT and CSMBCLK TIMEOUT MEXT are optional functions that are implemented in the second step.

## 42.4.4.2 FAST ACK and NACK

To improve reliability and communication robustness, implementation of packet error checking (PEC) by SMBus devices is optional for SMBus devices but required for devices participating in and only during the address resolution protocol (ARP) process. The PEC is a CRC-8 error checking byte, calculated on all the message bytes. The PEC is appended to the message by the device that supplied the last data byte. If the PEC is present but not correct, a NACK is issued by the receiver. Otherwise an ACK is issued. In order to calculate the CRC-8 by software, this module can hold the SCL line low after receiving the eighth SCL (8th bit) if this byte is a data byte. So software can determine whether an ACK or NACK should be sent to the bus by setting or clearing the TXAK bit if the FACK (fast ACK/NACK enable) bit is enabled.

SMBus requires a device always to acknowledge its own address, as a mechanism to detect the presence of a removable device (such as a battery or docking station) on the bus. In addition to indicating a slave device busy condition, SMBus uses the NACK mechanism to indicate the reception of an invalid command or invalid data. Because such a condition may occur on the last byte of the transfer, SMBus devices are required to

#### **Functional Description**

have the ability to generate the not acknowledge after the transfer of each byte and before the completion of the transaction. This requirement is important because SMBus does not provide any other resend signaling. This difference in the use of the NACK signaling has implications on the specific implementation of the SMBus port, especially in devices that handle critical system data such as the SMBus host and the SBS components.

#### NOTE

In the last byte of master receive slave transmit mode, the master must send a NACK to the bus, so FACK must be switched off before the last byte transmits.

## **42.4.5** Resets

The I2C module is disabled after a reset. The I2C module cannot cause a core reset.

# 42.4.6 Interrupts

The I2C module generates an interrupt when any of the events in the following table occur, provided that the IICIE bit is set. The interrupt is driven by the IICIF bit (of the I2C Status Register) and masked with the IICIE bit (of the I2C Control Register 1). The IICIF bit must be cleared (by software) by writing 1 to it in the interrupt routine. The SMBus timeouts interrupt is driven by SLTF and masked with the IICIE bit. The SLTF bit must be cleared by software by writing 1 to it in the interrupt routine. You can determine the interrupt type by reading the Status Register.

#### NOTE

In master receive mode, the FACK bit must be set to zero before the last byte transfer.

| Interrupt Source                              | Status | Flag  | Local Enable    |
|-----------------------------------------------|--------|-------|-----------------|
| Complete 1-byte transfer                      | TCF    | IICIF | IICIE           |
| Match of received calling address             | IAAS   | IICIF | IICIE           |
| Arbitration lost                              | ARBL   | IICIF | IICIE           |
| SMBus SCL low timeout interrupt flag          | SLTF   | IICIF | IICIE           |
| SMBus SCL high SDA low timeout interrupt flag | SHTF2  | IICIF | IICIE & SHTF2IE |
| Wakeup from stop interrupt                    | IAAS   | IICIF | IICIE & WUEN    |

## 42.4.6.1 Byte Transfer Interrupt

The transfer complete flag (TCF) bit is set at the falling edge of the ninth clock to indicate the completion of a byte and acknowledgement transfer. When FACK is enabled, TCF is then set at the falling edge of 8th clock to indicate the completion of byte.

## 42.4.6.2 Address Detect Interrupt

When the calling address matches the programmed slave address (I2C Address Register) or when the GCAEN bit is set and a general call is received, the IAAS bit in the Status Register is set. The CPU is interrupted, provided the IICIE bit is set. The CPU must check the SRW bit and set its Tx mode accordingly.

## 42.4.6.3 Exit from Low-Power/Stop Modes

The slave receive input detect circuit and address matching feature are still active on low power modes (wait and stop). An asynchronous input matching slave address or general call address brings the CPU out of low power/stop mode if the interrupt is not masked. Therefore, TCF and IAAS both can trigger this interrupt.

## 42.4.6.4 Arbitration Lost Interrupt

The I2C is a true multimaster bus that allows more than one master to be connected on it. If two or more masters try to control the bus at the same time, the relative priority of the contending masters is determined by a data arbitration procedure. The I2C module asserts the arbitration-lost interrupt when it loses the data arbitration process and the ARBL bit in the Status Register is set.

Arbitration is lost in the following circumstances:

- 1. SDA is sampled as low when the master drives high during an address or data transmit cycle.
- 2. SDA is sampled as low when the master drives high during the acknowledge bit of a data receive cycle.
- 3. A START cycle is attempted when the bus is busy.
- 4. A repeated START cycle is requested in slave mode.
- 5. A STOP condition is detected when the master did not request it.

The ARBL bit must be cleared (by software) by writing 1 to it.

## 42.4.6.5 Timeout Interrupt in SMBus

When the IICIE bit is set, the I2C module asserts a timeout interrupt (outputs SLTF and SHTF2) upon detection of any of the mentioned timeout conditions, with one exception. The SCL high and SDA high TIMEOUT mechanism must not be used to influence the timeout interrupt output, because this timeout indicates an idle condition on the bus. SHTF1 rises when it matches the SCL high and SDA high TIMEOUT and falls automatically just to indicate the bus status. The SHTF2's timeout period is the same as that of SHTF1, which is short compared to that of SLTF, so another control bit, SHTF2IE, is added to enable or disable it.

# 42.4.7 Programmable Input Glitch Filter

An I2C glitch filter has been added outside legacy I2C modules but within the I2C package. This filter can absorb glitches on the I2C clock and data lines for the I2C module. The width of the glitch to absorb can be specified in terms of the number of (half) bus clock cycles. A single Programmable Input Glitch Filter control register is provided. Effectively, any down-up-down or up-down-up transition on the data line that occurs within the number of clock cycles programmed in this register is ignored by the I2C module. The programmer must only specify the size of the glitch (in terms of bus clock cycles) for the filter to absorb and not pass.



Figure 42-65. Programmable input glitch filter diagram

# 42.4.8 Address Matching Wakeup

When a primary, range, or general call address match occurs when the I2C module is in slave receive mode, the MCU wakes from low power mode with no peripheral bus running. After the address matching IAAS bit is set, an interrupt is sent at the end of address matching to wake the core. The IAAS bit must be cleared after the clock recovery.

#### **NOTE**

After the system recovers and is in run mode, restart the I2C module if necessary. The SCL line is not held low until the I2C module resets after address matching.

# 42.4.9 DMA Support

If the DMAEN bit is cleared and the IICIE bit is set, an interrupt condition generates an interrupt request. If the DMAEN bit is set and the IICIE bit is set, an interrupt condition generates a DMA request instead. DMA requests are generated by the transfer complete flag (TCF).

If the DMAEN bit is set, the only arbitration lost is to another I2C module (error), and SCL low timeouts (error) generate CPU interrupts. All other events initiate a DMA transfer.

#### NOTE

Before the last byte of master receive mode, TXAK must be set to send a NACK after the last byte's transfer. Therefore, the DMA must be disabled before the last byte's transfer.

#### **NOTE**

In 10-bit address mode transmission, the addresses to send occupy 2-3 bytes. During this transfer period, the DMA must be disabled because the C1 register is written to send a repeat start or to change the transfer direction.

# 42.5 Initialization/Application Information

Module Initialization (Slave)

- 1. Write: Control Register 2
  - to enable or disable general call
  - to select 10-bit or 7-bit addressing mode
- 2. Write: Address Register 1 to set the slave address
- 3. Write: Control Register 1 to enable the I2C module and interrupts
- 4. Initialize RAM variables (IICEN = 1 and IICIE = 1) for transmit data
- 5. Initialize RAM variables used to achieve the routine shown in the following figure

Module Initialization (Master)

#### **Initialization/Application Information**

- 1. Write: Frequency Divider register to set the I2C baud rate (example provided in this chapter)
- 2. Write: Control Register 1 to enable the I2C module and interrupts
- 3. Initialize RAM variables (IICEN = 1 and IICIE = 1) for transmit data
- 4. Initialize RAM variables used to achieve the routine shown in the following figure
- 5. Write: Control Register 1 to enable TX
- 6. Write: Control Register 1 to enable MST (master mode)
- 7. Write: Data register with the address of the target slave (the LSB of this byte determines whether the communication is master receive or transmit)

The routine shown in the following figure can handle both master and slave I2C operations. For slave operation, an incoming I2C message that contains the proper address begins I2C communication. For master operation, communication must be initiated by writing the Data register.



- If general call is enabled, check to determine if the received address was a general call address (0x00).
   If the received address was a general call address, the general call must be handled by user software.
- 2. When 10-bit addressing addresses a slave, the slave sees an interrupt following the first byte of the extended address. Ensure that for this interrupt, the contents of the Data register are ignored and not treated as a valid data transfer.

Figure 42-66. Typical I2C Interrupt Routine

#### Initialization/Application Information



#### Notes:

- 1. If general call or SIICAEN is enabled, check to determine if the received address is a general call address (0x00) or an SMBus device default address. In either case, they must be handled by user software.
- 2. In receive mode, one bit time delay may needed before the first and second data reading.

Figure 42-67. Typical I2C SMBus Interrupt Routine

# Chapter 43 Universal Asynchronous Receiver/Transmitter (UART)

## 43.1 Introduction

The UART allows asynchronous serial communications with peripheral devices and other CPUs.

## **43.1.1** Features

The UART includes these distinctive features:

- Full-duplex operation
- Standard mark/space non-return-to-zero (NRZ) format
- 13-bit baud rate selection with /32 fractional divide, based on module clock frequency
- Programmable 8-bit or 9-bit data format
- Separately enabled transmitter and receiver
- Programmable transmitter output polarity
- Programmable receive input polarity
- 13-bit break character option
- 11-bit break character detection option
- Parameterizable buffer support 1, 4, 8, 16, 32, 64, and 128 data words for each transmit and receive
- Independent FIFO structure for transmit and receive
- Two receiver wakeup methods:

#### Introduction

- Idle line wakeup
- Address mark wakeup
- Address match feature in receiver to reduce address mark wakeup ISR overhead
- Ability to select MSB or LSB to be first bit on wire
- Hardware flow control support for request to send (RTS) and clear to send (CTS) signals
- Support for ISO 7816 protocol for interfacing with SIM cards and smart cards
  - Support of T=0 and T=1 protocols
  - Automatic retransmission of NACK'd packets with programmable retry threshold
  - Support for 11 and 12 ETU transfers
  - Detection of initial packet and automated transfer parameter programming
  - Interrupt-driven operation with seven ISO-7816 specific interrupts
    - Wait time violated
    - Character wait time violated
    - Block wait time violated
    - Initial frame detected
    - Transmit error threshold exceeded
    - Receive error threshold exceeded
    - · Guard time violated
- Interrupt-driven operation with 12 flags (not specific to ISO-7816 support):
  - Transmitter data buffer at or below watermark
  - Transmission complete
  - Receiver data buffer at or above watermark
  - Idle receiver input
  - Receiver data buffer overrun

- Receiver data buffer underflow
- Transmit data buffer overflow
- Noise error
- Framing error
- Parity error
- Active edge on receive pin
- LIN break detect
- Receiver framing error detection
- Hardware parity generation and checking
- 1/16 bit-time noise detection
- DMA interface

# 43.1.2 Modes of operation

The UART functions the same in all the normal modes.

It has two low power modes: Wait and Stop modes.

#### 43.1.2.1 Run mode

Normal mode of operation.

#### 43.1.2.2 Wait mode

UART operation in wait mode depends on the state of the C1[UARTSWAI] bit.

- If the C1[UARTSWAI] bit is cleared, the UART operates normally when the CPU is in Wait mode.
- If the C1[UARTSWAI] bit is set, UART clock generation ceases and the UART module enters a power-conservation state when the CPU is in Wait mode.

The C1[UARTSWAI] bit does not initiate any power down or power up procedures for the smartcard (ISO-7816) interface.

#### **UART** signal descriptions

Setting C1[UARTSWAI] does not affect the state of the C2[RE], or C2[TE].

If C1[UARTSWAI] is set, any transmission or reception in progress stops at Wait mode entry. The transmission or reception resumes when either an internal or external interrupt brings the CPU out of Wait mode. Exiting Wait mode by reset aborts any transmission or reception in progress and resets the UART.

## 43.1.2.3 Stop mode

The UART is inactive during stop mode for reduced power consumption. The STOP instruction does not affect the UART register states, but the UART module clock will be disabled. The UART operation resumes from where it left off after an external interrupt brings the CPU out of stop mode. Exiting stop mode by reset aborts any transmission or reception in progress and resets the UART. Entering or leaving stop mode does not initiate any power down or power up procedures for the smartcard (ISO-7816) interface.

# 43.2 UART signal descriptions

The UART signals are shown in the following table.

Table 43-1. UART signal descriptions

| Signal | Description     | I/O |
|--------|-----------------|-----|
| CTS    | Clear to send   | I   |
| RTS    | Request to send | 0   |
| RXD    | Receive data    | I   |
| TXD    | Transmit data   | 0   |

# 43.2.1 Detailed signal descriptions

The UART detailed signal descriptions are shown in the following table.

Table 43-2. UART—Detailed signal descriptions

| Signal | I/O | Description                                         |                                                                                                                                                                                          |  |  |  |
|--------|-----|-----------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| CTS    | ı   | Clear to send. I                                    | ndicates whether the UART can start to transmit data when flow control is enabled.                                                                                                       |  |  |  |
|        |     | State meaning                                       | Asserted—Data transmission can start.                                                                                                                                                    |  |  |  |
|        |     |                                                     | Negated—Data transmission can not start.                                                                                                                                                 |  |  |  |
|        |     | Timing                                              | Assertion—When transmitting device's RTS asserts.                                                                                                                                        |  |  |  |
|        |     |                                                     | Negation—When transmitting device's RTS deasserts.                                                                                                                                       |  |  |  |
| RTS    |     |                                                     |                                                                                                                                                                                          |  |  |  |
|        |     | State<br>Meaning                                    | Asserted—When driven by the receiver, ready to receive data. When driven by the transmitter, enable the external transmitter.                                                            |  |  |  |
|        |     |                                                     | Negated—When driven by the receiver, not ready to receive data. When driven by the transmitter, disable the external transmitter.                                                        |  |  |  |
|        |     | Timing                                              | Assertion—Can occur at any time; can assert asynchronously to the other input signals.                                                                                                   |  |  |  |
|        |     |                                                     | Negation—Can occur at any time; can deassert asynchronously to the other input signals.                                                                                                  |  |  |  |
| RXD    | I   |                                                     | Receive data. Serial data input to receiver.                                                                                                                                             |  |  |  |
|        |     | State meaning                                       | Whether RXD is interpreted as a '1' or '0' depends on the bit encoding method along with other configuration settings.                                                                   |  |  |  |
|        |     | Timing                                              | Sampled at a frequency determined by the module clock divided by the baud rate.                                                                                                          |  |  |  |
| TXD    | 0   | Transmit data. Serial data output from transmitter. |                                                                                                                                                                                          |  |  |  |
|        |     | State meaning                                       | Whether TXD is interpreted as a '1' or '0' depends on the bit encoding method along with other configuration settings.                                                                   |  |  |  |
|        |     | Timing                                              | Driven at the beginning or within a bit time according to the bit encoding method along with other configuration settings. Otherwise, transmissions are independent of reception timing. |  |  |  |

# 43.3 Module Memory Map

This section provides a detailed description of all memory and registers.

Accessing reserved addresses within the memory map will result in a transfer error. None of the contents of the implemented addresses will be modified as a result of that access.

Only byte accesses are supported.

#### **Module Memory Map**

## **UARTx** memory map

| Absolute address (hex) | Register name                               | Width<br>(in bits)                            | Access | Reset value | Section/<br>page |
|------------------------|---------------------------------------------|-----------------------------------------------|--------|-------------|------------------|
| FFFF_8140              | UART Baud Rate Registers:High (UART0_BDH)   | 8                                             | R/W    | 00h         | 43.3.1/<br>1063  |
| FFFF_8141              | UART Baud Rate Registers: Low (UART0_BDL)   | aud Rate Registers: Low (UART0_BDL) 8 R/W 04h |        | 04h         | 43.3.2/<br>1064  |
| FFFF_8142              | UART Control Register 1 (UART0_C1)          | 8                                             | R/W    | 00h         | 43.3.3/<br>1064  |
| FFFF_8143              | UART Control Register 2 (UART0_C2)          | 8                                             | R/W    | 00h         | 43.3.4/<br>1066  |
| FFFF_8144              | UART Status Register 1 (UART0_S1)           | 8                                             | R      | C0h         | 43.3.5/<br>1068  |
| FFFF_8145              | UART Status Register 2 (UART0_S2)           | 8                                             | R/W    | 00h         | 43.3.6/<br>1071  |
| FFFF_8146              | UART Control Register 3 (UART0_C3)          | 8                                             | R/W    | 00h         | 43.3.7/<br>1073  |
| FFFF_8147              | UART Data Register (UART0_D)                | 8                                             | R/W    | 00h         | 43.3.8/<br>1074  |
| FFFF_8148              | UART Match Address Registers 1 (UART0_MA1)  | ss Registers 1 (UART0_MA1) 8 R/W              |        | 00h         | 43.3.9/<br>1076  |
| FFFF_8149              | UART Match Address Registers 2 (UART0_MA2)  |                                               | R/W    | 00h         | 43.3.10/<br>1076 |
| FFFF_814A              | UART Control Register 4 (UART0_C4)          |                                               | R/W    | 00h         | 43.3.11/<br>1077 |
| FFFF_814B              | UART Control Register 5 (UART0_C5)          | (UART0_C5) 8 R/W                              |        | 00h         | 43.3.12/<br>1078 |
| FFFF_814C              | UART Extended Data Register (UART0_ED)      | 8                                             | R      | 00h         | 43.3.13/<br>1079 |
| FFFF_814D              | UART Modem Register (UART0_MODEM)           | 8                                             | R/W    | 00h         | 43.3.14/<br>1079 |
| FFFF_8150              | UART FIFO Parameters (UART0_PFIFO)          | 8                                             | R/W    | 00h         | 43.3.15/<br>1081 |
| FFFF_8151              | UART FIFO Control Register (UART0_CFIFO)    | 8                                             | R/W    | 00h         | 43.3.16/<br>1082 |
| FFFF_8152              | UART FIFO Status Register (UART0_SFIFO)     | 8                                             | R/W    | C0h         | 43.3.17/<br>1083 |
| FFFF_8153              | UART FIFO Transmit Watermark (UART0_TWFIFO) | 8 R/W 00h                                     |        | 00h         | 43.3.18/<br>1084 |
| FFFF_8154              | UART FIFO Transmit Count (UART0_TCFIFO)     | 8 R 00h                                       |        | 00h         | 43.3.19/<br>1085 |
| FFFF_8155              | UART FIFO Receive Watermark (UART0_RWFIFO)  | 8                                             | R/W    | 01h         | 43.3.20/<br>1086 |

Table continues on the next page...

#### Chapter 43 Universal Asynchronous Receiver/Transmitter (UART)

## **UARTx** memory map (continued)

| Absolute address (hex) | Register name                                      | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|------------------------|----------------------------------------------------|--------------------|--------|-------------|------------------|
| FFFF_8156              | UART FIFO Receive Count (UART0_RCFIFO)             | 8                  | R      | 00h         | 43.3.21/<br>1086 |
| FFFF_8158              | UART 7816 Control Register (UART0_C7816)           | 8                  | R/W    | 00h         | 43.3.22/<br>1087 |
| FFFF_8159              | UART 7816 Interrupt Enable Register (UART0_IE7816) | 8                  | R/W    | 00h         | 43.3.23/<br>1089 |
| FFFF_815A              | UART 7816 Interrupt Status Register (UART0_IS7816) | 8                  | R/W    | 00h         | 43.3.24/<br>1090 |
| FFFF_815B              | UART 7816 Wait Parameter Register (UART0_WP7816T0) | 8                  | R/W    | 0Ah         | 43.3.25/<br>1092 |
| FFFF_815B              | UART 7816 Wait Parameter Register (UART0_WP7816T1) | 8                  | R/W    | 0Ah         | 43.3.26/<br>1092 |
| FFFF_815C              | UART 7816 Wait N Register (UART0_WN7816)           | 8                  | R/W    | 00h         | 43.3.27/<br>1093 |
| FFFF_815D              | UART 7816 Wait FD Register (UART0_WF7816)          | 8                  | R/W    | 01h         | 43.3.28/<br>1093 |
| FFFF_815E              | UART 7816 Error Threshold Register (UART0_ET7816)  | 8                  | R/W    | 00h         | 43.3.29/<br>1094 |
| FFFF_815F              | UART 7816 Transmit Length Register (UART0_TL7816)  | 8                  | R/W    | 00h         | 43.3.30/<br>1095 |
| FFFF_8160              | UART Baud Rate Registers:High (UART1_BDH)          | 8                  | R/W    | 00h         | 43.3.1/<br>1063  |
| FFFF_8161              | UART Baud Rate Registers: Low (UART1_BDL)          | 8                  | R/W    | 04h         | 43.3.2/<br>1064  |
| FFFF_8162              | UART Control Register 1 (UART1_C1)                 | 8                  | R/W    | 00h         | 43.3.3/<br>1064  |
| FFFF_8163              | UART Control Register 2 (UART1_C2)                 | 8                  | R/W    | 00h         | 43.3.4/<br>1066  |
| FFFF_8164              | UART Status Register 1 (UART1_S1)                  | 8                  | R      | C0h         | 43.3.5/<br>1068  |
| FFFF_8165              | UART Status Register 2 (UART1_S2)                  | 8                  | R/W    | 00h         | 43.3.6/<br>1071  |
| FFFF_8166              | UART Control Register 3 (UART1_C3)                 | 8                  | R/W    | 00h         | 43.3.7/<br>1073  |
| FFFF_8167              | UART Data Register (UART1_D)                       | 8                  | R/W    | 00h         | 43.3.8/<br>1074  |
| FFFF_8168              | UART Match Address Registers 1 (UART1_MA1)         | 8                  | R/W    | 00h         | 43.3.9/<br>1076  |
| FFFF_8169              | UART Match Address Registers 2 (UART1_MA2)         | 8                  | R/W    | 00h         | 43.3.10/<br>1076 |

Table continues on the next page...

#### **Module Memory Map**

## **UARTx** memory map (continued)

| Absolute address (hex) | Register name                                      | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|------------------------|----------------------------------------------------|--------------------|--------|-------------|------------------|
| FFFF_816A              | UART Control Register 4 (UART1_C4)                 | 8                  | R/W    | 00h         | 43.3.11/<br>1077 |
| FFFF_816B              | UART Control Register 5 (UART1_C5)                 |                    | R/W    | 00h         | 43.3.12/<br>1078 |
| FFFF_816C              | UART Extended Data Register (UART1_ED)             | 8                  | R      | 00h         | 43.3.13/<br>1079 |
| FFFF_816D              | UART Modem Register (UART1_MODEM)                  | 8                  | R/W    | 00h         | 43.3.14/<br>1079 |
| FFFF_8170              | UART FIFO Parameters (UART1_PFIFO)                 | 8                  | R/W    | 00h         | 43.3.15/<br>1081 |
| FFFF_8171              | UART FIFO Control Register (UART1_CFIFO)           | 8                  | R/W    | 00h         | 43.3.16/<br>1082 |
| FFFF_8172              | UART FIFO Status Register (UART1_SFIFO)            | 8                  | R/W    | C0h         | 43.3.17/<br>1083 |
| FFFF_8173              | UART FIFO Transmit Watermark (UART1_TWFIFO)        | 8                  | R/W    | 00h         | 43.3.18/<br>1084 |
| FFFF_8174              | UART FIFO Transmit Count (UART1_TCFIFO)            | 8                  | R      | 00h         | 43.3.19/<br>1085 |
| FFFF_8175              | UART FIFO Receive Watermark (UART1_RWFIFO)         |                    | R/W    | 01h         | 43.3.20/<br>1086 |
| FFFF_8176              | UART FIFO Receive Count (UART1_RCFIFO)             | 8                  | R      | 00h         | 43.3.21/<br>1086 |
| FFFF_8178              | UART 7816 Control Register (UART1_C7816)           | 8                  | R/W    | 00h         | 43.3.22/<br>1087 |
| FFFF_8179              | UART 7816 Interrupt Enable Register (UART1_IE7816) | 8                  | R/W    | 00h         | 43.3.23/<br>1089 |
| FFFF_817A              | UART 7816 Interrupt Status Register (UART1_IS7816) | 8                  | R/W    | 00h         | 43.3.24/<br>1090 |
| FFFF_817B              | UART 7816 Wait Parameter Register (UART1_WP7816T0) | 8                  | R/W    | 0Ah         | 43.3.25/<br>1092 |
| FFFF_817B              | UART 7816 Wait Parameter Register (UART1_WP7816T1) | 8                  | R/W    | 0Ah         | 43.3.26/<br>1092 |
| FFFF_817C              | UART 7816 Wait N Register (UART1_WN7816)           | 8                  | R/W    | 00h         | 43.3.27/<br>1093 |
| FFFF_817D              | D UART 7816 Wait FD Register (UART1_WF7816)        |                    | R/W    | 01h         | 43.3.28/<br>1093 |
| FFFF_817E              | UART 7816 Error Threshold Register (UART1_ET7816)  | 8                  | R/W    | 00h         | 43.3.29/<br>1094 |
| FFFF_817F              | UART 7816 Transmit Length Register (UART1_TL7816)  | 8                  | R/W    | 00h         | 43.3.30/<br>1095 |

## 43.3.1 UART Baud Rate Registers: High (UARTx\_BDH)

This register, along with the BDL register, controls the prescale divisor for UART baud rate generation. To update the 13-bit baud rate setting (SBR[12:0]), first write to BDH to buffer the high half of the new value and then write to BDL. The working value in BDH does not change until BDL is written.

BDL is reset to a non-zero value, but after reset the baud rate generator remains disabled until the first time the receiver or transmitter is enabled (C2[RE] or C2[TE] bits are set).

Addresses: UART0\_BDH is FFFF\_8140h base + 0h offset = FFFF\_8140h UART1\_BDH is FFFF\_8160h base + 0h offset = FFFF\_8160h



#### **UARTx\_BDH** field descriptions

| Field         | Description                                                                                                                                                                      |  |  |  |  |  |  |  |
|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| 7<br>I BKDIF  | LIN Break Detect Interrupt Enable                                                                                                                                                |  |  |  |  |  |  |  |
|               | LBKDIE enables the LIN break detect flag, LBKDIF, to generate interrupt requests based on the state of LBKDDMAS.                                                                 |  |  |  |  |  |  |  |
|               | LBKDIF interrupt requests disabled.                                                                                                                                              |  |  |  |  |  |  |  |
|               | 1 LBKDIF interrupt requests enabled.                                                                                                                                             |  |  |  |  |  |  |  |
| 6<br>RXEDGIE  | RxD Input Active Edge Interrupt Enable                                                                                                                                           |  |  |  |  |  |  |  |
|               | RXEDGIE enables the Receive input active edge, RXEDGIF, to generate interrupt requests.                                                                                          |  |  |  |  |  |  |  |
|               | 0 Hardware interrupts from RXEDGIF disabled (use polling).                                                                                                                       |  |  |  |  |  |  |  |
|               | 1 RXEDGIF interrupt request enabled.                                                                                                                                             |  |  |  |  |  |  |  |
| 5<br>Reserved | This read-only bit is reserved and always has the value zero.                                                                                                                    |  |  |  |  |  |  |  |
| 4–0<br>SBR    | UART Baud Rate Bits                                                                                                                                                              |  |  |  |  |  |  |  |
|               | The baud rate for the UART is determined by these 13 bits. See Baud rate generation for details.                                                                                 |  |  |  |  |  |  |  |
|               | <b>NOTE:</b> The baud rate generator is disabled until the C2[TE] bit or the C2[RE] bit is set for the first time after reset. The baud rate generator is disabled when SBR = 0. |  |  |  |  |  |  |  |
|               | NOTE: Writing to BDH has no effect without writing to BDL, since writing to BDH puts the data in a temporary location until BDL is written.                                      |  |  |  |  |  |  |  |

# 43.3.2 UART Baud Rate Registers: Low (UARTx\_BDL)

This register, along with the BDH register, controls the prescale divisor for UART baud rate generation. To update the 13-bit baud rate setting (SBR[12:0]), first write to BDH to buffer the high half of the new value and then write to BDL. The working value in BDH does not change until BDL is written. BDL is reset to a non-zero value, but after reset the baud rate generator remains disabled until the first time the receiver or transmitter is enabled (C2[RE] or C2[TE] bits are set)





#### **UARTx\_BDL** field descriptions

| Field      | Description                                                                                                                                                                      |  |  |  |  |  |  |
|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| 7–0<br>SBR | UART Baud Rate Bits                                                                                                                                                              |  |  |  |  |  |  |
|            | baud rate for the UART is determined by these 13 bits. See Baud rate generation for details                                                                                      |  |  |  |  |  |  |
|            | <b>NOTE:</b> The baud rate generator is disabled until the C2[TE] bit or the C2[RE] bit is set for the first time after reset. The baud rate generator is disabled when SBR = 0. |  |  |  |  |  |  |
|            | <b>NOTE:</b> Writing to BDH has no effect without writing to BDL, since writing to BDH puts the data in a temporary location until BDL is written.                               |  |  |  |  |  |  |

# 43.3.3 UART Control Register 1 (UARTx\_C1)

This read/write register controls various optional features of the UART system.

Addresses: UART0\_C1 is FFFF\_8140h base + 2h offset = FFFF\_8142h UART1\_C1 is FFFF\_8160h base + 2h offset = FFFF\_8162h



## **UARTx\_C1** field descriptions

| Field     | Description                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |
|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 7         | Loop Mode Select                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |
| LOOPS     | When LOOPS is set, the RxD pin is disconnected from the UART and the transmitter output is internally connected to the receiver input. The transmitter and the receiver must be enabled to use the loop function.                                                                                                                                                                                                                         |  |  |  |  |
|           | <ul> <li>Normal operation.</li> <li>Loop mode where transmitter output is internally connected to receiver input. The receiver input is determined by the RSRC bit.</li> </ul>                                                                                                                                                                                                                                                            |  |  |  |  |
| 6         | UART Stops in Wait Mode                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |
| UARTSWAI  | 0 UART clock continues to run in wait mode.                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |
|           | 1 UART clock freezes while CPU is in wait mode.                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |
| 5<br>RSRC | Receiver Source Select                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |
|           | This bit has no meaning or effect unless the LOOPS bit is set. When LOOPS is set, the RSRC bit determines the source for the receiver shift register input.                                                                                                                                                                                                                                                                               |  |  |  |  |
|           | <ul> <li>Selects internal loop back mode and receiver input is internally connected to transmitter output.</li> <li>Single-wire UART mode where the receiver input is connected to the transmit pin input signal.</li> </ul>                                                                                                                                                                                                              |  |  |  |  |
| 4         | 9-bit or 8-bit Mode Select                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |
| M         | This bit must be set when 7816E is set/enabled.                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |
|           | 0 Normal - start + 8 data bits (MSB/LSB first as determined by MSBF) + stop.                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |
|           | 1 Use - start + 9 data bits (MSB/LSB first as determined by MSBF) + stop.                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |
| 3<br>WAKE | Receiver Wakeup Method Select                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |
| WAILE     | WAKE determines which condition wakes the UART: address mark in the most significant bit position of a received data character or an idle condition on the receive pin input signal.                                                                                                                                                                                                                                                      |  |  |  |  |
|           | 0 Idle-line wakeup.                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |
|           | 1 Address-mark wakeup.                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |
| 2<br>ILT  | Idle Line Type Select                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |
| .=.       | ILT determines when the receiver starts counting logic 1s as idle character bits. The counting begins either after a valid start bit or after the stop bit. If the count begins after the start bit, then a string of logic 1s preceding the stop bit can cause false recognition of an idle character. Beginning the count after the stop bit avoids false idle character recognition, but requires properly synchronized transmissions. |  |  |  |  |
|           | <b>NOTE:</b> In the case where UART is programmed with ILT = 1, a logic of 1'b0 is automatically shifted after a received stop bit thus resetting the idle count.                                                                                                                                                                                                                                                                         |  |  |  |  |
|           | NOTE: In the case where UART is programmed for IDLE line wakeup (RWU = 1 and WAKE = 0), ILT has no effect on when the receiver starts counting logic 1s as idle character bits. In idle line wakeup an idle character is recognized at anytime the receiver sees 10, 11, or 12 1s depending on the M, PE, and C4[M10] bits.                                                                                                               |  |  |  |  |
|           | 0 Idle character bit count starts after start bit.                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |
|           | 1 Idle character bit count starts after stop bit.                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |
| 1<br>PE   | Parity Enable                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |

Table continues on the next page...

#### **Module Memory Map**

## **UARTx\_C1** field descriptions (continued)

| Field   | Description                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |
|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
|         | Enables the parity function. When parity is enabled, parity function inserts a parity bit in the bit position immediately preceding the stop bit. This bit must be set when 7816E is set/enabled.                                                                                                                                                         |  |  |  |  |  |  |  |
|         | 0 Parity function disabled.                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |
|         | 1 Parity function enabled.                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |  |
| 0<br>PT | Parity Type                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |
|         | PT determines whether the UART generates and checks for even parity or odd parity. With even parity, an even number of 1s clears the parity bit and an odd number of 1s sets the parity bit. With odd parity, an odd number of 1s clears the parity bit and an even number of 1s sets the parity bit. This bit must be cleared when 7816E is set/enabled. |  |  |  |  |  |  |  |
|         | <ul><li>0 Even parity.</li><li>1 Odd parity.</li></ul>                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |

# 43.3.4 UART Control Register 2 (UARTx\_C2)

This register can be read or written at any time.

Addresses: UART0\_C2 is FFFF\_8140h base + 3h offset = FFFF\_8143h UART1\_C2 is FFFF\_8160h base + 3h offset = FFFF\_8163h

| Bit   | 7   | 6    | 5   | 4     | 3  | 2  | 1    | 0   |
|-------|-----|------|-----|-------|----|----|------|-----|
| Read  | TIE | TOIL | DIE | 11.15 | TE | חר | DWII | CDV |
| Write | TIE | TCIE | RIE | ILIE  | TE | RE | RWU  | SBK |
| Reset | 0   | 0    | 0   | 0     | 0  | 0  | 0    | 0   |

## **UARTx\_C2** field descriptions

| Field | Description                                                                                                                                 |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------|
| 7     | Transmitter Interrupt or DMA Transfer Enable.                                                                                               |
| TIE   | TIE enables the S1[TDRE] flag, to generate interrupt requests or DMA transfer requests, based on the state of C5[TDMAS].                    |
|       | NOTE: If C2[TIE] and C5[TDMAS] are both set, then TCIE must be cleared, and D[D] must not be written outside of servicing of a DMA request. |
|       | <ul><li>TDRE interrupt and DMA transfer requests disabled.</li><li>TDRE interrupt or DMA transfer requests enabled.</li></ul>               |
| 6     | Transmission Complete Interrupt Enable                                                                                                      |
| TCIE  | TCIE enables the transmission complete flag, S1[TC], to generate interrupt requests.                                                        |
|       | 0 TC interrupt requests disabled.                                                                                                           |
|       | 1 TC interrupt requests enabled.                                                                                                            |

Table continues on the next page...

## **UARTx\_C2** field descriptions (continued)

| Field   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5       | Receiver Full Interrupt or DMA Transfer Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| RIE     | RIE enables the S1[RDRF] flag, to generate interrupt requests or DMA transfer requests, based on the state of C5[RDMAS].                                                                                                                                                                                                                                                                                                                                                                            |
|         | <ul> <li>RDRF interrupt and DMA transfer requests disabled.</li> <li>RDRF interrupt or DMA transfer requests enabled</li> </ul>                                                                                                                                                                                                                                                                                                                                                                     |
| 4       | Idle Line Interruptor Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| ILIE    | ILIE enables the idle line flag, S1[IDLE], to generate interrupt requests, based on the state of C5[ILDMAS].                                                                                                                                                                                                                                                                                                                                                                                        |
|         | 0 IDLE interrupt requests disabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|         | 1 IDLE interrupt requests enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 3       | Transmitter Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| TE      | TE enables the UART transmitter. The TE bit can be used to queue an idle preamble by clearing and then setting the TE bit. When 7816E is set/enabled and C7816[TTYPE] = 1, this bit is automatically cleared after the requested block has been transmitted. This condition is detected when TL7816[TLEN] = 0 and four additional characters have been transmitted.                                                                                                                                 |
|         | 0 Transmitter off.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|         | 1 Transmitter on.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 2<br>RE | Receiver Enable  RE enables the UART receiver.                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|         | 0 Receiver off. 1 Receiver on.                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 1       | Receiver Wakeup Control                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| RWU     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|         | This bit can be set to place the UART receiver in a standby state. RWU automatically clears when an RWU event occurs (an IDLE event when C1[WAKE] is clear or an address match when C1[WAKE] is set). This bit must be cleared when 7816E is set.                                                                                                                                                                                                                                                   |
|         | NOTE: RWU should only be set with C1[WAKE] = 0 (wakeup on idle) if the channel is currently not idle. This can be determined by the S2[RAF] flag. If set to wake up an IDLE event and the channel is already idle, it is possible that the UART will discard data since data must be received (or a LIN break detect) after an IDLE is detected before IDLE is allowed to reasserted.                                                                                                               |
|         | <ul> <li>Normal operation.</li> <li>RWU enables the wakeup function and inhibits further receiver interrupt requests. Normally, hardware</li> </ul>                                                                                                                                                                                                                                                                                                                                                 |
|         | 1 RWU enables the wakeup function and inhibits further receiver interrupt requests. Normally, hardware wakes the receiver by automatically clearing RWU.                                                                                                                                                                                                                                                                                                                                            |
| 0       | Send Break                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| SBK     | Toggling SBK sends one break character (10, 11, or 12 logic 0s, if S2[BRK13] is cleared; 13 or 14 logic 0s, if S2[BRK13] is set). See Transmitting break characters for the number of logic 0s for the different configurations. Toggling implies clearing the SBK bit before the break character has finished transmitting. As long as SBK is set, the transmitter continues to send complete break characters (10, 11, or 12 bits, or 13 or 14 bits). This bit must be cleared when 7816E is set. |

Table continues on the next page...

## **UARTx\_C2** field descriptions (continued)

| Field | Description                            |
|-------|----------------------------------------|
|       | 0 Normal transmitter operation.        |
|       | 1 Queue break character(s) to be sent. |

# 43.3.5 UART Status Register 1 (UARTx\_S1)

The S1 register provides inputs to the MCU for generation of UART interrupts or DMA requests. This register can also be polled by the MCU to check the status of these bits. To clear a flag, the status register should be read followed by a read or write (depending on interrupt flag type) to the UART Data Register. Other instructions can be executed between the two steps as long as it does not compromise the handling of I/O, but the order of operations is important for flag clearing. When a flag is configured to trigger a DMA request, assertion of the associated DMA done signal from the DMA controller, clears the flag.

#### NOTE

If the condition that results in the assertion of the flag, interrupt or DMA request is not resolved prior to clearing the flag, the flag (and interrupt/DMA request) will reassert. For example, if the DMA or interrupt service routine failed to write sufficient data to the transmit buffer to raise it above the watermark level, the flag will reassert and generate another interrupt or DMA request.

#### NOTE

Reading an empty data register to clear one of these flags causes the FIFO pointers to get out of alignment. A receive FIFO flush reinitializes the pointers.

Addresses: UART0\_S1 is FFFF\_8140h base + 4h offset = FFFF\_8144h

UART1\_S1 is FFFF\_8160h base + 4h offset = FFFF\_8164h



## **UARTx\_S1** field descriptions

| Field     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7         | Transmit Data Register Empty Flag                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| TDRE      | TDRE will set when the number of datawords in the transmit buffer (D and C3[T8]) is equal to or less than the number indicated by TWFIFO[TXWATER]. A character that is in the process of being transmitted is not included in the count. To clear TDRE, read S1 when TDRE is set and then write to the UART data register (D). For more efficient interrupt servicing all data except the final value to be written to the buffer should written to D/C3[T8]. Then S1 can be read before writing the final data value, resulting in the clearing of the TRDE flag. This is more efficient since the TDRE will reassert until the watermark has been exceeded so attempting to clear the TDRE every write will be ineffective until sufficient data has been written.                                                                       |
|           | <ul> <li>The amount of data in the transmit buffer is greater than the value indicated by TWFIFO[TXWATER].</li> <li>The amount of data in the transmit buffer is less than or equal to the value indicated by TWFIFO[TXWATER] at some point in time since the flag has been cleared.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 6         | Transmit Complete Flag                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| TC        | TC is cleared when there is a transmission in progress or when a preamble or break character is loaded. TC is set when the transmit buffer is empty and no data, preamble, or break character is being transmitted. When TC is set, the transmit data output signal becomes idle (logic 1). When 7816E is set/enabled this bit is set after any NACK signal has been received but prior to any corresponding guard times expiring. TC is cleared by reading S1 with TC set and then doing one of the following:  • Writing to the UART data register (D) to transmit new data  • Queuing a preamble by clearing and then setting the C2[TE] bit.  • Queuing a break character by writing 1 to SBK in C2                                                                                                                                    |
|           | <ul><li>Transmitter active (sending data, a preamble, or a break).</li><li>Transmitter idle (transmission activity complete).</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 5<br>RDRF | Receive Data Register Full Flag                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| NUNF      | RDRF is set when the number of datawords in the receive buffer is equal to or more than the number indicated by TWFIFO[TXWATER]. A dataword that is in the process of being received is not included in the count. RDRF is prevented from setting while S2[LBKDE] is set. Additionally, when S2[LBKDE] is set, datawords that are received will be stored in the receive buffer but will over-write each other. To clear RDRF, read S1 when RDRF is set and then read the UART data register (D). For more efficient interrupt and DMA operation all data except the final value is to be read from the buffer using D/C3[T8]/ED. The S1 should then be read and the final data value read, resulting in the clearing of the RDRF flag. Even if the RDRF flag is set, data will continue to be received until an overrun condition occurs. |
|           | <ul> <li>The number of datawords in the receive buffer is less than the number indicated by RXWATER.</li> <li>The number of datawords in the receive buffer is equal to or greater than the number indicated by RXWATER at a case which flow was lest allowed.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 4         | RXWATER at some point in time since this flag was last cleared.  Idle Line Flag                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| IDLE      | IDLE is set when 10 consecutive logic 1s (if C1[M] = 0), 11 consecutive logic 1s (if C1[M] = 1 and C4[M10] = 0), or 12 consecutive logic 1s (if C1[M] = 1, C4[M10] = 1, and C1[PE] = 1) appear on the receiver input. After the IDLE flag is cleared, a frame must be received (although not necessarily stored in the data buffer, for example if C2[RWU] is set) or a LIN break character must set the S2[LBKDIF] flag before an idle condition can set the IDLE flag. To clear IDLE, read UART status S1 with IDLE set and then read D. Idle detection is not supported when 7816E is set/enabled and hence this flag is ignored.                                                                                                                                                                                                       |
|           | NOTE: When the receiver wakeup bit (RWU) is set and WAKE is cleared, an idle line condition sets the IDLE flag if RWUID is set, else the IDLE flag does not get set.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

Table continues on the next page...

#### **Module Memory Map**

## **UARTx\_S1** field descriptions (continued)

| Field   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         | 0 Receiver input is either active now or has never become active since the IDLE flag was last cleared.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|         | 1 Receiver input has become idle or the flag has not been cleared since it last asserted.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 3<br>OR | Receiver Overrun Flag                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|         | OR is set when software fails to prevent the receive data register from overflowing with data. The OR bit is set immediately after the stop bit has been completely received for the dataword that overflows the buffer and all the other error flags (FE,NF and PF) are prevented from setting. The data in the shift register is lost, but the data already in the UART data registers is not affected. If the OR flag is set, no data will be stored in the data buffer even if sufficient room exists. Additionally, while the OR flag is set the RDRF flag, and IDLE flags will be blocked from asserting, i.e. transition from an inactive to an active state. To clear OR, read S1 when OR is set and then read UART data register (D). If LBKDE is enabled and a LIN Break is detected, the OR bit will assert if the S2[LBKDIF] flag is not cleared before the next data character is received. See Overrun (OR) flag implications for more details regarding the operation of the OR bit. In 7816 mode, it is possible to configure a NACK to be returned by programing the C7816[ONACK] bit. |
|         | No overrun has occurred since the last time the flag was cleared.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|         | 1 Overrun has occurred or the overrun flag has not been cleared since the last overrun occured.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 2<br>NF | NF is set when the UART detects noise on the receiver input. NF bit does not get set in the case of an overrun or while the LIN break detect feature is enabled (S2[LBKDE] = 1). When NF is set, it only indicates that a dataword has been received with noise since the last time it was cleared. There is no guarantee that the first dataword read from the receive buffer has noise or that there is only one dataword in the buffer that was received with noise unless the receive buffer has a depth of one. To clear NF, read S1 and then read the UART data register (D).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|         | O No noise detected since the last time this flag was cleared. If the receive buffer has a depth greater than 1 then there may be data in the receiver buffer that was received with noise.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|         | 1 At least one dataword was received with noise detected since the last time the flag was cleared.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 1       | Framing Error Flag                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| FE      | FE is set when a logic 0 is accepted as the stop bit. FE bit does not set in the case of an overrun or while the LIN break detect feature is enabled (S2[LBKDE] = 1). FE inhibits further data reception until it is cleared. To clear FE, read S1 with FE set and then read the UART data register (D). The last data in the receive buffer represents the data that was received with the frame error enabled. However, framing errors are not supported when 7816E is set/enabled. However, if this flag is set, data will still not be received in 7816 mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|         | 0 No framing error detected.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|         | 1 Framing error.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 0<br>PF | Parity Error Flag                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| rr      | PF is set when PE is set, S2[LBKDE] is disabled, and the parity of the received data does not match its parity bit. The PF is not set in the case of an overrun condition. When the PF bit is set it only indicates that a dataword was received with parity error since the last time it was cleared. There is no guarantee that the first dataword read from the receive buffer has a parity error or that there is only one dataword in the buffer that was received with a parity error unless the receive buffer was a depth of one. To clear PF, read S1 and then read the UART data register (D). Within the receive buffer structure the received dataword is tagged if it was received with a parity error. That information is available by reading the ED register prior to reading the D register.                                                                                                                                                                                                                                                                                          |

Table continues on the next page...

#### **UARTx\_S1** field descriptions (continued)

| Field |   | Description                                                                                                                                                                                                       |
|-------|---|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | 0 | No parity error has been detected since the last time this flag was cleared. If the receive buffer has a depth greater than 1 then there may be data in the receive buffer what was received with a parity error. |
|       | 1 | At least one dataword was received with a parity error since the last time this flag was cleared.                                                                                                                 |

# 43.3.6 UART Status Register 2 (UARTx\_S2)

The S2 register provides inputs to the MCU for generation of UART interrupts or DMA requests. Also, this register can be polled by the MCU to check the status of these bits. This register can be read or written at any time, with the exception of the MSBF and RXINV bits which should only be changed by the user between transmit and receive packets.

Addresses: UART0\_S2 is FFFF\_8140h base + 5h offset = FFFF\_8145h UART1\_S2 is FFFF\_8160h base + 5h offset = FFFF\_8165h



## **UARTx\_S2** field descriptions

| Field        | Description                                                                                                                                                                                                                                                                                              |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>LBKDIF  | LIN Break Detect Interrupt Flag                                                                                                                                                                                                                                                                          |
|              | LBKDIF is set when LBKDE is set and a LIN break character is detected, when 11 consecutive logic 0s (if C1[M] = 0) or 12 consecutive logic 0s (if C1[M] = 1) appear on the receiver input. LBKDIF is set right after receiving the last LIN break character bit. LBKDIF is cleared by writing a 1 to it. |
|              | 0 No LIN break character has been detected.                                                                                                                                                                                                                                                              |
|              | 1 LIN break character has been detected.                                                                                                                                                                                                                                                                 |
| 6<br>RXEDGIF | RxD Pin Active Edge Interrupt Flag                                                                                                                                                                                                                                                                       |
|              | RXEDGIF is set when an active edge (falling if RXINV = 0, rising if RXINV=1) on the RxD pin occurs. RXEDGIF is cleared by writing a 1 to it. See RXEDGIF description for additional details.                                                                                                             |
|              | NOTE: The active edge is only detected when in two wire mode and on receive data coming from the RxD pin.                                                                                                                                                                                                |
|              | 0 No active edge on the receive pin has occurred.                                                                                                                                                                                                                                                        |
|              | 1 An active edge on the receive pin has occurred.                                                                                                                                                                                                                                                        |
| 5<br>MSBF    | Most Significant Bit First                                                                                                                                                                                                                                                                               |
|              | Setting this bit reverses the order of the bits that are transmitted and received on the wire. This bit does not affect the polarity of the bits, the location of the parity bit or the location of the start or stop bits. This bit                                                                     |

Table continues on the next page...

## **UARTx\_S2** field descriptions (continued)

| Field      | Description                                                                                                                                                                                                                                                                                                                                         |
|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | is automatically set or cleared when C7816[INIT] and C7816[ISO7816E] are enabled and an initial character is detected.                                                                                                                                                                                                                              |
|            | 0 LSB (bit0) is the first bit that is transmitted following the start bit. Further, the first bit received after the start bit is identified as bit0.                                                                                                                                                                                               |
|            | 1 MSB (bit8, bit7 or bit6) is the first bit that is transmitted following the start bit depending on the setting of C1[M] and C1[PE]. Further, the first bit received after the start bit is identified as bit8, bit7 or bit6 depending on the setting of C1[M] and C1[PE].                                                                         |
| 4<br>RXINV | Receive Data Inversion                                                                                                                                                                                                                                                                                                                              |
| TIXIIV     | Setting this bit, reverses the polarity of the received data input. In NRZ format, a one is represented by a mark and a zero is represented by a space for normal polarity, and the opposite for inverted polarity. This bit is automatically set or cleared when C7816[INIT] and C7816[ISO7816E] are enabled and an initial character is detected. |
|            | NOTE: Setting RXINV inverts the RxD input for: data bits, start and stop bits, break, and idle. When C7816[ISO7816E] is set/enabled then only the data bits and the parity bit are inverted.                                                                                                                                                        |
|            | 0 Receive data is not inverted.                                                                                                                                                                                                                                                                                                                     |
|            | 1 Receive data is inverted.                                                                                                                                                                                                                                                                                                                         |
| 3<br>RWUID | Receive Wakeup Idle Detect                                                                                                                                                                                                                                                                                                                          |
|            | When RWU is set and WAKE is cleared, this bit controls whether the idle character that wakes the receiver sets the S1[IDLE] bit. This bit must be cleared when C7816[ISO7816E] is set/enabled.                                                                                                                                                      |
|            | 0 The S1[IDLE] bit is not set upon detection of an idle character.                                                                                                                                                                                                                                                                                  |
|            | 1 The S1[IDLE] bit is set upon detection of an idle character.                                                                                                                                                                                                                                                                                      |
| 2<br>BRK13 | Break Transmit Character Length                                                                                                                                                                                                                                                                                                                     |
| Brittie    | This bit determines whether the transmit break character is 10, 11, or 12 bits long, or 13 or 14 bits long. Refer to Transmitting break characters for the length of the break character for the different configurations. The detection of a framing error is not affected by this bit.                                                            |
|            | 0 Break character is 10, 11, or 12 bits long.                                                                                                                                                                                                                                                                                                       |
|            | 1 Break character is 13 or 14 bits long.                                                                                                                                                                                                                                                                                                            |
| 1          | LIN Break Detection Enable                                                                                                                                                                                                                                                                                                                          |
| LBKDE      | LBKDE selects a longer break character detection length. While LBKDE is set, the S1[RDRF], S1[NF], S1[FE], and S1[PF] flags are prevented from setting. When LBKDE is set, see Overrun operation. The LBKDE bit must be cleared when C7816[ISO7816E] is set.                                                                                        |
|            | 0 Break character is detected at length of 10 bit times (C1[M] = 0), 11 (C1[M] = 1 and C4[M10] = 0), or 12 (C1[M] = 1, C4[M10] = 1, and S1[PE] = 1).                                                                                                                                                                                                |
|            | 1 Break character is detected at length of 11 bits times (if C1[M] = 0 or 12 bits time (if C1[M] = 1).                                                                                                                                                                                                                                              |
| 0<br>RAF   | Receiver Active Flag                                                                                                                                                                                                                                                                                                                                |
|            | RAF is set when the UART receiver detects a logic 0 during the RT1 time period of the start bit search. RAF is cleared when the receiver detects an idle character when C7816[ISO7816E] is cleared/disabled. When C7816[ISO7816E] is enabled the RAF is cleared if the C7816[TTYPE] = 0 expires or the C7816[TTYPE] = 1 expires.                    |
|            | <b>NOTE:</b> In the case when C7816[ISO7816E] is set and C7816[TTYPE] = 0, it is possible to configure the guard time to be 12. However, in the event that a NACK is required to be transmitted the data                                                                                                                                            |

Table continues on the next page...

## **UARTx\_S2** field descriptions (continued)

| Field | Description                                                                                                                                                           |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | transfer actually takes 13 ETU with the 13th ETU slot being a inactive buffer. Hence in this situation the RAF may deassert one ETU prior to actually being inactive. |
|       | <ul><li>0 UART receiver idle/inactive waiting for a start bit.</li><li>1 UART receiver active (RxD input not idle).</li></ul>                                         |

# 43.3.7 UART Control Register 3 (UARTx\_C3)

Writing to R8 bit does not have any effect. The TXDIR and TXINV bits can only be changed between transmit and receive packets.

Addresses: UART0\_C3 is FFFF\_8140h base + 6h offset = FFFF\_8146h UART1\_C3 is FFFF\_8160h base + 6h offset = FFFF\_8166h



## **UARTx\_C3** field descriptions

| Field      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>R8    | Received Bit 8  R8 is the ninth data bit received when the UART is configured for 9-bit data format (C1[M] = 1) or (C4[M10] = 1).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 6<br>T8    | Transmit Bit 8  T8 is the ninth data bit transmitted when the UART is configured for 9-bit data format (C1[M] = 1) or (C4[M10] = 1).  NOTE: If the value of T8 is the same as in the previous transmission, T8 does not have to be rewritten.  The same value is transmitted until T8 is rewritten.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 5<br>TXDIR | Transmitter Pin Data Direction in Single-Wire mode  This bit determines whether the TXD pin is used as an input or output in the single-wire mode of operation. This bit is relevant only to the single-wire mode. When C7816[ISO7816E] is set/enabled and C7816[TTYPE] = 1, this bit is automatically cleared after the requested block has been transmitted. This condition is detected when TL7816[TLEN] = 0 and 4 additional characters have been transmitted. Additionally, if C7816[ISO7816E] is set/enabled and C7816[TTYPE] = 0 and a NACK is being transmitted, the hardware will automatically override this bit as needed. In this situation TXDIR will not reflect the temporary state associated with the NACK.  0 TXD pin is an input in single-wire mode.  1 TXD pin is an output in single-wire mode. |
| 4<br>TXINV | Transmit Data Inversion.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

Table continues on the next page...

## **UARTx\_C3** field descriptions (continued)

| Field     | Description                                                                                                                                                                                                                                                                                                                                            |
|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|           | Setting this bit reverses the polarity of the transmitted data output. In NRZ format, a one is represented by a mark and a zero is represented by a space for normal polarity, and the opposite for inverted polarity. This bit is automatically set or cleared when C7816[INIT] and C7816[ISO7816E] are enabled and an initial character is detected. |
|           | NOTE: Setting TXINV inverts all transmitted values, including idle, break, start, and stop bits. In loop mode, if TXINV is set, the receiver gets the transmit inversion bit when RXINV is disabled. When C7816[ISO7816E] is set/enabled then only the transmitted data bits and parity bit are inverted.                                              |
|           | 0 Transmit data is not inverted.                                                                                                                                                                                                                                                                                                                       |
|           | 1 Transmit data is inverted.                                                                                                                                                                                                                                                                                                                           |
| 3         | Overrun Error Interrupt Enable                                                                                                                                                                                                                                                                                                                         |
| ORIE      | This bit enables the overrun error flag (S1[OR]) to generate interrupt requests.                                                                                                                                                                                                                                                                       |
|           | 0 OR interrupts are disabled.                                                                                                                                                                                                                                                                                                                          |
|           | 1 OR interrupt requests are enabled.                                                                                                                                                                                                                                                                                                                   |
| 2<br>NEIE | Noise Error Interrupt Enable                                                                                                                                                                                                                                                                                                                           |
|           | This bit enables the noise flag (S1[NF]) to generate interrupt requests.                                                                                                                                                                                                                                                                               |
|           | 0 NF interrupt requests are disabled.                                                                                                                                                                                                                                                                                                                  |
|           | 1 NF interrupt requests are enabled.                                                                                                                                                                                                                                                                                                                   |
| 1<br>FEIE | Framing Error Interrupt Enable                                                                                                                                                                                                                                                                                                                         |
| 1 2.2     | This bit enables the framing error flag (S1[FE]) to generate interrupt requests.                                                                                                                                                                                                                                                                       |
|           | 0 FE interrupt requests are disabled.                                                                                                                                                                                                                                                                                                                  |
|           | 1 FE interrupt requests are enabled.                                                                                                                                                                                                                                                                                                                   |
| 0<br>PEIE | Parity Error Interrupt Enable                                                                                                                                                                                                                                                                                                                          |
|           | This bit enables the parity error flag (S1[PF]) to generate interrupt requests.                                                                                                                                                                                                                                                                        |
|           | 0 PF interrupt requests are disabled.                                                                                                                                                                                                                                                                                                                  |
|           | 1 PF interrupt requests are enabled.                                                                                                                                                                                                                                                                                                                   |

# 43.3.8 UART Data Register (UARTx\_D)

This register is actually two separate registers. Reads return the contents of the read-only receive data register and writes go to the write-only transmit data register.

#### **NOTE**

In 8-bit or 9-bit data format, only UART data register (D) needs to be accessed in order to clear the S1[RDRF] bit (assuming receiver buffer level is less than RWFIFO[RXWATER]). The C3 register only needs to be read (prior to the D register) if the ninth bit of data needs to be captured. Likewise the ED register

only needs to be read (prior to the D register) if the additional flag data for the dataword needs to be captured.

#### NOTE

In the normal 8-bit mode (M bit cleared) if the parity is enabled, you get seven data bits and one parity bit. That one parity bit will be loaded into the D register. So if you care about only the data bits, you have to mask off the parity bit from the value you read out of this register.

#### NOTE

When transmitting in 9-bit data format and using 8-bit write instructions, write first to transmit bit 8 in UART control register 3 (C3[T8]), then D. A write to C3[T8] stores the data in a temporary register. If D register is written first then the new data on data bus is stored in D register, while the temporary value (written by last write to C3[T8]) gets stored in C3[T8] register.





#### **UARTx** D field descriptions

| Field     | Description                                                                                                              |
|-----------|--------------------------------------------------------------------------------------------------------------------------|
| 7–0<br>RT | Reads return the contents of the read-only receive data register and writes go to the write-only transmit data register. |

## 43.3.9 UART Match Address Registers 1 (UARTx\_MA1)

The MA1 and MA2 registers are compared to input data addresses when the most significant bit is set and the associated C4[MAEN] bit is set. If a match occurs, the following data is transferred to the data register. If a match fails, the following data is discarded. These registers can be read and written at anytime.





## **UARTx\_MA1** field descriptions

| Field     | Description   |
|-----------|---------------|
| 7–0<br>MA | Match Address |

# 43.3.10 UART Match Address Registers 2 (UARTx\_MA2)

These registers can be read and written at anytime. The MA1 and MA2 registers are compared to input data addresses when the most significant bit is set and the associated C4[MAEN] bit is set. If a match occurs, the following data is transferred to the data register. If a match fails, the following data is discarded.

Addresses: UART0\_MA2 is FFFF\_8140h base + 9h offset = FFFF\_8149h

UART1\_MA2 is FFFF\_8160h base + 9h offset = FFFF\_8169h



#### **UARTx\_MA2** field descriptions

| Field     | Description   |
|-----------|---------------|
| 7–0<br>MA | Match Address |

# 43.3.11 UART Control Register 4 (UARTx\_C4)

Addresses: UART0\_C4 is FFFF\_8140h base + Ah offset = FFFF\_814Ah

UART1\_C4 is FFFF\_8160h base + Ah offset = FFFF\_816Ah



## **UARTx\_C4** field descriptions

| Field       | Description                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>MAEN1  | Match Address Mode Enable 1                                                                                                                                                                                                                                                                                                                                                                                      |
|             | Refer to Match address operation for more information.                                                                                                                                                                                                                                                                                                                                                           |
|             | 0 All data received is transferred to the data buffer if MAEN2 is cleared.                                                                                                                                                                                                                                                                                                                                       |
|             | All data received with the most significant bit cleared, is discarded. All data received with the most significant bit set, is compared with contents of MA1 register. If no match occurs, the data is discarded. If match occurs, data is transferred to the data buffer. This bit must be cleared when C7816[ISO7816E] is set/enabled.                                                                         |
| 6<br>MAEN2  | Match Address Mode Enable 2                                                                                                                                                                                                                                                                                                                                                                                      |
|             | Refer to Match address operation for more information.                                                                                                                                                                                                                                                                                                                                                           |
|             | 0 All data received is transferred to the data buffer if MAEN1 is cleared.                                                                                                                                                                                                                                                                                                                                       |
|             | All data received with the most significant bit cleared, is discarded. All data received with the most significant bit set, is compared with contents of MA2 register. If no match occurs, the data is discarded. If match occurs, data is transferred to the data buffer. This bit must be cleared when C7816[ISO7816E] is set/enabled.                                                                         |
| 5<br>M10    | 10-bit Mode select                                                                                                                                                                                                                                                                                                                                                                                               |
| WITO        | The M10 bit causes a tenth, non-memory mapped bit to be part of the serial transmission. This tenth bit is generated and interpreted as a parity bit. The M10 bit does not affect the LIN send or detect break behavior. If M10 is set then both C1[M] and C1[PE] bits must also be set. This bit must be cleared when C7816[ISO7816E] is set/enabled. Refer to Data format (non ISO-7816) for more information. |
|             | 0 The parity bit is the ninth bit in the serial transmission.                                                                                                                                                                                                                                                                                                                                                    |
|             | 1 The parity bit is the tenth bit in the serial transmission.                                                                                                                                                                                                                                                                                                                                                    |
| 4–0<br>BRFA | Baud Rate Fine Adjust                                                                                                                                                                                                                                                                                                                                                                                            |
| טווו א      | This bit field is used to add more timing resolution to the average baud frequency, in increments of 1/32. Refer to Baud rate generation for more information.                                                                                                                                                                                                                                                   |

# 43.3.12 UART Control Register 5 (UARTx\_C5)

Addresses: UART0\_C5 is FFFF\_8140h base + Bh offset = FFFF\_814Bh

UART1\_C5 is FFFF\_8160h base + Bh offset = FFFF\_816Bh



## **UARTx\_C5** field descriptions

| Field           | Description                                                                                                                                                    |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>TDMAS      | Transmitter DMA Select                                                                                                                                         |
| TDWAG           | TDMAS configures the transmit data register empty flag, S1[TDRE], to generate interrupt or DMA requests if C2[TIE] is set.                                     |
|                 | NOTE: If C2[TIE] is cleared, TDRE DMA and TDRE interrupt request signals are not asserted when the TDRE flag is set, regardless of the state of TDMAS.         |
|                 | NOTE: If C2[TIE] and TDMAS are both set, then C2[TCIE] must be cleared, and D register must not be written outside of servicing of a DMA request.              |
|                 | 0 If C2[TIE] is set and the S1[TDRE] flag is set, the TDRE interrupt request signal is asserted to request interrupt service.                                  |
|                 | If C2[TIE] is set and the S1[TDRE] flag is set, the TDRE DMA request signal is asserted to request a DMA transfer.                                             |
| 6<br>Reserved   | This read-only bit is reserved and always has the value zero.                                                                                                  |
| 5<br>RDMAS      | Receiver Full DMA Select                                                                                                                                       |
| NDIVIAS         | RDMAS configures the receiver data register full flag, S1[RDRF], to generate interrupt or DMA requests if C2[RIE] is set.                                      |
|                 | NOTE: If C2[RIE] is cleared, the RDRF DMA and RDFR interrupt request signals are not asserted when the S1[RDRF] flag is set, regardless of the state of RDMAS. |
|                 | 0 If C2[RIE] is set and the S1[RDRF] flag is set, the RDFR interrupt request signal is asserted to request interrupt service.                                  |
|                 | 1 If C2[RIE] is set and the S1[RDRF] flag is set, the RDRF DMA request signal is asserted to request a DMA transfer.                                           |
| 4–0<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                             |

## 43.3.13 UART Extended Data Register (UARTx\_ED)

This register contains additional information flags that are stored with a received dataword. This register may be read at any time but only contains valid data if there is a dataword in the receive FIFO.

#### **NOTE**

The data contained in this register represents additional information regarding the conditions on which a dataword was received. The importance of this data varies with application, and in some cases maybe completely optional. These fields automatically update to reflect the conditions of the next dataword whenever D is read.

#### NOTE

If the S1[NF] and S1[PF] flags have not been set since the last time the receive buffer was empty, the NOISY and PARITYE bits will be zero.





#### **UARTx\_ED** field descriptions

| Field           | Description                                                                               |
|-----------------|-------------------------------------------------------------------------------------------|
| 7<br>NOISY      | The current received dataword contained in D and C3[R8] was received with noise.          |
|                 | 0 The dataword was received without noise.                                                |
|                 | 1 The data was received with noise.                                                       |
| 6<br>PARITYE    | The current received dataword contained in D and C3[R8] was received with a parity error. |
|                 | 0 The dataword was received without a parity error.                                       |
|                 | 1 The dataword was received with a parity error.                                          |
| 5–0<br>Reserved | This read-only bitfield is reserved and always has the value zero.                        |

# 43.3.14 UART Modem Register (UARTx\_MODEM)

The MODEM register controls options for setting the modem configuration.

## **NOTE**

RXRTSE, TXRTSPOL, TXRTSE and TXCTSE must all be cleared when C7816[ISO7816EN] is enabled. This will cause the RTS to deassert during ISO-7816 wait times. The ISO-7816 protocol does not make use of the RTS and CTS signals.

Addresses: UART0\_MODEM is FFFF\_8140h base + Dh offset = FFFF\_814Dh UART1\_MODEM is FFFF\_8160h base + Dh offset = FFFF\_816Dh



#### **UARTx\_MODEM** field descriptions

| Field           | Description                                                                                                                                                                                                                                                                                       |
|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–4<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                                                |
| 3<br>RXRTSE     | Receiver request-to-send enable                                                                                                                                                                                                                                                                   |
|                 | Allows the RTS output to control the CTS input of the transmitting device to prevent receiver overrun.                                                                                                                                                                                            |
|                 | NOTE: Do not set both RXRTSE and TXRTSE.                                                                                                                                                                                                                                                          |
|                 | 0 The receiver has no effect on RTS.                                                                                                                                                                                                                                                              |
|                 | 1 RTS is deasserted if the number of characters in the receiver data register (FIFO) is equal to or<br>greater than RWFIFO[RXWATER]. RTS is asserted when the number of characters in the receiver<br>data register (FIFO) is less than RWFIFO[RXWATER].                                          |
| 2               | Transmitter request-to-send polarity                                                                                                                                                                                                                                                              |
| TXRTSPOL        | Controls the polarity of the transmitter RTS. TXRTSPOL does not affect the polarity of the receiver RTS. RTS will remain negated in the active low state unless TXRTSE is set.                                                                                                                    |
|                 | Transmitter RTS is active low.                                                                                                                                                                                                                                                                    |
|                 | 1 Transmitter RTS is active high.                                                                                                                                                                                                                                                                 |
| 1               | Transmitter request-to-send enable                                                                                                                                                                                                                                                                |
| TXRTSE          | Controls RTS before and after a transmission.                                                                                                                                                                                                                                                     |
|                 | 0 The transmitter has no effect on RTS.                                                                                                                                                                                                                                                           |
|                 | 1 When a character is placed into an empty transmitter data buffer(FIFO), RTS asserts one bit time before the start bit is transmitted. RTS deasserts one bit time after all characters in the transmitter data buffer(FIFO) and shift register are completely sent, including the last stop bit. |
| 0<br>TXCTSE     | Transmitter clear-to-send enable                                                                                                                                                                                                                                                                  |
| IACISE          | TXCTSE controls the operation of the transmitter. TXCTSE can be set independently from the state of TXRTSE and RXRTSE.                                                                                                                                                                            |

Table continues on the next page...

#### **UARTx\_MODEM** field descriptions (continued)

| Field | Description                                                                                                                                                                                                                                                                                                                                                    |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | 0 CTS has no effect on the transmitter.                                                                                                                                                                                                                                                                                                                        |
|       | 1 Enables clear-to-send operation. The transmitter checks the state of CTS each time it is ready to send a character. If CTS is asserted, the character is sent. If CTS is deasserted, the signal TXD remains in the mark state and transmission is delayed until CTS is asserted. Changes in CTS as a character is being sent do not affect its transmission. |

## 43.3.15 UART FIFO Parameters (UARTx\_PFIFO)

This register provides the ability for the programmer to turn on and off FIFO functionality. It also provides the program with the size of the FIFO that has been implemented. This register may be read at any time. This register should only be written when the C2[RE] and C2[TE] bits are cleared / not set and when the data buffer/FIFO is empty.

Addresses: UART0\_PFIFO is FFFF\_8140h base + 10h offset = FFFF\_8150h UART1\_PFIFO is FFFF\_8160h base + 10h offset = FFFF\_8170h



#### **UARTx\_PFIFO** field descriptions

| Field      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>TXFE  | Transmit FIFO Enable                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|            | When this bit is set the built in FIFO structure for the transmit buffer is enabled. The size of the FIFO structure is indicated by the TXFIFOSIZE field. If this bit is not set then the transmit buffer operates as a FIFO of depth one dataword regardless of the value in TXFIFOSIZE. Both C2[TE] and C2[RE] must be cleared prior to changing this bit. Additionally TXFLUSH and RXFLUSH commands should be issued immediately after changing this bit. |
|            | <ul> <li>Transmit FIFO is not enabled. Buffer is depth 1. (Legacy support).</li> <li>Transmit FIFO is enabled. Buffer is depth indicted by TXFIFOSIZE.</li> </ul>                                                                                                                                                                                                                                                                                            |
| 6–4        | Transmit FIFO. Buffer Depth                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| TXFIFOSIZE | The maximum number of transmit datawords that can be stored in the transmit buffer. This field is read only.                                                                                                                                                                                                                                                                                                                                                 |
|            | 000 Transmit FIFO/Buffer Depth = 1 Dataword.                                                                                                                                                                                                                                                                                                                                                                                                                 |
|            | 001 Transmit FIFO/Buffer Depth = 4 Datawords.                                                                                                                                                                                                                                                                                                                                                                                                                |
|            | 010 Transmit FIFO/Buffer Depth = 8 Datawords.                                                                                                                                                                                                                                                                                                                                                                                                                |
|            | 011 Transmit FIFO/Buffer Depth = 16 Datawords.                                                                                                                                                                                                                                                                                                                                                                                                               |
|            | 100 Transmit FIFO/Buffer Depth = 32 Datawords.                                                                                                                                                                                                                                                                                                                                                                                                               |

Table continues on the next page...

#### **Module Memory Map**

#### **UARTx\_PFIFO** field descriptions (continued)

| Field             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                   | 101 Transmit FIFO/Buffer Depth = 64 Datawords.                                                                                                                                                                                                                                                                                                                                                                                                             |
|                   | 110 Transmit FIFO/Buffer Depth = 128 Datawords.                                                                                                                                                                                                                                                                                                                                                                                                            |
|                   | 111 Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 3<br>RXFE         | Receive FIFO Enable                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                   | When this bit is set the built in FIFO structure for the receive buffer is enabled. The size of the FIFO structure is indicated by the RXFIFOSIZE field. If this bit is not set then the receive buffer operates as a FIFO of depth one dataword regardless of the value in RXFIFOSIZE. Both C2[TE] and C2[RE] must be cleared prior to changing this bit. Additionally TXFLUSH and RXFLUSH commands should be issued immediately after changing this bit. |
|                   | Receive FIFO is not enabled. Buffer is depth 1. (Legacy support)                                                                                                                                                                                                                                                                                                                                                                                           |
|                   | 1 Receive FIFO is enabled. Buffer is depth indicted by RXFIFOSIZE.                                                                                                                                                                                                                                                                                                                                                                                         |
| 2–0<br>RXFIFOSIZE | Receive FIFO. Buffer Depth                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                   | The maximum number of receive datawords that can be stored in the receive buffer before an overrun occurs. This field is read only.                                                                                                                                                                                                                                                                                                                        |
|                   | 000 Receive FIFO/Buffer Depth = 1 Dataword.                                                                                                                                                                                                                                                                                                                                                                                                                |
|                   | 001 Receive FIFO/Buffer Depth = 4 Datawords.                                                                                                                                                                                                                                                                                                                                                                                                               |
|                   | 010 Receive FIFO/Buffer Depth = 8 Datawords.                                                                                                                                                                                                                                                                                                                                                                                                               |
|                   | 011 Receive FIFO/Buffer Depth = 16 Datawords.                                                                                                                                                                                                                                                                                                                                                                                                              |
|                   | 100 Receive FIFO/Buffer Depth = 32 Datawords.                                                                                                                                                                                                                                                                                                                                                                                                              |
|                   | 101 Receive FIFO/Buffer Depth = 64 Datawords.                                                                                                                                                                                                                                                                                                                                                                                                              |
|                   | 110 Receive FIFO/Buffer Depth = 128 Datawords.                                                                                                                                                                                                                                                                                                                                                                                                             |
|                   | 111 Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                              |

### 43.3.16 UART FIFO Control Register (UARTx\_CFIFO)

This register provides the ability to program various control bits for FIFO operation. This register may be read or written at any time. Note that writing the TXFLUSH and RXFLUSH bits may result in data loss and requires careful action to prevent unintended / unpredictable behavior, hence it is recommended that TE and RE be cleared prior to flushing the corresponding FIFO.





### **UARTx\_CFIFO** field descriptions

| Field           | Description                                                                                                                                                     |
|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>TXFLUSH    | Transmit FIFO/Buffer Flush                                                                                                                                      |
| 1741 20011      | Writing to this bit causes all data that is stored in the transmit FIFO/buffer to be flushed. This does not affect data that is in the transmit shift register. |
|                 | 0 No flush operation occurs.                                                                                                                                    |
|                 | 1 All data in the transmit FIFO/Buffer is cleared out.                                                                                                          |
| 6<br>RXFLUSH    | Receive FIFO/Buffer Flush                                                                                                                                       |
| TIXI LOGIT      | Writing to this bit causes all data that is stored in the receive FIFO/buffer to be flushed. This does not affect data that is in the receive shift register.   |
|                 | 0 No flush operation occurs.                                                                                                                                    |
|                 | All data in the receive FIFO/buffer is cleared out.                                                                                                             |
| 5–2<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                              |
| 1<br>TXOFF      | Transmit FIFO Overflow Interrupt Enable                                                                                                                         |
| TAOFE           | When this bit is set the TXOF flag will generate an interrupt to the host.                                                                                      |
|                 | 0 TXOF flag does not generate an interrupt to the host.                                                                                                         |
|                 | 1 TXOF flag generates an interrupt to the host.                                                                                                                 |
| 0<br>RXUFE      | Receive FIFO Underflow Interrupt Enable                                                                                                                         |
| 11701 L         | When this bit is set the RXUF flag will generate an interrupt to the host.                                                                                      |
|                 | 0 RXUF flag does not generate an interrupt to the host.                                                                                                         |
|                 | 1 RXUF flag generates an interrupt to the host.                                                                                                                 |

# 43.3.17 UART FIFO Status Register (UARTx\_SFIFO)

This register provides various status information regarding the transmit and receiver buffers/FIFOs, including interrupt information. This register may be written or read at anytime.

Addresses: UART0\_SFIFO is FFFF\_8140h base + 12h offset = FFFF\_8152h UART1\_SFIFO is FFFF\_8160h base + 12h offset = FFFF\_8172h



### **UARTx\_SFIFO** field descriptions

| Field           | Description                                                                                                                                                                                                                                                                             |
|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>TXEMPT     | Transmit Buffer/FIFO Empty                                                                                                                                                                                                                                                              |
| .,,,,,          | This status bit asserts when there is no data in the Transmit FIFO/buffer. This bit does not take into account data that is in the transmit shift register.                                                                                                                             |
|                 | 0 Transmit buffer is not empty.                                                                                                                                                                                                                                                         |
|                 | 1 Transmit buffer is empty.                                                                                                                                                                                                                                                             |
| 6<br>RXEMPT     | Receive Buffer/FIFO Empty                                                                                                                                                                                                                                                               |
|                 | This status bit asserts when there is no data in the receive FIFO/Buffer. This bit does not take into account data that is in the receive shift register.                                                                                                                               |
|                 | 0 Receive buffer is not empty.                                                                                                                                                                                                                                                          |
|                 | 1 Receive buffer is empty.                                                                                                                                                                                                                                                              |
| 5–2<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                                      |
| 1<br>TXOF       | Transmitter Buffer Overflow Flag                                                                                                                                                                                                                                                        |
| .,,,,           | This flag indicates that more data has been written to the transmit buffer than it can hold. This bit will assert regardless of the value of CFIFO[TXOFE]. However, an interrupt will only be issued to the host if the CFIFO[TXOFE] bit is set. This flag is cleared by writing a "1". |
|                 | No transmit buffer overflow has occurred since the last time the flag was cleared.                                                                                                                                                                                                      |
|                 | 1 At least one transmit buffer overflow has occurred since the last time the flag was cleared.                                                                                                                                                                                          |
| 0<br>RXUF       | Receiver Buffer Underflow Flag                                                                                                                                                                                                                                                          |
| -               | This flag indicates that more data has been read from the receive buffer than was present. This bit will assert regardless of the value of CFIFO[RXUFE]. However, an interrupt will only be issued to the host if the CFIFO[RXUFE] bit is set. This flag is cleared by writing a "1".   |
|                 | 0 No receive buffer underflow has occurred since the last time the flag was cleared.                                                                                                                                                                                                    |
|                 | 1 At least one receive buffer underflow has occurred since the last time the flag was cleared.                                                                                                                                                                                          |

# 43.3.18 UART FIFO Transmit Watermark (UARTx\_TWFIFO)

This register provides the ability to set a programmable threshold for notification of needing additional transmit data. This register may be read at any time but should only be written when C2[TE] is not set. Changing the value of the watermark will not clear the S1[TDRE] flag.

Addresses: UART0\_TWFIFO is FFFF\_8140h base + 13h offset = FFFF\_8153h UART1\_TWFIFO is FFFF\_8160h base + 13h offset = FFFF\_8173h



### **UARTx\_TWFIFO** field descriptions

| Field          | Description                                                                                                                                                                                                                                                                                                                                                                                                                    |
|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–0<br>TXWATER | Transmit Watermark                                                                                                                                                                                                                                                                                                                                                                                                             |
|                | When the number of datawords in the transmit FIFO/buffer is equal to or less than the value in this register field then an interrupt via S1[TDRE] or a DMA request via C5[TDMAS] will be generated as determined by C5[TDMAS] and C2[TIE] fields. For proper operation the value in the TXWATER field must be set to be less than the size of the transmit buffer/FIFO size as indicated by PFIFO[TXFIFOSIZE] and PFIFO[TXFE]. |

# 43.3.19 UART FIFO Transmit Count (UARTx\_TCFIFO)

This is a read only register that indicates how many datawords are currently in the transmit buffer/FIFO. It may be read at anytime.

Addresses: UART0\_TCFIFO is FFFF\_8140h base + 14h offset = FFFF\_8154h UART1\_TCFIFO is FFFF\_8160h base + 14h offset = FFFF\_8174h



### **UARTx\_TCFIFO** field descriptions

| Field          | Description                                                                                                                                                                                                                                                                                                                                                                             |
|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–0<br>TXCOUNT | Transmit Counter  The value in this register indicates the number of datawords that are in the transmit buffer/FIFO. If a dataword is in the process of being transmitted (i.e. in the transmit shift register) it is not included in the count. This value may be used in conjunction with the PFIFO[TXFIFOSIZE] field to calculate how much room is left in the transmit buffer/FIFO. |

### 43.3.20 UART FIFO Receive Watermark (UARTx\_RWFIFO)

This register provides the ability to set a programmable threshold for notification of needing to remove data from the receiver buffer/FIFO. This register may be read at any time but should only be written when C2[RE] is not asserted. Changing the value in this register will not clear the S1[RDRF] flag.





### **UARTx\_RWFIFO** field descriptions

| Field          | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–0<br>RXWATER | Receive Watermark  When the number of datawords in the Receive FIFO/buffer is equal to or greater than the value in this register field the event is flagged. An interrupt via S1[RDRF] or a DMA request via C5[RDMAS] will be generated as determined by C5[RDMAS] and C2[RIE] fields. For proper operation the value in the RXWATER field must be set to be less than the size of the Receive buffer/FIFO size as indicated by PFIFO[RXFIFOSIZE] and PFIFO[RXFE] and greater than 0. |

## 43.3.21 UART FIFO Receive Count (UARTx\_RCFIFO)

This is a read only register that indicates how many datawords are currently in the receive buffer/FIFO. It may be read at anytime.

Addresses: UART0\_RCFIFO is FFFF\_8140h base + 16h offset = FFFF\_8156h UART1\_RCFIFO is FFFF\_8160h base + 16h offset = FFFF\_8176h



### UARTx\_RCFIFO field descriptions

| Field          | Description     |
|----------------|-----------------|
| 7–0<br>RXCOUNT | Receive Counter |

#### **UARTx\_RCFIFO** field descriptions (continued)

| Field | Description                                                                                                                                                                                                                                                                                                                                                     |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | The value in this register indicates the number of datawords that are in the receive buffer/FIFO. If a dataword is in the process of being received (i.e. in the receive shift register) it is not included in the count. This value may be used in conjunction with the PFIFO[RXFIFOSIZE] field to calculate how much room is left in the receive buffer/FIFO. |

### 43.3.22 **UART 7816 Control Register (UARTx\_C7816)**

The C7816 register is the primary control register for ISO-7816 specific functionality. This register is specific to 7816 functionality and the values in this register have no effect on UART operation and should be ignored if ISO\_7816E is not set/enabled. This register may be read at anytime but values should only be changed when the ISO\_7816E bit is not set.

Addresses: UART0\_C7816 is FFFF\_8140h base + 18h offset = FFFF\_8158h UART1\_C7816 is FFFF\_8160h base + 18h offset = FFFF\_8178h



### **UARTx\_C7816** field descriptions

| Field           | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–5<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 4<br>ONACK      | Generate NACK on Overflow  When this bit is set, the receiver will automatically generate a NACK response if a receive buffer overrun occurs as indicated by the S1[OR] field. In many systems this will result in the transmitter resending the packet that overflowed until the retransmit threshold for that transmitter has been reached. A NACK is only generated if TTYPE=0. This bit operates independently of ANACK. See Overrun NACK considerations.  O The received data does not generate a NACK when the receipt of the data results in an overflow event.  I If the receiver buffer overflows, a NACK is automatically sent on a received character. |
| 3<br>ANACK      | Generate NACK on Error  When this bit is set, the receiver will automatically generate a NACK response if a parity error occurs or if INIT is set and an invalid initial character is detected. A NACK is only generated if TTYPE = 0. If ANACK is set the UART will attempt to retransmit the data indefinitely. To stop retransmission attempts, clear C2[TE] or ISO_7816E and do not set until S1[TC] set C2[TE] again.                                                                                                                                                                                                                                        |

Table continues on the next page...

#### **Module Memory Map**

## **UARTx\_C7816** field descriptions (continued)

| Field          | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                | No NACK is automatically generated.     A NACK is automatically generated if a parity error is detected or if an invalid initial character is detected.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 2<br>INIT      | Detect Initial Character  When this bit is set, all received characters will be searched for a valid initial character. If an invalid initial character is identified then a NACK will be sent if ANACK is set. All received data is discarded and error flags blocked (S1[NF], S1[OR], S1[FE], S1[PF], IS7816[WT], IS7816[CWT], IS7816[BWT], IS7816[GTV]) until a valid initial character is detected. Upon detection of a valid initial character the configuration values S2[MSBF], C3[TXINV] and S2[RXINV] are automatically updated to reflect the initial character that was received. The actual INIT data value is not stored in the receive buffer. Additionally, upon detection of a valid initial character the IS7816[INITD] flag is set and an interrupt issued as programmed by the IE7816[INITDE] bit. When a valid initial character is detected the INIT bit is automatically cleared. |
|                | <ul> <li>Normal operating mode. Receiver does not seek to identify initial character.</li> <li>Receiver searches for initial character.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 1<br>TTYPE     | Transfer Type  This bit indicates the transfer protocol being used.  Refer to ISO-7816 / smartcard support for more details.  0  T = 0 Per the ISO-7816 specification.  1  T = 1 Per the ISO-7816 specification.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 0<br>ISO_7816E | ISO-7816 Functionality Enabled  This bit indicates that the UART is operating according to the ISO-7816 protocol.  NOTE: This bit should only be modified when no transmit or receive is occurring. If this bit is changed during a data transfer the data being transmitted or received may be transferred incorrectly.  0 ISO-7816 functionality is turned off / not enabled.  1 ISO-7816 functionality is turned on / enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

### 43.3.23 UART 7816 Interrupt Enable Register (UARTx\_IE7816)

The IE7816 register controls which flags result in an interrupt being issued. This register is specific to 7816 functionality, the corresponding flags that drive the interrupts will not assert when 7816E is not set/enabled. However, these flags may remain set if they asserted while 7816E was set and not subsequently cleared. This register maybe read or written at anytime.

Addresses: UART0\_IE7816 is FFFF\_8140h base + 19h offset = FFFF\_8159h UART1\_IE7816 is FFFF\_8160h base + 19h offset = FFFF\_8179h



#### **UARTx\_IE7816** field descriptions

| Field         | Description                                                                                 |  |  |  |  |  |
|---------------|---------------------------------------------------------------------------------------------|--|--|--|--|--|
| 7<br>WTE      | Wait Timer Interrupt Enable                                                                 |  |  |  |  |  |
| VV1E          | 0 The assertion of the IS7816[WT] bit will not result in the generation of an interrupt.    |  |  |  |  |  |
|               | 1 The assertion of the IS7816[WT] bit will result in the generation of an interrupt.        |  |  |  |  |  |
| 6<br>CWTE     | Character Wait Timer Interrupt Enable                                                       |  |  |  |  |  |
|               | 0 The assertion of the IS7816[CWT] bit will not result in the generation of an interrupt.   |  |  |  |  |  |
|               | 1 The assertion of the IS7816[CWT] bit will result in the generation of an interrupt.       |  |  |  |  |  |
| 5<br>BWTE     | Block Wait Timer Interrupt Enable                                                           |  |  |  |  |  |
|               | 0 The assertion of the IS7816[BWT] bit will not result in the generation of an interrupt.   |  |  |  |  |  |
|               | 1 The assertion of the IS7816[BWT] bit will result in the generation of an interrupt.       |  |  |  |  |  |
| 4<br>INITDE   | Initial Character Detected Interrupt Enable                                                 |  |  |  |  |  |
|               | 0 The assertion of the IS7816[INITD] bit will not result in the generation of an interrupt. |  |  |  |  |  |
|               | 1 The assertion of the IS7816[INITD] bit will result in the generation of an interrupt.     |  |  |  |  |  |
| 3<br>Reserved | This read-only bit is reserved and always has the value zero.                               |  |  |  |  |  |
| 2<br>GTVE     | Guard Timer Violated Interrupt Enable                                                       |  |  |  |  |  |
|               | 0 The assertion of the IS7816[GTV] bit will not result in the generation of an interrupt.   |  |  |  |  |  |
|               | 1 The assertion of the IS7816[GTV] bit will result in the generation of an interrupt.       |  |  |  |  |  |
| 1<br>TXTE     | Transmit Threshold Exceeded Interrupt Enable                                                |  |  |  |  |  |
|               | 0 The assertion of the IS7816[TXT] bit will not result in the generation of an interrupt.   |  |  |  |  |  |
|               | 1 The assertion of the IS7816[TXT] bit will result in the generation of an interrupt.       |  |  |  |  |  |

Table continues on the next page...

#### **Module Memory Map**

### **UARTx\_IE7816** field descriptions (continued)

| Field     | Description                                                                                                                                                                    |
|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0<br>RXTE | Receive Threshold Exceeded Interrupt Enable                                                                                                                                    |
|           | O The assertion of the IS7816[RXT] bit will not result in the generation of an interrupt.  The assertion of the IS7816[RXT] bit will result in the generation of an interrupt. |

## 43.3.24 UART 7816 Interrupt Status Register (UARTx\_IS7816)

The IS7816 register provides a mechanism to read and clear the interrupt flags. All flags/interrupts are cleared by writing a "1" to the bit location. Writing a "0" has no effect. All bits are "sticky", meaning they only indicate that the flag condition occurred since the last time the bit was cleared not that the condition currently exists. The status flags are set regardless of if the corresponding bit in the IC7816 is set or cleared, the IC7816 only controls if a interrupt is issued to the host processor. This register is specific to 7816 functionality and the values in this register have no affect on UART operation and should be ignored if 7816E is not set/enabled. This register may be read or written at anytime.

Addresses: UART0\_IS7816 is FFFF\_8140h base + 1Ah offset = FFFF\_815Ah

UART1\_IS7816 is FFFF\_8160h base + 1Ah offset = FFFF\_817Ah



### **UARTx\_IS7816** field descriptions

| Field   | Description                                                                                                                                                                                                                                                                              |
|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>WT | Wait Timer Interrupt                                                                                                                                                                                                                                                                     |
| VVI     | This flag indicates that the wait time, the time between the leading edge of a character being transmitted and the leading edge of the next response character has exceeded the programed value. This flag only asserts when C7816[TTYPE] = 0. This interrupt is cleared by writing `1'. |
|         | 0 Wait time (WT) has not been violated.                                                                                                                                                                                                                                                  |
|         | 1 Wait time (WT) has been violated.                                                                                                                                                                                                                                                      |
| 6       | Character Wait Timer Interrupt                                                                                                                                                                                                                                                           |
| CWT     | This flag indicates that the character wait time, the time between the leading edges of two consecutive characters in a block has exceed the programed value. This flag only asserts when C7816[TTYPE] = 1. This interrupt is cleared by writing `1'.                                    |
|         | 0 Character wait time (CWT) has not been violated.                                                                                                                                                                                                                                       |
|         | 1 Character wait time (CWT) has been violated.                                                                                                                                                                                                                                           |

Table continues on the next page...

## **UARTx\_IS7816** field descriptions (continued)

| Field         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |
|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| 5<br>BWT      | Block Wait Timer Interrupt                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |
|               | This flag indicates that the block wait time, the time between the leading edge of first received character of a block and the leading edge of the last character the previously transmitted block. This flag only asserts when C7816[TTYPE] = 1.This interrupt is cleared by writing '1'.                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |
|               | 0 Block wait time (BWT) has not been violated.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |
|               | Block wait tTime (BWT) has been violated.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |
| 4<br>INITD    | Initial Character Detected Interrupt  This flag indicates that a valid initial character was received. This interrupt is cleared by writing `1'.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |
|               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |
|               | A valid initial character has not been received.     A valid initial character has been received.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |
| 0             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |
| 3<br>Reserved | This read-only bit is reserved and always has the value zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |
| 2             | Guard Timer Violated Interrupt                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |
| GTV           | This flag indicates that one or more of the character guard time, block guard time or guard time were violated. This interrupt is cleared by writing `1'.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |
|               | <ul> <li>A guard time (GT, CGT or BGT) has not been violated.</li> <li>A guard time (GT, CGT or BGT) has been violated.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |
| 1<br>TXT      | Transmit Threshold Exceeded Interrupt                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |
| 121           | This flag indicates that the transmit NACK threshold has been exceeded as indicated by the ET7816[TXTHRESHOLD] field. Regardless if this flag is set, the UART will continue to retransmit indefinitely. This flag only asserts when C7816[TTYPE] = 0. If 7816E is cleared/disabled, ANACK is cleared/disabled, C2[TE] is cleared/disabled, C7816[TTYPE] = 1 or packet is transferred without receiving a NACK the internal NACK detection counter is cleared and the count restarts from zero on the next received NACK. This interrupt is cleared by writing `1'.                                                                                                                                   |  |  |  |  |  |  |
|               | The number of retries and corresponding NACKS does not exceed the value in the ET7816[TXTHRESHOLD] field.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |
|               | The number of retries and corresponding NACKS exceeds the value in the ET7816[TXTHRESHOLD] field.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |
| 0<br>RXT      | Receive Threshold Exceeded Interrupt                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |
|               | This flag indicates that there were more than ET7816[RXTHRESHOLD] consecutive NACKS generated in response to parity errors on received data. This flag requires ANACK to be set. Additionally, this flag only asserts when C7816[TTYPE] = 0. Clearing this bit also resets the counter keeping track of consecutive NACKS. The UART will continue to attempt to receive data regardless of if this flag is set. If 7816E is cleared/disabled, RE is cleared/disabled, C7816[TTYPE] = 1 or packet is received without needing to issue a NACK, the internal NACK detection counter is cleared and the count restarts from zero on the next transmitted NACK. This interrupt is cleared by writing `1'. |  |  |  |  |  |  |
|               | 0 The number of consecutive NACKS generated as a result of parity errors and buffer overruns is less than or equal to the value in ET7816[RXTHRESHOLD].                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |
|               | 1 The number of consecutive NACKS generated as a result of parity errors and buffer overruns is greater than the value in ET7816[RXTHRESHOLD].                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |

### 43.3.25 UART 7816 Wait Parameter Register (UARTx\_WP7816T0)

The WP7816 register contains constants used in the generation of various wait timer counters. To save register space this register is used differently when C7816[TTYPE] = 0 and C7816[TTYPE] = 1. This register may be read at anytime. This register must only be written when C7816[ISO\_7816E] is not set.

Addresses: UART0\_WP7816T0 is FFFF\_8140h base + 1Bh offset = FFFF\_815Bh UART1\_WP7816T0 is FFFF\_8160h base + 1Bh offset = FFFF\_817Bh



### UARTx\_WP7816T0 field descriptions

| Field     | Description                                                                                                                                                                                                                                                                  |
|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–0<br>WI | Wait Timer Interrupt (C7816[TTYPE] = 0)  This value is used to calculate the value used for the WT counter. It represents a value between 1 and 255. The value of zero is not valid. This value is only used when C7816[TTYPE] = 0. See Wait time and guard time parameters. |

## 43.3.26 UART 7816 Wait Parameter Register (UARTx\_WP7816T1)

The WP7816 register contains constants used in the generation of various wait timer counters. To save register space this register is used differently when C7816[TTYPE] = 0 and C7816[TTYPE] = 1. This register maybe read at anytime. This register must only be written when C7816[ISO\_7816E] is not set.

Addresses: UART0\_WP7816T1 is FFFF\_8140h base + 1Bh offset = FFFF\_815Bh UART1\_WP7816T1 is FFFF\_8160h base + 1Bh offset = FFFF\_817Bh



#### **UARTx\_WP7816T1** field descriptions

| Field | Description                                    |
|-------|------------------------------------------------|
| 7–4   | Character Wait Time Integer (C7816[TTYPE] = 1) |
| CWI   |                                                |

Table continues on the next page...

#### **UARTx\_WP7816T1** field descriptions (continued)

| Field      | Description                                                                                                                                                                                         |
|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | This value is used to calculate the value used for the CWT counter. It represents a value between 0 and 15. This value is only used when C7816[TTYPE] = 1. See Wait time and guard time parameters. |
| 3–0<br>BWI | Block Wait Time Integer(C7816[TTYPE] = 1)                                                                                                                                                           |
|            | This value is used to calculate the value used for the BWT counter. It represent a value between 0 and 15. This value is only used when C7816[TTYPE] = 1. See Wait time and guard time parameters.  |

## 43.3.27 UART 7816 Wait N Register (UARTx\_WN7816)

The WN7816 register contains a parameter that is used in the calculation of the guard time counter. This register may be read at anytime. This register must only be written when C7816[ISO\_7816E] is not set.

Addresses: UART0\_WN7816 is FFFF\_8140h base + 1Ch offset = FFFF\_815Ch UART1\_WN7816 is FFFF\_8160h base + 1Ch offset = FFFF\_817Ch



### **UARTx\_WN7816** field descriptions

| Field      | Description                                                                                                                                                                                       |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–0<br>GTN | Guard Band N  This register field defines a parameter used in the calculation of GT, CGT and BGT counters. The value represents an integer number 0-255. See Wait time and guard time parameters. |

### 43.3.28 UART 7816 Wait FD Register (UARTx\_WF7816)

The WF7816 contains parameters that are used in the generation of various counters including GT, CGT, BGT, WT and BWT. This register may be read from at anytime. This register must only be written to when C7816[ISO\_7816E] is not set.

Addresses: UART0\_WF7816 is FFFF\_8140h base + 1Dh offset = FFFF\_815Dh UART1\_WF7816 is FFFF\_8160h base + 1Dh offset = FFFF\_817Dh



#### **Module Memory Map**

#### **UARTx\_WF7816** field descriptions

| Field       | Description                                                                                                                                                                                                                                                                               |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–0<br>GTFD | FD Multiplier  This field is used as another multiplier in the calculation of WT and BWT. This values represents a number between 1 and 255. The value of 0 is invalid. This value is NOT used in baud rate generation. See Wait time and guard time parameters and Baud rate generation. |

## 43.3.29 UART 7816 Error Threshold Register (UARTx\_ET7816)

The ET7816 register contains fields that determine the number of NACKs that must be received or transmitted before the host processor is notified. This register may be read at anytime. This register must only be written when C7816[ISO\_7816E] is not set.

Addresses: UART0\_ET7816 is FFFF\_8140h base + 1Eh offset = FFFF\_815Eh

UART1\_ET7816 is FFFF\_8160h base + 1Eh offset = FFFF\_817Eh

| Bit   | 7 | 6        | 5      | 4 | 3 | 2         | 1      | 0 |
|-------|---|----------|--------|---|---|-----------|--------|---|
| Read  |   | TYTHRI   | ESHOLD |   |   | RYTHRI    | ESHOLD |   |
| Write |   | 17/11/11 | LOHOLD |   |   | 11/111111 | LOHOLD |   |
| Reset | 0 | 0        | 0      | 0 | 0 | 0         | 0      | 0 |

### **UARTx\_ET7816** field descriptions

| Field              | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–4<br>TXTHRESHOLD | Transmit NACK Threshold  The value written to this field indicates the maximum number of failed attempts (NACKs) a transmitted character can have before the host processor is notified. Meaning a value of 0 will always result in TXT asserting on the first NACK that is received. A value of 1 will result in TXT being asserted on the second NACK that is received. This field is only meaningful when C7816[TTYPE] = 0 and C7816[ANACK] = 1. The value read from this field represents the number of consecutive NACKs that have been received since the last successful transmission. This counter saturates at 4'hF and does not wrap around. Regardless of how many NACKs that are received, the UART will continue to retransmit indefinitely. This flag only asserts when C7816[TTYPE] = 0. For additional information see the IS7816[TXT] bit description. |
| 3–0<br>RXTHRESHOLD | Receive NACK Threshold  The value written to this field indicates the maximum number of consecutive NACKs generated as a result of a parity error or receiver buffer overruns before the host processor is notified. Once the counter exceeds that value in the field the IS7816[RXT] will be asserted. This field is only meaningful when C7816[TTYPE] = 0. The value read from this field represents the number of consecutive NACKs that have been transmitted since the last successful reception. This counter saturates at 4'hF and does not wrap around. Regardless of the number of NACKs sent, the UART will continue to receive valid packets indefinitely. For additional information see IS7816[RXT] bit description.                                                                                                                                       |

### 43.3.30 UART 7816 Transmit Length Register (UARTx\_TL7816)

The TL7816 register is used to indicate how many characters are contained in the block being transmitted. This register is only used when C7816[TTYPE] = 1. This register may be read at anytime. This register should only be written when C2[TE] is not enabled.





#### UARTx\_TL7816 field descriptions

| Field       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–0<br>TLEN | Transmit Length  This value plus 4 indicates the number of characters contained in the block being transmitted. This register is automatically decremented by 1 for each character in the information field portion of the block. Additionally, this register is automatically decremented by 1 for the first character of a CRC in the epilogue field. Hence, this register should be programmed with the number of bytes in the data packet if a LRC is being transmitted, and the number of bytes + 1 if a CRC is being transmitted. This register is not decremented for characters that are assumed to be part of the Prologue field (first three characters transmitted in a block) or the LRC or last CRC character in the Epilogue field (last character transmitted). This field should only be programed or adjusted when C2[TE] is cleared. |

# 43.4 Functional description

This section provides a complete functional description of the UART block.

The UART allows full duplex, asynchronous, NRZ serial communication between the CPU and remote devices, including other CPUs. The UART transmitter and receiver operate independently, although they use the same baud rate generator. The CPU monitors the status of the UART, writes the data to be transmitted, and processes received data.

## 43.4.1 Transmitter



Figure 43-91. Transmitter Block Diagram

## 43.4.1.1 Transmitter character length

The UART transmitter can accommodate either 8, 9, or 10-bit data characters. The state of the C1[M] and C1[PE] bits and the C4[M10] bit determine the length of data characters. When transmitting 9-bit data, bit C3[T8] is the ninth bit (bit 8).

#### 43.4.1.2 Transmission bit order

When the S2[MSBF] bit is set, the UART automatically transmits the MSB of the data word as the first bit after the start bit. Likewise the LSB of the data word is transmitted immediately preceding the parity bit (or the stop bit if parity is not enabled). All necessary bit ordering is handled automatically by the module hence the format of the data written to the D register for transmission is completely independent of the S2[MSBF] setting.

#### 43.4.1.3 Character transmission

To transmit data, the MCU writes the data bits to the UART transmit buffer using UART data registers (C3[T8]/D). Data in the transmit buffer is then in turn transferred to the transmitter shift register as needed. The transmit shift register then shifts a frame out through the transmit data output signal after it has prefaced it with any required start and stop bits. The UART data registers (C3[T8] and D) provide access to the transmit buffer structure.

The UART also sets a flag, the transmit data register empty flag (S1[TDRE]) and generates interrupt or DMA request (C5[TDMAS]), whenever the number of datawords in the transmit buffer is equal to or less than the value indicated by the TWFIFO[TXWATER]. The transmit driver routine may respond to this flag by writing additional datawords to the transmit buffer using (C3[T8]/D) as space permits.

See Application information for specific programing sequences.

Setting the C2[TE] bit automatically loads the transmit shift register with a preamble of 10 logic 1s (if C1[M] = 0), 11 logic 1s (if C1[M] = 1 and C4[M10] = 0), or 12 logic 1s (if C1[M] = 1, C4[M10] = 1, C1[PE] = 1). After the preamble shifts out, control logic transfers the data from the UART data register into the transmit shift register. The transmitter automatically transmits the correct start bit and stop bit before and after the dataword.

When C7816[ISO\_7816E] = 1 setting the C2[TE] bit does not result in a preamble being generated. The transmitter starts transmitting as soon as the corresponding guard time expires. When C7816[TTYPE] = 0 the value in GT is used, when C7816[TTYPE] = 1 the value BGT is used since it is assumed that the C2[TE] will remain asserted until the end of the block transfer. The C2[TE] bit is automatically cleared when in C7816[TTYPE] = 1 and the block being transmitted has been completed. When C7816[TTYPE] = 0, the transmitter listens for a NACK indication. If no NACK is received it is assumed that character was correctly received. If a NACK is received the transmitter will resend the data, assuming that the number of retries for that character (number of NACKs received) is less than or equal to the value in ET7816[TXTHRESHOLD].

#### **Functional description**

Hardware supports odd or even parity. When parity is enabled, the bit immediately preceding the stop bit is the parity bit.

When the transmit shift register is not transmitting a frame, the transmit data output signal goes to the idle condition, logic 1. If at any time software clears the C2[TE] bit, the transmitter enable signal goes low and the transmit signal goes idle.

If software clears C2[TE] while a transmission is in progress, the character in the transmit shift register continues to shift out, provided S1[TC] flag was cleared during the data write sequence. To clear the S1[TC] flag, the S1 register must be read followed by a write to UARTx\_D register.

If the S1[TC] flag is cleared during character transmission and the C2[TE] bit is cleared, the transmission enable signal is deasserted at the completion of current frame. Following this, the transmit data out signal enters the idle state even if there is data pending in the UART transmit data buffer. To ensure that all the data written in the FIFO is transmitted on the link before clearing C2[TE], wait for the S1[TC] flag to set. Alternatively, the same can be achieved by setting TWFIFO[TXWATER] to 0x0 and waiting for S1[TDRE] to set.

# 43.4.1.4 Transmitting break characters

Setting the C2[SBK] loads the transmit shift register with a break character. A break character contains all logic 0s and has no start, stop, or parity bit. Break character length depends on the C1[M] and C1[PE] bits, the S2[BRK13] bit, and the C4[M10] bit. Refer to the following table.

| S2[BRK13] | C1[M] | C4[M10] | C1[PE] | Bits transmitted |
|-----------|-------|---------|--------|------------------|
| 0         | 0     | _       | _      | 10               |
| 0         | 1     | 0       | _      | 11               |
| 0         | 1     | 1       | 0      | 11               |
| 0         | 1     | 1       | 1      | 12               |
| 1         | 0     | _       | _      | 13               |
| 1         | 1     | _       | _      | 14               |

Table 43-96. Transmit break character length

As long as C2[SBK] is set, transmitter logic continuously loads break characters into the transmit shift register. After software clears the C2[SBK] bit, the shift register finishes transmitting the last break character and then transmits at least one logic 1. The automatic logic 1 at the end of a break character guarantees the recognition of the start bit of the next character. Break bits are not supported when C7816[ISO\_7816E] is set/enabled.

#### NOTE

When queuing a break character, it will be transmitted following the completion of the data value currently being shifted out from the shift register. This means that if data is queued in the data buffer to be transmitted, the break character will preempt that queued data. The queued data will then be transmitted after the break character is complete.

### 43.4.1.5 Idle characters

An idle character contains all logic 1s and has no start, stop, or parity bit. Idle character length depends on the C1[M] and C1[PE] bits and the C4[M10] bit. The preamble is a synchronizing idle character that begins the first transmission initiated after setting the C2[TE] bit. When C7816[ISO\_7816E] is set/enabled, idle characters are not sent or detected. When data is not being transmitted the data I/O line is in an inactive state.

If the C2[TE] bit is cleared during a transmission, the transmit data output signal becomes idle after completion of the transmission in progress. Clearing and then setting the C2[TE] bit during a transmission queues an idle character to be sent after the dataword currently being transmitted.

#### Note

When queuing an idle character the idle character will be transmitted following the completion of the data value currently being shifted out from the shift register. This means that if data is queued in the data buffer to be transmitted, the idle character will preempt that queued data. The queued data will then be transmitted after the idle character is complete.

If the C2[TE] bit is cleared and the transmission is completed, the UART is not the master of the TXD pin.

#### 43.4.1.6 Hardware flow control

The transmitter supports hardware flow control by gating the transmission with the value of  $\overline{CTS}$ . If the clear-to-send operation is enabled, the character is transmitted when  $\overline{CTS}$  is asserted. If  $\overline{CTS}$  is deasserted in the middle of a transmission with characters remaining in the receiver data buffer, the character in the shift register is sent and TXD remains in the mark state until  $\overline{CTS}$  is reasserted.

#### **Functional description**

If the clear-to-send operation is disabled, the transmitter ignores the state of  $\overline{CTS}$ . Also, if the transmitter is forced to send a continuous low condition because it is sending a break character, the transmitter ignores the state of  $\overline{CTS}$  regardless of whether the clear-to-send operation is enabled.

The transmitter's  $\overline{CTS}$  signal can also be enabled even if the same UART receiver's  $\overline{RTS}$  signal is disabled.

### 43.4.1.7 Transceiver driver enable

The transmitter can use  $\overline{RTS}$  as an enable signal for the driver of an external transceiver, see Transceiver driver enable using  $\overline{RTS}$  for details. If the request-to-send operation is enabled, when a character is placed into an empty transmitter data buffer,  $\overline{RTS}$  asserts one bit time before the start bit is transmitted.  $\overline{RTS}$  remains asserted for the whole time that the transmitter data buffer has any characters.  $\overline{RTS}$  deasserts one bit time after all characters in the transmitter data buffer and shift register are completely sent, including the last stop bit. Transmitting a break character also asserts  $\overline{RTS}$ , with the same assertion and deassertion timing as having a character in the transmitter data buffer.

The transmitter's  $\overline{RTS}$  signal only asserts when the transmitter is enabled. However, the transmitter's  $\overline{RTS}$  signal is unaffected by its  $\overline{CTS}$  signal.  $\overline{RTS}$  will remain asserted until the transfer is completed, even if the transmitter is disabled mid-way through a data transfer.

The following figure shows the functional timing information for the transmitter. Along with the actual character itself, TXD shows the start bit. The stop bit is also indicated, with a dashed line if necessary.



1. Cn = transmit characters

Figure 43-92. Transmitter RTS and CTS timing diagram

## 43.4.2 Receiver



Figure 43-93. UART receiver block diagram

# 43.4.2.1 Receiver character length

The UART receiver can accommodate 8-, 9-, or 10-bit data characters. The states of the C1[M] and C1[PE] bits and the C4[M10] bit determine the length of data characters. When receiving 9 or 10-bit data, bit C3[R8] is the ninth bit (bit 8).

## 43.4.2.2 Receiver bit ordering

When the S2[MSBF] bit is set, the receiver operates such that the first bit received after the start bit is the MSB of the data word. Likewise the bit received immediately preceding the parity bit (or the stop bit if parity is not enabled) is treated as the LSB for

the data word. All necessary bit ordering is handled automatically by the module hence the format of the data read from receive data buffer is completely independent of the S2[MSBF] setting.

## 43.4.2.3 Character reception

During UART reception, the receive shift register shifts a frame in from the unsynchronized receiver input signal. After a complete frame shifts into the receive shift register, the data portion of the frame transfers to the UART receive buffer. Additionally, the noise and parity error flags that are calculated during the receive process are also captured in the UART receive buffer. The receive data buffer is accessible via the D and C3[T8] registers. Additional received information flags regarding the receive dataword can be read in ED register. The S1[RDRF] flag is set if the number of resulting datawords in the receive buffer is equal to or greater than the number indicated by RWFIFO[RXWATER]. If the C2[RIE] is also set, the RDRF flag generates an RDRF interrupt request. Alternatively, by programming the C5[RDMAS] bit correctly a DMA request can be generated.

When 7816E is set/enabled and C7816[TTYPE] = 0, character reception operates slightly differently. Upon receipt of the parity bit, the validity of the parity bit is checked. If C7816[ANACK] is set and the parity check fails or if INIT and the received character is not a valid initial character, then a NACK is sent by the receiver. If the number of consecutive receive errors exceeds the threshold set by ET7816[RXTHRESHOLD] then the IS7816[RXT] flag is set and an interrupt generated if IE7816[RXTE] is set. If an error is detected (parity or invalid initial character) the data is NOT transferred from the receive shift register to the receive buffer. Instead, the data is overwritten by the next incoming data.

When the C7816[ISO\_7816E] is set/enabled and C7816[ONACK] is set/enabled and the received character would result in the receive buffer overflowing a NACK is issued by the receiver. Additionally, the S1[OR] flag is set and interrupt issued if appropriate and the data in the shift register is discarded.

## 43.4.2.4 Data sampling

The receiver samples the unsynchronized receiver input signal at the RT clock rate. The RT clock is an internal signal with a frequency 16 times the baud rate. To adjust for baud rate mismatch, the RT clock (see the following figure) is re-synchronized:

#### **Functional description**

- After every start bit.
- After the receiver detects a data bit change from logic 1 to logic 0 (after the majority of data bit samples at RT8, RT9, and RT10 returns a valid logic 1 and the majority of the next RT8, RT9, and RT10 samples returns a valid logic 0).

To locate the start bit, data recovery logic does an asynchronous search for a logic 0 preceded by three logic 1s. When the falling edge of a possible start bit occurs, the RT clock begins to count to 16.



Figure 43-94. Receiver data sampling

To verify the start bit and to detect noise, data recovery logic takes samples at RT3, RT5, and RT7 when C7816[ISO\_7816E] is cleared/disabled and RT8, RT9 and RT10 when C7816[ISO\_7816E] is set/enabled. The following table summarizes the results of the start bit verification samples.

| RT3, RT5, and RT7 samples<br>RT8, RT9, RT10 samples when 7816E | Start bit verification | Noise flag |  |
|----------------------------------------------------------------|------------------------|------------|--|
| 000                                                            | Yes                    | 0          |  |
| 001                                                            | Yes                    | 1          |  |
| 010                                                            | Yes                    | 1          |  |
| 011                                                            | No                     | 0          |  |
| 100                                                            | Yes                    | 1          |  |
| 101                                                            | No                     | 0          |  |
| 110                                                            | No                     | 0          |  |
| 111                                                            | No                     | 0          |  |

Table 43-97. Start bit verification

If start bit verification is not successful, the RT clock is reset and a new search for a start bit begins.

To determine the value of a data bit and to detect noise, recovery logic takes samples at RT8, RT9, and RT10. The following table summarizes the results of the data bit samples.

Table 43-98. Data bit recovery

| RT8, RT9, and RT10 samples | Data bit determination | Noise flag |  |
|----------------------------|------------------------|------------|--|
| 000                        | 0                      | 0          |  |
| 001                        | 0                      | 1          |  |
| 010                        | 0                      | 1          |  |
| 011                        | 1                      | 1          |  |
| 100                        | 0                      | 1          |  |
| 101                        | 1                      | 1          |  |
| 110                        | 1                      | 1          |  |
| 111                        | 1                      | 0          |  |

#### **Note**

The RT8, RT9, and RT10 samples do not affect start bit verification. If any or all of the RT8, RT9, and RT10 start bit samples are logic 1s following a successful start bit verification, the noise flag (S1[NF]) is set and the receiver assumes that the bit is a start bit (logic 0). With the exception of when C7816[ISO\_7816E] is set/enabled, where the values of RT8, RT9 and RT10 exclusively determine if a start bit exists.

To verify a stop bit and to detect noise, recovery logic takes samples at RT8, RT9, and RT10. The following table summarizes the results of the stop bit samples. In the event that C7816[ISO\_7816E] is set/enabled and C7816[TTYPE] = 0, verification of a stop bit does not take place. Rather, starting with RT8 the receiver transmits a NACK as programmed until time RT9 of the following time period. Framing Error detection is not supported when C7816[ISO\_7816E] is set/enabled.

Table 43-99. Stop bit recovery

| RT8, RT9, and RT10 samples | Framing error flag | Noise flag |  |
|----------------------------|--------------------|------------|--|
| 000                        | 1                  | 0          |  |
| 001                        | 1                  | 1          |  |
| 010                        | 1                  | 1          |  |
| 011                        | 0                  | 1          |  |
| 100                        | 1                  | 1          |  |
| 101                        | 0                  | 1          |  |
| 110                        | 0                  | 1          |  |
| 111                        | 0                  | 0          |  |

#### **Functional description**

In the following figure, the verification samples RT3 and RT5 determine that the first low detected was noise and not the beginning of a start bit. In this example C7816[ISO\_7816E] = 0. The RT clock is reset and the start bit search begins again. The noise flag is not set because the noise occurred before the start bit was found.



Figure 43-95. Start bit search example 1 (C7816[ISO\_7816E] = 0)

In the following figure, verification sample at RT3 is high. In this example C7816[ISO\_7816E] = 0. The RT3 sample sets the noise flag. Although the perceived bit time is misaligned, the data samples RT8, RT9, and RT10 are within the bit time and data recovery is successful.



Figure 43-96. Start bit search example 2 (C7816[ISO\_7816E] = 0)

In the following figure, a large burst of noise is perceived as the beginning of a start bit, although the test sample at RT5 is high. In this example C7816[ISO\_7816E] = 0. The RT5 sample sets the noise flag. Although this is a worst-case misalignment of perceived bit time, the data samples RT8, RT9, and RT10 are within the bit time and data recovery is successful.





Figure 43-97. Start bit search example 3 (C7816[ISO\_7816E] = 0)

The following figure shows the effect of noise early in the start bit time. In this example C7816[ISO\_7816E] = 0. Although this noise does not affect proper synchronization with the start bit time, it does set the noise flag.



Figure 43-98. Start bit search example 4 (C7816[ISO\_7816E] = 0)

The following figure shows a burst of noise near the beginning of the start bit that resets the RT clock. In this example C7816[ISO\_7816E] = 0. The sample after the reset is low but is not preceded by three high samples that would qualify as a falling edge. Depending on the timing of the start bit search and on the data, the frame may be missed entirely or it may set the framing error flag.



Figure 43-99. Start bit search example 5 (C7816[ISO\_7816E] = 0)

In the following figure, a noise burst makes the majority of data samples RT8, RT9, and RT10 high. In this example C7816[ISO\_7816E] = 0. This sets the noise flag but does not reset the RT clock. In start bits only, the RT8, RT9, and RT10 data samples are ignored. In this example, if C7816[ISO\_7816E] = 1 then a start bit would not have been detected at all since at least two of the three samples (RT8, RT9, RT10) were high.



Figure 43-100. Start bit search example 6

### 43.4.2.5 Framing errors

If the data recovery logic does not detect a logic 1 where the stop bit should be in an incoming frame, it sets the framing error flag, S1[FE] if S2[LBKDE] is disabled. A break character when S2[LBKDE] is disabled also sets the S1[FE] because a break character has no stop bit. The S1[FE] is set at the same time that received data is placed in the receive data buffer. Framing errors are not supported when C7816[ISO7816E] is set/enabled. However, if the S1[FE] is set data will not be received when C7816[ISO7816E] is set.

### 43.4.2.6 Receiving break characters

The UART recognizes a break character when a start bit is followed by eight, nine, or ten logic 0 data bits and a logic 0 where the stop bit should be. Receiving a break character has these effects on UART registers:

- Sets the framing error flag, S1[FE].
- Writes an all "0" dataword to the data buffer, which may cause S1[RDRF] to set depending on the watermark and number of values in the data buffer.
- May set the overrun flag, S1[OR], noise flag, S1[NF], parity error flag, S1[PE], or the receiver active flag, S2[RAF].

The detection threshold for a break character can be adjusted when using an internal oscillator in a LIN system by setting the S2[LBKDE] bit. The UART break character detection threshold depends on the C1[M] and C1[PE] bits, the C4[LBKDE] bit, and the C4[M10] bit. Refer to the following table.

**LBKDE** M10 M PΕ Threshold (bits) 0 0 10 0 1 0 11 1 1 11 0 1 1 1 12 0 1 11 1 12

Table 43-100. Receive break character detection threshold

While C4[LBKDE] is set, it will have these effects on the UART registers:

- Prevents the S1[RDRF], S1[FE], S1[NF], and S1[PF] flags from being set. However, if they are already set they will remain set.
- Sets the LIN break detect interrupt flag, S2[LBKDIF] if a LIN break character is received.

Break characters are not detected or supported when C7816[ISO\_7816E] is set/enabled.

### 43.4.2.7 Hardware flow control

To support hardware flow control, the receiver can be programmed to automatically deassert and assert  $\overline{RTS}$ .

- RTS will remain asserted until the transfer is completed, even if the transmitter is disabled mid way through a data transfer, see Transceiver driver enable using RTS for more details.
- If the receiver request-to-send functionality is enabled, the receiver automatically deasserts  $\overline{RTS}$  if the number of characters in the receiver data register is equal to or greater than receiver data buffer's watermark, RWFIFO[RXWATER].
- The receiver asserts  $\overline{RTS}$  when the number of characters in the receiver data register is less than the watermark. It is not affected by whether RDRF is asserted.
- Even if RTS is deasserted, the receiver continues to receive characters until the receiver data buffer is full or is overrun.
- If the receiver request-to-send functionality is disabled, the receiver  $\overline{RTS}$  remains deasserted.

The following figure shows receiver hardware flow control functional timing. Along with the actual character itself, RXD shows the start bit. The stop bit also indicated, with a dashed line if necessary. The watermark is set to 2.



Figure 43-101. Receiver hardware flow control timing diagram

#### 43.4.2.8 Baud rate tolerance

A transmitting device may be operating at a baud rate below or above the receiver baud rate. Accumulated bit time misalignment can cause one of the three stop bit data samples (RT8, RT9, and RT10) to fall outside the actual stop bit. A noise error will occur if the

RT8, RT9, and RT10 samples are not all the same logical values. A framing error will occur if the receiver clock is misaligned in such a way that the majority of the RT8, RT9, and RT10 stop bit samples are a logic zero.

As the receiver samples an incoming frame, it re-synchronizes the RT clock on any valid falling edge within the frame. Resynchronization within frames will correct a misalignment between transmitter bit times and receiver bit times.

#### 43.4.2.8.1 Slow data tolerance

The following figure shows how much a slow received frame can be misaligned without causing a noise error or a framing error. The slow stop bit begins at RT8 instead of RT1 but arrives in time for the stop bit data samples at RT8, RT9, and RT10.



Figure 43-102. Slow data

For an 8-bit data character, data sampling of the stop bit takes the receiver 154 RT cycles (9 bit times  $\times$  16 RT cycles + 10 RT cycles).

With the misaligned character shown in the above figure, the receiver counts 154 RT cycles at the point when the count of the transmitting device is 147 RT cycles (9 bit times × 16 RT cycles + 3 RT cycles).

The maximum percent difference between the receiver count and the transmitter count of a slow 8-bit data character with no errors is:

$$((154 - 147) \div 154) \times 100 = 4.54\%$$

For a 9-bit data character, data sampling of the stop bit takes the receiver 170 RT cycles (10 bit times × 16 RT cycles + 10 RT cycles).

With the misaligned character shown in the above figure, the receiver counts 170 RT cycles at the point when the count of the transmitting device is 163 RT cycles (10 bit times  $\times$  16 RT cycles + 3 RT cycles).

The maximum percent difference between the receiver count and the transmitter count of a slow 9-bit character with no errors is:

$$((170 - 163) \div 170) \times 100 = 4.12\%$$

#### 43.4.2.8.2 Fast data tolerance

The following figure shows how much a fast received frame can be misaligned. The fast stop bit ends at RT10 instead of RT16 but is still sampled at RT8, RT9, and RT10.



Figure 43-103. Fast data

For an 8-bit data character, data sampling of the stop bit takes the receiver 154 RT cycles (9 bit times  $\times$  16 RT cycles + 10 RT cycles).

With the misaligned character shown in the above figure, the receiver counts 154 RT cycles at the point when the count of the transmitting device is 160 RT cycles (10 bit times  $\times$  16 RT cycles).

The maximum percent difference between the receiver count and the transmitter count of a fast 8-bit character with no errors is:

$$((154 - 160) \div 154) \times 100 = 3.90\%$$

For a 9-bit data character, data sampling of the stop bit takes the receiver 170 RT cycles (10 bit times  $\times$  16 RT cycles + 10 RT cycles).

With the misaligned character shown in the above figure, the receiver counts 170 RT cycles at the point when the count of the transmitting device is 176 RT cycles (11 bit times  $\times$  16 RT cycles).

The maximum percent difference between the receiver count and the transmitter count of a fast 9-bit character with no errors is:

$$((170 - 176) \div 170) \times 100 = 3.53\%$$

## 43.4.2.9 Receiver wakeup

The C1[WAKE] bit determines how the UART is brought out of the standby state to process an incoming message. The C1[WAKE] bit enables either idle line wakeup or address mark wakeup.

Receiver wakeup is not supported when C7816[ISO\_7816E] is set/enabled since multi-receiver systems are not allowed.

### 43.4.2.9.1 Idle input line wakeup (C1[WAKE] = 0)

In this wakeup method, an idle condition on the unsynchronized receiver input signal clears the C2[RWU] bit and wakes the UART. The initial frame or frames of every message contain addressing information. All receivers evaluate the addressing information, and receivers for which the message is addressed process the frames that follow. Any receiver for which a message is not addressed can set its C2[RWU] bit and return to the standby state. The C2[RWU] bit remains set and the receiver remains in standby until another idle character appears on the unsynchronized receiver input signal.

Idle line wakeup requires that messages be separated by at least one idle character and that no message contains idle characters.

When C2[RWU] is one and S2[RWUID] is zero, the idle character that wakes the receiver does not set the S1[IDLE] flag or the receive data register full flag, S1[RDRF]. The receiver wakes and waits for the first data character of the next message which will be stored in the receive data buffer. When S2[RWUID] and C2[RWU] bits are set and C1[WAKE] is cleared, any idle condition sets the S1[IDLE] flag and generates an interrupt if enabled.

Idle Input Line Wakeup is not supported when C7816[ISO\_7816E] is set/enabled.

## 43.4.2.9.2 Address mark wakeup (C1[WAKE] = 1)

In this wakeup method, a logic 1 in the bit position immediately preceding the stop bit of a frame clears the C2[RWU] bit and wakes the UART. A logic 1 in the bit position immediately preceding the stop bit marks a frame as an address frame that contains addressing information. All receivers evaluate the addressing information, and the receivers for which the message is addressed process the frames that follow. Any receiver for which a message is not addressed can set its C2[RWU] bit and return to the standby state. The C2[RWU] bit remains set and the receiver remains in standby until another address frame appears on the unsynchronized receiver input signal.

A logic 1 in the bit position immediately preceding the stop bit clears the receiver's C2[RWU] bit before the stop bit is received and places the received data into the receiver data buffer.

Address mark wakeup allows messages to contain idle characters but requires that the bit position immediately preceding the stop bit be reserved for use in address frames.

If module is in standby mode and nothing triggers to wake the UART, no error flag is set even if an invalid error condition is detected on the receiving data line.

Address mark wakeup is not supported when C7816[ISO\_7816E] is set/enabled.

### 43.4.2.9.3 Match address operation

Match address operation is enabled when the C4[MAEN1] or C4[MAEN2] bit is set. In this function, a frame received by the RX pin with a logic 1 in the bit position immediately preceding the stop bit is considered an address and is compared with the associated MA1 or MA2 register. The frame is only transferred to the receive buffer, and S1[RDRF] is set, if the comparison matches. All subsequent frames received with a logic 0 in the bit position immediately preceding the stop bit are considered to be data associated with the address and are transferred to the receive data buffer. If no marked address match occurs then no transfer is made to the receive data buffer, and all following frames with logic zero in the bit position immediately preceding the stop bit are also discarded. If both the C4[MAEN1] and C4[MAEN2] bits are negated, the receiver operates normally and all data received is transferred to the receive data buffer.

Match Address operation functions in the same way for both MA1 and MA2 registers.

- If only one of C4[MAEN1] and C4[MAEN2] is asserted, a marked address is compared only with the associated match register and data is transferred to the receive data buffer only on a match.
- If C4[MAEN1] and C4[MAEN2] are asserted, a marked address is compared with both match registers and data is transferred only on a match with either register.

Address match operation is not supported when C7816[ISO\_7816E] is set/enabled.

## 43.4.3 Baud rate generation

A 13-bit modulus counter and a 5-bit fractional fine-adjust counter in the baud rate generator derive the baud rate for both the receiver and the transmitter. The value from 1 to 8191 written to the SBR[12:0] bits determines the module clock divisor. The SBR bits are in the UART baud rate registers (BDH and BDL). The baud rate clock is synchronized with the module clock and drives the receiver. The fractional fine-adjust counter adds fractional delays to the baud rate clock to allow fine trimming of the baud rate to match the system baud rate. The baud rate clock divided by 16 drives the transmitter. The receiver has an acquisition rate of 16 samples per bit time.

Baud rate generation is subject to two sources of error:

- Integer division of the module clock may not give the exact target frequency. This error can be reduced by means of the fine-adjust counter.
- Synchronization with the module clock can cause phase shift.

The Table 43-101 lists the available baud divisor fine adjust values.

### UART baud rate = UART module clock / $(16 \times (SBR[12:0] + BRFD))$

The following table lists some examples of achieving target baud rates with a module clock frequency of 10.2 MHz, with and without fractional fine adjustment.

Table 43-101. Baud rates (example: module clock = 10.2 MHz)

| Bits<br>SBR<br>(decimal) | Bits<br>BRFA | BRFD value    | Receiver<br>clock (Hz) | Transmitter<br>clock (Hz) | Target Baud<br>rate | Error<br>(%) |
|--------------------------|--------------|---------------|------------------------|---------------------------|---------------------|--------------|
| 17                       | 00000        | 0             | 600,000.0              | 37,500.0                  | 38,400              | 2.3          |
| 16                       | 10011        | 19/32=0.59375 | 614,689.3              | 38,418.08                 | 38,400              | 0.047        |
| 33                       | 00000        | 0             | 309,090.9              | 19,318.2                  | 19,200              | 0.62         |
| 33                       | 00110        | 6/32=0.1875   | 307,344.6              | 19,209.04                 | 19,200              | 0.047        |
| 66                       | 00000        | 0             | 154,545.5              | 9659.1                    | 9600                | 0.62         |
| 133                      | 00000        | 0             | 76,691.7               | 4793.2                    | 4800                | 0.14         |
| 266                      | 00000        | 0             | 38,345.9               | 2396.6                    | 2400                | 0.14         |
| 531                      | 00000        | 0             | 19,209.0               | 1200.6                    | 1200                | 0.11         |
| 1062                     | 00000        | 0             | 9604.5                 | 600.3                     | 600                 | 0.05         |
| 2125                     | 00000        | 0             | 4800.0                 | 300.0                     | 300                 | 0.00         |
| 4250                     | 00000        | 0             | 2400.0                 | 150.0                     | 150                 | 0.00         |
| 5795                     | 00000        | 0             | 1760.1                 | 110.0                     | 110                 | 0.00         |

Table 43-102. Baud rate fine adjust

| BRFA      | Baud Rate Fractional Divisor (BRFD) |
|-----------|-------------------------------------|
| 00000     | 0/32 = 0                            |
| 0 0 0 0 1 | 1/32 = 0.03125                      |
| 00010     | 2/32 = 0.0625                       |
| 00011     | 3/32 = 0.09375                      |
| 00100     | 4/32 = 0.125                        |
| 0 0 1 0 1 | 5/32 = 0.15625                      |
| 00110     | 6/32 = 0.1875                       |
| 00111     | 7/32 = 0.21875                      |
| 01000     | 8/32 = 0.25                         |
| 0 1 0 0 1 | 9/32 = 0.28125                      |
| 01010     | 10/32 = 0.3125                      |
| 0 1 0 1 1 | 11/32 = 0.34375                     |
| 01100     | 12/32 = 0.375                       |

Table continues on the next page...

#### **Functional description**

Table 43-102. Baud rate fine adjust (continued)

| BRFA      | Baud Rate Fractional Divisor (BRFD) |
|-----------|-------------------------------------|
| 01101     | 13/32 = 0.40625                     |
| 01110     | 14/32 = 0.4375                      |
| 01111     | 15/32 = 0.46875                     |
| 10000     | 16/32 = 0.5                         |
| 1 0 0 0 1 | 17/32 = 0.53125                     |
| 10010     | 18/32 = 0.5625                      |
| 1 0 0 1 1 | 19/32 = 0.59375                     |
| 10100     | 20/32 = 0.625                       |
| 10101     | 21/32 = 0.65625                     |
| 10110     | 22/32 = 0.6875                      |
| 10111     | 23/32 = 0.71875                     |
| 1 1 0 0 0 | 24/32 = 0.75                        |
| 1 1 0 0 1 | 25/32 = 0.78125                     |
| 11010     | 26/32 = 0.8125                      |
| 1 1 0 1 1 | 27/32 = 0.84375                     |
| 1 1 1 0 0 | 28/32 = 0.875                       |
| 1 1 1 0 1 | 29/32 = 0.90625                     |
| 11110     | 30/32 = 0.9375                      |
| 11111     | 31/32 = 0.96875                     |

## 43.4.4 Data format (non ISO-7816)

Each data character is contained in a frame that includes a start bit and a stop bit. The rest of the data format depends upon UARTx\_C1[M], UARTx\_C1[PE], UARTx\_S2[MSBF], and UARTx\_C4[M10].

# 43.4.4.1 Eight-bit configuration

Clearing the UART\_C1[M] configures the UART for 8-bit data characters, that is, eight bits are memory mapped in UART\_D. A frame with eight data bits has a total of 10 bits. The most significant bit of the eight data bits can be used as an address mark to wake the receiver. If that bit is used in this way, then it serves as an address or data indication, leaving the remaining seven bits as actual data. When UART\_C1[PE] is set, the 8th databit is automatically calculated as the parity bit. Refer to the following table.

Table 43-103. Configuration of 8-bit data format

| HART CIDEL  | Start | Data | Address        | Parity | Stop |
|-------------|-------|------|----------------|--------|------|
| UART_C1[PE] | bit   | bits | bits           | bits   | bit  |
| 0           | 1     | 8    | 0              | 0      | 1    |
| 0           | 1     | 7    | 1 <sup>1</sup> | 0      | 1    |
| 1           | 1     | 7    | 0              | 1      | 1    |

<sup>1.</sup> The address bit identifies the frame as an address character. See Receiver wakeup.

# 43.4.4.2 Nine-bit configuration

When UARTx\_C1[M] is set and UARTx\_C4[M10] is cleared the UART is configured for 9-bit data characters. The 9th bit is either UARTx\_C3[T8/R8] or the internally generated parity bit if UARTx\_C1[PE] is enabled. This results in a frame consisting of a total of 11 bits. In the event that the 9th data bit is selected to be UARTx\_C3[T8] it will remain unchanged after transmission and can be used repeatedly without rewriting it unless the value needs to be changed. This feature may be useful when the 9th data bit is being used as an address mark.

When UARTx\_C1[M] is set and UARTx\_C4[M10] is set the UART is configured for 9-bit data characters, but the frame consists of a total of 12 bits. The 12 bits include the start and stop bits, the 9 data character bits and a 10th internal data bit. Note that if UARTx\_C4[M10] is set UARTx\_C1[PE] must also be set. In this case, the 10th bit is the internally generated parity bit. The 9th bit is can either be used as a address mark or a 9th data bit.

Refer to the following table.

Table 43-104. Configuration of 9-bit data formats

| C1[DE] | LIC1[M] | C1[M10]  | Start                 | Data                        | Address           | Parity | Stop |     |
|--------|---------|----------|-----------------------|-----------------------------|-------------------|--------|------|-----|
| C1[PE] | UC1[M]  | OC I [W] | C1[M10]               | bit                         | bits              | bits   | bits | bit |
| 0      | 0       | 0        |                       | See                         | Eight-bit configu | ration |      |     |
| 0      | 0       | 1        |                       | In                          | valid configurati | on     |      |     |
| 0      | 1       | 0        | 1                     | 9                           | 0                 | 0      | 1    |     |
| 0      | 1       | 0        | 1                     | 8                           | 1 <sup>1</sup>    | 0      | 1    |     |
| 0      | 1       | 1        |                       | Inv                         | valid Configurati | on     |      |     |
| 1      | 0       | 0        |                       | See Eight-bit configuration |                   |        |      |     |
| 1      | 0       | 1        | Invalid Configuration |                             |                   |        |      |     |
| 1      | 1       | 0        | 1                     | 8                           | 0                 | 1      | 1    |     |
| 1      | 1       | 1        | 1                     | 9                           | 0                 | 1      | 1    |     |
| 1      | 1       | 1        | 1                     | 8                           | 1 <sup>2</sup>    | 1      | 1    |     |

#### **Functional description**

- 1. The address bit identifies the frame as an address character.
- 2. The address bit identifies the frame as an address character.

#### **Note**

Unless in 9-bit mode with M10 set, do not use address mark wakeup with parity enabled.

# 43.4.4.3 Timing examples

Timing examples of these configurations in the NRZ mark/space data format are illustrated in the following figures. The timing examples show all of the configurations in the following sub-sections along with the LSB and MSB first variations.

## 43.4.4.3.1 Eight-bit format with parity disabled

The most significant bit can be used for address mark wakeup.



Figure 43-104. Eight bits of data with LSB first

Figure 43-105. Eight bits of data with MSB first

# 43.4.4.3.2 Eight-bit format with parity enabled

Figure 43-106. Seven bits of data with LSB first and parity

Figure 43-107. Seven bits of data with MSB first and parity

# 43.4.4.3.3 Nine-bit format with parity disabled

The most significant bit can be used for address mark wakeup.

Figure 43-108. Nine bits of data with LSB first

Figure 43-109. Nine bits of data with MSB first

#### 43.4.4.3.4 Nine-bit format with parity enabled

START BIT 0 BIT 1 BIT 2 BIT 3 BIT 4 BIT 5 BIT 6 BIT 7 PARITY STOP START

Figure 43-110. Eight bits of data with LSB first and parity

Figure 43-111. Eight bits of data with MSB first and parity

#### 43.4.4.3.5 Non-memory mapped tenth bit for parity

The most significant memory-mapped bit can be used for address mark wakeup.

Figure 43-112. Nine bits of data with LSB first and parity



Figure 43-113. Nine bits of data with MSB first and parity

# 43.4.5 Single-wire operation

Normally, the UART uses two pins for transmitting and receiving. In single-wire operation, the RXD pin is disconnected from the UART and the UART implements a half-duplex serial connection. The UART uses the TXD pin for both receiving and transmitting.



Figure 43-114. Single-wire operation (C1[LOOPS] = 1, C1[RSRC] = 1)

#### **Functional description**

Enable single-wire operation by setting the C1[LOOPS] bit and the receiver source bit, C1[RSRC]. Setting the C1[LOOPS] bit disables the path from the unsynchronized receiver input signal to the receiver. Setting the C1[RSRC] bit connects the receiver input to the output of the TXD pin driver. Both the transmitter and receiver must be enabled (C2[TE] = 1 and C2[RE] = 1). When C7816[ISO\_7816EN] is set, it is not a requirement that both C2[TE] and C2[RE] are set.

# 43.4.6 Loop operation

In loop operation the transmitter output goes to the receiver input. The unsynchronized receiver input signal is disconnected from the UART.



**Figure 43-115. Loop operation (C1[LOOPS] = 1, C1[RSRC] = 0)** 

Enable loop operation by setting the C1[LOOPS] bit and clearing the C1[RSRC] bit. Setting the C1[LOOPS] bit disables the path from the unsynchronized receiver input signal to the receiver. Clearing the C1[RSRC] bit connects the transmitter output to the receiver input. Both the transmitter and receiver must be enabled (C2[TE] = 1 and C2[RE] = 1). When C7816[ISO\_7816EN] is set, it is not a requirement that both C2[TE] and C2[RE] are set.

# 43.4.7 ISO-7816 / smartcard support

The UART provides mechanisms to support the ISO-7816 protocol that is commonly used to interface with smartcards. The ISO-7816 protocol is an NRZ, single wire, half-duplex interface. The TxD pin is used in open-drain mode since the data signal is used for both transmitting and receiving. There are multiple subprotocols within the ISO-7816 standard. The UART supports both T = 0 and T = 1 protocols. The module also provides for automated initial character detection and configuration which allows for support of both direct convention and inverse convention data formats. A variety of interrupts specific to 7816 are provided in addition to the general interrupts to assist software.

Additionally the module is able to provide automated NACK responses and has programing automated retransmission of failed packets. An assortment of programmable timeouts and guard band times are also supported.

The term elemental time unit (ETU) is frequently used in the context of ISO-7816. This concept is used to relate the frequency that the system (UART) is running at and the frequency that data is being transmitted and received. One ETU represents the time it takes to transmit or receive a single bit. For example, a standard 7816 packet, excluding any guard time or NACK elements is 10 ETUs (start bit, 8 data bits and a parity bit). Guard times and wait times are also measured in ETUs.

#### **NOTE**

The ISO-7816 specification may have certain configuration options that are reserved. In order to maintain maximum flexibility to support future 7816 enhancements or devices which may not strictly conform to the specification, the UART does not prevent those options being used. Further, the UART may provide configuration options that exceed the flexibility of options explicitly allowed by the 7816 specification. Failure to correctly configure the UART may result in unexpected behavior or incompatibility with the ISO-7816 specification.

#### 43.4.7.1 Initial characters

In ISO-7816 mode, the UART can be configured to use the C7816[INIT] bit to detect the next valid initial character, referred to by the ISO-7816 specifically as a TS character. When the initial character is detected, the UART provides the host processor with an interrupt if IE7816[INITDE] is set. Additionally, the UART will set the S2[MSBF], C3[TXINV] and S2[RXINV] register fields automatically based on the initial character. The corresponding initial character and resulting register settings are listed in the following table.

| Initial character (bit 1-10) | Initial character (hex) | MSBF | TXINV | RXINV |
|------------------------------|-------------------------|------|-------|-------|
| LHHL LLL LLH                 | 3F                      | 1    | 1     | 1     |
| inverse convention           |                         |      |       |       |
| LHHL HHH LLH                 | 3B                      | 0    | 0     | 0     |
| direct convention            |                         |      |       |       |

Table 43-105. Initial character automated settings

#### **Functional description**

When the C7816[INIT] bit is set, the receiver will search all received data for the first valid initial character. All data received which is not a valid initial character will be ignored and all flags resulting from the invalid data will be blocked from asserting. If the C7816[ANACK] bit is set, a NACK will be returned for invalid received initial characters and a RXT interrupt will be generated as programmed.

#### 43.4.7.2 Protocol T = 0

When T = 0 protocol is selected, a relatively complex error detection scheme is used. Data characters are formatted as illustrated in the following figure. This scheme is also used for answer to reset and PPS formats.



Figure 43-116. ISO-7816 T = 0 data format

As with other protocols supported by the UART the data character includes a start bit. However, in this case there are two stop bits rather than the typical single stop bit. In addition to a standard even parity check, the receiver has the ability to generate and return a NACK during the second half of the first stop bit period. The NACK must be at least one time period (ETU) in length and no more than 2 time periods (ETU) in length. The transmitter must wait for at least two time units (ETU) after detection of the error signal before attempting to retransmit the character.

It is assumed that the UART and the device (smartcard) know in advance which device is receiving and which is transmitting. No special mechanism is supplied by the UART to control receive and transmit in the mode other than the C2[TE] and C2[RE] bits.

## 43.4.7.3 Protocol T = 1

When T = 1 protocol is selected the NACK error detection scheme is not used. Rather, the parity bit is used on a character basis and a CRC or LRC is used on the block basis (i.e. each group of characters). As such, in this mode the data format allows for a single stop bit although additional inactive bit periods may be present between the stop bit and the next start bit. Data characters are formatted as illustrated in the following figure.

Figure 43-117. ISO 7816 T=1 data format

The smallest data unit that is transferred is a block. A block is made up of several data characters and may vary in size depending on the block type. The UART does not provide a mechanism to decode the block type. As part of the block, an LRC or CRC is included. The UART does not calculate the CRC or LRC for transmitted blocks nor does it verify the validity of the CRC or LRC for received blocks. The 7816 protocol requires that the initiator and the smartcard (device) takes alternate turns in transmitting and receiving blocks. When the UART detects that the last character in a block has been transmitted it will automatically clear the C2[TE] bit and enter receive mode. Hence, software must program the transmit buffer with the next data to be transmitted and then enable the C2[TE] bit once software has determined that the last character of the received block has been received. The UART detects that the last character of the transmit block has been sent when TL7816[TLEN] = 0 and four additional characters have been sent. The four additional characters are made up of three prior to TL7816[TLEN] decrementing (prologue) and one after TL7816[TLEN] = 0, the final character of the epilogue.

# 43.4.7.4 Wait time and guard time parameters

The ISO-7816 specification defines several wait time and guard time parameters. The UART allows for flexible configuration and violation detection of these settings. On reset the wait time (IS7816[WT]) defaults to 9600 ETUs and guard time (GT) to 12 ETUs. These values are controlled by parameters in the WP7816, WN7816 and WF7816 registers. Additionally the value of C7816[TTYPE] also factors into the calculation. The formulas used to calculate the number ETU for each wait time and guard time value are shown in the following table.

Wait time (WT) is defined as the maximum allowable time between the leading edge of a character transmitted by the device (smartcard) and the leading edge of the previous character that was transmitted by the UART or the device. Likewise character wait time (CWT) is defined as the maximum allowable time between the leading edge of two characters within the same block, and block wait time (BWT) is defined as the maximum time between the leading edge character of the last block received by the device/smartcard.

Guard time (GT) is defined as the minimum allowable time between the leading edge of two consecutive characters. Character guard time (CGT) is the minimum allowable time between the leading edges of two consecutive characters in the same direction

#### **Functional description**

(transmission or reception). Block guard time (BGT) is the minimum allowable time between the leading edges of two consecutive characters in opposite directions (transmission then reception or reception then transmission).

The GT and WT counters reset whenever C7816[TTYPE] = 1 or C7816[ISO\_7816E] = 0 or a new dataword start bit has been received or transmitted as specified by the counter descriptions. The CWT, CGT, BWT, BGT counters reset whenever C7816[TTYPE] = 0 or C7816[ISO\_7816E] = 0 or a new dataword start bit has been received or transmitted as specified by the counter descriptions. When C7816[TTYPE] = 1 some of the counter values require an assumption regarding the first data transferred when the UART first starts. This assumption is required when the 7816E has been disabled, when transition from C7816[TTYPE] = 0 to C7816[TTYPE] = 1 or when coming out of reset. In this case, it is assumed that the previous (non-existent) transfer was a received transfer.

The UART will automatically handle GT, CGT and BGT such that the UART will not send a packet prior to the corresponding guard time expiring.

| Parameter                  | Reset value | C7816[TTYPE] = 0     | C7816[TTYPE] = 1                   |
|----------------------------|-------------|----------------------|------------------------------------|
| Parameter                  | [ETU]       | [ETU]                | [ETU]                              |
| Wait time (WT)             | 9600        | WI × 960 × GTFD      | Not used                           |
| Character wait time (CWT)  | Not used    | Not used             | 11 + 2 <sup>CWI</sup>              |
| Block wait time (BWT)      | Not used    | Not used             | 11 + 2 <sup>BWI</sup> × 960 × GTFD |
| Guard time (GT)            | 12          | GTN not wqual to 255 | Not used                           |
|                            |             | 12 + GTN             |                                    |
|                            |             | GTN wqual to 255     |                                    |
|                            |             | 12                   |                                    |
| Character guard time (CGT) | Not used    | Not used             | GTN not equal to 255               |
|                            |             |                      | 12 + GTN                           |
|                            |             |                      | GTN equal to 255                   |
|                            |             |                      | 11                                 |
| Block guard time (BGT)     | Not used    | Not used             | 22                                 |

Table 43-106. Wait and guard time calculations

# 43.4.7.5 Baud rate generation

The value in WF7816[GTFD] does not impact the clock frequency. The SBR and BRFD are used to generate the clock frequency. This clock frequency is used by the UART only and is not seen by the device (smartcard). The transmitter clocks operates at 1/16 the frequency of the receive clock so that the receiver is able to sample the received value 16 times during the ETU.

# 43.4.7.6 UART restrictions in ISO-7816 operation

Due to the flexibility of the UART module, there are several features and interrupts that are not supported while running in ISO-7816 mode. These restrictions are documented within the register bit definitions.

## 43.5 Reset

All registers reset to a particular value are indicated in Memory map and register definition.

# 43.6 System level interrupt sources

There are several interrupt signals that are sent from the UART. The following table lists the interrupt sources generated by the UART. The local enables for the UART interrupt sources are described in this table. Details regarding the individual operation of each interrupt are contained under various sub-sections of Register Descriptions. However, RXEDGIF description also outlines additional details regarding the RXEDGIF interrupt because of its complexity of operation. Any of the UART interrupt requests listed in the table can be used to bring the CPU out of wait mode.

Table 43-107. UART interrupt sources

| Interrupt Source | Flag    | Local enable | DMA select |
|------------------|---------|--------------|------------|
| Transmitter      | TDRE    | TIE          | TDMAS = 0  |
| Transmitter      | TC      | TCIE         | -          |
| Receiver         | IDLE    | ILIE         |            |
| Receiver         | RDRF    | RIE          | RDMAS = 0  |
| Receiver         | LBKDIF  | LBKDIE       | -          |
| Receiver         | RXEDGIF | RXEDGIE      | -          |
| Receiver         | OR      | ORIE         | -          |
| Receiver         | NF      | NEIE         | -          |
| Receiver         | FE      | FEIE         | -          |
| Receiver         | PF      | PEIE         | -          |
| Receiver         | RXUF    | RXUFE        | -          |
| Transmitter      | TXOF    | TXOFE        | -          |
| Receiver         | WT      | WTWE         | -          |

Table continues on the next page...

#### System level interrupt sources

Table 43-107. UART interrupt sources (continued)

| Interrupt Source | Flag  | Local enable | DMA select |
|------------------|-------|--------------|------------|
| Receiver         | CWT   | CWTE         | -          |
| Receiver         | BWT   | BWTE         | -          |
| Receiver         | INITD | INITDE       | -          |
| Receiver         | TXT   | TXTE         | -          |
| Receiver         | RXT   | RXTE         | -          |
| Receiver         | GTV   | GTVE         | -          |

# 43.6.1 RXEDGIF description

The S2[RXEDGIF] is set when an active edge is detected on the RxD pin. Hence, the active edge can only be detected when in two wire mode. A RXEDGIF interrupt is only generated when S2[RXEDGIF] is set. If RXEDGIE is not enabled prior to S2[RXEDGIF] getting set, an interrupt is not generated until S2[RXEDGIF] bit gets set.

# 43.6.1.1 RxD edge detect sensitivity

Edge sensitivity can be software programmed to be either falling or rising. The polarity of the edge sensitivity is selected using the S2[RXINV] bit. To detect falling edge S2[RXINV] is programmed to zero and to detect rising edge S2[RXINV] is programmed to one.

Synchronizing logic is used prior to detect edges. Prior to detecting an edge, the receive data on RxD input must be at the de-asserted logic level. A falling edge is detected when the RxD input signal is seen as a logic 1 (the deasserted level) during one module clock cycle and then a logic 0 (the asserted level) during the next cycle. A rising edge is detected when the input is seen as a logic 0 during one module clock cycle and then a logic 1 during the next cycle.

# 43.6.1.2 Clearing RXEDGIF interrupt request

Writing a logic 1 to the S2[RXEDGIF] bit immediately clears the RXEDGIF interrupt request even if the RxD input remains asserted. S2[RXEDGIF] will remain set if another active edge is detected on RxD while attempting to clear the S2[RXEDGIF] flag by writing a 1 to it.

# 43.6.1.3 Exit from low-power modes

The receive input active edge detect circuit is still active on low power modes (wait and stop). An active edge on the receive input brings the CPU out of low power mode if the interrupt is not masked (S2[RXEDGIF]=1).

# 43.7 DMA operation

In the transmitter, flags S1[TDRE] can be configured to assert a DMA transfer request. In the receiver, flag S1[RDRF] can be configured to assert a DMA transfer request. The following table shows the configuration bit settings required to configure each flag for DMA operation.

 Flag
 Request enable bit
 DMA select bit

 TDRE
 TIE = 1
 TDMAS = 1

 RDRF
 RIE = 1
 RDMAS = 1

Table 43-108. DMA configuration

When a flag is configured for a DMA request, its associated DMA request is asserted when the flag is set. When the S1[RDRF] flag is configured as a DMA request, the clearing mechanism of reading S1 register followed by reading D register does not clear the associated flag. The DMA request remains asserted until an indication is received that the DMA transactions are done. When this indication is received, the flag bit and the associated DMA request are cleared. If the DMA operation failed to remove the situation that caused the DMA request another request will be issued.

# 43.8 Application information

This section describes the UART application information.

# 43.8.1 Transmit/receive data buffer operation

The UART has independent receive and transmit buffers. The size of these buffers may vary depending on the implementation of the module. The implemented size of the buffers is a fixed constant via the PFIFO[TXFIFOSIZE] and PFIFO[RXFIFOSIZE] fields. Additionally, legacy support is provided that allows for the FIFO structure to

#### **Application information**

operate as a depth of one. This is the default/reset behavior of the module and can be adjusted using the PFIFO[RXFE] and PFIFO[TXFE] bits. Individual watermark levels are also provided for transmit and receive.

There are multiple ways to ensure that a data block (set of characters) has completed transmission. These methods include:

- 1. Set TXFIFO[TXWATER] to 0. The TDRE flag will assert when there is no further data in the transmit buffer. Alternatively the S1[TC] flag can be used to indicate when the transmit shift register is also empty.
- 2. Poll the TCFIFO[TXCOUNT] field. Assuming that only data for a data block has been put into the data buffer, when TCFIFO[TXCOUNT] = 0 all data has been transmitted or is in the process of transmission.
- 3. The S1[TC] flag can be monitored. When S1[TC] asserts it indicates that all data has been transmitted and there is no data currently being transmitted in the shift register.

# 43.8.2 ISO-7816 initialization sequence

This section outlines how to program the UART for ISO-7816 operation. Elements such as procedures to power up or power down the smartcard, and when to take those actions, are beyond the scope of this description. To setup the UART for ISO-7816 operation:

- 1. Select a baud rate. Write this value to the UART baud registers (BDH/L) to begin the baud rate generator. Remember that the baud rate generator is disabled when the baud rate is zero. Writing to the BDH has no effect without also writing to BDL. According to the 7816 specification the initial (default) baud rating setting should be Fi = 372 and Di = 1 and a maximum frequency of 5 MHz. In other words the BDH, BDL and C4 registers should be programmed such that the transmission frequency should be 1/372th of the clock provided to the smartcard device and should not exceed 5 MHz.
- 2. Write to set BDH[LBKDIE] = 0.
- 3. Write to C1 to configure word length, parity, and other configuration bits (LOOPS, RSRC) and set C1[M] = 1, C1[PE] = 1, C1[PT] = 0.
- 4. Write to set S2[RWUID] = 0, S2[LBKDE] = 0.
- 5. Write to set MODEM[RXRTSE] = 0, MODEM[TXRTSPOL] = 0, MODEM[TXRTSE] = 0, and MODEM[TXCTSE] = 0.

- 6. Write to set up interrupt enable bits desired (C3[ORIE], C3[NEIE], C3[PEIE], and C3[FEIE])
- 7. Write to set C4[MAEN1] = 0 and C4[MAEN2] = 0.
- 8. Write to C5 register and configure DMA control register bits as desired for application.
- 9. Write to set C7816[INIT] = 1,C7816[ TTYPE] = 0, 7C7816[ISO\_7816E] = 1. Program C7816[ONACK] and C7816[ANACK] as desired.
- 10. Write to IE7816 register to set interrupt enable parameters as desired.
- 11. Write to ET7816 register and set as desired.
- 12. Write to set C2[ILIE] = 0, C2[RE] = 1, C2[TE] = 1, C2[RWU] = 0 and C2[SBK] = 0. Setup interrupt enables C2[TIE], C2[TCIE] and C2[RIE] as desired.

At this time the UART will start listening for an initial character. Once identified it will automatically adjust the S2[MSBF], C3[TXINV] and S2[RXINV] bits. The software should then receive and process an answer to reset. Upon processing the answer to reset software should write to set C2[RE] = 0 and C2[TE] = 0. Software should then adjust 7816 specific and UART generic parameters to match and configuration data that was received during the answer on reset period. Once the new settings have been programmed (including the new baud rate and C7816[TTYPE]) the C2[RE] and C2[TE] can be reenabled as required.

# 43.8.2.1 Transmission procedure for (C7816[TTYPE] = 0)

When the protocol selected is C7816[TTYPE] = 0, it is assumed that the software has a prior knowledge of who should be transmitting and receiving. Hence, no mechanism is provided for automated transmission/receipt control. Software should monitor the S1[TDRE] flag (or configure for an interrupt) and provide additional data for transmission as appropriate. Additionally, software should set C2[TE] = 1 and control TXDIR whenever it is the UART's turn to transmit information. For ease of monitoring it is suggested that only data to be transmitted until the next receiver/transmit switch over be loaded into the transmit buffer/FIFO.

# 43.8.2.2 Transmission procedure for (C7816[TTYPE] = 1)

When the protocol selected is C7816[TTYPE] = 1, data is transferred in blocks. Prior to starting a transmission software should write the size (number of bytes) for the Information Field portion of the block in to the TLEN register. If a CRC is being transmitted for the block the value in TLEN should be one more than the size of the information field. Software should then set C2[TE] = 1, and C2[RE] = 1. Software should then monitor the S1[TDRE] flag / interrupt and write the prologue, Information and epilogue field to the transmit buffer. The TLEN register will automatically decrement (except for prologue bytes and the final epilogue byte). When the final epilogue byte has been transmitted the UART automatically clears the C2[TE] bit to 0, and the UART automatically starts capturing the response to the block that was transmitted. Once software has detected the receipt of the response, the transmission process should be repeated as needed with sufficient urgency to ensure that the block wait time and character wait times are not violated.

# 43.8.3 Initialization sequence (non ISO-7816)

To initiate an UART transmission:

- 1. Configure the UART:
  - a. Select a baud rate. Write this value to the UART baud registers (BDH/L) to begin the baud rate generator. Remember that the baud rate generator is disabled when the baud rate is zero. Writing to the BDH register has no effect without also writing to BDL register.
  - b. Write to C1 register to configure word length, parity, and other configuration bits (LOOPS, RSRC, M, WAKE, ILT, PE, PT). Write to C4, MA1 and MA2 register to configure.
  - c. Enable the transmitter, interrupts, receiver, and wakeup as required by writing to the C2 register bits (TIE, TCIE, RIE, ILIE, TE, RE, RWU, SBK), S2 register bits (MSBF, BRK13) and C3 register bits (ORIE, NEIE, PEIE, FEIE). A preamble or idle character is then shifted out of the transmitter shift register.
- 2. Transmit procedure for each byte:
  - a. Monitor the S1[TDRE] flag by reading the S1 or responding to the TDRE interrupt. Or monitor the amount of free space in the transmit buffer directly using TCFIFO[TXCOUNT].

- b. If the TDRE flag is set, or there is space in the transmit buffer, write the data to be transmitted to (C3[T8]/D). A new transmission will not result until data exists in the transmit buffer.
- 3. Repeat step 2 for each subsequent transmission.

#### **Note**

During normal operation, the S1[TDRE] flag is set when the shift register is loaded with the next data to be transmitted from the transmit buffer and the number of datawords contained in the transmit buffer is less than or equal to the value in TWFIFO[TXWATER], which occurs 9/16ths of a bit time after the start of the stop bit of the previous frame.

To separate messages with preambles with minimum idle line time, use this sequence between messages:

- 1. Write the last dataword of the first message to C3[T8]/D.
- 2. Wait for the S1[TDRE] flag to go high (with TWFIFO[TXWATER] = 0), indicating the transfer of the last frame to the transmit shift register.
- 3. Queue a preamble by clearing and then setting the C2[TE] bit.
- 4. Write the first (and subsequent) datawords of the second message to C3[T8]/D.

# 43.8.4 Overrun (OR) flag implications

To be flexible the overrun flag (OR) operates slight differently depending on the mode of operation. As such there may be implications that need to be carefully considered. This section clarifies that behavior and the resulting implications. Regardless of mode, if a dataword is received while the S1[OR] flag is set, the S1[RDRF] and S1[IDLE] flags are blocked from asserting. If the S1[RDRF] or S1[IDLE] flag were previously asserted they will remain asserted until cleared.

#### **Application information**

# 43.8.4.1 Overrun operation

The assertion of the S1[OR] flag indicates that a significant event has occurred. The assertion indicates that received data has been lost since there was a lack of room to store it in the data buffer. Hence, while the S1[OR] flag is set no further data will be stored in the data buffer until the S1[OR] flag is cleared. This ensures that the application will be able to handle the overrun condition.

In most applications since the total amount of lost data is known, the application will desire to return the system to a known state. Prior to the S1[OR] flag being cleared all received data will be dropped. To do this the software would:

- 1. Remove data from the receive data buffer. This could be done by reading data from the data buffer and processing it if the data in the FIFO was still valuable when though the overrun event occurred or using the CFIFO[RXFLUSH] bit to clear the buffer.
- 2. Clear the S1[OR] flag. Note that if data was cleared using the CFIFO[RXFLUSH] bit, then clearing the S1[OR] flag will result in the SFIFO[RXUF] flag asserting because the only way to clear the S1[OR] requires reading additional information from the FIFO. Care should be taken to disable the SFIFO[RXUF] interrupt prior to clearing the OR flag and then clearing the SFIFO[RXUF] flag after the OR flag has been cleared.

Note that in some applications if an overrun event is responded to fast enough, the lost data can be recovered. For example when C7816[ISO\_7816E] is asserted, C7816[TTYPE]=1 and C7816[ONACK] = 1 the application may reasonably be able to determine if the lost data will be resent by the device. In this scenario flushing the receiver data buffer might not be required. Rather, if the S1[OR] flag is cleared the lost data may be resent and hence recoverable.

When LIN break detect (LBKDE) is asserted the S1[OR] flag has significantly different behavior than in other modes. The S1[OR] bit will be set, regardless of how much space is actually available in the data buffer, if a LIN break character has been detected and the corresponding flag (S2[LBKDIF]) is not cleared before the first data character is received after the S2[LBKDIF] asserted. This behavior is intended to allow software sufficient time to read the LIN break character from the data buffer to ensure that a break character was actually detected. The checking of the break character was used on some older implementations and is hence supported for legacy reasons. Applications that do not require this checking can simply clear the S2[LBKDIF] without checking the stored value to ensure it is a break character.

## 43.8.5 Overrun NACK considerations

When C7816[ISO\_7816E] is enabled and C7816[TTYPE] = 0 the retransmission feature of the 7816 protocol can be used to help avoid lost data when the data buffer overflows. Using C7816[ONACK] the module can be programmed to issue a NACK on an overflow event. Assuming that the device (smartcard) has implemented retransmission, the lost data will be retransmitted. While useful, there is a programming implication which may require special consideration. The need to transmit a NACK must be determined and committed to prior to the dataword being fully received. While the NACK is being received it is possible that the application code will read the data buffer such that sufficient room will be made to store the dataword that is being NACKed. Even if room has been made in the data buffer once the transmission of a NACK is completed, the received data will always be discarded as a result of an overflow and the ET7816[RXTHRESHOLD] value will be incremented by one. However, if sufficient space now exists to write the received data which was NACK'ed the S1[OR] flag will be blocked and kept from asserting.

# 43.8.6 Match address registers

The two match address registers allow a second match address function for a broadcast or general call address to the serial bus, as an example.

# 43.8.7 Modem feature

This section describes the modem features.

# 43.8.7.1 Ready-to-receive using RTS

To help to stop overrun of the receiver data buffer, the  $\overline{RTS}$  signal can be used by the receiver to indicate to another UART that it is ready to receive data. The other UART can send the data when its  $\overline{CTS}$  signal is asserted. This handshaking conforms to the TIA-232-E standard. A transceiver is necessary if the required voltage levels of the communication link do not match the voltage levels of the UART's  $\overline{RTS}$  and  $\overline{CTS}$  signals.

#### **Application information**



Figure 43-118. Ready-to-receive

The transmitter's  $\overline{CTS}$  signal can be used for hardware flow control whether its  $\overline{RTS}$  signal is used for hardware flow control, transceiver driver enable, or not at all.

# 43.8.7.2 Transceiver driver enable using RTS

RS-485 is a multiple drop communication protocol in which the UART transceiver's driver is 3-stated unless that UART is driving. The  $\overline{RTS}$  signal can be used by the transmitter to enable the driver of a transceiver. The polarity of  $\overline{RTS}$  can be matched to the polarity of the transceiver's driver enable signal. Refer to the following figure.



Figure 43-119. Transceiver driver enable using RTS

In the figure, the receiver enable signal is asserted. Another option for that connection is to connect RTS\_B to both DE and RE\_B. The transceiver's receiver is disabled while driving. A pullup can pull RXD to a non-floating value during this time. This option can be refined further by operating the UART in single-wire mode, freeing the RXD pin for other uses.

# 43.8.8 Clearing 7816 wait timer (WT, BWT, CWT) interrupts

The 7816 wait timer interrupts associated with IS7816[WT], IS7816[BWT] and IS7816[CWT] will automatically reassert if they are cleared and the wait time is still violated. This behavior is similar to most of the other interrupts on the UART as in most cases if the condition that caused the interrupt to trigger still exists when the interrupt is cleared, than the interrupt will reassert. For example, consider the following scenario:

- 1. IS7816[WT] is programmed to assert after 9600 cycles of unresponsiveness.
- 2. The 9600 cycles pass without a response resulting in the WT interrupt asserting.
- 3. The IS7816[WT] is cleared at cycle 9700 by the interrupt service routine.
- 4. After the WT interrupt has been cleared, the smartcard remains unresponsive. At cycle 9701 the WT interrupt will reasserted.

If the intent of clearing the interrupt is such that it does not reassert, the interrupt service routine must remove or clear the condition that originally caused the interrupt to assert prior to clearing the interrupt. There are multiple ways that this can be accomplished including ensuring that an event that results in the wait timer resetting occurs such as the transmission of another packet.

# 43.8.9 Legacy and reverse compatibility considerations

Recent versions of the UART have added several new features. Whenever reasonably possible reverse compatibility was maintained, however, in some cases this was either not feasible or the behavior was deemed as not intended. This section describes several differences to legacy operation that resulted from these recent enhancements. If application codes from previous versions is used, they should be reviewed and modified to take the following items into account. Depending on the application code, additional items that are not listed here may also need to be considered.

- 1. Various reserved registers and register bits were used (i.e. MSFB and M10).
- 2. This module now generates an error when invalid address spaces are used.
- 3. While documentation indicated otherwise, in some cases it was possible for S1[IDLE] to assert even if S1[OR] was set.
- 4. The S1[OR] flag will only be set if the data buffer (FIFO) does not have sufficient room. Previously, the data buffer was always a fixed size of one and the S1[OR] flag would set so long as the S1[RDRF] flag was set even if there was room in the data buffer. While the clearing mechanism is has remained the save for the S1[RDRF] flag, keeping the OR flag assertion tied to the RDRF event rather than the data buffer being full would have greatly reduced the usefulness of the buffer when its size is larger than one.
- 5. Previously when the C2[RWU] was set (and WAKE = 0), the IDLE flag could reassert up to every bit period causing an interrupt and requiring the host processor to reassert the C2[RWU] bit. This behavior has been modified. Now, when the C2[RWU] is set (and WAKE = 0) at least one non-idle bit must be detected before an idle can be detected.

**Application information** 

# **Chapter 44 Integrated Interchip Sound (I2S) / Synchronous Audio Interface (SAI)**

## 44.1 Introduction

The I<sup>2</sup>S (or I2S) module provides a Synchronous Audio Interface (SAI) that supports full-duplex serial interfaces with frame synchronization such as I<sup>2</sup>S, AC97, and CODEC/DSP interfaces.

#### 44.1.1 Features

- Transmitter with independent Bit Clock and Frame Sync supporting 1 data channel
- Receiver with independent Bit Clock and Frame Sync supporting 1 data channel
- Maximum Frame Size of 16 Words
- Word size of between 8-bits and 32-bits Word size configured separately for first word and remaining words in frame
- Asynchronous 4 × 32-bit FIFO for each Transmit and Receive Channel
- Graceful restart after FIFO Error

# 44.1.2 Modes of Operation

The SAI operating modes include run mode, stop modes, low-leakage modes, and debug mode.

#### 44.1.2.1 Run Mode

In run mode, the SAI Transmitter and Receiver operate normally.

# 44.1.2.2 Stop Modes

In Stop Mode, the SAI Transmitter and/or Receiver can continue operating provided the Stop Enable bit is set, and provided it is using an externally generated Bit Clock or an Audio Master Clock that remains operating in Stop mode. The SAI Transmitter and/or Receiver can generate an asynchronous interrupt to wakeup the CPU from Stop mode.

In Stop Mode, if the Transmitter Stop Enable bit is clear, the Transmitter is disabled after completing the current transmit frame, and if the Receiver Stop Enable bit is clear, the Receiver is disabled after completing the current receive frame.

# 44.1.2.3 Low-Leakage Modes

When entering low leakage modes, the Stop Enable bits are ignored and the SAI is disabled after completing the current Transmit and Receive Frames.

# 44.1.2.4 Debug Mode

In Debug Mode, the SAI Transmitter and/or Receiver can continue operating provided the Debug Enable bit is set. When the Transmitter or Receiver Debug Enable bit is clear and Debug mode is entered, the SAI is disabled after completing the current Transmit or Receive Frame. The Transmitter and Receiver bit clocks are not affected by debug mode.

# 44.2 External signals

| Name        | Function            | I/O | Reset | Pull |
|-------------|---------------------|-----|-------|------|
| SAI_TX_BCLK | Transmit Bit Clock  | I/O | 0     | _    |
| SAI_TX_SYNC | Transmit Frame Sync | I/O | 0     | _    |
| SAI_TX_DATA | Transmit Data       | 0   | 0     | _    |
| SAI_RX_BCLK | Receive Bit Clock   | I/O | 0     | _    |
| SAI_RX_SYNC | Receive Frame Sync  | I/O | 0     | _    |
| SAI_RX_DATA | Receive Data        | I   | 0     | _    |
| SAI_MCLK    | Audio Master Clock  | I/O | 0     | _    |

# 44.3 Memory Map and Registers

## **I2S** memory map

| Absolute<br>address<br>(hex) | Register name                                     | Width<br>(in bits) | Access                         | Reset value | Section/<br>page |
|------------------------------|---------------------------------------------------|--------------------|--------------------------------|-------------|------------------|
| FFFF_8200                    | SAI Transmit Control Register (I2S0_TCSR)         | 32                 | R/W                            | 0000_0000h  | 44.3.1/<br>1140  |
| FFFF_8204                    | SAI Transmit Configuration 1 Register (I2S0_TCR1) | 32                 | R/W                            | 0000_0000h  | 44.3.2/<br>1143  |
| FFFF_8208                    | SAI Transmit Configuration 2 Register (I2S0_TCR2) | 32                 | R/W                            | 0000_0000h  | 44.3.3/<br>1144  |
| FFFF_820C                    | SAI Transmit Configuration 3 Register (I2S0_TCR3) | 32                 | R/W                            | 0000_0000h  | 44.3.4/<br>1145  |
| FFFF_8210                    | SAI Transmit Configuration 4 Register (I2S0_TCR4) | 32                 | R/W                            | 0000_0000h  | 44.3.5/<br>1146  |
| FFFF_8214                    | SAI Transmit Configuration 5 Register (I2S0_TCR5) | 32                 | R/W                            | 0000_0000h  | 44.3.6/<br>1147  |
| FFFF_8220                    | SAI Transmit Data Register (I2S0_TDR)             | 32                 | W<br>(always<br>reads<br>zero) | 0000_0000h  | 44.3.7/<br>1148  |
| FFFF_8240                    | SAI Transmit FIFO Register (I2S0_TFR)             | 32                 | R                              | 0000_0000h  | 44.3.8/<br>1148  |
| FFFF_8260                    | SAI Transmit Mask Register (I2S0_TMR)             | 32                 | R/W                            | 0000_0000h  | 44.3.9/<br>1149  |
| FFFF_8280                    | SAI Receive Control Register (I2S0_RCSR)          | 32                 | R/W                            | 0000_0000h  | 44.3.10/<br>1150 |
| FFFF_8284                    | SAI Receive Configuration 1 Register (I2S0_RCR1)  | 32                 | R/W                            | 0000_0000h  | 44.3.11/<br>1153 |
| FFFF_8288                    | SAI Receive Configuration 2 Register (I2S0_RCR2)  | 32                 | R/W                            | 0000_0000h  | 44.3.12/<br>1153 |
| FFFF_828C                    | SAI Receive Configuration 3 Register (I2S0_RCR3)  | 32                 | R/W                            | 0000_0000h  | 44.3.13/<br>1154 |
| FFFF_8290                    | SAI Receive Configuration 4 Register (I2S0_RCR4)  | 32                 | R/W                            | 0000_0000h  | 44.3.14/<br>1155 |
| FFFF_8294                    | SAI Receive Configuration 5 Register (I2S0_RCR5)  | 32                 | R/W                            | 0000_0000h  | 44.3.15/<br>1156 |
| FFFF_82A0                    | SAI Receive Data Register (I2S0_RDR)              | 32                 | R                              | 0000_0000h  | 44.3.16/<br>1157 |
| FFFF_82C0                    | SAI Receive FIFO Register (I2S0_RFR)              | 32                 | R                              | 0000_0000h  | 44.3.17/<br>1158 |

Table continues on the next page...

#### **Memory Map and Registers**

# I2S memory map (continued)

| Absolute address (hex) | Register name                        | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|------------------------|--------------------------------------|--------------------|--------|-------------|------------------|
| FFFF_82E0              | SAI Receive Mask Register (I2S0_RMR) | 32                 | R/W    | 0000_0000h  | 44.3.18/<br>1158 |
| FFFF_8300              | SAI MCLK Control Register (I2S0_MCR) | 32                 | R/W    | 0000_0000h  | 44.3.19/<br>1159 |
| FFFF_8304              | MCLK Divide Register (I2S0_MDR)      | 32                 | R/W    | 0000_0000h  | 44.3.20/<br>1160 |

# 44.3.1 SAI Transmit Control Register (I2Sx\_TCSR)

Addresses: I2S0\_TCSR is FFFF\_8200h base + 0h offset = FFFF\_8200h



# I2Sx\_TCSR field descriptions

| Field       | Description                                                                                                                       |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31<br>TE    | Transmitter enable  Enables/disables the transmitter. When software clears this bit, the transmitter remains enabled (and this    |
|             | bit remains set) until the end of the current frame.                                                                              |
|             | 0 Transmitter is disabled.                                                                                                        |
|             | 1 Transmitter is enabled, or transmitter has been disabled and not end of frame.                                                  |
| 30<br>STOPE | Stop enable                                                                                                                       |
| 3,3,2       | Configures transmitter operation in Stop mode. This bit is ignored and the transmitter is disabled in all low-leakage stop modes. |
|             | 0 Transmitter disabled in stop mode.                                                                                              |
|             | 1 Transmitter enabled in stop mode.                                                                                               |
| 29<br>DBGE  | Debug enable                                                                                                                      |

Table continues on the next page...

#### Chapter 44 Integrated Interchip Sound (I2S) / Synchronous Audio Interface (SAI)

## I2Sx\_TCSR field descriptions (continued)

| Field             | Description                                                                                                                                                                                                                                                                  |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                   | Enables/disables transmitter operation in debug mode. The transmit bit clock is not affected by debug mode.                                                                                                                                                                  |
|                   | <ul> <li>Transmitter is disabled in debug mode, after completing the current frame.</li> <li>Transmitter is enabled in debug mode.</li> </ul>                                                                                                                                |
| 28<br>BCE         | Bit Clock Enable                                                                                                                                                                                                                                                             |
|                   | Enables the transmit bit clock, separately from the transmit enable. This bit is automatically set whenever the transmit enable is set. When software clears this bit, the transmit bit clock remains enabled (and this bit remains set) until the end of the current frame. |
|                   | <ul><li>0 Transmit bit clock is disabled</li><li>1 Transmit bit clock is enabled</li></ul>                                                                                                                                                                                   |
| 27–26<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                           |
| 25<br>FR          | FIFO reset                                                                                                                                                                                                                                                                   |
|                   | Resets the FIFO pointers.                                                                                                                                                                                                                                                    |
|                   | 0 No effect. 1 FIFO reset.                                                                                                                                                                                                                                                   |
| 24                | Software reset                                                                                                                                                                                                                                                               |
| SR                | When set, resets the internal transmitter logic including the FIFO pointers. Software visible-registers are not affected, except for the status registers.                                                                                                                   |
|                   | No effect.     Software reset.                                                                                                                                                                                                                                               |
| 23–21<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                           |
| 20<br>WSF         | Word start flag                                                                                                                                                                                                                                                              |
| WVSF              | Indicates that the start of the configured word has been detected. Write a logic one to this register bit to clear this flag.                                                                                                                                                |
|                   | <ul><li>0 Start of word not detected.</li><li>1 Start of word detected.</li></ul>                                                                                                                                                                                            |
| 19<br>SEF         | Sync error flag                                                                                                                                                                                                                                                              |
|                   | Indicates that an error in the externally-generated frame sync has been detected. Write a logic one to this register bit to clear this flag.                                                                                                                                 |
|                   | <ul><li>0 Sync error not detected.</li><li>1 Frame sync error detected.</li></ul>                                                                                                                                                                                            |
| 18<br>FEF         | FIFO error flag                                                                                                                                                                                                                                                              |
|                   | Indicates that an enabled transmit FIFO has underrun. Write a logic one to this register bit to clear this flag.                                                                                                                                                             |

Table continues on the next page...

#### **Memory Map and Registers**

# I2Sx\_TCSR field descriptions (continued)

| Field             | Description                                                                                                                  |
|-------------------|------------------------------------------------------------------------------------------------------------------------------|
|                   | O Transmit underrun not detected.                                                                                            |
|                   | 1 Transmit underrun detected.                                                                                                |
| 17<br>FWF         | FIFO warning flag                                                                                                            |
|                   | Indicates that an enabled transmit FIFO is empty.                                                                            |
|                   | 0 No enabled transmit FIFO is empty.                                                                                         |
|                   | 1 Enabled transmit FIFO is empty.                                                                                            |
| 16<br>FRF         | FIFO request flag                                                                                                            |
|                   | Indicates that the number of words in an enabled transmit channel FIFO is less than or equal to the transmit FIFO watermark. |
|                   | 0 Transmit FIFO watermark not reached.                                                                                       |
|                   | 1 Transmit FIFO watermark has been reached.                                                                                  |
| 15–13<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                           |
| 12<br>WSIE        | Word start interrupt enable                                                                                                  |
| WOIE              | Enables/disables word start interrupts.                                                                                      |
|                   | 0 Disables interrupt.                                                                                                        |
|                   | 1 Enables interrupt.                                                                                                         |
| 11<br>SEIE        | Sync error interrupt enable                                                                                                  |
| SEIE              | Enables/disables sync error interrupts.                                                                                      |
|                   | 0 Disables interrupt.                                                                                                        |
|                   | 1 Enables interrupt.                                                                                                         |
| 10                | FIFO error interrupt enable                                                                                                  |
| FEIE              | Enables/disables FIFO error interrupts.                                                                                      |
|                   | 0 Disables the interrupt,                                                                                                    |
|                   | 1 Enables the interrupt.                                                                                                     |
| 9<br>FWIE         | FIFO warning interrupt enable                                                                                                |
| LAAIC             | Enables/disables FIFO warning interrupts.                                                                                    |
|                   | 0 Enables the interrupt.                                                                                                     |
|                   | 1 Disables the interrupt.                                                                                                    |
| 8<br>FRIE         | FIFO request interrupt enable                                                                                                |
| 11116             | Enables/disables FIFO request interrupts.                                                                                    |
|                   | 0 Disables the interrupt.                                                                                                    |
|                   | 1 Enables the interrupt.                                                                                                     |
| 7–5<br>Reserved   | This read-only bitfield is reserved and always has the value zero.                                                           |

Table continues on the next page...

#### Chapter 44 Integrated Interchip Sound (I2S) / Synchronous Audio Interface (SAI)

## I2Sx\_TCSR field descriptions (continued)

| Field           | Description                                                                      |
|-----------------|----------------------------------------------------------------------------------|
| 4–2<br>Reserved | This read-only bitfield is reserved and always has the value zero.               |
| 1<br>FWDE       | FIFO warning DMA enable Enables/disables DMA requests.                           |
|                 | Disables the DMA request.     Enables the DMA request.                           |
| 0<br>FRDE       | FIFO request DMA enable Enables/disables DMA requests.                           |
|                 | <ul><li>0 Disables the DMA request.</li><li>1 Enables the DMA request.</li></ul> |

# 44.3.2 SAI Transmit Configuration 1 Register (I2Sx\_TCR1)

Addresses: I2S0\_TCR1 is FFFF\_8200h base + 4h offset = FFFF\_8204h



## I2Sx\_TCR1 field descriptions

| Field            | Description                                                                                |
|------------------|--------------------------------------------------------------------------------------------|
| 31–2<br>Reserved | This read-only bitfield is reserved and always has the value zero.                         |
| 1–0<br>TFW       | Transmit FIFO watermark  Configures the watermark level for all enabled transmit channels. |

# 44.3.3 SAI Transmit Configuration 2 Register (I2Sx\_TCR2)

This register cannot be altered when the transmit enable bit is set.

Addresses: I2S0\_TCR2 is FFFF\_8200h base + 8h offset = FFFF\_8208h



# I2Sx\_TCR2 field descriptions

| Field             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–28<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 27–26<br>CLKMODE  | Clocking mode  When configured for external bit clock configures for asynchronous or synchronous operation. When configured for internal bit clock, selects the Audio Master Clock used to generate the internal bit clock.  ON Asynchronous mode (external bit clock) or Bus Clock selected (internal bit clock).  Synchronous with receiver (external bit clock) or Master Clock 1 selected (internal bit clock).  Synchronous with another SAI transmitter (external bit clock) or Master Clock 2 selected (internal bit clock).  Synchronous with another SAI receiver (external bit clock) or Master Clock 3 selected (internal bit clock). |
| 25<br>BCP         | Bit clock polarity  Configures the polarity of the bit clock.  0 Bit Clock is active high (drive outputs on rising edge and sample inputs on falling edge).  1 Bit Clock is active low (drive outputs on falling edge and sample inputs on rising edge).                                                                                                                                                                                                                                                                                                                                                                                         |
| 24<br>BCD         | Bit clock direction  Configures the direction of the bit clock.  Bit clock is generated externally (slave mode).  Bit clock is generated internally (master mode).                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 23–8<br>Reserved  | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 7–0<br>DIV        | Bit clock divide                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

Table continues on the next page...

#### I2Sx\_TCR2 field descriptions (continued)

| Field | Description                                                                                                                                      |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------|
|       | Divides down the audio master clock to generate the bit clock when configured for an internal bit clock. The division value is $(DIV + 1) * 2$ . |

# 44.3.4 SAI Transmit Configuration 3 Register (I2Sx\_TCR3)

This register cannot be altered when the transmit enable bit is set.

Addresses: I2S0\_TCR3 is FFFF\_8200h base + Ch offset = FFFF\_820Ch



## I2Sx\_TCR3 field descriptions

| Field             | Description                                                                                                                                                                                                                                                                                                             |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–17<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                                                                      |
| 16<br>TCE         | Transmit channel enable  Enables a data channel for a transmit operation. A channel must be enabled before its FIFO can be accessed.  O Transmit data channel is disabled.  Transmit data channel is enabled.                                                                                                           |
| 15–4<br>Reserved  | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                                                                      |
| 3–0<br>WDFL       | Word flag configuration  Configures which word the start of word flag is set. The value written should be one less than the word number (for example, write zero to configure for the first word in the frame). When configured to a value greater than the Frame Size field, then the start of word flag is never set. |

# 44.3.5 SAI Transmit Configuration 4 Register (I2Sx\_TCR4)

This register cannot be altered when the transmit enable bit is set.

Addresses: I2S0\_TCR4 is FFFF\_8200h base + 10h offset = FFFF\_8210h



#### I2Sx\_TCR4 field descriptions

| Field             | Description                                                                                                                                                                                                                                                                                              |
|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–20<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                                                       |
| 19–16<br>FRSZ     | Frame size  Configures the number of words in each frame. The value written should be one less than the number of words in the frame (for example, write 0 for one word per frame). The maximum supported frame size is 16 words.                                                                        |
| 15–13<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                                                       |
| 12–8<br>SYWD      | Sync width  Configures the length of the frame sync in number of bit clocks. The value written should be one less than the number of bit clocks (for example, write 0 for the frame sync to assert for one bit clock only). The sync width cannot be configured longer than the first word of the frame. |
| 7–5<br>Reserved   | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                                                       |
| 4<br>MF           | MSB first  Specifies whether the LSB or the MSB is transmitted/received first.  URS is transmitted/received first.  MBS is transmitted/received first.                                                                                                                                                   |
| 3<br>FSE          | Frame sync early  O Frame sync asserts with the first bit of the frame.  1 Frame sync asserts one bit before the first bit of the frame.                                                                                                                                                                 |
| 2<br>Reserved     | This read-only bit is reserved and always has the value zero.                                                                                                                                                                                                                                            |
| 1<br>FSP          | Frame sync polarity  Configures the polarity of the frame sync.  0 Frame sync is active high.  1 Frame sync is active low.                                                                                                                                                                               |

Table continues on the next page...

#### Chapter 44 Integrated Interchip Sound (I2S) / Synchronous Audio Interface (SAI)

#### I2Sx\_TCR4 field descriptions (continued)

| Field | Description                                                                                                                                                                |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FSD   | Frame sync direction  Configures the direction of the frame sync.  0 Frame Sync is generated externally (slave mode).  1 Frame Sync is generated internally (master mode). |

# 44.3.6 SAI Transmit Configuration 5 Register (I2Sx\_TCR5)

This register cannot be altered when the transmit enable bit is set.

Addresses: I2S0\_TCR5 is FFFF\_8200h base + 14h offset = FFFF\_8214h



#### I2Sx\_TCR5 field descriptions

| Field             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–29<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 28–24<br>WNW      | Word N width  Configures the number of bits in each word, for each word except the first in the frame. The value written should be one less than the number of bits per word. This field must be configured greater than or equal to Word 0 Width even when there is only one word in each frame. Words of fewer than 8 bits wide are not supported.                                                                                                                                                                   |
| 23–21<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 20–16<br>W0W      | Word 0 width  Configures the number of bits in the first word in each frame. The value written should be one less than the number of bits in the first word. Words of less than 8 bits wide are not supported if there is only one word per frame.                                                                                                                                                                                                                                                                     |
| 15–13<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 12–8<br>FBT       | Configures the bit index for the first bit transmitted for each word in the frame. If configured for MSB First, the index of the next bit transmitted is one less than the current bit transmitted. If configured for LSB First, the index of the next bit transmitted is one more than the current bit transmitted. The value written should be greater than or equal to the word width when configured for MSB First. The value written should be less than or equal to 31-word width when configured for LSB First. |

Table continues on the next page...

#### **Memory Map and Registers**

#### I2Sx\_TCR5 field descriptions (continued)

| Field           | Description                                                        |
|-----------------|--------------------------------------------------------------------|
| 7–0<br>Reserved | This read-only bitfield is reserved and always has the value zero. |

# 44.3.7 SAI Transmit Data Register (I2Sx\_TDR)

Addresses: I2S0\_TDR is FFFF\_8200h base + 20h offset = FFFF\_8220h



#### I2Sx\_TDR field descriptions

| Field             | Description                                                                                                                                                                                               |
|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–0<br>TDR[31:0] | Transmit data register  Writes to this register when the transmit data channel is enabled and not full will push the data written into the transmit FIFO. Otherwise, writes to this register are ignored. |

# 44.3.8 SAI Transmit FIFO Register (I2Sx\_TFR)

The MSB of the read pointer and write pointer is used to distinguish between FIFO full and empty conditions. If the read and write pointers are identical then the FIFO is empty. If the read and write pointers are identical except for the MSB then the FIFO is full.

Addresses: I2S0\_TFR is FFFF\_8200h base + 40h offset = FFFF\_8240h



#### I2Sx\_TFR field descriptions

| Field             | Description                                                        |
|-------------------|--------------------------------------------------------------------|
| 31–19<br>Reserved | This read-only bitfield is reserved and always has the value zero. |
| 18–16<br>WFP      | Write FIFO pointer                                                 |

Table continues on the next page...

#### Chapter 44 Integrated Interchip Sound (I2S) / Synchronous Audio Interface (SAI)

## I2Sx\_TFR field descriptions (continued)

| Field            | Description                                                        |
|------------------|--------------------------------------------------------------------|
|                  | FIFO write pointer for transmit data channel.                      |
| 15–3<br>Reserved | This read-only bitfield is reserved and always has the value zero. |
| 2–0<br>RFP       | Read FIFO pointer  FIFO read pointer for transmit data channel.    |

# 44.3.9 SAI Transmit Mask Register (I2Sx\_TMR)

Addresses: I2S0\_TMR is FFFF\_8200h base + 60h offset = FFFF\_8260h



## **I2Sx\_TMR** field descriptions

| Field             | Description                                                                                     |
|-------------------|-------------------------------------------------------------------------------------------------|
| 31–16<br>Reserved | This read-only bitfield is reserved and always has the value zero.                              |
| 15–0<br>TWM       | Transmit word mask  For each word in the frame, configures whether the transmit word is masked. |
|                   | Word N is enabled.     Word N is masked. The transmit data pins are tri-stated when masked.     |

# 44.3.10 SAI Receive Control Register (I2Sx\_RCSR)

Addresses: I2S0\_RCSR is FFFF\_8200h base + 80h offset = FFFF\_8280h



## I2Sx\_RCSR field descriptions

| Field       | Description                                                                                                                                                                                                                                                              |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>RE    | Receiver enable                                                                                                                                                                                                                                                          |
|             | Enables/disables the receiver. When software clears this bit, the receiver remains enabled (and this bit remains set) until the end of the current frame.                                                                                                                |
|             | 0 Receiver is disabled.                                                                                                                                                                                                                                                  |
|             | Receiver is enabled, or receiver has been disabled and not end of frame.                                                                                                                                                                                                 |
| 30<br>STOPE | Stop enable                                                                                                                                                                                                                                                              |
|             | Configures receiver operation in Stop mode. This bit is ignored and the receiver is disabled in all low-leakage stop modes.                                                                                                                                              |
|             | 0 Receiver disabled in stop mode.                                                                                                                                                                                                                                        |
|             | 1 Receiver enabled in stop mode.                                                                                                                                                                                                                                         |
| 29<br>DBGE  | Debug enable                                                                                                                                                                                                                                                             |
|             | Enables/disables receiver operation in debug mode. The receive bit clock is not affected by debug mode.                                                                                                                                                                  |
|             | 0 Receiver is disabled in debug mode, after completing the current frame.                                                                                                                                                                                                |
|             | 1 Receiver is enabled in debug mode.                                                                                                                                                                                                                                     |
| 28<br>BCE   | Bit Clock enable                                                                                                                                                                                                                                                         |
|             | Enables the receive bit clock, separately from the receive enable. This bit is automatically set whenever the receive enable is set. When software clears this bit, the receive bit clock remains enabled (and this bit remains set) until the end of the current frame. |
|             | 0 Receive bit clock is disabled                                                                                                                                                                                                                                          |
|             | 1 Receive bit clock is enabled                                                                                                                                                                                                                                           |

Table continues on the next page...

#### Chapter 44 Integrated Interchip Sound (I2S) / Synchronous Audio Interface (SAI)

## I2Sx\_RCSR field descriptions (continued)

| Field             | Description                                                                                                                                             |
|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| 27–26<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                      |
| 25<br>FR          | FIFO reset                                                                                                                                              |
|                   | Resets the FIFO pointers.                                                                                                                               |
|                   | 0 No effect. 1 FIFO reset.                                                                                                                              |
| 24<br>SR          | Software reset                                                                                                                                          |
|                   | When set, resets the internal receiver logic including the FIFO pointers. Software visible-registers are not affected, except for the status registers. |
|                   | 0 No effect. 1 Software reset.                                                                                                                          |
| 23–21<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                      |
| 20<br>WSF         | Word start flag                                                                                                                                         |
|                   | Indicates that the start of the configured word has been detected. Write a logic one to this register bit to clear this flag.                           |
|                   | 0 Start of word not detected.                                                                                                                           |
|                   | 1 Start of word detected.                                                                                                                               |
| 19<br>SEF         | Sync error flag                                                                                                                                         |
|                   | Indicates that an error in the externally-generated frame sync has been detected. Write a logic one to this register bit to clear this flag.            |
|                   | 0 Sync error not detected.                                                                                                                              |
|                   | 1 Frame sync error detected.                                                                                                                            |
| 18<br>FEF         | FIFO error flag                                                                                                                                         |
|                   | Indicates that an enabled receive FIFO has overflowed. Write a logic one to this register bit to clear this flag.                                       |
|                   | 0 Receive underrun not detected.                                                                                                                        |
|                   | 1 Receive underrun detected.                                                                                                                            |
| 17<br>FWF         | FIFO warning flag                                                                                                                                       |
|                   | Indicates that an enabled receive FIFO is full.                                                                                                         |
|                   | 0 No enabled receive FIFO is full.                                                                                                                      |
|                   | 1 Enabled receive FIFO is full.                                                                                                                         |
| 16<br>FRF         | FIFO request flag                                                                                                                                       |
|                   | Indicates that the number of words in an enabled receive channel FIFO is greater than the receive FIFO watermark.                                       |

Table continues on the next page...

#### **Memory Map and Registers**

# I2Sx\_RCSR field descriptions (continued)

| Field             | Description                                                                       |
|-------------------|-----------------------------------------------------------------------------------|
|                   | Receive FIFO watermark not reached.      Receive FIFO watermark has been reached. |
|                   | 1 Receive FIFO watermark has been reached.                                        |
| 15–13<br>Reserved | This read-only bitfield is reserved and always has the value zero.                |
| 12<br>WSIE        | Word start interrupt enable                                                       |
|                   | Enables/disables word start interrupts.                                           |
|                   | <ul><li>0 Disables interrupt.</li><li>1 Enables interrupt.</li></ul>              |
| 11                | Sync error interrupt enable                                                       |
| SEIE              | Enables/disables sync error interrupts.                                           |
|                   | 0 Disables interrupt.                                                             |
|                   | 1 Enables interrupt.                                                              |
| 10<br>FEIE        | FIFO error interrupt enable                                                       |
|                   | Enables/disables FIFO error interrupts.                                           |
|                   | <ul><li>0 Disables the interrupt,</li><li>1 Enables the interrupt.</li></ul>      |
| 9                 | FIFO warning interrupt enable                                                     |
| FWIE              | Enables/disables FIFO warning interrupts.                                         |
|                   | 0 Enables the interrupt.                                                          |
|                   | 1 Disables the interrupt.                                                         |
| 8<br>FRIE         | FIFO request interrupt enable                                                     |
|                   | Enables/disables FIFO request interrupts.                                         |
|                   | 0 Disables the interrupt.                                                         |
|                   | 1 Enables the interrupt.                                                          |
| 7–5<br>Reserved   | This read-only bitfield is reserved and always has the value zero.                |
| 4–2<br>Reserved   | This read-only bitfield is reserved and always has the value zero.                |
| 1                 | FIFO warning DMA enable                                                           |
| FWDE              | Enables/disables DMA requests.                                                    |
|                   | 0 Disables the DMA request.                                                       |
|                   | 1 Enables the DMA request.                                                        |
| 0<br>FRDE         | FIFO request DMA enable                                                           |
|                   | Enables/disables DMA requests.                                                    |

Table continues on the next page...

### I2Sx\_RCSR field descriptions (continued)

| Field | Description                 |
|-------|-----------------------------|
|       | 0 Disables the DMA request. |
|       | 1 Enables the DMA request.  |

# 44.3.11 SAI Receive Configuration 1 Register (I2Sx\_RCR1)

Addresses: I2S0\_RCR1 is FFFF\_8200h base + 84h offset = FFFF\_8284h



### I2Sx\_RCR1 field descriptions

| Field            | Description                                                                               |
|------------------|-------------------------------------------------------------------------------------------|
| 31–2<br>Reserved | This read-only bitfield is reserved and always has the value zero.                        |
| 1–0<br>RFW       | Receive FIFO watermark  Configures the watermark level for all enabled receiver channels. |

# 44.3.12 SAI Receive Configuration 2 Register (I2Sx\_RCR2)

This register cannot be altered when the receive enable bit is set.

Addresses: I2S0\_RCR2 is FFFF\_8200h base + 88h offset = FFFF\_8288h



### **Memory Map and Registers**

### I2Sx\_RCR2 field descriptions

| Field             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–28<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 27–26<br>CLKMODE  | Clocking mode  When configured for external bit clock, this field configures for asynchronous or synchronous operation.  When configured for internal bit clock, this field selects the Audio Master Clock used to generate the internal bit clock. See the Chip Configuration details for information about the availability of these options.  O Asynchronous mode (external bit clock) or Bus Clock selected (internal bit clock).  Synchronous with transmitter (external bit clock) or Master Clock 1 selected (internal bit clock).  Synchronous with another SAI receiver (external bit clock) or Master Clock 2 selected (internal bit clock).  Synchronous with another SAI transmitter (external bit clock) or Master Clock 3 selected (internal bit clock). |
| 25<br>BCP         | Bit clock polarity  Configures the polarity of the bit clock.  Bit Clock is active high (drive outputs on rising edge and sample inputs on falling edge).  Bit Clock is active low (drive outputs on falling edge and sample inputs on rising edge).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 24<br>BCD         | Bit clock direction  Configures the direction of the bit clock.  Bit clock is generated externally (slave mode).  Bit clock is generated internally (master mode).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 23–8<br>Reserved  | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 7–0<br>DIV        | Bit clock divide  Divides down the audio master clock to generate the bit clock when configured for an internal bit clock.  The division value is (DIV + 1) * 2.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

# 44.3.13 SAI Receive Configuration 3 Register (I2Sx\_RCR3)

This register cannot be altered when the receive enable bit is set.

Addresses: I2S0\_RCR3 is FFFF\_8200h base + 8Ch offset = FFFF\_828Ch



#### Chapter 44 Integrated Interchip Sound (I2S) / Synchronous Audio Interface (SAI)

### I2Sx\_RCR3 field descriptions

| Field             | Description                                                                                                                                                                                                                                                                                                             |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–17<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                                                                      |
| 16<br>RCE         | Receive channel enable  Enables a data channel for a receive operation. A channel must be enabled before its FIFO can be accessed.  O Receive data channel is disabled.  Receive data channel is enabled.                                                                                                               |
| 15–4<br>Reserved  | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                                                                      |
| 3–0<br>WDFL       | Word flag configuration  Configures which word the start of word flag is set. The value written should be one less than the word number (for example, write zero to configure for the first word in the frame). When configured to a value greater than the Frame Size field, then the start of word flag is never set. |

# 44.3.14 SAI Receive Configuration 4 Register (I2Sx\_RCR4)

This register cannot be altered when the receive enable bit is set.

Addresses: I2S0\_RCR4 is FFFF\_8200h base + 90h offset = FFFF\_8290h



### I2Sx\_RCR4 field descriptions

| Field             | Description                                                                                                                                                                                                                                                                                              |
|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–20<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                                                       |
| 19–16<br>FRSZ     | Frame size  Configures the number of words in each frame. The value written should be one less than the number of words in the frame (for example, write 0 for one word per frame). The maximum supported frame size is 16 words.                                                                        |
| 15–13<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                                                       |
| 12–8<br>SYWD      | Sync width  Configures the length of the frame sync in number of bit clocks. The value written should be one less than the number of bit clocks (for example, write 0 for the frame sync to assert for one bit clock only). The sync width cannot be configured longer than the first word of the frame. |

Table continues on the next page...

#### **Memory Map and Registers**

### I2Sx\_RCR4 field descriptions (continued)

| Field           | Description                                                                                                                                                                |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–5<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                                         |
| 4<br>MF         | MSB first  Specifies whether the LSB or the MSB is transmitted/received first.  Under the LSB or the MSB is transmitted/received first.                                    |
|                 | 1 MBS is transmitted/received first.                                                                                                                                       |
| 3<br>FSE        | Frame sync early  O Frame sync asserts with the first bit of the frame.  Trame sync asserts one bit before the first bit of the frame.                                     |
| 2<br>Reserved   | This read-only bit is reserved and always has the value zero.                                                                                                              |
| 1<br>FSP        | Frame sync polarity  Configures the polarity of the frame sync.  0 Frame sync is active high.  1 Frame sync is active low.                                                 |
| 0<br>FSD        | Frame sync direction  Configures the direction of the frame sync.  0 Frame Sync is generated externally (slave mode).  1 Frame Sync is generated internally (master mode). |

# 44.3.15 SAI Receive Configuration 5 Register (I2Sx\_RCR5)

This register cannot be altered when the receive enable bit is set.

Addresses: I2S0\_RCR5 is FFFF\_8200h base + 94h offset = FFFF\_8294h



### I2Sx\_RCR5 field descriptions

| Field             | Description                                                        |
|-------------------|--------------------------------------------------------------------|
| 31–29<br>Reserved | This read-only bitfield is reserved and always has the value zero. |
| 28–24<br>WNW      | Word N width                                                       |

Table continues on the next page...

### I2Sx\_RCR5 field descriptions (continued)

| Field             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                   | Configures the number of bits in each word, for each word except the first in the frame. The value written should be one less than the number of bits per word. This field must be configured greater than or equal to Word 0 Width even when there is only one word in each frame. Words of fewer than 8 bits wide are not supported.                                                                                                                                                                                         |
| 23–21<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 20–16<br>W0W      | Word 0 width  Configures the number of bits in the first word in each frame. The value written should be one less than the number of bits in the first word. Words of less than 8 bits wide are not supported if there is only one word per frame.                                                                                                                                                                                                                                                                             |
| 15–13<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 12–8<br>FBT       | First bit shifted  Configures the bit index for the first bit received for each word in the frame. If configured for MSB First.  The index of the next bit received is one less than the current bit received. If configured for LSB First, the index of the next bit received is one more than the current bit received. The value written should be greater than or equal to the word width when configured for MSB First. The value written should be less than or equal to (31 - word with) when configured for LSB First. |
| 7–0<br>Reserved   | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

# 44.3.16 SAI Receive Data Register (I2Sx\_RDR)

Reading this register when the receive channel is enabled and not empty introduces one additional peripheral clock wait state on each read.

Addresses: I2S0\_RDR is FFFF\_8200h base + A0h offset = FFFF\_82A0h



### I2Sx\_RDR field descriptions

| Field             | Description                                                                                                                                                                       |
|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–0<br>RDR[31:0] | Receive data register                                                                                                                                                             |
|                   | Reads from this register when the receive data channel is enabled and not empty return the data from the top of the receive FIFO. Otherwise, writes to this register are ignored. |

### 44.3.17 SAI Receive FIFO Register (I2Sx\_RFR)

The MSB of the read pointer and write pointer is used to distinguish between FIFO full and empty conditions. If the read and write pointers are identical then the FIFO is empty. If the read and write pointers are identical except for the MSB then the FIFO is full.





### I2Sx\_RFR field descriptions

| Field             | Description                                                        |
|-------------------|--------------------------------------------------------------------|
| 31–19<br>Reserved | This read-only bitfield is reserved and always has the value zero. |
| 18–16<br>WFP      | Write FIFO pointer  FIFO write pointer for receive data channel.   |
| 15–3<br>Reserved  | This read-only bitfield is reserved and always has the value zero. |
| 2–0<br>RFP        | Read FIFO pointer  FIFO read pointer for receive data channel.     |

# 44.3.18 SAI Receive Mask Register (I2Sx\_RMR)

This register is double-buffered and updates when the receive enable bit is first set and then at the end of each frame. This allows the masked words in each frame to change from frame to frame.

Addresses: I2S0\_RMR is FFFF\_8200h base + E0h offset = FFFF\_82E0h



### I2Sx\_RMR field descriptions

| Field             | Description                                                                                                    |
|-------------------|----------------------------------------------------------------------------------------------------------------|
| 31–16<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                             |
| 15–0<br>RWM       | Receive word mask  For each word in the frame, configures if the receive word is masked.  0 Word N is enabled. |
|                   | 1 Word N is masked.                                                                                            |

# 44.3.19 SAI MCLK Control Register (I2Sx\_MCR)

The MCLK Control Register controls the clock source and direction of the Audio Master Clock.

Addresses: I2S0\_MCR is FFFF\_8200h base + 100h offset = FFFF\_8300h



### I2Sx\_MCR field descriptions

| Field     | Description                                                                                                                                                          |
|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>DUF | Divider Update Flag                                                                                                                                                  |
|           | Provides the status of on-the-fly updates to the MCLK Divider ratio.                                                                                                 |
|           | 0 MCLK Divider ratio is not being updated currently.                                                                                                                 |
|           | 1 MCLK Divider ratio is updating on-the-fly. Furthur updates to the MCLK Divider ratio are blocked while this flag remains set.                                      |
| 30<br>MOE | MCLK Output Enable                                                                                                                                                   |
|           | Enables the MCLK Divider and configures the SAI_MCLK pin as an output. When software clears this bit, this bit remains set until the MCLK divider is fully disabled. |

Table continues on the next page...

#### **Memory Map and Registers**

### I2Sx\_MCR field descriptions (continued)

| Field             | Description                                                                                                                                                                                           |  |  |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|                   | O SAI_MCLK pin is configured as an input that bypasses the MCLK Divider.                                                                                                                              |  |  |
|                   | 1 SAI_MCLK pin is configured as an output from the MCLK Divider and the MCLK Divider is enabled.                                                                                                      |  |  |
| 29–26<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                                                                    |  |  |
| 25–24<br>MICS     | MCLK Input Clock Select                                                                                                                                                                               |  |  |
|                   | Selects the clock input to the MCLK Divider. This field cannot be changed when the MCLK divider is enabled. See the Chip Configuration details for information about the connections to these inputs. |  |  |
|                   | 00 MCLK Divider input clock 0 selected.                                                                                                                                                               |  |  |
|                   | 01 MCLK Divider input clock 1 selected.                                                                                                                                                               |  |  |
|                   | 10 MCLK Divider input clock 2 selected.                                                                                                                                                               |  |  |
|                   | 11 MCLK Divider input clock 3 selected.                                                                                                                                                               |  |  |
| 23–0<br>Reserved  | This read-only bitfield is reserved and always has the value zero.                                                                                                                                    |  |  |

# 44.3.20 MCLK Divide Register (I2Sx\_MDR)

Configures the MCLK Divide Ratio. Although the MCLK Divide Register can be changed when the MCLK divided clock is enabled, additional writes to the MCLK Divide Register are blocked while the Divider Update Flag is set. Writes to the MCLK Divide Register when the MCLK divided clock is disabled do not set the Divider Update Flag.

Addresses: I2S0\_MDR is FFFF\_8200h base + 104h offset = FFFF\_8304h



#### I2Sx\_MDR field descriptions

| Field             | Description                                                                                                                                                                   |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–20<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                                            |
| 19–12<br>FRACT    | MCLK Fraction  The MCLK FRACT must be set equal or less than the MCLK DIVIDE. Sets the MCLK divide ratio such that: MCLK output = MCLK input * ( (FRACT + 1) / (DIVIDE + 1) ) |
| 11–0<br>DIVIDE    | MCLK Divide  The MCLK FRACT must be set equal or less than the MCLK DIVIDE. Sets the MCLK divide ratio such that: MCLK output = MCLK input * ( (FRACT + 1) / (DIVIDE + 1) )   |

# 44.4 Functional description

# 44.4.1 SAI clocking

The SAI clocks include the audio master clock, the bit clock, and the bus clock.

### 44.4.1.1 Audio Master Clock

The audio master clock is used to generate the bit clock when the receiver or transmitter is configured for an internally-generated bit clock. The transmitter and receiver can independently select between the bus clock and up to three audio master clocks to generate the bit clock.

Each SAI peripheral can control the input clock selection, pin direction and divide ratio of one audio master clock. The input clock selection and pin direction cannot be altered if an SAI using that audio master clock has been enabled. The master clock divide ratio can be altered while an SAI is using that master clock, although the change in the divide ratio takes several cycles. The divide update flag can be polled to determine when the divide ratio change has completed.

The audio master clock generation and selection is chip specific. Refer to chip-specific clocking information about how the audio master clocks are generated. A typical implementation appears in the following figure.



Figure 44-41. SAI Master Clock Generation

### 44.4.1.2 Bit Clock

The SAI transmitter and receiver support asynchronous free running bit clocks that can be generated internally from an audio master clock or supplied externally. There is also the option for synchronous bit clock and frame sync operation between the receiver and transmitter or between multiple SAI peripherals.

Externally generated bit clocks should be enabled before the SAI transmitter or receiver is enabled and should be disabled after the SAI transmitter or receiver is disabled and they have completed their current frames.

### 44.4.1.3 Bus Clock

The bus clock is used by the control and configuration registers and to generate synchronous interrupts and DMA requests.

### 44.4.2 SAI resets

The SAI is asynchronously reset on system reset. The SAI has a software reset and a FIFO reset.

### 44.4.2.1 Software reset

The SAI transmitter includes a software reset that resets all transmitter internal logic, including the bit clock generation, status flags and FIFO pointers. It does not reset the configuration registers. The software reset remains asserted until cleared by software.

The SAI receiver includes a software reset that resets all receiver internal logic, including the bit clock generation, status flags and FIFO pointers. It does not reset the configuration registers. The software reset remains asserted until cleared by software.

### 44.4.2.2 FIFO reset

The SAI transmitter includes a FIFO reset that synchronizes the FIFO write pointer to the same value as the FIFO read pointer. This empties the FIFO contents and is to be used after the Transmit FIFO Error Flag is set, and before the FIFO is re-initialized and the Error Flag is cleared. The FIFO Reset is asserted for one cycle only.

The SAI receiver includes a FIFO reset that synchronizes the FIFO read pointer to the same value as the FIFO write pointer. This empties the FIFO contents and is to be used after the Receive FIFO Error Flag is set and any remaining data has been read from the FIFO, and before the Error Flag is cleared. The FIFO Reset is asserted for one cycle only.

# 44.4.3 Synchronous Modes

The SAI transmitter and receiver can operate synchronously to each other or synchronously to other SAI peripherals.

### 44.4.3.1 Synchronous Mode

The SAI transmitter and receiver can be configured to operate with synchronous bit clock and frame sync.

If the transmitter bit clock and frame sync are to be used by both the transmitter and receiver, the transmitter should be configured for asynchronous operation and the receiver for synchronous operation. In synchronous mode, the receiver is only enabled when both the transmitter and receiver are both enabled. It is recommended that the transmitter is the last enabled and the first disabled.

If the receiver bit clock and frame sync are to be used by both the transmitter and receiver, the receiver should be configured for asynchronous operation and the transmitter for synchronous operation. In synchronous mode, the transmitter is only enabled when both the receiver and transmitter are both enabled. It is recommended that the receiver is the last enabled and the first disabled.

When operating in synchronous mode only the bit clock, frame sync and transmitter/ receiver enable are shared. The transmitter and receiver otherwise operate independently, although configuration registers should be configured consistently across both the transmitter and receiver.

### 44.4.3.2 Multiple SAI Synchronous Mode

Synchronous operation between multiple SAI peripherals is not supported on all devices, and requires the source of the bit clock and frame sync to be configured for asynchronous operation and the remaining users of the bit clock and frame sync to be configured for synchronous operation.

#### **Data FIFO**

Synchronous operation between multiple SAI transmitters or receivers also requires the source of the bit clock and frame sync to be enabled for any of the synchronous transmitters or receivers to also be enabled. It is recommended that the source of the bit clock and frame sync is the last enabled and the first disabled.

When operating in synchronous mode only the bit clock, frame sync and transmitter/receiver enable are shared. The separate SAI peripherals otherwise operate independently, although configuration registers should be configured consistently across both the transmitter and receiver.

# 44.4.4 Frame sync configuration

The Frame Sync signal is used to indicate the start of each Frame. A valid Frame Sync requires a rising edge (if active high) or falling edge (if active low) to be detected and the Transmitter or Receiver cannot be busy with a previous frame. A valid Frame Sync is also ignored (slave mode) or not generated (master mode) for the first four bit clock cycles after enabling the Transmitter or Receiver.

The Transmitter and Receiver Frame Sync can be configured independently with any of the following options:

- Externally generated or internally generated
- Active high or active low
- Asserts with first bit in frame or asserts one bit early
- Asserts for between 1 bit clock and first word length
- Frame length can be configured from 1 word per frame to 16 words per frame
- Word length can be configured to support from 8 bits to 32 bits per word
  - First word length and remaining word lengths can be configured separately
- Can be configured for Most Significant Bit first or Least Significant Bit first

These configuration options cannot be changed after the SAI transmitter or receiver is enabled.

# 44.4.5 Data FIFO

### 44.4.5.1 Data alignment

Each transmit and receive channel includes a FIFO of size  $4 \times 32$ -bit. The FIFO data is accessed using the SAI Transmit/Receive Data Registers. Data in the FIFO can be aligned anywhere within the 32-bit wide register through the use of the First Bit Shifted configuration field, which selects the bit index (between 31 and 0) of the first bit shifted.

Examples of supported data alignment and the required First Bit Shifted configuration are illustrated in Figure 44-42 for LSB First configurations and Figure 44-43 for MSB First configurations.



Figure 44-42. SAI First Bit Shifted, LSB First



Figure 44-43. SAI First Bit Shifted, MSB First

# 44.4.5.2 FIFO pointers

When writing to the Transmit Data Register (TDR), the write FIFO pointer increments after each valid write. The SAI supports 8-bit and 16-bit writes to TDR for transmitting 8-bit and 16-bit data respectively.

Writes to the Transmit Data Register are ignored if the corresponding Transmit Channel Enable is clear or if the FIFO is full. If the Transmit FIFO is empty, the Transmit Data Register must be written at least three bit clocks before the start of the next unmasked word to avoid a FIFO underrun.

#### **Data FIFO**

When reading the Receive Data Register (RDR), the read FIFO pointer increments after each valid read. The SAI supports 8-bit and 16-bit reads from RDR for receiving 8-bit and 16-bit data respectively.

Reads from the Receive Data Register are ignored if the corresponding Receive Channel Enable is clear or if the FIFO is empty. If the Receive FIFO is full, the Receive Data Register must be read at least three bit clocks before the end of an unmasked word to avoid a FIFO overrun.

# 44.4.6 Word mask register

The SAI transmitter and receiver each contain a word mask register that can be used to mask any word in the frame. Since the Word Mask Register is double buffered, software can update it before the end of each frame to mask a particular word in the next frame.

The transmitter word mask causes the Transmit Data pin to be tri-stated for the length of each selected word and the transmit FIFO is not read for masked words.

The receiver word mask causes the received data for each selected word to be discarded and not written to the receive FIFO.

# 44.4.7 Interrupts and DMA requests

The SAI transmitter and receiver generate separate interrupts and separate DMA requests, but support the same status flags. Asynchronous versions of the transmitter and receiver interrupts are generated to wake up the CPU from stop mode.

### 44.4.7.1 FIFO data ready flag

The FIFO data ready flag is set based on the number of entries in the FIFO and the FIFO watermark configuration.

The transmit data ready flag is set when the number of entries in any of the enabled transmit FIFOs is less than or equal to the transmit FIFO watermark configuration and is cleared when the number of entries in each enabled transmit FIFO is greater than the transmit FIFO watermark configuration.

The receive data ready flag is set when the number of entries in any of the enabled receive FIFOs is greater than the receive FIFO watermark configuration and is cleared when the number of entries in each enabled receive FIFO is less than or equal to the receive FIFO watermark configuration.

The FIFO data ready flag can generate an interrupt or a DMA request.

### 44.4.7.2 FIFO warning flag

The FIFO warning flag is set based on the number of entries in the FIFO.

The transmit warning flag is set when the number of entries in any of the enabled transmit FIFOs is empty and is cleared when the number of entries in each enabled transmit FIFO is not empty.

The receive warning flag is set when the number of entries in any of the enabled receive FIFOs is full and is cleared when the number of entries in each enabled receive FIFO is not full.

The FIFO warning flag can generate an Interrupt or a DMA request.

### 44.4.7.3 FIFO error flag

The transmit FIFO error flag is set when the any of the enabled transmit FIFOs underflow. After it is set, all enabled transmit channels repeat the last valid word read from the transmit FIFO until the transmit FIFO error flag is cleared and the start of the next transmit frame. All enabled transmit FIFOs should be reset and initialized with new data before the transmit FIFO error flag is cleared.

The receive FIFO error flag is set when the any of the enabled receive FIFOs overflow. After it is set, all enabled receive channels discard received data until the receive FIFO error flag is cleared and the start of the next receive frame. All enabled receive FIFOs should be emptied before the receive FIFO error flag is cleared.

The FIFO error flag can generate an interrupt only.

# 44.4.7.4 Sync error flag

The sync error flag is set when configured for an externally generated frame sync and the external frame sync asserts when the transmitter or receiver is busy with the previous frame. The external frame sync assertion is ignored and the sync error flag is set. The transmitter or receiver continues checking for frame sync assertion at the end of each frame (or when idle) when the sync error flag is set.

The sync error flag can generate an interrupt only.

# 44.4.7.5 Word start flag

The word start flag is set at the start of the second bit clock for the selected word, as configured by the Word Flag register field.

The word start flag can generate an interrupt only.

# Chapter 45 Rapid GPIO (RGPIO)

### 45.1 Introduction

The Rapid GPIO (RGPIO) module provides a 16-bit general-purpose I/O module directly connected to the processor's high-speed 32-bit local bus. This connection plus support for single-cycle, zero wait-state data transfers allows the RGPIO module to provide improved pin performance when compared to more traditional GPIO modules located on the internal slave peripheral bus.

Many of the pins associated with a device may be used for several different functions. Their primary functions are to provide external interfaces to access off-chip resources. When not used for their primary function, many of the pins may be used as general-purpose digital I/O (GPIO) pins. The definition of the exact pin functions and the affected signals is specific to each device. Every GPIO port, including the RGPIO module, has registers that configure, monitor, and control the port pins.

#### **Note**

Most pin functions default to GPIO and must be software configured before using RGPIO.

### 45.1.1 Overview

The RGPIO module provides 16-bits of high-speed GPIO functionality, mapped to the processor's bus. The key features of this module include:

- 16 bits of high-speed GPIO functionality connected to the processor's local 32-bit bus
- Memory-mapped device connected to the ColdFire core's local bus

#### Introduction

- Support for all access sizes: byte, word, and longword
- All reads and writes complete in a single data phase cycle for zero wait-state response
- Data bits can be accessed directly or via alternate addresses to provide set, clear, and toggle functions
  - Alternate addresses allow set, clear, toggle functions using simple store operations without the need for read-modify-write references
- Unique data direction and pin enable control registers
- Package pin toggle rates typically 1.5–3.5x faster than comparable pin mapped onto peripheral bus

A simplified block diagram of the RGPIO module is shown in the following figure. The details of the pin muxing and pad logic are device -specific.



Figure 45-1. RGPIO Block Diagram

# 45.1.2 Features

The major features of the RGPIO module providing 16 bits of high-speed general-purpose input/output are:

- Small memory-mapped device connected to the processor's local bus
  - All memory references complete in a single cycle to provide zero wait-state responses
  - Located in processor's high-speed clock domain
- Simple programming model
  - Four 16-bit registers, mapped as three program-visible locations

#### **External Signal Description**

- Register for pin enables
- Register for controlling the pin data direction
- Register for storing output pin data
- Register for reading current pin state
- The two data registers (read, write) are mapped to a single program-visible location
- Alternate addresses to perform data set, clear, and toggle functions using simple writes
- Separate read and write programming model views enable simplified driver software
  - Support for any access size (byte, word, or longword)

# 45.1.3 Modes of Operation

The RGPIO module does not support any special modes of operation. As a memory-mapped device located on the processor's high-speed local bus, it responds based strictly on memory address and does not consider the operating mode (supervisor, user) of its references.

# 45.2 External Signal Description

### 45.2.1 Overview

As shown in Figure 45-1, the RGPIO module's interface to external logic is indirect via the device pin-muxing and pad logic. The following table shows a list of the associated RGPIO input/output signals.

Table 45-1. RGPIO Module External I/O Signals

| Signal Name | Туре | Description             |
|-------------|------|-------------------------|
| RGPIO[15:0] | I/O  | RGPIO Data Input/Output |

# 45.2.2 Detailed Signal Descriptions

The following table provides descriptions of the RGPIO module's input and output signals.

**Signal** I/O **Description** RGPIO[15:0] I/O Data Input/Output. When configured as an input, the state of this signal is reflected in the read data register. When configured as an output, this signal is the output of the write data register. State Asserted— Meaning Input: Indicates the RGPIO pin was sampled as a logic high at the time of the read. Output: Indicates a properly-enabled RGPIO output pin is to be driven high. Negated-Input: Indicates the RGPIO pin was sampled as a logic low at the time of the read. Output: Indicates a properly-enabled RGPIO output pin is to be driven low. Timing Assertion/Negation— Input: Anytime. The input signal is sampled at the rising-edge of the processor's high-speed clock on the data phase cycle of a read transfer of this register. Output: Occurs at the rising-edge of the processor's high-speed

clock on the data phase cycle of a write transfer to this register.

This output is asynchronously cleared by system reset.

Table 45-2. RGPIO Detailed Signal Descriptions

# 45.3 Memory Map and Registers

The RGPIO module provides a compact 16-byte programming model based at a system memory address of  $0x(00)C0\_0000$  (noted as RGPIO\_BASE throughout the chapter). The programming model views are different between reads and writes to enable simplified software for manipulating the RGPIO pins.

Additionally, the RGPIO programming model is defined with a 32-bit organization. The basic size of each program-visible register is 16 bits, but the programming model may be referenced using byte (8-bit), word (16-bit) or longword (32-bit) accesses. Performance is typically maximized using 32-bit accesses.

#### **NOTE**

Writes to the two-byte fields at RGPIO\_BASE + 0x8 and RGPIO\_BASE + 0xC are allowed, but do not affect any program-visible register within the RGPIO module.

#### **RGPIO** memory map

| Absolute address (hex) | Register name                             | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|------------------------|-------------------------------------------|--------------------|--------|-------------|------------------|
| 00C0_0000              | RGPIO Data Direction Register (RGPIO_DIR) | 16                 | R/W    | 0000h       | 45.3.1/<br>1174  |
| 00C0_0002              | RGPIO Data Register (RGPIO_DATA)          | 16                 | R/W    | 0000h       | 45.3.3/<br>1175  |
| 00C0_0004              | RGPIO Pin Enable Register (RGPIO_ENB)     | 16                 | R/W    | 0000h       | 45.3.4/<br>1175  |
| 00C0_0006              | RGPIO Clear Data Register (RGPIO_CLR)     | 16                 | W      | See section | 45.3.5/<br>1176  |
| 00C0_0008              | RGPIO Data Direction Register (RGPIO_DIR) | 16                 | R      | 0000h       | 45.3.2/<br>1177  |
| 00C0_000A              | RGPIO Set Data Register (RGPIO_SET)       | 16                 | W      | See section | 45.3.6/<br>1177  |
| 00C0_000C              | RGPIO Data Direction Register (RGPIO_DIR) | 16                 | R      | 0000h       | 45.3.8/<br>1178  |
| 00C0_000E              | RGPIO Toggle Data Register (RGPIO_TOG)    | 16                 | W      | See section | 45.3.7/<br>1178  |

### 45.3.1 RGPIO Data Direction Register (RGPIO\_DIR)

The read/write RGPIO\_DIR register defines whether a properly-enabled RGPIO pin is configured as an input or output:

- Setting any bit in RGPIO\_DIR configures a properly-enabled RGPIO port pin as an output
- Clearing any bit in RGPIO\_DIR configures a properly-enabled RGPIO port pin as an input

At reset, all bits in the RGPIO\_DIR are cleared.

Address: RGPIO\_DIR is C00000h base + 0h offset = 00C0\_0000h



### **RGPIO\_DIR** field descriptions

| Field       | Description                                                |
|-------------|------------------------------------------------------------|
| 15–0<br>DIR | Data direction                                             |
|             | 0 A properly-enabled RGPIO pin is configured as an input.  |
|             | 1 A properly-enabled RGPIO pin is configured as an output. |

# 45.3.3 RGPIO Data Register (RGPIO\_DATA)

The read/write RGPIO\_DATA register specifies the write data for a properly-enabled RGPIO output pin or the sampled read data value for a properly-enabled input pin. An attempted read of the RGPIO\_DATA register returns undefined data for disabled pins because the data value depends on the chip-level pin muxing and pad implementation. At reset, all bits in the RGPIO\_DATA registers are cleared.

To set bits in the RGPIO\_DATA register, directly set the RGPIO\_DATA bits or set the corresponding bits in the RGPIO\_SET register. To clear bits in the RGPIO\_DATA register, directly clear the RGPIO\_DATA bits or clear the corresponding bits in the RGPIO\_CLR register. Setting a bit in the RGPIO\_TOG register inverts (toggles) the state of the corresponding bit in the RGPIO\_DATA register.





### RGPIO\_DATA field descriptions

| Field        | Description                                                                                                                                                                                                                                                                                            |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15–0<br>DATA | <ul> <li>RGPIO data</li> <li>A properly-enabled RGPIO output pin is driven with a logic 0, or a properly-enabled RGPIO input pin was read as a logic 0.</li> <li>A properly-enabled RGPIO output pin is driven with a logic 1, or a properly-enabled RGPIO input pin was read as a logic 1.</li> </ul> |

# 45.3.4 RGPIO Pin Enable Register (RGPIO\_ENB)

The read/write RGPIO\_ENB register configures the corresponding package pin as an RGPIO pin instead of the normal GPIO pin mapped onto the peripheral bus.

#### **Memory Map and Registers**

At reset, all bits in the RGPIO\_ENB register are cleared, disabling the RGPIO functionality.

Address: RGPIO\_ENB is C00000h base + 4h offset = 00C0\_0004h



### RGPIO\_ENB field descriptions

| Field       | Description                                                                                                                                                                                   |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15–0<br>ENB | Enable pin for RGPIO                                                                                                                                                                          |
|             | <ul> <li>The corresponding package pin is configured for use as a normal GPIO pin, not an RGPIO pin.</li> <li>The corresponding package pin is configured for use as an RGPIO pin.</li> </ul> |

# 45.3.5 RGPIO Clear Data Register (RGPIO\_CLR)

The RGPIO\_CLR register provides a mechanism to clear specific bits in the RGPIO\_DATA by performing a simple write. Clearing a bit in RGPIO\_CLR clears the corresponding bit in the RGPIO\_DATA register. Setting it has no effect. The RGPIO\_CLR register is write-only; reads of this address return the RGPIO\_DATA register.

Address: RGPIO\_CLR is C00000h base + 6h offset = 00C0\_0006h



- \* Notes:
- x = Undefined at reset.

#### **RGPIO CLR field descriptions**

| Field       | Description                                                                      |
|-------------|----------------------------------------------------------------------------------|
| 15–0<br>CLR | Clear data  Clears the corresponding bit in the RGPIO_DATA register.  No effect. |

### 45.3.2 RGPIO Data Direction Register (RGPIO\_DIR)

Reading this read-only register returns the value of the RGPIO\_DIR register at offset 0h.

Address: RGPIO\_DIR is C00000h base + 8h offset = 00C0\_0008h



### **RGPIO\_DIR field descriptions**

| Field       | Description                                                                                                                         |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------|
| 15–0<br>DIR | Data direction  O A properly-enabled RGPIO pin is configured as an input.  A properly-enabled RGPIO pin is configured as an output. |

# 45.3.6 RGPIO Set Data Register (RGPIO\_SET)

The RGPIO\_SET register provides a mechanism to set specific bits in the RGPIO\_DATA register by performing a simple write. Setting a bit in RGPIO\_SET asserts the corresponding bit in the RGPIO\_DATA register. Clearing it has no effect. The RGPIO\_SET register is write-only; reads of this address return the RGPIO\_DATA register.

Address: RGPIO\_SET is C00000h base + Ah offset = 00C0\_000Ah



<sup>\*</sup> Notes:

#### RGPIO\_SET field descriptions

| Field       | Description                                              |
|-------------|----------------------------------------------------------|
| 15–0<br>SET | Set data                                                 |
|             | 0 No effect.                                             |
|             | 1 Sets the corresponding bit in the RGPIO_DATA register. |

<sup>•</sup> x = Undefined at reset.

### 45.3.8 RGPIO Data Direction Register (RGPIO\_DIR)

Reading this read-only register returns the value of the RGPIO\_DIR register at offset 0h.

Address: RGPIO\_DIR is C00000h base + Ch offset = 00C0\_000Ch



### **RGPIO\_DIR field descriptions**

| Field       | Description                                                                                                                           |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------|
| 15–0<br>DIR | Data direction  O A properly-enabled RGPIO pin is configured as an input.  1 A properly-enabled RGPIO pin is configured as an output. |

# 45.3.7 RGPIO Toggle Data Register (RGPIO\_TOG)

The RGPIO\_TOG register provides a mechanism to invert (toggle) specific bits in the RGPIO\_DATA register by performing a simple write. Setting a bit in RGPIO\_TOG inverts the corresponding bit in the RGPIO\_DATA register. Clearing it has no effect. The RGPIO\_TOG register is write-only; reads of this address return the RGPIO\_DATA register.

Address: RGPIO\_TOG is C00000h base + Eh offset = 00C0\_000Eh



<sup>\*</sup> Notes:

### RGPIO\_TOG field descriptions

| Field       | Description                                   |
|-------------|-----------------------------------------------|
| 15–0<br>TOG | Toggle data                                   |
|             | 0 No effect                                   |
|             | 1 Inverts the corresponding bit in RGPIO_DATA |

<sup>•</sup> x = Undefined at reset.

# 45.4 Functional Description

The RGPIO module is a relatively-simple design with its behavior controlled by the program-visible registers defined within its programming model.

The RGPIO module is connected to the processor's local two-stage pipelined bus with the stages of the ColdFire core's operand execution pipeline (OEP) mapped directly onto the bus. This structure allows the processor access to the RGPIO module for single-cycle pipelined reads and writes with a zero wait-state response (as viewed in the system bus data phase stage).

### 45.5 Initialization Information

The reset state of the RGPIO module disables the entire 16-bit data port. Prior to using the RGPIO port, software typically:

- Enables the appropriate pins in RGPIO\_ENB
- Configures the pin direction in RGPIO\_DIR
- Defines the contents of the data register (RGPIO\_DATA)

# 45.6 Application Information

This section examines the relative performance of the RGPIO output pins for two simple applications

- The processor executes a loop to toggle an output pin for a specific number of cycles, producing a square-wave output
- The processor transmits a 16-bit message using a three-pin SPI-like interface with a serial clock, serial chip select, and serial data bit.

In both applications, the relative speed of the GPIO output is presented as a function of the location of the output bit (RGPIO versus peripheral bus GPIO).

# 45.6.1 Application 1: Simple Square-Wave Generation

In this example, several different instruction loops are executed, each generating a square-wave output with a 50% duty cycle. For this analysis, the executed code is mapped into the processor's RAM. This configuration is selected to remove any jitter from the output square wave caused by the limitations defined by the two-cycle flash memory accesses and restrictions on the initiation of a flash access. The following instruction loops were studied:

- BCHG\_LOOP In this loop, a bit change instruction was executed using the GPIO data byte as the operand. This instruction performs a read-modify-write operation and inverts the addressed bit. A pulse counter is decremented until the appropriate number of square-wave pulses have been generated.
- SET+CLR\_LOOP For this construct, two store instructions are executed: one to set the GPIO data pin and another to clear it. Single-cycle NOP instructions (the tpf opcode) are included to maintain the 50% duty cycle of the generated square wave. The pulse counter is decremented until the appropriate number of square-wave pulse have been generated.

The square-wave output frequency was measured and the relative performance results are presented in the following table. The relative performance is stated as a fraction of the processor's operating frequency, defined as f MHz. The performance of the BCHG loop operating on a GPIO output is selected as the reference.

Peripheral Bus-mapped GPIO **RGPIO** Sq-Wave Frequency @ Relative Sq-Wave Frequency @ Relative Loop Frequency CPU f = 50 MHzSpeed Frequency CPU f = 50 MHzSpeed  $(1/24) \times f \text{ MHz}$ 2.083 MHz 1.00x  $(1/14) \times f MHz$ 3.571 MHz 1.71x bchg set+clr (+toggle)  $(1/12) \times f MHz$ 4.167 MHz 2.00x  $(1/8) \times f MHz$ 6.250 MHz 3.00x

Table 45-12. Square-Wave Output Performance

#### **Note**

The square-wave frequency is measured from rising-edge to rising-edge, where the output wave has a 50% duty cycle.

### 45.6.2 Application 2: 16-bit Message Transmission using SPI Protocol

In this second example, a 16-bit message is transmitted using three programmable output pins. The output pins include a serial clock, an active-high chip select, and the serial data bit. The software is configured to sample the serial data bit at the rising-edge of the clock with the data sent in a most-significant to least-significant bit order. The resulting 3-bit output is shown in the following figure.



Figure 45-10. GPIO SPI Example Timing Diagram

For this example, the processing of the SPI message is considerably more complex than the generation of a simple square wave of the previous example. The code snippet used to extract the data bit from the message and build the required GPIO data register writes is shown in the following example.

# subtest: send a 16-bit message via a SPI interface using a RGPIO

```
# the SPI protocol uses a 3-bit value: clock, chip-select, data
                      # the data is centered around the rising-edge of the clock
                              align
                      send 16b spi message rgpio:
                                      -12(%sp),%sp
00510: 4fef fff4
                              lea
                                                          # allocate stack space
00514: 48d7 008c
                              movm.l &0x8c,(%sp)
                                                          # save d2,d3,d7
00518: 3439 0080 0582
                              mov.w
                                      RAM_BASE+message2,%d2 # get 16-bit message
0051e: 760f
                                      &15,%d3
                                                          # static shift count
                              movq.1
00520: 7e10
                              movq.l
                                     &16,%d7
                                                          # message bit length
00522: 207c 00c0 0003
                                      &RGPIO_DATA+1,%a0  # pointer to low-order data byte
                              mov.l
                                      \&0xffff, %d0
00528: 203c 0000 ffff
                              mov.1
                                                         # data value for ENB and DIR regs
0052e: 3140 fffd
                                                          # set RGPIO_DIR register
                                      %d0,-3(%a0)
                              mov.w
                                                          # set RGPIO_ENB register
00532: 3140 0001
                              mov.w
                                      %d0,1(%a0)
00536: 223c 0001 0000
                              mov.l
                                      &0x10000,%d1
                                                          # d1[17:16] = \{clk, cs\}
                                                          # copy into temp reg
0053c: 2001
                              mov.l
                                      %d1,%d0
                                      %d3,%d0
                                                          # align in d0[2:0]
0053e: e6a8
                              lsr.l
00540: 5880
                              addq.l
                                      &4,%d0
                                                          \# set clk = 1
00542: 1080
                              mov.b
                                      %d0,(%a0)
                                                          # initialize data
00544: 6002
                              bra.b
                                      T.%1
                              align
                      T.%1:
00548: 3202
                              mov.w
                                      %d2,%d1
                                                          \# d1[17:15] = \{clk, cs, data\}
0054a: 2001
                              mov.1
                                      %d1,%d0
                                                          # copy into temp reg
0054c: e6a8
                                      %d3,%d0
                              lsr.l
                                                          # align in d0[2:0]
0054e: 1080
                              mov.b
                                      %d0,(%a0)
                                                          # transmit data with clk = 0
00550: 5880
                              addq.l
                                      &4,%d0
                                                           # force clk = 1
00552: e38a
                              lsl.l
                                      &1,%d2
                                                           # d2[15] = new message data bit
00554: 51fc
                              tpf
                                                           # preserve 50% duty cycle
00556: 51fc
                              tpf
                              tpf
00558: 51fc
0055a: 51fc
                              tpf
                                      %d0,(%a0)
0055c: 1080
                              mov.b
                                                           # transmit data with clk = 1
                                      &1,%d7
                                                           # decrement loop counter
0055e: 5387
                              subq.1
00560: 66e6
                              bne.b
                                      L%1
```

#### **Application Information**

| 00562: c0bc 0000 fff5<br>00568: 1080 | and.1 &0xfff5,%d0<br>mov.b %d0,(%a0)  | <pre># negate chip-select # update gpio</pre>          |
|--------------------------------------|---------------------------------------|--------------------------------------------------------|
| 0056a: 4cd7 008c<br>0056e: 4fef 000c | movm.l (%sp),&0x8c<br>lea 12(%sp),%sp | <pre># restore d2,d3,d7 # deallocate stack space</pre> |
| 00572: 4e75                          | rts                                   |                                                        |

The resulting SPI performance, as measured in the effective Mbps transmission rate for the 16-bit message, is shown in the following table.

Table 45-13. Emulated SPI Performance using GPIO Outputs

| Peripheral Bus-mapped GPIO |          | RGPIO                 |          |  |
|----------------------------|----------|-----------------------|----------|--|
| SPI Speed @                | Relative | SPI Speed @           | Relative |  |
| CPU <i>f</i> = 50 MHz      | Speed    | CPU <i>f</i> = 50 MHz | Speed    |  |
| 2.063 Mbps                 | 1.00x    | 3.809 Mbps            | 1.29x    |  |

# Chapter 46 Enhanced GPIO (EGPIO)

### 46.1 Introduction

This section explains software controls related to parallel input/output (I/O) and pin control. Refer to the device's data sheet for more information about pin assignments and external hardware considerations for these pins.

In addition to standard I/O port functionality, some ports have set, clear, and toggle functions that are integrated as part of the ColdFire core itself to improve edge resolution on those pins. For additional information, see the Functional description and the description of Rapid GPIO (RGPIO). Refer to Port Mux details to identify the specific ports that have this additional RGPIO functionality.

Many port pins are shared with on-chip peripherals such as timer systems, communication systems, or keyboard interrupts as shown in Figure 46-1. The peripheral modules have priority over general-purpose I/O functions. When a peripheral is enabled, the I/O functions associated with the shared pins may be disabled.

After reset, the shared peripheral functions are disabled and the pins are configured as inputs (each PTDDn bit is 0). The pin control functions for each pin are configured as follows: slew rate control is disabled (each PTSREn bit is 0), low drive strength is selected (each PTDSn bit is 0), and internal pulls are disabled (each PTPUEn bit is 0).

#### **Note**

Not all general-purpose I/O pins are available on all packages. To avoid extra current drain from floating input pins, the user's reset initialization routine in the application program must either enable on-chip pullup devices or change the direction of unconnected pins to outputs, so the pins do not float.

### 46.2 Overview

The second generation parallel input/output, EGPIO, is a purely digital module (synthesizable for all technologies) present at both sides of the multiplex control module, as shown in the following figure.



Figure 46-1. Top-level interface of EGPIO

### 46.2.1 Features

The EGPIO includes four main functions with these features:

- Port data logic
  - Pin input data mapped to, and output data controlled through, port data (D) register
  - Independent directional control per pin through data direction (DD) register
  - Independent pin value (PV) register to read logic level on digital pin
- Independent port control

- Independent internal input pulling resistor enable per pin through pulling enable (PUE) register
- Independent internal input pullup/pulldown select per pin through pullup/pulldown select (PUS) register
- Independent output slew rate control per pin through slew rate enable (SRE) register
- Independent output drive strength control per pin through drive strength control (DS) register
- Independent input passive filter per pin through PFE register

### • Pin interrupt

- Pin interrupt for each pin with individual flag and individual enable bit
- Each pin is programmable as falling edge (or rising edge) only, or both falling edge and low level (or both rising edge and high level) interrupt sensitivity.
- One software-enabled interrupt to CPU
- One asynchronous interrupt to wake the CPU from low-power mode
- DMA interface to support transfer by DMA
- Digital filters
  - Digital filter for each pin if configured as input with individual enable bit in DFE register
  - Programmable digital filtering frequency through DFC register

### 46.2.2 Modes of operation

The section defines the EGPIO operation in wait, stop, and background debug modes.

**Memory Map and Registers** 

### 46.2.2.1 Operation in wait mode

All EGPIO functions continue to operate in wait mode if enabled before execution of the WAIT instruction. If a pin DMA request is not enabled (the PTDMAEN bit is 0), an enabled interrupt pin (the corresponding PTIPEn bit is 1) can be used to bring the MCU out of wait mode if the interrupt of EGPIO is enabled (the PTIE bit is 1).

### 46.2.2.2 Operation in stop mode

The pin interrupt function operates asynchronously in stop mode if enabled before execution of the STOP instruction. Therefore, an enabled interrupt pin (the corresponding PTIPEn bit is 1) can be used to bring the MCU out of stop mode if the interrupt of EGPIO is enabled (the PTIE bit is 1) and either the digital filter on this pin is disabled (bypass mode) or the digital filter continues to operate on the LPO clock.

The digital filter continues to operate if it is enabled and the LPO clock is selected for digital filtering before entry to stop mode.

# 46.2.2.3 Operation in active background mode

When the MCU is in active background mode, all EGPIO functions continue to operate normally.

# 46.3 Memory Map and Registers

#### **PCTL** memory map

| Absolute address (hex) | Register name                                    | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|------------------------|--------------------------------------------------|--------------------|--------|-------------|------------------|
| FFFF_9200              | Port Pulling Enable Register (PCTLA_PUE)         | 8                  | R/W    | 00h         | 46.3.1/<br>1190  |
| FFFF_9201              | Port Pullup/Pulldown Select Register (PCTLA_PUS) | 8                  | R/W    | 00h         | 46.3.2/<br>1191  |
| FFFF_9202              | Port Drive Strength Enable Register (PCTLA_DS)   | 8                  | R/W    | 00h         | 46.3.3/<br>1191  |
| FFFF_9203              | Port Slew Rate Enable Register (PCTLA_SRE)       | 8                  | R/W    | 00h         | 46.3.4/<br>1192  |

Table continues on the next page...

### **PCTL** memory map (continued)

| Absolute address (hex) | Register name                                    | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|------------------------|--------------------------------------------------|--------------------|--------|-------------|------------------|
| FFFF_9204              | Port Passive Filter Enable Register (PCTLA_PFE)  | 8                  | R/W    | FFh         | 46.3.5/<br>1192  |
| FFFF_9205              | Port Interrupt Control Register (PCTLA_IC)       | 8                  | R/W    | 00h         | 46.3.6/<br>1193  |
| FFFF_9206              | Port Interrupt Pin Enable Register (PCTLA_IPE)   | 8                  | R/W    | 00h         | 46.3.7/<br>1194  |
| FFFF_9207              | Port Interrupt Flag Register (PCTLA_IF)          | 8                  | R/W    | 00h         | 46.3.8/<br>1195  |
| FFFF_9208              | Interrupt Edge Select Register (PCTLA_IES)       | 8                  | R/W    | 00h         | 46.3.9/<br>1196  |
| FFFF_9209              | Reserved                                         |                    |        |             |                  |
| FFFF_920A              | Reserved                                         |                    |        |             |                  |
| FFFF_9210              | Port Pulling Enable Register (PCTLB_PUE)         | 8                  | R/W    | 00h         | 46.3.1/<br>1190  |
| FFFF_9211              | Port Pullup/Pulldown Select Register (PCTLB_PUS) | 8                  | R/W    | 00h         | 46.3.2/<br>1191  |
| FFFF_9212              | Port Drive Strength Enable Register (PCTLB_DS)   | 8                  | R/W    | 00h         | 46.3.3/<br>1191  |
| FFFF_9213              | Port Slew Rate Enable Register (PCTLB_SRE)       | 8                  | R/W    | 00h         | 46.3.4/<br>1192  |
| FFFF_9214              | Port Passive Filter Enable Register (PCTLB_PFE)  | 8                  | R/W    | FFh         | 46.3.5/<br>1192  |
| FFFF_9215              | Port Interrupt Control Register (PCTLB_IC)       | 8                  | R/W    | 00h         | 46.3.6/<br>1193  |
| FFFF_9216              | Port Interrupt Pin Enable Register (PCTLB_IPE)   | 8                  | R/W    | 00h         | 46.3.7/<br>1194  |
| FFFF_9217              | Port Interrupt Flag Register (PCTLB_IF)          | 8                  | R/W    | 00h         | 46.3.8/<br>1195  |
| FFFF_9218              | Interrupt Edge Select Register (PCTLB_IES)       | 8                  | R/W    | 00h         | 46.3.9/<br>1196  |
| FFFF_9219              | Port Digital Filter Enable Register (PCTLB_DFE)  | 8                  | R/W    | 00h         | 46.3.10/<br>1196 |
| FFFF_921A              | Port Digital Filter Control Register (PCTLB_DFC) | 8                  | R/W    | 00h         | 46.3.11/<br>1197 |
| FFFF_9220              | Port Pulling Enable Register (PCTLC_PUE)         | 8                  | R/W    | 00h         | 46.3.1/<br>1190  |
| FFFF_9221              | Port Pullup/Pulldown Select Register (PCTLC_PUS) | 8                  | R/W    | 00h         | 46.3.2/<br>1191  |

Table continues on the next page...

### **Memory Map and Registers**

# PCTL memory map (continued)

| Absolute address (hex) | Register name                                    | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|------------------------|--------------------------------------------------|--------------------|--------|-------------|------------------|
| FFFF_9222              | Port Drive Strength Enable Register (PCTLC_DS)   | 8                  | R/W    | 00h         | 46.3.3/<br>1191  |
| FFFF_9223              | Port Slew Rate Enable Register (PCTLC_SRE)       | 8                  | R/W    | 00h         | 46.3.4/<br>1192  |
| FFFF_9224              | Port Passive Filter Enable Register (PCTLC_PFE)  | 8                  | R/W    | FFh         | 46.3.5/<br>1192  |
| FFFF_9225              | Port Interrupt Control Register (PCTLC_IC)       | 8                  | R/W    | 00h         | 46.3.6/<br>1193  |
| FFFF_9226              | Port Interrupt Pin Enable Register (PCTLC_IPE)   | 8                  | R/W    | 00h         | 46.3.7/<br>1194  |
| FFFF_9227              | Port Interrupt Flag Register (PCTLC_IF)          | 8                  | R/W    | 00h         | 46.3.8/<br>1195  |
| FFFF_9228              | Interrupt Edge Select Register (PCTLC_IES)       | 8                  | R/W    | 00h         | 46.3.9/<br>1196  |
| FFFF_9229              | Port Digital Filter Enable Register (PCTLC_DFE)  | 8                  | R/W    | 00h         | 46.3.10/<br>1196 |
| FFFF_922A              | Port Digital Filter Control Register (PCTLC_DFC) | 8                  | R/W    | 00h         | 46.3.11/<br>1197 |
| FFFF_9230              | Port Pulling Enable Register (PCTLD_PUE)         | 8                  | R/W    | 00h         | 46.3.1/<br>1190  |
| FFFF_9231              | Port Pullup/Pulldown Select Register (PCTLD_PUS) | 8                  | R/W    | 00h         | 46.3.2/<br>1191  |
| FFFF_9232              | Port Drive Strength Enable Register (PCTLD_DS)   | 8                  | R/W    | 00h         | 46.3.3/<br>1191  |
| FFFF_9233              | Port Slew Rate Enable Register (PCTLD_SRE)       | 8                  | R/W    | 00h         | 46.3.4/<br>1192  |
| FFFF_9234              | Port Passive Filter Enable Register (PCTLD_PFE)  | 8                  | R/W    | FFh         | 46.3.5/<br>1192  |
| FFFF_9235              | Port Interrupt Control Register (PCTLD_IC)       | 8                  | R/W    | 00h         | 46.3.6/<br>1193  |
| FFFF_9236              | Port Interrupt Pin Enable Register (PCTLD_IPE)   | 8                  | R/W    | 00h         | 46.3.7/<br>1194  |
| FFFF_9237              | Port Interrupt Flag Register (PCTLD_IF)          | 8                  | R/W    | 00h         | 46.3.8/<br>1195  |
| FFFF_9238              | Interrupt Edge Select Register (PCTLD_IES)       | 8                  | R/W    | 00h         | 46.3.9/<br>1196  |
| FFFF_9239              | Reserved                                         |                    |        |             |                  |
| FFFF_923A              | Reserved                                         |                    |        |             |                  |

## **PCTL** memory map (continued)

| Absolute address (hex) | Register name                                    | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|------------------------|--------------------------------------------------|--------------------|--------|-------------|------------------|
| FFFF_9240              | Port Pulling Enable Register (PCTLE_PUE)         | 8                  | R/W    | 00h         | 46.3.1/<br>1190  |
| FFFF_9241              | Port Pullup/Pulldown Select Register (PCTLE_PUS) | 8                  | R/W    | 00h         | 46.3.2/<br>1191  |
| FFFF_9242              | Port Drive Strength Enable Register (PCTLE_DS)   | 8                  | R/W    | 00h         | 46.3.3/<br>1191  |
| FFFF_9243              | Port Slew Rate Enable Register (PCTLE_SRE)       | 8                  | R/W    | 00h         | 46.3.4/<br>1192  |
| FFFF_9244              | Port Passive Filter Enable Register (PCTLE_PFE)  | 8                  | R/W    | FFh         | 46.3.5/<br>1192  |
| FFFF_9245              | Port Interrupt Control Register (PCTLE_IC)       | 8                  | R/W    | 00h         | 46.3.6/<br>1193  |
| FFFF_9246              | Port Interrupt Pin Enable Register (PCTLE_IPE)   | 8                  | R/W    | 00h         | 46.3.7/<br>1194  |
| FFFF_9247              | Port Interrupt Flag Register (PCTLE_IF)          | 8                  | R/W    | 00h         | 46.3.8/<br>1195  |
| FFFF_9248              | Interrupt Edge Select Register (PCTLE_IES)       | 8                  | R/W    | 00h         | 46.3.9/<br>1196  |
| FFFF_9249              | Reserved                                         |                    |        |             |                  |
| FFFF_924A              | Reserved                                         |                    |        |             |                  |
| FFFF_9250              | Port Pulling Enable Register (PCTLF_PUE)         | 8                  | R/W    | 00h         | 46.3.1/<br>1190  |
| FFFF_9251              | Port Pullup/Pulldown Select Register (PCTLF_PUS) | 8                  | R/W    | 00h         | 46.3.2/<br>1191  |
| FFFF_9252              | Port Drive Strength Enable Register (PCTLF_DS)   | 8                  | R/W    | 00h         | 46.3.3/<br>1191  |
| FFFF_9253              | Port Slew Rate Enable Register (PCTLF_SRE)       | 8                  | R/W    | 00h         | 46.3.4/<br>1192  |
| FFFF_9254              | Port Passive Filter Enable Register (PCTLF_PFE)  | 8                  | R/W    | FFh         | 46.3.5/<br>1192  |
| FFFF_9255              | Port Interrupt Control Register (PCTLF_IC)       | 8                  | R/W    | 00h         | 46.3.6/<br>1193  |
| FFFF_9256              | Port Interrupt Pin Enable Register (PCTLF_IPE)   | 8                  | R/W    | 00h         | 46.3.7/<br>1194  |
| FFFF_9257              | Port Interrupt Flag Register (PCTLF_IF)          | 8                  | R/W    | 00h         | 46.3.8/<br>1195  |
| FFFF_9258              | Interrupt Edge Select Register (PCTLF_IES)       | 8                  | R/W    | 00h         | 46.3.9/<br>1196  |

Table continues on the next page...

#### **Memory Map and Registers**

#### PCTL memory map (continued)

| Absolute<br>address<br>(hex) | Register name | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|------------------------------|---------------|--------------------|--------|-------------|------------------|
| FFFF_9259                    | Reserved      |                    |        |             |                  |
| FFFF_925A                    | Reserved      |                    |        |             |                  |

# 46.3.1 Port Pulling Enable Register (PCTLx\_PUE)



#### PCTLx\_PUE field descriptions

| Field             | Description                                                                                                                                                                                                                                   |
|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–0<br>PTPUE[7:0] | Port internal pulling enable bits  Each pin has a pullup and pulldown resistor associated with it. For port pins that are not configured as inputs, these bits have no effect and the internal pull resistors are disabled.                   |
|                   | If there is no special note or description for the module that controls the pin whether a pulling resistor is enabled for the module, it is decided by the associated PUE bit.  O Pulling resistor is disabled.  Pulling resistor is enabled. |

## 46.3.2 Port Pullup/Pulldown Select Register (PCTLx\_PUS)



#### PCTLx\_PUS field descriptions

| Field             | Description                                                                                                                                                                                                             |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–0<br>PTPUS[7:0] | Port pullup/pulldown select bits  Each bit selects the pullup or pulldown resistor enabled by the corresponding PUE bit. For port pins that are not configured as inputs, these bits have no effect.                    |
|                   | If there is no special note or description for the module that controls the pin, the selection of pullup/pulldown is decided by the associated PUS bit.  O Pulldown resistor is selected.  Pullup resistor is selected. |

# 46.3.3 Port Drive Strength Enable Register (PCTLx\_DS)



#### **Memory Map and Registers**

#### PCTLx\_DS field descriptions

| Field            | Description                                                                                                                                                               |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–0<br>PTDS[7:0] | Port output drive strength control bits                                                                                                                                   |
|                  | Each of these control bits selects between low and high output drive for the associated port pin. For port pins that are configured as inputs, these bits have no effect. |
|                  | 0 Low output drive strength selected.                                                                                                                                     |
|                  | 1 High output drive strength selected.                                                                                                                                    |

## 46.3.4 Port Slew Rate Enable Register (PCTLx\_SRE)



#### PCTLx SRE field descriptions

| Field             | Description                                                                                                                                                                                     |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–0<br>PTSRE[7:0] | Port output slow rate enable bits                                                                                                                                                               |
|                   | Each of these control bits determines whether the output slew rate control is enabled for the associated port pin. For port pins that are not configured as outputs, these bits have no effect. |
|                   | 0 Slew rate control disabled.                                                                                                                                                                   |
|                   | 1 Slew rate control enabled.                                                                                                                                                                    |

## 46.3.5 Port Passive Filter Enable Register (PCTLx\_PFE)

The PFE register enables control of the input low-pass filter on the pad. The filter is enabled by setting the bit corresponding to a given pin. When set high, a low pass filter (10 MHz to 30 MHz bandwidth) is enabled in the logic input path. When set low, the filter is bypassed.

The filter is enabled during and after reset by setting the associated PTPFE bit. The filter is disabled through software control by clearing the associated PTPFE bit.



#### PCTLx\_PFE field descriptions

| Field             | Description                                                                                                                           |
|-------------------|---------------------------------------------------------------------------------------------------------------------------------------|
| 7–0<br>PTPFE[7:0] | Port passive input filter enable bits                                                                                                 |
| 1 111 [[1.0]      | These bits enable control of input low-pass filters for port pins. For port pins not configured as inputs, these bits have no effect. |
|                   | 0 Input low-pass filter on pad disabled.                                                                                              |
|                   | 1 Input low-pass filter on pad enabled.                                                                                               |

# 46.3.6 Port Interrupt Control Register (PCTLx\_IC)

Addresses: PCTLA\_IC is FFFF\_9200h base + 5h offset = FFFF\_9205h
PCTLB\_IC is FFFF\_9210h base + 5h offset = FFFF\_9215h
PCTLC\_IC is FFFF\_9220h base + 5h offset = FFFF\_9225h
PCTLD\_IC is FFFF\_9230h base + 5h offset = FFFF\_9235h
PCTLE\_IC is FFFF\_9240h base + 5h offset = FFFF\_9245h
PCTLF\_IC is FFFF\_9250h base + 5h offset = FFFF\_9255h



#### **Memory Map and Registers**

#### PCTLx\_IC field descriptions

| Field           | Description                                                                                                                                                                                                                                                                         |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>PTDMAEN    | DMA enable                                                                                                                                                                                                                                                                          |
|                 | Determines whether the pin DMA request is enabled. If it is enabled, the pin DMA request is asserted when an interrupt flag of any pin is set (at least one bit of the IF register is set). Meanwhile, a synchronous interrupt from the IF register is disabled if this bit is set. |
|                 | 0 Pin DMA request is disabled and synchronous interrupt from IF is allowed.                                                                                                                                                                                                         |
|                 | 1 Pin DMA request is enabled and synchronous interrupt from IF is disabled.                                                                                                                                                                                                         |
| 6–2<br>Reserved | This read-only bitfield is reserved and always has the value zero.                                                                                                                                                                                                                  |
| 1               | Interrupt enable                                                                                                                                                                                                                                                                    |
| PTIE            | Determines whether a pin interrupt is requested to the CPU.                                                                                                                                                                                                                         |
|                 | 0 Pin interrupt request not enabled.                                                                                                                                                                                                                                                |
|                 | 1 Pin interrupt request enabled.                                                                                                                                                                                                                                                    |
| 0<br>PTMOD      | Direction mode for pin interrupt                                                                                                                                                                                                                                                    |
|                 | This bit (along with the EDG bits) controls the detection mode of the pin interrupt for pins.                                                                                                                                                                                       |
|                 | 0 Pin interrupt detects edges only.                                                                                                                                                                                                                                                 |
|                 | 1 Pin interrupt detects both edges and levels.                                                                                                                                                                                                                                      |

## 46.3.7 Port Interrupt Pin Enable Register (PCTLx\_IPE)

This register's bits enable control of pin interrupts.



## PCTLx\_IPE field descriptions

| Field      | Description                                                       |
|------------|-------------------------------------------------------------------|
| 7–0        | Interrupt pin enables                                             |
| PTIPE[7:0] | Each PTIPE bit enables the corresponding pin for a pin interrupt. |

#### PCTLx\_IPE field descriptions (continued)

| Field | Description                          |
|-------|--------------------------------------|
|       | 0 Pin not enabled for pin interrupt. |
|       | 1 Pin enabled for pin interrupt.     |

## 46.3.8 Port Interrupt Flag Register (PCTLx\_IF)

This register contains the interrupt flag bits for pin interrupts.



#### PCTLx\_IF field descriptions

| Field            | Description                                                                                                                                                                                                                                                                                          |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–0<br>PTIF[7:0] | Interrupt flags Indicate whether a pin interrupt condition is detected on each input pin if the interrupt is enabled by the associated PTIPE bit. Writing 1 to one bit clears the associated PTIF bit if it is set.  O No condition of pin interrupt detected.  Condition of pin interrupt detected. |

## 46.3.9 Interrupt Edge Select Register (PCTLx\_IES)

This register contains the edge select control bits.



#### PCTLx\_IES field descriptions

| Field             | Description                                                                                                                                 |
|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| 7–0<br>PTEDG[7:0] | Edge selects of pin interrupt  Each EDG bit selects the falling edge/low level or rising edge/high level function of the corresponding pin. |
|                   | <ul><li>Falling edge/low level.</li><li>Rising edge/high level.</li></ul>                                                                   |

# 46.3.10 Port Digital Filter Enable Register (PCTLx\_DFE)

This register contains the enable control bits for digital filters.

#### NOTE

Only ports B and C have this register.

Addresses: PCTLB\_DFE is FFFF\_9210h base + 9h offset = FFFF\_9219h

PCTLC\_DFE is FFFF\_9220h base + 9h offset = FFFF\_9229h



#### PCTLx\_DFE field descriptions

| Field             | Description                                                                                                                                                                                                                                                                                                                        |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–0<br>PTDFE[7:0] | Digital filter enables                                                                                                                                                                                                                                                                                                             |
|                   | Each PTDFE bit enables the digital filter on the pin when the pin is configured as an input. If the pin is not configured as an input, the digital filter circuit is not used. When enabled, the digital filter is included in the signal path to EGPIO and any module that gets control of the pin and configures it as an input. |
|                   | <ul><li>0 Digital filter disabled (bypass mode).</li><li>1 Digital filter enabled.</li></ul>                                                                                                                                                                                                                                       |

# 46.3.11 Port Digital Filter Control Register (PCTLx\_DFC)

This register contains the control bits to select clock and filter factors for all digital filters of the port.

#### NOTE

Only ports B and C have this register.

Addresses: PCTLB\_DFC is FFFF\_9210h base + Ah offset = FFFF\_921Ah

PCTLC\_DFC is FFFF\_9220h base + Ah offset = FFFF\_922Ah



#### PCTLx\_DFC field descriptions

| Field            | Description                                                                                                                                                                    |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>PTCLKS      | Clock select bit                                                                                                                                                               |
| I TOLKS          | Selects the counting clock for digital filters.                                                                                                                                |
|                  | 0 Digital filters count on the bus clock.                                                                                                                                      |
|                  | 1 Digital filters count on the LPO clock.                                                                                                                                      |
| 6–5<br>Reserved  | This read-only bitfield is reserved and always has the value zero.                                                                                                             |
| 4–0<br>DTEE[4:0] | Filter factor bits                                                                                                                                                             |
| PTFF[4:0]        | Controls the width of the glitch (in terms of clock cycles) the filter should absorb; glitches less than or equal to this width setting are not allowed by the filter to pass. |

Table continues on the next page...

#### **Functional description**

## PCTLx\_DFC field descriptions (continued)

| Field |       | Description     |
|-------|-------|-----------------|
|       | 00000 | 1 clock cycle   |
|       | 00001 | 2 clock cycles  |
|       | 00010 | 3 clock cycles  |
|       | 00011 | 4 clock cycles  |
|       | 00100 | 5 clock cycles  |
|       | 00101 | 6 clock cycles  |
|       | 00110 | 7 clock cycles  |
|       | 00111 | 8 clock cycles  |
|       |       | •••             |
|       | 11000 | 25 clock cycles |
|       | 11001 | 26 clock cycles |
|       | 11010 | 27 clock cycles |
|       | 11011 | 28 clock cycles |
|       | 11100 | 29 clock cycles |
|       | 11101 | 30 clock cycles |
|       | 11110 | 31 clock cycles |
|       | 11111 | 32 clock cycles |

# 46.4 Functional description

This section provides full descriptions for all EGPIO functions.

# 46.4.1 Port data logic

The following figure illustrates port data logic.



Figure 46-79. Diagram of port data logic function

Port data logic applies to the general purpose input/output function, which is the default function for a port pin when no shared on-chip module is enabled and the pin interrupt function is disabled.

Each port has a data register, a data direction register, and a pin value register. Besides the EGPIO pin interrupt function, an I/O port bit may or may not share an I/O pin with another on-chip module. Consult the Signal Multiplexing description for information about pin assignments.

# 46.4.1.1 Operation when EGPIO controls pin

If the pin interrupt for a pin is not enabled (the PTIPE bit is 0), the direction of the pin depends on the associated PTDD bit. When the PTDD bit is 1, data written to the port data (D) register is driven out to the corresponding pad.

If the pin interrupt for a pin is enabled (the PTIPE bit is 1), the direction of the pin is configured as an input and the associated PTDD bit has no effect. In this case, data written to the port data (D) register is not driven out to the corresponding pad. When the associated PTDD bit is cleared, a read of the port data register returns the logic level of the associated pin. When the PTDD bit is set, a read of the port data register returns the last value written to the associated bit of the port data register.

#### **Functional description**

When a port pin is controlled by EGPIO, the port is configured for digital functionality, so reading the the pin value (PV) register always returns the actual logic level on the pads.

## 46.4.1.2 Operation when another on-chip module controls pin

When a pin is controlled by another on-chip module, the PTDD bit associated with the pin does not affect the input or output direction of the pin. However, when the PTDD bit is set, reading the port data (D) register still returns the last value written to the port data register's associated bit. When the PTDD bit is cleared and the port pin is configured for digital functionality, a read of the port data register still returns the actual logic level on the pad.

## 46.4.1.3 Pin value register

For port pins that are configured as digital pins, no matter as input or output, pin value register read always reflects logic level on pads. For port pins that are controlled by analog functions, pin value register read returns zeros (off-value).

#### 46.4.2 Port control

The following figure diagrams the PCTRL function.



Figure 46-80. Diagram of PCTRL function

The pin control registers are CPU-accessible and operate as described in the Memory map and registers.

# 46.4.3 Pin interrupt

The pin interrupt function provides up to eight independently enabled external interrupt sources. The following figure is the block diagram for the pin interrupt function.

#### **Functional description**



Figure 46-81. Diagram of pin interrupt function

The pin interrupt function is included in EGPIO to supersede an existing KBI module. The main difference is that the pin interrupt function is still able to operate only if a port pin is configured as a digital pin even when EGPIO does not control the pin. That means the pin interrupt, if enabled, can operate with another on-chip module at the same time.

When a port pin is controlled by EGPIO, if the pin interrupt is enabled for this pin (the port interrupt pin enable register's bit is 1), the pin is configured as an input. When a port pin is controlled by the digital function of another on-chip module, the pin interrupt, if enabled (the port interrupt pin enable register's bit is 1), still operates because the EGPIO always receives the actual logic level on external pads when the pin is configured for digital use. But special care must be taken when the pin interrupt operates at the same time with other on-chip modules, and it is strongly recommended to disable the pin interrupt function when another on-chip module controls the pin for output function. When a port pin is configured for analog function, the input for the pin interrupt function is zero and it is recommended to disable the pin interrupt function as well.

## 46.4.3.1 Edge only sensitivity

A valid edge on an enabled pin interrupt sets an associated PTIF bit. If the PTDMAEN bit in the IC register is set, a DMA request is asserted. If the PTDMAEN bit is not set and the PTIE bit is set, an interrupt request is presented to the CPU. Clearing a PTIF bit is accomplished by writing 1 to the same bit or when the DMA DONE signal for a pin DMA request is asserted.

## 46.4.3.2 Edge and level sensitivity

A valid edge or level on a pin enabled for pin interrupt sets an associated PTIF bit. If the PTDMAEN bit in the IC register is set, a DMA request is asserted. If the PTDMAEN bit is not set and the PTIE bit is set, an interrupt request is presented to the CPU. Clearing a PTIF bit is accomplished by writing 1 to the same bit or when the DMA DONE signal for a pin DMA request is asserted, provided the associated enabled input of the pin interrupt is at its negated level. During an attempt to clear a PTIF bit, if the associated pin enabled for pin interrupt is asserted, the PTIF bit remains set. Because the DMA process is automatic and negating all enabled inputs before the DMA DONE signal is done is very difficult, it is strongly recommended not to enable a pin DMA request when both edge and level are selected as valid conditions for pin interrupt (the corresponding PTMOD bit is 1).

## 46.4.3.3 Control of pullup/pulldown resistors

The enabled pin interrupt can be configured to use an internal pullup/pulldown resistor with the associated I/O port pulling enable register. When an internal pulling resistor is enabled (the pin is configured as an input and the PTPUE bit is 1), three situations can apply:

- 1. If the EGPIO gets control of the pin and the pin is enabled for pin interrupt, the associated PTEDG bit in the IES register selects whether the resistor is a pullup (the PTEDG bit is 0) or a pulldown (the PTEDG bit is 1).
- 2. If the EGPIO does not get control of the pin or if the pin is not enabled for pin interrupt, the PTEDG bits have no effect.
- 3. If the EGPIO does not get control of the pin and the pin is still enabled for pin interrupt, the PTEDG bits have no effect on selecting pullup/pulldown resistors. Nevertheless, the value of the associated PTEDG bit must match the pullup/pulldown selection on the pad as defined by the module that gets control of the pin: if the module's actual selection is an internal pullup, the PTEDG bit must be cleared, and if

#### **Functional description**

the module's actual selection is an internal pulldown, the PTEDG bit must be set. Without these aligned settings, when there is no drive on the pad outside, false conditions may be detected as valid conditions for pin interrupt.

## 46.4.3.4 Asynchronous interrupt in stop mode

When the MCU enters stop mode, the synchronous edge-detection logic is bypassed (because clocks are stopped). In stop mode, enabled inputs of pin interrupt act as asynchronous level-sensitive inputs so they can wake the MCU from stop mode. In stop mode, the pin interrupt requests are not blocked by the PTDMAEN bit being set to 1.

# 46.4.3.5 Pin interrupt initialization

When an interrupt pin is first enabled or reconfigured, a false interrupt flag can result. To prevent a false interrupt request during pin interrupt initialization, you must perform the following steps:

- 1. Mask port interrupts by clearing the PTIE bit in the IC register.
- 2. Enable the polarity for pin interrupt by setting the appropriate PTEDGn bits in the IES register. If the pin interrupt function operates at the same time with another on-chip module that gets control of the pin, the associated PTEDG bit must be set according to the actual selection of internal pullup (the PTEDG bit must be cleared) or pulldown (the PTEDG bit must be set) on the pad by the module that gets control of the pin.
- 3. If using an internal pullup/pulldown device, configure the associated pulling enable bits in the PUE register.
- 4. Enable the pins for pin interrupt by setting the appropriate bits in the IPE register.
- 5. Execute three NOP instructions before the next step to avoid a timing conflict between setting the IPE register and clearing the flag.
- 6. Write FFh to the IF register to clear any false interrupt flags.
- 7. Enable the DMA request or interrupt request by configuring the IC register.

## 46.4.4 Digital filters

The passive input low-pass filter can filter only signals greater than 10 MHz. EGPIO provides programmable digital filters to filter signals much less than 10 MHz for low-speed applications.

The digital filters absorb glitches on digital pins. For the port pin configured as a digital pin, the digital filter is enabled for the pin if the associated bit is set in the port digital filter enable register. For a port pin that is not configured for analog function, the digital filter for the pin is disabled, and the associated bit in the port digital filter enable register has no effect.

The width of the glitch to absorb can be specified in terms of number of filter clock cycles. The bus clock or LPO clock can be selected as a filter clock that is configured by the PTCLKS bit in the port digital filter control register. The width of the glitch to absorb depends on the Filter Factor (FF) bits in the port digital filter control register. Effectively, any down-up-down or up-down-up transition on the digital input line that occurs within the number of clock cycles programmed by the filter factor is ignored by on-chip modules. For details, see the description of the port digital filter control register.

Because the configuration of the port digital filter control register is for all digital filters of the port, changing the port digital filter control register affects all digital filters of the port if enabled. Configuration of the port digital filter control register must occur when no digital filter is active (the port digital filter enable register is 00h).

The LPO clock can operate in stop mode; if the digital filter works in stop mode, the PTCLKS bit must be set before the entry to stop mode.

## 46.4.4.1 Initialization of digital filters

When a digital filter for a port pin is enabled from a disabled state or pin control is changed from one module to another module while the digital filter is active, some enabled modules may get a false input. To prevent a false input to on-chip modules and related errors during initialization of digital filters, you must do the following to enable the digital filter for input of the target module:

- 1. Write 0 to the PTDFE bit to disable the digital filter for the pin, if it is active.
- 2. Write 0 to the PTIPE bit to disable the pin interrupt function, if it is enabled.
- 3. Disable other on-chip modules that have higher priority for pin control than the target module.
- 4. Write 1 to the associated pin enable bit of the target module, if it is not enabled.

#### Reset

- 5. Follow the flow for initialization of the pin interrupt if you still want the pin interrupt function working with the target module.
- 6. Write 1 to the associated PTDFE bit to enable the digital filter for the pin.

The preceding flow assumes that selection of the filter clock and filter factor do not change and the target module is an on-chip module other than EGPIO.

If you enable the pin interrupt function of EGPIO on a port pin when the digital filter for the pin is active for the input of another on-chip module, you must follow the initialization of the pin interrupt.

If you enable only a digital filter for EGPIO input, you must perform the following steps:

- 1. Write 0 to the PTDFE bit to disable the digital filter for the pin, if it is active.
- 2. Disable other on-chip modules that have higher priority for pin control than EGPIO.
- 3. Follow initialization of the pin interrupt if you enable the pin interrupt function on this port pin.
- 4. Write 1 to the PTDFE bit to enable the digital filter for the pin.

#### 46.5 Reset

The EGPIO module is reset automatically by any MCU reset.

The EGPIO module cannot cause an MCU reset.

Regarding EGPIO registers:

- The IFE register resets to FFh to disable passive low-pass filters on pads.
- The PV register is unaffected by reset. For details, refer to the register's description.
- A reset clears all other EGPIO registers.

# **Chapter 47 EGPIO Port Control**

#### 47.1 Introduction

Registers for EGPIO control are in two groups. Registers for general port (pin) control are described here. Refer to Introduction for more information about both sets of registers and about parallel I/O control in general.

# 47.2 Memory Map and Registers

#### PT memory map

| Absolute address (hex) | Register name                         | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|------------------------|---------------------------------------|--------------------|--------|-------------|------------------|
| FFFF_8000              | Port Data Register (PTA_D)            | 8                  | R/W    | 00h         | 47.2.1/<br>1208  |
| FFFF_8001              | Port Data Direction Register (PTA_DD) | 8                  | R/W    | 00h         | 47.2.2/<br>1209  |
| FFFF_8002              | Port Pin Value Register (PTA_PV)      | 8                  | R      | See section | 47.2.3/<br>1210  |
| FFFF_8010              | Port Data Register (PTB_D)            | 8                  | R/W    | 00h         | 47.2.1/<br>1208  |
| FFFF_8011              | Port Data Direction Register (PTB_DD) | 8                  | R/W    | 00h         | 47.2.2/<br>1209  |
| FFFF_8012              | Port Pin Value Register (PTB_PV)      | 8                  | R      | See section | 47.2.3/<br>1210  |
| FFF_8020               | Port Data Register (PTC_D)            | 8                  | R/W    | 00h         | 47.2.1/<br>1208  |
| FFFF_8021              | Port Data Direction Register (PTC_DD) | 8                  | R/W    | 00h         | 47.2.2/<br>1209  |
| FFFF_8022              | Port Pin Value Register (PTC_PV)      | 8                  | R      | See section | 47.2.3/<br>1210  |

#### **Memory Map and Registers**

#### PT memory map (continued)

| Absolute<br>address<br>(hex) | Register name                         | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|------------------------------|---------------------------------------|--------------------|--------|-------------|------------------|
| FFFF_8030                    | Port Data Register (PTD_D)            | 8                  | R/W    | 00h         | 47.2.1/<br>1208  |
| FFFF_8031                    | Port Data Direction Register (PTD_DD) | 8                  | R/W    | 00h         | 47.2.2/<br>1209  |
| FFFF_8032                    | Port Pin Value Register (PTD_PV)      | 8                  | R      | See section | 47.2.3/<br>1210  |
| FFFF_8040                    | Port Data Register (PTE_D)            | 8                  | R/W    | 00h         | 47.2.1/<br>1208  |
| FFFF_8041                    | Port Data Direction Register (PTE_DD) | 8                  | R/W    | 00h         | 47.2.2/<br>1209  |
| FFFF_8042                    | Port Pin Value Register (PTE_PV)      | 8                  | R      | See section | 47.2.3/<br>1210  |
| FFFF_8050                    | Port Data Register (PTF_D)            | 8                  | R/W    | 00h         | 47.2.1/<br>1208  |
| FFFF_8051                    | Port Data Direction Register (PTF_DD) | 8                  | R/W    | 00h         | 47.2.2/<br>1209  |
| FFFF_8052                    | Port Pin Value Register (PTF_PV)      | 8                  | R      | See section | 47.2.3/<br>1210  |

## 47.2.1 Port Data Register (PTx\_D)

Addresses: PTA\_D is FFFF\_8000h base + 0h offset = FFFF\_8000h
PTB\_D is FFFF\_8010h base + 0h offset = FFFF\_8010h
PTC\_D is FFFF\_8020h base + 0h offset = FFFF\_8020h
PTD\_D is FFFF\_8030h base + 0h offset = FFFF\_8030h
PTE\_D is FFFF\_8040h base + 0h offset = FFFF\_8040h
PTF\_D is FFFF\_8050h base + 0h offset = FFFF\_8050h



- \* Notes:
- PTD[7:0] bitfield:

The reset values of internal registers for D are zeros. However, a read of the D register after reset returns the actual logic level on external pins.

#### PTx\_D field descriptions

| Field           | Description    |
|-----------------|----------------|
| 7–0<br>PTD[7:0] | Port data bits |

#### PTx\_D field descriptions (continued)

| Field | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
|       | Writes are latched into all bits of this register. When port data direction bits for port pins are set (each DD bit is 1), reads return the last value written to this register. When a port pin is controlled by EGPIO with the pin interrupt function disabled, an associated port data direction bit is set (the DD bit is 1). The logic level is driven out to the corresponding MCU pin when port data direction bits for port pins are cleared (each DD bit is 0). For pins that are configured as digital pins, reads return logic level on the pin. For port pins that are controlled by analog functions, reads return zeros (off-value). |  |  |  |  |

<sup>1.</sup> The reset values of internal registers for D are zeros. However, a read of the D register after reset returns the actual logic level on external pins.

## 47.2.2 Port Data Direction Register (PTx\_DD)



#### PTx\_DD field descriptions

| Field            | Description                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–0<br>PTDD[7:0] | Port data direction bits                                                                                                                                                                                                                                                                                                                                                                                                     |
|                  | Each bit of the port data direction register controls whether an associated port pin is an input or output when pin interrupt is disabled and no other module controls the pin. If the DD bit for a port pin is equal to logic one, and Port Data Logic has control of the pin, the port pin is defined as output and the logic value of an internal register for the D register is driven out to the corresponding MCU pin. |
|                  | <ul><li>The port pin is defined only as an input.</li><li>The port pin is defined as an output.</li></ul>                                                                                                                                                                                                                                                                                                                    |

## 47.2.3 Port Pin Value Register (PTx\_PV)



<sup>\*</sup> Notes:

• x = Undefined at reset.

#### PTx\_PV field descriptions

| Field            | Description                                                                                                                                                                                                                                                                           |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–0<br>PTPV[7:0] | Port pin value bits  Each bit of port pin value register is mapped to one MCU pin. For pins that are configured as digital pins, this register always reflects the digital level on the actual PAD. For pins that are controlled by analog functions, reads return zeros (off-value). |

1. A read of the PV register after reset returns the actual logic level on external pins because reset configures all port pins as high-impedance inputs with pullup/pulldown disabled.

<sup>•</sup> A read of the PV register after reset returns the actual logic level on external pins because reset configures all port pins as high-impedance inputs with pullup/pulldown disabled.x = Undefined at reset.

# Chapter 48 Touch Sense Input (TSI)

#### 48.1 Introduction

The touch sensing input (TSI) module provides capacitive touch sensing detection with high sensitivity and enhanced robustness. Each TSI pin implements the capacitive measurement of an electrode having individual programmable detection thresholds and result registers. The TSI module can be functional in several low power modes with ultra low current adder and waking up the CPU in a touch event. It provides a solid capacitive measurement module for the implementation of touch keypad, rotaries and sliders.

#### 48.2 Features

- Support as many as 16 input capacitive touch sensing pins with individual result registers
- Automatic detection of electrode capacitance change with programmable upper and lower threshold
- Automatic periodic scan unit with different duty cycles for run and low power modes
- Full support with FSL touch sensing SW library (TSS) for the implementation of keypads, rotaries and sliders
- Operation across all low power modes: Wait,Stop, VLPR, VLPW, VLPS, LLS,VLLS{3,2,1}
- Capability to wake up MCU from low power modes
- Configurable interrupts:
  - End-of-scan or out-of-range interrupt
  - ullet TSI error interrupts: pad short to  $V_{DD}/V_{SS}$  or conversion overrun
- Compensate temperature and supply voltage variations
- Stand alone operation not requiring any external crystal even in low power modes
- Configurable integration of each electrode capacitance measurement from 1 to 4096 times

#### Overview

- Programmable electrode oscillator and TSI Reference Oscillator for high sensitivity, small scan time and low power functionality
- Only uses one pin per electrode implementation with no external hardware required

#### 48.3 Overview

This section presents an overview of the TSI module. The following figure presents the simplified TSI module block diagram.



Figure 48-1. Touch sensing input block diagram

## 48.3.1 Electrode capacitance measurement unit

The electrode capacitance measurement unit senses the capacitance of a TSI pin and outputs a 16-bit result. This module is based in dual oscillator architecture. One oscillator is connected to the external electrode array and oscillates according to the electrode capacitance, while the other according to an internal reference capacitor. The pin capacitance measurement is given by the counted number of periods of the reference oscillator during a configurable number of oscillations of the external electrode oscillator.

The electrode oscillator charges and discharges the pin capacitance with a programmable 5-bit binary current source in order to accommodate different sizes of electrode capacitance. The electrode oscillator frequency, before being compared to that of the reference oscillator, goes through a prescaler and modulo counter to decrease its frequency and consecutively increase the measurement resolution and noise robustness.

The following figure presents the simplified block diagram of how the electrode capacitance is measured.



Figure 48-2. TSI capacitance measurement unit block diagram

#### 48.3.2 Electrode scan unit

This section describes the functionality of the electrode scan unit. It is responsible for triggering the start of the active electrode scan.

The touch sense input module needs to periodically scan all active electrodes to determine if a touch event has occurred. The electrode scan unit has two independent scan periods, one for TSI active mode and the other for TSI low power mode. This independent control allows the application to configure longer scan period during low power mode, so contributing to smaller average power consumption. The TSI, in low power mode, has the capability to wake the CPU upon an electrode capacitance change. When the CPU wakes, the TSI enters active mode, and produces a shorter scan period for a faster response and more robust touch detection. Apart from the periodical mode, the electrode scan unit also allows software triggering of the electrode scans. This feature is very useful for initialization of the touch application to detect the initial electrode capacitances. This module generates configurable end-of-scan interrupt to indicate the

#### **Modes of operation**

application that all electrodes were scanned. If a new electrode scan is started while the previous one is still in progress, an overrun error flag is generated, TSI continues the previous scan sequence and the latest trigger is ignored.

#### 48.3.3 Touch detection unit

The touch detection unit indicates the change in the pin capacitance. This module compares the pin capacitance value in the result register with a pre-configured low and high threshold. If the capacitance result register value is outside the ranges defined by the upper and lower threshold, the touch detection unit generates an out-of-range flag to indicate a pin capacitance change.

The upper and lower threshold values are configurable allowing the application to select the magnitude of the capacitance change to trigger the out-of-range flag. With the threshold values programmed properly the application noise level does not cause frequent CPU interrupts, so minimizes the CPU touch application usage. This feature also allows the TSI to wake up the CPU from low power modes only in a capacitance change event.

# 48.4 Modes of operation

The TSI module has three operation modes: disabled, active mode and low power mode.

## 48.4.1 TSI disabled mode

When GENCS[TSIEN] is cleared, the TSI module is disabled.

## 48.4.2 TSI active mode

In active mode, the TSI module has its full functionality, being able to scan up to 16 electrodes. The TSI can be in active mode with the MCU in Run, Wait, VLPR, and VLPW modes, and the TSI can run in low power mode (only one electrode scanning in Stop, VLPS, LLS, and VLLSx modes).

Three clock sources can be selected for the TSI module in active mode: BUS\_CLK, MCGIRCLK and OSCERCLK.

## 48.4.3 TSI low power mode

The TSI module enters low power mode if the GENCS[STPE] is set to one and the MCU is programmed into one of the following operational modes: LLS, VLLS1, VLLS2 or VLLS3. In low power mode, only one selectable pin is active, being able to perform capacitance measurements. The scan period is defined by GENCS[LPSCNITV]. Two low power clock sources are available in the TSI low power mode, LPOCLK and VLPOSCCLK, being selected by the GENCS[LPCLKS].

In low power mode the TSI interrupt can also be configured as end-of-scan or out-of-range and the GENCS[TSIIEN] must be set in order to generate these interrupts. The TSI interrupt causes the exit of the low power mode, entrance into the active mode, and the MCU wake up.

In low power mode the electrode scan unit is always configured to periodical low power scan.

## 48.4.4 Block diagram

The following figure shows the block diagram of TSI module.



Figure 48-3. TSI block diagram

# 48.5 TSI signal descriptions

The TSI module has up to 16 external pins for touch sensing. The table below itemizes all the TSI external pins.

Table 48-1. TSI signal descriptions

| Signal       | Description                                                                                                 | 1/0 |
|--------------|-------------------------------------------------------------------------------------------------------------|-----|
| TSI_IN[15:0] | TSI pins. Switchable driver that connects directly to the electrode pins TSI[15:0] can operate as GPIO pins | I/O |

# 48.5.1 TSI\_IN[15:0]

When TSI functionality is enabled by the PEN[PEN], the TSI analog portion uses corresponding TSICHn to connect external on-board touch capacitors. The connection between the pin and the touch pad must be kept as short as possible to reduce distribution capacity on board that will add to the system base capacitance.

# 48.6 Memory map and register definition

This section presents the touch sensing input module memory map and registers definition.

**TSIx memory map** 

| Absolute address (hex) | Register name                                    | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|------------------------|--------------------------------------------------|--------------------|--------|-------------|------------------|
| FFFF_9400              | General Control and Status Register (TSI0_GENCS) | 32                 | R/W    | 0000_0000h  | 48.6.1/<br>1218  |
| FFFF_9404              | SCAN control register (TSI0_SCANC)               | 32                 | R/W    | 0000_0000h  | 48.6.2/<br>1222  |
| FFFF_9408              | Pin enable register (TSI0_PEN)                   | 32                 | R/W    | 0000_0000h  | 48.6.3/<br>1225  |
| FFFF_940C              | Status Register (TSI0_STATUS)                    | 32                 | w1c    | 0000_0000h  | 48.6.4/<br>1227  |
| FFFF_9500              | Counter Register (TSI0_CNTR1)                    | 32                 | R      | 0000_0000h  | 48.6.5/<br>1230  |

Table continues on the next page...

## TSIx memory map (continued)

| Absolute address (hex) | Register name                                  | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|------------------------|------------------------------------------------|--------------------|--------|-------------|------------------|
| FFFF_9504              | Counter Register (TSI0_CNTR3)                  | 32                 | R      | 0000_0000h  | 48.6.5/<br>1230  |
| FFFF_9508              | Counter Register (TSI0_CNTR5)                  | 32                 | R      | 0000_0000h  | 48.6.5/<br>1230  |
| FFFF_950C              | Counter Register (TSI0_CNTR7)                  | 32                 | R      | 0000_0000h  | 48.6.5/<br>1230  |
| FFFF_9510              | Counter Register (TSI0_CNTR9)                  | 32                 | R      | 0000_0000h  | 48.6.5/<br>1230  |
| FFFF_9514              | Counter Register (TSI0_CNTR11)                 | 32                 | R      | 0000_0000h  | 48.6.5/<br>1230  |
| FFFF_9518              | Counter Register (TSI0_CNTR13)                 | 32                 | R      | 0000_0000h  | 48.6.5/<br>1230  |
| FFFF_951C              | Counter Register (TSI0_CNTR15)                 | 32                 | R      | 0000_0000h  | 48.6.5/<br>1230  |
| FFFF_9520              | Channel n threshold register (TSI0_THRESHLD0)  | 32                 | R/W    | 0000_0000h  | 48.6.6/<br>1231  |
| FFFF_9524              | Channel n threshold register (TSI0_THRESHLD1)  | 32                 | R/W    | 0000_0000h  | 48.6.6/<br>1231  |
| FFFF_9528              | Channel n threshold register (TSI0_THRESHLD2)  | 32                 | R/W    | 0000_0000h  | 48.6.6/<br>1231  |
| FFFF_952C              | Channel n threshold register (TSI0_THRESHLD3)  | 32                 | R/W    | 0000_0000h  | 48.6.6/<br>1231  |
| FFFF_9530              | Channel n threshold register (TSI0_THRESHLD4)  | 32                 | R/W    | 0000_0000h  | 48.6.6/<br>1231  |
| FFFF_9534              | Channel n threshold register (TSI0_THRESHLD5)  | 32                 | R/W    | 0000_0000h  | 48.6.6/<br>1231  |
| FFFF_9538              | Channel n threshold register (TSI0_THRESHLD6)  | 32                 | R/W    | 0000_0000h  | 48.6.6/<br>1231  |
| FFFF_953C              | Channel n threshold register (TSI0_THRESHLD7)  | 32                 | R/W    | 0000_0000h  | 48.6.6/<br>1231  |
| FFFF_9540              | Channel n threshold register (TSI0_THRESHLD8)  | 32                 | R/W    | 0000_0000h  | 48.6.6/<br>1231  |
| FFFF_9544              | Channel n threshold register (TSI0_THRESHLD9)  | 32                 | R/W    | 0000_0000h  | 48.6.6/<br>1231  |
| FFFF_9548              | Channel n threshold register (TSI0_THRESHLD10) | 32                 | R/W    | 0000_0000h  | 48.6.6/<br>1231  |
| FFFF_954C              | Channel n threshold register (TSI0_THRESHLD11) | 32                 | R/W    | 0000_0000h  | 48.6.6/<br>1231  |
| FFFF_9550              | Channel n threshold register (TSI0_THRESHLD12) | 32                 | R/W    | 0000_0000h  | 48.6.6/<br>1231  |

Table continues on the next page...

#### Memory map and register definition

#### TSIx memory map (continued)

| Absolute<br>address<br>(hex) | Register name                                  | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|------------------------------|------------------------------------------------|--------------------|--------|-------------|------------------|
| FFFF_9554                    | Channel n threshold register (TSI0_THRESHLD13) | 32                 | R/W    | 0000_0000h  | 48.6.6/<br>1231  |
| FFFF_9558                    | Channel n threshold register (TSI0_THRESHLD14) | 32                 | R/W    | 0000_0000h  | 48.6.6/<br>1231  |
| FFFF_955C                    | Channel n threshold register (TSI0_THRESHLD15) | 32                 | R/W    | 0000_0000h  | 48.6.6/<br>1231  |

## 48.6.1 General Control and Status Register (TSIx\_GENCS)

All GENCS bits can be read at any time, but must not be written while GENCS[SCNIP] is set.

Addresses: TSI0\_GENCS is FFFF\_9400h base + 0h offset = FFFF\_9400h



#### TSIx\_GENCS field descriptions

| Field             | Description                                                        |
|-------------------|--------------------------------------------------------------------|
| 31<br>Reserved    | Reserved This bit is reserved.                                     |
| 30–29<br>Reserved | This read-only bitfield is reserved and always has the value zero. |

Table continues on the next page...

## TSIx\_GENCS field descriptions (continued)

| Field    | Description                               |
|----------|-------------------------------------------|
| 28       | Low Power Mode Clock Source Selection     |
| LPCLKS   | 0 LPOCLK                                  |
|          | 1 VLPOSCCLK                               |
| 27–24    | TSI Low Power Mode Scan Interval          |
| LPSCNITV | 131 Low 1 ower Mode Scan Interval         |
|          | 0000 1 ms scan interval                   |
|          | 0001 5 ms scan interval                   |
|          | 0010 10 ms scan interval                  |
|          | 0011 15 ms scan interval                  |
|          | 0100 20 ms scan interval                  |
|          | 0101 30 ms scan interval                  |
|          | 0110 40 ms scan interval                  |
|          | 0111 50 ms scan interval                  |
|          | 1000 75 ms scan interval                  |
|          | 1001 100 ms scan interval                 |
|          | 1010 125 ms scan interval                 |
|          | 1011 150 ms scan interval                 |
|          | 1100 200 ms scan interval                 |
|          | 1101 300 ms scan interval                 |
|          | 1110 400 ms scan interval                 |
|          | 1111 500 ms scan interval                 |
| 23–19    | Number of Consecutive Scans per Electrode |
| NSCN     | 00000 1 time per electrode                |
|          | 00001 2 times per electrode               |
|          | 00010 3 times per electrode               |
|          | 00011 4 times per electrode               |
|          | 00100 5 times per electrode               |
|          | 00101 6 times per electrode               |
|          | 00110 7 times per electrode               |
|          | 00111 8 times per electrode               |
|          | 01000 9 times per electrode               |
|          | 01001 10 times per electrode              |
|          | 01010 11 times per electrode              |
|          | 01011 12 times per electrode              |
|          | 01100 13 times per electrode              |
|          | 01101 14 times per electrode              |
|          | 01110 15 times per electrode              |
|          | 01111 16 times per electrode              |
|          | 10000 17 times per electrode              |
|          | 10001 18 times per electrode              |
|          | 10010 19 times per electrode              |
|          | 10011 20 times per electrode              |
|          | 10100 21 times per electrode              |
|          | 10101 22 times per electrode              |
|          | 10110 23 times per electrode              |
| I .      | 1.0                                       |

Table continues on the next page...

#### Memory map and register definition

## TSIx\_GENCS field descriptions (continued)

| 1011   24 times per electrode   11000   25 times per electrode   11010   26 times per electrode   11010   27 times per electrode   11011   28 times per electrode   11011   28 times per electrode   11101   29 times per electrode   11101   30 times per electrode   11110   30 times per electrode   11111   32 times per electrode   1111   32 times per electrode   11111   3111   3111   3111   3111   3111   3111   3111   3111   3111   3111   3111   3111   3111   3111   3111   3111   3111   3111   3111   3111   3111   3111   3111   3111   3111   3111   3111   3111   3111   3111   3111   3111   3111   3111   3111   3111   3111   3111   3111   3111   3111   3111   3111   3111   3111   3111      | Field  | Description                                                                      |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|----------------------------------------------------------------------------------|
| 11001 26 times per electrode 11010 27 times per electrode 11010 27 times per electrode 11011 28 times per electrode 11110 30 times per electrode 11110 30 times per electrode 11110 31 times per electrode 11111 32 times per electrode 1000 Electrode oscillator frequency divided by 1 1011 Electrode oscillator frequency divided by 2 1012 Electrode oscillator frequency divided by 8 1013 Electrode oscillator frequency divided by 9 1111 Electrode oscillator frequency divided by 9 1111 Electrode oscillator frequency divided by 9 1111 Electrode oscillator frequency divided by 128 111 Electrode oscillator frequency divided by 128 1111 Electrode oscillator frequency divided by 64 1111 Electrode oscillator frequency divided by 128 1111 Electrode oscillator frequency divided by 64 1111 Electrode oscillator frequency divided by 128 112 End of scan flag 113 End of scan flag 114 OUTROF 115 In olear the flag. 116 Overrun error flag 117 Overrun error flag 118 Overrun error flag 119 Overrun error flag 110 No overrun 110 Overrun error flag 1111 Overrun occurred 1111 Electrode oscillator frequency divided by 2 1111 Electrode oscillator frequency divided by 128 1111 Electrode oscillator frequency d |        | 10111 24 times per electrode                                                     |
| 11010 27 times per electrode 11011 28 times per electrode 111101 30 times per electrode 111101 30 times per electrode 111101 30 times per electrode 11111 32 times per electrode 1111 32 times per electrode 1111                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |        |                                                                                  |
| 11011 28 times per electrode 11100 29 times per electrode 111101 30 times per electrode 11110 31 times per electrode 11111 32 times per electrode 1101 Electrode oscillator prescaler 100 Electrode oscillator frequency divided by 2 101 Electrode oscillator frequency divided by 4 101 Electrode oscillator frequency divided by 4 101 Electrode oscillator frequency divided by 4 101 Electrode oscillator frequency divided by 32 110 Electrode oscillator frequency divided by 42 111 Electrode oscillator frequency divided by 42 112 Electrode oscillator frequency divided by 128 113 ENTERF  12 OVAR Write 1 to clear the flag. 13 EXTERF  14 OUTRGF  Write 1 to clear the flag. 15 External electrode error occurred 1 No short 1 Short to VDD or VSS occured on the electrodes  12 Overrun error flag 0 No overrun 1 Overrun occurred 11-10 Reserved 11-10 This read-only bitfield is reserved and always has the value zero.  11-10 Reserved 11-10 Reserved 11-10 This read-only bitfield is reserved and always has the value zero. 11-10 Reserved 11-10 This read-only bitfield is reserved and always has the value zero. 11-10 Schill a Schill bit is read-only bit is tart as a scan sequence. Writing zero to this bit has no effect. 17 TSIEN 17 TSI module enable 0 TSI disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |        |                                                                                  |
| 11100 29 times per electrode 11101 30 times per electrode 111101 30 times per electrode 11111 32 times per electrode 1100 Electrode oscillator frequency divided by 1 1010 Electrode oscillator frequency divided by 2 1010 Electrode oscillator frequency divided by 8 100 Electrode oscillator frequency divided by 16 101 Electrode oscillator frequency divided by 32 110 Electrode oscillator frequency divided by 64 111 Electrode oscillator frequency divided by 128  ENDER  ENDER  Write 1 to clear the flag.  13 EXTERF  External electrode error occurred 0 No short 1 Short to VDD or VSS occured on the electrodes  12 OVERF  Overrun error flag 0 No overrun 1 Overrun occurred  11-10 Reserved  9 Scan-in-progress status Indicates if a scanning process is in progress. This bit is read-only and is changed automatically by the TSI module.  8 Software trigger start Setting this bit starts a scan sequence. Writing zero to this bit has no effect.  7 TSIEN  TSI module enable 0 TSI disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |        |                                                                                  |
| 11101 30 times per electrode 111110 31 times per electrode 111111 32 times per electrode 111111 32 times per electrode 111111 32 times per electrode 11111 32 times per electrode 11111 32 times per electrode 11111 32 times per electrode 1111 32 times per electrode 1112 times per electrode 1112 times per electrode 1112 times per electrode 1113 times per electrode 1114 times per electrode oscillator frequency divided by 1 115 times per oscillator frequency divided by 16 1101 times per oscillator frequency divided by 32 110 times torde oscillator frequency divided by 32 1110 times per oscillator frequency divided by 128 1111 times per oscillator frequency divided by 128 1111 times per oscillator frequency divided by 128 1112 times per oscillator frequency divided by 128 112 times per oscillator frequency divided by 128 113 times per oscillator frequency divided by 128 114                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |        | · ·                                                                              |
| 18–16 PS  Belectrode oscillator prescaler  000 Electrode oscillator frequency divided by 1 001 Electrode oscillator frequency divided by 2 010 Electrode oscillator frequency divided by 4 011 Electrode oscillator frequency divided by 4 011 Electrode oscillator frequency divided by 8 100 Electrode oscillator frequency divided by 16 101 Electrode oscillator frequency divided by 16 101 Electrode oscillator frequency divided by 32 110 Electrode oscillator frequency divided by 84 111 Electrode oscillator frequency divided by 94 111 Electrode oscillator frequency divided by 128  End of scan flag Write 1 to clear the flag.  Out of Range Flag Write 1 to clear the flag.  External electrode error occurred 0 No short 1 Short to VDD or VSS occured on the electrodes  Overrun 1 Overrun occurred  11–10 Reserved  9 Scan-in-progress status Indicates if a scanning process is in progress. This bit is read-only and is changed automatically by the TSI module.  8 SMTS  Software trigger start Setting this bit starts a scan sequence. Writing zero to this bit has no effect.  TSI module enable 0 TSI disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |        |                                                                                  |
| 11111 32 times per electrode  18–16 PS  Electrode oscillator prescaler  000 Electrode oscillator frequency divided by 1 001 Electrode oscillator frequency divided by 2 010 Electrode oscillator frequency divided by 4 011 Electrode oscillator frequency divided by 8 100 Electrode oscillator frequency divided by 18 100 Electrode oscillator frequency divided by 18 101 Electrode oscillator frequency divided by 18 102 Electrode oscillator frequency divided by 32 110 Electrode oscillator frequency divided by 64 111 Electrode oscillator frequency divided by 128  End of scan flag Write 1 to clear the flag.  14 OUTRGF Write 1 to clear the flag.  External electrode error occurred 0 No short 1 Short to VDD or VSS occured on the electrodes  12 OVRF  Overrun error flag 0 No overrun 1 Overrun occurred  This read-only bitfield is reserved and always has the value zero.  8 SCNIP Indicates if a scanning process is in progress. This bit is read-only and is changed automatically by the TSI module.  8 Software trigger start Setting this bit starts a scan sequence. Writing zero to this bit has no effect.  7 TSIEN  TSI module enable 0 TSI disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |        | ·                                                                                |
| 18–16 PS  Electrode oscillator prescaler  000 Electrode oscillator frequency divided by 1 001 Electrode oscillator frequency divided by 2 010 Electrode oscillator frequency divided by 8 011 Electrode oscillator frequency divided by 8 100 Electrode oscillator frequency divided by 16 101 Electrode oscillator frequency divided by 16 101 Electrode oscillator frequency divided by 16 101 Electrode oscillator frequency divided by 2 110 Electrode oscillator frequency divided by 64 111 Electrode oscillator frequency divided by 92  End of scan flag Write 1 to clear the flag.  Out of Range Flag Write 1 to clear the flag.  External electrode error occurred  O No short 1 Short to VDD or VSS occured on the electrodes  Overrun error flag Overrun 1 Overrun occurred  11–10 Reserved  SCANIP  This read-only bitfield is reserved and always has the value zero.  Reserved  SCANIP  SCANIP  SCANIP  This read-only bitfield is reserved and always has the value zero.  Reserved  Software trigger start Setting this bit starts a scan sequence. Writing zero to this bit has no effect.  TSI module enable TSI module enable TSI disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |        |                                                                                  |
| 000 Electrode oscillator frequency divided by 1 001 Electrode oscillator frequency divided by 2 010 Electrode oscillator frequency divided by 4 011 Electrode oscillator frequency divided by 8 100 Electrode oscillator frequency divided by 16 101 Electrode oscillator frequency divided by 16 101 Electrode oscillator frequency divided by 32 110 Electrode oscillator frequency divided by 32 111 Electrode oscillator frequency divided by 64 111 Electrode oscillator frequency divided by 128  End of scan flag Write 1 to clear the flag.  Out of Range Flag Write 1 to clear the flag.  13 EXTERF  O No short 1 Short to VDD or VSS occured on the electrodes  O No overrun 1 Overrun error flag O No overrun 1 Overrun occurred  11–10 Reserved  9 SCNIP  Scan-in-progress status Indicates if a scanning process is in progress. This bit is read-only and is changed automatically by the TSI module.  8 SWTS  Software trigger start Setting this bit starts a scan sequence. Writing zero to this bit has no effect.  TSI module enable 0 TSI disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |        |                                                                                  |
| 010 Electrode oscillator frequency divided by 4 011 Electrode oscillator frequency divided by 8 100 Electrode oscillator frequency divided by 16 101 Electrode oscillator frequency divided by 32 110 Electrode oscillator frequency divided by 32 110 Electrode oscillator frequency divided by 64 111 Electrode oscillator frequency divided by 128  End of scan flag Write 1 to clear the flag.  Out of Range Flag Write 1 to clear the flag.  13 External electrode error occurred 0 No short 1 Short to VDD or VSS occured on the electrodes  Overrun error flag 0 No overrun 1 Overrun occurred  11–10 Reserved  Scan-in-progress status Indicates if a scanning process is in progress. This bit is read-only and is changed automatically by the TSI module.  8 SWTS  Software trigger start Setting this bit starts a scan sequence. Writing zero to this bit has no effect.  7 TSIEN  TSI module enable 0 TSI disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |        | 000 Electrode oscillator frequency divided by 1                                  |
| 011 Electrode oscillator frequency divided by 8 100 Electrode oscillator frequency divided by 16 101 Electrode oscillator frequency divided by 32 110 Electrode oscillator frequency divided by 32 1110 Electrode oscillator frequency divided by 64 111 Electrode oscillator frequency divided by 128  End of scan flag Write 1 to clear the flag.  Out of Range Flag Write 1 to clear the flag.  External electrode error occurred 0 No short 1 Short to VDD or VSS occured on the electrodes  Overrun error flag 0 No overrun 1 Overrun occurred  11–10 Reserved  Scan-in-progress status  ScNIP  ScNIP  Scan-in-progress status  Schipar trigger start  Setting this bit starts a scan sequence. Writing zero to this bit has no effect.  TSI module enable 0 TSI disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |        | 001 Electrode oscillator frequency divided by 2                                  |
| 100 Electrode oscillator frequency divided by 16 101 Electrode oscillator frequency divided by 32 110 Electrode oscillator frequency divided by 64 111 Electrode oscillator frequency divided by 128  15 EOSF  End of scan flag Write 1 to clear the flag.  Out of Range Flag Write 1 to clear the flag.  13 EXTERF  EXTERF  ON short 1 Short to VDD or VSS occured on the electrodes  Overrun error flag O No overrun 1 Overrun occurred  11–10 Reserved  SCAIP  SCAIP  SCAIP  SCAIP  SCAIP  Software trigger start Setting this bit starts a scan sequence. Writing zero to this bit has no effect.  7 TSIEN  TSI module enable 0 TSI disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |        | 010 Electrode oscillator frequency divided by 4                                  |
| 101 Electrode oscillator frequency divided by 32 110 Electrode oscillator frequency divided by 64 111 Electrode oscillator frequency divided by 64 111 Electrode oscillator frequency divided by 128  End of scan flag Write 1 to clear the flag.  Out of Range Flag Write 1 to clear the flag.  External electrode error occurred  0 No short 1 Short to VDD or VSS occured on the electrodes  Overrun error flag 0 No overrun 1 Overrun occurred  11–10 Reserved  9 SCNIP  Scan-in-progress status Indicates if a scanning process is in progress. This bit is read-only and is changed automatically by the TSI module.  8 SWTS  Software trigger start Setting this bit starts a scan sequence. Writing zero to this bit has no effect.  7 TSIEN  TSI module enable 0 TSI disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |        |                                                                                  |
| 110 Electrode oscillator frequency divided by 64 111 Electrode oscillator frequency divided by 128  15 EOSF Write 1 to clear the flag.  Out of Range Flag Write 1 to clear the flag.  13 External electrode error occurred 0 No short 1 Short to VDD or VSS occured on the electrodes  Overrun error flag 0 No overrun 1 Overrun occurred 11–10 Reserved 9 SCNIP SCNIP SCNIP Software trigger start Setting this bit starts a scan sequence. Writing zero to this bit has no effect.  7 TSIEN TSI module enable 0 TSI disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |        |                                                                                  |
| 111 Electrode oscillator frequency divided by 128  15 EOSF  End of scan flag Write 1 to clear the flag.  Out of Range Flag Write 1 to clear the flag.  13 EXTERF  13 External electrode error occurred 0 No short 1 Short to VDD or VSS occured on the electrodes  Overrun error flag 0 No overrun 1 Overrun occurred  11–10 Reserved  9 SCNIP  Scan-in-progress status Indicates if a scanning process is in progress. This bit is read-only and is changed automatically by the TSI module.  8 SWTS  Software trigger start Setting this bit starts a scan sequence. Writing zero to this bit has no effect.  7 TSIEN  7 TSIEN  TSI module enable 0 TSI disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |        |                                                                                  |
| ## End of scan flag ## Write 1 to clear the flag.    14                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |        |                                                                                  |
| EOSF Write 1 to clear the flag.  Out of Range Flag Write 1 to clear the flag.  13 EXTERF  13 EXTERF  ON Short 1 Short to VDD or VSS occured on the electrodes  Overrun error flag Overrun 1 Overrun occurred  11–10 Reserved  Scan-in-progress status Indicates if a scanning process is in progress. This bit is read-only and is changed automatically by the TSI module.  8 SWTS  Software trigger start Setting this bit starts a scan sequence. Writing zero to this bit has no effect.  7 TSIEN  TSI module enable 0 TSI disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |        |                                                                                  |
| OUTRGF Write 1 to clear the flag.  External electrode error occurred  0 No short 1 Short to VDD or VSS occured on the electrodes  Overrun error flag 0 No overrun 1 Overrun occurred  11–10 Reserved  9 SCNIP  Scan-in-progress status Indicates if a scanning process is in progress. This bit is read-only and is changed automatically by the TSI module.  8 SWTS  Software trigger start Setting this bit starts a scan sequence. Writing zero to this bit has no effect.  7 TSIEN  TSI module enable 0 TSI disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |        |                                                                                  |
| OUTRGF Write 1 to clear the flag.  13 EXTERF 0 No short 1 Short to VDD or VSS occured on the electrodes  Overrun error flag 0 No overrun 1 Overrun occurred  11–10 Reserved  9 SCNIP SCNIP SCNIP  8 SWTS Software trigger start Setting this bit starts a scan sequence. Writing zero to this bit has no effect.  TSI module enable 0 TSI disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 14     | Out of Range Flag                                                                |
| EXTERF  0 No short 1 Short to VDD or VSS occured on the electrodes  12 OVRF  0 No overrun error flag 0 No overrun 1 Overrun occurred  11–10 Reserved  7 TSIEN  12 OVerrun error flag 0 No overrun 1 Overrun occurred 1 Neserved and always has the value zero.  Scan-in-progress status Indicates if a scanning process is in progress. This bit is read-only and is changed automatically by the TSI module.  Software trigger start Setting this bit starts a scan sequence. Writing zero to this bit has no effect.  TSI module enable 0 TSI disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | OUTRGF |                                                                                  |
| 0 No short 1 Short to VDD or VSS occured on the electrodes  12 OVRF 0 No overrun 1 Overrun occurred  11–10 Reserved  9 SCNIP SCNIP SCNIP SCNIP  8 SWTS Software trigger start Setting this bit starts a scan sequence. Writing zero to this bit has no effect.  7 TSIEN TSI module enable 0 TSI disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |        | External electrode error occurred                                                |
| 1 Short to VDD or VSS occured on the electrodes  Overrun error flag  No overrun  O No overrun  Toverrun occurred  This read-only bitfield is reserved and always has the value zero.  ScNIP  ScNIP  Scan-in-progress status  Indicates if a scanning process is in progress. This bit is read-only and is changed automatically by the TSI module.  Software trigger start  Setting this bit starts a scan sequence. Writing zero to this bit has no effect.  TSI module enable  TSI module enable  TSI module enable  TSI disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | EXTERF | 0 No short                                                                       |
| 12 OVRF OVRF OVRF OVRF ON overrun ON overrun Overrun occurred  11–10 Reserved  Scan-in-progress status Indicates if a scanning process is in progress. This bit is read-only and is changed automatically by the TSI module.  Software trigger start Setting this bit starts a scan sequence. Writing zero to this bit has no effect.  TSIEN  Overrun error flag Overrun error flag O No overrun O No overu |        |                                                                                  |
| OVRF  0 No overrun 1 Overrun occurred  11–10 Reserved  Scan-in-progress status Indicates if a scanning process is in progress. This bit is read-only and is changed automatically by the TSI module.  Software trigger start Setting this bit starts a scan sequence. Writing zero to this bit has no effect.  7 TSIEN  TSI module enable 0 TSI disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 12     |                                                                                  |
| 1 Overrun occurred  11–10 Reserved  This read-only bitfield is reserved and always has the value zero.  9 SCNIP  Indicates if a scanning process is in progress. This bit is read-only and is changed automatically by the TSI module.  8 Software trigger start Setting this bit starts a scan sequence. Writing zero to this bit has no effect.  7 TSIEN  TSI module enable 0 TSI disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |        | overtain errer mag                                                               |
| 11–10 Reserved  This read-only bitfield is reserved and always has the value zero.  Scan-in-progress status Indicates if a scanning process is in progress. This bit is read-only and is changed automatically by the TSI module.  Software trigger start Setting this bit starts a scan sequence. Writing zero to this bit has no effect.  TSI module enable  TSIEN  TSI module enable  TSI disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |        |                                                                                  |
| Reserved  9 SCNIP Indicates if a scanning process is in progress. This bit is read-only and is changed automatically by the TSI module.  8 Software trigger start Setting this bit starts a scan sequence. Writing zero to this bit has no effect.  7 TSI module enable 0 TSI disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |        | 1 Overrun occurred                                                               |
| SCNIP Indicates if a scanning process is in progress. This bit is read-only and is changed automatically by the TSI module.  8 Software trigger start Setting this bit starts a scan sequence. Writing zero to this bit has no effect.  7 TSI module enable 0 TSI disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |        | This read-only bitfield is reserved and always has the value zero.               |
| Indicates if a scanning process is in progress. This bit is read-only and is changed automatically by the TSI module.  8 Software trigger start  Setting this bit starts a scan sequence. Writing zero to this bit has no effect.  7 TSI module enable  0 TSI disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |        | Scan-in-progress status                                                          |
| 8 Software trigger start Setting this bit starts a scan sequence. Writing zero to this bit has no effect.  7 TSI module enable 0 TSI disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | SCNIP  |                                                                                  |
| SWTS Setting this bit starts a scan sequence. Writing zero to this bit has no effect.  7 TSI module enable TSIEN 0 TSI disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |        |                                                                                  |
| Setting this bit starts a scan sequence. Writing zero to this bit has no effect.  7 TSI module enable TSIEN 0 TSI disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |        | Software trigger start                                                           |
| TSIEN 0 TSI disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 3,410  | Setting this bit starts a scan sequence. Writing zero to this bit has no effect. |
| 0 TSI disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |        | TSI module enable                                                                |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | ISIEN  | 0 TSI disabled                                                                   |
| . Tot onablod                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |        | 1 TSI enabled                                                                    |

Table continues on the next page...

## TSIx\_GENCS field descriptions (continued)

| Field         | Description                                                                                  |
|---------------|----------------------------------------------------------------------------------------------|
| 6<br>TSIIE    | TSI interrupt enable  0 Disable                                                              |
|               | 1 Enable                                                                                     |
| 5<br>ERIE     | TSI error interrupt Enable  Caused by a short or overrun error.                              |
|               | Caused by a short or overrun error.                                                          |
|               | 0 Error interrupt disabled                                                                   |
|               | 1 Error interrupt enabled                                                                    |
| 4<br>ESOR     | End-of-scan or out-of-range interrupt select                                                 |
|               | <ul><li>0 Out-of-range interrupt selected</li><li>1 End-of-scan interrupt selected</li></ul> |
|               | ·                                                                                            |
| 3<br>Reserved | Reserved                                                                                     |
| 110001700     | This bit is reserved.                                                                        |
| 2             | Reserved                                                                                     |
| Reserved      | This bit is reserved.                                                                        |
| 1<br>STM      | Scan trigger mode                                                                            |
|               | 0 Software trigger scan                                                                      |
|               | 1 Periodical scan                                                                            |
| 0<br>STPE     | TSI stop enable while in low-power modes (STOP, VLPS, LLS, and VLLS{3,2,1})                  |
|               | 0 Disable TSI when MCU enters low-power modes                                                |
|               | 1 Allow TSI to continue running in all low power modes                                       |

# 48.6.2 SCAN control register (TSIx\_SCANC)

All SCANC bits can be read at any time, but must not be written while GENCS[SCNIP] is set.

Addresses: TSI0\_SCANC is FFFF\_9400h base + 4h offset = FFFF\_9404h



#### TSIx\_SCANC field descriptions

| Field            | Description                                |
|------------------|--------------------------------------------|
| 31–27<br>REFCHRG | Reference oscillator charge current select |
|                  | 00000 1 μA charge current                  |
|                  | 00001 2 μA charge current                  |
|                  | 00010 3 μA charge current                  |
|                  | 00011 4 μA charge current                  |
|                  | 00100 5 μA charge current                  |
|                  | 00101 6 μA charge current                  |
|                  | 00110 7 μA charge current                  |
|                  | 00111 8 μA charge current                  |
|                  | 01000 9 μA charge current                  |
|                  | 01001 10 μA charge current                 |
|                  | 01010 11 μA charge current                 |
|                  | 01011 12 μA charge current                 |
|                  | 01100 13 μA charge current                 |
|                  | 01101 14 μA charge current                 |
|                  | 01110 15 μA charge current                 |
|                  | 01111 16 μA charge current                 |
|                  | 10000 17 μA charge current                 |
|                  | 10001 18 μA charge current                 |
|                  | 10010 19 μA charge current                 |
|                  | 10011 20 μA charge current                 |
|                  | 10100 21 μA charge current                 |
|                  | 10101 22 μA charge current                 |
|                  |                                            |

Table continues on the next page...

## TSIx\_SCANC field descriptions (continued)

| Field            | Description                               |
|------------------|-------------------------------------------|
|                  | 10110 23 µA charge current                |
|                  | 10111 24 μA charge current                |
|                  | 11000 25 μA charge current                |
|                  | 11001 26 µA charge current                |
|                  | 11010 27 μA charge current                |
|                  | 11011 28 µA charge current                |
|                  | 11100 29 μA charge current                |
|                  | 11101 30 μA charge current                |
|                  | 11110 31 µA charge current                |
|                  | 11111 32 μA charge current                |
| 26–24<br>CAPTRM  | Internal capacitance trim value           |
|                  | 000 0.5 pF internal reference capacitance |
|                  | 001 0.6 pF internal reference capacitance |
|                  | 010 0.7 pF internal reference capacitance |
|                  | 011 0.8 pF internal reference capacitance |
|                  | 100 0.9 pF internal reference capacitance |
|                  | 101 1.0 pF internal reference capacitance |
|                  | 110 1.1 pF internal reference capacitance |
|                  | 111 1.2 pF internal reference capacitance |
| 23–19<br>EXTCHRG | External oscillator charge current select |
|                  | 00000 1 μA charge current                 |
|                  | 00001 2 μA charge current                 |
|                  | 00010 3 μA charge current                 |
|                  | 00011 4 μA charge current                 |
|                  | 00100 5 μA charge current                 |
|                  | 00101 6 μA charge current                 |
|                  | 00110 7 μA charge current                 |
|                  | 00111 8 μA charge current                 |
|                  | 01000 9 μA charge current                 |
|                  | 01001 10 μA charge current                |
|                  | 01010 11 μA charge current                |
|                  | 01011 12 μA charge current                |
|                  | 01100 13 μA charge current                |
|                  | 01101 14 μA charge current                |
|                  | 01110 15 μA charge current                |
|                  | 01111 16 μA charge current                |
|                  | 10000 17 μA charge current                |
|                  | 10001 18 μA charge current                |
|                  | 10010 19 μA charge current                |
|                  | 10011 20 μA charge current                |
|                  | 10100 21 µA charge current                |
|                  | 10101 22 μA charge current                |
|                  | 10110 23 μA charge current                |
|                  | 10111 24 μA charge current                |
|                  | 11000 25 µA charge current                |

Table continues on the next page...

#### Memory map and register definition

## TSIx\_SCANC field descriptions (continued)

| Field           | Description                                                        |
|-----------------|--------------------------------------------------------------------|
|                 | 11001 26 µA charge current                                         |
|                 | 11010 27 μA charge current                                         |
|                 | 11011 28 µA charge current                                         |
|                 | 11100 29 µA charge current                                         |
|                 | 11101 30 μA charge current                                         |
|                 | 11110 31 µA charge current                                         |
|                 | 11111 32 μA charge current                                         |
| 18–16<br>DELVOL | Delta voltage select applied to analog oscillators                 |
|                 | 000 100 mV delta voltage is applied                                |
|                 | 001 150 mV delta voltage is applied                                |
|                 | 010 200 mV delta voltage is applied                                |
|                 | 011 250 mV delta voltage is applied                                |
|                 | 100 300 mV delta voltage is applied                                |
|                 | 101 400 mV delta voltage is applied                                |
|                 | 110 500 mV delta voltage is applied                                |
|                 | 111 600 mV delta voltage is applied                                |
| 15–8<br>SMOD    | Scan modulo                                                        |
|                 | 00000000 Continuous scan                                           |
|                 | Others Scan period modulo                                          |
| 7–6<br>Reserved | This read-only bitfield is reserved and always has the value zero. |
| 5               | Active mode clock divider                                          |
| AMCLKDIV        | 0 Divider set to 1                                                 |
|                 | 1 Divider set to 2048                                              |
| 4–3             | Active mode clock source                                           |
| AMCLKS          |                                                                    |
|                 | 00 Bus Clock                                                       |
|                 | 01 MCGIRCLK                                                        |
|                 | 10 OSCERCLK                                                        |
|                 | 11 Not valid                                                       |
| 2-0<br>AMPSC    | Active mode prescaler                                              |
|                 | 000 Input clock source divided by 1                                |
|                 | 001 Input clock source divided by 2                                |
|                 | 010 Input clock source divided by 4                                |
|                 | 011 Input clock source divided by 8                                |
|                 | 100 Input clock source divided by 16                               |
|                 | 101 Input clock source divided by 32                               |
|                 | 110 Input clock source divided by 64                               |
|                 | 111 Input clock source divided by 128                              |

## 48.6.3 Pin enable register (TSIx\_PEN)

#### **NOTE**

Do not change PEN when GENCS[TSIEN] is set.

#### **NOTE**

All PEN bits can be read at any time, but must not be written while GENCS[SCNIP] is set.





## TSIx\_PEN field descriptions

| Field             | Description                                                        |  |  |  |  |  |  |
|-------------------|--------------------------------------------------------------------|--|--|--|--|--|--|
| 31–20<br>Reserved | This read-only bitfield is reserved and always has the value zero. |  |  |  |  |  |  |
| 19–16<br>LPSP     | Low-power scan pin                                                 |  |  |  |  |  |  |
|                   | Selects which input is active in low-power mode.                   |  |  |  |  |  |  |
|                   | 0000 TSI_IN[0] is active in low power mode                         |  |  |  |  |  |  |
|                   | 0001 TSI_IN[1] is active in low power mode                         |  |  |  |  |  |  |
|                   | 0010 TSI_IN[2] is active in low power mode                         |  |  |  |  |  |  |
|                   | 0011 TSI_IN[3] is active in low power mode                         |  |  |  |  |  |  |
|                   | 0100 TSI_IN[4] is active in low power mode                         |  |  |  |  |  |  |
|                   | 0101 TSI_IN[5] is active in low power mode                         |  |  |  |  |  |  |
|                   | 0110 TSI_IN[6] is active in low power mode                         |  |  |  |  |  |  |
|                   | 0111 TSI_IN[7] is active in low power mode                         |  |  |  |  |  |  |
|                   | 1000 TSI_IN[8] is active in low power mode                         |  |  |  |  |  |  |
|                   | 1001 TSI_IN[9] is active in low power mode                         |  |  |  |  |  |  |
|                   | 1010 TSI_IN[10] is active in low power mode                        |  |  |  |  |  |  |
|                   | 1011 TSI_IN[11] is active in low power mode                        |  |  |  |  |  |  |
|                   | 1100 TSI_IN[12] is active in low power mode                        |  |  |  |  |  |  |
|                   | 1101 TSI_IN[13] is active in low power mode                        |  |  |  |  |  |  |
|                   | 1110 TSI_IN[14] is active in low power mode                        |  |  |  |  |  |  |
|                   | 1111 TSI_IN[15] is active in low power mode                        |  |  |  |  |  |  |
| 15<br>PEN15       | TSI pin 15 enable                                                  |  |  |  |  |  |  |
|                   | 0 The corresponding pin is not used by TSI                         |  |  |  |  |  |  |
|                   | 1 The corresponding pin is used by TSI                             |  |  |  |  |  |  |

Table continues on the next page...

#### Memory map and register definition

## TSIx\_PEN field descriptions (continued)

| Field       | Description                                                                                           |
|-------------|-------------------------------------------------------------------------------------------------------|
| 14<br>PEN14 | TSI pin 14 enable  0 The corresponding pin is not used by TSI  1 The corresponding pin is used by TSI |
| 13<br>PEN13 | TSI pin 13 enable  0 The corresponding pin is not used by TSI  1 The corresponding pin is used by TSI |
| 12<br>PEN12 | TSI pin 12 enable  0 The corresponding pin is not used by TSI  1 The corresponding pin is used by TSI |
| 11<br>PEN11 | TSI pin 11 enable  0 The corresponding pin is not used by TSI  1 The corresponding pin is used by TSI |
| 10<br>PEN10 | TSI pin 10 enable  0 The corresponding pin is not used by TSI  1 The corresponding pin is used by TSI |
| 9<br>PEN9   | TSI pin 9 enable  0 The corresponding pin is not used by TSI  1 The corresponding pin is used by TSI  |
| 8<br>PEN8   | TSI pin 8 enable  0 The corresponding pin is not used by TSI 1 The corresponding pin is used by TSI   |
| 7<br>PEN7   | TSI pin 7 enable  0 The corresponding pin is not used by TSI 1 The corresponding pin is used by TSI   |
| 6<br>PEN6   | TSI pin 6 enable  0 The corresponding pin is not used by TSI 1 The corresponding pin is used by TSI   |
| 5<br>PEN5   | TSI pin 5 enable  0 The corresponding pin is not used by TSI 1 The corresponding pin is used by TSI   |
| 4<br>PEN4   | TSI pin 4 enable  0 The corresponding pin is not used by TSI  1 The corresponding pin is used by TSI  |
| 3<br>PEN3   | TSI pin 3 enable                                                                                      |

Table continues on the next page...

## TSIx\_PEN field descriptions (continued)

| Field     | Description                                |
|-----------|--------------------------------------------|
|           | 0 The corresponding pin is not used by TSI |
|           | 1 The corresponding pin is used by TSI     |
| 2<br>PEN2 | TSI pin 2 enable                           |
|           | 0 The corresponding pin is not used by TSI |
|           | 1 The corresponding pin is used by TSI     |
| 1<br>PEN1 | TSI pin 1 enable                           |
|           | 0 The corresponding pin is not used by TSI |
|           | 1 The corresponding pin is used by TSI     |
| 0<br>PEN0 | TSI pin 0 enable                           |
|           | 0 The corresponding pin is not used by TSI |
|           | 1 The corresponding pin is used by TSI     |

# 48.6.4 Status Register (TSIx\_STATUS)

Addresses: TSI0\_STATUS is FFFF\_9400h base + Ch offset = FFFF\_940Ch

| Bit   | 31      | 30      | 29      | 28      | 27      | 26      | 25     | 24     | 23     | 22     | 21     | 20     | 19     | 18     | 17     | 16     |
|-------|---------|---------|---------|---------|---------|---------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|
| R     | ERROF15 | ERROF14 | ERROF13 | ERROF12 | ERROF11 | ERROF10 | ERROF9 | ERROF8 | ERROF7 | ERROF6 | ERROF5 | ERROF4 | ERROF3 | ERROF2 | ERROF1 | ERROF0 |
| w     | w1c     | w1c     | w1c     | w1c     | w1c     | w1c     | w1c    | w1c    | w1c    | w1c    | w1c    | w1c    | w1c    | w1c    | w1c    | w1c    |
| Reset | 0       | 0       | 0       | 0       | 0       | 0       | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |
| Bit   | 15      | 14      | 13      | 12      | 11      | 10      | 9      | 8      | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
| R     | ORNGF15 | ORNGF14 | ORNGF13 | ORNGF12 | ORNGF11 | ORNGF10 | ORNGF9 | ORNGF8 | ORNGF7 | ORNGF6 | ORNGF5 | ORNGF4 | ORNGF3 | ORNGF2 | ORNGF1 | ORNGF0 |
| w     | w1c     | w1c     | w1c     | w1c     | w1c     | w1c     | w1c    | w1c    | w1c    | w1c    | w1c    | w1c    | w1c    | w1c    | w1c    | w1c    |
| Reset | 0       | 0       | 0       | 0       | 0       | 0       | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |

### TSIx\_STATUS field descriptions

| Field         | Description                |
|---------------|----------------------------|
| 31<br>ERROF15 | TouchSensing Error Flag 15 |

Table continues on the next page...

#### Memory map and register definition

## TSIx\_STATUS field descriptions (continued)

| Field         | Description                                                                                                                                                                  |
|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|               | This bit indicates when the corresponding electrode is shorted to VDD or VSS. If the GENCS[ERIE] bit is set, an error interrupt is generated. Write a one to clear this bit. |
| 30            | TouchSensing Error Flag 14                                                                                                                                                   |
| ERROF14       | This bit indicates when the corresponding electrode is shorted to VDD or VSS. If the GENCS[ERIE] bit is set, an error interrupt is generated. Write a one to clear this bit. |
| 29<br>ERROF13 | TouchSensing Error Flag 13                                                                                                                                                   |
| LITTO 13      | This bit indicates when the corresponding electrode is shorted to VDD or VSS. If the GENCS[ERIE] bit is set, an error interrupt is generated. Write a one to clear this bit. |
| 28<br>ERROF12 | TouchSensing Error Flag 12                                                                                                                                                   |
| ETITIOT 12    | This bit indicates when the corresponding electrode is shorted to VDD or VSS. If the GENCS[ERIE] bit is set, an error interrupt is generated. Write a one to clear this bit. |
| 27<br>ERROF11 | TouchSensing Error Flag 11                                                                                                                                                   |
| LITTOTT       | This bit indicates when the corresponding electrode is shorted to VDD or VSS. If the GENCS[ERIE] bit is set, an error interrupt is generated. Write a one to clear this bit. |
| 26            | TouchSensing Error Flag 10                                                                                                                                                   |
| ERROF10       | This bit indicates when the corresponding electrode is shorted to VDD or VSS. If the GENCS[ERIE] bit is set, an error interrupt is generated. Write a one to clear this bit. |
| 25<br>ERROF9  | TouchSensing Error Flag 9                                                                                                                                                    |
| ERROF9        | This bit indicates when the corresponding electrode is shorted to VDD or VSS. If the GENCS[ERIE] bit is set, an error interrupt is generated. Write a one to clear this bit. |
| 24            | TouchSensing Error Flag 8                                                                                                                                                    |
| ERROF8        | This bit indicates when the corresponding electrode is shorted to VDD or VSS. If the GENCS[ERIE] bit is set, an error interrupt is generated. Write a one to clear this bit. |
| 23            | TouchSensing Error Flag 7                                                                                                                                                    |
| ERROF7        | This bit indicates when the corresponding electrode is shorted to VDD or VSS. If the GENCS[ERIE] bit is set, an error interrupt is generated. Write a one to clear this bit. |
| 22<br>ERROF6  | TouchSensing Error Flag 6                                                                                                                                                    |
| Ennoro        | This bit indicates when the corresponding electrode is shorted to VDD or VSS. If the GENCS[ERIE] bit is set, an error interrupt is generated. Write a one to clear this bit. |
| 21<br>ERROF5  | TouchSensing Error Flag 5                                                                                                                                                    |
| ENNOFS        | This bit indicates when the corresponding electrode is shorted to VDD or VSS. If the GENCS[ERIE] bit is set, an error interrupt is generated. Write a one to clear this bit. |
| 20            | TouchSensing Error Flag 4                                                                                                                                                    |
| ERROF4        | This bit indicates when the corresponding electrode is shorted to VDD or VSS. If the GENCS[ERIE] bit is set, an error interrupt is generated. Write a one to clear this bit. |
| 19<br>ERROF3  | TouchSensing Error Flag 3                                                                                                                                                    |

Table continues on the next page...

## TSIx\_STATUS field descriptions (continued)

| Field         | Description                                                                                                                                                                                                    |
|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|               | This bit indicates when the corresponding electrode is shorted to VDD or VSS. If the GENCS[ERIE] bit is set, an error interrupt is generated. Write a one to clear this bit.                                   |
| 18            | TouchSensing Error Flag 2                                                                                                                                                                                      |
| ERROF2        | This bit indicates when the corresponding electrode is shorted to VDD or VSS. If the GENCS[ERIE] bit is set, an error interrupt is generated. Write a one to clear this bit.                                   |
| 17<br>ERROF1  | TouchSensing Error Flag 1                                                                                                                                                                                      |
| LITTOLI       | This bit indicates when the corresponding electrode is shorted to VDD or VSS. If the GENCS[ERIE] bit is set, an error interrupt is generated. Write a one to clear this bit.                                   |
| 16<br>ERROF0  | TouchSensing Error Flag 0                                                                                                                                                                                      |
| ENNOFO        | This bit indicates when the corresponding electrode is shorted to VDD or VSS. If the GENCS[ERIE] bit is set, an error interrupt is generated. Write a one to clear this bit.                                   |
| 15<br>ORNGF15 | Touch Sensing Electrode Out-of-Range Flag 15                                                                                                                                                                   |
| ORNGETS       | This bit indicates when the corresponding electrode is out of range. If the GENCS[TSIIE] bit is set and the GENCS[ESOR] bit is cleared, an out-of-range interrupt is generated. Write a one to clear this bit. |
| 14<br>ORNGF14 | Touch Sensing Electrode Out-of-Range Flag 14                                                                                                                                                                   |
| ORNGF14       | This bit indicates when the corresponding electrode is out of range. If the GENCS[TSIIE] bit is set and the GENCS[ESOR] bit is cleared, an out-of-range interrupt is generated. Write a one to clear this bit. |
| 13            | Touch Sensing Electrode Out-of-Range Flag 13                                                                                                                                                                   |
| ORNGF13       | This bit indicates when the corresponding electrode is out of range. If the GENCS[TSIIE] bit is set and the GENCS[ESOR] bit is cleared, an out-of-range interrupt is generated. Write a one to clear this bit. |
| 12<br>ORNGF12 | Touch Sensing Electrode Out-of-Range Flag 12                                                                                                                                                                   |
| ONINGF12      | This bit indicates when the corresponding electrode is out of range. If the GENCS[TSIIE] bit is set and the GENCS[ESOR] bit is cleared, an out-of-range interrupt is generated. Write a one to clear this bit. |
| 11<br>ORNGF11 | Touch Sensing Electrode Out-of-Range Flag 11                                                                                                                                                                   |
| ONIGETT       | This bit indicates when the corresponding electrode is out of range. If the GENCS[TSIIE] bit is set and the GENCS[ESOR] bit is cleared, an out-of-range interrupt is generated. Write a one to clear this bit. |
| 10<br>ORNGF10 | Touch Sensing Electrode Out-of-Range Flag 10                                                                                                                                                                   |
| Offinal 10    | This bit indicates when the corresponding electrode is out of range. If the GENCS[TSIIE] bit is set and the GENCS[ESOR] bit is cleared, an out-of-range interrupt is generated. Write a one to clear this bit. |
| 9<br>ORNGF9   | Touch Sensing Electrode Out-of-Range Flag 9                                                                                                                                                                    |
| ORNGF9        | This bit indicates when the corresponding electrode is out of range. If the GENCS[TSIIE] bit is set and the GENCS[ESOR] bit is cleared, an out-of-range interrupt is generated. Write a one to clear this bit. |
| 8<br>ORNGF8   | Touch Sensing Electrode Out-of-Range Flag 8                                                                                                                                                                    |
| UNINGF8       | This bit indicates when the corresponding electrode is out of range. If the GENCS[TSIIE] bit is set and the GENCS[ESOR] bit is cleared, an out-of-range interrupt is generated. Write a one to clear this bit. |
| 7<br>ORNGF7   | Touch Sensing Electrode Out-of-Range Flag 7                                                                                                                                                                    |

Table continues on the next page...

#### Memory map and register definition

#### TSIx\_STATUS field descriptions (continued)

| Field       | Description                                                                                                                                                                                                    |
|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             | This bit indicates when the corresponding electrode is out of range. If the GENCS[TSIIE] bit is set and the GENCS[ESOR] bit is cleared, an out-of-range interrupt is generated. Write a one to clear this bit. |
| 6<br>ORNGF6 | Touch Sensing Electrode Out-of-Range Flag 6                                                                                                                                                                    |
| Ortival o   | This bit indicates when the corresponding electrode is out of range. If the GENCS[TSIIE] bit is set and the GENCS[ESOR] bit is cleared, an out-of-range interrupt is generated. Write a one to clear this bit. |
| 5<br>ORNGF5 | Touch Sensing Electrode Out-of-Range Flag 5                                                                                                                                                                    |
| Ortival 3   | This bit indicates when the corresponding electrode is out of range. If the GENCS[TSIIE] bit is set and the GENCS[ESOR] bit is cleared, an out-of-range interrupt is generated. Write a one to clear this bit. |
| 4<br>ORNGF4 | Touch Sensing Electrode Out-of-Range Flag 4                                                                                                                                                                    |
| OTHING! 4   | This bit indicates when the corresponding electrode is out of range. If the GENCS[TSIIE] bit is set and the GENCS[ESOR] bit is cleared, an out-of-range interrupt is generated. Write a one to clear this bit. |
| 3<br>ORNGF3 | Touch Sensing Electrode Out-of-Range Flag 3                                                                                                                                                                    |
| Critical    | This bit indicates when the corresponding electrode is out of range. If the GENCS[TSIIE] bit is set and the GENCS[ESOR] bit is cleared, an out-of-range interrupt is generated. Write a one to clear this bit. |
| 2<br>ORNGF2 | Touch Sensing Electrode Out-of-Range Flag 2                                                                                                                                                                    |
| Ortival 2   | This bit indicates when the corresponding electrode is out of range. If the GENCS[TSIIE] bit is set and the GENCS[ESOR] bit is cleared, an out-of-range interrupt is generated. Write a one to clear this bit. |
| 1<br>ORNGF1 | Touch Sensing Electrode Out-of-Range Flag 1                                                                                                                                                                    |
| 0<br>ORNGF0 | Touch Sensing Electrode Out-of-Range Flag 0                                                                                                                                                                    |
| 011110110   | This bit indicates when the corresponding electrode is out of range. If the GENCS[TSIIE] bit is set and the GENCS[ESOR] bit is cleared, an out-of-range interrupt is generated. Write a one to clear this bit. |

## 48.6.5 Counter Register (TSIx\_CNTRn)

Addresses: TSI0\_CNTR1 is FFFF\_9400h base + 100h offset = FFFF\_9500h TSI0\_CNTR3 is FFFF\_9400h base + 104h offset = FFFF\_9504h

TSI0\_CNTR5 is FFFF\_9400h base + 108h offset = FFFF\_9508h

TSI0\_CNTR7 is FFFF\_9400h base + 10Ch offset = FFFF\_950Ch

TSIO\_CNTR9 is FFFF\_9400h base + 110h offset = FFFF\_9510h

TSIO\_CNTR11 is FFFF\_9400h base + 114h offset = FFFF\_9514h

TSIO\_CNTR13 is FFFF\_9400h base + 118h offset = FFFF\_9518h

TSI0\_CNTR15 is FFFF\_9400h base + 11Ch offset = FFFF\_951Ch



### TSIx\_CNTRn field descriptions

| Field          | Description                                           |
|----------------|-------------------------------------------------------|
| 31–16<br>CNTN1 | TouchSensing channel <i>n</i> +1 16-bit counter value |
| 15–0<br>CNTN   | TouchSensing channel <i>n</i> 16-bit counter value    |

## 48.6.6 Channel n threshold register (TSIx\_THRESHLDn)

All THRESHLD bits can be read at any time, but must not be written while GENCS[SCNIP] is set.





#### TSIx\_THRESHLDn field descriptions

| Field         | Description          |
|---------------|----------------------|
| 31–16<br>LTHH | Low threshold value  |
| 15–0<br>HTHH  | High threshold value |

# 48.7 Functional descriptions

This section provides functional description of the TSI module.

## 48.7.1 Capacitance measurement

The electrode pin capacitance measurement uses a dual oscillator approach. The TSI electrode oscillator has its frequency dependable on the external electrode capacitance and the TSI module configuration. After going to a configurable prescaler, the TSI electrode oscillator signal goes to the input of the modulo counter. The time for the external electrode oscillations is measured using the TSI reference oscillator. The measured electrode capacitance is directly proportional to this time.

#### 48.7.1.1 TSI electrode oscillator

The TSI electrode oscillator circuit is illustrated in the following figure. A configurable constant current source is used to charge and discharge the external electrode capacitance. A buffer hysteresis defines the oscillator delta voltage. The delta voltage defines the margin of high and low voltage which are the reference input of the comparator in different time.



Figure 48-64. TSI electrode oscillator circuit

The current source applied to the pad capacitance is 5-bit binary controlled by the SCANC[EXTCHRG]. The hysteresis delta voltage is also configurable and is 3-bit binary controlled by the SCANC[DELVOL]. The figure below shows the voltage amplitude waveform of the electrode capacitance charging and discharging with a programmable current.



Figure 48-65. TSI electrode oscillator chart

The oscillator frequency is given by the following equation:

$$F_{elec} = \frac{I}{2 * C_{elec} * \Delta V}$$

Figure 48-66. Equation 1: TSI electrode oscillator frequency

Where:

I: constant current

C<sub>elec</sub>: electrode capacitance

 $\Delta V$ : Hysteresis delta voltage

So by this equation, for example, an electrode with  $C_{elec}$ = 20 pF, with a current source of I = 16  $\mu$ A and  $\Delta$ V = 600 mV will have the following oscillation frequency:

$$F_{elec} = \frac{16 \ \mu A}{2 * 20pF * 600mV} = 0.67MHz$$

Figure 48-67. Equation 2: TSI electrode oscillator frequency

The current source and hysteresis delta voltage are used to accommodate the TSI electrode oscillator frequency with different electrode capacitance sizes.

## 48.7.1.2 Electrode oscillator and counter control

The TSI oscillator frequency signal goes through a prescaler defined by the GENCS[PS] and then enters a counter. The bit field GENCS[NSCN] defines the number of scans for each external electrode.

The pin capacitance sampling time is given by the time the module counter takes to go from zero to its maximum value, defined by NSCN. The electrode sample time is expressed by the following equation:

$$T_{cap\_samp} = \frac{PS * NSCN}{F_{elec}}$$

Using Equation 1.

$$T_{cap\_samp} = \frac{2 * PS * NSCN * C_{elec} * \Delta V}{I}$$

Figure 48-68. Equation 3: Electrode sampling time

Where:

PS: prescaler value

**Functional descriptions** 

NSCN: number of scan

I: constant current

C<sub>elec</sub>: electrode capacitance

 $\Delta V$ : Hysteresis delta voltage

By this equation, an electrode with C = 20 pF, with a current source of  $I = 16 \mu A$  and  $\Delta V = 600$  mV, PS = 2 and NSCN = 16 will have the following sampling time:

$$T_{cap\_samp} = \frac{2*2*16*20pF*600mV}{16\mu A} = 48\mu s$$

#### 48.7.1.3 TSI reference oscillator

The TSI reference oscillator has the same topology of the TSI electrode oscillator. The TSI reference oscillator instead of using an external capacitor for the electrode oscillator has an internal reference capacitor which can be programmable. The SCANC[CAPTRM] defines the internal reference capacitor trimming value \*.

The TSI reference oscillator share the same voltage hysteresis levels defined with the SCANC[DELVOL] and has an independent programmable current source controlled by the SCANC[REFCHRG].

\* The reference oscillator frequency is given by the following equation:

$$F_{ref\_osc} = \frac{I_{ref}}{2 * C_{ref} * \Delta V}$$

Figure 48-69. Equation 4: TSI reference oscillator frequency

Where:

C<sub>ref</sub>: Internal reference capacitor

I<sub>ref</sub>: Reference oscillator current source

 $\Delta V$ : Hysteresis delta voltage

Considering  $C_{ref} = 1.0 \text{ pF}$ ,  $I_{ref} = 12 \mu A$  and  $\Delta V = 600 \text{ mV}$ , follows

$$F_{ref\_osc} = \frac{12\mu A}{2 * 1.0 pF * 600 mV} = 10.0 MHz$$

#### 48.7.2 TSI measurement result

The capacitance measurement result is defined by the number of TSI reference oscillator periods during the sample time and is stored in the TSICHnCNT register.

$$TSICHnCNT = T_{cap\_samp} * F_{ref\_osc}$$

Using Equation 2 and Equation 1 follows:

TSICHnCNT = 
$$\frac{I_{ref} * PS * NSCN}{C_{ref} * I_{ref}} * C_{elec}$$

Figure 48-70. Equation 5: Capacitance result value

In the example where  $F_{ref\_osc} = 10.0 MHz$  and  $T_{cap\_samp} = 48 \mu s$ , TSICHnCNT = 480

#### 48.7.3 Electrode scan unit

This section describes the functionality of the electrode scan unit. It is responsible for triggering the start of the active electrode scan.

The touch sense input module needs to periodically scan all active electrodes to determine if a touch event has occurred. The electrode scan unit has two independent scan periods, one for TSI active mode and the other for TSI low power mode. This independent control allows the application to configure longer scan period during low power mode, so contributing to smaller average power consumption. The TSI, in low power mode, has the capability to wake the CPU upon an electrode capacitance change. When the CPU wakes, the TSI enters active mode, and produces a shorter scan period for a faster response and more robust touch detection. Apart from the periodical mode, the electrode scan unit also allows software triggering of the electrode scans. This feature is very useful for initialization of the touch application to detect the initial electrode capacitances. This module generates configurable end-of-scan interrupt to indicate the application that all electrodes were scanned. If a new electrode scan is started while the previous one is still in progress, an overrun error flag is generated, TSI continues the previous scan sequence and the latest trigger is ignored.

#### 48.7.3.1 Active electrodes

The electrode scan unit starts the capacitance measurement of all active electrodes. Each electrode pin should be activated by writing a 1 to the respective PEN[PEN] 16-bit field.

#### **Functional descriptions**

Once an electrode scan is triggered, the electrode scan unit controls the scanning of all the active electrodes sequentially. It starts the scanning of the electrode pin TSI\_IN[0] and goes sequentially scanning until it reaches the electrode pin TSI\_IN[15]. The electrode pin that does not have its bit (PEN[PEN]) enabled is not scanned and is skipped.

Only one electrode pin is functional in the low power mode scan and it's defined by the PEN[LPSP]. In low power scan mode, the configuration of PEN[PEN] bits is ignored.

## 48.7.3.2 Scan trigger

The scan trigger can be set to periodical scan or software trigger. The bit GENCS[STM] determines the TSI scan trigger mode. If STM = 1 the trigger mode is selected as continuous. If STM = 0, the software trigger mode is selected. In periodic mode the scan trigger is generated automatically by the electrode scan unit.

#### NOTE

It takes some time (less than 40  $\mu$ s) for TSI oscillators to be stable in software trigger mode and periodical scan mode.In the first scan process, TSI\_GENCS[SCNIP] lags some time before a valid after trigger happens.

## 48.7.3.3 Software trigger mode

The software trigger scan is started by writing 1 to the bit GENCS[SWTS]. A single scan of all active electrodes is performed. The software trigger scan only can be initiated by the GENCS[SWTS] bit if the STM = 0. If STM = 1, any write in the GENCS[SWTS] bit is ignored.

#### 48.7.3.4 Periodic scan control

The electrode scan unit operates both in TSI active mode and TSI low power mode. It has a separate scan period control for each one of these modes. It allows the application to controls the trade-off of the scan frequency and the average TSI module power consumption.

#### 48.7.3.4.1 Active mode periodic scan

In active mode periodic scan the scan following clocks can be selected: BUS\_CLK, MCGIRCLK and OSCERCLK. The bit field SCANC[AMCLKS] selects the TSI clock source for the active mode scan. The scan period is determined by the SCANC[SMOD] value. SMOD is the modulo of the counter that determines the scan period.

The following figure presents the scan sequence performed by the TSI module. Every active electrode is scanned sequentially, stating with the TSI\_IN[0] and ending with the TSI\_IN[15] pin, if they are active.

When the electrode scan unit starts a scan sequence, all the active electrodes will be scanned sequentially where each electrode has the scanned time defined by GENCS[NSCN]. The counter value is the sum of the total scan times of that electrode.



Figure 48-71. Scan sequence

## 48.7.3.4.2 Low power mode scan

In low power periodic scan, the scan period is define by the 4-bit binary GENCS[LPSCNITV]. The TSI module is enabled in low power modes only if the bit GENCS[STPE] is 1.

Only one electrode pin is functional in the low power mode scan and its defined by the bit-field PEN[LPSP].

#### **Functional descriptions**

## 48.7.3.4.3 End-of-scan interrupt

The electrode scan unit sets the EOSF flag in the GENCS registers once all the active electrode scan finishes. The EOSF flag generates an end-of-scan interrupt request if it is enabled. The interrupt is asserted if enabled by GENCS[TSIIE] and GENCS[ESOR] bits.

The GENCS[EOSF] indicates that all active electrode scans are finished and the respective capacitance results are in the TSICHnCNT registers. The GENCS[EOSF] is cleared by writing one to it.

## 48.7.3.4.4 Over-run interrupt

If an electrode scan is in progress and there is a scan trigger, the electrode scan unit generates an over-run error by asserting the GENCS[OVRF]. If the TSI error interrupt is active by setting the GENCS[ERIE] bit a interrupt request is asserted. The OVRF flag is cleared by writing 1 to it.

Table 48-64. TSI Module funtionality in MCU operation modes

| MCU operation mode | TSI clock sources             | TSI operation mode when TSIEN = 1 | Functional electrode pins | Required STPE state |
|--------------------|-------------------------------|-----------------------------------|---------------------------|---------------------|
| Run                | BUSCLK, MCGIRCLK,<br>OSCERCLK | Active mode                       | All                       | Don't care          |
| Wait               | BUSCLK, MCGIRCLK,<br>OSCERCLK | Active mode                       | All                       | Don't care          |
| Stop               | MCGIRCLK,<br>OSCERCLK         | Active mode                       | All                       | 1                   |
| VLPR               | BUSCLK, MCGIRCLK,<br>OSCERCLK | Active mode                       | All                       | Don't care          |
| VLPW               | BUSCLK, MCGIRCLK,<br>OSCERCLK | Active mode                       | All                       | Don't care          |
| VLPS               | MCGIRCLK,<br>OSCERCLK         | Active mode                       | All                       | 1                   |
| LLS                | LPOCLK,<br>VLPOSCCLK          | Low power mode                    | Determined by PEN[LPSP]   | 1                   |
| VLLS3              | LPOCLK,<br>VLPOSCCLK          | Low power mode                    | Determined by PEN[LPSP]   | 1                   |
| VLLS2              | LPOCLK,<br>VLPOSCCLK          | Low power mode                    | Determined by PEN[LPSP]   | 1                   |
| VLLS1              | LPOCLK,<br>VLPOSCCLK          | Low power mode                    | Determined by PEN[LPSP]   | 1                   |

### 48.7.4 Touch detection unit

The touch detection unit is responsible to detect electrode capacitance changes. It also detects the occurrence of error with the electrode in case the capacitance result is 0x0000 or 0xFFFF. The errors can be caused by the electrode pin shorted to  $V_{DD}$  or  $V_{SS}$  or by electrode capacitances out of the configuration range of the TSI module.

## 48.7.4.1 Capacitance change threshold

Each TSI pin has its result register TSICHnCNT. At the end of each electrode conversion the touch detection unit compares if the TSICHnCNT result value is inside a configurable range. The comparison range is defined individually for each TSI pin by the following registers, TSICHnHTH, the upper threshold value and TSICHnLTH, the lower threshold value. If the TSICHnCNT happens to be out of the range defined by TSICHnLTH and TSICHnHTH the GENCS[OUTRGF] flag is set. Also the corresponding bit STATUS[ORNGFx] is set indicating which electrode pins happened to have their result register out-of- range.

To clear the GENCS[OUTRGF] write 1 to it.

## 48.7.4.1.1 Out-of-range interrupt

The GENCS[OUTRGF] flag generates a TSI interrupt request if the GENCS[TSIIE] bit is set and GENCS[ESOR] bit is cleared. With this configuration, after the end-of-electrode scan, the TSI interrupt is only requested if there is a capacitance change. The capacitance change is detected when the result register gets outside the window defined by the TSI\_THRESHLD register. If the electrodes capacitance does not vary, the TSI Interrupt do not interrupt the CPU.

## 48.7.4.2 Error interrupt

The GENCS[EXTERF] is set in the case the capacitance result registers, TSICHnCNT, of a TSI pin is either 0 or 0xFFFF, the two possible extreme values. The EXTERF flag generates a TSI Error Interrupt request if the GENCS[ERIE] bit is set.

When the GENCS[EXTERF] is set, the registers STATUS register indicates which TSI pins have the error condition by setting the correspondent STATUS[ERRORx] bit.

## 48.8 Application information

After enabling the TSI module for the first time, it is highly recommended a calibration to all the enabled channels by setting proper high and low threshold value for each active channel. All the channel dedicated counter values can be read from each counter value registers, software suite can then adjust the threshold based on these values.

Follow proper PCB layout guidelines for board design on electrode shapes, sizes, routes, etc. Visit www.freescale.com/touch for application notes and reference designs.

## 48.8.1 TSI module sensitivity

The TSI module sensitivity is defined by the increment in the two 16-bit TSICHnCNT result registers caused by a reference capacitor value delta in the electrode pin capacitance.

It is given by the following equation:

$$TSI_{sensitivity} = \frac{I_{ref} * PS * NSCN}{C_{ref} * I}$$

For the example provided,  $I_{ref}$  = 2  $\mu$ A, PS = 2; NSCN = 16,  $C_{ref}$  = 1.0 pF and I =1  $\mu$ A, the TSI<sub>sensitivity</sub> = 64 count/pF

# Chapter 49 External Interrupt (IRQ)

## 49.1 Introduction

The IRQ (External Interrupt) module provides an interrupt input.

#### 49.1.1 Features

The IRQ includes these distinctive features:

- IP Bus V2.0 compliant
- External interrupt pin (IRQ)
- IRQ pin can be selected as falling edge and low level or rising edge and high level
- Separate IRQ pin enable
- Software enabled interrupt
- Programmable falling edge (or rising edge) only, or both falling edge and low level (or both rising edge and high level) interrupt sensitivity
- Exit from low-power modes
- Wake-up request to internal module(s) independent of interrupt enable
- Software control of whether on-chip pullup/pulldown device is enabled on IRQ pin

## 49.1.2 Modes of Operation

The IRQ module is mode independent and will continue to operate in all user modes. In the low power STOP mode, the IRQ input becomes an asynchronous path.

## 49.1.3 Block Diagram

The following is a block diagram of the IRQ module.



Figure 49-1. IRQ Block Diagram

# 49.2 Signal Description

The following table shows the user-accessible signal for the IRQ module.

**Table 49-1. Signal Properties** 

| Name | Function               | Reset State |
|------|------------------------|-------------|
| IRQ  | External interrupt pin | input       |

# 49.2.1 Detailed Signal Descriptions

This section describes each user-accessible pin.

1. IRQ — External interrupt input pin

This input pin is used to detect either falling edge, or both falling edge and low level interrupt requests. This input pin can also be used to detect either rising edge, or both rising edge and high level interrupt requests.

# 49.3 Memory Map and Register Description

This section provides a detailed description of the IRQ register that is accessible to the end user.

#### **IRQ** memory map

| Absolute address (hex) | Register name                                  |   | Access | Reset value | Section/<br>page |
|------------------------|------------------------------------------------|---|--------|-------------|------------------|
| FFFF_80A0              | Interrupt status and control register (IRQ_SC) | 8 | R/W    | 00h         | 49.3.1/<br>1243  |

## 49.3.1 Interrupt status and control register (IRQ\_SC)

Address: IRQ\_SC is FFFF\_80A0h base + 0h offset = FFFF\_80A0h



### IRQ\_SC field descriptions

| Field         | Description                                                                                                                                                                                                                                                               |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>Reserved | This read-only bit is reserved and always has the value zero.                                                                                                                                                                                                             |
| 6<br>IRQPDD   | IRQ pull device disable  Use this bit to disable the on-chip pullup/pulldown device on the IRQ pin. This allows users to have an external device if required for their application.  On-chip pullup/pulldown device is enabled On-chip pullup/pulldown device is disabled |
| 5<br>IRQEDG   | IRQ edge select  This bit selects the falling edge/low level or rising edge/high level function of the IRQ pin.  0 Falling edge/low level 1 Rising edge/high level                                                                                                        |
| 4<br>IRQPE    | IRQ pin enable  This bit determines whether the IRQ pin is enabled.                                                                                                                                                                                                       |

Table continues on the next page...

#### **Functional Description**

#### IRQ\_SC field descriptions (continued)

| Field       | Description                                                                                                                                                                                                   |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             | 0 IRQ pin not enabled                                                                                                                                                                                         |
|             | 1 IRQ pin enabled                                                                                                                                                                                             |
| 3<br>IRQF   | IRQ flag                                                                                                                                                                                                      |
| iriQi       | This bit indicates when an IRQ interrupt is detected.                                                                                                                                                         |
|             | 0 No IRQ interrupt detected                                                                                                                                                                                   |
|             | 1 IRQ interrupt detected                                                                                                                                                                                      |
| 2<br>IRQACK | IRQ acknowledge                                                                                                                                                                                               |
| INQACK      | Writing 1 to this bit is part of the flag clearing mechanism. For more information about flag clearing, refer to the functional description of clearing an IRQ interrupt request. This bit always reads as 0. |
| 1           | IRQ interrupt enable                                                                                                                                                                                          |
| IRQIE       | This bit determines whether an IRQ interrupt request is enabled.                                                                                                                                              |
|             | 0 IRQ interrupt requests not enabled                                                                                                                                                                          |
|             | 1 IRQ interrupt requests enabled                                                                                                                                                                              |
| 0           | IRQ detection mode                                                                                                                                                                                            |
| IRQMOD      | This bit (along with the IRQEDG bit) controls the detection mode of the IRQ pin.                                                                                                                              |
|             | 0 IRQ interrupt requests on falling edge only or on rising edge only                                                                                                                                          |
|             | 1 IRQ interrupt requests on falling edge and low level or on rising edge and high levels                                                                                                                      |

# 49.4 Functional Description

This section provides a complete functional description of the IRQ module.

## 49.4.1 External Interrupt Pin

Writing to the IRQPE bit in the SC register, enables or disables the IRQ pin.

## 49.4.2 IRQ Edge Select

The IRQEDG bit in the SC register determines if the IRQ pin is either falling edge and low level or rising edge and high level sensitive.

## 49.4.3 IRQ Sensitivity

The IRQMOD bit in the SC register controls the detection mode of the IRQ module.

- If the IRQ interrupt is falling (or rising) edge sensitive only, a falling (or rising) edge on the enabled IRQ pin will set the IRQF bit.
- If the IRQ interrupt is both falling (or rising) edge and low (or high) level sensitive, a falling (or rising) edge on the enabled IRQ sets the IRQF bit. The IRQF bit remains set as long as the IRQ pin remains asserted.

## 49.4.4 IRQ Interrupts

The IRQ module can provide a source of interrupts. To cause an IRQ module interrupt request, the following must occur:

- The IRQIE bit in the SC register must be set.
- The IRQF bit in the SC register must become set by a triggered IRQ pin. The IRQF bit becomes set by the fifth clock cycle after the IRQ pin has become asserted.
- The IRQ pin must have been in an inactive state for at least one clock cycle before becoming active.
- Changing the IRQMOD or IRQEDG bit while the IRQPE bit is enabled may cause a spurious interrupt and the IRQF bit may be inadvertently cleared.

## 49.4.5 Clearing an IRQ Interrupt Request

If the IRQ module interrupt pin is either falling edge and low level sensitive or rising edge and high level sensitive, both of the following actions must occur to clear an IRQ interrupt request:

- Software provides an interrupt acknowledge by writing a logic 1 to the IRQACK bit in the SC register.
- And either of the following:
  - The IRQ pin returns to a deasserted logic state.
  - The IRQ pin is disabled using the IRQPE bit.

If the IRQ module interrupt pin is falling (or rising) edge sensitive only, writing a logic 1 to the IRQACK bit in the SC register immediately clears the IRQ interrupt request even if the enabled IRQ pin remains asserted.

### 49.4.6 Exit from Low-Power Modes

The IRQ interrupt, if enabled, can provide a means to exit CPU low power modes, WAIT and STOP. If the detection mode is set to both falling (or rising) edge and low (or high) level sensitive and the IRQ pin is enabled and low upon entering WAIT or STOP, an immediate exit from the Low Power Mode may occur depending on the specific chip implementation. If the detection mode is set to falling (or rising) edge sensitivity only, an edge must be seen on the enabled IRQ pin to exit STOP or WAIT mode.

#### 49.4.6.1 Wait

The IRQ module remains active in WAIT mode. Setting the IRQIE bit in the SC register enables the IRQ interrupt request. Any detected IRQ interrupt will bring the CPU out of WAIT mode.

## 49.4.6.2 Stop

The IRQ module remains active in stop mode. Setting the IRQIE bit in the SC register enables the IRQ interrupt request. Any detected IRQ interrupt will bring the CPU out of stop mode.

## 49.5 Resets

The IRQ interrupt is disabled after reset. The IRQ module cannot cause an MCU reset.

## 49.6 Interrupts

The IRQ module generates a single interrupt.

The IRQ interrupt is listed in the following table, which shows the interrupt name and the name of the local enable that can be used to disable a IRQ interrupt request.

#### Chapter 49 External Interrupt (IRQ)

## **Table 49-4. Interrupt Summary**

| Interrupt | Local<br>Enable | Source    | Description                                                                                                                                                     |
|-----------|-----------------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| IRQF      | IRQIE           | IRQ input | Software programmable for falling edge only (or rising edge only), or both falling edge and low level detection (or both rising edge and high level detection). |

Interrupts

# Chapter 50 Debug

## 50.1 Introduction

This chapter describes the capabilities defined by the Version 1 ColdFire debug architecture. The Version 1 ColdFire core supports BDM functionality using the HCS08's single-pin interface. The traditional 3-pin full-duplex ColdFire BDM serial communication protocol based on 17-bit data packets is replaced with the HCS08 debug protocol where all communication is based on an 8-bit data packet using a single package pin (BKGD).

An on-chip trace buffer allows a stream of compressed processor execution status packets to be recorded for subsequent retrieval to provide program (and partial data) trace capabilities.

The following sections in this chapter provide details on the BKGD pin, the background debug serial interface controller (BDC), a standard 6-pin BDM connector, the BDM command set as well as real-time debug and trace capabilities. The V1 definition supports revision B+ (DEBUG\_B+) of the ColdFire debug architecture.

A simplified block diagram of the V1 core including the processor and debug module is shown in the following figure.

Introduction



Figure 50-1. Simplified Version 1 ColdFire Core Block Diagram

## 50.1.1 Overview

Debug support is divided into three areas:

- Background debug mode (BDM)—Provides low-level debugging in the ColdFire
  processor core. In BDM, the processor core is halted and a variety of commands can
  be sent to the processor to access memory, registers, and peripherals. The external
  emulator uses a one-pin serial communication protocol. See Background Debug
  Mode (BDM).
- Real-time debug support—Use of the full BDM command set requires the processor to be halted, which many real-time embedded applications cannot support. The core includes a variety of internal breakpoint registers which can be configured to trigger and generate a special interrupt. The resulting debug interrupt lets real-time systems execute a unique service routine that can quickly save the contents of key registers

- and variables and return the system to normal operation. The external development system can then access the saved data, because the hardware supports concurrent operation of the processor and BDM-initiated memory commands. In addition, the option is provided to allow interrupts to occur. See Real-Time Debug Support.
- Program trace support—The ability to determine the dynamic execution path through an application is fundamental for debugging. The V1 solution implements a trace buffer that records processor execution status and data, which can be subsequently accessed by the external emulator system to provide program (and optional partial data) trace information. See Trace Support.

There are two fields in debug registers which provide revision information: the hardware revision level in CSR and the 1-pin debug hardware revision level in CSR2. The following table summarizes the various debug revisions.

| Revision                | CSR[HRL] | CSR2[D1HRL] | Enhancements                                                         |
|-------------------------|----------|-------------|----------------------------------------------------------------------|
| А                       | 0000     | N/A         | Initial ColdFire debug definition                                    |
| В                       | 0001     | N/A         | BDM command execution does not affect hardware breakpoint logic      |
|                         |          |             | Added BDM address attribute register (BAAR)                          |
|                         |          |             | BKPT configurable interrupt (CSR[BKD])                               |
|                         |          |             | Level 1 and level 2 triggers on OR condition, in addition to AND     |
|                         |          |             | SYNC_PC command to display the processor's current PC                |
| B+                      | 1001     | N/A         | Added 3 PC breakpoint registers PBR1–3                               |
| CF1_B+                  | 1001     | 0001        | Converted to HCS08 1-pin BDM serial interface                        |
|                         |          |             | Added PST compression and on-chip PST/DDATA buffer for program trace |
| CF1_B+ for<br>90 nm TFS | 1001     | 0011        | CF1 debug with DBGCR and DBGSR                                       |

**Table 50-1. Debug Revision Summary** 

## 50.1.2 Features

The Version 1 ColdFire debug definition supports the following features:

- Classic ColdFire DEBUG\_B+ functionality mapped into the single-pin BDM interface
- Real time debug support, with 6 hardware breakpoints (4 PC, 1 address pair and 1 data) that can be configured into a 1- or 2-level trigger with a programmable response (processor halt or interrupt)

#### Introduction

- Capture of compressed processor status and debug data into on-chip trace buffer provides program (and optional slave bus data) trace capabilities
- On-chip trace buffer provides programmable start/stop recording conditions plus support for obtrusive or PC-profiling modes
- Debug resources are accessible via single-pin BDM interface or the privileged WDEBUG instruction from the core

## 50.1.3 Modes of Operation

V1 ColdFire devices typically implement a number of modes of operation, including run, wait, and stop modes. Additionally, the operation of the core's debug module is highly dependent on a number of chip configurations which determine its operating state.

When operating in secure mode, as defined by a 2-bit field in the flash memory examined at reset, BDM access to debug resources is extremely restricted. It is possible to tell that the device has been secured, and to clear security, which involves mass erasing the onchip flash memory. No other debug access is allowed. Secure mode can be used in conjunction with each of the wait and stop low-power modes .

If the BDM interface is not enabled, access to the debug resources is limited in the same manner as a secure device.

If the device is not secure and the BDM interface is enabled (XCSR[ENBDM] is set), the device is operating in debug mode and additional resources are available via the BDM interface. In this mode, the status of the processor (running, stopped, or halted) determines which BDM commands may be used.

Debug mode functions are managed through the background debug controller (BDC) in the Version 1 ColdFire core. The BDC provides the means for analyzing MCU operation during software development.

BDM commands can be classified into three types as shown in the following table.

Command Type

Flash
Secure?

BDM?
Core Status
Command Set

Command Set

Always-available

Secure or Unsecure
Unsecure

Enabled or Disabled

CSR2[31-24], CSR3[31-24]

Table 50-2. BDM Command Types

Table continues on the next page...

Table 50-2. BDM Command Types (continued)

| Command Type      | Flash<br>Secure? | BDM?    | Core Status | Command Set                                                                                                                                                                          |  |
|-------------------|------------------|---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Non-intrusive     | Unsecure         | Enabled | Run, Halt   | <ul><li>Memory access</li><li>Memory access with status</li><li>Debug register access</li><li>BACKGROUND</li></ul>                                                                   |  |
| Active background | Unsecure         | Enabled | Halt        | <ul> <li>Read or write CPU registers (also available in stop mode)</li> <li>Single-step the application</li> <li>Exit halt mode to return to the application program (GO)</li> </ul> |  |

For more information on these three BDM command classifications, see BDM Command Set Summary.

The core's halt mode is entered in a number of ways:

- The BKGD pin is low during POR
- The BKGD pin is low immediately after a BDM-initiated force reset (see CSR2[BDFR] in Configuration/Status Register 2 (CSR2), for details)
- A background debug force reset occurs (CSR2[BDFR] is set) and CSR2[BFHBR] is set
- An illegal operand reset occurs and CSR2[IOPHR] is set
- An illegal address reset occurs and CSR2[IADHR] is set
- A computer operating properly reset occurs and CSR2[ COPHR] is set
- A BACKGROUND command is received through the BKGD pin. If necessary, this wakes the device from STOP/WAIT modes.
- A properly-enabled (XCSR[ENBDM] is set) HALT instruction is executed
- Encountering a BDM breakpoint and the trigger response is programmed to generate a halt
- Reaching a PSTB trace buffer full condition when operating in an obtrusive recording mode (CSR2[PSTBRM] is set to 01 or 11)

While in halt mode, the core waits for serial background commands rather than executing instructions from the application program.

#### **External Signal Descriptions**



Figure 50-2. Debug Modes State Transition Diagram

The preceding figure contains a simplified view of the V1 ColdFire debug mode states. The XCSR[CLKSW] bit controls the BDC clock source. When CLKSW is set, the BDC serial clock frequency is half the CPU clock. When CLKSW is cleared, the BDC serial clock is supplied from an alternate clock source.

The ENBDM bit determines if the device can be placed in halt mode, if the core and BDC serial clocks continue to run in STOP modes, and if the regulator can be placed into standby mode. Again, if booting to halt mode, XCSR[ENBDM, CLKSW] are automatically set.

If ENBDM is cleared, the ColdFire core treats the HALT instruction as an illegal instruction and generates a reset (if CPUCR[IRD] is cleared) or an exception (if CPUCR[IRD] is set) if execution is attempted.

If XCSR[ENBDM] is set, the device can be restarted from STOP/WAIT via the BDM interface.

## 50.2 External Signal Descriptions

The following table describes the debug module's 1-pin external signal (BKGD). A standard 6-pin debug connector is shown in Freescale-Recommended BDM Pinout.

#### Table 50-3. Debug Module Signals

| Signal                     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Background Debug<br>(BKGD) | Single-wire background debug interface pin. The primary function of this pin is for bidirectional serial communication of background debug mode commands and data. During reset, this pin selects between starting in active background (halt) mode or starting the application program. This pin also requests a timed sync response pulse to allow a host development tool to determine the correct clock frequency for background debug serial communications. |

# 50.3 Memory Map and Register Descriptions

In addition to the BDM commands that provide access to the processor's registers and the memory subsystem, the debug module contains a number of registers. Most of these registers (all except the PST/DDATA trace buffer) are also accessible (write-only) from the processor's supervisor programming model by executing the WDEBUG instruction. Thus, the breakpoint hardware in the debug module can be read (certain registers) or written by the external development system using the serial debug interface or written by the operating system running on the processor core. Software is responsible for guaranteeing that accesses to these resources are serialized and logically consistent. The hardware provides a locking mechanism in the CSR to allow the external development system to disable any attempted writes by the processor to the breakpoint registers (setting CSR[IPW]). BDM commands must not be issued during the processor's execution of the WDEBUG instruction to configure debug module registers or the resulting behavior is undefined.

These registers are treated as 32-bit quantities regardless of the number of implemented bits. Unimplemented bits are reserved and must be cleared. These registers are also accessed through the BDM port by the commands WRITE\_DREG and READ\_DREG described in BDM Command Set Summary. These commands contain a 5-bit field, DRc, that specifies the register, as shown in the following table.

#### Note

Most debug control registers can be written either by the external development system or by the CPU through the WDEBUG instruction. These control registers are write-only from the programming model and they can be written through the BDM port using the WRITE\_DREG command. In addition, the four configuration/status registers (CSR, XCSR, CSR2, CSR3) can be read through the BDM port using the READ\_DREG command.

#### **Memory Map and Register Descriptions**

The ColdFire debug architecture supports a number of hardware breakpoint registers that can be configured into single- or double-level triggers based on the PC or operand address ranges with an optional inclusion of specific data values. The triggers can be configured to halt the processor or generate a debug interrupt exception. Additionally, these same breakpoint registers can be used to specify start/stop conditions for recording in the PST trace buffer.

The core includes four PC breakpoint triggers and a set of operand address breakpoint triggers with two independent address registers (to allow specification of a range) and an optional data breakpoint with masking capabilities. Core breakpoint triggers are accessible through the serial BDM interface or written through the supervisor programming model using the WDEBUG instruction.

**Table 50-4. Debug Module Memory Map** 

| DRc[4:0] | Register                                      | Width (bits)    | Access                             | Reset Value           |
|----------|-----------------------------------------------|-----------------|------------------------------------|-----------------------|
| 0x00     | Configuration/Status Register (CSR)           | 32              | R/W (BDM), W<br>(CPU)              | 0x0090_0000           |
| 0x01     | Extended Configuration/Status Register (XCSR) | 32              | R/W <sup>1</sup> (BDM), W<br>(CPU) | 0x0000_0000           |
| 0x02     | Configuration/Status Register 2 (CSR2)        | 32              | R/W <sup>1</sup> (BDM), W<br>(CPU) | See section           |
| 0x03     | Configuration/Status Register 3 (CSR3)        | 32 <sup>2</sup> | R/W <sup>1</sup> (BDM), W<br>(CPU) | 0x0000_0000           |
| _        | Debug Control Register (DBGCR)                | 32              | Indirect W via<br>CSR3 (BDM)       | 0x0000_0000           |
| _        | Debug Status Register (DBGSR)                 | 32              | Indirect R via<br>CSR3 (BDM)       | 0x0000_0000           |
| 0x05     | BDM Address Attribute Register (BAAR)         | 32 <sup>2</sup> | W                                  | 0x0000_0005           |
| 0x06     | Address Attribute Trigger Register (AATR)     | 32 <sup>2</sup> | W                                  | 0x0000_0005           |
| 0x07     | Trigger Definition Register (TDR)             | 32              | W                                  | 0x0000_0000           |
| 0x08     | Program Counter Breakpoint Register 0 (PBR0)  | 32              | W                                  | Undefined, unaffected |
| 0x09     | Program Counter Mask Register (PBMR)          | 32              | W                                  | Undefined, unaffected |
| 0x0C     | Address Breakpoint High Register (ABHR)       | 32              | W                                  | Undefined, unaffected |
| 0x0D     | Address Breakpoint Low Register (ABLR)        | 32              | W                                  | 0x0000_0000           |
| 0x0E     | Data Breakpoint Register (DBR)                | 32              | W                                  | 0x0000_0000           |
| 0x0F     | Data Breakpoint Mask Register (DBMR)          | 32              | W                                  | 0x0000_0000           |
| 0x18     | Program Counter Breakpoint Register 1 (PBR1)  | 32              | W                                  | PBR1[0] = 0           |
| 0x1A     | Program Counter Breakpoint Register 2 (PBR2)  | 32              | W                                  | PBR2[0] = 0           |
| 0x1B     | Program Counter Breakpoint Register 3 (PBR3)  | 32              | W                                  | PBR3[0] = 0           |
| _        | PST Trace Buffern (PSTBn); n = 0-11 (0xB)     | 32              | R (BDM) <sup>3</sup>               | Undefined, unaffected |

- The most significant bytes of the XCSR, CSR2, and CSR3 registers support special control functions and are writeable via BDM using the WRITE\_XCSR\_BYTE, WRITE\_CSR2\_BYTE, and WRITE\_CSR3\_BYTE commands. They can be read from BDM using the READ\_XCSR\_BYTE, READ\_CSR2\_BYTE, and READ\_CSR3\_BYTE commands. These 3 registers, along with the CSR, can also be referenced as 32-bit quantities using the BDM READ\_DREG and WRITE\_DREG commands, but the WRITE\_DREG command only writes bits 23-0 of these three registers.
- 2. Each debug register is accessed as a 32-bit value; undefined fields are reserved and must be cleared.
- 3. The contents of the PST trace buffer is only read from BDM (32 bits per access) using READ\_PSTB commands.

# 50.3.1 Configuration/Status Register (CSR)

CSR defines the debug configuration for the processor and memory subsystem and contains status information from the breakpoint logic. CSR is accessible from the programming model using the WDEBUG instruction and through the BDM port using the READ\_DREG and WRITE\_DREG commands.

DRc: 0x00 (CSR) Access: Supervisor write-only BDM read/write 27 23 31 30 29 28 26 25 24 22 21 20 19 18 17 16 HAL **BKP BSTAT** FOF TRG HRL 0 R Т Т **IPW BKD VBD** W Reset 0 0 0 0 0 0 0 0 0 0 15 12 4 14 13 11 10 9 8 6 5 3 2 1 0 0 0 0 SSM 0 0 R DDC ΙΡΙ FID TRO UHE **BTB** NPL DDH W 0 0 0 0 0 Reset 0 0 0 0 0 0 0 0 0 0 0

Table 50-5. Configuration/Status Register (CSR)

Table 50-6. CSR Field Descriptions

| Field | Description                                                                                                                                                                                                                                                                                                                                   |  |  |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 31–28 | Breakpoint status                                                                                                                                                                                                                                                                                                                             |  |  |
| BSTAT | Provides read-only status (from the BDM port only) information concerning hardware breakpoints. BSTAT is cleared by a TDR write, by a CSR read when a level-2 breakpoint is triggered, or a level-1 breakpoint is triggered and the level-2 breakpoint is disabled. The PSTB value that follows the PSTB entry of 0x1B is 0x20 + (2 x BSTAT). |  |  |
|       | 0000 No breakpoints enabled                                                                                                                                                                                                                                                                                                                   |  |  |
|       | 0001 Waiting for level-1 breakpoint                                                                                                                                                                                                                                                                                                           |  |  |
|       | 0010 Level-1 breakpoint triggered                                                                                                                                                                                                                                                                                                             |  |  |
|       | 0101 Waiting for level-2 breakpointB                                                                                                                                                                                                                                                                                                          |  |  |
|       | 0110 Level-2 breakpoint triggered                                                                                                                                                                                                                                                                                                             |  |  |

Table continues on the next page...

#### **Memory Map and Register Descriptions**

## Table 50-6. CSR Field Descriptions (continued)

| FOF Indi<br>CS<br>26 Har | ult-on-fault licates a catastrophic halt occurred and forced entry into BDM. FOF is cleared by reset or when R is read (from the BDM port only).                                                                                                                                                                                                        |
|--------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CS<br>26 Har             | R is read (from the BDM port only).                                                                                                                                                                                                                                                                                                                     |
|                          |                                                                                                                                                                                                                                                                                                                                                         |
| TPG Indi                 | rdware breakpoint trigger                                                                                                                                                                                                                                                                                                                               |
|                          | licates a hardware breakpoint halted the processor core and forced entry into BDM. Reset, the<br>oug GO command, or reading CSR (from the BDM port only) clears TRG.                                                                                                                                                                                    |
| 25 Pro                   | ocessor halt                                                                                                                                                                                                                                                                                                                                            |
|                          | licates the processor executed a HALT and forced entry into BDM. Reset, the debug go mmand, or reading CSR (from the BDM port only) clears HALT.                                                                                                                                                                                                        |
| 24 Bre                   | eakpoint assert                                                                                                                                                                                                                                                                                                                                         |
| BKPT Indi                | licates when either:                                                                                                                                                                                                                                                                                                                                    |
|                          | <ul> <li>The BKPT input was asserted,</li> <li>BDM BACKGROUND command received, or</li> <li>The PSTB halt on full condition, CSR2[PSTBH], sets.</li> </ul>                                                                                                                                                                                              |
|                          | is forces the processor into a BDM halt. Reset, the debug go command, or reading CSR (from BDM port only) clears BKPT.                                                                                                                                                                                                                                  |
| 23–20 Har                | rdware revision level                                                                                                                                                                                                                                                                                                                                   |
|                          | licates, from the BDM port only, the level of debug module functionality. An emulator can use this ormation to identify the level of functionality supported.                                                                                                                                                                                           |
| 000                      | 00 Revision A                                                                                                                                                                                                                                                                                                                                           |
| 000                      | D1 Revision B                                                                                                                                                                                                                                                                                                                                           |
| 001                      | 10 Revision C                                                                                                                                                                                                                                                                                                                                           |
| 001                      | 11 Revision D                                                                                                                                                                                                                                                                                                                                           |
| 100                      | Revision B+ (The value used for this device)                                                                                                                                                                                                                                                                                                            |
| 011                      | 10 Revision D+                                                                                                                                                                                                                                                                                                                                          |
| 19 Res                   | served; must be cleared.                                                                                                                                                                                                                                                                                                                                |
| 18 Bre                   | eakpoint disable                                                                                                                                                                                                                                                                                                                                        |
|                          | cables the BACKGROUND command functionality, and allows the execution of the CKGROUND command to generate a debug interrupt.                                                                                                                                                                                                                            |
| 0                        | Normal operation                                                                                                                                                                                                                                                                                                                                        |
| 1                        | The receipt of a BDM BACKGROUND command signals a debug interrupt to the ColdFire core. The processor makes this interrupt request pending until the next sample point occurs, when the exception is initiated. In the ColdFire architecture, the interrupt sample point occurs once per instruction. There is no support for nesting debug interrupts. |
| 17 Res                   | served; must be cleared.                                                                                                                                                                                                                                                                                                                                |
|                          | ibit processor writes. Inhibits processor-initiated writes to the debug module's programming del registers. IPW can be modified only by commands from the BDM interface.                                                                                                                                                                                |
| 15 Res                   | served; must be cleared.                                                                                                                                                                                                                                                                                                                                |

Table continues on the next page...

# Table 50-6. CSR Field Descriptions (continued)

| Field | Description                                                                                                                                                                                                                                                                                                                                                                          |  |  |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 14    | Force emulation mode on trace exception                                                                                                                                                                                                                                                                                                                                              |  |  |
| TRC   | 0 Processor enters supervisor mode.                                                                                                                                                                                                                                                                                                                                                  |  |  |
|       | 1 Processor enters emulator mode when a trace exception occurs.                                                                                                                                                                                                                                                                                                                      |  |  |
| 13    | Reserved; must be cleared.                                                                                                                                                                                                                                                                                                                                                           |  |  |
| 12–11 | Debug data control.                                                                                                                                                                                                                                                                                                                                                                  |  |  |
| DDC   | Controls peripheral bus operand data capture for DDATA, which displays the number of bytes defined by the operand reference size (a marker) before the actual data; byte displays 8 bits, word displays 16 bits, and long displays 32 bits (one nibble at a time across multiple PSTCLK clock cycles). See Table 27-30. A non-zero value enables partial data trace capabilities.    |  |  |
|       | 00 No operand data is displayed.                                                                                                                                                                                                                                                                                                                                                     |  |  |
|       | 01 Capture all write data.                                                                                                                                                                                                                                                                                                                                                           |  |  |
|       | 10 Capture all read data.                                                                                                                                                                                                                                                                                                                                                            |  |  |
|       | 11 Capture all read and write data.                                                                                                                                                                                                                                                                                                                                                  |  |  |
| 10    | User halt enable                                                                                                                                                                                                                                                                                                                                                                     |  |  |
| UHE   | Selects the CPU privilege level required to execute the HALT instruction. The core must be operating with XCSR[ENBDM] set to execute any HALT instruction, else the instruction is treated as an illegal opcode.                                                                                                                                                                     |  |  |
|       | 0 HALT is a supervisor-only instruction.                                                                                                                                                                                                                                                                                                                                             |  |  |
|       | 1 HALT is a supervisor/user instruction.                                                                                                                                                                                                                                                                                                                                             |  |  |
| 9–8   | Branch target bytes                                                                                                                                                                                                                                                                                                                                                                  |  |  |
| втв   | Defines the number of bytes of branch target address DDATA displays.                                                                                                                                                                                                                                                                                                                 |  |  |
|       | 00 No target address capture.                                                                                                                                                                                                                                                                                                                                                        |  |  |
|       | 01 Lower 2 bytes of the target address                                                                                                                                                                                                                                                                                                                                               |  |  |
|       | 1x Lower 3 bytes of the target address                                                                                                                                                                                                                                                                                                                                               |  |  |
| 7     | Reserved; must be cleared.                                                                                                                                                                                                                                                                                                                                                           |  |  |
| 6     | Non-pipelined mode                                                                                                                                                                                                                                                                                                                                                                   |  |  |
| NPL   | Determines if the core operates in pipelined mode.                                                                                                                                                                                                                                                                                                                                   |  |  |
|       | 0 Pipelined mode                                                                                                                                                                                                                                                                                                                                                                     |  |  |
|       | Non-pipelined mode. The processor effectively executes one instruction at a time with no overlap. This typically adds five cycles to the execution time of each instruction. Given an average execution latency of ~2 cycles per instruction, throughput in non-pipeline mode would be ~7 cycles per instruction, approximately 25% - 33% of pipelined performance.                  |  |  |
|       | Regardless of the NPL state, a triggered PC breakpoint is always reported before the triggering instruction executes. In normal pipeline operation, the occurrence of an address and/or data breakpoint trigger is imprecise. In non-pipeline mode, these triggers are always reported before the next instruction begins execution and trigger reporting can be considered precise. |  |  |
| 5     | Ignore pending interrupts when in single-step mode                                                                                                                                                                                                                                                                                                                                   |  |  |
| IPI   | O Core services any pending interrupt requests signalled while in single-step mode.                                                                                                                                                                                                                                                                                                  |  |  |
|       | 1 Core ignores any pending interrupt requests signalled while in single-step mode.                                                                                                                                                                                                                                                                                                   |  |  |

Table continues on the next page...

#### **Memory Map and Register Descriptions**

Table 50-6. CSR Field Descriptions (continued)

| Field | Description                                                                                                                                                                                                                                                       |  |  |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 4     | Single-step mode enable                                                                                                                                                                                                                                           |  |  |
| SSM   | 0 Normal mode.                                                                                                                                                                                                                                                    |  |  |
|       | Single-step mode. The processor halts after execution of each instruction. While halted, any BDM command can be executed. On receipt of the GO command, the processor executes the next instruction and halts again. This process continues until SSM is cleared. |  |  |
| 3–2   | Reserved; must be cleared.                                                                                                                                                                                                                                        |  |  |
| 1     | Force ipg_debug                                                                                                                                                                                                                                                   |  |  |
| FID   | The core generates this output to the device, signaling it is in debug mode.                                                                                                                                                                                      |  |  |
|       | 0 Do not force the assertion of ipg_debug.                                                                                                                                                                                                                        |  |  |
|       | 1 Force the assertion of ipg_debug.                                                                                                                                                                                                                               |  |  |
| 0     | Disable ipg_debug due to a halt condition.                                                                                                                                                                                                                        |  |  |
| DDH   | The core generates an output to the other modules in the device, signaling it is in debug mode. By default, this output signal is asserted when the core halts.                                                                                                   |  |  |
|       | 0 Assert ipg_debug if the core is halted.                                                                                                                                                                                                                         |  |  |
|       | 1 Negate ipg_debug due to the core being halted.                                                                                                                                                                                                                  |  |  |

## 50.3.2 Extended Configuration/Status Register (XCSR)

The 32-bit XCSR is partitioned into two sections: the upper byte contains status and command bits always accessible to the BDM interface, even if debug mode is disabled. This status byte is also known as XCSR\_SB. The lower 24 bits contain fields related to the generation of automatic SYNC\_PC commands, which can be used to periodically capture and display the current program counter (PC) in the PST trace buffer (if properly configured).

This table summarizes the methods for accessing the XCSR.

Table 50-7. XCSR Access Summary

| Reference method | Details                                                                             |
|------------------|-------------------------------------------------------------------------------------|
| READ_XCSR_BYTE   | Reads bits 31–24 from the BDM interface. Available in all modes.                    |
| WRITE_XCSR_BYTE  | Writes bits 31–24 from the BDM interface. Available in all modes.                   |
| READ_DREG        | Reads bits 31–0 from the BDM interface. Classified as a non-intrusive BDM command.  |
| WRITE_DREG       | Writes bits 23–0 from the BDM interface. Classified as a non-intrusive BDM command. |

Table continues on the next page...

# Table 50-7. XCSR Access Summary (continued)

| Reference method   | Details                                                                                                                         |
|--------------------|---------------------------------------------------------------------------------------------------------------------------------|
| WDEBUG instruction | Writes bits 23–0 during execution of the core WDEBUG instruction. This instruction is a privileged supervisor-mode instruction. |

## Table 50-8. Extended Configuration/Status Register (XCSR)



## Table 50-9. XCSR Field Descriptions

| Field   | Description                                                                                                                                                                                              |
|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31      | CPU Halt                                                                                                                                                                                                 |
| CPUHALT | Indicates that the CPU is in the halt state. The CPU state may be running, stopped, or halted, as indicated by the CPUHALT and CPUSTOP bits. If both CPUHALT and CPUSTOP are 0, then the CPU is running. |
| 30      | CPU Stop                                                                                                                                                                                                 |
| CPUSTOP | Indicates that the CPU is in the stop state. The CPU state may be running, stopped, or halted, as indicated by the CPUHALT and CPUSTOP bits. If both CPUHALT and CPUSTOP are 0, then the CPU is running. |

Table 50-9. XCSR Field Descriptions (continued)

| Field    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |
|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 29–27    | BDM Command Status                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |
| CSTAT    | Indicates the BDM command status.                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |
|          | 000 Command done, no errors                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |
|          | 001 Command done, data invalid                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |
|          | 01x Command done, illegal                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |
|          | 1xx Command busy, overrun                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |
|          | If an overrun is detected (CSTAT = 1xx), the following sequence is suggested to clear the source of the error:  1. Issue a SYNC command to reset the BDC channel.  2. The host issues a BDM NOP command.  3. The host checks the channel status using a READ_XCSR_BYTE command.  4. If CSTAT = 000, then you can proceed; else:  a. Halt the CPU with a BDM BACKGROUND command.  b. Repeat steps 1 through 3.  c. If CSTAT != 000, then reset device. |  |  |  |  |
| 26       | Clock Select                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |
| CLKSW    | Select source for serial BDC communication clock.                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |
|          | 0 Alternate, asynchronous BDC clock, typically 10 MHz                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |
|          | 1 Synchronous bus clock (CPU clock divided by 2)                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |
|          | The initial state of the CLKSW bit is loaded by the hardware in response to certain reset events and the state of the BKGD pin, as described in Figure 50-2.                                                                                                                                                                                                                                                                                          |  |  |  |  |
| 25       | Flash Security Status                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |
| SEC      | This bit's read value typically indicates the status of the flash security field.                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |
|          | 0 Flash security disabled                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |
|          | 1 Flash security enabled                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |
|          | In addition, the SEC bit is context-sensitive during reads. After a mass erase sequence has been initiated by BDM, SEC acts as a flash busy flag. When the erase operation is complete and the bit is cleared, it returns to indicating the status of flash security.                                                                                                                                                                                 |  |  |  |  |
|          | 0 Flash is not busy performing a BDM mass erase sequence                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |
|          | 1 Flash is busy performing a BDM mass erase sequence                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |
| 24       | Enable BDM                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |
| ENBDM    | 0 Disable BDM                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |
|          | 1 Enable BDM (assuming the flash is not secure, as indicated in SEC)                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |
| 23–3     | Reserved for future use by the debug module. These bits must all equal 0b.                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |
| Reserved |                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |
| 2–1      | Automatic PC Synchronization Control                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |
| APCSC    | If APCENB is 1b, determines the periodic interval of PC address captures. When the selected interval is reached, a SYNC_PC command is sent to the CPU. For more information on the SYNC_PC operation, see the APCENB description.                                                                                                                                                                                                                     |  |  |  |  |
|          | The chosen frequency depends on the setting of CSR2[APCDIV16], as shown in Table 50-10.                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |

Table continues on the next page...

## MCF51JF128 Reference Manual, Rev. 2, 03/2011

Table 50-9. XCSR Field Descriptions (continued)

| Field  | Description                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |
|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 0      | Automatic PC Synchronization Enable                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |
| APCENB | Enables the periodic output of the PC, which can be used for PST/DDATA trace synchronization and code profiling.                                                                                                                                                                                                                                                                                                                        |  |  |  |
|        | As described in APCSC, when the enabled periodic timer expires, a SYNC_PC command is sent to the CPU that generates a forced instruction fetch of the next instruction. The PST/DDATA module captures the target address as defined by CSR[9] (two bytes if CSR[9] is 0b, three bytes if CSR[9] is 1b). This produces a PST sequence of the PST marker indicating a 2- or 3-byte address, followed by the captured instruction address. |  |  |  |
|        | 0 Disable automatic PC synchronization                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |
|        | 1 Enable automatic PC synchronization                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |

This table shows the selected PC address capture period as determined by the XCSR[APCENB], CSR2[APCDIV16], and XCSR[APCSC] fields.

Table 50-10. PC address capture period (SYNC\_PC interval)

| XCSR[APCENB] | CSR2[APCDIV16] | XCSR[APCSC] | SYNC_PC interval (cycles) |
|--------------|----------------|-------------|---------------------------|
| 1            | 1              | 00          | 128                       |
| 1            | 1              | 01          | 256                       |
| 1            | 1              | 10          | 512                       |
| 1            | 1              | 11          | 1024                      |
| 1            | 0              | 00          | 2048                      |
| 1            | 0              | 01          | 4096                      |
| 1            | 0              | 10          | 8092                      |
| 1            | 0              | 11          | 16384                     |

## 50.3.3 Configuration/Status Register 2 (CSR2)

The 32-bit CSR2 is partitioned into two sections. The upper byte contains status and configuration bits always accessible to the BDM interface, even if debug mode is disabled. The lower 24 bits contain fields related to the configuration of the PST trace buffer (PSTB).

This table summarizes the methods for accessing CSR2.

Table 50-11. CSR2 Access Summary

| Reference method | Details                                                          |  |  |  |
|------------------|------------------------------------------------------------------|--|--|--|
| READ_CSR2_BYTE   | Reads bits 31–24 from the BDM interface. Available in all modes. |  |  |  |

## Table 50-11. CSR2 Access Summary (continued)

| Reference method   | Details                                                                                                                         |
|--------------------|---------------------------------------------------------------------------------------------------------------------------------|
| WRITE_CSR2_BYTE    | Writes bits 31–24 from the BDM interface. Available in all modes.                                                               |
| READ_DREG          | Reads bits 31–0 from the BDM interface. Classified as a non-intrusive BDM command.                                              |
| WRITE_DREG         | Writes bits 23–0 from the BDM interface. Classified as a non-intrusive BDM command.                                             |
| WDEBUG instruction | Writes bits 23–0 during execution of the core WDEBUG instruction. This instruction is a privileged supervisor-mode instruction. |

| DRc: 0x02 (       | DRc: 0x02 (CSR2)         |    |           |           | Access: Supervisor read-only |    |           |          |           | ad-only  |          |         |      |     |       |    |  |
|-------------------|--------------------------|----|-----------|-----------|------------------------------|----|-----------|----------|-----------|----------|----------|---------|------|-----|-------|----|--|
|                   |                          |    |           |           |                              |    |           |          |           | ВІ       | OM rea   | d/write |      |     |       |    |  |
|                   | 31                       | 30 | 29        | 28        | 27                           | 26 | 25        | 24       | 23        | 22       | 21       | 20      | 19   | 18  | 17    | 16 |  |
| R                 | PST<br>BP                | 0  | COP<br>HR | IOP<br>HR | IADH<br>R                    | 0  | BFH<br>BR | 0        | PST<br>BH | PST      | PSTBST 0 |         |      | D1I | D1HRL |    |  |
| W                 |                          |    |           |           |                              |    |           | BDF<br>R |           |          |          |         |      |     |       |    |  |
| Power-on<br>Reset | 1                        | 1  | 0         | 0         | 0                            | 0  | 0         | 0        | 0         | 0        | 0        | 0       | 0    | 0   | 1     | 1  |  |
| Other<br>Reset    | 0                        | 0  | u         | u         | u                            | 0  | u         | 0        | 0         | 0        | 0        | 0       | 0    | 0   | 1     | 1  |  |
|                   | 15                       | 14 | 13        | 12        | 11                           | 10 | 9         | 8        | 7         | 6        | 5        | 4       | 3    | 2   | 1     | 0  |  |
| R                 | PSTBWA                   |    |           |           |                              | •  | 0         | 9        | 0         | PST      | BRM      | F       | STBS | S   |       |    |  |
| W                 |                          |    |           |           |                              |    |           |          | PSTB<br>R | APCDIV16 |          |         |      |     |       |    |  |
| Reset             | Undefined and Unaffected |    |           |           |                              | 0  | 0         | 0        | 0         | 0        | 0        | 0       | 0    |     |       |    |  |

## Table 50-12. CSR2 Field Descriptions

| Field | Description                                              |
|-------|----------------------------------------------------------|
| 31    | PST Buffer Stop                                          |
| PSTBP | Signals if a PST buffer stop condition has been reached. |
|       | 0 Stop condition has not been reached                    |
|       | 1 Stop condition has been reached                        |
| 30    | Reserved. Must write 0.                                  |

# Table 50-12. CSR2 Field Descriptions (continued)

| Field | Description                                                                                                                                                                                      |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 29    | Computer Operating Properly Halt After Reset                                                                                                                                                     |
| COPHR | Specifies operation of the device after a COP reset. This bit is 0b after a power-on reset and is unaffected by any other reset.                                                                 |
|       | NOTE: This bit can be changed only if XCSR[ENBDM] is 1b and the system is not secure.                                                                                                            |
|       | 0 The device immediately enters normal operation mode.                                                                                                                                           |
|       | 1 The device halts (as if the BKGD pin was held low after a power-on reset).                                                                                                                     |
| 28    | Illegal Operation Halt After Reset                                                                                                                                                               |
| IOPHR | Specifies operation of the device after an illegal operation reset. This bit is 0b after a power-on reset and is unaffected by any other reset.                                                  |
|       | NOTE: This bit can be changed only if XCSR[ENBDM] is 1b and the flash is not secure.                                                                                                             |
|       | 0 The device immediately enters normal operation mode.                                                                                                                                           |
|       | 1 The device halts (as if the BKGD pin was held low after a power-on reset).                                                                                                                     |
| 27    | Illegal Address Halt After Reset                                                                                                                                                                 |
| IADHR | Specifies operation of the device after an illegal address reset. This bit is 0b after a power-on reset and is unaffected by any other reset.                                                    |
|       | NOTE: This bit can be changed only if XCSR[ENBDM] is 1b and the system is not secure.                                                                                                            |
|       | 0 The device immediately enters normal operation mode.                                                                                                                                           |
|       | 1 The device halts (as if the BKGD pin was held low after a power-on reset).                                                                                                                     |
| 26    | Reserved. Must write 0.                                                                                                                                                                          |
| 25    | BDM Force Halt on BDM Reset                                                                                                                                                                      |
| BFHBR | Specifies operation of the device after a BDM reset (on any reset based on external BKGD logic implementation). This bit is cleared after a power-on reset and is unaffected by any other reset. |
|       | NOTE: This bit can be changed only if XCSR[ENBDM] is 1b and the system is not secure.                                                                                                            |
|       | 0 The device immediately enters normal operation mode.                                                                                                                                           |
|       | 1 The device halts (as if the BKGD pin was held low after a power-on reset).                                                                                                                     |
| 24    | Background Debug Force Reset                                                                                                                                                                     |
| BDFR  | Forces a BDM reset to the device. This bit always reads as 0 after the reset has been initiated.                                                                                                 |
|       | 0 No reset                                                                                                                                                                                       |
|       | 1 Force a BDM reset                                                                                                                                                                              |
| 23    | PST Trace Buffer Halt                                                                                                                                                                            |
| PSTBH | Indicates if the processor is halted due to the PST trace buffer being full when recording in obtrusive mode.                                                                                    |
|       | 0 Not halted                                                                                                                                                                                     |
|       | 1 Halted                                                                                                                                                                                         |

## Table 50-12. CSR2 Field Descriptions (continued)

| Field    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 22–21    | PST Trace Buffer State                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| PSTBST   | Indicates the current state of PST trace buffer recording.                                                                                                                                                                                                                                                                                                                                                                                                           |
|          | 00 Disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|          | 01 Enabled and waiting for the start condition                                                                                                                                                                                                                                                                                                                                                                                                                       |
|          | 10 Enabled, recording, and waiting for the stop condition                                                                                                                                                                                                                                                                                                                                                                                                            |
|          | 11 Enabled, completed recording after the stop condition was reached                                                                                                                                                                                                                                                                                                                                                                                                 |
| 20       | Reserved. Must write 0.                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 19–16    | Debug 1-pin Hardware Revision Level                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| D1HRL    | Indicates the hardware revision level of the 1-pin debug module implemented in the core. For this device, this field is 3h.                                                                                                                                                                                                                                                                                                                                          |
| 15–8     | PST Trace Buffer Write Address                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| PSTBWA   | Indicates the current write address of the PST trace buffer. The most significant bit of this field is sticky; if set, it remains set until a PST/DDATA reset event occurs. As the core inserts PST and DDATA packets into the trace buffer, this field is incremented. The value of the write address defines the next location in the PST trace buffer to be loaded. In other words, the contents of PSTB[PSTBWA – 1] is the last valid entry in the trace buffer. |
|          | The most-significant bit of this field can be used to determine if the entire PST trace buffer has been loaded with valid data.                                                                                                                                                                                                                                                                                                                                      |
|          | The PSTBWA is unaffected when a buffer stop condition has been reached, the buffer is disabled, or a system reset occurs. This allows the contents of the PST trace buffer to be retrieved after these events to assist in debug.                                                                                                                                                                                                                                    |
|          | NOTE: Because this device contains a 64-entry trace buffer, PSTBWA[6] is always zero.                                                                                                                                                                                                                                                                                                                                                                                |
|          | Bit 7 PSTB valid data locations (oldest to newest)                                                                                                                                                                                                                                                                                                                                                                                                                   |
|          | 0 0, 1,, PSTBWA – 1                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|          | 1 PSTBWA, PSTBWA + 1,, 0, 1,, PSTBWA – 1                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 7        | PST Trace Buffer Reset                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| PSTBR    | Generates a reset of the PST trace buffer logic, which clears PSTBWA and PSTBST. The same resources are reset when a disabled trace buffer becomes enabled and upon the receipt of a BDM GO command when operating in obtrusive trace mode. These reset events also clear any accumulation of PSTs. This bit always reads as 0b.                                                                                                                                     |
|          | 0 No reset                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|          | 1 Force a PST trace buffer reset                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 6        | Automatic PC Synchronization Divide Cycle Counts by 16                                                                                                                                                                                                                                                                                                                                                                                                               |
| APCDIV16 | Divides the cycle counts for automatic SYNC_PC command insertion by 16. See the XCSR[APCSC] and XCSR[APCENB] fields.                                                                                                                                                                                                                                                                                                                                                 |
| 5        | Reserved. Must write 0.                                                                                                                                                                                                                                                                                                                                                                                                                                              |

Table 50-12. CSR2 Field Descriptions (continued)

| Field  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |
|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 4–3    | PST Trace Buffer Recording Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |
| PSTBRM | Specifies the trace buffer recording mode. The start and stop recording conditions are defined by the PSTBSS field.                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |
|        | <ul> <li>The terms obtrusive and non-obtrusive are defined as:</li> <li>Non-obtrusive—The core is not halted. The PST trace buffer is overwritten unless a PSTB start/stop combination results in less than or equal to 64 PSTB captures.</li> <li>Obtrusive—The core is halted when the PSTB trace buffer reaches its full level (full before overwriting). The PSTB trace buffer contents are available by the BDM PSTB_READ commands. The PSTB trace buffer write address resets and the CPU resumes upon a BDM GO command.</li> </ul> |  |  |  |  |
|        | 00 Non-obtrusive, normal recording mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |
|        | 01 Obtrusive, normal recording                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |
|        | Non-obtrusive, PC profile recording. Automatic PC synchronization must be enabled (see XCSR[APCSC, APCENB], CSR2[APCDIV16], and CSR[BTB]).                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |
|        | Obtrusive, PC profile recording. Automatic PC synchronization must be enabled (see XCSR[APCSC, APCENB], CSR2[APCDIV16], and CSR[BTB]).                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |
| 2–0    | PST Trace Buffer Start/Stop Definition                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |
| PSTBSS | Specifies the start and stop conditions for PST trace buffer recording. In certain cases, the start and stop conditions are defined by the breakpoint registers. The remaining breakpoint registers are available for trigger configurations. See Table 50-13.                                                                                                                                                                                                                                                                            |  |  |  |  |

This table shows the start and stop recording conditions as specified by the PSTBSS field.

Table 50-13. PST trace buffer start and stop recording conditions (CSR2[PSTBSS])

| PSTBSS | Start condition    | Stop condition     |  |  |  |  |
|--------|--------------------|--------------------|--|--|--|--|
| 000    | Trace buffer disal | bled, no recording |  |  |  |  |
| 001    | Uncondition        | nal recording      |  |  |  |  |
| 010    | ABxR{& DBR/DBMR}   | PBR0/PBMR          |  |  |  |  |
| 011    |                    | PBR1               |  |  |  |  |
| 100    | PBR0/PBMR          | ABxR{& DBR/DBMR}   |  |  |  |  |
| 101    |                    | PBR1               |  |  |  |  |
| 110    | PBR1               | ABxR{& DBR/DBMR}   |  |  |  |  |
| 111    |                    | PBR0/PBMR          |  |  |  |  |

## 50.3.4 Configuration/Status Register 3 (CSR3)

The CSR3 contains fields enabling indirect writes to the DBGCR. Writes to these CSR3 fields execute 4-bit nibble writes to the DBGCR. Thus, writing to the entire 32-bit DBGCR would require eight "write CSR3" commands be processed via the single-pin BDM interface.

When read, CSR3 enables indirect reads of the DBGSR. When a "read CSR3" command is transmitted on the single-pin BDM interface, one byte of DBGSR is read and returned. The debug logic maintains a 2-bit counter that selects the byte of the DBGSR register to be read, starting with DBGSR[7:0]. The 2-bit counter is cleared by POR and by any write to the CSR3. It is incremented by any read of the CSR3. Thus, a read of the entire 32-bit DBGSR would require four "read CSR3" commands be processed on the single-pin BDM interface, and the sequential commands would return data in the following order: DBGSR[7:0], DBGSR[15:8], DBGSR[23:16], and DBGSR[31:24].

This table summarizes the methods for accessing CSR3.

Table 50-14. CSR3 Reference Summary

| Method             | Reference Details                                                                         |
|--------------------|-------------------------------------------------------------------------------------------|
| READ_CSR3_BYTE     | Reads bits CSR3[31–24] from the BDM interface. Available in all modes.                    |
| WRITE_CSR3_BYTE    | Writes bits CSR3[31–24] from the BDM interface. Available in all modes.                   |
| READ_DREG          | Reads bits CSR3[31–0] from the BDM interface. Classified as a non-intrusive BDM command.  |
| WRITE_DREG         | Writes bits CSR3[23–0] from the BDM interface. Classified as a non-intrusive BDM command. |
| WDEBUG instruction | No operation while the core executes a WDEBUG instruction.                                |

| DRc: 0x03 (CSR3) |    |    |    |    |    |    |    |    | Access: Supervisor write-only |    |    |    |    |    |        |         |
|------------------|----|----|----|----|----|----|----|----|-------------------------------|----|----|----|----|----|--------|---------|
|                  |    |    |    |    |    |    |    |    |                               |    |    |    |    | ВІ | DM rea | d/write |
|                  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23                            | 22 | 21 | 20 | 19 | 18 | 17     | 16      |
| R                | UI |    | NS | !  |    | V  | /D |    | 0                             | 0  | 0  | 0  | 0  | 0  | 0      | 0       |
| W                | 1  |    |    |    |    |    |    |    |                               |    |    |    |    |    |        |         |
| Reset            | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                             | 0  | 0  | 0  | 0  | 0  | 0      | 0       |
|                  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7                             | 6  | 5  | 4  | 3  | 2  | 1      | 0       |
| R                | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                             | 0  | 0  | 0  | 0  | 0  | 0      | 0       |
| W                |    |    |    |    |    |    |    |    |                               |    |    |    |    |    |        |         |
| Reset            | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                             | 0  | 0  | 0  | 0  | 0  | 0      | 0       |

| Table 30-13. Collo i leia bescriptions | Table 50-15. | <b>CSR3 Field Descriptions</b> |
|----------------------------------------|--------------|--------------------------------|
|----------------------------------------|--------------|--------------------------------|

| Field | Description                                                                                                                                     |  |  |  |  |  |  |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| 31    | Update indicator for write to DBGCR                                                                                                             |  |  |  |  |  |  |
| UI    | When set to 1, this bit signals the chip that an update has been completed and the content of the DBGCR is valid.                               |  |  |  |  |  |  |
| 30–28 | Nibble select for write to DBGCR                                                                                                                |  |  |  |  |  |  |
| NS    | This field selects which nibble in the DBGCR is written.                                                                                        |  |  |  |  |  |  |
|       | 000 Write DBGCR[31:28]                                                                                                                          |  |  |  |  |  |  |
|       | 001 Write DBGCR[27:24]                                                                                                                          |  |  |  |  |  |  |
|       | 010 Write DBGCR[23:20]                                                                                                                          |  |  |  |  |  |  |
|       |                                                                                                                                                 |  |  |  |  |  |  |
|       | 111 Write DBGCR[3:0]                                                                                                                            |  |  |  |  |  |  |
| 27–24 | Write data to DBGCR                                                                                                                             |  |  |  |  |  |  |
| WD    | This field defines the data to be written into the selected nibble of the DBGCR. The selected nibble is determined by the value of CSR3[30:28]. |  |  |  |  |  |  |
| 23–0  | Reserved for future use by the debug module; must be cleared.                                                                                   |  |  |  |  |  |  |

# 50.3.5 Debug Control Register (DBGCR) and Debug Status Register (DBGSR)

The 32-bit DBGCR and 32-bit DBGSR are accessible only via the BDM port. They provide functionality for mass erase operations and for monitoring when the chip is or was in low power modes.

The DBGCR and DBGSR are accessed indirectly via fields in the CSR3.

The CSR3 contains fields enabling indirect writes to the DBGCR. Writes to these CSR3 fields execute 4-bit nibble writes to the DBGCR. Thus, writing to the entire 32-bit DBGCR would require eight "write CSR3" commands be processed via the single-pin BDM interface.

When read, CSR3 enables indirect reads of the DBGSR. When a "read CSR3" command is transmitted on the single-pin BDM interface, one byte of DBGSR is read and returned. The debug logic maintains a 2-bit counter that selects the byte of the DBGSR register to be read, starting with DBGSR[7:0]. The 2-bit counter is cleared by POR and by any write to the CSR3. It is incremented by any read of the CSR3. Thus, a read of the entire 32-bit DBGSR would require four "read CSR3" commands be processed on the single-pin BDM interface, and the sequential commands would return data in the following order: DBGSR[7:0], DBGSR[15:8], DBGSR[23:16], and DBGSR[31:24].

Using these registers, the flash memory mass erase procedure consists of these steps:

- 1. Initiate the operation: Write the CSR3 to set DBGCR[0] to 1.
- 2. Confirm that the operation is complete: Read the CSR3 to poll the DBGSR[0] flag, which reflects the operation's status. The operation is complete when DBGSR[0] is 1.

#### Table 50-16. DBGCR Definition

| Bit Number | Bit Name                            | Description                                                                                                                                                                                                                   |
|------------|-------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0          | Flash Mass<br>Erase Command         | Set this bit to 1 to initiate a mass erase. This bit is cleared by hardware after the launch of the mass erase operation.                                                                                                     |
|            |                                     | NOTE: When the mass erase capability is disabled (due to the values of the flash memory module's FSEC[MEEN] and FSEC[SEC] fields), the Erase Command request is still issued and acknowledged, but no erase operation occurs. |
| 1          | LLS, VLLSx<br>Status<br>Acknowledge | Set this bit to 1 to acknowledge that a read of the DBGSR's LLS and VLLSx Mode Exit status bits has occurred. This acknowledgement automatically clears the status bits.                                                      |

#### Table 50-17. DBGSR Definition

| Bit Number | Bit Name                      | Description                                                                                                                                                                                                                                     |  |  |  |  |  |
|------------|-------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 0          | ERASE STATUS                  | This bit is cleared after any system reset. The bit is also cleared at the launch of a mass erase command due to a write of the DBGCR[0] bit. The bit is set at the completion of the mass erase sequence.                                      |  |  |  |  |  |
|            |                               | NOTE: If the mass erase function is disabled, the mass erase sequence is completed, but no erase operation occurs. The value of DBGSR[2] reflects whether the flash memory module's FSEC[MEEN] field is set to disable the mass erase function. |  |  |  |  |  |
|            |                               | 0: Status cleared or mass erase not done                                                                                                                                                                                                        |  |  |  |  |  |
|            |                               | 1: Mass erase sequence done                                                                                                                                                                                                                     |  |  |  |  |  |
| 1          | Freescale<br>Factory Access   | This bit indicates whether or not Freescale's factory testing can access the chip's flash memory contents.                                                                                                                                      |  |  |  |  |  |
|            |                               | 0: Freescale factory access is denied (FSEC[FSLACC] is 01 or 10)                                                                                                                                                                                |  |  |  |  |  |
|            |                               | 1: Freescale factory access is granted (FSEC[FSLACC] is 00 or 11)                                                                                                                                                                               |  |  |  |  |  |
| 2          | Mass Erase                    | This bit indicates whether or not the flash memory can be mass erased.                                                                                                                                                                          |  |  |  |  |  |
|            | Enable                        | 0: Mass erase is disabled (FSEC[MEEN] is 10)                                                                                                                                                                                                    |  |  |  |  |  |
|            |                               | 1: Mass erase is enabled (FSEC[MEEN] is 00, 01, or 11)                                                                                                                                                                                          |  |  |  |  |  |
| 3          | Backdoor Key<br>Access Enable | This bit indicates whether or not the the flash memory has backdoor key access enabled.                                                                                                                                                         |  |  |  |  |  |
|            |                               | 0: Backdoor key access is disabled (FSEC[KEYEN] is 00, 01, or 11)                                                                                                                                                                               |  |  |  |  |  |
|            |                               | 1: Backdoor key access is enabled (FSEC[KEYEN] is 10)                                                                                                                                                                                           |  |  |  |  |  |
| 4          | Very Low Power<br>Modes       | This bit always indicates whether the current power mode is one of the VLPx modes. This bit is used to throttle debugger frequency up/down.                                                                                                     |  |  |  |  |  |

Table 50-17. DBGSR Definition (continued)

| Bit Number | Bit Name            | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5          | LLS Mode Exit       | This bit indicates that an exit from LLS mode has occurred. The debugger loses communication (including access to this register) while the system is in LLS mode. When communication is re-established, this bit indicates that the system had been in LLS mode. The debug modules hold their state during LLS mode, so they do not require reconfiguration after an exit from LLS mode. The LLS Mode Exit bit is held until the debugger recognizes that LLS mode was exited. The bit is cleared by a write of 1 to the DBGCR[1] bit (LLS, VLLSx Status Acknowledge bit).                          |
| 6          | VLLSx Modes<br>Exit | This bit indicates that an exit from one of the VLLSx modes has occurred. The debugger loses communication (including access to this register) while the system is in a VLLSx mode. When communication is re-established, this bit indicates that the system had been in a VLLSx mode. The debug modules lose their state during VLLSx modes, so they must be reconfigured after an exit from a VLLSx mode. The VLLSx Mode Exit bit is held until the debugger recognizes that a VLLSx mode was exited. The bit is cleared by a write of 1 to the DBGCR[1] bit (LLS, VLLSx Status Acknowledge bit). |

## 50.3.6 BDM Address Attribute Register (BAAR)

BAAR defines the address space for memory-referencing BDM commands. BAAR[R, SZ] are loaded directly from the BDM command, while the lower five bits can be programmed from the external development system. BAAR is loaded any time AATR is written and is initialized to a value of 0x05, setting supervisor data as the default address space. The upper 24 bits of this register are reserved for future use and any attempted write of these bits is ignored.

Table 50-18. BDM Address Attribute Register (BAAR)



Table 50-19. BAAR Field Descriptions

| Field | Description                                                   |
|-------|---------------------------------------------------------------|
| 31–8  | Reserved for future use by the debug module; must be cleared. |

Table 50-19. BAAR Field Descriptions (continued)

| Field | Descript    | Description                                    |  |  |  |  |  |  |
|-------|-------------|------------------------------------------------|--|--|--|--|--|--|
| 7     | Read/Wri    | Read/Write                                     |  |  |  |  |  |  |
| R     | 0           | Write.                                         |  |  |  |  |  |  |
|       | 1           | Read.                                          |  |  |  |  |  |  |
| 6–5   | Size        | Size                                           |  |  |  |  |  |  |
| SZ    | 00 Longword |                                                |  |  |  |  |  |  |
|       | 01 Byte     |                                                |  |  |  |  |  |  |
|       | 10          | 10 Word                                        |  |  |  |  |  |  |
|       | 11          | Reserved                                       |  |  |  |  |  |  |
| 4–3   | Transfer t  | Transfer type                                  |  |  |  |  |  |  |
| TT    | See the T   | See the TT definition in the AATR description. |  |  |  |  |  |  |
| 2–0   | Transfer i  | Transfer modifier                              |  |  |  |  |  |  |
| ТМ    | See the T   | M definition in the AATR description.          |  |  |  |  |  |  |

# 50.3.7 Address Attribute Trigger Register (AATR)

AATR defines address attributes and a mask to be matched in the trigger. The register value is compared with address attribute signals from the processor's high-speed local bus, as defined by the setting of the trigger definition register (TDR). AATR is accessible in supervisor mode as debug control register 0x06 using the WDEBUG instruction and through the BDM port using the WRITE\_DREG command.

Table 50-20. Address Attribute Trigger Register (AATR)

| DRc: 0x06 ( | AATR) |     |    |     |    |     |    |    |    |    |    | A  | ccess: | Superv | isor wri | te-only |
|-------------|-------|-----|----|-----|----|-----|----|----|----|----|----|----|--------|--------|----------|---------|
|             |       |     |    |     |    |     |    |    |    |    |    |    |        | В      | DM wri   | te-only |
|             | 31    | 30  | 29 | 28  | 27 | 26  | 25 | 24 | 23 | 22 | 21 | 20 | 19     | 18     | 17       | 16      |
| R           |       |     |    |     |    |     |    |    |    |    |    |    |        |        |          |         |
| W           | 0     | 0   | 0  | 0   | 0  | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0      | 0      | 0        | 0       |
| Reset       | 0     | 0   | 0  | 0   | 0  | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0      | 0      | 0        | 0       |
|             | 15    | 14  | 13 | 12  | 11 | 10  | 9  | 8  | 7  | 6  | 5  | 4  | 3      | 2      | 1        | 0       |
| R           |       |     |    |     |    |     |    |    |    |    |    |    |        |        |          |         |
| w           | RM    | SZM |    | TTM |    | ТММ |    |    | R  | SZ |    | TT |        | ТМ     |          |         |
| Reset       | 0     | 0   | 0  | 0   | 0  | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0      | 1      | 0        | 1       |

## Table 50-21. AATR Field Descriptions

| Field | Description                                                                                                                                                                                                     |  |  |  |  |  |  |  |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| 31–16 | Reserved; must be cleared.                                                                                                                                                                                      |  |  |  |  |  |  |  |
| 15    | Read/write mask                                                                                                                                                                                                 |  |  |  |  |  |  |  |
| RM    | Masks the R bit in address comparisons.                                                                                                                                                                         |  |  |  |  |  |  |  |
| 14–13 | Size mask                                                                                                                                                                                                       |  |  |  |  |  |  |  |
| SZM   | Masks the corresponding SZ bit in address comparisons.                                                                                                                                                          |  |  |  |  |  |  |  |
| 12–11 | Transfer type mask                                                                                                                                                                                              |  |  |  |  |  |  |  |
| TTM   | Masks the corresponding TT bit in address comparisons.                                                                                                                                                          |  |  |  |  |  |  |  |
| 10–8  | Transfer modifier mask                                                                                                                                                                                          |  |  |  |  |  |  |  |
| TMM   | Masks the corresponding TM bit in address comparisons.                                                                                                                                                          |  |  |  |  |  |  |  |
| 7     | Read/Write                                                                                                                                                                                                      |  |  |  |  |  |  |  |
| R     | R is compared with the R/W signal of the processor's local bus.                                                                                                                                                 |  |  |  |  |  |  |  |
| 6–5   | Size                                                                                                                                                                                                            |  |  |  |  |  |  |  |
| SZ    | Compared to the processor's local bus size signals.                                                                                                                                                             |  |  |  |  |  |  |  |
|       | 00 Longword                                                                                                                                                                                                     |  |  |  |  |  |  |  |
|       | 01 Byte                                                                                                                                                                                                         |  |  |  |  |  |  |  |
|       | 10 Word                                                                                                                                                                                                         |  |  |  |  |  |  |  |
|       | 11 Reserved                                                                                                                                                                                                     |  |  |  |  |  |  |  |
| 4–3   | Transfer type                                                                                                                                                                                                   |  |  |  |  |  |  |  |
| ТТ    | Compared with the local bus transfer type signals. These bits also define the TT encoding for BDM memory commands.                                                                                              |  |  |  |  |  |  |  |
|       | 00 Normal processor access                                                                                                                                                                                      |  |  |  |  |  |  |  |
|       | Else Reserved                                                                                                                                                                                                   |  |  |  |  |  |  |  |
| 2–0   | Transfer modifier                                                                                                                                                                                               |  |  |  |  |  |  |  |
| ТМ    | Compared with the local bus transfer modifier signals, which give supplemental information for each transfer type. These bits also define the TM encoding for BDM memory commands (for backward compatibility). |  |  |  |  |  |  |  |
|       | 000 Reserved                                                                                                                                                                                                    |  |  |  |  |  |  |  |
|       | 001 User-mode data access                                                                                                                                                                                       |  |  |  |  |  |  |  |
|       | 010 User-mode code access                                                                                                                                                                                       |  |  |  |  |  |  |  |
|       | 011 Reserved                                                                                                                                                                                                    |  |  |  |  |  |  |  |
|       | 100 Reserved                                                                                                                                                                                                    |  |  |  |  |  |  |  |
|       | 101 Supervisor-mode data access                                                                                                                                                                                 |  |  |  |  |  |  |  |
|       | 110 Supervisor-mode code access                                                                                                                                                                                 |  |  |  |  |  |  |  |
|       | 111 Reserved                                                                                                                                                                                                    |  |  |  |  |  |  |  |

## 50.3.8 Trigger Definition Register (TDR)

TDR configures the operation of the hardware breakpoint logic that corresponds with the ABHR/ABLR/AATR, PBR/PBR1/PBR2/PBR3/PBMR, and DBR/DBMR registers within the debug module. TDR controls the actions taken under the defined conditions. Breakpoint logic may be configured as one- or two-level trigger. TDR[31–16] defines the second-level trigger, and TDR[15–0] defines the first-level trigger.

#### NOTE

The debug module has no hardware interlocks. To prevent spurious breakpoint triggers while the breakpoint registers are being loaded, disable TDR (write 0 to L2EBL and L1EBL) before defining triggers.

A write to TDR clears the CSR trigger status bits, CSR[BSTAT]. TDR is accessible in supervisor mode as debug control register 0x07 using the WDEBUG instruction and through the BDM port using the WRITE\_DREG command.

DRc: 0x07 (TDR) Access: Supervisor write-only BDM write-only Second Level Trigger 30 29 28 27 25 24 23 22 21 20 19 31 26 18 17 16 R W L2E L2E L2P **TRC** L2ED L2DI L2EA PC BL CI Reset 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 First Level Trigger 11 15 12 8 6 5 3 0 14 13 10 9 4 1 R W L2T L<sub>1</sub>T L1E L1ED L1DI L1EA L1E L<sub>1</sub>P BL PC CI 0 0 0 0 Reset 0 0 0 0 0 0

Table 50-22. Trigger Definition Register (TDR)

Table 50-23. TDR Field Descriptions

| Field | Description                                                                                                                                                                                |  |  |  |  |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 31–30 | Trigger Response Control                                                                                                                                                                   |  |  |  |  |
| TRC   | Determines how the processor responds to a completed trigger condition. The trigger response is displayed on PST.                                                                          |  |  |  |  |
|       | 00 Display on PST only                                                                                                                                                                     |  |  |  |  |
|       | 01 Processor halt                                                                                                                                                                          |  |  |  |  |
|       | 10 Debug interrupt                                                                                                                                                                         |  |  |  |  |
|       | 11 Reserved                                                                                                                                                                                |  |  |  |  |
| 29    | Enable Level 2 Breakpoints                                                                                                                                                                 |  |  |  |  |
| L2EBL | Global enable for the level 2 breakpoint triggers.                                                                                                                                         |  |  |  |  |
|       | 0 Disable all level 2 breakpoints                                                                                                                                                          |  |  |  |  |
|       | 1 Enable all level 2 breakpoints                                                                                                                                                           |  |  |  |  |
| 28–22 | Enable Level 2 Data Breakpoint                                                                                                                                                             |  |  |  |  |
| L2ED  | Setting an L2ED bit enables the corresponding data breakpoint condition based on the size and placement on the processor's local data bus. Clearing all ED bits disables data breakpoints. |  |  |  |  |
|       | Bit Description                                                                                                                                                                            |  |  |  |  |
|       | Data longword. Entire processor's local data bus                                                                                                                                           |  |  |  |  |
|       | 27 Lower data word                                                                                                                                                                         |  |  |  |  |
|       | 26 Upper data word                                                                                                                                                                         |  |  |  |  |
|       | 25 Lower lower data byte. Low-order byte of the low-order word                                                                                                                             |  |  |  |  |
|       | 24 Lower middle data byte. High-order byte of the low-order word                                                                                                                           |  |  |  |  |
|       | Upper middle data byte. Low-order byte of the high-order word                                                                                                                              |  |  |  |  |
|       | Upper upper data byte. High-order byte of the high-order word                                                                                                                              |  |  |  |  |
| 21    | Level 2 Data Breakpoint Invert                                                                                                                                                             |  |  |  |  |
| L2DI  | Inverts the logical sense of all the data breakpoint comparators. This can develop a trigger based on the occurrence of a data value other than the DBR contents.                          |  |  |  |  |
|       | 0 Do not invert                                                                                                                                                                            |  |  |  |  |
|       | 1 Invert                                                                                                                                                                                   |  |  |  |  |
| 20–18 | Enable Level 2 Address Breakpoint                                                                                                                                                          |  |  |  |  |
| L2EA  | Setting an L2EA bit enables the corresponding address breakpoint. Clearing all three bits disables the breakpoint.                                                                         |  |  |  |  |
|       | Bit Description                                                                                                                                                                            |  |  |  |  |
|       | 20 Address breakpoint inverted. Breakpoint is based outside the range between ABLR and ABHR.                                                                                               |  |  |  |  |
|       | Address breakpoint range. The breakpoint is based on the inclusive range defined by ABLR and ABHR.                                                                                         |  |  |  |  |
|       | 18 Address breakpoint low. The breakpoint is based on the address in the ABLR.                                                                                                             |  |  |  |  |

## Table 50-23. TDR Field Descriptions (continued)

| Field | Description                                                                                                                                                                                                                                                         |  |  |  |  |  |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 17    | Enable Level 2 PC Breakpoint                                                                                                                                                                                                                                        |  |  |  |  |  |
| L2EPC | 0 Disable                                                                                                                                                                                                                                                           |  |  |  |  |  |
|       | 1 Enable                                                                                                                                                                                                                                                            |  |  |  |  |  |
| 16    | Level 2 PC Breakpoint Invert                                                                                                                                                                                                                                        |  |  |  |  |  |
| L2PCI | 0 Do not invert                                                                                                                                                                                                                                                     |  |  |  |  |  |
|       | 1 Invert                                                                                                                                                                                                                                                            |  |  |  |  |  |
| 15    | Level 2 Trigger                                                                                                                                                                                                                                                     |  |  |  |  |  |
| L2T   | Determines the logic operation for the trigger between the PC_condition and the (Address_range and Data_condition) condition where the inclusion of a Data_condition is optional. The debug architecture supports the creation of single- or double-level triggers. |  |  |  |  |  |
|       | 0 Trigger = PC_condition && (Address_range && Data_condition)                                                                                                                                                                                                       |  |  |  |  |  |
|       | 1 Trigger = PC_condition    (Address_range && Data_condition)                                                                                                                                                                                                       |  |  |  |  |  |
| 14    | Level 1 Trigger                                                                                                                                                                                                                                                     |  |  |  |  |  |
| L1T   | Determines the logic operation for the trigger between the PC_condition and the (Address_range and Data_condition) condition where the inclusion of a Data_condition is optional. The debug architecture supports the creation of single- or double-level triggers. |  |  |  |  |  |
|       | 0 Trigger = PC_condition && (Address_range && Data_condition)                                                                                                                                                                                                       |  |  |  |  |  |
|       | 1 Trigger = PC_condition    (Address_range && Data_condition)                                                                                                                                                                                                       |  |  |  |  |  |
| 13    | Enable Level 1 Breakpoints                                                                                                                                                                                                                                          |  |  |  |  |  |
| L1EBL | Global enable for the level 1 breakpoint triggers.                                                                                                                                                                                                                  |  |  |  |  |  |
|       | 0 Disable all level 1 breakpoints                                                                                                                                                                                                                                   |  |  |  |  |  |
|       | 1 Enable all level 1 breakpoints                                                                                                                                                                                                                                    |  |  |  |  |  |
| 12–6  | Enable Level 1 Data Breakpoint                                                                                                                                                                                                                                      |  |  |  |  |  |
| L1ED  | Setting an L1ED bit enables the corresponding data breakpoint condition based on the size and placement on the processor's local data bus. Clearing all ED bits disables data breakpoints.                                                                          |  |  |  |  |  |
|       | Bit Description                                                                                                                                                                                                                                                     |  |  |  |  |  |
|       | 28 Data longword. Entire processor's local data bus                                                                                                                                                                                                                 |  |  |  |  |  |
|       | 27 Lower data word                                                                                                                                                                                                                                                  |  |  |  |  |  |
|       | 26 Upper data word                                                                                                                                                                                                                                                  |  |  |  |  |  |
|       | 25 Lower lower data byte. Low-order byte of the low-order word                                                                                                                                                                                                      |  |  |  |  |  |
|       | 24 Lower middle data byte. High-order byte of the low-order word                                                                                                                                                                                                    |  |  |  |  |  |
|       | 23 Upper middle data byte. Low-order byte of the high-order word                                                                                                                                                                                                    |  |  |  |  |  |
|       | 22 Upper upper data byte. High-order byte of the high-order word                                                                                                                                                                                                    |  |  |  |  |  |
| 5     | Level 1 Data Breakpoint Invert                                                                                                                                                                                                                                      |  |  |  |  |  |
| L1DI  | Inverts the logical sense of all the data breakpoint comparators. This can develop a trigger based on the occurrence of a data value other than the DBR contents.                                                                                                   |  |  |  |  |  |
|       | 0 Do not invert                                                                                                                                                                                                                                                     |  |  |  |  |  |
|       | 1 Invert                                                                                                                                                                                                                                                            |  |  |  |  |  |

Table continues on the next page...

## MCF51JF128 Reference Manual, Rev. 2, 03/2011

Table 50-23. TDR Field Descriptions (continued)

| Field | Description                                                                                                        |  |  |  |  |
|-------|--------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 4–2   | Enable Level 1 Address Breakpoint                                                                                  |  |  |  |  |
| L1EA  | Setting an L1EA bit enables the corresponding address breakpoint. Clearing all three bits disables the breakpoint. |  |  |  |  |
|       | Bit Description                                                                                                    |  |  |  |  |
|       | Address breakpoint inverted. Breakpoint is based outside the range between ABLR and ABHR.                          |  |  |  |  |
|       | Address breakpoint range. The breakpoint is based on the inclusive range defined by ABLR and ABHR.                 |  |  |  |  |
|       | Address breakpoint low. The breakpoint is based on the address in the ABLR.                                        |  |  |  |  |
| 1     | Enable Level 1 PC Breakpoint                                                                                       |  |  |  |  |
| L1EPC | 0 Disable                                                                                                          |  |  |  |  |
|       | 1 Enable                                                                                                           |  |  |  |  |
| 0     | Level 1 PC Breakpoint Invert                                                                                       |  |  |  |  |
| L1PCI | 0 Do not invert                                                                                                    |  |  |  |  |
|       | 1 Invert                                                                                                           |  |  |  |  |

# 50.3.9 Program Counter Breakpoint/Mask Registers (PBR0–3, PBMR)

The PBRn registers define instruction addresses for use as part of the trigger. These registers' contents are compared with the processor's program counter register when the appropriate valid bit is set (for PBR1–3) and TDR is configured appropriately. PBR0 bits are masked by setting corresponding PBMR bits (PBMR has no effect on PBR1–3). Results are compared with the processor's program counter register, as defined in TDR. The PC breakpoint registers, PBR1–3, have no masking associated with them, but do include a valid bit. These registers' contents are compared with the processor's program counter register when TDR is configured appropriately.

The PC breakpoint registers are accessible in supervisor mode using the WDEBUG instruction and through the BDM port using the WRITE\_DREG command using values shown in BDM Command Set Descriptions.

#### NOTE

Version 1 ColdFire core devices implement a 24-bit, 16 MB address map. When programming these registers with a 32-bit address, the upper byte should be zero-filled when referencing

the flash, RAM, and RGPIO regions, and set to 0xFF when referencing any of the slave peripheral devices.

Table 50-24. Program Counter Breakpoint Register 0 (PBR0)



## Table 50-25. PBR0 Field Descriptions

| Field   | Description                                                                                                                                                         |
|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–0    | PC breakpoint address                                                                                                                                               |
| Address | The address to be compared with the PC as a breakpoint trigger. Because all instruction sizes are multiples of 2 bytes, bit 0 of the address should always be zero. |

## Table 50-26. Program Counter Breakpoint Register n (PBRn, n = 1, 2, 3)



Table 50-27. PBRn Field Descriptions

| Field   | Description                                                            |  |  |  |
|---------|------------------------------------------------------------------------|--|--|--|
| 31–1    | PC breakpoint address                                                  |  |  |  |
| Address | The 31-bit address to be compared with the PC as a breakpoint trigger. |  |  |  |

Table continues on the next page...

#### MCF51JF128 Reference Manual, Rev. 2, 03/2011

Table 50-27. PBRn Field Descriptions (continued)

| Field | Description                                                                                        |
|-------|----------------------------------------------------------------------------------------------------|
| 0     | Valid bit                                                                                          |
| V     | This bit must be set for the PC breakpoint to occur at the address specified in the Address field. |
|       | 0 PBR is disabled.                                                                                 |
|       | 1 PBR is enabled.                                                                                  |

This figure shows PBMR. PBMR is accessible in supervisor mode using the WDEBUG instruction and via the BDM port using the WRITE\_DREG command. PBMR only masks PBR0.

Table 50-28. Program Counter Breakpoint Mask Register (PBMR)



Table 50-29. PBMR Field Descriptions

| Field | Description                                                                      |  |  |  |
|-------|----------------------------------------------------------------------------------|--|--|--|
| 31–1  | breakpoint mask                                                                  |  |  |  |
| Mask  | using PBR0, this register must be initialized since it is undefined after reset. |  |  |  |
|       | 0 The corresponding PBR0 bit is compared to the appropriate PC bit.              |  |  |  |
|       | 1 The corresponding PBR0 bit is ignored.                                         |  |  |  |

# 50.3.10 Address Breakpoint Registers (ABLR, ABHR)

The ABLR and ABHR define regions in the processor's data address space that can be used as part of the trigger. These register values are compared with the address for each transfer on the processor's high-speed local bus. The trigger definition register (TDR) identifies the trigger as one of three cases:

• Identical to the value in ABLR

- Inside the range bound by ABLR and ABHR inclusive
- Outside that same range

The address breakpoint registers are accessible in supervisor mode using the WDEBUG instruction and through the BDM port using the WRITE\_DREG command using values shown in BDM Command Set Descriptions.

#### NOTE

Version 1 ColdFire core devices implement a 24-bit, 16 MB address map. When programming these registers with a 32-bit address, the upper byte should be zero-filled when referencing the flash, RAM, and RGPIO regions, and set to 0xFF when referencing any of the slave peripheral devices.

Table 50-30. Address Breakpoint Registers (ABLR, ABHR)

| DRc:          | 0x0C (ABHR) Access: Supervisor write-only |         |    |    |    |    |    |     |      |    |    |    |    |    |    |    |
|---------------|-------------------------------------------|---------|----|----|----|----|----|-----|------|----|----|----|----|----|----|----|
|               | 0x0D (ABLR) BDM write-only                |         |    |    |    |    |    |     |      |    |    |    |    |    |    |    |
|               | 31                                        | 30      | 29 | 28 | 27 | 26 | 25 | 24  | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| R             |                                           |         |    |    |    |    |    |     |      |    |    |    |    |    |    |    |
| W             |                                           |         |    |    |    |    |    | Add | ress | •  |    |    |    |    |    |    |
| ABHR<br>Reset | _                                         | -       | _  | _  | _  | _  | _  | _   | _    | _  | _  | _  | _  | _  | _  | -  |
| ABLR<br>Reset | 0                                         | 0       | 0  | 0  | О  | 0  | 0  | 0   | 0    | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
|               | 15                                        | 14      | 13 | 12 | 11 | 10 | 9  | 8   | 7    | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| R             |                                           |         |    |    |    |    |    |     |      |    |    |    |    |    |    |    |
| w             |                                           | Address |    |    |    |    |    |     |      |    |    |    |    |    |    |    |
| ABHR<br>Reset | _                                         | -       | _  | _  | _  | _  | _  | _   | _    | _  | _  | _  | _  | _  | _  | _  |
| ABLR<br>Reset | 0                                         | 0       | 0  | 0  | 0  | 0  | 0  | 0   | 0    | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

### Table 50-31. ABLR Field Descriptions

| Field   | Description                                                                                                                                    |
|---------|------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–0    | Low address                                                                                                                                    |
| Address | Holds the 32-bit address marking the lower bound of the address breakpoint range. Breakpoints for specific addresses are programmed into ABLR. |

#### Table 50-32. ABHR Field Descriptions

| Field   | Description                                                                       |
|---------|-----------------------------------------------------------------------------------|
| 31–0    | High address                                                                      |
| Address | Holds the 32-bit address marking the upper bound of the address breakpoint range. |

#### MCF51JF128 Reference Manual, Rev. 2, 03/2011

# 50.3.11 Data Breakpoint and Mask Registers (DBR, DBMR)

DBR specifies data patterns used as part of the trigger into debug mode. DBR bits are masked by setting corresponding DBMR bits, as defined in TDR.

DBR and DBMR are accessible in supervisor mode using the WDEBUG instruction and through the BDM port using the WRITE\_DREG commands.

DRc: 0x0E (DBR) Access: Supervisor write-only 0x0F (DBMR) BDM write-only R W Data (DBR); Mask (DBMR) Reset R W Data (DBR); Mask (DBMR) Reset 

Table 50-33. Data Breakpoint and Mask Registers (DBR, DBMR)

## Table 50-34. DBR Field Descriptions

| Field | Description                                                                                                   |
|-------|---------------------------------------------------------------------------------------------------------------|
| 31–0  | Data breakpoint value.                                                                                        |
| Data  | Contains the value to be compared with the data value from the processor's local bus as a breakpoint trigger. |

#### Table 50-35. DBMR Field Descriptions

| Field | Description                                                                                     |  |  |  |  |
|-------|-------------------------------------------------------------------------------------------------|--|--|--|--|
| 31–0  | ata breakpoint mask                                                                             |  |  |  |  |
| Mask  | The 32-bit mask for the data breakpoint trigger.                                                |  |  |  |  |
|       | The corresponding DBR bit is compared to the appropriate bit of the processor's local data bus. |  |  |  |  |
|       | 1 The corresponding DBR bit is ignored                                                          |  |  |  |  |

The DBR supports aligned and misaligned references. This table shows the relationships between processor address, access size, and location within the 32-bit data bus.

Table 50-36. Access Size and Operand Data Location

| Address[1-0] | Access Size | Operand Location |  |  |
|--------------|-------------|------------------|--|--|
| 00           | Byte        | D[31–24]         |  |  |
| 01           | Byte        | D[23–16]         |  |  |
| 10           | Byte        | D[15–8]          |  |  |
| 11           | Byte        | D[7-0]           |  |  |
| 0x           | Word        | D[31–16]         |  |  |
| 1x           | Word        | D[15–0]          |  |  |
| XX           | Longword    | D[31-0]          |  |  |

# 50.3.12 Resulting Set of Possible Trigger Combinations

The resulting set of possible breakpoint trigger combinations consists of the following options where || denotes logical OR, && denotes logical AND, and {} denotes an optional additional trigger term:

One-level triggers of the form:

## Two-level triggers of the form:

In these examples, PC\_breakpoint is the logical summation of the PBR0/PBMR, PBR1, PBR2, and PBR3 breakpoint registers; Address\_breakpoint is a function of ABHR, ABLR, and AATR; Data\_breakpoint is a function of DBR and DBMR. In all cases, the data breakpoints can be included with an address breakpoint to further qualify a trigger event as an option.

The breakpoint registers can also be used to define the start and stop recording conditions for the PST trace buffer.

## 50.3.13 PST Buffer (PSTB)

The PST trace buffer contains 64 six-bit entries, packed consecutively into 12 longword locations. See the following figure for an illustration of how the buffer entries are packed.

The write pointer for the trace buffer is available as CSR2[PSTBWA]. Using this pointer, it is possible to determine the oldest-to-newest entries in the trace buffer.

Core register number (CRN) 22 21 | 19| 18| 17| 16| 15| 14| 13| 12| 11| 10| 9| 8| 7| 6| 5| 4| 3| 2| 1| 31 30 29 28 27 26 25 24 23 20 0 05[5 Х TB #00 TB #01 TB #02 TB #03 TB #04 1 :4] 0 0 TB Χ TB #05[3:0] TB #06 TB #07 TB #08 TB #09 1 #10[5:2] 1 0 Х 10[1:0] TB #14 TB #15 TB #11 TB #12 TB #13 2 0 Х 21[5 TB #16 TB #17 TB #18 TB #19 TB #20 1 :4] 3 0 Χ TB TB #21[3:0] TB #22 TB #23 TB #24 TB #25 1 #26[5:2] 4 0 Χ 26[1:0] TB #27 TB #28 TB #29 TB #30 TB #31 1 5 0 Х 37[5 TB #32 TB #33 TB #36 TB #34 TB #35 1 :4] 6

Table 50-37. PST Trace Buffer Entries and Locations

Table 50-37. PST Trace Buffer Entries and Locations (continued)

| Core register number (CRN) | 31   | 30   | 29    | 28  | 27 | 26  | 25 | 24  | 23     | 22     | 21 | 20  | 19     | 18     | 17     | 16  | 15   | 14     | 13     | 12  | 11          | 10 | 9      | 8 | 7         | 6 | 5 | 4 | 3 2 | 1         | 0   |
|----------------------------|------|------|-------|-----|----|-----|----|-----|--------|--------|----|-----|--------|--------|--------|-----|------|--------|--------|-----|-------------|----|--------|---|-----------|---|---|---|-----|-----------|-----|
| 0<br>x<br>1<br>7           | TI   | B #3 | 7[3:0 | )]  |    |     | ТВ | #38 |        |        |    |     | ТВ     | #39    |        |     |      | Т      | В #4   | 0   |             |    | Т      | В | #4        | 1 |   |   |     | TB<br>2[5 | :2] |
| 0<br>x<br>1<br>8           | 42[1 | 1:0] |       |     | ТВ | #43 |    |     |        |        | ТВ | #44 |        |        | TB #45 |     |      |        | TB #46 |     |             |    | TB #47 |   |           |   |   |   |     |           |     |
| 0<br>x<br>1<br>9           |      |      | TB i  | #48 |    |     |    | '   | ТВ     | TB #49 |    |     |        | TB #50 |        |     | Т    | TB #51 |        |     |             |    |        |   | 3[5<br>4] |   |   |   |     |           |     |
| 0<br>x<br>1<br>A           | TI   | B #5 | 3[3:0 | )]  |    |     | ТВ | #54 | TB #55 |        |    | #55 | TB #56 |        |        | #56 | TB # |        |        | #57 | TB #58[5:2] |    | :2]    |   |           |   |   |   |     |           |     |
| 0<br>x<br>1<br>B           | 58[1 | 1:0] |       |     | ТВ | #59 |    |     |        |        | ТВ | #60 |        |        |        |     | ТВ   | #61    |        |     |             | ТВ | #6     | 2 |           |   |   | Т | В#  | 63        |     |

## 50.4 Functional Description

The following sections describe functional details of the debug module.

# 50.4.1 Background Debug Mode (BDM)

This section provides details on the background debug serial interface controller (BDC) and the BDM command set.

The BDC provides a single-wire debug interface to the target MCU. As shown in the Version 1 ColdFire core block diagram of Figure 50-1, the BDC module interfaces between the single-pin (BKGD) interface and the remaining debug modules, including

MCF51JF128 Reference Manual, Rev. 2, 03/2011

the ColdFire background debug logic, the real-time debug hardware, and the PST/DDATA trace logic. This interface provides a convenient means for programming the on-chip flash and othernon-volatile memories. The BDC is the primary debug interface for development and allows non-intrusive access to memory data and traditional debug features such as run/halt control, read/write of core registers, breakpoints, and single instruction step.

Features of the background debug controller (BDC) include:

- Single dedicated pin for mode selection and background communications
- Special BDC registers not located in system memory map
- SYNC command to determine target communications rate
- Non-intrusive commands for memory access
- Active background (halt) mode commands for core register access
- GO command to resume execution
- BACKGROUND command to halt core or wake CPU from low-power modes
- Oscillator runs in stop mode, if BDM enabled

Based on these features, BDM is useful for the following reasons:

- In-circuit emulation is not needed, so physical and electrical characteristics of the system are not affected.
- BDM is always available for debugging the system and provides a communication link for upgrading firmware in existing systems.
- Provides high-speed memory downloading, especially useful for flash programming
- Provides absolute control of the processor, and thus the system. This feature allows
  quick hardware debugging with the same tool set used for firmware development.

## 50.4.1.1 CPU Halt

Although certain BDM operations can occur in parallel with CPU operations, unrestricted BDM operation requires the CPU to be halted. The sources that can cause the CPU to halt are listed below in order of priority. Recall that the default configuration of the Version 1 ColdFire core (CF1Core) defines the occurrence of certain exception types to

#### **Functional Description**

automatically generate a system reset. Some of these fault types include illegal instructions, privilege errors, address errors, and bus error terminations, with the response under control of the processor's CPUCR[ARD, IRD] bits.

Table 50-38. CPU Halt Sources

| Halt Source                       | Halt Timing | ng Description                                                                                                                                                                                                       |                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                 |  |  |  |  |
|-----------------------------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
|                                   |             | Refers to the occurrence of any fault while exception processing. For example, a bus error is signaled during exception stack frame writes or while fetching the first instruction in the exception service routine. |                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                 |  |  |  |  |
| Fault-on-fault                    | Immediate   | CPUCR[ARD] = 1                                                                                                                                                                                                       | . Initieulaleiv enleis hail.                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                 |  |  |  |  |
|                                   |             | CPUCR[ARD] = 0                                                                                                                                                                                                       |                                                                                                                                                                                                  | Reset event is initiated.                                                                                                                                                                                                                                                                                       |  |  |  |  |
| Hardware<br>breakpoint<br>trigger | Pending     |                                                                                                                                                                                                                      | pending in the processor. The processor samples for pending halt and ditions once per instruction. When a pending condition is asserted, the processor halts execution at the next sample point. |                                                                                                                                                                                                                                                                                                                 |  |  |  |  |
|                                   |             | BDM disabled                                                                                                                                                                                                         | CPUCR[IRD] = 0                                                                                                                                                                                   | A reset is initiated since attempted execution of an illegal instruction                                                                                                                                                                                                                                        |  |  |  |  |
|                                   |             |                                                                                                                                                                                                                      | CPUCR[IRD] = 1                                                                                                                                                                                   | An illegal instruction exception is generated.                                                                                                                                                                                                                                                                  |  |  |  |  |
|                                   | Immediate   | BDM enabled, supervisor mode                                                                                                                                                                                         | Processor immediately halts execution at the next instruction point. The processor can be restarted by a BDM GO come Execution continues at the instruction after HALT.                          |                                                                                                                                                                                                                                                                                                                 |  |  |  |  |
| HALT instruction                  |             | BDM enabled,<br>user mode                                                                                                                                                                                            | CSR[UHE] = 0<br>CPUCR[IRD] = 0                                                                                                                                                                   | A reset event is initiated, because a privileged instruction was attempted in user mode.                                                                                                                                                                                                                        |  |  |  |  |
|                                   |             |                                                                                                                                                                                                                      | CSR[UHE] = 0<br>CPUCR[IRD] = 1                                                                                                                                                                   | A privilege violation exception is generated.                                                                                                                                                                                                                                                                   |  |  |  |  |
|                                   |             | user mode                                                                                                                                                                                                            | CSR[UHE] = 1                                                                                                                                                                                     | Processor immediately halts execution at the next instruction sample point. The processor can be restarted by a BDM GO command. Execution continues at the instruction after HALT.                                                                                                                              |  |  |  |  |
|                                   |             | BDM disabled or flash secure                                                                                                                                                                                         | Illegal command response and BACKGROUND command is ignored.                                                                                                                                      |                                                                                                                                                                                                                                                                                                                 |  |  |  |  |
| BACKGROUND                        | Pending     | BDM enabled                                                                                                                                                                                                          | Processor is running                                                                                                                                                                             | Halt is made pending in the processor. The processor samples for pending halt and interrupt conditions once per instruction. When a pending condition is asserted, the processor halts execution at the next sample point.                                                                                      |  |  |  |  |
| command                           | Ü           | and flash unsecure                                                                                                                                                                                                   | Processor is stopped                                                                                                                                                                             | Processing of the BACKGROUND command is treated in a special manner. The processor exits the stopped mode and enters the halted state, at which point all BDM commands may be exercised. When restarted, the processor continues by executing the next sequential instruction (the instruction following STOP). |  |  |  |  |

#### Table 50-38. CPU Halt Sources (continued)

| Halt Source                                                         | Halt Timing |                | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |
|---------------------------------------------------------------------|-------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| PSTB full condition                                                 | Pending     | PSTB           | PSTB obtrusive recording mode pends halt in the processor if the trace buffer reaches its full threshold (full is defined as before the buffer is overwritten). When a pending condition is asserted, the processor halts at the next sample point.                                                                                                                                                                                                                                            |  |  |  |  |
|                                                                     |             |                | Enters debug mode with XCSR[ENBDM, CLKSW] set. The full set of BDM commands is available and debug can proceed.                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |
| BKGD held low                                                       | Immediate   | Flash unsecure | If the core is reset into a debug halt condition, the processor's response to the GO command depends on the BDM command(s) performed while it was halted. Specifically, if the PC register was loaded, the GO command causes the processor to exit halted state and pass control to the instruction address in the PC, bypassing normal reset exception processing. If the PC was not loaded, the GO command causes the processor to exit halted state and continue reset exception processing |  |  |  |  |
| for ≥2 bus clocks<br>after reset<br>negated for POR<br>or BDM reset |             |                | Enters debug mode with XCSR[ENBDM, CLKSW] set. The allowable commands are limited to the always-available group. A GO command to start the processor is not allowed. The only recovery actions in this mode are:                                                                                                                                                                                                                                                                               |  |  |  |  |
|                                                                     |             | Flash secure   | Issue a BDM reset setting CSR2[BDFR] with CSR2[BDHBR]     cleared and the BKGD pin held high to reset into normal     operating mode                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |
|                                                                     |             |                | Erase the flash to unsecure the memory and then proceed with debug                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |
|                                                                     |             |                | Power cycle the device with the BKGD pin held high to reset into<br>the normal operating mode                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |

The processor's run/stop/halt status is always accessible in XCSR[CPUHALT,CPUSTOP]. Additionally, CSR[27–24] indicate the halt source, showing the highest priority source for multiple halt conditions. This field is cleared by a read of the CSR. A processor halt due to the PSTB full condition as indicated by CSR2[PSTH] is also reflected in CSR[BKPT]. The debug GO command clears CSR[26–24] and CSR2[PSTBH].

## 50.4.1.2 Background Debug Serial Interface Controller (BDC)

BDC serial communications use a custom serial protocol first introduced on the M68HC12 Family of microcontrollers and later used in the M68HCS08 family. This protocol assumes that the host knows the communication clock rate determined by the target BDC clock rate. The BDC clock rate may be the system bus clock frequency or an alternate frequency source depending on the state of XCSR[CLKSW]. All communication is initiated and controlled by the host which drives a high-to-low edge to signal the beginning of each bit time. Commands and data are sent most significant bit (msb) first. For a detailed description of the communications protocol, refer to BDM Communication Details.

#### **Functional Description**

If a host is attempting to communicate with a target MCU that has an unknown BDC clock rate, a SYNC command may be sent to the target MCU to request a timed synchronization response signal from which the host can determine the correct communication speed. After establishing communications, the host can read XCSR and write the clock switch (CLKSW) control bit to change the source of the BDC clock for further serial communications if necessary.

BKGD is a pseudo-open-drain pin and there is an on-chip pullup so no external pullup resistor is required. Unlike typical open-drain pins, the external RC time constant on this pin, which is influenced by external capacitance, plays almost no role in signal rise time. The custom protocol provides for brief, actively driven speed-up pulses to force rapid rise times on this pin without risking harmful drive level conflicts. Refer to BDM Communication Details, for more details.

When no debugger pod is connected to the standard 6-pin BDM interface connector (Freescale-Recommended BDM Pinout), the internal pullup on BKGD chooses normal operating mode. When a development system is connected, it can pull BKGD and RESET low, release RESET to select active background (halt) mode rather than normal operating mode, and then release BKGD. It is not necessary to reset the target MCU to communicate with it through the background debug interface. There is also a mechanism to generate a reset event in response to setting CSR2[BDFR].

### 50.4.1.3 BDM Communication Details

The BDC serial interface requires the external host controller to generate a falling edge on the BKGD pin to indicate the start of each bit time. The external controller provides this falling edge whether data is transmitted or received.

BKGD is a pseudo-open-drain pin that can be driven by an external controller or by the MCU. Data is transferred msb first at 16 BDC clock cycles per bit (nominal speed). The interface times-out if 512 BDC clock cycles occur between falling edges from the host. If a time-out occurs, the status of any command in progress must be determined before new commands can be sent from the host. To check the status of the command, follow the steps detailed in the bit description of XCSR[CSTAT].

The custom serial protocol requires the debug pod to know the target BDC communication clock speed. The clock switch (CLKSW) control bit in the XCSR[31–24] register allows you to select the BDC clock source. The BDC clock source can be the bus clock or the alternate BDC clock source. When the MCU is reset in normal user mode, CLKSW is cleared and that selects the alternate clock source. This clock source is a fixed frequency independent of the bus frequency so it does change if the user modifies clock generator settings. This is the preferred clock source for general debugging.

When the MCU is reset in active background (halt) mode, CLKSW is set which selects the bus clock as the source of the BDC clock. This CLKSW setting is most commonly used during flash memory programming because the bus clock can usually be configured to operate at the highest allowed bus frequency to ensure the fastest possible flash programming times. Because the host system is in control of changes to clock generator settings, it knows when a different BDC communication speed should be used. The host programmer also knows that no unexpected change in bus frequency could occur to disrupt BDC communications.

Normally, setting CLKSW should not be used for general debugging because there is no way to ensure the application program does not change the clock generator settings. This is especially true in the case of application programs that are not yet fully debugged.

After any reset (or at any other time), the host system can issue a SYNC command to determine the speed of the BDC clock. CLKSW may be written using the serial WRITE\_XCSR\_BYTE command through the BDC interface. CLKSW is located in the special XCSR byte register in the BDC module and it is not accessible in the normal memory map of the ColdFire core. This means that no program running on the processor can modify this register (intentionally or unintentionally).

The BKGD pin can receive a high- or low-level or transmit a high- or low-level. The following diagrams show timing for each of these cases. Interface timing is synchronous to clocks in the target BDC, but asynchronous to the external host. The internal BDC clock signal is shown for reference in counting cycles.

The following figure shows an external host transmitting a logic 1 or 0 to the BKGD pin of a target MCU. The host is asynchronous to the target so there is a 0–1 cycle delay from the host-generated falling edge to where the target perceives the beginning of the bit time. Ten target BDC clock cycles later, the target senses the bit level on the BKGD pin. Typically, the host actively drives the pseudo-open-drain BKGD pin during host-to-target transmissions to speed up rising edges. Because the target does not drive the BKGD pin during the host-to-target transmission period, there is no need to treat the line as an open-drain signal during this period.





Figure 50-3. BDC Host-to-Target Serial Bit Timing

The following figure shows the host receiving a logic 1 from the target MCU. Because the host is asynchronous to the target MCU, there is a 0–1 cycle delay from the host-generated falling edge on BKGD to the perceived start of the bit time in the target MCU. The host holds the BKGD pin low long enough for the target to recognize it (at least two target BDC cycles). The host must release the low drive before the target MCU drives a brief active-high speedup pulse seven cycles after the perceived start of the bit time. The host should sample the bit level about 10 cycles after it started the bit time.



Figure 50-4. BDC Target-to-Host Serial Bit Timing (Logic 1)

The following figure shows the host receiving a logic 0 from the target MCU. Because the host is asynchronous to the target MCU, there is a 0–1 cycle delay from the host-generated falling edge on BKGD to the start of the bit time as perceived by the target

MCU. The host initiates the bit time, but the target MCU finishes it. Because the target wants the host to receive a logic 0, it drives the BKGD pin low for 13 BDC clock cycles, then briefly drives it high to speed up the rising edge. The host samples the bit level about 10 cycles after starting the bit time.



Figure 50-5. BDM Target-to-Host Serial Bit Timing (Logic 0)

## 50.4.1.4 BDM Command Set Descriptions

This section presents detailed descriptions of the BDM commands.

The V1 BDM command set is based on transmission of one or more 8-bit data packets per operation. Each operation begins with a host-to-target transmission of an 8-bit command code packet. The command code definition broadly maps the operations into four formats as shown in the following figure.

#### **Functional Description**



Figure 50-6. BDM Command Encodings

Table 50-39. BDM Command Field Descriptions

| Field | Description                                                                               |
|-------|-------------------------------------------------------------------------------------------|
| 5     | Read/Write.                                                                               |
| R/W   | 0 Command is performing a write operation.                                                |
|       | 1 Command is performing a read operation.                                                 |
| 3–0   | Miscellaneous command. Defines the miscellaneous command to be performed.                 |
| MSCMD | 0000 No operation                                                                         |
|       | 0001 Display the CPU's program counter (PC) plus optional capture in the PST trace buffer |
|       | 0010 Enable the BDM acknowledge communication mode                                        |
|       | 0011 Disable the BDM acknowledge communication mode                                       |
|       | 0100 Force a CPU halt (background)                                                        |
|       | 1000 Resume CPU execution (go)                                                            |
|       | 1101 Read/write of the debug XCSR most significant byte                                   |
|       | 1110 Read/write of the debug CSR2 most significant byte                                   |
|       | 1111 Read/write of the debug CSR3 most significant byte                                   |

Table 50-39. BDM Command Field Descriptions (continued)

| Field | Description                                                    |                                                        |                            |                            |                  |  |  |  |  |
|-------|----------------------------------------------------------------|--------------------------------------------------------|----------------------------|----------------------------|------------------|--|--|--|--|
| 3–2   | Memory operand size. Defines the size of the memory reference. |                                                        |                            |                            |                  |  |  |  |  |
| SZ    | 00 8-bit byte                                                  |                                                        |                            |                            |                  |  |  |  |  |
|       | 01 16-bit word                                                 |                                                        |                            |                            |                  |  |  |  |  |
|       | 10 32-bit long                                                 |                                                        |                            |                            |                  |  |  |  |  |
| 1–0   | Memory command                                                 | d. Defines the type of the                             | memory reference to be p   | performed.                 |                  |  |  |  |  |
| MCMD  | 00 Simple write if                                             | $R/\overline{W} = 0$ ; simple read if $R/\overline{W}$ | $\sqrt{W} = 1$             |                            |                  |  |  |  |  |
|       | 01 Write + status i                                            | if $R/\overline{W} = 0$ ; read + status if             | $f R/\overline{W} = 1$     |                            |                  |  |  |  |  |
|       | 10 Fill if $R/\overline{W} = 0$ ;                              | dump if $R/\overline{W} = 1$                           |                            |                            |                  |  |  |  |  |
|       | 11 Fill + status if F                                          | $R/\overline{W} = 0$ ; dump + status if                | $R/\overline{W} = 1$       |                            |                  |  |  |  |  |
| 7–6   | Core register grou                                             | p. Defines the core regist                             | er group to be referenced  | l.                         |                  |  |  |  |  |
| CRG   | 01 CPU's general-                                              | -purpose registers (An, Dr                             | n) or PST trace buffer     |                            |                  |  |  |  |  |
|       | 10 Debug's control registers                                   |                                                        |                            |                            |                  |  |  |  |  |
|       | 11 CPU's control registers (PC, SR, VBR, CPUCR,)               |                                                        |                            |                            |                  |  |  |  |  |
| 4–0   | _                                                              | ber. Defines the specific of                           | core register (its number) | to be referenced. All othe | r CRN values are |  |  |  |  |
| CRN   | reserved.                                                      |                                                        |                            |                            | _                |  |  |  |  |
|       |                                                                | CRG                                                    | CRN                        | Register                   |                  |  |  |  |  |
|       |                                                                |                                                        | 0x00-0x07                  | D0-7                       |                  |  |  |  |  |
|       |                                                                | 01                                                     | 0x08-0x0F                  | A0–7                       |                  |  |  |  |  |
|       |                                                                |                                                        | 0x10-0x1B                  | PST Buffer 0-11            |                  |  |  |  |  |
|       |                                                                | 10                                                     | DRc[4:0] as de             | scribed in CSR             |                  |  |  |  |  |
|       |                                                                |                                                        | 0x00                       | OTHER_A7                   |                  |  |  |  |  |
|       |                                                                |                                                        | 0x01                       | VBR                        |                  |  |  |  |  |
|       | 0x02 CPUCR                                                     |                                                        |                            |                            |                  |  |  |  |  |
|       |                                                                | 44                                                     | 0x04                       | MACSR                      |                  |  |  |  |  |
|       |                                                                | 11                                                     | 0x05                       | MASK                       |                  |  |  |  |  |
|       |                                                                |                                                        | 0x06                       | ACC                        |                  |  |  |  |  |
|       |                                                                |                                                        | 0x0E                       | SR                         |                  |  |  |  |  |
|       |                                                                |                                                        | 0x0F                       | PC                         |                  |  |  |  |  |

# 50.4.1.5 BDM Command Set Summary

The following table summarizes the BDM command set. Subsequent paragraphs contain detailed descriptions of each command. The nomenclature below is used in the following table to describe the structure of the BDM commands. Commands begin with an 8-bit hexadecimal command code in the host-to-target direction (most significant bit first)

#### **Functional Description**

```
separates parts of the command
       d
                         delay 32 target BDC clock cycles
                         24-bit memory address in the host-to-target direction
       ad24
       rd8
                         8 bits of read data in the target-to-host direction
       rd16
                        16 bits of read data in the target-to-host direction
       rd32
                        32 bits of read data in the target-to-host direction
                         read data, size defined by sz, in the target-to-host direction
       rd.sz
       wd8
                         8 bits of write data in the host-to-target direction
                        16 bits of write data in the host-to-target direction
       wd16
       wd32
                        32 bits of write data in the host-to-target direction
       wd.sz
                         write data, size defined by sz, in the host-to-target direction
       SS
                         the contents of XCSR[31:24] in the target-to-host direction
(STATUS)
                         memory operand size (0b00 = byte, 0b01 = word, 0b10 = long)
       SZ
       crn
                         core register number
       WS
                         command suffix signaling the operation is with status
```

#### **Table 50-40. BDM Command Summary**

| Command        | Command          | ACK       | Command                  | B                                                                                                                                                                                                                                                                                                           |  |  |  |
|----------------|------------------|-----------|--------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Mnemonic       | Classification   | if Enb? 1 | Structure                | Description                                                                                                                                                                                                                                                                                                 |  |  |  |
| SYNC           | Always Available | N/A       | N/A <sup>2</sup>         | Request a timed reference pulse to determine the target BDC communication speed                                                                                                                                                                                                                             |  |  |  |
| ACK_DISABLE    | Always Available | No        | 0x03/d                   | Disable the communication handshake. This command does not issue an ACK pulse.                                                                                                                                                                                                                              |  |  |  |
| ACK_ENABLE     | Always Available | Yes       | 0x02/d                   | Enable the communication handshake. Issues an ACK pulse after the command is executed.                                                                                                                                                                                                                      |  |  |  |
| BACKGROUND     | Non-Intrusive    | Yes       | 0x04/d                   | Halt the CPU if ENBDM is set.<br>Otherwise, ignore as illegal<br>command.                                                                                                                                                                                                                                   |  |  |  |
| DUMP_MEM.sz    | Non-Intrusive    | Yes       | (0x32+4 x sz)/d/rd.sz    | Dump (read) memory based on operand size (sz). Used with READ_MEM to dump large blocks of memory. An initial READ_MEM is executed to set up the starting address of the block and to retrieve the first result. Subsequent DUMP_MEM commands retrieve sequential operands.                                  |  |  |  |
| DUMP_MEM.sz_WS | Non-Intrusive    | No        | (0x33+4 x sz)/d/ss/rd.sz | Dump (read) memory based on operand size (sz) and report status. Used with READ_MEM{_WS} to dump large blocks of memory. An initial READ_MEM{_WS} is executed to set up the starting address of the block and to retrieve the first result. Subsequent DUMP_MEM{_WS} commands retrieve sequential operands. |  |  |  |

## Table 50-40. BDM Command Summary (continued)

| Command        | Command              | ACK                  | Command                           | B                                                                                                                                                                                                                                                                                                         |  |  |  |
|----------------|----------------------|----------------------|-----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Mnemonic       | Classification       | if Enb? <sup>1</sup> | Structure                         | Description                                                                                                                                                                                                                                                                                               |  |  |  |
| FILL_MEM.sz    | Non-Intrusive        | Yes                  | (0x12+4 x sz)/wd.sz/d             | Fill (write) memory based on operand size (sz). Used with WRITE_MEM to fill large blocks of memory. An initial WRITE_MEM is executed to set up the starting address of the block and to write the first operand. Subsequent FILL_MEM commands write sequential operands.                                  |  |  |  |
| FILL_MEM.sz_WS | Non-Intrusive        | No                   | (0x13+4 x sz)/wd.sz/d/ss          | Fill (write) memory based on operand size (sz) and report status. Used with WRITE_MEM{_WS} to fill large blocks of memory. An initial WRITE_MEM{_WS} is executed to set up the starting address of the block and to write the first operand. Subsequent FILL_MEM{_WS} commands write sequential operands. |  |  |  |
| GO             | Non-Intrusive        | Yes                  | 0x08/d                            | Resume the CPU's execution <sup>3</sup>                                                                                                                                                                                                                                                                   |  |  |  |
| NOP            | Non-Intrusive        | Yes                  | 0x00/d                            | No operation                                                                                                                                                                                                                                                                                              |  |  |  |
| READ_CREG      | Active<br>Background | Yes                  | (0xE0+CRN)/d/rd32                 | Read one of the CPU's control registers                                                                                                                                                                                                                                                                   |  |  |  |
| READ_DREG      | Non-Intrusive        | Yes                  | (0xA0+CRN)/d/rd32                 | Read one of the debug module's control registers                                                                                                                                                                                                                                                          |  |  |  |
| READ_MEM.sz    | Non-Intrusive        | Yes                  | (0x30+4 x sz)/ad24/d/rd.sz        | Read the appropriately-sized (sz) memory value from the location specified by the 24-bit address                                                                                                                                                                                                          |  |  |  |
| READ_MEM.sz_WS | Non-Intrusive        | No                   | (0x31+4 x sz)/ad24/d/ss/<br>rd.sz | Read the appropriately-sized (sz) memory value from the location specified by the 24-bit address and report status                                                                                                                                                                                        |  |  |  |
| READ_PSTB      | Non-Intrusive        | Yes                  | (0x40+CRN)/d/rd32                 | Read the requested longword location from the PST trace buffer                                                                                                                                                                                                                                            |  |  |  |
| READ_Rn        | Active<br>Background | Yes                  | (0x60+CRN)/d/rd32                 | Read the requested general-<br>purpose register (An, Dn) from the<br>CPU                                                                                                                                                                                                                                  |  |  |  |
| READ_XCSR_BYTE | Always Available     | No                   | 0x2D/rd8                          | Read the most significant byte of the debug module's XCSR                                                                                                                                                                                                                                                 |  |  |  |
| READ_CSR2_BYTE | Always Available     | No                   | 0x2E/rd8                          | Read the most significant byte of the debug module's CSR2                                                                                                                                                                                                                                                 |  |  |  |
| READ_CSR3_BYTE | Always Available     | No                   | 0x2F/rd8                          | Read the most significant byte of the debug module's CSR3                                                                                                                                                                                                                                                 |  |  |  |
| SYNC_PC        | Non-Intrusive        | Yes                  | 0x01/d                            | Display the CPU's current PC and capture it in the PST trace buffer                                                                                                                                                                                                                                       |  |  |  |

#### **Functional Description**

Table 50-40. BDM Command Summary (continued)

| Command         | Command              | ACK                  | Command                           | Description                                                                                                       |  |  |
|-----------------|----------------------|----------------------|-----------------------------------|-------------------------------------------------------------------------------------------------------------------|--|--|
| Mnemonic        | Classification       | if Enb? <sup>1</sup> | Structure                         | Description                                                                                                       |  |  |
| WRITE_CREG      | Active<br>Background | Yes                  | (0xC0+CRN)/wd32/d                 | Write one of the CPU's control registers                                                                          |  |  |
| WRITE_DREG      | Non-Intrusive        | Yes                  | (0x80+CRN)/wd32/d                 | Write one of the debug module's control registers                                                                 |  |  |
| WRITE_MEM.sz    | Non-Intrusive        | Yes                  | (0x10+4 x sz)/ad24/wd.sz/<br>d    | Write the appropriately-sized (sz) memory value to the location specified by the 24-bit address                   |  |  |
| WRITE_MEM.sz_WS | Non-Intrusive        | No                   | (0x11+4 x sz)/ad24/wd.sz/<br>d/ss | Write the appropriately-sized (sz) memory value to the location specified by the 24-bit address and report status |  |  |
| WRITE_Rn        | Active<br>Background | Yes                  | (0x40+CRN)/wd32/d                 | Write the requested general-<br>purpose register (An, Dn) of the<br>CPU                                           |  |  |
| WRITE_XCSR_BYTE | Always Available     | No                   | 0x0D/wd8                          | Write the most significant byte of the debug module's XCSR                                                        |  |  |
| WRITE_CSR2_BYTE | Always Available     | No                   | 0x0E/wd8                          | Write the most significant byte of the debug module's CSR2                                                        |  |  |
| WRITE_CSR3_BYTE | Always Available     | No                   | 0x0F/wd8                          | Write the most significant byte of the debug module's CSR3                                                        |  |  |

This column identifies if the command generates an ACK pulse if operating with acknowledge mode enabled. See ACK\_ENABLE, for addition information.

#### 50.4.1.5.1 SYNC

The SYNC command is unlike other BDC commands because the host does not necessarily know the correct speed to use for serial communications until after it has analyzed the response to the SYNC command.

To issue a SYNC command, the host:

- 1. Drives the BKGD pin low for at least 128 cycles of the slowest possible BDC clock (bus clock or device-specific alternate clock source).
- 2. Drives BKGD high for a brief speed-up pulse to get a fast rise time. (This speedup pulse is typically one cycle of the host clock which is as fast as the maximum target BDC clock.)
- 3. Removes all drive to the BKGD pin so it reverts to high impedance.
- 4. Listens to the BKGD pin for the sync response pulse.

<sup>2.</sup> The SYNC command is a special operation which does not have a command code.

<sup>3.</sup> If a GO command is received while the processor is not halted, it performs no operation.

Upon detecting the sync request from the host (which is a much longer low time than would ever occur during normal BDC communications), the target:

- 1. Waits for BKGD to return to a logic high.
- 2. Delays 16 cycles to allow the host to stop driving the high speed-up pulse.
- 3. Drives BKGD low for 128 BDC clock cycles.
- 4. Drives a 1-cycle high speed-up pulse to force a fast rise time on BKGD.
- 5. Removes all drive to the BKGD pin so it reverts to high impedance.

The host measures the low time of this 128-cycle sync response pulse and determines the correct speed for subsequent BDC communications. Typically, the host can determine the correct communication speed within a few percent of the actual target speed and the serial protocol can easily tolerate this speed error.

### 50.4.1.5.2 ACK DISABLE

Disable host/target handshake protocol

**Always Available** 



Disables the serial communication handshake protocol. The subsequent commands, issued after the ACK\_DISABLE command, do not execute the hardware handshake protocol. This command is not followed by an ACK pulse.

### 50.4.1.5.3 ACK\_ENABLE

Enable host/target handshake protocol

**Always Available** 



Enables the hardware handshake protocol in the serial communication. The hardware handshake is implemented by an acknowledge (ACK) pulse issued by the target MCU in response to a host command. The ACK\_ENABLE command is interpreted and executed in the BDC logic without the need to interface with the CPU. However, an acknowledge (ACK) pulse is issued by the target device after this command is executed. This feature can be used by the host to evaluate if the target supports the hardware handshake

protocol. If the target supports the hardware handshake protocol, subsequent commands are enabled to execute the hardware handshake protocol; otherwise, this command is ignored by the target.

For additional information about the hardware handshake protocol, refer to Serial Interface Hardware Handshake Protocol and Hardware Handshake Abort Procedure.

### 50.4.1.5.4 BACKGROUND

Enter active background mode (if enabled)

Non-intrusive



Provided XCSR[ENBDM] is set (BDM enabled), the BACKGROUND command causes the target MCU to enter active background (halt) mode as soon as the current CPU instruction finishes. If ENBDM is cleared (its default value), the BACKGROUND command is ignored.

A delay of 32 BDC clock cycles is required after the BACKGROUND command to allow the target MCU to finish its current CPU instruction and enter active background mode before a new BDC command can be accepted.

After the target MCU is reset into a normal operating mode, the host debugger would send a WRITE\_XCSR\_BYTE command to set ENBDM before attempting to send the BACKGROUND command the first time. Normally, the development host would set ENBDM once at the beginning of a debug session or after a target system reset, and then leave the ENBDM bit set during debugging operations. During debugging, the host would use GO commands to move from active background mode to normal user program execution and would use BACKGROUND commands or breakpoints to return to active background mode.

### 50.4.1.5.5 DUMP\_MEM.sz, DUMP\_MEM.sz\_WS

DUMP\_MEM.sz

Read memory specified by debug address register, then increment address

Non-intrusive



DUMP\_MEM.sz\_WS

Read memory specified by debug address register with status, Non-intrusive then increment address

|   | 0x33             |             | XCSR_SB          | Memory<br>data[7-0]   |                       |                      |                     |   |
|---|------------------|-------------|------------------|-----------------------|-----------------------|----------------------|---------------------|---|
| ļ | host → target    | D<br>L<br>Y | target → host    | target → host         | ļ                     |                      |                     |   |
|   | 0x37             |             | XCSR_SB          | Memory<br>data[15-8]  | Memory<br>data[7-0]   |                      |                     |   |
| • | host →<br>target | D<br>L<br>Y | target →<br>host | target →<br>host      | target →<br>host      | •                    |                     |   |
|   | 0x3B             |             | XCSR_SB          | Memory<br>data[31-24] | Memory<br>data[23-16] | Memory<br>data[15-8] | Memory<br>data[7-0] |   |
|   | host →<br>target | D<br>L<br>Y | target →<br>host | target →<br>host      | target →<br>host      | target →<br>host     | target →<br>host    | - |

DUMP\_MEM{\_WS} is used with the READ\_MEM{\_WS} command to access large blocks of memory. An initial READ\_MEM{\_WS} is executed to set-up the starting address of the block and to retrieve the first result. If an initial READ\_MEM{\_WS} is not executed before the first DUMP\_MEM{\_WS}, an illegal command response is returned. The DUMP\_MEM{\_WS} command retrieves subsequent operands. The initial address is incremented by the operand size (1, 2, or 4) and saved in a temporary register. Subsequent DUMP\_MEM{\_WS} commands use this address, perform the memory read,

increment it by the current operand size, and store the updated address in the temporary register. If the with-status option is specified, the core status byte (XCSR\_SB) contained in XCSR[31–24] is returned before the read data. XCSR\_SB reflects the state after the memory read was performed.

### Note

DUMP\_MEM{\_WS} does not check for a valid address; it is a valid command only when preceded by NOP, READ\_MEM{\_WS}, or another DUMP\_MEM{\_WS} command. Otherwise, an illegal command response is returned. NOP can be used for inter-command padding without corrupting the address pointer.

The size field (sz) is examined each time a DUMP\_MEM{\_WS} command is processed, allowing the operand size to be dynamically altered. The examples show the DUMP\_MEM.B{\_WS}, DUMP\_MEM.W{\_WS} and DUMP\_MEM.L{\_WS} commands.

### 50.4.1.5.6 FILL\_MEM.sz, FILL\_MEM.sz\_WS

FILL\_MEM.sz

Write memory specified by debug address register, then increment address



FILL\_MEM.sz\_WS

Write memory specified by debug address register with status, then increment address

Non-intrusive



FILL\_MEM{\_WS} is used with the WRITE\_MEM{\_WS} command to access large blocks of memory. An initial WRITE\_MEM{\_WS} is executed to set up the starting address of the block and write the first datum. If an initial WRITE\_MEM{\_WS} is not executed before the first FILL\_MEM{\_WS}, an illegal command response is returned. The FILL\_MEM{\_WS} command stores subsequent operands. The initial address is incremented by the operand size (1, 2, or 4) and saved in a temporary register. Subsequent FILL\_MEM{\_WS} commands use this address, perform the memory write, increment it by the current operand size, and store the updated address in the temporary register. If the with-status option is specified, the core status byte (XCSR\_SB) contained in XCSR[31–24] is returned after the write data. XCSR\_SB reflects the state after the memory write was performed.

### **Note**

FILL\_MEM{\_WS} does not check for a valid address; it is a valid command only when preceded by NOP, WRITE\_MEM{\_WS}, or another FILL\_MEM{\_WS} command. Otherwise, an illegal command response is returned. NOP can be used for intercommand padding without corrupting the address pointer.

The size field (sz) is examined each time a FILL\_MEM{\_WS} command is processed, allowing the operand size to be dynamically altered. The examples show the FILL\_MEM.B{\_WS}, FILL\_MEM.W{\_WS} and FILL\_MEM.L{\_WS} commands.

### 50.4.1.5.7 GO



This command is used to exit active background (halt) mode and begin (or resume) execution of the application's instructions. The CPU's pipeline is flushed and refilled before normal instruction execution resumes. Prefetching begins at the current address in the PC and at the current privilege level. If any register (such as the PC or SR) is altered by a BDM command while the processor is halted, the updated value is used when prefetching resumes. If a GO command is issued and the CPU is not halted, the command is ignored.

### 50.4.1.5.8 NOP



NOP performs no operation and may be used as a null command where required.

### 50.4.1.5.9 **READ\_CREG**



If the processor is halted, this command reads the selected control register and returns the 32-bit result. This register grouping includes the PC, SR, CPUCR, MACSR, MASK, ACC, VBR, and OTHER\_A7. Accesses to processor control registers are always 32-bits wide, regardless of implemented register width. The register is addressed through the core register number (CRN). See Table 50-39 for the CRN details when CRG is 11.

If the processor is not halted, this command is rejected as an illegal operation and no operation is performed.

### 50.4.1.5.10 READ\_DREG

### Read debug control register

Non-intrusive

| 0xA0+CRN         |             | DREG data<br>[31-24] | DREG data<br>[23-16]                                                    | DREG data<br>[15-8] | DREG data<br>[7-0] |
|------------------|-------------|----------------------|-------------------------------------------------------------------------|---------------------|--------------------|
| host →<br>target | D<br>L<br>Y | target →<br>host     | $\begin{array}{c} \text{target} \rightarrow \\ \text{host} \end{array}$ | target →<br>host    | target →<br>host   |

This command reads the selected debug control register and returns the 32-bit result. This register grouping includes the CSR, XCSR, CSR2, and CSR3. Accesses to debug control registers are always 32-bits wide, regardless of implemented register width. The register is addressed through the core register number (CRN). See Table 50-4 for CRN details.

### 50.4.1.5.11 READ\_MEM.sz, READ\_MEM.sz\_WS

READ\_MEM.sz

Read memory at the specified address

Non-intrusive



#### READ\_MEM.sz\_WS

### Read memory at the specified address with status

Non-intrusive

|   | 0x31             | Address[23-0]    |             | XCSR_SB          | Memory<br>data[7-0]   |                                                                         |                      |                     |
|---|------------------|------------------|-------------|------------------|-----------------------|-------------------------------------------------------------------------|----------------------|---------------------|
|   | host →<br>target | host →<br>target | D<br>L<br>Y | target →<br>host | target →<br>host      |                                                                         |                      |                     |
|   | 0x35             | Address[23-0]    |             | XCSR_SB          | Memory<br>data[15-8]  | Memory<br>data[7-0]                                                     |                      |                     |
|   | host →<br>target | host →<br>target | D<br>L<br>Y | target →<br>host | target →<br>host      | target →<br>host                                                        |                      |                     |
|   | 0x39             | Address[23-0]    |             | XCSR_SB          | Memory<br>data[31-24] | Memory<br>data[23-16]                                                   | Memory<br>data[15-8] | Memory<br>data[7-0] |
| _ | host →<br>target | host →<br>target | D<br>L<br>Y | target →<br>host | target →<br>host      | $\begin{array}{c} \text{target} \rightarrow \\ \text{host} \end{array}$ | target →<br>host     | target → host       |

Read data at the specified memory address. The reference address is transmitted as three 8-bit packets (msb to lsb) immediately after the command packet. The access attributes are defined by BAAR[TT,TM]. The hardware forces low-order address bits to zeros for word and longword accesses to ensure these accesses are on 0-modulo-size alignments. If the with-status option is specified, the core status byte (XCSR\_SB) contained in XCSR[31–24] is returned before the read data. XCSR\_SB reflects the state after the memory read was performed.

The examples show the READ\_MEM.B{\_WS}, READ\_MEM.W{\_WS} and READ\_MEM.L{\_WS} commands.

### 50.4.1.5.12 **READ\_PSTB**

### Read PST trace buffer at the specified address

Non-intrusive



Read 32 bits of captured PST/DDATA values from the trace buffer at the specified address. The PST trace buffer contains 64 six-bit entries, packed consecutively into 12 longword locations. See Table 50-37 for an illustration of how the buffer entries are packed.

### 50.4.1.5.13 READ\_Rn

### Read general-purpose CPU register

### **Active Background**



If the processor is halted, this command reads the selected CPU general-purpose register (An, Dn) and returns the 32-bit result. See Table 50-39 for the CRN details when CRG is 01.

If the processor is not halted, this command is rejected as an illegal operation and no operation is performed.

### 50.4.1.5.14 **READ\_XCSR\_BYTE**

#### **Read XCSR Status Byte**

**Always Available** 



Read the special status byte of XCSR (XCSR[31–24]). This command can be executed in any mode.

### 50.4.1.5.15 **READ\_CSR2\_BYTE**

### **Read CSR2 Status Byte**

**Always Available** 



Read the most significant byte of CSR2 (CSR2[31–24]). This command can be executed in any mode.

### 50.4.1.5.16 READ\_CSR3\_BYTE

**Read CSR2 Status Byte** 

**Always Available** 



Read the most significant byte of the CSR3 (CSR3[31–24]). This command can be executed in any mode.

### 50.4.1.5.17 SYNC\_PC

Synchronize PC to PST/DDATA Signals

Non-intrusive



Capture the processor's current PC (program counter) and display it on the PST/DDATA signals. After the debug module receives the command, it sends a signal to the ColdFire core that the current PC must be displayed. The core responds by forcing an instruction fetch to the next PC with the address being captured by the DDATA logic. The DDATA logic captures a 2- or 3-byte instruction address, based on CSR[9]. If CSR[9] is cleared, then a 2-byte address is captured, else a 3-byte address is captured. The specific sequence of PST and DDATA values is defined as:

- 1. Debug signals a SYNC\_PC command is pending.
- 2. CPU completes the current instruction.
- 3. CPU forces an instruction fetch to the next PC, generating a PST = 0x5 value indicating a taken branch. DDATA captures the instruction address corresponding to the PC. DDATA generates a PST marker signalling a 2- or 3-byte address as defined by CSR[9] (CSR[9] = 0, 2-byte; CSR[9] = 1, 3-byte) and displays the captured PC address.

This command can be used to provide a PC synchronization point between the core's execution and the application code in the PST trace buffer. It can also be used to dynamically access the PC for performance monitoring as the execution of this command is considerably less intrusive to the real-time operation of an application than a BACKGROUND/read-PC/GO command sequence.

### 50.4.1.5.18 WRITE CREG

#### Write CPU control register

### **Active Background**

| 0xC0+CRN         | CREG data<br>[31-24] | CREG data<br>[23-16] | CREG data<br>[15-8] | CREG data<br>[7-0] |             |  |
|------------------|----------------------|----------------------|---------------------|--------------------|-------------|--|
| host →<br>target | host →<br>target     | host →<br>target     | host →<br>target    | host →<br>target   | D<br>L<br>Y |  |

If the processor is halted, this command writes the 32-bit operand to the selected control register. This register grouping includes the PC, SR, CPUCR, MACSR, MASK, ACC, VBR, and OTHER\_A7. Accesses to processor control registers are always 32-bits wide, regardless of implemented register width. The register is addressed through the core register number (CRN). See Table 50-39 for the CRN details when CRG is 11.

If the processor is not halted, this command is rejected as an illegal operation and no operation is performed.

### 50.4.1.5.19 WRITE\_DREG

#### Write debug control register

#### Non-intrusive

| 0x80+CRN      | DREG data   DREG data   [23-16] |                  | DREG data<br>[15-8] | DREG data<br>[7-0] |             |
|---------------|---------------------------------|------------------|---------------------|--------------------|-------------|
| host → target | host →<br>target                | host →<br>target | host →<br>target    | host →<br>target   | D<br>L<br>Y |

This command writes the 32-bit operand to the selected debug control register. This grouping includes all the debug control registers ({X}CSR*n*, BAAR, AATR, TDR, PBR*n*, PBMR, AB*x*R, DBR, DBMR). Accesses to debug control registers are always 32-bits wide, regardless of implemented register width. The register is addressed through the core register number (CRN).

### **Note**

When writing XCSR, CSR2, or CSR3, WRITE\_DREG only writes bits 23–0. The upper byte of these debug registers is only written with the special WRITE\_XCSR\_BYTE, WRITE CSR2 BYTE, and WRITE CSR3 BYTE commands.

### 50.4.1.5.20 WRITE\_MEM.sz, WRITE\_MEM.sz\_WS

#### WRITE\_MEM.sz

### Write memory at the specified address

#### Non-intrusive

|           | 0x10             | Address[23-0]             | Memory<br>data[7-0]        |                            |                      |                     |  |
|-----------|------------------|---------------------------|----------------------------|----------------------------|----------------------|---------------------|--|
|           | host →<br>target | host → target             | host →<br>target           | D<br>L<br>Y                |                      |                     |  |
|           | 0x14             | Address[23-0]             | Memory<br>data[15-8]       | Memory<br>data[7–0]        |                      |                     |  |
|           | host →           | host $\rightarrow$ target | host →                     | host →                     | D<br>I               |                     |  |
|           | target           | nosi → laigei             | target                     | target                     | Ÿ                    |                     |  |
| $\exists$ | target<br>0x18   | Address[23-0]             | target  Memory data[31-24] | target  Memory data[23-16] | Memory<br>data[15-8] | Memory<br>data[7-0] |  |

#### WRITE\_MEM.sz\_WS

#### Write memory at the specified address with status

**Non-intrusive** 

|   | 0x11             | Address[23-0]    | Memory<br>data[7–0]   |             | XCSR_SE              | 3           |                      |                     |             |               |
|---|------------------|------------------|-----------------------|-------------|----------------------|-------------|----------------------|---------------------|-------------|---------------|
| _ | host →<br>target | host →<br>target | host →<br>target      | D<br>L<br>Y | target →<br>host     |             |                      |                     |             |               |
|   | 0x15             | Address[23-0]    | Memory<br>data[15-8]  | 1           | Memory<br>ata[7–0]   |             | XCSR_SE              | 3                   |             |               |
|   | host →<br>target | host →<br>target | host →<br>target      |             | host →<br>target     | D<br>L<br>Y | target →<br>host     | _                   |             |               |
|   | 0x19             | Address[23-0]    | Memory<br>data[31-24] | 1           | Memory<br>ata[23-16] |             | Memory<br>data[15-8] | Memory<br>data[7–0] |             | XCSR_SB       |
|   | host →<br>target | host →<br>target | host →<br>target      |             | host →<br>target     |             | host → target        | host → target       | D<br>L<br>Y | target → host |

Write data at the specified memory address. The reference address is transmitted as three 8-bit packets (msb to lsb) immediately after the command packet. The access attributes are defined by BAAR[TT,TM]. The hardware forces low-order address bits to zeros for word and longword accesses to ensure these accesses are on 0-modulo-size alignments. If the with-status option is specified, the core status byte (XCSR\_SB) contained in XCSR[31–24] is returned after the read data. XCSR\_SB reflects the state after the memory write was performed.

The examples show the WRITE\_MEM.B{\_WS}, WRITE\_MEM.W{\_WS}, and WRITE\_MEM.L{\_WS} commands.

### 50.4.1.5.21 WRITE\_Rn

### Write general-purpose CPU register

### **Active Background**

| 0x40+CRN         | Rn data<br>[31-24] | Rn data<br>[23-16] | Rn data<br>[15-8] | Rn data<br>[7-0] |             |  |
|------------------|--------------------|--------------------|-------------------|------------------|-------------|--|
| host →<br>target | host →<br>target   | host →<br>target   | host →<br>target  | host →<br>target | D<br>L<br>Y |  |

If the processor is halted, this command writes the 32-bit operand to the selected CPU general-purpose register (An, Dn). See Table 50-39 for the CRN details when CRG is 01.

If the processor is not halted, this command is rejected as an illegal operation and no operation is performed.

### 50.4.1.5.22 WRITE\_XCSR\_BYTE

### Write XCSR Status Byte

**Always Available** 



Write the special status byte of XCSR (XCSR[31–24]). This command can be executed in any mode.

### 50.4.1.5.23 WRITE CSR2 BYTE

### Write CSR2 Status Byte

**Always Available** 



Write the most significant byte of CSR2 (CSR2[31–24]). This command can be executed in any mode.

### 50.4.1.5.24 WRITE\_CSR3\_BYTE

Write CSR3 Status Byte

**Always Available** 



Write the most significant byte of CSR3 (CSR3[31–24]). This command can be executed in any mode.

### 50.4.1.5.25 BDM Accesses of the MAC Registers

The presence of rounding logic in the output datapath of the MAC requires special care for BDM-initiated reads and writes of its programming model. In particular, any result rounding modes must be disabled during the read/write process so the exact bit-wise MAC register contents are accessed.

For example, a BDM read of the accumulator (ACC) must be preceded by two commands accessing the MAC status register, as shown in the following sequence:

Likewise, to write an accumulator register, the following BDM sequence is needed:

For more information on saving and restoring the complete MAC programming model, see <<create reference to "Saving and Restoring the EMAC Programming Model" section>>.

### 50.4.1.6 Serial Interface Hardware Handshake Protocol

BDC commands that require CPU execution are ultimately treated at the core clock rate. Because the BDC clock source can be asynchronous relative to the bus frequency when CLKSW is cleared, it is necessary to provide a handshake protocol so the host can determine when an issued command is executed by the CPU. This section describes this protocol.

The hardware handshake protocol signals to the host controller when an issued command was successfully executed by the target. This protocol is implemented by a low pulse (16 BDC clock cycles) followed by a brief speedup pulse on the BKGD pin, generated by the target MCU when a command, issued by the host, has been successfully executed. See Figure 50-7. This pulse is referred to as the ACK pulse. After the ACK pulse is finished, the host can start the data-read portion of the command if the last-issued command was a read command, or start a new command if the last command was a write command or a control command (BACKGROUND, GO, NOP, SYNC\_PC). The ACK pulse is not issued earlier than 32 BDC clock cycles after the BDC command was issued. The end of the BDC command is assumed to be the 16th BDC clock cycle of the last bit. This minimum delay assures enough time for the host to recognize the ACK pulse. There is no upper limit for the delay between the command and the related ACK pulse, because the command execution depends on the CPU bus frequency, which in some cases could be slow compared to the serial communication rate. This protocol allows great flexibility for pod designers, because it does not rely on any accurate time measurement or short response time to any event in the serial communication.



Figure 50-7. Target Acknowledge Pulse (ACK)

### **Note**

If the ACK pulse was issued by the target, the host assumes the previous command was executed. If the CPU enters a stop mode prior to executing a non-intrusive command, the

command is discarded and the ACK pulse is not issued. After entering a stop mode, the BDC command is no longer pending and the XCSR[CSTAT] value of 001 is kept until the next command is successfully executed.

Figure 50-8 shows the ACK handshake protocol in a command level timing diagram. A READ\_MEM.B command is used as an example:

- 1. The 8-bit command code is sent by the host, followed by the address of the memory location to be read.
- 2. The target BDC decodes the command and sends it to the CPU.
- 3. Upon receiving the BDC command request, the CPU schedules a execution slot for the command.
- 4. The CPU temporarily stalls the instruction stream at the scheduled point, executes the READ\_MEM.B command and then continues.

This process is referred to as cycle stealing. The READ\_MEM.B appears as a single-cycle operation to the processor, even though the pipelined nature of the Operand Execution Pipeline requires multiple CPU clock cycles for it to actually complete. After that, the debug module tracks the execution of the READ\_MEM.b command as the processor resumes the normal flow of the application program. After detecting the READ\_MEM.B command is done, the BDC issues an ACK pulse to the host controller, indicating that the addressed byte is ready to be retrieved. After detecting the ACK pulse, the host initiates the data-read portion of the command.



Figure 50-8. Handshake Protocol at Command Level

Unlike a normal bit transfer, where the host initiates the transmission by issuing a negative edge in the BKGD pin, the serial interface ACK handshake pulse is initiated by the target MCU. The hardware handshake protocol in Figure 50-8 specifies the timing when the BKGD pin is being driven, so the host should follow these timing relationships to avoid the risks of an electrical conflict at the BKGD pin.

The ACK handshake protocol does not support nested ACK pulses. If a BDC command is not acknowledged by an ACK pulse, the host first needs to abort the pending command before issuing a new BDC command. When the CPU enters a stop mode at about the same time the host issues a command that requires CPU execution, the target discards the incoming command. Therefore, the command is not acknowledged by the target, meaning that the ACK pulse is not issued in this case. After a certain time, the host could decide to abort the ACK protocol to allow a new command. Therefore, the protocol provides a mechanism where a command (a pending ACK) could be aborted. Unlike a regular BDC command, the ACK pulse does not provide a timeout. In the case of a STOP instruction where the ACK is prevented from being issued, it would remain pending indefinitely if not aborted. See the handshake abort procedure described in Hardware Handshake Abort Procedure.

### 50.4.1.7 Hardware Handshake Abort Procedure

The abort procedure is based on the SYNC command. To abort a command that has not responded with an ACK pulse, the host controller generates a sync request (by driving BKGD low for at least 128 serial clock cycles and then driving it high for one serial clock cycle as a speedup pulse). By detecting this long low pulse on the BKGD pin, the target executes the sync protocol (see SYNC), and assumes that the pending command and therefore the related ACK pulse, are being aborted. Therefore, after the sync protocol completes, the host is free to issue new BDC commands.

Because the host knows the target BDC clock frequency, the SYNC command does not need to consider the lowest possible target frequency. In this case, the host could issue a SYNC close to the 128 serial clock cycles length, providing a small overhead on the pulse length to assure the sync pulse is not misinterpreted by the target.

It is important to notice that any issued BDC command that requires CPU execution is scheduled for execution by the pipeline based on the dynamic state of the machine, provided the processor does not enter any of the stop modes. If the host aborts a command by sending the sync pulse, it should then read XCSR[CSTAT] after the sync response is issued by the target, checking for CSTAT cleared, before attempting to send any new command that requires CPU execution. This prevents the new command from being discarded at the debug/CPU interface, due to the pending command being executed by the CPU. Any new command should be issued only after XCSR[CSTAT] is cleared.

There are multiple reasons that could cause a command to take too long to execute, measured in terms of the serial communication rate: The BDC clock frequency could be much faster than the CPU clock frequency, or the CPU could be accessing a slow memory, which would cause pipeline stall cycles to occur. All commands referencing the CPU registers or memory require access to the processor's local bus to complete. If the

processor is executing a tight loop contained within a single aligned longword, the processor may never successfully grant the internal bus to the debug command. For example:

```
align 4
label1: nop bra.b label1
or align 4
label2: bra.w label2
```

These two examples of tight loops exhibit the BDM lockout behavior. If the loop spans across two longwords, there are no issues, so the recommended construct is:

```
align 4 label3: bra.l label3
```

The hardware handshake protocol is appropriate for these situations, but the host could also decide to use the software handshake protocol instead. In this case, if XCSR[CSTAT] is 001, there is a BDC command pending at the debug/CPU interface. The host controller should monitor XCSR[CSTAT] and wait until it is 000 to be able to issue a new command that requires CPU execution. However, if the XCSR[CSTAT] is 1xx, the host should assume the last command failed to execute. To recover from this condition, the following sequence is suggested:

- 1. Issue a SYNC command to reset the BDC communication channel.
- 2. The host issues a BDM NOP command.
- 3. The host reads the channel status using a READ\_XCSR\_BYTE command.
- 4. If XCSR[CSTAT] is 000

then the status is okay; proceed

else

Halt the CPU using a BDM BACKGROUND command Repeat steps 1,2,3 If XCSR[CSTAT] is 000, then proceed, else reset the device

The following figure shows a SYNC command aborting a READ\_MEM.B. After the command is aborted, a new command could be issued by the host.

#### Note

In the following figure, signal timing is not drawn to scale.



Figure 50-9. ACK Abort Procedure at the Command Level

The following figure shows a conflict between the ACK pulse and the sync request pulse. This conflict could occur if a pod device is connected to the target BKGD pin and the target is already executing a BDC command. Consider that the target CPU is executing a pending BDC command at the exact moment the pod is being connected to the BKGD pin. In this case, an ACK pulse is issued at the same time as the SYNC command. In this case there is an electrical conflict between the ACK speedup pulse and the sync pulse. Because this is not a probable situation, the protocol does not prevent this conflict from happening.



Figure 50-10. ACK Pulse and SYNC Request Conflict

The hardware handshake protocol is enabled by the ACK\_ENABLE command and disabled by the ACK\_DISABLE command. It also allows for pod devices to choose between the hardware handshake protocol or the software protocol that monitors the XCSR status byte. The ACK\_ENABLE and ACK\_DISABLE commands are:

- ACK\_ENABLE Enables the hardware handshake protocol. The target issues the ACK pulse when a CPU command is executed. The ACK\_ENABLE command itself also has the ACK pulse as a response.
- ACK\_DISABLE Disables the ACK pulse protocol. In this case, the host should verify the state of XCSR[CSTAT] to evaluate if there are pending commands and to check if the CPU's operating state has changed to or from active background mode via XCSR[31–30].

The default state of the protocol, after reset, is hardware handshake protocol disabled.

The commands that do not require CPU execution, or that have the status register included in the retrieved bit stream, do not perform the hardware handshake protocol. Therefore, the target does not respond with an ACK pulse for those commands even if the hardware protocol is enabled. Conversely, only commands that require CPU execution and do not include the status byte perform the hardware handshake protocol. See the third column in Table 50-40 for the complete enumeration of this function.

An exception is the ACK\_ENABLE command, which does not require CPU execution but responds with the ACK pulse. This feature can be used by the host to evaluate if the target supports the hardware handshake protocol. If an ACK pulse is issued in response to this command, the host knows that the target supports the hardware handshake protocol. If the target does not support the hardware handshake protocol the ACK pulse is not issued. In this case, the ACK\_ENABLE command is ignored by the target, because it is not recognized as a valid command.

### 50.4.2 Real-Time Debug Support

The ColdFire family supports debugging real-time applications. For these types of embedded systems, the processor must continue to operate during debug. The foundation of this area of debug support is that while the processor cannot be halted to allow debugging, the system can generally tolerate the small intrusions with minimal effect on real-time operation.

### **Note**

The details regarding real-time debug support will be supplied at a later time.

## 50.4.3 Trace Support

For the baseline V1 ColdFire core and its single debug signal, support for trace functionality is completely redefined. The V1 solution provides an on-chip PST/DDATA trace buffer (known as the PSTB) to record the stream of PST and DDATA values.

As a review, the classic ColdFire debug architecture supports real-time trace via the PST/DDATA output signals. For this functionality, the following apply:

- One (or more) PST value is generated for each executed instruction
- Branch target instruction address information is displayed on all non-PC-relative change-of-flow instructions, where the user selects a programmable number of bytes of target address
  - Displayed information includes PST marker plus target instruction address as DDATA
  - Captured address creates the appropriate number of DDATA entries, each with 4 bits of address
- Optional data trace capabilities are provided for accesses mapped to the slave peripheral bus
  - Displayed information includes PST marker plus captured operand value as DDATA
  - Captured operand creates the appropriate number of DDATA entries, each with 4 bits of data

The resulting PST/DDATA output stream, with the application program memory image, provides an instruction-by-instruction dynamic trace of the execution path.

Even with the application of a PST trace buffer, problems associated with the PST bandwidth and associated fill rate of the buffer remain. Given that there is one (or more) PST entry per instruction, the PSTB would fill rapidly without some type of data compression.

Consider the following example to illustrate the PST compression algorithm. Most sequential instructions generate a single PST = 1 value. Without compression, the execution of ten sequential instructions generates a stream of ten PST = 1 values. With PST compression, the reporting of any PST = 1 value is delayed so that consecutive PST = 1 values can be accumulated. When a PST  $\neq$  1 value is reported, the maximum accumulation count is reached, or a debug data value is captured, a single accumulated

PST value is generated. Returning to the example with compression enabled, the execution of ten sequential instructions generates a single PST value indicating ten sequential instructions have been executed.

This technique has proven to be effective at significantly reducing the average PST entries per instruction and PST entries per machine cycle. The application of this compression technique makes the application of a useful PST trace buffer for the V1 ColdFire core realizable. The resulting 5-bit PST definitions are shown in the following table.

Table 50-41. CF1 Debug Processor Status Encodings

| PST[4:0]      | Definition                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x00          | Continue execution. Many instructions execute in one processor cycle. If an instruction requires more processor clock cycles, subsequent clock cycles are indicated by driving PST with this encoding.                                                                                                                                                                                                                                                                                           |
| 0x01          | Begin execution of one instruction. For most instructions, this encoding signals the first processor clock cycle of an instruction's execution. Certain change-of-flow opcodes, plus the PULSE and WDDATA instructions, generate different encodings.                                                                                                                                                                                                                                            |
| 0x02          | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 0x03          | Entry into user-mode. Signaled after execution of the instruction that caused the ColdFire processor to enter user mode.                                                                                                                                                                                                                                                                                                                                                                         |
| 0x04          | Begin execution of PULSE and WDDATA instructions. PULSE defines triggers or markers for debug and/or performance analysis. WDDATA lets the core write any operand (byte, word, or longword) directly to the DDATA port, independent of debug module configuration. When WDDATA is executed, a value of 0x04 is signaled on the PST port, followed by the appropriate marker, and then the data transfer on the DDATA port. The number of captured data bytes depends on the WDDATA operand size. |
| 0x05          | Begin execution of taken branch or SYNC_PC BDM command. For some opcodes, a branch target address may be displayed on DDATA depending on the CSR settings. CSR also controls the number of address bytes displayed, indicated by the PST marker value preceding the DDATA nibble that begins the data output. This encoding also indicates that the SYNC_PC command has been processed.                                                                                                          |
| 0x06          | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 0x07          | Begin execution of return from exception (RTE) instruction.                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 0x08–<br>0x0B | Indicates the number of data bytes to be loaded into the PST trace buffer. The capturing of peripheral bus data references is controlled by CSR[DDC].                                                                                                                                                                                                                                                                                                                                            |
|               | 0x08 Begin 1-byte data transfer on DDATA                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|               | 0x09 Begin 2-byte data transfer on DDATA                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|               | 0x0A Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|               | 0x0B Begin 4-byte data transfer on DDATA                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 0x0C-<br>0x0F | Indicates the number of address bytes to be loaded into the PST trace buffer. The capturing of branch target addresses is controlled by CSR[BTB].                                                                                                                                                                                                                                                                                                                                                |
|               | 0x0C Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|               | 0x0D Begin 2-byte address transfer on DDATA (Displayed address is shifted right 1: ADDR[16:1])                                                                                                                                                                                                                                                                                                                                                                                                   |
|               | 0x0E Begin 3-byte address transfer on DDATA (Displayed address is shifted right 1: ADDR[23:1])                                                                                                                                                                                                                                                                                                                                                                                                   |
|               | 0x0F Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

Table continues on the next page...

Table 50-41. CF1 Debug Processor Status Encodings (continued)

| PST[4:0]      | Definition                                                                                                                                                                                                                                                                                        |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x10-<br>0x11 | Reserved                                                                                                                                                                                                                                                                                          |
| 0x12          | Completed execution of 2 sequential instructions                                                                                                                                                                                                                                                  |
| 0x13          | Completed execution of 3 sequential instructions                                                                                                                                                                                                                                                  |
| 0x14          | Completed execution of 4 sequential instructions                                                                                                                                                                                                                                                  |
| 0x15          | Completed execution of 5 sequential instructions                                                                                                                                                                                                                                                  |
| 0x16          | Completed execution of 6 sequential instructions                                                                                                                                                                                                                                                  |
| 0x17          | Completed execution of 7 sequential instructions                                                                                                                                                                                                                                                  |
| 0x18          | Completed execution of 8 sequential instructions                                                                                                                                                                                                                                                  |
| 0x19          | Completed execution of 9 sequential instructions                                                                                                                                                                                                                                                  |
| 0x1A          | Completed execution of 10 sequential instructions                                                                                                                                                                                                                                                 |
| 0x1B          | This value signals there has been a change in the breakpoint trigger state machine. It appears as a single marker for each state change and is immediately followed by a DDATA value signaling the new breakpoint trigger state encoding.                                                         |
|               | The DDATA breakpoint trigger state value is defined as (0x20 + 2 × CSR[BSTAT]):                                                                                                                                                                                                                   |
|               | 0x20 No breakpoints enabled                                                                                                                                                                                                                                                                       |
|               | 0x22 Waiting for a level-1 breakpoint                                                                                                                                                                                                                                                             |
|               | 0x24 Level-1 breakpoint triggered                                                                                                                                                                                                                                                                 |
|               | 0x2A Waiting for a level-2 breakpoint                                                                                                                                                                                                                                                             |
|               | 0x2C Level-2 breakpoint triggered                                                                                                                                                                                                                                                                 |
| 0x1C          | Exception processing. This value signals the processor has encountered an exception condition. Although this is a multi-cycle mode, there are only two PST = 0x1C values recorded before the mode value is suppressed.                                                                            |
| 0x1D          | Emulator mode exception processing. This value signals the processor has encountered a debug interrupt or a properly-configured trace exception. Although this is a multi-cycle mode, there are only two PST = 0x1D values recorded before the mode value is suppressed.                          |
| 0x1E          | Processor is stopped. This value signals the processor has executed a STOP instruction. Although this is a multi-cycle mode because the ColdFire processor remains stopped until an interrupt or reset occurs, there are only two PST = 0x1E values recorded before the mode value is suppressed. |
| 0x1F          | Processor is halted. This value signals the processor has been halted. Although this is a multi-cycle mode because the ColdFire processor remains halted until a BDM go command is received or reset occurs, there are only two PST = 0x1F values recorded before the mode value is suppressed.   |

# 50.4.3.1 Begin Execution of Taken Branch (PST = 0x05)

The PST is 0x05 when a taken branch is executed. For some opcodes, a branch target address may be loaded into the trace buffer (PSTB) depending on the CSR settings. CSR also controls the number of address bytes loaded that is indicated by the PST marker value immediately preceding the DDATA entry in the PSTB that begins the address entries.

Multiple byte DDATA values are displayed in least-to-most-significant order. The processor captures only those target addresses associated with taken branches that use a variant addressing mode (RTE and RTS instructions, JMP and JSR instructions using address register indirect or indexed addressing modes, and all exception vectors).

The simplest example of a branch instruction using a variant address is the compiled code for a C language case statement. Typically, the evaluation of this statement uses the variable of an expression as an index into a table of offsets, where each offset points to a unique case within the structure. For such change-of-flow operations, the ColdFire processor loads the PSTB as follows:

- 1. Load PST=0x05 to identify that a taken branch is executed.
- 2. Optionally load the marker for the target address capture. Encodings 0x0D or 0x0E identify the number of bytes loaded into the PSTB.
- 3. The new target address is optionally available in the PSTB. The number of bytes of the target address loaded is configurable (2 or 3 bytes, where the encoding is 0x0D and 0x0E, respectively).

Another example of a variant branch instruction is a JMP (A0) instruction. The following figure shows the PSTB entries that indicate a JMP (A0) execution, assuming CSR[BTB] was programmed to display the lower two bytes of an address.

| PST/DDATA Values     | Description           |
|----------------------|-----------------------|
| 0x05                 | Taken Branch          |
| 0x0D                 | 2-byte Address Marker |
| {10, Address[4:1]}   | Address >> 1          |
| {10, Address[8:5]}   |                       |
| {10, Address[12:9]}  |                       |
| {10, Address[16:13]} |                       |

Figure 50-11. Example JMP Instruction Output in PSTB

The PST of 0x05 indicates a taken branch and the marker value 0x0D indicates a 2-byte address. Therefore, the following entries display the lower two bytes of address register A0, right-shifted by 1, in least-to-most-significant nibble order. The next PST entry after the JMP instruction completes depends on the target instruction. See PST Trace Buffer (PSTB) Entry Format, for entry descriptions explaining the 2-bit prefix before each address nibble.

### 50.4.3.2 PST Trace Buffer (PSTB) Entry Format

As PST and DDATA values are captured and loaded in the trace buffer, each entry is six bits in size therefore, the type of the entry can easily be determined when post-processing the PSTB.



Depending on which nibble is displayed (as determined by SDR[9:8]), Address [3:0] s (least-to-most-significant nibble order) displays four bits of the real CPU address [16:1] or [24:1].

Figure 50-12. V1 PST/DDATA Trace Buffer Entry Format

### 50.4.3.3 PST/DDATA Example

In this section, an example showing the behavior of the PST/DDATA functionality is detailed. Consider the following interrupt service routine that counts the interrupt, negates the IRQ, performs a software IACK, and then exits. This example is presented here because it exercises a considerable set of the PST/DDATA capabilities.

```
isr:
01074: 46fc 2700
                       mov.w
                               &0x2700,%sr
                                                  # disable interrupts
01078: 2f08
                       mov.l
                                %a0,-(%sp)
                                                  # save a0
0107a: 2f00
                                %d0,-(%sp)
                                                  # save d0
                       mov.l
0107c: 302f 0008
                                (8,%sp),%d0
                                                  # load format/vector word
                       mov.w
                       andi.l &0xff,%d0
01080: e488
                                                  # align vector number
01082: 0280 0000 00ff
                                                  # isolate vector number
01088: 207c 0080 1400
                       mov.l
                               &int count,%a0
                                                 # base of interrupt counters
                     _isr_entry1:
0108e: 52b0 0c00
                       ad\overline{dq}.1 &1,(0,%a0,%d0.1*4) # count the interrupt
                                %d0,IGCR0+1.w # negate the irq
01092: 11c0 a021
                       mov.b
01096: 1038 a020
                       mov.b
                               IGCR0.w,%d0
                                                  # force the write to complete
0109a: 4e71
                                                  # synchronize the pipelines
                       nop
                       mvz.b
                                SWIACK.w,%d0
0109c: 71b8 ffe0
                                                  # software iack: pending irq?
                       cmpi.1 %d0,&0x41
010a0: 0c80 0000 0041
                                                  # level 7 or none pending?
                                _isr_exit
                                                  # yes, then exit
010a6: 6f08
                       ble.b
010a8: 52b9 0080 145c
                       addq.l &1, swiack count
                                                  # increment the swiack count
                                                  # continue at entry1
010ae: 60de
                       bra.b
                               isr entry1
                     _isr_exit:
010b0: 201f
                       mov. 1
                               (%sp) + , %d0
                                                  # restore d0
010b2: 205f
                                (%sp) + , %a0
                       mov.l
                                                  # restore a0
010b4: 4e73
                       rte
                                                  # exit
```

This ISR executes mostly as straight-line code: there is a single conditional branch @ PC = 0x10A6, which is taken in this example. The following description includes the PST and DDATA values generated as this code snippet executes. In this example, the CSR setting enables only the display of 2-byte branch addresses. Operand data captures are not enabled. The sequence begins with an interrupt exception:

```
interrupt exception occurs @ pc = 5432 while in user mode
                                           \# pst = 1c, 1c, 05, 0d
                                           \# ddata = 2a, 23, 28, 20
                                                  trq addr = 083a << 1
                                                  trg_addr = 1074
_isr:
                                                 = 01
                                                 = 01
                                                 = 01
                                                 = 01
                                          # pst = 01
                                                 = 01
                                                 = 01
                                          # pst = 01, 08c
                                           # ddata = 30, 30
                                                  wdata.b = 0x00
                                          # pst = 01, 08
01096: 1038 a020 mov.b IGCR0.w,%d0
                                           # ddata = 28, 21
                                                  rdata.b = 0x18
                 nop
mvz.b SWIACK.w,%d0
0109a: 4e71
                                           # pst = 01
0109c: 71b8 ffe0
                                           # pst = 01, 08
                                          \# ddata = 20, 20
                                                 rdata.b = 0x00
# pst = 01
                                          # pst = 05 (taken branch)
                                          # pst = 01
                                          # pst = 01
                                          # pst = 07, 03, 05, 0d
# ddata = 29, 21, 2a, 22
010b4: 4e73
                                                  trg_addr = 2a19 << 1
                                                   trg addr = 5432
```

As the PSTs are compressed, the resulting stream of 6-bit hexadecimal entries is loaded into consecutive locations in the PST trace buffer:

Architectural studies on the compression algorithm determined an appropriate size for the PST trace buffer. Using a suite of ten MCU benchmarks, a 64-entry PSTB was found to capture an average window of time of 520 processor cycles with program trace using 2-byte addresses enabled.

### 50.4.3.4 Processor Status, Debug Data Definition

This section specifies the ColdFire processor and debug module's generation of the processor status (PST) and debug data (DDATA) output on an instruction basis. In general, the PST/DDATA output for an instruction is defined as follows:

$$PST = 0x01$$
, { $PST = 0x0[89B]$ ,  $DDATA = operand$ }

where the {...} definition is optional operand information defined by the setting of the CSR, and [...] indicates the presence of one value from the list.

The CSR provides capabilities to display operands based on reference type (read, write, or both). A PST value {0x08, 0x09, or 0x0B} identifies the size and presence of valid data to follow in the PST trace buffer (PSTB) {1, 2, or 4 bytes, respectively}. Additionally, CSR[DDC] specifies whether operand data capture is enabled and what size. Also, for certain change-of-flow instructions, CSR[BTB] provides the capability to display the target instruction address in the PSTB (2 or 3 bytes) using a PST value of 0x0D or 0x0E, respectively.

### 50.4.3.4.1 User Instruction Set

The following table shows the PST/DDATA specification for user-mode instructions. Rn represents any {Dn, An} register. In this definition, the y suffix generally denotes the source, and x denotes the destination operand. For a given instruction, the optional operand data is displayed only for those effective addresses referencing memory. The DD nomenclature refers to the DDATA outputs.

Table 50-42. PST/DDATA Specification for User-Mode Instructions

| Instructio<br>n | Operand<br>Syntax          | PST/DDATA                                                             |
|-----------------|----------------------------|-----------------------------------------------------------------------|
| add.l           | <ea>y,Dx</ea>              | PST = 0x01, {PST = 0x0B, DD = source operand}                         |
| add.l           | Dy, <ea>x</ea>             | PST = 0x01, {PST = 0x0B, DD = source}, {PST = 0x0B, DD = destination} |
| adda.l          | <ea>y,Ax</ea>              | PST = 0x01, {PST = 0x0B, DD = source operand}                         |
| addi.l          | # <data>,Dx</data>         | PST = 0x01                                                            |
| addq.l          | # <data>,<ea>x</ea></data> | PST = 0x01, {PST = 0x0B, DD = source}, {PST = 0x0B, DD = destination} |
| addx.l          | Dy,Dx                      | PST = 0x01                                                            |
| and.l           | <ea>y,Dx</ea>              | PST = 0x01, {PST = 0x0B, DD = source operand}                         |
| and.l           | Dy, <ea>x</ea>             | PST = 0x01, {PST = 0x0B, DD = source}, {PST = 0x0B, DD = destination} |
| andi.l          | # <data>,Dx</data>         | PST = 0x01                                                            |
| asl.l           | {Dy,# <data>},Dx</data>    | PST = 0x01                                                            |
| asr.l           | {Dy,# <data>},Dx</data>    | PST = 0x01                                                            |
| bcc.{b,w,l}     |                            | if taken, then PST = 0x05, else PST = 0x01                            |

Table continues on the next page...

### Table 50-42. PST/DDATA Specification for User-Mode Instructions (continued)

| Instructio<br>n | Operand<br>Syntax          | PST/DDATA                                                             |  |
|-----------------|----------------------------|-----------------------------------------------------------------------|--|
| bchg.{b,l}      | # <data>,<ea>x</ea></data> | PST = 0x01, {PST = 0x08, DD = source}, {PST = 0x08, DD = destination} |  |
| bchg.{b,l}      | Dy, <ea>x</ea>             | PST = 0x01, {PST = 0x08, DD = source}, {PST = 0x08, DD = destination} |  |
| bclr.{b,l}      | # <data>,<ea>x</ea></data> | PST = 0x01, {PST = 0x08, DD = source}, {PST = 0x08, DD = destination} |  |
| bclr.{b,l}      | Dy, <ea>x</ea>             | PST = 0x01, {PST = 0x08, DD = source}, {PST = 0x08, DD = destination} |  |
| bitrev.l        | Dx                         | PST = 0x01                                                            |  |
| bra.{b,w,l}     |                            | PST = 0x05                                                            |  |
| bset.{b,l}      | # <data>,<ea>x</ea></data> | PST = 0x01, {PST = 0x08, DD = source}, {PST = 0x08, DD = destination} |  |
| bset.{b,l}      | Dy, <ea>x</ea>             | PST = 0x01, {PST = 0x08, DD = source}, {PST = 0x08, DD = destination} |  |
| bsr.{b,w,l}     |                            | PST = 0x05, {PST = 0x0B, DD = destination operand}                    |  |
| btst.{b,l}      | # <data>,<ea>x</ea></data> | PST = 0x01, {PST = 0x08, DD = source operand}                         |  |
| btst.{b,l}      | Dy, <ea>x</ea>             | PST = 0x01, {PST = 0x08, DD = source operand}                         |  |
| byterev.l       | Dx                         | PST = 0x01                                                            |  |
| clr.b           | <ea>x</ea>                 | PST = 0x01, {PST = 0x08, DD = destination operand}                    |  |
| clr.l           | <ea>x</ea>                 | PST = 0x01, {PST = 0x0B, DD = destination operand}                    |  |
| clr.w           | <ea>x</ea>                 | PST = 0x01, {PST = 0x09, DD = destination operand}                    |  |
| cmp.b           | <ea>y,Dx</ea>              | PST = 0x01, {0x08, source operand}                                    |  |
| cmp.l           | <ea>y,Dx</ea>              | PST = 0x01, {PST = 0x0B, DD = source operand}                         |  |
| cmp.w           | <ea>y,Dx</ea>              | PST = 0x01, {0x09, source operand}                                    |  |
| cmpa.l          | <ea>y,Ax</ea>              | PST = 0x01, {PST = 0x0B, DD = source operand}                         |  |
| cmpa.w          | <ea>y,Ax</ea>              | PST = 0x01, {0x09, source operand}                                    |  |
| cmpi.b          | # <data>,Dx</data>         | PST = 0x01                                                            |  |
| cmpi.l          | # <data>,Dx</data>         | PST = 0x01                                                            |  |
| cmpi.w          | # <data>,Dx</data>         | PST = 0x01                                                            |  |
| divs.l          | <ea>y,Dx</ea>              | PST = 0x01, {PST = 0x0B, DD = source operand}                         |  |
| divs.w          | <ea>y,Dx</ea>              | PST = 0x01, {PST = 0x09, DD = source operand}                         |  |
| divu.l          | <ea>y,Dx</ea>              | PST = 0x01, {PST = 0x0B, DD = source operand}                         |  |
| divu.w          | <ea>y,Dx</ea>              | PST = 0x01, {PST = 0x09, DD = source operand}                         |  |
| eor.l           | Dy, <ea>x</ea>             | PST = 0x01, {PST = 0x0B, DD = source}, {PST = 0x0B, DD = destination} |  |
| eori.l          | # <data>,Dx</data>         | PST = 0x01                                                            |  |
| ext.l           | Dx                         | PST = 0x01                                                            |  |
| ext.w           | Dx                         | PST = 0x01                                                            |  |
| extb.l          | Dx                         | PST = 0x01                                                            |  |
| illegal         |                            | $PST = 0x01^{1}$                                                      |  |
| jmp             | <ea>y</ea>                 | PST = 0x05, {PST = 0x0[DE], DD = target address} <sup>2</sup>         |  |

Table continues on the next page...

### Table 50-42. PST/DDATA Specification for User-Mode Instructions (continued)

| Instructio<br>n | Operand<br>Syntax                          | PST/DDATA                                                             |  |
|-----------------|--------------------------------------------|-----------------------------------------------------------------------|--|
| jsr             | <ea>y</ea>                                 | PST = 0x05, {PST = 0x0[DE], DD = target address},                     |  |
|                 |                                            | $\{PST = 0x0B, DD = destination operand\}^2$                          |  |
| lea.l           | <ea>y,Ax</ea>                              | PST = 0x01                                                            |  |
| link.w          | Ay,# <displaceme<br>nt&gt;</displaceme<br> | PST = 0x01, {PST = 0x0B, DD = destination operand}                    |  |
| Isl.I           | {Dy,# <data>},Dx</data>                    | PST = 0x01                                                            |  |
| Isr.I           | {Dy,# <data>},Dx</data>                    | PST = 0x01                                                            |  |
| mov3q.l         | # <data>,<ea>x</ea></data>                 | PST = 0x01, {PST = 0x0B,DD = destination operand}                     |  |
| move.b          | <ea>y,<ea>x</ea></ea>                      | PST = 0x01, {PST = 0x08, DD = source}, {PST = 0x08, DD = destination} |  |
| move.l          | <ea>y,<ea>x</ea></ea>                      | PST = 0x01, {PST = 0x0B, DD = source}, {PST = 0x0B, DD = destination} |  |
| move.w          | <ea>y,<ea>x</ea></ea>                      | PST = 0x01, {PST = 0x09, DD = source}, {PST = 0x09, DD = destination} |  |
| move.w          | CCR,Dx                                     | PST = 0x01                                                            |  |
| move.w          | {Dy,# <data>},CC<br/>R</data>              | PST = 0x01                                                            |  |
| movea.l         | <ea>y,Ax</ea>                              | PST = 0x01, {PST = 0x0B, DD = source}                                 |  |
| movea.w         | <ea>y,Ax</ea>                              | PST = 0x01, {PST = 0x09, DD = source}                                 |  |
| movem.l         | #list, <ea>x</ea>                          | PST = 0x01, {PST = 0x0B, DD = destination},                           |  |
| movem.l         | <ea>y,#list</ea>                           | PST = 0x01, {PST = 0x0B, DD = source},                                |  |
| moveq.l         | # <data>,Dx</data>                         | PST = 0x01                                                            |  |
| muls.l          | <ea>y,Dx</ea>                              | PST = 0x01, {PST = 0x0B, DD = source operand}                         |  |
| muls.w          | <ea>y,Dx</ea>                              | PST = 0x01, {PST = 0x09, DD = source operand}                         |  |
| mulu.l          | <ea>y,Dx</ea>                              | PST = 0x01, {PST = 0x0B, DD = source operand}                         |  |
| mulu.w          | <ea>y,Dx</ea>                              | PST = 0x01, {PST = 0x09, DD = source operand}                         |  |
| mvs.b           | <ea>y,Dx</ea>                              | PST = 0x01, {0x08, source operand}                                    |  |
| mvs.w           | <ea>y,Dx</ea>                              | PST = 0x01, {0x09, source operand}                                    |  |
| mvz.b           | <ea>y,Dx</ea>                              | PST = 0x01, {0x08, source operand}                                    |  |
| mvz.w           | <ea>y,Dx</ea>                              | PST = 0x01, {0x09, source operand}                                    |  |
| neg.l           | Dx                                         | PST = 0x01                                                            |  |
| negx.l          | Dx                                         | PST = 0x01                                                            |  |
| nop             |                                            | PST = 0x01                                                            |  |
| not.l           | Dx                                         | PST = 0x01                                                            |  |
| or.l            | <ea>y,Dx</ea>                              | PST = 0x01, {PST = 0x0B, DD = source operand}                         |  |
| or.l            | Dy, <ea>x</ea>                             | PST = 0x01, {PST = 0x0B, DD = source}, {PST = 0x0B, DD = destination} |  |
| ori.l           | # <data>,Dx</data>                         | PST = 0x01                                                            |  |
| pea.l           | <ea>y</ea>                                 | PST = 0x01, {PST = 0x0B, DD = destination operand}                    |  |

Table continues on the next page...

### Table 50-42. PST/DDATA Specification for User-Mode Instructions (continued)

| Instructio<br>n | Operand<br>Syntax          | PST/DDATA                                                             |
|-----------------|----------------------------|-----------------------------------------------------------------------|
| pulse           |                            | PST = 0x04                                                            |
| rems.l          | <ea>y,Dw:Dx</ea>           | PST = 0x01, {PST = 0x0B, DD = source operand}                         |
| remu.l          | <ea>y,Dw:Dx</ea>           | PST = 0x01, {PST = 0x0B, DD = source operand}                         |
| rts             |                            | PST = 0x01, {PST = 0x0B, DD = source operand},                        |
|                 |                            | PST = 0x05, {PST = 0x0[DE], DD = target address}                      |
| sats.l          | Dx                         | PST = 0x01                                                            |
| scc.b           | Dx                         | PST = 0x01                                                            |
| sub.l           | <ea>y,Dx</ea>              | PST = 0x01, {PST = 0x0B, DD = source operand}                         |
| sub.l           | Dy, <ea>x</ea>             | PST = 0x01, {PST = 0x0B, DD = source}, {PST = 0x0B, DD = destination} |
| suba.l          | <ea>y,Ax</ea>              | PST = 0x01, {PST = 0x0B, DD = source operand}                         |
| subi.l          | # <data>,Dx</data>         | PST = 0x01                                                            |
| subq.l          | # <data>,<ea>x</ea></data> | PST = 0x01, {PST = 0x0B, DD = source}, {PST = 0x0B, DD = destination} |
| subx.l          | Dy,Dx                      | PST = 0x01                                                            |
| swap.w          | Dx                         | PST = 0x01                                                            |
| tas.b           | <ea>x</ea>                 | PST = 0x01, {0x08, source}, {0x08, destination}                       |
| tpf             |                            | PST = 0x01                                                            |
| tpf.l           | # <data></data>            | PST = 0x01                                                            |
| tpf.w           | # <data></data>            | PST = 0x01                                                            |
| trap            | # <data></data>            | $PST = 0x01^{1}$                                                      |
| tst.b           | <ea>x</ea>                 | PST = 0x01, {PST = 0x08, DD = source operand}                         |
| tst.l           | <ea>y</ea>                 | PST = 0x01, {PST = 0x0B, DD = source operand}                         |
| tst.w           | <ea>y</ea>                 | PST = 0x01, {PST = 0x09, DD = source operand}                         |
| unlk            | Ax                         | PST = 0x01, {PST = 0x0B, DD = destination operand}                    |
| wddata.b        | <ea>y</ea>                 | PST = 0x04, {PST = 0x08, DD = source operand}                         |
| wddata.l        | <ea>y</ea>                 | PST = 0x04, {PST = 0x0B, DD = source operand}                         |
| wddata.w        | <ea>y</ea>                 | PST = 0x04, {PST = 0x09, DD = source operand}                         |

1. During normal exception processing, the PSTB is loaded with two successive 0x1C entries indicating the exception processing state. The exception stack write operands, as well as the vector read and target address of the exception handler may also be displayed.

A similar set of PST/DD values is generated in response to an emulator mode excetion. For these events (caused by a debug interrupt or properly-enabled trace exception), the initial PST values are 0x1D, 0x1D and the remaining sequence is equivalent to normal exception processing. The PST/DDATA specification for the reset exception is shown below:

```
Exception Processing:
    PST = 0x1C, 0x1C,
    PST = 0x05,{PST = 0x0[DE],DD = target} // initial PC
```

The initial references at address 0 and 4 are never captured nor displayed because these accesses are treated as instruction fetches. For all types of exception processing, the PST = 0x1C (or 0x1D) value is driven for two trace buffer entries.

2. For JMP and JSR instructions, the optional target instruction address is displayed only for those effective address fields defining variant addressing modes. This includes the following <ea>x values: (An), (d16,An), (d8,An,Xi), (d8,PC,Xi).

Table 50-43 shows the PST/DDATA specification for the MAC instructions if the optional MAC unit is present.

Table 50-43. PST/DDATA Values for Multiply-Accumulate Instructions

| Instruction | Operand Syntax             | PST/DDATA                                   |
|-------------|----------------------------|---------------------------------------------|
| mac.l       | Ry,Rx                      | PST = 0x1                                   |
| mac.l       | Ry,Rx, <ea>y,Rw</ea>       | PST = 0x1, {PST = 0xB, DD = source operand} |
| mac.w       | Ry,Rx                      | PST = 0x1                                   |
| mac.w       | Ry,Rx,ea,Rw                | PST = 0x1, {PST = 0xB, DD = source operand} |
| move.l      | {Ry,# <data>},ACC</data>   | PST = 0x1                                   |
| move.l      | {Ry,# <data>},MACSR</data> | PST = 0x1                                   |
| move.l      | {Ry,# <data>},MASK</data>  | PST = 0x1                                   |
| move.l      | ACC,Rx                     | PST = 0x1                                   |
| move.l      | MACSR,CCR                  | PST = 0x1                                   |
| move.l      | MACSR,Rx                   | PST = 0x1                                   |
| move.l      | MASK,Rx                    | PST = 0x1                                   |
| msac.l      | Ry,Rx                      | PST = 0x1                                   |
| msac.l      | Ry,Rx, <ea>y,Rw</ea>       | PST = 0x1, {PST = 0xB, DD = source},        |
|             |                            | {PST = 0xB, DD = destination}               |
| msac.w      | Ry,Rx                      | PST = 0x1                                   |
| msac.w      | Ry,Rx, <ea>y,Rw</ea>       | PST = 0x1, {PST = 0xB, DD = source},        |
|             |                            | {PST = 0xB, DD = destination}               |

### 50.4.3.4.2 Supervisor Instruction Set

The supervisor instruction set has complete access to the user mode instructions plus the opcodes shown below. The PST/DDATA specification for these opcodes is shown in the following table.

Table 50-44. PST/DDATA Specification for Supervisor-Mode Instructions

| Instruction | Operand Syntax          | PST/DDATA                                                                 |
|-------------|-------------------------|---------------------------------------------------------------------------|
| halt        |                         | PST = 0x1F,                                                               |
|             |                         | PST = 0x1F                                                                |
| move.l      | Ay,USP                  | PST = 0x01                                                                |
| move.l      | USP,Ax                  | PST = 0x01                                                                |
| move.w      | SR,Dx                   | PST = 0x01                                                                |
| move.w      | {Dy,# <data>},SR</data> | PST = 0x01, {PST = 0x03}                                                  |
| movec.l     | Ry,Rc                   | PST = 0x01                                                                |
| rte         |                         | PST = 0x07, {PST = 0x0B, DD = source operand}, {PST = 0x03}, {PST = 0x0B, |
|             |                         | DD = source operand},                                                     |
|             |                         | PST = 0x05, {PST = 0x0[DE], DD = target address}                          |
| stldsr.w    | #imm                    | PST = 0x01, {PST = 0x0B, DD = destination operand, PST = 0x03}            |
| stop        | # <data></data>         | PST = 0x1E,                                                               |
|             |                         | PST = 0x1E                                                                |
| wdebug.l    | <ea>y</ea>              | PST = 0x01, {PST = 0x0B, DD = source, PST = 0x0B, DD = source}            |

The move-to-SR, STLDSR, and RTE instructions include an optional PST = 0x3 value, indicating an entry into user mode.

Similar to the exception processing mode, the stopped state (PST = 0x1E) and the halted state (PST = 0x1F) display this status for two entries when the ColdFire processor enters the given mode.

### 50.4.4 Freescale-Recommended BDM Pinout

Typically, a relatively simple interface pod is used to translate commands from a host computer into commands for the custom serial interface to the single-wire background debug system. Depending on the development tool vendor, this interface pod may use a standard RS-232 serial port, a parallel printer port, or some other type of communications such as a universal serial bus (USB) to communicate between the host PC and the pod. The pod typically connects to the target system with ground, the BKGD pin,  $\overline{\text{RESET}}$ , and sometimes  $V_{DD}$ . An open-drain connection to reset allows the host to force a target system reset, useful to regain control of a lost target system or to control startup of a target system before the on-chip nonvolatile memory has been programmed. Sometimes  $V_{DD}$  can be used to allow the pod to use power from the target system to avoid the need for a separate power supply. However, if the pod is powered separately, it can be connected to a running target system without forcing a target system reset or otherwise disturbing the running application program.



Figure 50-13. Recommended BDM Connector

# Appendix A Release Notes

# A.1 About This Document chapter changes

· Added a definition of the term reserved.

# A.2 Introduction chapter changes

 In "Feature Summary by Package" table, added clarification about using the Comparator to connect an external input to FTM channel 0.

# A.3 Chip Configuration chapter changes

- To the INTC configuration diagram, added peripheral bridge to show register access.
- To the LLWU Inputs table, added other signals that can be muxed to each pin.
- In the MCG section, added new subsection about storing values for trimming oscillator frequency, and removed SIM interface from configuration diagram and table.
- In the OSC section, clarified OSC1 and OSC2 configuration in the table, and removed SIM interface from configuration diagram for OSC2.
- To the Flash Memory Map subsection, added high level program flash memory map.
- In the Erase All Flash Contents and FTFL\_FOPT subsections, corrected mnemonics of registers and bits.
- In the section about the system register file, clarified the file's accessibility via 8-bit and 16-bit accesses.
- In the section of FTM instantiation information, clarified the availability of FTM0 channels on different packages.
- In the section about LPTMR instantiations, clarified the register settings for pin connections and clock options.
- In the I2S/SAI section, clarified that multiple SAI synchronous mode is not supported by the single I2S instance, and added new subsection about clocking options.

# A.4 Memory Map chapter changes

• Added a high level program flash memory map.

# A.5 Clock Distribution chapter changes

- · From main clocking diagram, removed MCGFLLCLK routing to SAICLK
- In Device Clock Summary table, corrected MCGFFCLK information for run mode and VLPR mode
- In USB 48 MHz Clock Source diagram, corrected SIM register reference

# A.6 Reset and Boot chapter changes

In "Stop mode acknowledge error (SACKERR)" section, updated the number of 1 kHz LPO clock cycles.

Corrected and expanded the Multipurpose Clock Generator loss of clock (LOC) section.

# A.7 Power Management chapter changes

In "Module operation in low power modes" table:

- Added RCM to group of System modules.
- · Corrected information about MCG in VLPS mode.

# A.8 Security chapter changes

· No substantial content changes

# A.9 Signal Multiplexing and Signal Descriptions chapter changes

- For PTB4, clarified that ALT2 setting is BKGD/MS and ALT3 setting is not applicable.
- For PTB0, clarified that default and ALT5 setting is IRQ/EZP\_MS\_b.

# A.10 MXC changes

- · Corrected reset values of PTBPF2, PTBPF4, and PTCPF4 registers.
- In the description of the PTBPF2[B4] field, clarified that setting value 0010 is for BKGD/MS and that setting value 0011 is reserved.
- In the description of the PTBPF4[B0] field, clarified that setting value 0101 is for IRQ/EZP\_MS\_b.

# A.11 V1 ColdFire Core changes

In CPUCR section, added note about requirement to maintain memory coherence, and added FHP and HAE bitfields to CPUCR[23] and CPUCR[26].

# A.12 EMAC changes

No substantial content changes

# A.13 SIM changes

- Simplified the SDIDL register by presenting its content as a single bitfield.
- Updated bitfields of SPCR register.
- · Corrected bit range in bitfield name of UIDL3 register.

# A.14 Crossbar switch chapter changes

· Updated Arbitration and Priority Elevation sections.

# A.15 INTC V1 chapter changes

· No substantial content changes

# A.16 LLWU changes

· No substantial content changes

### A.17 SMC changes

· No substantial content changes

# A.18 PMC changes

No substantial content changes

# A.19 DMA Controller changes

Updated register information:

- Clarified that DCR[24:23] is a read/write field, and in the field's description added a Caution notice emphasizing that its
  value must always remain zero.
- In the description of the DCR[ERQ] bit, corrected references to other bit and register mnemonics.
- In the DSR\_BSR register, clarified that the CE, BES, and BED bits are read-only, and clarified how the BES and BED bits are reset.
- In the diagram of the DSR\_BSR register, illustrated that the DONE bit is cleared by writing 1 to it.

# A.20 MCG changes

 In features section, updated "External clock monitor with reset request capability" to "External clock monitor with reset request capability to check for external clock failure when running in FBE, PEE, BLPE or FEE modes."

# A.21 OSC changes

- Updated OSC External Clock Connections diagram and added a note before this diagram.
- · Added 'Low Power Modes Operation' section.

# A.22 FMC changes

- Throughout the content, clarified that configuration options such as caching and buffering are available only for program flash memory in bank 0.
- In "Memory map and register descriptions" section, added note about requirement to maintain memory coherence.

# A.23 FTFL changes

· No substantial content changes

# A.24 FlexBus changes

- Added Initialization/Application Information section
- Updated CSCR[SWS] bitfield description
- Added FB\_TS signal throughout as inverse of FB\_ALE

# A.25 EzPort changes

No substantial content changes

### A.26 CAU changes

· No substantial content changes

# A.27 RNGB changes

No substantial content changes

# A.28 CRC changes

Corrected CTRL register's width from 32 bits to 16 bits.

# A.29 ADC changes

- In "Short conversion time configuration" section, corrected total time of sample short conversion to 1.45 µs.
- For SC1n[ADCH], simplified and corrected descriptions for setting values 10110b and 10111b.
- Added warnings not to change the reset value of the SC1n[5] bit and not to set the CFG1[MODE] field to 11b.
- For SC1n[ADCH], corrected module-level descriptions for setting values 00000b to 00011b.
- Corrected register memory map: added PG register and removed minus-side general calibration value registers.
- In the "Calibration function" section, removed references to minus-side registers, and added CLPD to the description of the calibration procedure.

# A.30 CMP changes

Updated Introduction and CMP Functional Description sections.

#### **DAC** changes

Updated SCR[DMAEN] bit field values.

Updated CR0[HYSTCTR] bit field descriptions.

Updated 'CMP, DAC and ANMUX Blocks Diagram' and 'Features' section.

- Clarified 'Functional Description', 'Continuous Mode (2A and 2B)', and 'Sampled, Non-Filtered Mode (3A and 3B)' sections.
- Clarified 'Low-Leakage Mode Operation' section and Windowed Mode Operation waveforms.

# A.31 DAC changes

No substantial content changes

# A.32 VREF changes

- Updated SC[REGEN] bit field description.
- · Added information about the TRM register and its TRIM bitfield.

# A.33 PDB changes

No substantial content changes

# A.34 MTIM changes

· No substantial content changes

# A.35 LPTMR changes

- Revised the descriptions of the CSR[TPS] and PSR[PCS] fields; to each, added a reference to the module's Chip Configuration information for connection details.
- Simplified the "LPTMR clocking" section's content.

# A.36 CMT changes

· No substantial content changes

# A.37 FTM changes

- · Added illustration of the FTM behavior in the beginning of section "Reset Overview".
- Updated the figure Dual Edge Capture One-Shot Mode to Measure of the Period Between Two Consecutive Rising Edges.
- Corrected the second bitfield value in the description of settings for the COMBINEn[DECAPEN] bit.
- · Added the equation for calculating the deadtime insert value in the description of the DEADTIME[DTVAL] field.
- · Corrected the second bitfield value in the description of settings for the EXTTRIG[TRIGF] bit.
- Clarified the spelled-out names of the FLTFILTER and FLTCTRL registers.
- Whereas FTM0 and FTM1 previously had separate chapters, both are now documented in a single, combined FTM chapter.

# A.38 SPI chapter changes

- Whereas SPI0 and SPI1 previously had separate chapters, both are now documented in a single, combined SPI chapter.
- In descriptions of the C3 register's TNEARIEN and RNFULLIEN bits, removed references to the SPTIE and SPIE bits, respectively.
- In "Pseudo-Code Example" section, corrected references to some register bits.

# A.39 USB changes

No substantial content changes

# A.40 USBDCD changes

No substantial content changes

# A.41 USBVREG changes

No substantial content changes

# A.42 I2C changes

No substantial content changes

# A.43 UART changes

· Infrared support references were removed.

# A.44 I2S/SAI changes

- Revised the descriptions of the MCR[MICS] and RCR2[CLKMODE] fields; to each, added a reference to the module's Chip Configuration information for connection details.
- Clarified information in the following sections:
  - Audio Master Clock
  - · Bit Clock
  - Synchronous Mode
  - · Multiple SAI Synchronous Mode
  - Frame sync configuration

# A.45 RGPIO changes

· No substantial content changes

# A.46 EGPIO changes

· Added a new, final Reset section.

## A.47 TSI changes

No substantial content changes

# A.48 IRQ changes

· No substantial content changes

### A.49 Debug changes

Clarified FILL\_MEM.sz, FILL\_MEM.sz\_WS section.

#### How to Reach Us:

#### **Home Page:**

www.freescale.com

### Web Support:

http://www.freescale.com/support

### **USA/Europe or Locations Not Listed:**

Freescale Semiconductor Technical Information Center, EL516 2100 East Elliot Road Tempe, Arizona 85284 +1-800-521-6274 or +1-480-768-2130 www.freescale.com/support

#### **Europe, Middle East, and Africa:**

Freescale Halbleiter Deutschland GmbH **Technical Information Center** Schatzbogen 7 81829 Muenchen, Germany +44 1296 380 456 (English) +46 8 52200080 (English) +49 89 92103 559 (German) +33 1 69 35 48 48 (French)

#### Japan:

Freescale Semiconductor Japan Ltd. Headquarters ARCO Tower 15F 1-8-1, Shimo-Meguro, Meguro-ku, Tokyo 153-0064 Japan 0120 191014 or +81 3 5437 9125 support.japan@freescale.com

www.freescale.com/support

### Asia/Pacific:

Freescale Semiconductor China Ltd. Exchange Building 23F No. 118 Jianguo Road Chaoyang District Beijing 100022 China +86 10 5879 8000 support.asia@freescale.com

#### For Literature Requests Only:

Freescale Semiconductor Literature Distribution Center 1-800-441-2447 or +1-303-675-2140

Fax: +1-303-675-2150

LDCForFreescaleSemiconductor@hibbertgroup.com

Information in this document is provided solely to enable system and sofware implementers to use Freescale Semiconductors products. There are no express or implied copyright licenses granted hereunder to design or fabricate any integrated circuits or integrated circuits based on the information in this document.

Freescale Semiconductor reserves the right to make changes without further notice to any products herein. Freescale Semiconductor makes no warranty, representation, or guarantee regarding the suitability of its products for any particular purpose, nor does Freescale Semiconductor assume any liability arising out of the application or use of any product or circuit, and specifically disclaims any liability, including without limitation consequential or incidental damages. "Typical" parameters that may be provided in Freescale Semiconductor data sheets and/or specifications can and do vary in different applications and actual performance may vary over time. All operating parameters, including "Typicals", must be validated for each customer application by customer's technical experts. Freescale Semiconductor does not convey any license under its patent rights nor the rights of others. Freescale Semiconductor products are not designed, intended, or authorized for use as components in systems intended for surgical implant into the body, or other applications intended to support or sustain life, or for any other application in which failure of the Freescale Semiconductor product could create a situation where personal injury or death may occur. Should Buyer purchase or use Freescale Semiconductor products for any such unintended or unauthorized application, Buyer shall indemnify Freescale Semiconductor and its officers, employees, subsidiaries, affiliates, and distributors harmless against all claims, costs, damages, and expenses, and reasonable attorney fees arising out of, directly or indirectly, any claim of personal injury or death associated with such unintended or unauthorized use, even if such claims alleges that Freescale Semiconductor was negligent regarding the design or manufacture of

RoHS-compliant and/or Pb-free versions of Freescale products have the functionality and electrical characteristics as their non-RoHS-complaint and/or non-Pb-free counterparts. For further information, see http://www.freescale.com or contact your Freescale

For information on Freescale's Environmental Products program, go to http://www.freescale.com/epp.

Freescale™ and the Freescale logo are trademarks of Freescale Semiconductor, Inc. All other product or service names are the property of their respective owners.

© 2010-2011 Freescale Semiconductor, Inc.

Document Number: MCF51JF128RM

Rev. 2, 03/2011

**Preliminary** 

