## **KM Family Reference Manual** Supports: MKM14Z64CHH5, MKM14Z128CHH5, MKM33Z64CLH5, MKM33Z128CLH5, MKM33Z64CLL5, MKM33Z128CLL5, MKM34Z128CLL5 Document Number: MKMxxZxxCxx5RM Rev. 5, Oct 2013 ## **Contents** | Sec | etion number Title | | Page | |-----|-----------------------|---------------------------------|------| | | | Chapter 1 About This Document | | | 1.1 | Overvie | ew | 39 | | | 1.1.1 | Purpose | 39 | | | 1.1.2 | Audience | 39 | | 1.2 | Conven | tions | 39 | | | 1.2.1 | Numbering systems. | 39 | | | 1.2.2 | Typographic notation | 40 | | | 1.2.3 | Special terms | 40 | | | | Chapter 2<br>Introduction | | | 2.1 | KM fan | nily introduction | 41 | | 2.2 | Detailed | d block diagram | 41 | | 2.3 | KM fea | ture set. | | | 2.4 | Device | configuration | 45 | | 2.5 | Modules on the device | | 47 | | | 2.5.1 | Platform modules | 47 | | | 2.5.2 | System modules | | | | 2.5.3 | Clock | 50 | | | 2.5.4 | Security modules | 50 | | | 2.5.5 | Analog modules | 51 | | | 2.5.6 | Timer modules | | | | 2.5.7 | Communication interfaces. | 53 | | | 2.5.8 | Human-machine interfaces. | 55 | | | | Chapter 3<br>Chip Configuration | | | 3.1 | Introduc | ction | 57 | | Sec | tion nu | umber Title | Page | | |-----|--------------|----------------------------------------------------------------|------|--| | 3.2 | Core modules | | 57 | | | | 3.2.1 | ARM Cortex-M0+ Core Configuration | 57 | | | | 3.2.2 | ARM Cortex M0+ core | 58 | | | | 3.2.3 | Buses, interconnects, and interfaces. | 59 | | | | 3.2.4 | Debug facilities | 59 | | | | 3.2.5 | Interrupt priority levels | 59 | | | | 3.2.6 | Performance targets | 60 | | | | 3.2.7 | Nested Vectored Interrupt Controller (NVIC) configuration | 60 | | | | 3.2.8 | Asynchronous Wake-up Interrupt Controller (AWIC) Configuration | 62 | | | 3.3 | System | 64 | | | | | 3.3.1 | SIM Configuration. | 64 | | | | 3.3.2 | PMC Configuration. | 64 | | | | 3.3.3 | Low-Leakage Wake-up Unit (LLWU) Configuration | 65 | | | | 3.3.4 | Crossbar-Light Switch Configuration. | 67 | | | | 3.3.5 | DMA request multiplexer (DMA MUX) configuration | 69 | | | | 3.3.6 | External Watchdog Monitor (EWM) configuration | 71 | | | | 3.3.7 | Watchdog Configuration. | 72 | | | | 3.3.8 | Inter-Peripheral Crossbar Switch (XBAR) Configuration | 73 | | | 3.4 | Memor | 77 | | | | | 3.4.1 | RAM sizes. | 77 | | | | 3.4.2 | Flash Memory Sizes | 77 | | | 3.5 | Clock N | Clock Modules | | | | | 3.5.1 | RTC OSC configuration. | 77 | | | 3.6 | Security | y | 78 | | | | 3.6.1 | CRC Configuration | 78 | | | Sec | tion nu | mber Title | Page | |------|-----------|--------------------------------------------------|------| | | 3.6.2 | RNG Configuration | 79 | | 3.7 | Analog | | 80 | | | 3.7.1 | 16-bit SAR ADC | 80 | | | 3.7.2 | Analog Front End (AFE) configuration | | | | 3.7.3 | CMP Configuration | | | | 3.7.4 | VREF Configuration | | | 3.8 | Timers | | 92 | | | 3.8.1 | Independent Real Time Clock (iRTC) configuration | 92 | | | 3.8.2 | TMR Configuration. | 94 | | | 3.8.3 | Low-power timer (LPTMR)configuration | 95 | | | 3.8.4 | PIT Configuration | 97 | | 3.9 | Commu | 98 | | | | 3.9.1 | Serial Peripheral Interface (SPI) Configuration | 98 | | | 3.9.2 | UART configuration | 99 | | | 3.9.3 | I2C Configuration | 101 | | 3.10 | Human | machine interface | 103 | | | 3.10.1 | eGPIO controller | 103 | | | 3.10.2 | Segment LCD controller | 106 | | | | Chapter 4<br>System Memory Map | | | 4.1 | Introduc | ction | | | 4.2 | System | Memory Map | | | 4.3 | Flash M | emory Map | 110 | | 4.4 | SRAM 1 | memory map | 110 | | 4.5 | Peripher | ral bridge (AIPS-Lite) memory map | 111 | | 4.6 | AIPS pe | eripheral slot assignment | | | 4.7 | Private 1 | peripherals | 116 | | 4.8 | Private 1 | Peripheral Bus (PPB) memory map | 116 | **Title** Section number **Page Chapter 5 Clock Distribution** 5.1 Introduction 119 5.2 5.3 5.3.1 5.4 5.4.1 5.4.2 5.4.3 5.5 Clock Gating 125 5.6 **Chapter 6 Reset and Boot** 6.1 System resets and sources. 129 6.1.1 6.2 6.2.1 6.2.2 6.2.3 6.2.4 Chapter 7 **Power Management** 7.1 Introduction 137 7.2 7.3 7.4 7.5 7.6 | Section number | | umber Title | Page | |----------------|-------------------------------------------------|----------------------------------------------------------------------|------| | 7.7 | Clockir | ng modes | 144 | | | 7.7.1 | Partial Stop | 144 | | | 7.7.2 | DMA Wakeup | 145 | | | 7.7.3 | Compute Operation. | 146 | | | 7.7.4 | Peripheral Doze | 147 | | | 7.7.5 | Clock gating | 148 | | | | Chapter 8 Security | | | 8.1 | Introdu | oction | 149 | | 8.2 | Externa | al Watchdog Monitor | 149 | | | 8.2.1 | EWM Counter | 149 | | | 8.2.2 | EWM_out Signal | 150 | | | 8.2.3 | EWM_In Signal. | 150 | | 8.3 | Robust Watchdog for Improved System Reliability | | 151 | | | 8.3.1 | 32-bit programmable timeout Period | 151 | | | 8.3.2 | Independent Clock Source. | 152 | | | 8.3.3 | Write Protection. | 152 | | | 8.3.4 | Robust Refresh Mechanism. | 153 | | | 8.3.5 | Windowed Refresh | 154 | | | 8.3.6 | Fast Response to Code Runaway | 154 | | 8.4 | Watch | log configuration | 156 | | 8.5 | iRTC V | Vrite Protect State Machine. | 156 | | 8.6 | iRTC T | Tamper Detection Mechanism | 157 | | | 8.6.1 | Internal Tamper Condition 1: Battery removed when MCU is powered OFF | 157 | | | 8.6.2 | Internal Tamper Condition 2: Battery removed when MCU is powered ON | 157 | | | 8.6.3 | External Tamper Condition: Off Chip Tamper Indication | 158 | | | 8.6.4 | Tamper Detection Flow. | 158 | | | 8.6.5 | Active Tamper Detection | 159 | | Section number | | ımber Title | Page | |----------------|-------------------|-----------------------------------------------|------| | | | Chapter 9<br>Debug | | | 9.1 | Introduc | ction | 161 | | 9.2 | Debug I | Port Pin Descriptions | 161 | | 9.3 | SWD st | atus and control registers. | 162 | | | 9.3.1 | MDM-AP Control Register | 163 | | | 9.3.2 | MDM-AP Status Register | 164 | | 9.4 | Debug I | Resets | 166 | | 9.5 | Micro T | Frace Buffer (MTB) | 166 | | 9.6 | Debug i | in Low Power Modes | 167 | | 9.7 | Debug & | & Security | 167 | | | | Chapter 10 Pinouts and Packaging | | | 10.1 | Package | e Types | 169 | | 10.2 | Photon | Signal Multiplexing and Pin Assignments | 169 | | 10.3 | KM Family Pinouts | | 172 | | | 10.3.1 | 100-pin LQFP | 172 | | | 10.3.2 | 64-pin LQFP | 173 | | | 10.3.3 | 44-pin LGA | 174 | | | | Chapter 11 Port Control and Interrupts (PORT) | | | 11.1 | Introduc | ction | 177 | | 11.2 | Overvie | ew | 177 | | | 11.2.1 | Features | 177 | | | 11.2.2 | Modes of operation | 178 | | 11.3 | External | l signal description | 179 | | 11.4 | Detailed | d signal description | 179 | | 11.5 | Memory | y map and register definition | 179 | | | 11.5.1 | Pin Control Register n (PORTx_PCRn) | 184 | | | 11.5.2 | Global Pin Control Low Register (PORTx_GPCLR) | 186 | | | | 1/11 F 11 B / 11 B F B 1 2010 | | | Sec | tion nur | on number Title | | |------|-----------|----------------------------------------------------|-----| | | 11.5.3 | Global Pin Control High Register (PORTx_GPCHR) | 187 | | | 11.5.4 | 187 | | | | 11.5.5 | Digital Filter Enable Register (PORTx_DFER) | 188 | | | 11.5.6 | Digital Filter Clock Register (PORTx_DFCR) | 189 | | | 11.5.7 | Digital Filter Width Register (PORTx_DFWR) | 189 | | 11.6 | Function | al description | 190 | | | 11.6.1 | Pin control | 190 | | | 11.6.2 | Global pin control. | 191 | | | 11.6.3 | External interrupts. | 191 | | | 11.6.4 | Digital filter | 192 | | | | Chapter 12 System Integration Module (SIM) | 400 | | 12.1 | | tion | | | 12.2 | Features. | | | | 12.3 | · | map and register definition | | | | 12.3.1 | System Options Register 1 (SIM_SOPT1) | | | | 12.3.2 | SOPT1 Configuration Register (SIM_SOPT1_CFG) | | | | 12.3.3 | System Control Register (SIM_CTRL_REG) | | | | 12.3.4 | System Device Identification Register (SIM_SDID) | | | | 12.3.5 | System Clock Gating Control Register 4 (SIM_SCGC4) | | | | 12.3.6 | System Clock Gating Control Register 5 (SIM_SCGC5) | | | | 12.3.7 | System Clock Gating Control Register 6 (SIM_SCGC6) | | | | 12.3.8 | System Clock Gating Control Register 7 (SIM_SCGC7) | | | | 12.3.9 | System Clock Divider Register 1 (SIM_CLKDIV1) | | | | 12.3.10 | Flash Configuration Register 1 (SIM_FCFG1) | | | | 12.3.11 | Flash Configuration Register 2 (SIM_FCFG2) | | | | 12.3.12 | Unique Identification Register 0 (SIM_UID0). | | | | 12.3.13 | Unique Identification Register 1 (SIM_UID1) | | | | 12.3.14 | Unique Identification Register 2 (SIM_UID2) | 216 | | Sect | ion nui | mber Title | Page | |------|----------|---------------------------------------------------------|------| | | 12.3.15 | Unique Identification Register 3 (SIM_UID3) | 217 | | | 12.3.16 | Miscellaneous Control Register (SIM_MISC_CTL) | 217 | | 12.4 | Function | al description | 221 | | | | Chapter 13<br>Miscellaneous Control Module (MCM) | | | 13.1 | Introduc | tion | 223 | | | 13.1.1 | Features | 223 | | 13.2 | Memory | map/register descriptions | 223 | | | 13.2.1 | Crossbar Switch (AXBS) Slave Configuration (MCM_PLASC) | 224 | | | 13.2.2 | Crossbar Switch (AXBS) Master Configuration (MCM_PLAMC) | 225 | | | 13.2.3 | Platform Control Register (MCM_PLACR) | 225 | | | 13.2.4 | Process ID register (MCM_PID) | 228 | | | 13.2.5 | Compute Operation Control Register (MCM_CPO) | 229 | | | 13.2.6 | Master Attribute Configuration Register (MCM_MATCRn) | 230 | | | | Chapter 14 Reset Control Module (RCM) | | | 14.1 | Introduc | tion | 233 | | 14.2 | Reset me | emory map and register descriptions. | 233 | | | 14.2.1 | System Reset Status Register 0 (RCM_SRS0) | 234 | | | 14.2.2 | System Reset Status Register 1 (RCM_SRS1) | 235 | | | 14.2.3 | Reset Pin Filter Control register (RCM_RPFC) | 236 | | | 14.2.4 | Reset Pin Filter Width register (RCM_RPFW) | 237 | | | | Chapter 15 System Mode Controller (SMC) | | | 15.1 | Introduc | tion | 239 | | 15.2 | Modes o | f operation | 239 | | 15.3 | Memory | map and register descriptions | 241 | | | 15.3.1 | Power Mode Protection register (SMC_PMPROT) | 242 | | | 15.3.2 | Power Mode Control register (SMC_PMCTRL) | 243 | | | 15.3.3 | Stop Control Register (SMC_STOPCTRL) | 244 | | | | | | | Sec | tion nu | mber Title | Page | |------|----------|-------------------------------------------------------|------| | | 15.3.4 | Power Mode Status register (SMC_PMSTAT) | 245 | | 15.4 | Function | nal description | 246 | | | 15.4.1 | Power mode transitions | 246 | | | 15.4.2 | Power mode entry/exit sequencing | 249 | | | 15.4.3 | Run modes | 252 | | | 15.4.4 | Wait modes | 253 | | | 15.4.5 | Stop modes | 254 | | | 15.4.6 | Debug in low power modes | 256 | | | | Chapter 16<br>Inter-Peripheral Crossbar Switch (XBAR) | | | 16.1 | Introduc | tion | 259 | | | 16.1.1 | Overview | 259 | | | 16.1.2 | Features | 259 | | | 16.1.3 | Modes of Operation. | 260 | | | 16.1.4 | Block Diagram | 260 | | 16.2 | Signal D | Descriptions | 261 | | | 16.2.1 | XBAR_OUT[0:NUM_OUT-1] - MUX Outputs | 261 | | | 16.2.2 | XBAR_IN[0:NUM_IN-1] - MUX Inputs | 261 | | | 16.2.3 | DMA_REQ[n] - DMA Request Output(s) | 261 | | | 16.2.4 | DMA_ACK[n] - DMA Acknowledge Input(s) | 261 | | | 16.2.5 | INT_REQ[n] - Interrupt Request Output(s) | 262 | | 16.3 | Memory | Map and Register Descriptions | 262 | | | 16.3.1 | Crossbar Select Register 0 (XBAR_SEL0) | 263 | | | 16.3.2 | Crossbar Select Register 1 (XBAR_SEL1) | 263 | | | 16.3.3 | Crossbar Select Register 2 (XBAR_SEL2) | 264 | | | 16.3.4 | Crossbar Select Register 3 (XBAR_SEL3) | 264 | | | 16.3.5 | Crossbar Select Register 4 (XBAR_SEL4) | 265 | | | 16.3.6 | Crossbar Select Register 5 (XBAR_SEL5) | 265 | | | 16.3.7 | Crossbar Select Register 6 (XBAR_SEL6) | 266 | | Sect | Section number Title | | Page | |------|----------------------|----------------------------------------------|------| | | 16.3.8 | 266 | | | | 16.3.9 | Crossbar Select Register 8 (XBAR_SEL8) | 267 | | | 16.3.10 | Crossbar Select Register 9 (XBAR_SEL9) | | | | 16.3.11 | Crossbar Select Register 10 (XBAR_SEL10) | | | | 16.3.12 | Crossbar Select Register 11 (XBAR_SEL11) | | | | 16.3.13 | Crossbar Select Register 12 (XBAR_SEL12) | 269 | | | 16.3.14 | Crossbar Select Register 13 (XBAR_SEL13) | 269 | | | 16.3.15 | Crossbar Select Register 14 (XBAR_SEL14) | 270 | | | 16.3.16 | Crossbar Select Register 15 (XBAR_SEL15) | 270 | | | 16.3.17 | Crossbar Select Register 16 (XBAR_SEL16) | 271 | | | 16.3.18 | Crossbar Control Register 0 (XBAR_CTRL0) | 271 | | 16.4 | Function | nal Description | 272 | | | 16.4.1 | General | 272 | | | 16.4.2 | Functional Mode | 273 | | 16.5 | Resets | | 273 | | 16.6 | Clocks | | 273 | | 16.7 | Interrupt | ss and DMA Requests | 273 | | | | Chapter 17<br>Low-Leakage Wakeup Unit (LLWU) | | | 17.1 | Introduc | tion | 275 | | | 17.1.1 | Features | 275 | | | 17.1.2 | Modes of operation | 276 | | | 17.1.3 | Block diagram | 276 | | 17.2 | LLWU s | signal descriptions | 277 | | 17.3 | Memory | map/register definition. | 278 | | | 17.3.1 | LLWU Pin Enable 1 register (LLWU_PE1) | 279 | | | 17.3.2 | LLWU Pin Enable 2 register (LLWU_PE2) | | | | 17.3.3 | LLWU Pin Enable 3 register (LLWU_PE3) | 281 | | | 17.3.4 | LLWU Pin Enable 4 register (LLWU_PE4) | 282 | | Sec | tion nui | mber Title | Page | |------|----------|----------------------------------------------------------|------| | | 17.3.5 | LLWU Module Enable register (LLWU_ME) | 283 | | | 17.3.6 | LLWU Flag 1 register (LLWU_F1) | 285 | | | 17.3.7 | LLWU Flag 2 register (LLWU_F2) | 286 | | | 17.3.8 | LLWU Flag 3 register (LLWU_F3) | 288 | | | 17.3.9 | LLWU Pin Filter 1 register (LLWU_FILT1) | 290 | | | 17.3.10 | LLWU Pin Filter 2 register (LLWU_FILT2) | 291 | | 17.4 | Function | nal description | 292 | | | 17.4.1 | VLLS modes | 292 | | | 17.4.2 | Initialization | 292 | | | | Chapter 18 DMA Controller Module | | | 18.1 | Introduc | 295 | | | | 18.1.1 | Overview | 295 | | | 18.1.2 | Features | 296 | | 18.2 | DMA Tr | ransfer Overview | 297 | | 18.3 | Memory | 298 | | | | 18.3.1 | Source Address Register (DMA_SARn) | 300 | | | 18.3.2 | Destination Address Register (DMA_DARn) | 301 | | | 18.3.3 | DMA Status Register / Byte Count Register (DMA_DSR_BCRn) | 301 | | | 18.3.4 | DMA Control Register (DMA_DCRn) | 304 | | 18.4 | Function | nal Description. | 308 | | | 18.4.1 | Transfer requests (Cycle-Steal and Continuous modes) | 309 | | | 18.4.2 | Channel initialization and startup. | 309 | | | 18.4.3 | Dual-Address Data Transfer Mode | 312 | | | 18.4.4 | Advanced Data Transfer Controls: Auto-Alignment | 312 | | | 18.4.5 | Termination | 313 | **Title** Section number **Page** Chapter 19 **Direct Memory Access Multiplexer (DMAMUX)** 19.1 19.1.1 19.1.2 Features 316 19.1.3 19.2 19.3 19.3.1 19.4 19.4.1 19.4.2 19.4.3 19.5 19.5.1 19.5.2 Chapter 20 **Peripheral Bridge (AIPS-Lite)** 20.1 Introduction 327 20.1.1 Features 327 20.1.2 20.2 20.2.1 20.2.2 20.3.1 Chapter 21 **Memory Protection Unit (MPU)** 21.1 | Sect | tion nu | mber Title | Page | |------|--------------------------------|---------------------------------------------------------------|------| | 21.2 | Overvie | :w | 337 | | | 21.2.1 | Block diagram. | 337 | | | 21.2.2 | Features | 338 | | 21.3 | Memory map/register definition | | 339 | | | 21.3.1 | Control/Error Status Register (MPU_CESR) | 341 | | | 21.3.2 | Error Address Register, slave port n (MPU_EARn) | 343 | | | 21.3.3 | Error Detail Register, slave port n (MPU_EDRn) | 344 | | | 21.3.4 | Region Descriptor n, Word 0 (MPU_RGDn_WORD0) | 345 | | | 21.3.5 | Region Descriptor n, Word 1 (MPU_RGDn_WORD1) | 345 | | | 21.3.6 | Region Descriptor n, Word 2 (MPU_RGDn_WORD2) | 346 | | | 21.3.7 | Region Descriptor n, Word 3 (MPU_RGDn_WORD3) | 349 | | | 21.3.8 | Region Descriptor Alternate Access Control n (MPU_RGDAACn) | 350 | | 21.4 | Function | 352 | | | | 21.4.1 | Access evaluation macro. | 352 | | | 21.4.2 | Putting it all together and error terminations. | 354 | | | 21.4.3 | Power management | 354 | | 21.5 | Initializ | ation information | 355 | | 21.6 | Applica | tion information | 355 | | | | Chapter 22 Power Management Controller (PMC) | | | 22.1 | Introduc | ction | 359 | | 22.2 | Features | S | 359 | | 22.3 | Low-vo | ltage detect (LVD) system | 359 | | | 22.3.1 | LVD reset operation | 360 | | | 22.3.2 | LVD interrupt operation | 360 | | | 22.3.3 | Low-voltage warning (LVW) interrupt operation | 360 | | 22.4 | I/O rete | ntion | 361 | | 22.5 | Memory | y map and register descriptions | 361 | | | 22.5.1 | Low Voltage Detect Status And Control 1 register (PMC_LVDSC1) | 362 | | Sec | tion nu | mber Title | Page | |------|------------------------------------|---------------------------------------------------------------|------| | | 22.5.2 | Low Voltage Detect Status And Control 2 register (PMC_LVDSC2) | 363 | | | 22.5.3 | Regulator Status And Control register (PMC_REGSC) | 364 | | | | Chapter 23<br>Watchdog Timer (WDOG) | | | 23.1 | Introduc | tion | 367 | | 23.2 | Features | | 367 | | 23.3 | Function | 369 | | | | 23.3.1 | Unlocking and updating the watchdog | 370 | | | 23.3.2 | Watchdog configuration time (WCT) | 371 | | | 23.3.3 | Refreshing the watchdog | 372 | | | 23.3.4 | Windowed mode of operation. | 372 | | | 23.3.5 | Watchdog disabled mode of operation. | 372 | | | 23.3.6 | Low-power modes of operation | 373 | | | 23.3.7 | Low-power and Debug modes of operation | 373 | | 23.4 | Testing | the watchdog | 374 | | | 23.4.1 | Quick test | 374 | | | 23.4.2 | Byte test | 375 | | 23.5 | Backup | reset generator | 376 | | 23.6 | Generate | ed resets and interrupts | 376 | | 23.7 | Memory map and register definition | | 377 | | | 23.7.1 | Watchdog Status and Control Register High (WDOG_STCTRLH) | 378 | | | 23.7.2 | Watchdog Status and Control Register Low (WDOG_STCTRLL) | 379 | | | 23.7.3 | Watchdog Time-out Value Register High (WDOG_TOVALH) | 380 | | | 23.7.4 | Watchdog Time-out Value Register Low (WDOG_TOVALL) | 380 | | | 23.7.5 | Watchdog Window Register High (WDOG_WINH) | 381 | | | 23.7.6 | Watchdog Window Register Low (WDOG_WINL) | 381 | | | 23.7.7 | Watchdog Refresh register (WDOG_REFRESH) | 382 | | | 23.7.8 | Watchdog Unlock register (WDOG_UNLOCK) | 382 | | | 23.7.9 | Watchdog Timer Output Register High (WDOG_TMROUTH) | 382 | | | | | | | Sec | Section number Title | | Page | | |------|----------------------|---------------------------------------------------|------|--| | | 23.7.10 | Watchdog Timer Output Register Low (WDOG_TMROUTL) | 383 | | | | 23.7.11 | Watchdog Reset Count register (WDOG_RSTCNT) | 383 | | | | 23.7.12 | Watchdog Prescaler register (WDOG_PRESC) | 384 | | | 23.8 | Watchdo | og operation with 8-bit access | 384 | | | | 23.8.1 | General guideline | 384 | | | | 23.8.2 | Refresh and unlock operations with 8-bit access | 384 | | | 23.9 | Restricti | ons on watchdog operation | 385 | | | | | Chapter 24 External Watchdog Monitor (EWM) | | | | 24.1 | Introduc | tion | 389 | | | | 24.1.1 | Features | 389 | | | | 24.1.2 | Modes of Operation | 390 | | | | 24.1.3 | Block Diagram | 391 | | | 24.2 | EWM Si | ignal Descriptions | 392 | | | 24.3 | Memory | 392 | | | | | 24.3.1 | Control Register (EWM_CTRL) | 392 | | | | 24.3.2 | Service Register (EWM_SERV) | 393 | | | | 24.3.3 | Compare Low Register (EWM_CMPL) | 393 | | | | 24.3.4 | Compare High Register (EWM_CMPH) | 394 | | | 24.4 | Function | nal Description | 395 | | | | 24.4.1 | The EWM_out Signal | 395 | | | | 24.4.2 | The EWM_in Signal | 396 | | | | 24.4.3 | EWM Counter | 396 | | | | 24.4.4 | EWM Compare Registers | 396 | | | | 24.4.5 | EWM Refresh Mechanism. | 397 | | | | 24.4.6 | EWM Interrupt | 397 | | | | | Chapter 25 Analog Front End (AFE) | | | | 25.1 | Introduc | tion | 399 | | | Sec | tion nur | mber Title | Page | |------|----------|-----------------------------------------------|------| | 25.2 | Features | | 399 | | 25.3 | Block Di | agram | 400 | | 25.4 | AFE Clo | cking | 402 | | 25.5 | OSR Sel | ect | 403 | | 25.6 | Analog ( | Gain Select | 403 | | 25.7 | Memory | Map and Register Definition | 403 | | | 25.7.1 | Channel Configuration Register (AFE_CH0_CFR) | 404 | | | 25.7.2 | Channel1 Configuration Register (AFE_CH1_CFR) | 406 | | | 25.7.3 | Channel2 Configuration Register (AFE_CH2_CFR) | 409 | | | 25.7.4 | Channel3 Configuration Register (AFE_CH3_CFR) | 411 | | | 25.7.5 | Control Register (AFE_CR) | 413 | | | 25.7.6 | Clock Configuration Register (AFE_CKR) | 415 | | | 25.7.7 | DMA and Interrupt Register (AFE_DI) | 416 | | | 25.7.8 | Channel0 Delay Register (AFE_CH0_DR) | 417 | | | 25.7.9 | Channel1 Delay Register (AFE_CH1_DR) | 417 | | | 25.7.10 | Channel2 Delay Register (AFE_CH2_DR) | 418 | | | 25.7.11 | Channel3 Delay Register (AFE_CH3_DR) | 418 | | | 25.7.12 | Channel0 Result Register (AFE_CH0_RR) | 419 | | | 25.7.13 | Channel1 Result Register (AFE_CH1_RR) | 419 | | | 25.7.14 | Channel2 Result Register (AFE_CH2_RR) | 420 | | | 25.7.15 | Channel3 Result Register (AFE_CH3_RR) | 420 | | | 25.7.16 | Status Register (AFE_SR) | 422 | | 25.8 | Power M | Iodes | 424 | | | 25.8.1 | Normal Run Mode | 424 | | | 25.8.2 | Wait Mode | 424 | | | 25.8.3 | Low Power Run Mode | 424 | | | 25.8.4 | STOP Mode | 424 | | 25.9 | Function | al Description | 425 | | | 25.9.1 | Start Up | 425 | | Sect | ion nui | mber Title | Page | |-------|--------------------------------------|-------------------------------------------------------------|------| | | 25.9.2 | Conversion Control | 425 | | | 25.9.3 | Modes of Conversion. | 429 | | | 25.9.4 | Independent Control for Conversion. | 433 | | 25.10 | Decimati | ion Filter | 434 | | | 25.10.1 | Sampling Phase Control | 434 | | | 25.10.2 | Frequency response | 434 | | 25.11 | Modulate | or Bypass Mode | 435 | | | | Chapter 26 Analog-to-Digital Converter (ADC) | | | 26.1 | Introduct | tion | 437 | | | 26.1.1 | Features | 437 | | | 26.1.2 | Block diagram | 438 | | 26.2 | ADC signal descriptions | | 439 | | | 26.2.1 | Analog Power (VDDA) | 440 | | | 26.2.2 | Analog Ground (VSSA) | 440 | | | 26.2.3 | Analog Channel Inputs (ADx) | 440 | | 26.3 | Memory map and register definitions. | | | | | 26.3.1 | ADC Status and Control Registers 1 (ADC_SC1n) | 441 | | | 26.3.2 | ADC Configuration Register 1 (ADC_CFG1) | 445 | | | 26.3.3 | ADC Configuration Register 2 (ADC_CFG2) | 446 | | | 26.3.4 | ADC Data Result Register (ADC_Rn) | 447 | | | 26.3.5 | Compare Value Registers (ADC_CVn) | 448 | | | 26.3.6 | Status and Control Register 2 (ADC_SC2) | 449 | | | 26.3.7 | Status and Control Register 3 (ADC_SC3) | 451 | | | 26.3.8 | ADC Offset Correction Register (ADC_OFS) | 453 | | | 26.3.9 | ADC Plus-Side Gain Register (ADC_PG) | 453 | | | 26.3.10 | ADC Plus-Side General Calibration Value Register (ADC_CLPD) | 454 | | | 26.3.11 | ADC Plus-Side General Calibration Value Register (ADC_CLPS) | 454 | | | 26.3.12 | ADC Plus-Side General Calibration Value Register (ADC_CLP4) | 455 | | | | | | | Sec | Section number Title | | Page | |------|--------------------------|-------------------------------------------------------------|------| | | 26.3.13 | ADC Plus-Side General Calibration Value Register (ADC_CLP3) | 455 | | | 26.3.14 | ADC Plus-Side General Calibration Value Register (ADC_CLP2) | 456 | | | 26.3.15 | ADC Plus-Side General Calibration Value Register (ADC_CLP1) | 456 | | | 26.3.16 | ADC Plus-Side General Calibration Value Register (ADC_CLP0) | 457 | | 26.4 | Function | al description | 457 | | | 26.4.1 | Clock select and divide control. | 458 | | | 26.4.2 | Voltage reference selection | 458 | | | 26.4.3 | Hardware trigger and channel selects. | 459 | | | 26.4.4 | Conversion control | 460 | | | 26.4.5 | Automatic compare function | 468 | | | 26.4.6 | Calibration function. | 469 | | | 26.4.7 | User-defined offset function. | 470 | | | 26.4.8 | Temperature sensor | 471 | | | 26.4.9 | MCU wait mode operation. | 472 | | | 26.4.10 | MCU Normal Stop mode operation | 473 | | | 26.4.11 | MCU Low-Power Stop mode operation | 474 | | 26.5 | Initializa | tion information | 474 | | | 26.5.1 | ADC module initialization example | 474 | | 26.6 | Application information. | | | | | 26.6.1 | External pins and routing | 476 | | | 26.6.2 | Sources of error | 478 | | | | Chapter 27<br>Comparator (CMP) | | | 27.1 | Introduc | tion | 483 | | | 27.1.1 | CMP features | 483 | | | 27.1.2 | 6-bit DAC key features | 484 | | | 27.1.3 | ANMUX key features | 484 | | | 27.1.4 | CMP, DAC and ANMUX diagram | 485 | | | 27.1.5 | CMP block diagram. | 486 | | Sect | Section number Title | | Page | |-------|----------------------|--------------------------------------------|------| | 27.2 | Memory | map/register definitions | 488 | | | 27.2.1 | CMP Control Register 0 (CMPx_CR0) | 488 | | | 27.2.2 | CMP Control Register 1 (CMPx_CR1) | 489 | | | 27.2.3 | CMP Filter Period Register (CMPx_FPR) | 491 | | | 27.2.4 | CMP Status and Control Register (CMPx_SCR) | 491 | | | 27.2.5 | DAC Control Register (CMPx_DACCR) | 492 | | | 27.2.6 | MUX Control Register (CMPx_MUXCR) | 493 | | 27.3 | Function | nal description | 494 | | | 27.3.1 | CMP functional modes. | 494 | | | 27.3.2 | Power modes | 503 | | | 27.3.3 | Startup and operation. | 504 | | | 27.3.4 | Low-pass filter | 505 | | 27.4 | CMP int | errupts | 507 | | 27.5 | DMA su | pport | 507 | | 27.6 | CMP As | yncrhonous DMA support | 508 | | 27.7 | Digital-t | o-analog converter | 509 | | 27.8 | DAC fur | nctional description | 509 | | | 27.8.1 | Voltage reference source select | 509 | | 27.9 | DAC res | sets | 510 | | 27.10 | DAC clo | ocks | 510 | | 27.11 | DAC int | errupts | 510 | | 27.12 | CMP Tri | igger Mode | 510 | | | | Chapter 28<br>Voltage Reference (VREF) | | | 28.1 | Introduc | tion | 511 | | | 28.1.1 | Features | 512 | | | 28.1.2 | Modes of Operation | 512 | | | 28.1.3 | VREF Signal Descriptions | 513 | | Sec | Section number Title | | Page | | |------|----------------------|-------------------------------------------------------|------|--| | 28.2 | Memory | Map and Register Definition | 513 | | | | 28.2.1 | VREF Trim Register (VREF_VREFH_TRM) | 514 | | | | 28.2.2 | VREF Status and Control Register (VREF_VREFH_SC) | 515 | | | | 28.2.3 | VREFL TRIM Register (VREF_VREFL_TRM) | 516 | | | 28.3 | Function | nal Description | 517 | | | | 28.3.1 | Voltage Reference Disabled, SC[VREFEN] = 0 | 517 | | | | 28.3.2 | Voltage Reference Enabled, SC[VREFEN] = 1 | 517 | | | 28.4 | Initializa | ation/Application Information | 519 | | | | | Chapter 29 Multipurpose Clock Generator (MCG) | | | | 29.1 | Introduc | tion | 521 | | | | 29.1.1 | Features | 521 | | | | 29.1.2 | Modes of Operation | 525 | | | 29.2 | External | Signal Description. | 525 | | | 29.3 | Memory | 525 | | | | | 29.3.1 | MCG Control 1 Register (MCG_C1) | 526 | | | | 29.3.2 | MCG Control 2 Register (MCG_C2) | 527 | | | | 29.3.3 | MCG Control 3 Register (MCG_C3) | 528 | | | | 29.3.4 | MCG Control 4 Register (MCG_C4) | 528 | | | | 29.3.5 | MCG Control 5 Register (MCG_C5) | 530 | | | | 29.3.6 | MCG Control 6 Register (MCG_C6) | 530 | | | | 29.3.7 | MCG Status Register (MCG_S) | 531 | | | | 29.3.8 | MCG Status and Control Register (MCG_SC) | 533 | | | | 29.3.9 | MCG Auto Trim Compare Value High Register (MCG_ATCVH) | 534 | | | | 29.3.10 | MCG Auto Trim Compare Value Low Register (MCG_ATCVL) | 534 | | | | 29.3.11 | MCG Control 7 Register (MCG_C7) | 535 | | | | 29.3.12 | MCG Control 8 Register (MCG_C8) | 536 | | | | 29.3.13 | MCG Control 9 Register (MCG_C9) | 537 | | | Section number | | mber Title | Page | | |----------------|---------------------------------|------------------------------------|------|--| | 29.4 | Functional description. | | 538 | | | | 29.4.1 | MCG mode state diagram | 538 | | | | 29.4.2 | Low-power bit usage | 544 | | | | 29.4.3 | MCG Internal Reference Clocks | 544 | | | | 29.4.4 | External Reference Clock. | 545 | | | | 29.4.5 | MCG Fixed Frequency Clock | 545 | | | | 29.4.6 | MCG PLL clock | 545 | | | | 29.4.7 | MCG Auto TRIM (ATM) | 546 | | | 29.5 | Initializa | ation / Application information | 547 | | | | 29.5.1 | MCG module initialization sequence | 547 | | | | 29.5.2 | Using a 32.768 kHz reference | 549 | | | | 29.5.3 | MCG mode switching | 550 | | | | | Chapter 30<br>Oscillator (OSC) | | | | 30.1 | Introduc | tion | 557 | | | 30.2 | Features | and Modes | 557 | | | 30.3 | Block D | iagram | 558 | | | 30.4 | OSC Sig | gnal Descriptions | 558 | | | 30.5 | External | Crystal / Resonator Connections | 559 | | | 30.6 | External | Clock Connections. | 561 | | | 30.7 | Memory Map/Register Definitions | | 561 | | | | 30.7.1 | OSC Memory Map/Register Definition | 562 | | | 30.8 | Function | nal Description. | 563 | | | | 30.8.1 | OSC module states | 563 | | | | 30.8.2 | OSC module modes | 565 | | | | 30.8.3 | Counter | 567 | | | | 30.8.4 | Reference clock pin requirements. | 567 | | | 30.9 | Reset | | 567 | | | 30.10 | Low power modes operation | | | | | Sect | ion nun | nber Title | Page | |-------|------------|-------------------------------------------------------|------| | 30.11 | Interrupts | S | 568 | | | | Chapter 31<br>RTC Oscillator (OSC32K) | | | 31.1 | Introducti | ion | 569 | | | 31.1.1 | Features and Modes. | 569 | | | 31.1.2 | Block Diagram | 569 | | 31.2 | RTC Sign | nal Descriptions. | 570 | | | 31.2.1 | EXTAL32 — Oscillator Input. | 570 | | | 31.2.2 | XTAL32 — Oscillator Output | 570 | | 31.3 | External | Crystal Connections | 571 | | 31.4 | Functiona | al Description | 571 | | 31.5 | Reset Ove | erview | 571 | | 31.6 | Interrupts | S | 571 | | | | Chapter 32<br>Independent Real Time Clock (iRTC) | | | 32.1 | Introducti | ion | 573 | | | 32.1.1 | Features. | 573 | | | 32.1.2 | Modes of Operation. | 574 | | | 32.1.3 | Design Overview. | 575 | | 32.2 | Signal De | escription | 576 | | | 32.2.1 | EXTAL32K, XTAL32K | 576 | | | 32.2.2 | TAMPER[2:0] | 577 | | | 32.2.3 | VBAT | 577 | | 32.3 | Memory | Map and Registers | 577 | | | 32.3.1 | RTC Year and Month Counters Register (RTC_YEARMON) | 579 | | | 32.3.2 | RTC Days and Day-of-Week Counters Register (RTC_DAYS) | 580 | | | 32.3.3 | RTC Hours and Minutes Counters Register (RTC_HOURMIN) | 581 | | | 32.3.4 | RTC Seconds Counters Register (RTC_SECONDS) | 582 | | | 32.3.5 | RTC Year and Months Alarm Register (RTC_ALM_YEARMON) | 582 | | Sec | Section number Title | | Page | | |------|----------------------|----------------------------------------------------------------|------|--| | | 32.3.6 | RTC Days Alarm Register (RTC_ALM_DAYS) | 583 | | | | 32.3.7 | RTC Hours and Minutes Alarm Register (RTC_ALM_HOURMIN) | 583 | | | | 32.3.8 | RTC Seconds Alarm Register (RTC_ALM_SECONDS) | 584 | | | | 32.3.9 | RTC Control Register (RTC_CTRL) | 585 | | | | 32.3.10 | RTC Status Register (RTC_STATUS) | 587 | | | | 32.3.11 | RTC Interrupt Status Register (RTC_ISR) | 589 | | | | 32.3.12 | RTC Interrupt Enable Register (RTC_IER) | 592 | | | | 32.3.13 | RTC General Purpose Data Register (RTC_GP_DATA_REG) | 594 | | | | 32.3.14 | RTC Daylight Saving Hour Register (RTC_DST_HOUR) | 595 | | | | 32.3.15 | RTC Daylight Saving Month Register (RTC_DST_MONTH) | 596 | | | | 32.3.16 | RTC Daylight Saving Day Register (RTC_DST_DAY) | 597 | | | | 32.3.17 | RTC Compensation Register (RTC_COMPEN) | 597 | | | | 32.3.18 | Tamper Direction Register (RTC_TAMPER_DIRECTION) | 598 | | | | 32.3.19 | Tamper Queue Status and Control Register (RTC_TAMPER_QSCR) | 599 | | | | 32.3.20 | RTC Tamper Status and Control Register (RTC_TAMPER_SCR) | 600 | | | | 32.3.21 | RTC Tamper 01 Filter Configuration Register (RTC_FILTER01_CFG) | 601 | | | | 32.3.22 | RTC Tamper 2 Filter Configuration Register (RTC_FILTER2_CFG) | 602 | | | | 32.3.23 | Tamper Queue Register (RTC_TAMPER_QUEUE) | 603 | | | | 32.3.24 | RTC Control 2 Register (RTC_CTRL2) | 604 | | | 32.4 | Function | al Description | 605 | | | | 32.4.1 | Time and Calendaring Functions | 605 | | | | 32.4.2 | RTC Compensation Logic | 606 | | | | 32.4.3 | Write Protection Mechanism | 609 | | | | 32.4.4 | Tamper Detection and Logging | 610 | | | | 32.4.5 | RTC Isolation | 613 | | | | 32.4.6 | Wakeup Mode | 613 | | ## Section number Title Page ## Chapter 33 Low-Power Timer (LPTMR) | | | 2011 01101 1111101 (21 111111) | | |------|----------|-----------------------------------------------------|-----| | 33.1 | Introduc | tion | 615 | | | 33.1.1 | Features | 615 | | | 33.1.2 | Modes of operation | 615 | | 33.2 | LPTMR | signal descriptions. | 616 | | | 33.2.1 | Detailed signal descriptions. | 616 | | 33.3 | Memory | map and register definition | 616 | | | 33.3.1 | Low Power Timer Control Status Register (LPTMR_CSR) | 617 | | | 33.3.2 | Low Power Timer Prescale Register (LPTMR_PSR) | 618 | | | 33.3.3 | Low Power Timer Compare Register (LPTMR_CMR) | 620 | | | 33.3.4 | Low Power Timer Counter Register (LPTMR_CNR) | 620 | | 33.4 | Function | nal description | 621 | | | 33.4.1 | LPTMR power and reset | 621 | | | 33.4.2 | LPTMR clocking | 621 | | | 33.4.3 | LPTMR prescaler/glitch filter | 621 | | | 33.4.4 | LPTMR compare | 623 | | | 33.4.5 | LPTMR counter | 623 | | | 33.4.6 | LPTMR hardware trigger | 624 | | | 33.4.7 | LPTMR interrupt | 624 | | | | Chapter 34 Periodic Interrupt Timer (PIT) | | | 34.1 | Introduc | tion | 625 | | | 34.1.1 | Block diagram. | 625 | | | 34.1.2 | Features | 626 | | 34.2 | Signal d | escription | 626 | | 34.3 | Memory | map/register description | 627 | | | 34.3.1 | PIT Module Control Register (PITx_MCR) | 627 | | | 34.3.2 | Timer Load Value Register (PITx_LDVALn) | 629 | | | | | | | Sec | tion nui | mber Title | Page | |------|-------------------------|--------------------------------------------------------------------|------| | | 34.3.3 | Current Timer Value Register (PITx_CVALn) | 629 | | | 34.3.4 | Timer Control Register (PITx_TCTRLn) | 630 | | | 34.3.5 | Timer Flag Register (PITx_TFLGn) | 631 | | 34.4 | Functional description. | | | | | 34.4.1 | General operation. | 631 | | | 34.4.2 | Interrupts | 633 | | | 34.4.3 | Chained timers | 633 | | 34.5 | Initializa | ation and application information | 633 | | 34.6 | Example | e configuration for chained timers | 634 | | | | Chapter 35<br>Quad Timer (TMR) | | | 35.1 | Overview | w | 637 | | 35.2 | Features | | 638 | | 35.3 | Modes o | f Operation | 638 | | 35.4 | Block D | iagram | 638 | | 35.5 | Memory | Map and Registers | 639 | | | 35.5.1 | Timer Channel Compare Register 1 (TMRx_COMP1) | 641 | | | 35.5.2 | Timer Channel Compare Register 2 (TMRx_COMP2) | 642 | | | 35.5.3 | Timer Channel Capture Register (TMRx_CAPT) | 642 | | | 35.5.4 | Timer Channel Load Register (TMRx_LOAD) | 642 | | | 35.5.5 | Timer Channel Hold Register (TMRx_HOLD) | 643 | | | 35.5.6 | Timer Channel Counter Register (TMRx_CNTR) | 643 | | | 35.5.7 | Timer Channel Control Register (TMRx_CTRL) | 643 | | | 35.5.8 | Timer Channel Status and Control Register (TMRx_SCTRL) | 646 | | | 35.5.9 | Timer Channel Comparator Load Register 1 (TMRx_CMPLD1) | 647 | | | 35.5.10 | Timer Channel Comparator Load Register 2 (TMRx_CMPLD2) | 648 | | | 35.5.11 | Timer Channel Comparator Status and Control Register (TMRx_CSCTRL) | 648 | | | 35.5.12 | Timer Channel Input Filter Register (TMRx_FILT) | 650 | | | 35.5.13 | Timer Channel Enable Register (TMRx_ENBL) | 651 | | Sec | tion nu | mber Title | Page | |------|---------------------------------|----------------------------------------------------------|------| | 35.6 | Functional Description. | | 652 | | | 35.6.1 | General | 652 | | | 35.6.2 | Usage of Compare Registers | 653 | | | 35.6.3 | Usage of Compare Load Registers | 654 | | | 35.6.4 | Usage of the Capture Register | 655 | | | 35.6.5 | Functional Modes | 655 | | 35.7 | Resets | | 670 | | | 35.7.1 | General | 670 | | 35.8 | Clocks | | 671 | | | 35.8.1 | General | 671 | | 35.9 | Interrupts | | 671 | | | 35.9.1 | General | 671 | | | 35.9.2 | Description of Interrupt Operation. | 672 | | | | Chapter 36<br>Inter-Integrated Circuit (I2C) | | | 36.1 | Introduc | ction | 673 | | | 36.1.1 | Features | 673 | | | 36.1.2 | Modes of operation | 674 | | | 36.1.3 | Block diagram | 674 | | 36.2 | I2C sign | nal descriptions | 675 | | 36.3 | Memory map/register definition. | | 675 | | | 36.3.1 | I2C Address Register 1 (I2Cx_A1) | 676 | | | 36.3.2 | I2C Frequency Divider register (I2Cx_F) | 677 | | | 36.3.3 | I2C Control Register 1 (I2Cx_C1) | 678 | | | 36.3.4 | I2C Status register 1 (I2Cx_S1) | 680 | | | 36.3.5 | I2C Data I/O register (I2Cx_D) | 681 | | | 36.3.6 | I2C Control Register 2 (I2Cx_C2) | 682 | | | 36.3.7 | I2C Programmable Input Glitch Filter register (I2Cx_FLT) | 683 | | | 36.3.8 | I2C Range Address register (I2Cx_RA) | 684 | | Section numb | | mber Title | Page | |--------------|--------------|-------------------------------------------------------|------| | | 36.3.9 | I2C SMBus Control and Status register (I2Cx_SMB) | 685 | | | 36.3.10 | I2C Address Register 2 (I2Cx_A2) | 687 | | | 36.3.11 | I2C SCL Low Timeout Register High (I2Cx_SLTH) | 687 | | | 36.3.12 | I2C SCL Low Timeout Register Low (I2Cx_SLTL) | 687 | | 36.4 | Function | 688 | | | | 36.4.1 | I2C protocol | 688 | | | 36.4.2 | 10-bit address. | 693 | | | 36.4.3 | Address matching. | 695 | | | 36.4.4 | System management bus specification | 695 | | | 36.4.5 | Resets | 698 | | | 36.4.6 | Interrupts | 698 | | | 36.4.7 | Programmable input glitch filter | 700 | | | 36.4.8 | Address matching wakeup | 701 | | | 36.4.9 | DMA support | 702 | | 36.5 | Initializa | tion/application information | 702 | | | | Chapter 37<br>Serial Peripheral Interface (SPI) | | | 37.1 | Introduction | | 707 | | | 37.1.1 | Features | 707 | | | 37.1.2 | Modes of operation | 708 | | | 37.1.3 | Block diagrams. | 709 | | 37.2 | External | 37.1.3Block diagrams.70External signal description.71 | | | | 37.2.1 | SPSCK — SPI Serial Clock | 713 | | | 37.2.2 | MOSI — Master Data Out, Slave Data In | 713 | | | 37.2.3 | MISO — Master Data In, Slave Data Out | 713 | | | 37.2.4 | SS — Slave Select | 713 | | 37.3 | Memory | map/register definition | 714 | | | 37.3.1 | SPI Status Register (SPIx_S) | 714 | | | 37.3.2 | SPI Baud Rate Register (SPIx_BR) | 718 | | | | | | | Sec | tion nui | mber Title | Page | |------|----------------------------------------|---------------------------------------------------------------|------| | | 37.3.3 | SPI Control Register 2 (SPIx_C2) | 719 | | | 37.3.4 | SPI Control Register 1 (SPIx_C1) | 720 | | | 37.3.5 | SPI Match Register low (SPIx_ML) | 722 | | | 37.3.6 | SPI match register high (SPIx_MH) | 723 | | | 37.3.7 | SPI Data Register low (SPIx_DL) | 723 | | | 37.3.8 | SPI data register high (SPIx_DH) | 724 | | | 37.3.9 | SPI clear interrupt register (SPIx_CI) | 724 | | | 37.3.10 | SPI control register 3 (SPIx_C3) | 726 | | 37.4 | Function | Functional description. | | | | 37.4.1 | General | 727 | | | 37.4.2 | Master mode | 728 | | | 37.4.3 | Slave mode | 729 | | | 37.4.4 | SPI FIFO Mode | 731 | | | 37.4.5 | SPI Transmission by DMA | 732 | | | 37.4.6 | Data Transmission Length | 735 | | | 37.4.7 | SPI clock formats | 735 | | | 37.4.8 | SPI baud rate generation. | 739 | | | 37.4.9 | Special features. | 739 | | | 37.4.10 | Error conditions | 741 | | | 37.4.11 | Low-power mode options. | 742 | | | 37.4.12 | Reset | 743 | | | 37.4.13 | Interrupts | 744 | | 37.5 | Initialization/application information | | 746 | | | 37.5.1 | Initialization sequence | 746 | | | 37.5.2 | Pseudo-Code Example | 746 | | | | Chapter 38 Universal Asynchronous Receiver/Transmitter (UART) | | | 38.1 | Introduc | tion | 751 | | | 38.1.1 | Features | 751 | | Section number | | mber Title | Page | |----------------|---------|----------------------------------------------------|------| | | 38.1.2 | Modes of operation | 753 | | 38.2 | UART si | ignal descriptions. | 754 | | | 38.2.1 | Detailed signal descriptions. | 754 | | 38.3 | Memory | 755 | | | | 38.3.1 | UART Baud Rate Registers: High (UARTx_BDH) | 760 | | | 38.3.2 | UART Baud Rate Registers: Low (UARTx_BDL) | 761 | | | 38.3.3 | UART Control Register 1 (UARTx_C1) | 761 | | | 38.3.4 | UART Control Register 2 (UARTx_C2) | 763 | | | 38.3.5 | UART Status Register 1 (UARTx_S1) | 765 | | | 38.3.6 | UART Status Register 2 (UARTx_S2) | 768 | | | 38.3.7 | UART Control Register 3 (UARTx_C3) | 769 | | | 38.3.8 | UART Data Register (UARTx_D) | 771 | | | 38.3.9 | UART Match Address Registers 1 (UARTx_MA1) | 772 | | | 38.3.10 | UART Match Address Registers 2 (UARTx_MA2) | 772 | | | 38.3.11 | UART Control Register 4 (UARTx_C4) | 773 | | | 38.3.12 | UART Control Register 5 (UARTx_C5) | 773 | | | 38.3.13 | UART Extended Data Register (UARTx_ED) | 774 | | | 38.3.14 | UART Modem Register (UARTx_MODEM) | 775 | | | 38.3.15 | UART FIFO Parameters (UARTx_PFIFO) | 777 | | | 38.3.16 | UART FIFO Control Register (UARTx_CFIFO) | 778 | | | 38.3.17 | UART FIFO Status Register (UARTx_SFIFO) | 779 | | | 38.3.18 | UART FIFO Transmit Watermark (UARTx_TWFIFO) | 780 | | | 38.3.19 | UART FIFO Transmit Count (UARTx_TCFIFO) | 781 | | | 38.3.20 | UART FIFO Receive Watermark (UARTx_RWFIFO) | 781 | | | 38.3.21 | UART FIFO Receive Count (UARTx_RCFIFO) | 782 | | | 38.3.22 | UART 7816 Control Register (UARTx_C7816) | 782 | | | 38.3.23 | UART 7816 Interrupt Enable Register (UARTx_IE7816) | 784 | | | 38.3.24 | UART 7816 Interrupt Status Register (UARTx_IS7816) | 785 | | | 38.3.25 | UART 7816 Wait Parameter Register (UARTx_WP7816T0) | 786 | | | | | | | Section number | | mber Title | Page | | |----------------|--------------------------------|----------------------------------------------------|------|--| | | 38.3.26 | UART 7816 Wait Parameter Register (UARTx_WP7816T1) | 787 | | | | 38.3.27 | UART 7816 Wait N Register (UARTx_WN7816) | 787 | | | | 38.3.28 | UART 7816 Wait FD Register (UARTx_WF7816) | 788 | | | | 38.3.29 | UART 7816 Error Threshold Register (UARTx_ET7816) | 788 | | | | 38.3.30 | UART 7816 Transmit Length Register (UARTx_TL7816) | 789 | | | 38.4 | Function | Functional description | | | | | 38.4.1 | Transmitter | 790 | | | | 38.4.2 | Receiver | 794 | | | | 38.4.3 | Baud rate generation. | 807 | | | | 38.4.4 | Data format (non ISO-7816) | 809 | | | | 38.4.5 | Single-wire operation. | 812 | | | | 38.4.6 | Loop operation. | 813 | | | | 38.4.7 | ISO-7816/smartcard support | 813 | | | 38.5 | Reset | | 818 | | | 38.6 | System level interrupt sources | | 818 | | | | 38.6.1 | RXEDGIF description | 819 | | | 38.7 | 7 DMA operation | | 820 | | | 38.8 | Application information. | | 820 | | | | 38.8.1 | Transmit/receive data buffer operation | 820 | | | | 38.8.2 | ISO-7816 initialization sequence | 821 | | | | 38.8.3 | Initialization sequence (non ISO-7816) | 823 | | | | 38.8.4 | Overrun (OR) flag implications | 824 | | | | 38.8.5 | Overrun NACK considerations | 825 | | | | 38.8.6 | Match address registers | 825 | | | | 38.8.7 | Modem feature | 825 | | | | 38.8.8 | Clearing 7816 wait timer (WT, BWT, CWT) interrupts | 827 | | | | 38.8.9 | Legacy and reverse compatibility considerations | 827 | | **Title** Section number **Page** Chapter 39 Cyclic Redundancy Check (CRC) 39.1 Introduction 829 39.1.1 Features 829 39.1.2 39.1.3 39.2 CRC Data register (CRC\_DATA).....831 39.2.1 39.2.2 CRC Polynomial register (CRC\_GPOLY)......832 39.2.3 CRC Control register (CRC\_CTRL)......832 39.3 39.3.1 39.3.2 CRC calculations 834 Transpose feature.......835 39.3.3 39.3.4 Chapter 40 Random Number Generator Accelerator (RNGA) 40.1 40.1.1 Overview 839 40.2 40.3 40.4 40.4.1 RNGA Control Register (RNG\_CR).....841 40.4.2 RNGA Status Register (RNG SR).....843 40.4.3 RNGA Entropy Register (RNG\_ER).....845 40.4.4 RNGA Output Register (RNG\_OR).....845 40.5 40.5.1 RNGA Output Register (RNG\_OR).....846 | Sec | tion nui | mber Title | Page | |------|------------|----------------------------------------------|------| | | 40.5.2 | RNGA Core/Control Logic Block | 846 | | 40.6 | Initializa | tion/application information | 847 | | | | Chapter 41<br>LCD Controller (SLCD) | | | 41.1 | Introduc | tion | 849 | | | 41.1.1 | Features | 849 | | | 41.1.2 | Modes of operation | 850 | | | 41.1.3 | Block diagram. | 851 | | 41.2 | LCD sig | nal descriptions | 852 | | | 41.2.1 | LCD_P[63:0] | 853 | | | 41.2.2 | VLL1, VLL2, VLL3 | 853 | | | 41.2.3 | Vcap1, Vcap2 | 853 | | 41.3 | Memory | map and register definition. | 853 | | | 41.3.1 | LCD General Control Register (LCD_GCR) | 854 | | | 41.3.2 | LCD Auxiliary Register (LCD_AR) | 859 | | | 41.3.3 | LCD Fault Detect Control Register (LCD_FDCR) | 861 | | | 41.3.4 | LCD Fault Detect Status Register (LCD_FDSR) | 863 | | | 41.3.5 | LCD Pin Enable register (LCD_PENn) | 864 | | | 41.3.6 | LCD Back Plane Enable register (LCD_BPENn) | 865 | | | 41.3.7 | LCD Waveform register (LCD_WF3TO0) | 865 | | | 41.3.8 | LCD Waveform register (LCD_WF7TO4) | 866 | | | 41.3.9 | LCD Waveform register (LCD_WF11TO8) | 867 | | | 41.3.10 | LCD Waveform register (LCD_WF15TO12) | 868 | | | 41.3.11 | LCD Waveform register (LCD_WF19TO16) | 868 | | | 41.3.12 | LCD Waveform register (LCD_WF23TO20) | 869 | | | 41.3.13 | LCD Waveform register (LCD_WF27TO24) | 869 | | | 41.3.14 | LCD Waveform register (LCD_WF31TO28) | 870 | | | 41.3.15 | LCD Waveform register (LCD_WF35TO32) | 871 | | | 41.3.16 | LCD Waveform register (LCD_WF39TO36) | 871 | | | | | | | Section number | | mber Title | Page | | |----------------|------------------------------------|---------------------------------------------------|------|--| | | 41.3.17 | LCD Waveform register (LCD_WF43TO40) | 872 | | | | 41.3.18 | LCD Waveform register (LCD_WF47TO44) | 872 | | | | 41.3.19 | LCD Waveform register (LCD_WF51TO48) | 873 | | | | 41.3.20 | LCD Waveform register (LCD_WF55TO52) | 874 | | | | 41.3.21 | LCD Waveform register (LCD_WF59TO56) | 874 | | | | 41.3.22 | LCD Waveform register (LCD_WF63TO60) | 875 | | | 41.4 | Functional description. | | | | | | 41.4.1 | LCD controller driver description. | 876 | | | | 41.4.2 | WFyTOx registers | 884 | | | | 41.4.3 | LCD display modes | 885 | | | | 41.4.4 | LCD charge pump and power supply operation | 887 | | | | 41.4.5 | Resets | 891 | | | | 41.4.6 | Interrupts | 891 | | | | 41.4.7 | LCD display fault detect circuit (LFD) | 891 | | | 41.5 | Initialization section. | | | | | | 41.5.1 | Initialization sequence | 898 | | | | 41.5.2 | Initialization examples | 899 | | | 41.6 | Application information. | | | | | | 41.6.1 | LCD seven segment example description. | 903 | | | | 41.6.2 | LCD contrast control. | 906 | | | | | Chapter 42<br>General-Purpose Input/Output (GPIO) | | | | 42.1 | Introduct | tion | 909 | | | | 42.1.1 | Features | 909 | | | | 42.1.2 | Modes of operation. | 909 | | | | 42.1.3 | GPIO signal descriptions | 910 | | | 42.2 | Memory map and register definition | | | | | | 42.2.1 | Port Data Output Register (GPIOx_PDOR) | 912 | | | | 42.2.2 | Port Data Input Register (GPIOx_PDIR) | 913 | | | | | | | | | Section number | | mber Title | Page | |----------------|-------------------------|-------------------------------------------------------------|------| | | 42.2.3 | Port Data Direction Register (GPIOx_PDDR) | 913 | | | 42.2.4 | GPIO Attribute Checker Register (GPIOx_GACR) | 914 | | 42.3 | Function | 915 | | | | 42.3.1 | General-purpose input. | 915 | | | 42.3.2 | General-purpose output | 915 | | | | Chapter 43 Bit Manipulation Engine (BME) | | | 43.1 | Introduc | 917 | | | | 43.1.1 | Overview | 918 | | | 43.1.2 | Features. | 918 | | | 43.1.3 | Modes of operation. | 919 | | 43.2 | Memory | y map and register definition | 919 | | 43.3 | Functional description. | | 920 | | | 43.3.1 | BME decorated stores. | 920 | | | 43.3.2 | BME decorated loads | 927 | | | 43.3.3 | Additional details on decorated addresses and GPIO accesses | 933 | | 43.4 | Applica | tion information | 934 | | | | Chapter 44 Micro Trace Buffer (MTB) | | | 44.1 | Introduc | 937 | | | | 44.1.1 | Overview | 937 | | | 44.1.2 | Features | 940 | | | 44.1.3 | Modes of operation | 941 | | 44.2 | External | l signal description | 941 | | Sec | tion nui | mber Title | Page | |------|----------|----------------------------------------|------| | 44.3 | Memory | map and register definition. | 942 | | | 44.3.1 | MTB_RAM Memory Map | 942 | | | 44.3.2 | MTB_DWT Memory Map | 955 | | | 44.3.3 | System ROM Memory Map | 965 | | | | Chapter 45 Flash Memory Module (FTFA) | | | 45.1 | Introduc | tion | 971 | | | 45.1.1 | Features | 972 | | | 45.1.2 | Block Diagram | 972 | | | 45.1.3 | Glossary | 973 | | 45.2 | External | Signal Description. | 974 | | 45.3 | Memory | Map and Registers | 974 | | | 45.3.1 | Flash Configuration Field Description. | 974 | | | 45.3.2 | Program Flash IFR Map. | 975 | | | 45.3.3 | Register Descriptions | 976 | | 45.4 | Function | nal Description | 985 | | | 45.4.1 | Flash Protection | 985 | | | 45.4.2 | Interrupts | 986 | | | 45.4.3 | Flash Operation in Low-Power Modes | 986 | | | 45.4.4 | Functional Modes of Operation | 987 | | | 45.4.5 | Flash Reads and Ignored Writes | 987 | | | 45.4.6 | Read While Write (RWW) | 987 | | | 45.4.7 | Flash Program and Erase | 987 | | | 45.4.8 | Flash Command Operations | 988 | | | 45.4.9 | Margin Read Commands | 992 | | | 45.4.10 | Flash Command Description | 993 | | | 45.4.11 | Security | 1006 | | | 45.4.12 | Reset Sequence | 1008 | ## Section number Title Page # Chapter 46 Flash Memory Controller (FMC) | 46.1 | Introduct | ion | 1009 | |------|-----------|-------------------------------|------| | | 46.1.1 | Overview | 1009 | | | 46.1.2 | Features | 1009 | | 46.2 | Modes of | f operation | 1010 | | 46.3 | External | signal description | 1010 | | 46.4 | Memory | map and register descriptions | 1010 | | 46.5 | Function | al description | 1010 | # **Chapter 1 About This Document** ### 1.1 Overview ## 1.1.1 Purpose This document describes the features, architecture, and programming model of the Freescale microcontroller family. ### 1.1.2 Audience This document is primarily for system architects and software application developers who are using or considering using the KM microcontroller 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 <i>0b</i> . | | 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 <i>0x</i> . | KM Family Reference Manual, Rev. 5, Oct 2013 39 # 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. | | | in some cases, deasserted signals are described as negated. | | reserved | Refers to a memory space, register, or field that is either reserved for future use or for which, when written to, the module or chip behavior is unpredictable. | # Chapter 2 Introduction ## 2.1 KM family introduction KM family of devices are 32-bit MCUs in 90nm Thin Film Storage (TFS) embedded flash technology. These devices are primarily focused to serve the metering markets for smart single-phase energy meters (India and China) and two-phase meters (US, Japan, and Europe). KM family targets EN 50470-1, EN 50470-3, IEC 62053-21, IEC 62053-22, and IEC 62053-23 class of meters. KM devices are based on 32-bit ARM Cortex M0+ core with integrated Analog Front End (AFE). CPU clock rates on these devices can reach up to 50 MHz. The KM family of devices includes highly accurate Sigma Delta (SD) ADC, Programmable Gain Amplifier (PGA), high precision internal voltage reference, flash, RAM, phase compensation logic block and other peripherals. KM family provides tamper detection and accurate real time clock on all devices. ## 2.2 Detailed block diagram The following figure shows the detailed block diagram for KM family of micorcontrollers: 41 #### r√ıvı ıeature set Figure 2-1. Detailed block diagram ### 2.3 KM feature set KM family of devices have the following features: Table 2-1. KM feature set | Features | Description | |---------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Operating Characteristics | <ul> <li>Voltage range 1.71V - 3.6V (without AFE)</li> <li>Voltage range 2.7V - 3.6V (with AFE)</li> <li>Flash programming voltage from 1.71 V to 3.6 V</li> <li>iRTC battery supply range 1.71V to 3.6 V</li> <li>Temperature range (T<sub>A</sub>) -40°C to 85°C</li> <li>Flexible modes of operation</li> </ul> | ## Table 2-1. KM feature set (continued) | Features | Description | |----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Core | <ul> <li>High Performance ARM Cortex M0+ Core</li> <li>Upto 50 MHz of Core Clock Frequency</li> <li>Supports v6-M Instruction Set Architecture (ISA) including all 16-bit v7-M instructions plus a number of 32-bit Thumb-2 instructions</li> <li>100% compatible with Cortex M0</li> <li>0.95 DMIPS per MHz performance when executing from internal RAM</li> <li>Nested Vectored Interrupt Controller <ul> <li>32 vectored interrupts</li> <li>4 programmable priority levels</li> </ul> </li> </ul> | | Clocks | <ul> <li>MHz Oscillator <ul> <li>Mid Range: 1 MHz to 8 MHz</li> <li>High Range: 8 MHz to 32 MHz</li> </ul> </li> <li>32.768 kHz crystal oscillator in iRTC power domain</li> <li>Two internal trim-able clock references <ul> <li>32 kHz</li> <li>4 MHz</li> </ul> </li> <li>Internal 1 kHz low power oscillator</li> <li>PLL to generate clocks for AFE <ul> <li>Input range: 31.25 kHz to 39.0625 kHz</li> <li>Output range: 11.72 MHz to 14.65 MHz</li> </ul> </li> <li>FLL to generate core, system &amp; flash clocks <ul> <li>Input range: 31.25 kHz to 39.0625 kHz</li> <li>Output Range: 20 MHz to 50 MHz</li> </ul> </li> <li>Clock ratio <ul> <li>Core:Bus:Flash = 2:1:1 for core clock &gt; 25 MHz</li> <li>Core:Bus:Flash = 1:1:1 for core clock &lt;= 25 MHz</li> <li>NOTE: Bus clock must be configured to be higher than equal to 64 kHz</li> </ul> </li> </ul> | | Analog | <ul> <li>24 bit Sigma Delta ADC</li> <li>Can operate in RUN, VLPR, STOP &amp; PSTOP1 modes</li> <li>PGA with gains from 1 to 32</li> <li>1.2V VREF</li> <li>16-bit SAR ADC</li> <li>CMP with 6-bit DAC</li> </ul> | ### nivi reature set ## Table 2-1. KM feature set (continued) | Features | Description | |--------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | System, protection and power management features | <ul> <li>Various stop, wait, and run modes to provide lower power based on application needs</li> <li>AWIC to wakeup from STOP and VLPS modes</li> <li>Peripheral clock enable register can disable clocks to unused modules, thereby reducing currents</li> <li>Low voltage warning and detect with selectable trip points</li> <li>Illegal opcode and illegal address detection with reset</li> <li>Hardware Programmable CRC module to support fast cyclic redundancy checks (CRC)</li> <li>Random Number Generator (RNGA)</li> <li>128-bit unique chip identifier</li> <li>Software and hardware watchdog with external monitor pin</li> <li>4 Tamper inputs for Tamper Detection (Part of iRTC)</li> <li>Flash security and block protection</li> <li>Peripheral crossbar to allow internal signal remapping for flexibility</li> </ul> | | Debug | 2-pin Serial Wire Debug (SWD) - Standard ARM debug interface | | DMA | <ul><li>4 channel DMA</li><li>No support for Scater/Gather</li></ul> | | Timers | <ul> <li>Independent Real Time Clock (iRTC) independently powered by battery and on-chip crystal clock drift compensation.</li> <li>Quad Timer (4 channels)</li> <li>Programmable Interrupt Timer (PIT)</li> <li>Low-power timer (LPTMR)</li> </ul> | | Communications | Universal asynchronous receiver/transmitter UART (all supporting hardware flow control) W/ ISO 7816 (on 2 UART) IrDA capability on all UART (one can be used at a time) W/ DMA (all UARTs) I UART with 5V AMR support (UART1) Serial Peripheral Interface (SPI) with FIFO (SPI1) and without FIFO (SPI0) I SPI with 5V AMR support (SPI1) Inter-Integrated Circuit (I2C) (x2) with SMBUS protocol support | | Input/Output | Upto 9 eGPIOs ports and 1 port with digital glitch filters Pin interrupt/DMA request capability eGPIO pins connected to the processor's local 32-bit platform bus (RGPIO) eGPIO pins also accessible via IPS bus accesses (protected via AIPS) eGPIO module to have inbuilt access protection | | Memory | <ul> <li>128 KB / 64 KB single array Flash</li> <li>Flash memory read and write down to 1.71V</li> <li>No FlexMemory</li> <li>Core:Flash frequency is 2:1 <ul> <li>1:1 for low core frequency (&lt;= 25 MHz)</li> </ul> </li> <li>16 KB of single access RAM</li> </ul> | 45 Table 2-1. KM feature set (continued) | Features | Description | | |-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | Display | <ul> <li>4x40 Segment LCD</li> <li>8x36 Segment LCD</li> <li>3V LCD glass supported with segment fault detection</li> </ul> | | | Power Consumption | <ul> <li>RUN Mode (all modules OFF): 6.0 mA</li> <li>IDD Equation: 1.14 mA + 97 μA/MHz</li> <li>Please refer to Power Modes section for more details.</li> </ul> | | ### **NOTE** Features will vary from device to device. See next section for exact details. # 2.4 Device configuration The following table lists the device configuration for KM microcontroller and its phantoms: Table 2-2. Device configuration | Configuration/Module | 100 LQFP | 44 LGA | 64 LQFP | |-------------------------------------|-----------------------------|-----------------------------|-----------------------------| | General | | | | | Maximum CPU frequency (MHz) | 50 | 50 | 50 | | Dimensions (mm²) | 14 x 14 mm <sup>2</sup> | 5 x 5 mm <sup>2</sup> | 10 x 10 mm <sup>2</sup> | | Core, Platform and Debug | | | | | DMA | 4 ch | 4 ch | 4 ch | | MPU | 1 | 1 | 1 | | Peripheral XBAR (# of IO supported) | upto 9 inputs and 9 outputs | upto 5 inputs and 5 outputs | upto 7 inputs and 7 outputs | | Single Wire Debug (SWD) | 1 | 1 | 1 | | System Security and Integrity | | | | | Cyclic redundancy check (CRC) | 1 | 1 | 1 | | RNGA (Random Number Generator) | 1 | 1 | 1 | | Watchdog timer | 1 | 1 | 1 | | External Watchdog Monitor | 1 | 1 | 1 | | Passive Tamper Pins <sup>1</sup> | 3 | 1 | 1 | | Active Tamper Pins | One pair | NA | NA | | Embedded Memory | | | | | Flash memory (KB) | 128/64 | 128/64 | 128/64 | | RAM (KB) | 16 | 16 | 16 | | Clock Generator | <u> </u> | | | ### Device configuration Table 2-2. Device configuration (continued) | Configuration/Module | 100 LQFP | 44 LGA | 64 LQFP | |----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------|-------------------------------------------------|-------------------------------------------------| | MCG | FLL + Internal OSC | FLL + Internal OSC | FLL + Internal OSC | | | (32 kHz or 2 MHz) | (32 kHz or 2 MHz) | (32 kHz or 2 MHz) | | | PLL (32.768 kHz<br>reference) | PLL (32.768 kHz<br>reference) | PLL (32.768 kHz<br>reference) | | Real Time Clock (32 kHz OSC) | 1 | 1 | 1 | | Timer/PWM | | | | | QuadTimer | 1 with 4 channels | 1 with 4 channels | 1 with 4 channels | | Low power timer (LPTMR) | 1 | 1 | 1 | | Periodic Interrupt Timer(PIT) | 2 | 2 | 2 | | Communication Interfaces | | | | | UART <sup>2</sup> | 4 (1 support 5 V AMR) | 2 (1 supports 5 V AMR) | 4 (1 support 5 V AMR) | | SPI (16-bit) | 2 (1 supports 5 V AMR) | 2 (1 supports 5 V AMR) | 2 (No 5 V AMR) | | 12C | 2 | 1 | 2 | | Analog | | | | | Total dedicated SD ADC differential channels (for current measurement) with PGA Total dedicated SD ADC single ended/differential channels (for voltage measurement). No PGA. | Up to 2<br>Up to 2 | 2<br>Up to 2 | Up to 2<br>1 | | 16 bit SAR ADC | 1 | 1 | 1 | | Total Single Ended Channels for SAR ADC | 12 | 5 | 6 | | 1.2V VREF | 1 | 1 | 1 | | CMP | 2 | 2 | 2 | | (Number of Channels) | (12) | (6) | (8) | | Human Machine Interface | | | | | Segmented LCD | 4x40 (8x36) | NA | 4x24 (8x20) | | Total GPIO pins | 68 | 20 | 38 | | eGPIO | All GPIO pins (when accessed via Core's IOPORT) | All GPIO pins (when accessed via Core's IOPORT) | All GPIO pins (when accessed via Core's IOPORT) | - 1. These pins also used for Active Tamper - 2. Any UART can be selected for IrDA. But only one IrDA communication is supported (enforced via XBAR) - 3. See Supported Packages section for exact number of supported channels ### **NOTE** Please refer to "Support Packages" section for exact number of SD channels, memory and LCD options. ## 2.5 Modules on the device ## 2.5.1 Platform modules The following table lists all platform modules that are available on this device: Table 2-3. Platform modules | Module | Description | Reference | |--------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------| | ARM Cortex-M0+ core | The Cortex-M0+ processor is an entry-level 32-bit ARM Cortex processor designed for a broad range of embedded applications. • Upto 50 MHz of Core Clock Frequency • Supports v6-M Instruction Set Architecture (ISA) including all 16-bit v7-M instructions plus a number of 32-bit Thumb-2 instructions • 100% compatible with Cortex M0 • 0.95 DMIPS per MHz performance when executing from internal RAM • Nested Vectored Interrupt Controller • 32 vectored interrupts • 4 programmable priority levels • User and privileged mode execution • Single-cycle 32-bit hardware multiplier • Low latency, high-speed peripheral I/O port • A Vector Table Offset Register | For ARM processor documentation, refer to arm.com | | Nested Vectored<br>Interrupt Controller<br>(NVIC) | External interrupt signals connect to the NVIC, and the NVIC prioritizes the interrupts. Software can set the priority of each interrupt. The NVIC and the Cortex-M0+ processor core are closely coupled, providing low latency interrupt processing and efficient processing of late arriving interrupts. All NVIC registers are only accessible using word transfers. Any attempt to read or write a halfword | Full documentation for this module is provided by ARM and can be found at http://www.arm.com | | | or byte individually is Unpredictable. NVIC registers are always little-endian. Processor accesses are correctly handled regardless of the endian configuration of the processor. | | | Asynchronous Wake-up<br>Interrupt Controller<br>(AWIC) | The primary function of the Asynchronous Wake-<br>up Interrupt Controller (AWIC) is to detect<br>asynchronous wake-up events in stop modes<br>and signal to clock control logic to resume<br>system clocking. After clock restart, the NVIC<br>observes the pending interrupt and performs the<br>normal interrupt or event processing. | Full documentation for this module is provided by ARM and can be found at http://www.arm.com | ### woules on the device ## Table 2-3. Platform modules (continued) | Module | Description | Reference | |------------------|---------------------|------------------------------------------------------------------------------------------------------------------------| | Debug Interfaces | ARM debug interface | For ARM debug documentation, refer to ARM Debug Interface - IHI0031A_ARM_debug_interface_v5.pdf at http:// www.arm.com | # 2.5.2 System modules The following system modules are available on this device: Table 2-4. System modules | Module | Description | |--------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | DMA Controller | <ul> <li>Four independently programmable DMA controller channels provides the means to directly transfer data between system memory and I/O peripherals</li> <li>DMA controller can operate in run and wait modes</li> <li>Dual-address (source, destination) transfers via 32-bit master connection to the system bus</li> <li>Data transfers in 8-, 16-, or 32-bit accesses</li> <li>Continuous-mode or cycle-steal transfers from software initiated or peripheral paced transfers</li> <li>Programmable request per channel selected from 16 possible sources</li> </ul> | | Crossbar Switch (AXBS) | <ul> <li>Hardware interconnect matrix interfacing bus masters to bus slaves</li> <li>Supports 2 masters and 3 slaves</li> <li>Two-stage pipelined AMBA-AHB system bus protocol</li> <li>Support for concurrent data transfers to slave targets</li> <li>Programmable fixed priority or round robin arbitration</li> </ul> | | Memory Protection Unit (MPU) | <ul> <li>Concurrently monitors and evaluates access controls for 2 slave transfers</li> <li>Supports 8 memory region descriptors, each 128 bits in size defining start and end addresses and access rights</li> <li>Detects access protection errors if a memory reference does not hit in any memory region, or if the reference is illegal in all memory regions hit. If an access error occurs, the reference is terminated with an error response, and the MPU inhibits the bus cycle being sent to the targeted slave device.</li> <li>64-bit error registers (one per slave port) capture the last faulting address, attributes, and other information</li> <li>Global MPU enable/disable control bit</li> </ul> | | Low-Leakage Wakeup Unit (LLWU) | The LLWU module allows the device to wake from low leakage power modes (VLLS) through various internal peripheral and external pin sources. | ## Table 2-4. System modules (continued) | Module | Description | |-----------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Power Management Controller (PMC) | <ul> <li>Separate digital (regulated) and analog (referenced to digital) supply outputs</li> <li>Programmable power saving modes</li> <li>No output supply decoupling capacitors required</li> <li>Available wake-up from power saving modes via RTC and external inputs</li> <li>Integrated Power-on Reset (POR)</li> <li>Integrated Low Voltage Detect (LVD) with reset (brownout) capability</li> <li>Selectable LVD trip points</li> <li>Programmable Low Voltage Warning (LVW) interrupt capability</li> <li>Buffered bandgap reference voltage output</li> <li>Factory programmed trim for bandgap and LVD</li> <li>1 kHz Low Power Oscillator (LPO)</li> </ul> | | System Integration Module(SIM) | System clocking configuration System clock divide values Architectural clock gating control LPTPM clock selection Flash and System RAM size configuration LP Timer external clock and input capture selection Compiled memory self-time control Quadtimer Clock Selection DMA Done flag selection Selectable clock for CLKOUT pin UART Receive/Transmit select PIT0 or PIT1 output selection | | External Watchdog Monitor (EWM) | <ul> <li>Independent 1 kHz LPO clock source</li> <li>Programmable time-out period specified in terms of number of EWM LPO clock cycles</li> <li>Windowed refresh option <ul> <li>Provides robust check that program flow is faster than expected</li> <li>Programmable window</li> <li>Refresh outside window leads to assertion of EWM_out</li> </ul> </li> <li>Robust refresh mechanism <ul> <li>Write values of 0xB4 and 0x2C to EWM Refresh Register within (EWM_service_time) peripheral bus clock cycles</li> </ul> </li> <li>One output port, EWM_out, when asserted is used to reset or place the external circuit into safe mode</li> <li>One Input port, EWM_in, allows an external circuit to control the EWM_out signal</li> </ul> | | Watchdog Timer (WDOG) | IEC 60730 compliant watchdog monitor Independent, configurable clock source input Write-once control bits with unlock sequence Programmable timeout period Ability to test watchdog timer and reset Windowed refresh option Robust refresh mechanism Cumulative count of watchdog resets between power-on resets Configurable interrupt on timeout | | Inter-Peripheral Crossbar Switch (XBAR) | <ul> <li>33 identical 33-input muxes with individual select fields.</li> <li>Edge detection with associated interrupt or DMA request generation for a subset of mux outputs.</li> <li>Memory mapped registers with IPBus interface for select and control fields.</li> <li>Register write protection input signal.</li> </ul> | ## 2.5.3 Clock The following clocks are available on this device: Table 2-5. Clock modules | range Option to program DCO frequency for a 32.768 kHz external refer clock source Internal or external reference clock can be used to control the FLI Phase-Locked Loop (PLL) Fixed multiplier to get Voltage-Controlled Oscillator (VCO) frequent for a 31.25 kHz to 39.0625 kHz (typ. 32.768 kHz) external referent clock source input range VCO frequency range 11.71875 MHz @ 31.25 kHz to 14.6484375 MHz @ 39.0625 kHz (typ. 12.288 MHz @ 32.768 kHz) Modulo VCO frequency divider phase/frequency detector Integrated loop filter Primarily drives the AFE clock Internal Reference Clock (IRC) generator 32 kHz low range clock with 9 trim bits for accuracy 2 MHz fast clock with 3 trim bits Low range clock can be used to control the FLL Low range or fast clock can be selected as MCU's clock source Can be used as a clock source for other on-chip peripherals External Clock (ERCLK) from the Crystal Oscillator (XOSC) Can be used as the FLL and/or PLL source Can be used as the FLL and/or PLL source Can be selected as the clock source for the MCU. This can impact AFE accuracy and is not preferred when using AFE for metering. External clock monitor with reset request capability Lock detector with interrupt request capability for use with the PLL Auto Trim Machine (ATM) for trimming both the low range and fast interreference clocks | Module | Description | |----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Auto Trim Machine (ATM) for trimming both the low range and fast inter reference clocks | | Frequency-Locked Loop (FLL) Digitally controlled oscillator (DCO) with programmable frequency range Option to program DCO frequency for a 32.768 kHz external reference clock source Internal or external reference clock can be used to control the FLL Phase-Locked Loop (PLL) Fixed multiplier to get Voltage-Controlled Oscillator (VCO) frequency for a 31.25 kHz to 39.0625 kHz (typ. 32.768 kHz) external reference clock source input range VCO frequency range 11.71875 MHz @ 31.25 kHz to 14.6484375 MHz @ 39.0625 kHz (typ. 12.288 MHz @ 32.768 kHz) Modulo VCO frequency divider phase/frequency detector Integrated loop filter Primarily drives the AFE clock Internal Reference Clock (IRC) generator 32 kHz low range clock with 9 trim bits for accuracy 2 MHz fast clock with 3 trim bits Low range clock can be used to control the FLL Low range or fast clock can be selected as MCU's clock source Can be used as a clock source for other on-chip peripherals External Clock (ERCLK) from the Crystal Oscillator (XOSC) Can be selected as the clock source for the MCU. This can impact AFE accuracy and is not preferred when using AFE for metering. | | <ul> <li>Reference dividers for FLL are provided</li> <li>Clock source selected can be divided down by 1, 2, 4, 8, or 16</li> </ul> | | <ul> <li>Lock detector with interrupt request capability for use with the PLL</li> <li>Auto Trim Machine (ATM) for trimming both the low range and fast internal reference clocks</li> <li>Reference dividers for FLL are provided</li> </ul> | # 2.5.4 Security modules The following security modules are available on this device: ## Table 2-6. Security modules | Module | Description | |--------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Programmable CRC (PCRC) | <ul> <li>Hardware CRC generator circuit using 16/32-bit shift register</li> <li>User Configurable 16/32 bit CRC</li> <li>Programmable Generator Polynomial</li> <li>Error detection for all single, double, odd, and most multi-bit errors</li> <li>Programmable initial seed value</li> <li>High-speed CRC calculation</li> <li>Optional feature to transpose input data and CRC result via transpose register, required on applications where bytes are in LSB format</li> </ul> | | Random Number Generator (RNGA) | <ul> <li>RNGA can be used along with software to attain NIST SP800-90 standards</li> <li>National Institute of Standards and Technology (NIST)-approved pseudorandom number generator <a href="http://csrc.nist.gov">http://csrc.nist.gov</a></li> <li>Supports the key generation algorithm defined in the Digital Signature Standard <a href="http://www.itl.nist.gov/fipspubs/fip186.htm">http://www.itl.nist.gov/fipspubs/fip186.htm</a></li> <li>Integrated entropy sources capable of providing the PRNG with entropy for its seed</li> </ul> | # 2.5.5 Analog modules The following analog modules are available on this device: Table 2-7. Analog modules | Module | Description | |------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Analog Front End (AFE) | <ul> <li>Four Independent 16-bit 2nd Order Sigma Delta ADC for simultaneous voltage and current sampling</li> <li>24-bit AFE dynamic range for energy calculations (after averaging)</li> <li>Two Continuous Time Programmable Gain Amplifiers (PGA)</li> <li>PGA with gains from 1x to 32x (1, 2, 4, 8, 16, and 32)</li> <li>Fixed Gain of 32 for shunt Resistor</li> <li>Final SD ADC sample rate selectable from 3 kHz to 96 kHz (3 kHz, 6 kHz, 12 kHz, 24 kHz, 48 KHz, 96 KHz) (OSR in range 2048x down to 64x)</li> <li>Modes of operation <ul> <li>Normal mode (Higher accuracy)</li> <li>Low power mode (lower accuracy)</li> </ul> </li> <li>On chip phase compensation and decimation</li> <li>Separate controls to enable or disable PGA, ADC, filters individually.</li> <li>Synchronized start of operation</li> <li>Supports current transformer, shunt resistor, Rogowski coil</li> <li>Supports current transformer, shunt resistor, Rogowski coil</li> <li>Support for interfacing with external Sigma Delta Modulators</li> <li>+/-250mV (1 Vpp differential, 0.5 Vpp single ended), input range for both differential and single ended inputs</li> </ul> <li>Temperature Stable 1.2V Voltage Reference @ 15 PPM (TBD)¹ with trim capability</li> <li>Conversion ready signals asserted when conversion results are moved to the corresponding result registers</li> <li>AFE clocked from dedicated PLL. Option to run AFE with other clock sources but at reduced accuracy.</li> <li>Optimized for IEC50470 Class C: 0.15-5(150)A and ANSI C 12.20 Class 0.1, 3-50(320)A</li> | ### woulles on the device ## Table 2-7. Analog modules (continued) | Module | Description | |---------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | High Speed Comparator (CMP) | <ul> <li>6-bit DAC programmable reference generator output</li> <li>Up to seven selectable comparator inputs; each input can be compared with any input by any polarity sequence</li> <li>Differential input on 2 comparator channels (CMP1) to support zero crossing detection on voltage channels of AFE. These can be used as stand alone channels also. CMP0 channels can be used to implement IrDA communication along with UART</li> <li>Selectable interrupt on rising edge, falling edge, or either rising or falling edges of comparator output</li> <li>Comparator output supports: <ul> <li>Sampled</li> <li>Windowed (ideal for certain PWM zero-crossing-detection applications</li> <li>Digitally filtered using external sample signal or scaled peripheral clock</li> </ul> </li> <li>Two performance modes: <ul> <li>Shorter propagation delay at the expense of higher power</li> <li>Low power, with longer propagation delay</li> </ul> </li> </ul> | | Voltage Reference (VREF) | <ul> <li>Operational in all MCU power modes</li> <li>Programmable trim register with 0.5 mV steps, automatically loaded with room temp value upon reset</li> <li>Programmable mode selection: <ul> <li>Off</li> <li>Bandgap out (or stabilization delay)</li> <li>Low-power buffer mode</li> <li>Tight-regulation buffer mode</li> </ul> </li> <li>1.2 V output with 15 ppm (TBD)<sup>1</sup> at room temperature</li> <li>Dedicated output pin</li> </ul> | | Analog-to-Digital Converter (SAR ADC) | • • | 1. Value will be updated based on Silicon results ### 2.5.6 Timer modules The following timer modules are available on this device: Table 2-8. Timer modules | Module | Description | |--------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Periodic Interrupt Timer (PIT) | <ul> <li>Up to two general purpose interrupt timers</li> <li>Up to two interrupt timers for triggering ADC conversions</li> <li>32-bit counter resolution</li> <li>Clocked by system clock frequency</li> <li>DMA support</li> </ul> | 53 ## Table 2-8. Timer modules (continued) | Module | Description | |------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Low Power Timer (LPTMR) | Operation as timer or pulse counter Selectable clock for prescaler/glitch filter 1 kHz internal LPO External low power crystal oscillator Internal reference clock (not available in low leakage power modes) Secondary external reference clock (for example, 32 kHz crystal) Configurable glitch filter or prescaler Interrupt generated on timer compare Hardware trigger generated on timer compare | | Independent Real Time Clock (iRTC) | <ul> <li>Independent Power Supply, POR with brownout detection and 32 kHz Crystal Oscillator</li> <li>On-chip Hardware Calendaring</li> <li>Programmable alarm with interrupt</li> <li>Hardware compensation to compensate the 1 Hz clock <ul> <li>Support for Coarse and Fine Compensation</li> </ul> </li> <li>32 bytes Battery backed Memory</li> <li>Support for upto 3 Passive external tampers</li> <li>Upto 2 Active Tamper pins</li> <li>Write Protection Mechanism</li> <li>Power Supply Glitch Detector</li> <li>Tamper Queue for storing upto 4 tamper events along with time stamp</li> <li>IRTC operation from 1.71V to 3.6V</li> <li>Ultra low power IRTC operation (&lt; 1μA)</li> </ul> | | Quad Timer (TMR) | <ul> <li>Four 16-bit counters/timers</li> <li>Counters are cascadable</li> <li>Max count rate equals peripheral clock for internal clocks</li> <li>Max count rate equals peripheral clock/2 for external clocks</li> <li>Programmable count modulo</li> <li>Count once or repeatedly</li> <li>Separate prescaler for each counter</li> <li>Each counter has capture and compare capability</li> </ul> | # 2.5.7 Communication interfaces The following communication interfaces are available on this device: ### woulles on the device ## **Table 2-9. Communication modules** | Module | Description | |-----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Serial Peripheral Interface (SPI) | <ul> <li>Master and slave mode</li> <li>Full-duplex, three-wire synchronous transfers</li> <li>Programmable transmit bit rate</li> <li>Double-buffered transmit and receive data registers</li> <li>Serial clock phase and polarity options</li> <li>Slave select output</li> <li>Mode fault error flag with CPU interrupt capability</li> <li>Control of SPI operation during wait mode</li> <li>Selectable MSB-first or LSB-first shifting</li> <li>Programmable 8-bit or 16-bit data transmission length</li> <li>Receive data buffer hardware match feature</li> <li>64-bit FIFO mode for high speed transfers of large amounts of data (SPI0 only)</li> <li>5V AMR support on one SPI (SPI1)</li> <li>Support for both transmit and receive by DMA</li> </ul> | | Inter-Integrated Circuit (I2C) | <ul> <li>Compatible with I2C bus standard and SMBus Specification Version 2 features</li> <li>Up to 100 kbps with maximum bus loading</li> <li>Multi-master operation</li> <li>Software programmable for one of 64 different serial clock frequencies</li> <li>Programmable slave address and glitch input filter</li> <li>Interrupt or DMA driven byte-by-byte data transfer</li> <li>Arbitration lost interrupt with automatic mode switching from master to slave</li> <li>Calling address identification interrupt</li> <li>Bus busy detection broadcast and 10-bit address extension</li> <li>Address matching causes wake-up when processor is in low power mode</li> </ul> | ## Table 2-9. Communication modules (continued) | | Description | |-----------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Jniversal Asynchronous Receiver/ Transmitter (UART) | Support for ISO 7816 protocol for interfacing with smart cards Full-duplex operation Standard mark/space non-return-to-zero (NRZ) format 13-bit baud rate selection with fractional divide of 32 Programmable 8-bit or 9-bit data format Separately enabled transmitter and receiver Programmable receive input polarity Programmable receive input polarity 13-bit break character option 11-bit break character detection option Parameterizable buffer support for one dataword for each transmit and receive Independent FIFO structure for transmit and receive Independent FIFO structure for transmit and receive Idle line wakeup Address mark 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 Interrupt-driven operation with 11 flags: Transmitter data buffer at or below watermark Transmission complete Receiver data buffer at or above watermark Idle receiver input Receiver overrun Receiver data buffer underflow Noise error Framing error Parity error Active edge on receive pin Receiver framing error detection Hardware parity generation and checking | ## 2.5.8 Human-machine interfaces The following Human-Machine Interfaces (HMI) are available on this device: ### woulles on the device ## Table 2-10. HMI modules | Module | Description | |-----------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Segment LCD(SLCD) | LCD waveforms functional in low-power modes Up to 44 LCD pins with selectable front plane/back plane configuration Generate up to 40 front plane signals Generate up to 8 back planes signals Programmable LCD frame frequency Programmable blink modes and frequency All segments blank during blink period Alternate display for each LCD segment in x4 or less mode Blink operation in low-power modes Programmable LCD power supply switch, making it an ideal solution for battery-powered and board-level applications Charge pump requires only four external capacitors Internal LCD power using VDD Internal VIREG regulated power supply option for 3 V LCD glass External VLL3 power supply option (3 V) Internal-regulated voltage source with a 4-bit trim register to apply contrast control Integrated charge pump for generating LCD bias voltages Hardware-configurable to drive 3 V LCD panels On-chip generation of bias voltages Waveform storage registers Backplane reassignment to assist in vertical scrolling on dot-matrix displays Software-configurable LCD frame frequency interrupt | | Enhanced general purpose input/out<br>(eGPIO) | <ul> <li>Programmable glitch filter on up to 8 input pins and interrupt with selectable polarity on all input pins</li> <li>Independent pin value register to read logic level on digital pin</li> <li>Configurable data direction &amp; pin enable on all pins</li> <li>Protected access to all GPIO registers</li> <li>Dual access to GPIO registers</li> <li>Single cycle access with zero wait states (IOPORT access)</li> <li>Access via AIPS slave port (non-zero wait states)</li> </ul> | # **Chapter 3 Chip Configuration** ### 3.1 Introduction This chapter provides details on the individual modules of the micro-controller. It includes: - module block diagrams - specific module-to-module interactions, instantiation information, clocking requirements, module-to-IO interactions, and - links for more information. ### 3.2 Core modules ## 3.2.1 ARM Cortex-M0+ 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. KM Family Reference Manual, Rev. 5, Oct 2013 57 Figure 3-1. Core configuration Table 3-1. Reference links to related information | Topic | Related module | Reference | |------------------------------------|---------------------------------------------------|------------------------------------------------------------------------------| | Full description | ARM Cortex-M0+ core | ARM Cortex-M0+ Technical Reference Manual can be found at http://www.arm.com | | System memory map | _ | System memory map | | Clocking | _ | Clocking | | Power management | _ | Power mangement | | System/instruction/data bus module | Crossbar switch | Crossbar switch | | Debug | Serial Wire Debug<br>(SWD) | Debug | | Interrupts | Nested Vectored<br>Interrupt Controller<br>(NVIC) | NVIC | ## 3.2.2 ARM Cortex M0+ core The ARM Cortex M0+ parameter settings are as follows: Table 3-2. ARM Cortex-M0+ parameter settings | Parameter | Verilog name | Value | Description | |------------------------|--------------|-------------|-----------------------------------------------------------------| | Arch Clock Gating | ACG | 1 = Present | Implements architectural clock gating | | DAP Slave Port Support | AHBSLV | 1 | Supports any AHB debug access port (like the CM4 DAP) | | DAP ROM Table Base | BASEADDR | 0xF000_2003 | Base address for DAP ROM table | | Endianess | BE | 0 | Little endian control for data transfers | | Breakpoints | BKPT | 2 | Implements 2 breakpoints | | Debug Support | DBG | 1 = Present | _ | | Halt Event Support | HALTEV | 1 = Present | _ | | I/O Port | IOP | 1 = Present | Implements single-cycle ld/st accesses to special address space | 59 | <b>Table 3-2.</b> | ARM Cortex-M0+ | parameter settings | (continued) | ) | |-------------------|----------------|--------------------|-------------|---| |-------------------|----------------|--------------------|-------------|---| | Parameter | Verilog name | Value | Description | |------------------------------|--------------|--------------|----------------------------------------------------------------| | IRQ Mask Enable | IRQDIS | 0x00000000 | Assume (for now) all 32 IRQs are used (set if IRQ is disabled) | | Debug Port Protocol | JTAGnSW | 0 = SWD | SWD protocol, not JTAG | | Core Memory Protection | MPU | 0 = Absent | No MPU | | Number of IRQs | NUMIRQ | 32 | Assume full NVIC request vector | | Reset all registers | RAR | 0 = Standard | Do not force all registers to be async reset | | Multiplier | SMUL | 0 = Fast Mul | Implements single-cycle multiplier | | Multi-drop Support | SWMD | 0 = Absent | Do not include serial wire support for multi-<br>drop | | System Tick Timer | SYST | 1 = Present | Implements system tick timer (for CM4 compatibility) | | DAP Target ID | TARGETID | 0 | _ | | User/Privileged | USER | 1 = Present | Implements processor operating modes | | Vector Table Offset Register | VTOR | 1 = Present | Implements relocation of exception vector table | | WIC Support | WIC | 1 = Present | Implements WIC interface | | WIC Requests | WICLINES | 34 | Exact number of wake-up IRQs is 34 | | Watchpoints | WPT | 2 | Implements two watchpoints | For details on the ARM Cortex-M0+ processor core, see the ARM website: arm.com. ## 3.2.3 Buses, interconnects, and interfaces The ARM Cortex-M0+ core has two system bus interfaces: - Single 32-bit AMBA-3 AHB-Lite system interface that provides connections to all system memory (flash, RAM) and peripherals - Single 32-bit I/O Port bus interfacing to the device pads (all GPIO pins) with 1-cycle loads and stores. This port is connected to eGPIO module. ## 3.2.4 Debug facilities KM family of devices supports the standard ARM 2-pin Serial Wire Debug (SWD) debug port only, which provides an efficient pin interface. ## 3.2.5 Interrupt priority levels This device supports four priority levels for interrupts in the NVIC. ## 3.2.6 Performance targets This device targets maximum core operating frequency of 50 MHz. The CM0+ core is a high efficient processor core achieving 0.95 DMIPS/MHz when executing from single-cycle access memories. ## 3.2.7 Nested Vectored Interrupt Controller (NVIC) configuration This section summarizes how the module has been configured in the chip. Full documentation for this module is provided by ARM and can be found at http://www.arm.com Figure 3-2. NVIC configuration Table 3-3. Reference links to related information | Topic | Related module | Reference | |------------------------------|---------------------------------------------------|------------------------------------------------------------------------------| | Full description | Nested Vectored<br>Interrupt Controller<br>(NVIC) | ARM Cortex-M0+ Technical Reference Manual can be found at http://www.arm.com | | System memory map | _ | System memory map | | Clocking | _ | Clocking | | Power management | _ | Power mangement | | Private Peripheral Bus (PPB) | ARM Cortex-M0+ core | ARM Cortex-M0+ core | ## 3.2.7.1 Interrupt priority levels This device supports 4 priority levels for interrupts. Therefore, in the NVIC each source in the IPR registers contains 2 bits. For example, IPR0 is shown below: ### 3.2.7.2 Non-maskable interrupt The non-maskable interrupt request to the NVIC is controlled by the external $\overline{\text{NMI}}$ signal. The pin on which the $\overline{\text{NMI}}$ signal is multiplexed on, must be configured for the $\overline{\text{NMI}}$ function to generate the non-maskable interrupt request. ### 3.2.7.3 Interrupt Channel Assignments The interrupt vector assignments are defined in the following table. - Vector number the value stored on the stack when an interrupt is serviced - IRQ number non-core interrupt source count, which is the vector number minus 16 The IRQ number is used within ARM's NVIC documentation. Table 3-5. Interrupt vector assignments | Address | Vector | IRQ number | Source module | Source description | | |-------------|------------------------------|------------|---------------------|------------------------------------------------------|--| | | | ARM Core S | ystem Handler Vecto | ors | | | 0x0000_0000 | 0 | - | ARM core | Initial Stack Pointer | | | 0x0000_0004 | 1 | _ | ARM core | Initial Program Counter | | | 0x0000_0008 | 2 | _ | ARM core | Non-Maskable Interrupt (NMI) | | | 0x0000_000C | 3 | - | ARM core | Hard Fault | | | 0x0000_0010 | 4 | _ | _ | _ | | | 0x0000_0014 | 5 | _ | _ | _ | | | 0x0000_0018 | 6 | _ | _ | _ | | | 0x0000_001C | 7 | _ | _ | _ | | | 0x0000_0020 | 8 | _ | _ | _ | | | 0x0000_0024 | 9 | _ | _ | _ | | | 0x0000_0028 | 10 | _ | _ | _ | | | 0x0000_002C | 11 | _ | ARM core | Supervisor call (SVCall) | | | 0x0000_0030 | 12 | _ | _ | _ | | | 0x0000_0034 | 13 | _ | _ | _ | | | 0x0000_0038 | 14 | - | ARM core | Pendable request for system service (PendableSrvReq) | | | 0x0000_003C | 15 | _ | ARM core | System tick timer (SysTick) | | | | Non-Core On Platform Vectors | | | | | | 0x0000_0040 | 16 | 0 | DMA | DMA channel 0 transfer complete | | | 0x0000_0044 | 17 | 1 | DMA | DMA channel 1 transfer complete | | | 0x0000_0048 | 18 | 2 | DMA | DMA channel 2 transfer complete | | | 0x0000_004C | 19 | 3 | DMA | DMA channel 3 transfer complete | | Core modules Table 3-5. Interrupt vector assignments (continued) | Address | Vector | IRQ number | Source module | Source description | | |-------------|--------------------------|------------|---------------|-------------------------------------------------------------|--| | | Off Platform IRQ Vectors | | | | | | 0x0000_0050 | 20 | 4 | SPI0 | ORed Interrupt SPI0 | | | 0x0000_0054 | 21 | 5 | SPI1 | ORed Interrupt SPI1 | | | 0x0000_0058 | 22 | 6 | PMC | Low-voltage detect, low-voltage warning | | | 0x0000_005C | 23 | 7 | TMR_0 | Quad Timer Channel0 | | | 0x0000_0060 | 24 | 8 | TMR_1 | Quad Timer Channel1 | | | 0x0000_0064 | 25 | 9 | TMR_2 | Quad Timer Channel2 | | | 0x0000_0068 | 26 | 10 | TMR_3 | Quad Timer Channel3 | | | 0x0000_006C | 27 | 11 | PIT0/PIT1 | ORed Interrupt of PITs | | | 0x0000_0070 | 28 | 12 | LLWU | Low Leakage Wakeup | | | 0x0000_0074 | 29 | 13 | Flash | ORed interrupt for Flash Command<br>Complete/Read collision | | | 0x0000_0078 | 30 | 14 | CMP0/CMP1 | ORed Interrupt of PRACMP | | | 0x0000_007C | 31 | 15 | SLCD | ORed Interrupt of SLCD | | | 0x0000_0080 | 32 | 16 | ADC | ORed Interrupt from SAR | | | 0x0000_0084 | 33 | 17 | PTx | ORed Interrupt from all GPIO (PTx) ports | | | 0x0000_0088 | 34 | 18 | RNGA | ORed Interrupt from RNGA | | | 0x0000_008C | 35 | 19 | UART0/UART1 | ORed Interrupt UART0 and UART1 | | | 0x0000_0090 | 36 | 20 | UART2/UART3 | ORed Interrupt UART2 and UART3 | | | 0x0000_0094 | 37 | 21 | AFE_CH0 | AFE Channel 0 ORed Interrupt | | | 0x0000_0098 | 38 | 22 | AFE_CH1 | AFE Channel 1 ORed Interrupt | | | 0x0000_009C | 39 | 23 | AFE_CH2 | AFE Channel 2 ORed Interrupt | | | 0x0000_00A0 | 40 | 24 | AFE_CH3 | AFE Channel 3 ORed Interrupt | | | 0x0000_00A4 | 41 | 25 | iRTC | iRTC Interrupt | | | 0x0000_00A8 | 42 | 26 | I2C0/I2C1 | ORed I2C interrupt | | | 0x0000_00AC | 43 | 27 | EWM | External Watchdog Monitor | | | 0x0000_00B0 | 44 | 28 | MCG | MCG Loss of Clock, Loss of Lock | | | 0x0000_00B4 | 45 | 29 | WDOG | ORed WDOG Interrupt | | | 0x0000_00B8 | 46 | 30 | LPTMR | ORed LPTMR Interrupt | | | 0x0000_00BC | 47 | 31 | XBAR | Peripheral XBAR ORed Interrupt | | # 3.2.8 Asynchronous Wake-up Interrupt Controller (AWIC) 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-3. Asynchronous Wake-up Interrupt Controller configuration Table 3-6. Reference links to related information | Topic | Related module | Reference | |-------------------|---------------------------------------------------|----------------------| | System memory map | _ | System memory map | | Clocking | _ | Clocking | | Power management | _ | Power mangement | | | Nested Vectored<br>Interrupt Controller<br>(NVIC) | NVIC | | Wake-up requests | _ | AWIC wake-up sources | ## 3.2.8.1 Wake-up sources The device uses the following internal and external inputs to the AWIC module. Table 3-7. AWIC Stop and VLPS Wake-up Sources | Wake-up source | Description | | |-------------------------|------------------------------------------------------------------------------------------|--| | Available system resets | RESET pin and WDOG when LPO is its clock source | | | Low-voltage detect | Mode Controller <sup>1</sup> | | | Low-voltage warning | Mode Controller <sup>1</sup> | | | Pin interrupts | Port Control Module - Any enabled pin interrupt is capable of waking the system | | | ADCx | The ADC is functional when using internal clock source | | | СМРх | Since no system clocks are available, functionality is limited | | | I <sup>2</sup> C | Address match wakeup (on all I <sup>2</sup> Cs) | | | UART | Active edge on RXD (on all UARTs) | | | LPTMR | Functional in Stop/VLPS modes | | | iRTC Interrupt | Functional in Stop/VLPS modes (this includes the tamper event) | | | iRTC Alarm | Functional in Stop/VLPS modes | | | AFE | Optionally active in Stop/VLPS modes | | | NMI | NMI_B functionality enabled on PTA4 pin | | | MCG | MCG Loss of clock and loss of lock interrupts, if configured appropriately. <sup>2</sup> | | #### **System modules** - 1. Only in STOP mode. LVD, LVW disabled in VLPS mode. - 2. Only in STOP mode. ### NOTE Any module that is Optionally active in STOP/VLPS modes and capable of generating asynchronous interrupt can wakeup the system. The above table lists the sources which must be available. ## 3.3 System modules ## 3.3.1 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-4. SIM configuration Table 3-8. Reference links to related information | Topic | Related module | Reference | |-------------------|----------------|-------------------| | Full description | SIM | SIM | | System memory map | | System memory map | | Clocking | | Clocking | | Power management | | Power mangement | ## 3.3.2 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. 65 Figure 3-5. PMC configuration Table 3-9. Reference links to related information | Topic | Related module | Reference | |-------------------|-----------------------------------|------------------------| | Full description | PMC | PMC | | System memory map | | System memory map | | Power management | | Power mangement | | Full description | System Mode<br>Controller (SMC) | System Mode Controller | | | Low-Leakage Wakeup<br>Unit (LLWU) | LLWU | | | Reset Control Module<br>(RCM) | Reset | # 3.3.3 Low-Leakage Wake-up 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-6. Low-Leakage Wake-up Unit configuration Table 3-10. Reference links to related information | Topic | Related module | Reference | |-------------------|--------------------------------------|-----------------------------------| | Full description | LLWU | LLWU | | System memory map | | System memory map | | Clocking | | Clocking | | Power management | | Power mangement | | | Power Management<br>Controller (PMC) | Power Management Controller (PMC) | | | Mode Controller | SMC | | Wake-up requests | | LLWU wake-up sources | ## 3.3.3.1 Wakeup Sources The LLWU module has the following internal and external inputs. LLWU\_P0-LLWU\_P15 are external pin inputs, and module interrupt flags (M0IF-M4IF) are internal peripheral connections. ### NOTE - The RESET pin is also a wakeup source when the pin is enabled as RESET or GPIO via port mux control. - Any input function muxed along with the LLWU\_Px pin will cause wakeup Table 3-11. LLWU Inputs | Wakeup Pin | Source | Wakeup Pin | Source | |------------|----------------------------------|------------|------------------------------------------------------| | LLWU_P0 | LCD13/PTG6/LLWU_P0/LPTMR2 | _ | CMP0P1/PTD2/UART1_RxD/SPI0_SCK/<br>XBAR_IN3/LLWU_P10 | | LLWU_P1 | LCD9/AD11/PTG2/SPI0_SS_B/LLWU_P1 | _ | CMP0P0/PTD0/UART0_RxD/XBAR_IN2/<br>LLWU_P11 | | LLWU_P2 | LCD8/AD10/PTG1/LLWU_P2/LPTMR0 | LLWU_P12 | AD0/PTC5/UART0_RTS/LLWU_P12 | ### Table 3-11. LLWU Inputs (continued) | Wakeup Pin | Source | Wakeup Pin | Source | |------------|-----------------------------------------------------|------------|------------------------------------------| | LLWU_P3 | LCD5/PTF6/SPI1_MOSI/I2C1_SDA/<br>LLWU_P3 | LLWU_P13 | LCD42/CMP0P3/PTC3/UART3_RxD/<br>LLWU_P13 | | LLWU_P4 | AD7/PTF0/RTCCLKOUT/QT2/CMP0OUT/<br>LLWU_P4 | LLWU_P14 | LCD29/PTA6/XBAR_IN0/LLWU_P14 | | LLWU_P5 | CMP0P2/PTE6/XBAR_IN5/UART2_RxD/<br>LLWU_P5/SWD_IO | LLWU_P15 | LCD27/PTA4/LLWU_P15/NMI_B | | LLWU_P6 | PTE5/QT3/UART2_RTS/EWM_OUT/<br>LLWU_P6 | LLWU_M0IF | LPTMR0 <sup>1</sup> | | LLWU_P7 | CMP0P4/PTD7/I2C0_SCL/XBAR_IN4/<br>UART3_RxD/LLWU_P7 | LLWU_M1IF | iRTC Alarm <sup>1</sup> | | LLWU_P8 | AD5/PTD6/LPTMR1/CMP1OUT/<br>UART3_RTS/LLWU_P8 | LLWU_M2IF | CMP0 <sup>1</sup> | | LLWU_P9 | AD3/PTD4/UART1_RTS/SPI0_MISO/ | LLWU_M3IF | iRTC Interrupt <sup>1</sup> | | LLWU_P9 | | LLWU_M4IF | CMP1 <sup>1</sup> | <sup>1.</sup> 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.3.4 Crossbar-Light Switch Configuration The AHB Crossbar Switch (or AXBS) allows connection between multiple masters with different slaves and performs arbitration between them. On this device the AXBS connects two masters with three slaves. The following figure shows the AXBS configuration. #### **System modules** Figure 3-7. AXBS Configuration Table 3-12. Reference links to related information | Topic | Related module | Reference | |--------------------------------------------|-----------------|---------------------| | Full description | Crossbar switch | Crossbar switch | | System memory map | | System memory map | | Clocking | | Clocking | | Memory protection | MPU | MPU | | Crossbar switch master ARM Cortex-M0+ core | | ARM Cortex-M0+ core | # 3.3.4.1 Crossbar Switch Master Assignments The master assignment is as follows: **Table 3-13. AXBS Master Assignments** | Master Module | Master Port Number | | |---------------|--------------------|--| | ARM M0+ Core | 0 | | | DMA | 2 | | 69 ## 3.3.4.2 Crossbar Switch Slave Assignments This device contains 3 slaves connected to the crossbar switch. Flash & SRAM controllers modules are protected by the MPU. AIPS peripheral bridge is not protected by MPU as it has its own protection built-in. The slave assignment is as follows: **Table 3-14. AXBS Slave Assignments** | Slave Module | Slave Port Number | |--------------------------|-------------------| | Flash Memory Controller | 0 | | SRAM Controller | 1 | | AIPS (Peripheral Bridge) | 2 | ## 3.3.5 DMA request multiplexer (DMA MUX) 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. DMA request multiplexer configuration Table 3-15. Reference links to related information | Topic | Related module | Reference | |-------------------|-------------------------|-------------------| | Full description | DMA request multiplexer | DMA Mux | | System memory map | | System memory map | | Clocking | | Clocking | | Power management | | Power mangement | ### 3.3.5.1 DMA Request Sources The DMA Request mux allows up to 64 DMA request signals to be mapped to the 4 channels of the DMA Controller. KM Family Reference Manual, Rev. 5, Oct 2013 #### System modules This device includes four DMA request MUXes that allows up to 64 DMA request signals to be mapped to any of the 4 DMA channels. There is one DMA Mux module for each channel of DMA. To allow for flexibility and optimal usage of the available DMA channels some of the DMA request sources are available on more than 1 DMA mux. Because of the mux there is not a hard correlation between any of the DMA request sources and a specific DMA channel. The DMA request sources for this device are muxed as described in table below. Table 3-16. DMA request sources | Request ID | DMA Channel 0<br>Assignment | DMA Channel 1<br>Assignment | DMA Channel 2<br>Assignment | DMA Channel 3<br>Assignment | |------------|-----------------------------|-----------------------------|-----------------------------|-----------------------------| | 0 | Disabled | Disabled | Disabled | Disabled | | 1 | SPI0_Tx | SPI0_Tx | SPI1_Tx | SPI1_Tx | | 2 | SPI0_Rx | SPI0_Rx | SPI1_Rx | SPI1_Rx | | 3 | UART0_Tx | UART1_Tx | UART1_Tx | UART0_Tx | | 4 | UART0_Rx | UART1_Rx | UART1_Rx | UART0_Rx | | 5 | I2C0 | I2C0 | I2C1 | I2C1 | | 6 | XBAR | XBAR | XBAR | XBAR | | 7 | UART3_Tx | UART3_Tx | UART2_Tx | UART2_Tx | | 8 | UART3_Rx | UART3_Rx | UART2_Rx | UART2_Rx | | 9 | AFE_CH0 | AFE_CH0 | AFE_CH1 | AFE_CH1 | | 10 | TMR_0 | TMR_0 | TMR_2 | TMR_2 | | 11 | TMR_3 | TMR_3 | TMR_1 | TMR_1 | | 12 | AFE_CH2 | AFE_CH2 | AFE_CH3 | AFE_CH3 | | 13 | ADC | PTE | PTI | ADC | | 14 | CMP0 | CMP0 | CMP1 | CMP1 | | 15 | PTE | PTF | PTG | PTH | | 16 | PTA | PTB | PTC | PTD | | 17 | Always Enabled | Always Enabled | Always Enabled | Always Enabled | | 18 | Always Enabled | Always Enabled | Always Enabled | Always Enabled | **Asynchronous DMA sources:** The following module are capable of generating asynchronous DMA request. - Analog Front End (AFE) - Comparators - SAR ADC - GPIO Control Module (PCTL) 71 ## 3.3.6 External Watchdog Monitor (EWM) 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. External Watchdog Monitor configuration Table 3-17. Reference links to related information | Topic | Related module | Reference | |---------------------|------------------------------------|---------------------| | Full description | External Watchdog<br>Monitor (EWM) | EWM | | System memory map | | System memory map | | Clocking | | Clocking | | Power management | | Power mangement | | Signal multiplexing | Port Control Module | Signal multiplexing | ### 3.3.6.1 Clock Connections This table shows the EWM clocks and the corresponding chip clocks. Table 3-18. EWM clock connections | Module clock | Chip clock | | |-----------------|-------------------------|--| | Low Power Clock | 1 kHz LPO Clock | | | Alternate Clock | 32 kHz Oscillator Clock | | ### 3.3.6.2 Low Power Modes This table shows the EWM low-power modes and the corresponding chip low-power modes. KM Family Reference Manual, Rev. 5, Oct 2013 Table 3-19. EWM low-power modes | Module mode | Chip mode | |-------------|----------------------------| | Wait | Wait, VLPW | | Stop | Stop, VLPS | | Power Down | VLLS3, VLLS2, VLLS1, VLLS0 | ### 3.3.6.3 **EWM\_OUT** pin state in Low Power Modes During Wait, Stop and Power Down modes the EWM\_OUT pin enters a high-impedance state. A user has the option to control the logic state of the pin using an external pull device or by configuring the internal pull device. When the CPU enters a Run mode from Wait or Stop recovery, the pin resumes its previous state before entering Wait or Stop mode. When the CPU enters Run mode from Power Down, the pin returns to its reset state. ## 3.3.7 Watchdog 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. Watchdog configuration Table 3-20. Reference links to related information | Topic | Related module | Reference | |-------------------|----------------------|------------------------| | Full description | Watchdog | WDOG | | System memory map | | System memory map | | Clocking | | Clocking | | Power management | | Power mangement | | | Mode Controller (MC) | System Mode Controller | ## 3.3.7.1 Watchdog configuration Table 3-21. Watchdog configuration | Description | Value | |-----------------------------------------------------------------------------|--------| | Default Value for WDOG Timer High | 0x004C | | Default Value for WDOG Timer High | 0x4B40 | | Watchdog Configuration Time (in number of bus clocks) | 256 | | Time allowed in between the two writes of the unlock and refresh sequences. | 20 | ### 3.3.7.2 Clock Connections This table shows the WDOG module clocks and the corresponding chip clock connections. Table 3-22. WDOG clock connections | Module clock | Chip clock | | |------------------|---------------------------|--| | LPO Oscillator | 1 kHz LPO Clock | | | Alt Clock | 32 kHz Clock <sup>1</sup> | | | Fast Test Clock | Bus Clock | | | System Bus Clock | Bus Clock | | <sup>1.</sup> Can be either 32k OSC clock, 32k IRC clock # 3.3.8 Inter-Peripheral Crossbar Switch (XBAR) 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. Table 3-23. Reference links to related information | Topic | Related module | Reference | |---------------------|---------------------|-----------------------| | Full description | XBAR | XBAR | | System memory map | | System memory map | | Clocking | | Clocking distribution | | Power management | | Power mangement | | Signal multiplexing | SIM's GPS registers | Signal multiplexing | **System modules** # 3.3.8.1 Peripheral Interconnects The XBAR has the following connection to various peripherals or device IOs. The XBAR Inputs can be configured to connected to XBAR Outputs as per application requirements. Table 3-24. XBAR Interconnects | No. | XBAR Inputs | XBAR Outputs | | |-----|------------------------------------------------------------------|--------------------------------------------------------------|--| | 0 | Logic 1 (VDD) | XBAR DMA request or Interrupt <sup>1</sup> | | | 1 | Logic 0 (VSS) | External modulator data input for AFE Channel 02 | | | 2 | AFE master clock output <sup>3</sup> | External modulator data input for AFE Channel 12 | | | 3 | AFE modulator data output <sup>4</sup> | External modulator data input for AFE Channel 2 <sup>2</sup> | | | 4 | LPTimer Output | External modulator data input for AFE Channel 32 | | | 5 | Clock Output <sup>5</sup> | Quad Timer channel 0 secondary input <sup>6</sup> | | | 6 | Quad Timer channel 0 output | Quad Timer channel 1 secondary input <sup>6</sup> | | | 7 | Quad Timer channel 1 output | Quad Timer channel 2 secondary input <sup>6</sup> | | | 8 | Quad Timer channel 2 output | Quad Timer channel 3 secondary input <sup>6</sup> | | | 9 | Quad Timer channel 3 output | Quad Timer primary clock input 1 | | | 10 | iRTC Clock Output <sup>7</sup> | Quad Timer primary clock input 2 | | | 11 | CMP0 Output | CMP0 Sample Window input | | | 12 | CMP1 Output | CMP1 Sample Window input | | | 13 | iRTC Alarm Output | UART Rx Input <sup>8</sup> | | | 14 | UART TX Output (after modulation) <sup>9</sup> | UART Tx Modulation Output <sup>10</sup> | | | 15 | EWM Output (EWM_OUT) | SAR ADC trigger select A pulse <sup>11</sup> | | | 16 | PIT Output <sup>12</sup> | SAR ADC trigger select B pulse <sup>11</sup> | | | 17 | XBAR Input pin 0 | XBAR Output pin 0 | | | 18 | XBAR Input pin 1 | XBAR Output pin 1 | | | 19 | XBAR Input pin 2 | XBAR Output pin 2 | | | 20 | XBAR Input pin 3 | XBAR Output pin 3 | | | 21 | XBAR Input pin 4 | XBAR Output pin 4 | | | 22 | XBAR Input pin 5 | XBAR Output pin 5 | | | 23 | XBAR Input pin 6 | XBAR Output pin 6 | | | 24 | XBAR Input pin 7 | XBAR Output pin 7 | | | 25 | XBAR Input pin 8 | XBAR Output pin 8 | | | 26 | SAR ADC conversion complete flag | SAR ADC trigger select C pulse <sup>11</sup> | | | 27 | ORed conversion complete flag for all AFE channels <sup>13</sup> | ADC trigger select D pulse <sup>11</sup> | | | 28 | AFE Channel 0 conversion complete | AFE Channel 0 Trigger | | | 29 | AFE Channel 1 conversion complete | AFE Channel 1 Trigger | | | 30 | AFE Channel 2 conversion complete | AFE Channel 2 Trigger | | | 31 | AFE Channel 3 conversion complete | AFE Channel 3 Trigger | | | 32 | DMA Done Signal <sup>14</sup> | EWM input (EWM_IN) | | <sup>1.</sup> DMA or Interrupt selectable inside XBAR <sup>2.</sup> Clock input for $\Sigma\Delta$ ADC will not be routed from XBAR. - 3. This is the modulator clock output from AFE. - 4. User configurable selection of modulator output. One of the following will be selected: - ΣΔ modulator 0 data output - ΣΔ modulator 1 data output - ΣΔ modulator 2 data output - ΣΔ modulator 3 data output - 5. Clock out is configurable to select one of the following clocks (NOTE: This selection does not drive CLKOUT pin): - Core Clock (gated in WAIT) - Flash Clock - · Bus Clock - IRC Clock - PLL Clock - · 32 kHz Osc clock - MHz Osc clock - 1 kHz LPO clock - 6. The XBAR should not be configured to have any of Quad Timer channel's outputs driving any of the channel's secondary inputs - 7. iRTC Clock out is configurable to select one of the following clocks (NOTE: This selection is different from clock selection in iRTC which drives iRTCLKOUT): - · 32 kHz Osc clock - Fine 1 Hz Clock (after fine compensation) - Coarse 1 Hz Clock (clock running the counters) - 8. Comparator 0 output routed to this output for IrDA. Connects to UART Rx module input which is selected by software. SIM registers provide for selection of UART for IrDA. Common selection for Rx & Tx - This is user selectable. This is output via XBAR according to UART selected. Software should select correct UART & XBAR output pin. - 10. This signal is used to modulate the UART Tx output. - 11. Generates the trigger to SAR. Separate trigger for each result register. See SAR Chapter for details on triggering. - 12. User configurable to select either PIT0 or PIT1 output. SIM register provides section between PIT0 and PIT1. - 13. For cases where $\Sigma\Delta s$ work independently - 14. User configurable to select DMA Done signal from any channel. DMA Done signal will not work when DMA transfer is initiated using DMA\_DCRn[START] bit. #### **NOTE** All interconnections required in XBAR must be done before any other peripheral is enabled. ### 3.3.8.2 Quad Timer (or TMR) Source Configuration The figure below shows how the various inputs for TMR can be select. The first level of selection is via SIM and final selection is in TMR. Both must be configured for proper functioning ວyຣເem modules Figure 3-11. TMR and XBAR connection #### NOTE - For frequencies >= bus clock; the primary path (XBAR --> TMR\_clk) can be used to select the TMR\_CLK. - For frequencies < bus clock (! Not == bus clock); the TMR\_CLK can be selected through the secondary input. # 3.3.8.3 Number of inputs and outputs This device has one instance of the XBAR. There is only 1 interrupt/DMA request signal output from this crossbar. The dedicated XBAR chapters refer to each instance's number of inputs as NUM\_IN or N and number of outputs as NUM\_OUT or M. The following table identifies the values. Table 3-25. XBAR inputs and outputs | XBAR instance | Number of inputs (NUM_IN or N) | Number of outputs (NUM_OUT or M) | | |---------------|--------------------------------|----------------------------------|--| | XBAR | 33 | 33 | | # 3.4 Memories and Memory Interfaces ### 3.4.1 RAM sizes This device contains 16KB of RAM on all devices. The RAM supports single cycle access (zero wait states) at all core speeds. # 3.4.2 Flash Memory Sizes KM family has a single array of 128 KBytes of flash memory. The flash access time supports two cycle reads at the maximum CPU frequency (50 MHz; 2:1). The access time is reduced to single cycle as the operating speed is decreased (=< 25 MHz; 1:1). The flash on KM devices does not contain any Flex Memory. As a result the PGMSEC command will not be available to program the Flash. On various phantoms, 64 KBytes of Flash memory will be supported. The phantom information will be stored in the Flash's IFR ILAD (illegal address) error will be be generated for any access to upper 64 KByte Flash memory. ### 3.5 Clock Modules # 3.5.1 RTC OSC 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. ວecurity Figure 3-12. RTC OSC configuration Table 3-26. Reference links to related information | Topic | Related module | Reference | |---------------------|----------------|---------------------| | Full description | RTC OSC | RTC OSC | | Signal multiplexing | Port control | Signal multiplexing | | Full description | MCG | MCG | #### NOTE Refer to section RTC General Purpose Data Register # 3.6 Security # 3.6.1 CRC 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-13. CRC configuration Table 3-27. Reference links to related information | Topic | Related module | Reference | |-------------------|----------------|-------------------| | Full description | CRC | CRC | | System memory map | | System memory map | | Power management | | Power mangement | # 3.6.2 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-14. RNG configuration Table 3-28. Reference links to related information | Topic | Related module | Reference | |-------------------|----------------|--------------------| | Full description | RNG | RNGA | | System memory map | | System memory map | | Clocking | | Clock distribution | | Power management | | Power mangement | ### 3.6.2.1 Overview KM family includes one instance of the RNGA module which can be used along with software to attain NIST SP800-90 standards. A change request on the IP has been raised to make the SLP bit inside the IP to 1 so as to reduce the power consumption of MCU during boot. By not having this SLP bit set to 1, the inverter chain inside IP starts to toggle by default after reset de-assertion and this caused MCU current to increase significantly and this bit could be set to 0 by software only in Photon 1.0. This is quite late and startup current for MCU is required to be low immediately after power up and during boot. This change has been implement in Photon 2.0 silicon. # 3.7 Analog ### 3.7.1 16-bit SAR ADC 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-15. 16-bit SAR ADC Table 3-29. Reference links to related information | Topic | Related module | Reference | |---------------------|----------------|---------------------| | Full description | 16-bit SAR ADC | 16-bit SAR ADC | | System memory map | | System memory map | | Clocking | | Clocking | | Power management | | Power mangement | | Signal multiplexing | Port control | Signal multiplexing | ### 3.7.1.1 Instantiation This device contains one 16-bit SAR ADC with 12 single ended channels (AD11 - AD0; number varies on each package) and 4 result registers. The reference voltage option for this ADC are discussed in Reference Options section. # 3.7.1.2 DMA Support on SAR ADC Applications that may require continuous sampling of the ADC, may have considerable load on the CPU. The ADC supports DMA request functionality for higher performance when the ADC is sampled at a very high rate. The ADC can trigger the DMA (via DMA req) on conversion completion. ## 3.7.1.3 Connections/Channel Assignment ### 3.7.1.3.1 Channel Assignments The following table describes all the connections to SAR ADC channels. Unused channels shall be connected to SAR VREFL. #### **NOTE** Channels 0 - 3 do not have a mux in their path while other channels are muxed before being connected to SAR. Channel 0 - 3 are expected to give better performance compared to muxed channels. Table 3-30. SAR ADC Channel Assignments | Channel<br>Number | Assignment | Description | | |-------------------|------------|-----------------------------|--| | 0 | AD3 | Single ended input from pin | | | 1 | AD6 | Single ended input from pin | | | 2 | AD8 | Single ended input from pin | | | 3 | AD9 | Single ended input from pin | | | 4 | VLL1 | LCD VLL1 Voltage | | | 5 | VCAP1 | LCD VCAP1 Voltage | | | 6 | AD0 | Single ended input from pin | | | 7 | AD1 | Single ended input from pin | | | 8 | VLL2 | LCD VLL2 Voltage | | | 9 | VCAP2 | LCD VCAP1 Voltage | | Table continues on the next page... **connections/Channel Assignment** Table 3-30. SAR ADC Channel Assignments (continued) | Channel<br>Number | Assignment | Description | | |-------------------|--------------------|-------------------------------|--| | 10 | AD2 | Single ended input from pin | | | 11 | AD4 | Single ended input from pin | | | 12 | PMC_VDD | VDD supply from PMC | | | 13 | PMC_VDD_SW | Switched VDD supply from PMC | | | 14 | SAR_VDDA | VDDA supply for SAR | | | 15 | AD5 | Single ended input from pin | | | 16 | AD7 | Single ended input from pin | | | 17 | CMP0 DAC Out | CMP0 DAC output voltage | | | 18 | CMP1 DAC Out | CMP1 DAC output voltage | | | 19 | AD10 | Single ended input from pin | | | 20 | AD11 | Single ended input from pin | | | 21 | Unused | Reserved for future expansion | | | 22 | Unused | Reserved for future expansion | | | 23 | Unused | Reserved for future expansion | | | 24 | Unused | Reserved for future expansion | | | 25 | Unused | Internal to SAR ADC | | | 26 | Temperature Sensor | Internal to SAR ADC | | | 27 | PMC 1V Bandgap | Internal to SAR ADC | | | 28 | Unused | Internal to SAR ADC | | | 29 | Unused | Internal to SAR ADC | | | 30 | Unused | Internal to SAR ADC | | | 31 | Unused | Internal to SAR ADC | | # 3.7.1.3.2 Reference Options The reference selection is done from within the SAR ADC. The SAR ADC supports the following references: - SAR\_VREFH and SAR\_VREFL connected as the primary reference option. However, these are bonded to SAR\_VDDA & SAR\_VSSA respectively on the device package - Bandgap voltage from PMC - 1.2V VREF (either from off-chip source or internal source for which the selection is controlled from SIM) #### NOTE Refer to Status and Control Register 2 (ADC\_SC2), bit REFSEL for more information. ### 3.7.1.3.3 Trigger Options The ADC supports both software and hardware triggers. The hardware trigger options are shown in table below. | | Quad Timer | PIT | iRTC | LPTIMER | |--------------------------------------|------------------------------------------------------|------------------------------------------------------|------|---------| | RUN, VLPR | Yes | Yes | Yes | Yes | | WAIT, VLPW, VLPS,<br>STOP and PSTOP1 | No in VLPS & STOP. Yes if module active in WAIT/VLPW | No in VLPS & STOP. Yes if module active in WAIT/VLPW | Yes | Yes | Table 3-31. Hardware trigger options for SAR ADC The selection of trigger can be done via the XBAR. The trigger outputs from XBAR are connected to respective SAR ADC trigger inputs, thereby forcing ADC conversions. The ADC can be triggered in low power modes (WAIT, VLPW, VLPS, STOP and PSTOP1) using the LPTIMER or iRTC. This allows the ADC to do conversions in low power modes and store the output in the result register. The ADC generates interrupt when the data is ready in the result register that wakes the system from low power mode. #### **NOTE** - The timer channels used for trigger generation must be programmed to generate the trigger pulses (Trigger A .. Trigger D) in an interleaved fashion. Pulses should not come at the same time. - Generation of a trigger before conversion completes for previous trigger is an error condition #### 3.7.1.3.4 Alternate Clock For alt\_clk this clock source has to be clocking at a high enough frequency to meet the minimum adc\_clk operating frequency. #### NOTE It is not a usable source in stop – ADC wrapper logic requires the select of the ADC internal clock source to operate in stop. For this device, the alternate clock is connected to OSCERCLK. #### NOTE This clock option is only usable when OSCERCLK is in the MHz range. A system with OSCERCLK in the kHz range has the optional clock source below minimum ADC clock operating frequency. ### 3.7.1.3.5 Clock Gating The clock to SAR ADC module can be gated on and off using clock-gate control bits in the SIM module. 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 clock-gate control bit in the SIM module to enable the clock: Before turning off the clock, make sure to disable the module. For more details, refer to the clock distribution chapter. #### NOTE The clock to the ADC should not be gated during an active conversion. # 3.7.2 Analog Front End (AFE) 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. | Topic | Related module | Reference | |---------------------|------------------------|------------------------| | Full description | Analog Front End (AFE) | Analog Front End (AFE) | | System memory map | | System memory map | | Clocking | | Clocking | | Power management | | Power mangement | | Signal multiplexing | Port control | Signal multiplexing | Table 3-32. Reference links to related information ### 3.7.2.1 Clock Sources AFE can be clocked by the following clock sources (see Figure below): - 6.144 MHz clock generated from PLL with 32.768 kHz reference clock input - MHz crystal oscillator clock output (if crystal clock < 32 MHz). Prescaler on AFE will divide this external clock to generate required range of clock at modulator input (30 kHz to 6.5 MHz). - Externally supplied clock (30 kHz to 50 MHz) via AFE\_CLK pin - This pin can additionally be used to interface clock port of external modulators (which provide clock output with data). - Prescaler on AFE will divide this external clock to generate required range of clock at modulator input (30 kHz to 6.5 MHz). - Quad Timer channel 0 output - 4 MHz IRC from MCG The above clock sources are available in all MCU power modes where AFE can work, except for VLPS where PLL cannot work. Hence for operating AFE in VLPS, a different clock source would be required. The selected clock source is prescaled down to the AFE modulator clock operating range (30 kHz to 6.5 MHz in Normal Mode and less than 1.6 MHz for Low Power Mode) before enabling AFE operations. The Prescaler divides down the selected clock in powers of 2 (i.e.1, 2, 4, 8, 16. 32, 64, 128 and 256). It is important to divide the selected clock by at least 2 to compensate for any duty cycle variations during muxing and clock propagation. #### NOTE - The externally supplied clock is routed directly from the AFE\_CLK pad to AFE Prescaler. - The clock source selection is one time selection and cannot be changed on the fly. AFE will have to be disabled to change the clock and prescaler. - Using any clock source other than the PLL output clock or oscillator clock will not guarantee AFE performance. - Refer to Clocking Chapter for details on generation of MCGPLLCLK and muxing options therein. - All AFE Channels should run on the same clock. The clock selection is done via register bits in AFE and is common to all AFE Channels. Following figure shows the clocking strategy for the AFE. Figure 3-16. AFE Clocking Options #### **connections/Channel Assignment** The selected clock is common to all AFE channels (0-3) even if some have of the channels use an external modulator. When AFE is disabled, the clock sources should be gated or disabled to save power. # 3.7.3 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-17. High Speed Comparator Table 3-33. Reference links to related information | Topic | Related module | Reference | |---------------------|------------------|---------------------| | Full description | Comparator (CMP) | Comparator | | System memory map | | System memory map | | Clocking | | Clocking | | Power management | | Power mangement | | Signal multiplexing | Port control | Signal multiplexing | #### 3.7.3.1 Instantiation Information KM microcontrollers has two high speed comparator modules with an integrated 6-bit DAC and analog mux. The CMP's 6-bit DAC sub-block supports selection of two voltage references. For KM devices, the references implemented are: - $\bullet$ CMP $V_{in1}$ is connected to VREF Output. - CMP V<sub>in2</sub> is connected to V<sub>DD</sub>. Table 3-34. CMP instantiation | Comparator Features | СМРО | CMP1 | | |----------------------|------|------|--| | Number of 6-bit DACs | 1 | 1 | | Table continues on the next page... ### Table 3-34. CMP instantiation (continued) | Comparator Features | СМРО | CMP1 | |----------------------------|--------|--------| | Analog mux size | 8-bits | 8-bits | | Number of CMP OUT pins | 1 | 1 | | External Comparator Inputs | Upto 6 | Upto 6 | #### NOTE Refer to Device Configuration for the number of external inputs supported on each device. The following table shows the fixed internal and external connections to each CMP and output connections for each CMP instance, respectively. For information about the specific pins to which the input and output signals are assigned on the package, refer to the KM Family Pinouts chapter. ### **NOTE** The "Reserved for Test" input is to be connected to the Analog Test Sense Bus signal. Table 3-35. CMP Input connections | CMP inputs | СМРО | CMP1 | |------------|---------------------|---------------------| | CMP Input0 | CMP0P0 | CMP1P0 | | CMP Input1 | CMP0P1 | CMP1P1 | | CMP Input2 | CMP0P2 | SDADP2 | | CMP Input3 | CMP0P3 | SDADM2 | | CMP Input4 | CMP0P4 | SDADP3 | | CMP Input5 | CMP0P5 | SDADM3 | | CMP Input6 | Reserved for Test | Reserved for Test | | CMP Input7 | 6-bit DAC reference | 6-bit DAC reference | ### CMP0 output connections are: - CMP output (CMP0OUT) pin - Quad Timer input via XBAR - Any UART Rx input via XBAR (one UART can work at a time) - EWM\_IN input via XBAR - LLWU\_M2IF input - LPTMR input ### CMP1 output connections are: - CMP output (CMP1OUT) pin - Quad Timer input via XBAR - LLWU\_M4IF input #### **Connections/Channel Assignment** - EWM\_IN input via XBAR - LPTMR input The CMP0 is used for IrDA operation using UART. The CMP1 is used for zero crossing detection (for frequency measurement). ### 3.7.3.2 CMP Trigger Mode The CMP and 6-bit DAC sub-block supports trigger mode operation when the CMP\_CR1[TRIGM] is set. When trigger mode is enabled, the trigger event will initiate a compare sequence that must first enable the CMP and DAC prior to performing a CMP operation and capturing the output. In this device, control for this two staged sequencing is provided from the LPTMR. The LPTMR triggering output is always enabled when the LPTMR is enabled. The first signal is supplied to enable the CMP and DAC and is asserted at the same time as the TCF flag is set. The delay to the second signal that triggers the CMP to capture the result of the compare operation is dependent on the LPTMR configuration. In Time Counter mode with prescaler enabled, the delay is 1/2 Prescaler output period. In Time Counter mode with prescaler bypassed, the delay is 1/2 Prescaler clock period. The delay between the first signal from LPTMR and the second signal from LPTMR must be greater than the Analog comparator initialization delay as defined in the device datasheet. # 3.7.4 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-18. 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 | | Clocking | | Power management | | Power mangement | | Signal multiplexing | Port control | Signal multiplexing | ### 3.7.4.1 Overview This device includes a voltage reference (VREF) to supply an accurate 1.2 V voltage output. The voltage reference can provide a reference voltage to external peripherals or a reference to analog peripherals, such as the Sigma Delta ADCs, SAR and CMP. ### 3.7.4.2 Instantiation Information This device contains one VREF module to produce a 1.2 V reference. This VREF is placed in the VDDA domain . The VREF is shared between SAR, AFE & DAC (in CMP). The figure below shows the VREF integration and sharing scheme. #### onnections/Channel Assignment Figure 3-19. VREF Integration #### NOTE The switch S1 is meant for output of 1.2V VREF onto the SoC pin. When using externally supplied VREF, this switch (S1) should be open. The following table describes the various uses of VREF as references for SAR, SD ADC and CMP: Table 3-37. VREF Sharing Scenarios **SAR Reference** 6-bit DAC (CMP) Description **AFE Reference** Reference 1.2V VREF Internal 3.3V SAR\_VDDA 1.2V VREF Internal Case I (S3 in current (S0 in current (S2 flipped from Most common use-case in metering application. Good AFE performance. SAR ADC absolute accuracy driven by tolerance of the LDO regulator position) position) current position) (tolerance of typical LDOs is +/-2-3%). Internal 1.2V VREF optionally routed to VREF pin (S1 closed) for use by external circuitries. 1.2V VREF Internal | 1.2V VREF Internal Case II 1.2V VREF Internal Most common use-case in metering application. Good SAR ADC absolute driven by 1.2V VREF (S3 in current (S0, S2 flipped (S2 flipped from Internal reference (buffered). AFE performance position) from current current position) might be impacted by the SAR ADC kick-backs via position) buffer. Internal 1.2V VREF optionally routed to Table continues on the next page... VREF pin (S1 closed) for use by external circuitries. # Table 3-37. VREF Sharing Scenarios (continued) | | AFE Reference | SAR Reference | 6-bit DAC (CMP)<br>Reference | Description | |----------|-------------------------------------------------------|-------------------------------------------------------------------------------|------------------------------------------------------|--------------------------------------------| | Case III | 1.2V VREF External (S3 flipped from current position) | 1.2V VREF External (S0 flipped from current position, S2 in current position) | 1.2V VREF<br>External<br>(S2 in current<br>position) | Complementary use-case | | Case IV | 1.2V VREF Internal<br>(S3 in current<br>position) | 1.2V VREF External (S0 flipped from current position, S2 in current position) | 1.2V VREF<br>External<br>(S2 in current<br>position) | AFE reference decoupled from other blocks. | The VREF supports running in tight regulation mode (high power) and low power buffer modes. KM family microcontrollers will use this feature in VREF. #### **NOTE** S0 corresponds to SAR ADC Voltage Reference Select: ADC\_SC2 [REFSEL] S1 corresponds to VREF Buffer Output Enable: SIM\_MISC\_CTL[VREFBUFOUTEN] S2 corresponds to VREF Buffer Input Select: SIM\_MISC\_CTL[VREFBUFINSEL] S3 corresponds to Internal and External 1.2 V Reference Select: VREF\_VREFL\_TRM[VREFL\_SEL] # 3.7.4.3 Clock Gating The clock to the VREF module can be turned on or off using the clock gating bits in the SIM module. These bits are cleared after any reset, which disables the clock to the corresponding module to conserve power. Prior to initializing the corresponding module, set corresponding bit in the SIM module to enable the clock. Before turning off the clock, make sure to disable the module. For more details, refer to the clock distribution chapter. rimers ## **3.7.4.4** Accuracy Metering requires 10-15 PPM/°C (typical) accuracy on the VREF output to satisfy the requirement for lower drift over temperature for higher class meters that need that level of measurement accuracy. ### 3.8 Timers # 3.8.1 Independent Real Time Clock (iRTC) 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. Independent Real Time Clock (iRTC) configuration Topic Related module Reference Full description RTC OSC RTC OSC Signal multiplexing Port control Signal multiplexing Full description MCG MCG Table 3-38. Reference links to related information ### 3.8.1.1 Overview iRTC or Independent Real Time Clock is completely powered by battery (via independent power rails) and does not use a power switch. iRTC maintains time & date keeping functions along with tamper detection capability and register protection. It includes a compensation logic to compensate for variations in the 32.768 kHz crystal clock. iRTC has option to output the desired clock onto the SoC pin. # 3.8.1.2 RTC General Purpose Data Register (RTC\_GP\_DATA\_REG) | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |---------------|-------|-------|-------|-------|-------|-------|------|------| | Read<br>Write | CFG15 | CFG14 | CFG13 | CFG12 | CFG11 | CFG10 | CFG9 | CFG8 | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Read<br>Write | CFG7 | CFG6 | CFG5 | CFG4 | CFG3 | CFG2 | CFG1 | CFG0 | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Figure 3-21. RTC General Purpose Data Register Table 3-39. RTC General Purpose Data Register Table | Bit Number | Description | |------------|---------------------------------------------------------------------------| | CFG0 | 32 kHz RTC OSC Control. | | | This bit can be used to disable clock when writing to RTC registers. | | | '1'—Disable the oscillator | | | '0'—Enables the oscillator | | CFG1 | Switched capacitor 2pf enable. | | | Enables 2 pf capacitor inside oscillator to be used as load capacitance. | | | '1'—Enables capacitor | | | '0'—Disables capacitor | | CFG2 | Switched capacitor 4pf enable. | | | Enables 4 pf capacitor inside oscillator to be used as load capacitance. | | | '1'—Enables capacitor | | | '0'—Disables capacitor | | CFG3 | Switched capacitor 8pf enable. | | | Enables 8 pf capacitor inside oscillator to be used as load capacitance. | | | '1'—Enables capacitor | | | '0'—Disables capacitor | | CFG4 | Switched capacitor 16pf enable. | | | Enables 16 pf capacitor inside oscillator to be used as load capacitance. | | | '1'—Enables capacitor | | | '0'—Disables capacitor | | CFG5 | Reserved | | CFG6 | Reserved | Table continues on the next page... Table 3-39. RTC General Purpose Data Register Table (continued) | Bit Number | Description | |------------|----------------------------------------------------------------------------------------------------------------------------| | CFG7 | Boot mode override bit. | | | This bit can be used to override the boot to happen in VLPR mode. The effect of this bit can be seen on next system reset. | | | '1'—Boot in VLPR | | | '0'—Boot in RUN | | CFG8 | Reserved | | CFG9 | Reserved | | CFG10 | Reserved | | CFG11 | Reserved | | CFG12 | Reserved | | CFG13 | Reserved | | CFG14 | Reserved | | CFG15 | Reserved | # 3.8.2 TMR 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. TMR Configuration Table 3-40. Reference links to related information | Topic | Related module | Reference | |---------------------|---------------------|---------------------| | Full description | TMR | TMR | | System memory map | | System memory map | | Clocking | | Clock distribution | | Power management | | Power mangement | | Signal multiplexing | SIM's GPS registers | Signal multiplexing | ### 3.8.2.1 Overview The quad-timer module provides four timer channels with a variety of controls affecting both individual and multi-channel features. Specific features include up/down count, cascading of counters, programmable modulo, count once/repeated, counter preload, compare registers with preload, shared use of input signals, prescaler controls, independent capture/compare, fault input control, programmable input filters, and multi-channel synchronization. #### 3.8.2.2 Instantiation Information This device has one instance of quad timer with 4 timer channels. # 3.8.3 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-23. LPTMR configuration Table 3-41. Reference links to related information | Topic | Related module | Reference | |---------------------|-----------------|---------------------| | Full description | Low-power timer | Low-power timer | | System memory map | | System memory map | | Clocking | | Clock distribution | | Power management | | Power mangement | | Signal Multiplexing | Port control | Signal multiplexing | rimers ### 3.8.3.1 **Overview** The LPTMR or Low Power Timer can operate as either a real time interrupt or as a pulse accumulator and operate in all of the chip's power modes (including VLLSx). #### 3.8.3.2 Instantiation Information This device has one LPTMR module with one 16-bit channel. There are three LPTMR pins: LPTMR0, LPTMR1, and LPTMR2. Each of these are connected to LPTMR and can be selected by module's CSR[TPS] field with the settings 01, 10, and 11, respectively. Either of the CMP output can also be connected to LPTMR by setting each module's CSR[TPS] field to 00. This configuration allows pulse counting of the CMP output. Selection between CMP0 & CMP1 will be done using SIM registers. Table 3-42. Selects the timer pin to be used by the LPT in pulse counter mode. | LPT_CSR<br>register;<br>TPS bit-<br>field | LPTMR | |-------------------------------------------|----------------------------------------------------------| | 0b00 | Pin LPT_ALT0 selected (CMP0 or CMP1 output) <sup>1</sup> | | 0b01 | Pin LPT_ALT1 selected (External pin LPTMR0) | | 0b10 | Pin LPT_ALT2 selected (External pin LPTMR1) | | 0b11 | Pin LPT_ALT3 selected (External pin LPTMR2) | <sup>1</sup>Selection between CMP0 & CMP1 . controlled via SIM registers ### 3.8.3.3 Clock Options LPTMR's PSR[PCS] field controls the selection of external clock options. - 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 OSCCLK32K, the 32.768 kHz clock from OSC32K. This connection is optimized for minimal power consumption in stop modes. - Setting PSR[PCS] to 11 selects the ERCLK # 3.8.4 PIT 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-24. PIT configuration Table 3-43. Reference links to related information | Topic | Related module | Reference | |-------------------|----------------|--------------------| | Full description | PIT | PIT | | System memory map | | System memory map | | Clocking | | Clock distribution | | Power management | | Power mangement | #### 3.8.4.1 Overview The periodic interrupt timer (PIT) is a 32-bit timer that provides precise interrupts at regular intervals with minimal processor intervention. The timer can count down from the value written in the PIT modulus register, or it can be a free-running down-counter. ### 3.8.4.2 Instantiation Information This device contains two PIT modules. # 3.8.4.3 PIT/DMA Periodic Trigger Assignments The PIT generates periodic trigger events to the DMA Mux as shown in the table below. #### **communication interface** Table 3-44. PIT channel assignments for periodic DMA triggering | DMA Mux Number | PIT Channel | |----------------|----------------| | DMA Mux 0 | PIT0 Channel 0 | | DMA Mux 1 | PIT0 Channel 1 | | DMA Mux 2 | PIT1 Channel 0 | | DMA Mux 3 | PIT1 Channel 1 | ### 3.9 Communication interface # 3.9.1 Serial Peripheral Interface (SPI) Configuration Figure 3-25. SPI configuration Table 3-45. 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 mangement | | Signal multiplexing | Port mux control | Signal multiplexing | #### 3.9.1.1 Overview 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 micro-controllers, analog-to-digital converters, shift registers, sensors, memories, etc. ### 3.9.1.2 Instantiation Information KM family of devices have two SPI modules. The SPI instances support the following features: | Features | SPI0 | SPI1 | |--------------|----------|-------------| | FIFO Depth | NA | 8 for Tx | | (in Bytes) | | 8 for Rx | | AMR support | 3 V only | 3 V and 5 V | | DMA support | Yes | Yes | | Module Clock | 50 MHz | 50 MHz | Table 3-46. SPI instantiation The SPI supports a baud rate up to the bus clock divided by two in master mode and up to the bus clock divided by 4 in slave mode. The SPI modules can be configured to work in WAIT, VLPR, VLPW modes. # 3.9.2 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. Figure 3-26. UART configuration Table 3-47. Reference links to related information | Topic | Related module | Reference | |-------------------|----------------|-------------------| | Full description | UART | UART | | System memory map | | System memory map | | Clocking | | Clocking | Table continues on the next page... #### **communication interface** #### Table 3-47. Reference links to related information (continued) | Topic | Related module | Reference | |---------------------|------------------|---------------------| | Power management | | Power mangement | | Signal multiplexing | Port mux control | Signal multiplexing | ### 3.9.2.1 Instantiation Information This section describes how each UART module is instantiated. Table 3-48. UART instantiation information | Feature | UART0 | UART1 | UART2 | UART3 | |-------------------------------------|---------------------|-------------------------|---------------------|---------------------| | UART modules with standard features | Yes | Yes | Yes | Yes | | UART modules with ISO7816 | No | Yes | No | Yes | | IrDA | Yes | Yes | Yes | Yes | | | (via CMP0 & XBAR) | (via CMP0 & XBAR) | (via CMP0 & XBAR) | (via CMP0 & XBAR) | | Flow Control | Yes | Yes | Yes | Yes | | FIFO Depth (number of entries) | 8 for Tx | 8 for Tx | 8 for Tx | 8 for Tx | | | 8 for Rx | 8 for Rx | 8 for Rx | 8 for Rx | | Module Clock (max.) | 25 MHz <sup>1</sup> | 50 MHz <sup>2</sup> | 25 MHz <sup>1</sup> | 50 MHz <sup>2</sup> | | Buad Rate | 1.5625 Mbps | 3.125 Mbps <sup>3</sup> | 1.5625 Mbps | 3.125 Mbps | | AMR Support | 3 V only | 3 V and 5 V | 3 V only | 3 V only | - 1. Clocked on bus clock - 2. Clocked on core clock - 3. Baud rate might be less for UART1 pads which are true open drain (PTI1) - 1. Standard features of all UARTs: - RS-485 support - Hardware flow control (RTS/CTS) - 9-bit UART to support address mark with parity - MSB/LSB configuration on data - 2. IrDA is supported on all UART by connecting the corresponding Comparator output to Rx input of UART via the peripheral crossbar. However, one UART can be used at a time. - 3. UART1 is 5V tolerant to support AMR operations and has open-drain pad PTI1 which has TxD1 muxed on it. - PTI0 is not open drain and requires an external resistor divider to interface 5 V input signal for RxD - 4. UART0, UART1 and UART3 are muxed on multiple pins. See Signal multiplexing sheet for pin details. - 5. UART3 Tx pad (PTC2) has double drive capability (20 mA drive). Rest of the UART Tx pads have normal drive. #### **NOTE** Baud rate will be limited to 1Mbps where UART pads have open drain configuration. ### 3.9.2.2 **Overview** 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. ### 3.9.2.3 Clock gating The clock to each UART can be gated on and off using the corresponding clock gating register bits in SIM. These bits are cleared after any reset, which disables the bus clock to the corresponding module. Before initializing the module, set this bit to enable the UART clock. When the module is not in use, clear the corresponding clock gating control bits in SIM to conserve power. # 3.9.3 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-27. I2C configuration Table 3-49. Reference links to related information | Topic | Related module | Reference | |---------------------|----------------|---------------------| | Full description | I2C | I2C | | System memory map | | System memory map | | Clocking | | Clock Distribution | | Power management | | Power management | | Signal Multiplexing | Port control | Signal Multiplexing | ### 3.9.3.1 Overview The inter-integrated circuit (I2C) provides a method of communication between a number of devices. The interface is designed to operate up to 100 kbps with maximum bus loading. 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 100 pF. The I2C modules include SMBus support. Option to keep module active in Stop/VLPS mode, and can wake up CPU from Stop/VLPS mode. ### 3.9.3.2 Instantiation Information KM family contains two I2C modules, I2C0 and I2C1. These I2C modules support the SMBUS protocol along with DMA support. I2C modules will be clocked by bus clock. ### 3.9.3.3 Clock Gating The clock to each I2C module can be gated on and off using the SIM's clock gating register bits. These bits are cleared after any reset, which disables the clock to the each module to conserve power. Prior to initializing a module, set the corresponding bit to enable the clock. Before turning off the clock, disable the module. For additional details, refer to Clocking Chapter. ### 3.10 Human machine interface ### 3.10.1 eGPIO controller 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. GPIO configuration Table 3-50. Reference links to related information | Topic | Related module | Reference | |---------------------|-----------------|---------------------| | Full description | GPIO | GPIO | | System memory map | | System memory map | | Clocking | | Clocking | | Power management | | Power mangement | | Transfers | Crossbar switch | Clock distribution | | Signal Multiplexing | Port control | Signal multiplexing | numan machine interface #### 3.10.1.1 Overview The Enhanced General Purpose Input / Output controller (eGPIO) supports common pin input and output functions. This module combines keyboard interrupt functionality for rising/falling edges or level sensitivity. The eGPIO module is a dual port eGPIO module. eGPIO shall have one port connected to the M0+ core directly (via IOPORT) to allow direct accesses the GPIO (single cycle access). The other port will be connected to AIPS to allow normal IPS accesses to the module. #### Some features of the module: - The module can support any number of GPIO pins via a number of control and data registers. All these registers are also accessible at the byte and halfword level, so the configuration and data values associated with smaller sets of GPIO pins can be independently controlled. - The module has access control registers to control access to GPIOs. One access control register will include four 4-bit GPIO Access Control Registers (GACRn) modeled after the same functionality present in the AIPS's PACRn registers. This includes a lock bit and a 3-bit attribute. The attribute controls the access permission for privileged secure, user secure and user non-secure mode. The lock bit can be set to "lock" the configuration and prevent any subsequent writes until the next reset. - There will be one access control register per 8-pins of GPIO. For 8-bit or 16-bit or 32-bit accesses, the appropriate number of GACRn registers are selected, their flags logically summed together (OR'd) and the access evaluated. - After the "effective" protect bits are formed, the access is checked. If the access is permitted, the operation completes. If the access is denied, the response is dependent on the source of the reference: - If the access is from the IPS port, the transaction is aborted and a bus error termination generated the read data is zeroed and the write is ignored. - If the access is from the core's IOPORT, the required response is different recall this bus does not support any type of wait state insertion nor any type of error termination. For IOPORT accesses that are not allowed, the reference is treated as a RAZ/WI, the ARM notation for Read As Zero, Write Ignored. - The GACRn registers will be accessible in Supervisor mode only. Protection to GACRn registers provided via lock bit (in module itself) and via PACR register of AIPS. #### 3.10.1.2 Instantiation Information The maximum total number of GPIO pins for general purpose is 68 (number varies from device to device). GPIO pins are configured as 8-pins per port. The peripheral bus interface for the eGPIO operates at the bus clock. Only one eGPIO ports have the digital filter feature for reduced noise and hardware switch de-bouncing: Port E. The other ports do not have this feature. ### 3.10.1.3 Clock Gating The clock to the Enhanced General-purpose Input / Output (eGPIO) ports can be gated on and off using the SCGCx[PORTx] bit. This bit is cleared after any reset, which disables the clock to the respective eGPIO 8-pin port to conserve power. Prior to initializing the module set SCGCx[PORTx] bit to enable the clock. ## 3.10.1.4 Debugger write to the I/O port A debugger write to the I/O port might be corrupted during a processor write. A debugger can perform memory accesses through the Cortex-M0+ processor bus matrix while the processor is running. Because of this, a debugger write to the I/O port might be corrupted if it occurs while the processor is executing a write. The processor write completes successfully. However, under specific timing conditions, the matrix might incorrectly replace the debugger write data with the value zero. Although, this does not affect debugger writes outside the I/O port region of the memory map, or debugger reads. #### **Conditions** The following timing-specific conditions must all be met: - The processor is running (not halted in Debug state). - The debugger performs a write within the I/O port region of the memory map. - The processor performs a write. ## **Implications** The debugger might corrupt the targeted memory or configure the targeted device incorrectly. #### Workaround The debugger can work around this by halting the processor in Debug state before performing writes to the I/O port region of the memory map. # 3.10.2 Segment LCD controller 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. SLCD configuration Table 3-51. Reference links to related information | Topic | Related module | Reference | |---------------------|----------------|---------------------| | Full description | Segment LCD | Segment LCD | | System memory map | | System memory map | | Clocking | | Clocking | | Power management | | Power mangement | | Signal multiplexing | Port control | Signal multiplexing | ### 3.10.2.1 Instantiation information The following table lists the Segment LCD (SLCD) support information information across the KM platform devices. Table 3-52. SLCD support<sup>1</sup> | Max. number of segments | Configurations | |-------------------------|-------------------------------------------------| | Up to 288 | Up to 8 backplanes and up to 40 front planes | | | Both 4x40 and 8x36 configurations are supported | 1. The LCD controller can support multiplexing from x1 up to x8. #### NOTE • 5 V LCD glass is not supported - Default configuration of VSUPPLY is 0. Here VLL3 is derived from VDD\_3V internally. If VLL3 is derived from any other source than VDD on board, there will be a current between VLL3 and VDD at bootup. It is recommended to have VLL3 derived from VDD on board - Vsupply options to generate VLL3 from VLL2(VSUPPLY=0) can generate maximum 3.6 V on VLL3 at MCU VDD(1.8 V - 3.6 V) - KM family devices have a 1/3 bias controller that works with a 1/3 bias LCD glass. To avoid ghosting, the LCD OFF threshold should be greater than VLL1 level. If the LCD glass has an OFF threshold less than VLL1 level, use the internal VREG mode and generate VLL1 internally using RVTRIM option. This can reduce VLL1 level to allow for a lower OFF threshold LCD glass. пишап machine interface # **Chapter 4 System Memory Map** ## 4.1 Introduction This device contains various memories and memory-mapped peripherals which are located in one 32-bit contiguous memory space. This chapter describes the memory and peripheral locations within that memory space. # 4.2 System Memory Map The following table shows the high-level device memory map: Table 4-1. System memory map | System 32-bit Address Range | Destination Slave | Size | Access | |-----------------------------|-------------------------------------------------------------------------|---------|----------------------| | 0x0000_0000-0x0001_FFFF | Flash Memory | 128 kB | All masters | | | (Includes exception vectors in first 192 bytes) | | | | 0x0002_0000-0x1FFF_EFFF | Reserved | _ | _ | | 0x1FFF_F000-0x1FFF_FFFF | SRAM_L: Lower SRAM | 4 kB | All masters | | 0x2000_0000-0x2000_2FFF | SRAM_U: Upper SRAM | 12 kB | All masters | | 0x2000_3000-0x3FFF_FFFF | Reserved | _ | _ | | 0x4000_0000-0x4007_EFFF | AIPS peripherals - See AIPS peripheral slot assignment for more details | 508 kB | All masters | | 0x4007_F000-0x400F_EFFF | Reserved | _ | _ | | 0x400F_F000-0x400F_FFFF | eGPIO Ports | 4 kB | All masters | | 0x4010_0000-0x43FF_FFFF | Reserved | _ | _ | | 0x4400_0000-0x5FFF_FFF | Peripheral Bit Manipulation Engine | 448 MB | Cortex M0+ core only | | 0x6000_0000 - 0xDFFF_FFF | Reserved | _ | _ | | 0xE000_0000-0xE00F_FFFF | Private Peripherals | 1000 kB | Cortex M0+ core only | | 0xE010_0000-0xEFFF_FFFF | Reserved | _ | _ | Table continues on the next page... KM Family Reference Manual, Rev. 5, Oct 2013 гіазіі Memory Мар Table 4-1. System memory map (continued) | System 32-bit Address Range | Destination Slave | Size | Access | |-----------------------------|---------------------------------------------------------------------------------------------|--------|----------------------| | | Private Peripheral Bus (PPB) - See Private Peripheral Bus (PPB) memory map for more details | 256 MB | Cortex M0+ core only | #### NOTE - Exception vectors are included in first 1024 bytes of the Flash Memory space - Accesses to invalid memory ranges should cause a transfer error exception. - The 4 kB region of SRAM\_U from 0x2000\_0000 to 0x2000\_2FFF block is the region of RAM left powered on in low-power mode VLLS2. - There are no bitband regions supported by M0+ (neither for RAM nor peripheral) # 4.3 Flash Memory Map The flash array 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 4-1. Flash memory map Addresses for flash read accesses is determined according to the overall system memory as shown in System Memory Map. # 4.4 SRAM memory map The on-chip RAM is split amongst SRAM\_L and SRAM\_U in the ratio of 1:3. The RAM is implemented such that the SRAM\_L and SRAM\_U ranges from a contiguous block in the memory map. Accesses to SRAM\_L and SRAM\_U memory ranges outside the amount of RAM on the device causes the bus cycle to be terminated with an error followed by the appropriate response in the requesting bus master. # 4.5 Peripheral bridge (AIPS-Lite) memory map The peripheral memory map is accessible via one slave port on the crossbar in the 0x4000\_0000-0x4007\_FFFF region. The device implements one peripheral bridge that defines a 512 KB address space. #### **NOTE** The eGPIO registers is present in the 0x400F\_F000 - 0x400F\_FFFF address range. Slave peripheral space is divided into three regions: - A 128 KB region, partitioned as 32 spaces, each 4 KB in size and reserved for onplatform peripheral devices. The AIPS controller generates unique module enables for all 32 spaces. - A 380 KB region, partitioned as 95 spaces, each 4 KB in size and reserved for off-platform modules. The AIPS controller generates unique module enables for all 95 spaces. - A 4 KB region left reserved to have compatibility with Kinetis. The AIPS controller supports disabling of individual slots via a bus of input control signals. Unimplemented slots have their control signal tied off to disabled (logic 1). Modules that have clock gate control bits (implemented in the SIM's SCGCx registers) to disable system clocking to identified peripherals should also use these control bits to enable/disable associated AIPS slots. #### NOTE When the associated SCGCx bit is logic 0, the disable input is driven to logic 1. Modules that are disabled via their clock gate control bits in the SIM registers disable the associated AIPS slots. Access to any address within an unimplemented or disabled peripheral bridge slot results in a transfer error termination. For programming model accesses via the peripheral bridges, there is generally only a small range within the 4 KB slots that is implemented. Accessing an address that is not implemented in the peripheral results in a transfer error termination. #### AIRS peripheral slot assignment Ideally the IP peripherals are implemented to indicate a transfer error to the AIPS controller for accesses to the IP peripheral with an address that is not implemented. Normally, all IPs should generate transfer errors for all unimplemented addresses in its AIPS slot. In cases where a peripheral cannot be updated to fully support this requirement, SoC level gasket logic is required to detect accesses to unsupported ranges and generate transfer error detection to the AIPS controller. SoC level gasket logic must also suppress the ips\_module\_en driven to that peripheral. This is need for the following module(s): 1. the RNGA does not fully support transfer error. There are only 6 address lines input (ips\_addr[5:0]) and generates transfer error on unimplemented registers in this 64-byte range. Top-level glue logic detects and generates the transfer error detection beyond the 64-byte by decoding invalid accesses by monitoring the upper addresses (ips addr[11:6]) in the 4K slot. The eGPIO module has two ports. The first port is connected to IOPORT bus of the core to allow direct and fast access to GPIO pins from the core. The other port of eGPIO is active when access to 0x400F\_F000 - 0x400F\_FFFF address space via the AIPS is done. # 4.6 AIPS peripheral slot assignment #### **NOTE** - Slots 0-79 are 32-bit data width modules - Slots 80-95 are 16-bit data width modules and - Slots 96-126 are 8-bit data width modules - Peripherals generate transfer error for reserved addresses in their assigned slots Table 4-2. Peripheral bridge slot assignments | System 32-bit base address | Slot<br>number | Module | |----------------------------|----------------|-------------------------------| | 0x4000_0000 | 0 | AIPS Lite | | 0x4000_1000 | 1 | Reserved for Platform Modules | | 0x4000_2000 | 2 | Reserved for Platform Modules | | 0x4000_3000 | 3 | Reserved for Platform Modules | | 0x4000_4000 | 4 | _ | | 0x4000_5000 | 5 | _ | | 0x4000_6000 | 6 | _ | | 0x4000_7000 | 7 | _ | | 0x4000_8000 | 8 | DMA Controller (DMA) | | 0x4000_9000 | 9 | _ | Table 4-2. Peripheral bridge slot assignments (continued) | System 32-bit base address | Slot<br>number | Module | |----------------------------|----------------|--------------------------------------| | 0x4000_A000 | 10 | Memory Protection Unit (MPU) | | 0x4000_B000 | 11 | _ | | 0x4000_C000 | 12 | _ | | 0x4000_D000 | 13 | _ | | 0x4000_E000 | 14 | _ | | 0x4000_F000 | 15 | eGPIO <sup>1</sup> | | 0x4001_0000 | 16 | _ | | 0x4001_1000 | 17 | _ | | 0x4001_2000 | 18 | _ | | 0x4001_3000 | 19 | _ | | 0x4001_4000 | 20 | _ | | 0x4001_5000 | 21 | _ | | 0x4001_6000 | 22 | _ | | 0x4001_7000 | 23 | _ | | 0x4001_8000 | 24 | _ | | 0x4001_9000 | 25 | _ | | 0x4001_A000 | 26 | _ | | 0x4001_B000 | 27 | _ | | 0x4001_C000 | 28 | _ | | 0x4001_D000 | 29 | _ | | 0x4001_E000 | 30 | _ | | 0x4001_F000 | 31 | _ | | | | Off-platform Modules | | 0x4002_0000 | 32 | Flash Registers | | 0x4002_1000 | 33 | DMA Mux 0 | | 0x4002_2000 | 34 | DMA Mux 1 | | 0x4002_3000 | 35 | DMA Mux 2 | | 0x4002_4000 | 36 | DMA Mux 3 | | 0x4002_5000 | 37 | _ | | 0x4002_6000 | 38 | _ | | 0x4002_7000 | 39 | _ | | 0x4002_8000 | 40 | _ | | 0x4002_9000 | 41 | Random Number Generator (RNGA) | | 0x4002_A000 | 42 | _ | | 0x4002_B000 | 43 | SAR ADC | | 0x4002_C000 | 44 | _ | | 0x4002_D000 | 45 | Programmable Interval Timer 0 (PIT0) | | 0x4002_E000 | 46 | PIT1 | | 0x4002_F000 | 47 | _ | #### AIPS peripheral slot assignment Table 4-2. Peripheral bridge slot assignments (continued) | System 32-bit base address Slot Module | | | | | |----------------------------------------|----------------|-----------------------------------------------------|--|--| | System 32-bit base address | Slot<br>number | iviouule | | | | 0x4003_0000 | 48 | Analog Front End (AFE) <sup>2</sup> | | | | 0x4003_1000 | 49 | _ | | | | 0x4003_2000 | 50 | _ | | | | 0x4003_3000 | 51 | _ | | | | 0x4003_4000 | 52 | Programmable CRC (PCRC) | | | | 0x4003_5000 | 53 | _ | | | | 0x4003_6000 | 54 | _ | | | | 0x4003_7000 | 55 | _ | | | | 0x4003_8000 | 56 | _ | | | | 0x4003_9000 | 57 | _ | | | | 0x4003_A000 | 58 | _ | | | | 0x4003_B000 | 59 | _ | | | | 0x4003_C000 | 60 | Low Power Timer (LPTMR) | | | | 0x4003_D000 | 61 | _ | | | | 0x4003_E000 | 62 | System Integration Module Low Power Logic (SIM_LP) | | | | 0x4003_F000 | 63 | System Integration Module High Power Logic (SIM_HP) | | | | 0x4004_0000 | 64 | _ | | | | 0x4004_1000 | 65 | _ | | | | 0x4004_2000 | 66 | _ | | | | 0x4004_3000 | 67 | Segment LCD (SLCD) | | | | 0x4004_4000 | 68 | _ | | | | 0x4004_5000 | 69 | _ | | | | 0x4004_6000 | 70 | Port A Pin Mux Control (PORT A) | | | | 0x4004_7000 | 71 | Port B Pin Mux Control (PORT B) | | | | 0x4004_8000 | 72 | Port C Pin Mux Control (PORT C) | | | | 0x4004_9000 | 73 | Port D Pin Mux Control (PORT D) | | | | 0x4004_A000 | 74 | Port E Pin Mux Control (PORT E) | | | | 0x4004_B000 | 75 | Port F Pin Mux Control (PORT F) | | | | 0x4004_C000 | 76 | Port G Pin Mux Control (PORT G) | | | | 0x4004_D000 | 77 | Port H Pin Mux Control (PORT H) | | | | 0x4004_E000 | 78 | Port I Pin Mux Control (PORT I) | | | | 0x4004_F000 | 79 | _ | | | | 0x4005_0000 | 80 | Independent Real Time Clock (iRTC) | | | | 0x4005_1000 | 81 | iRTC 32 Byte Standby RAM (iRTC_RAM) | | | | 0x4005_2000 | 82 | _ | | | | 0x4005_3000 | 83 | Watchdog (WDOG) | | | | 0x4005_4000 | 84 | _ | | | | 0x4005_5000 | 85 | Peripheral Crossbar (XBAR) | | | | 0x4005_6000 | 86 | _ | | | Table 4-2. Peripheral bridge slot assignments (continued) | | Table 4-2. Felipheral bridge slot assignments (continued) | | | | | |----------------------------|-----------------------------------------------------------|-----------------------------------|--|--|--| | System 32-bit base address | Slot<br>number | Module | | | | | 0x4005_7000 | 87 | Quad Timer (TMR) Channel 0 | | | | | 0x4005_8000 | 88 | Quad Timer (TMR) Channel 1 | | | | | 0x4005_9000 | 89 | Quad Timer (TMR) Channel 2 | | | | | 0x4005_A000 | 90 | Quad Timer (TMR) Channel 3 | | | | | 0x4005_B000 | 91 | _ | | | | | 0x4005_C000 | 92 | _ | | | | | 0x4005_D000 | 93 | _ | | | | | 0x4005_E000 | 94 | _ | | | | | 0x4005_F000 | 95 | _ | | | | | 0x4006_0000 | 96 | _ | | | | | 0x4006_1000 | 97 | External Watchdog Monitor (EWM) | | | | | 0x4006_2000 | 98 | _ | | | | | 0x4006_3000 | 99 | _ | | | | | 0x4006_4000 | 100 | Module Clock Generator (MCG) | | | | | 0x4006_5000 | 101 | _ | | | | | 0x4006_6000 | 102 | MHz Oscillator (OSC) | | | | | 0x4006_7000 | 103 | 12C0 | | | | | 0x4006_8000 | 104 | I2C1 | | | | | 0x4006_9000 | 105 | | | | | | 0x4006_A000 | 106 | UARTO | | | | | 0x4006_B000 | 107 | UART1 | | | | | 0x4006_C000 | 108 | UART2 | | | | | 0x4006_D000 | 109 | UART3 | | | | | 0x4006_E000 | 110 | _ | | | | | 0x4006_F000 | 111 | 1.2V Voltage Reference (VREF) | | | | | 0x4007_0000 | 112 | _ | | | | | 0x4007_1000 | 113 | _ | | | | | 0x4007_2000 | 114 | Comparator (CMP) <sup>3</sup> | | | | | 0x4007_3000 | 115 | _ | | | | | 0x4007_4000 | 116 | _ | | | | | 0x4007_5000 | 117 | SPI0 | | | | | 0x4007_6000 | 118 | SPI1 | | | | | 0x4007_7000 | 119 | _ | | | | | 0x4007_8000 | 120 | _ | | | | | 0x4007_9000 | 121 | _ | | | | | 0x4007_A000 | 122 | _ | | | | | 0x4007_B000 | 123 | Reset Control Module (RCM) | | | | | 0x4007_C000 | 124 | Low Leakage Wakeup Unit (LLWU) | | | | | 0x4007_D000 | 125 | Power Management Controller (PMC) | | | | #### rrivate peripherals Table 4-2. Peripheral bridge slot assignments (continued) | System 32-bit base address | Slot<br>number | Module | |----------------------------|----------------|--------------------------------------------| | 0x4007_E000 | 126 | System Mode Controller (SMC) | | 0x4007_F000 | 127 | Reserved | | 0x400F_F000 | _ | eGPIO (All ports: PTA to PTI) <sup>4</sup> | - 1. Alias of the eGPIO module - 2. All channels covered in one module - 3. This module has two comparators each with DAC and 8 channels - 4. This address range is for accessing GPIO through AIPS. For single cycle access, IOPORT should be used ## 4.7 Private peripherals **Table 4-3. Private Peripherals** | System 32-bit Address Range | Destination Slave | |-----------------------------|---------------------------| | 0xE000_0000-0xE000_DFFF | Reserved | | 0xE000_E000-0xE000_EFFF | System Control Space(SCS) | | 0xE000_E000-0xE000_E00F | Reserved | | 0xE000_E010-0xE000_E0FF | SysTick | | 0xE000_E100-0xE000_ECFF | NVIC | | 0xE000_ED00- 0xE000_ED8F | System Control Block | | 0xE000_ED90-0xE000_EDEF | Reserved | | 0xE000_EDF0-0xE000_EEFF | Debug | | 0xE000_EF00-0xE000_EFFF | Reserved | | 0xE000_F000-0xE00F_EFFF | Reserved | | 0xE00F_F000 - 0xE00F_FFFF | M0+ Core ROM Table | # 4.8 Private Peripheral Bus (PPB) memory map The PPB is part of the defined ARM bus architecture and provides access to select processor-local modules. These resources are only accessible from the core; other system masters do not have access to them. The M0+ core does not support a true "External PPB". It has an IOPORT which is used to access the eGPIO. All of the resources shown in the table below are standard ARM supplied blocks supporting the ARM Cortex-M0+ except for the miscellaneous control modules. Table 4-4. PPB memory map | System 32-bit Address Range | Resource | |-----------------------------|--------------------------------------------| | 0xF000_0000-0xF000_0FFF | Micro Trace Buffer (MTB) for program trace | | 0xF000_1000-0xF000_1FFF | MTB Data Watchpoint and Trace | | 0xF000_2000-0xF000_2FFF | Debug ROM Table | | 0xF000_3000-0xF000_3FFF | Miscellaneous Control Module (MCM) | | 0xF000_4000-0xF7FF_FFFF | Reserved | | 0xF800_0000-0xFFFF_FFFF | IOPORT (connected to eGPIO) <sup>1</sup> | 1. This port accesses one port of eGPIO while the other port of eGPIO is connected to AIPS as normal IPS connection #### **NOTE** The platform provides access control registers in the eGPIO module thereby securing the accesses to GPIO. Please refer to eGPIO chapter for more details. rrivate Peripheral Bus (PPB) memory map # **Chapter 5 Clock Distribution** ### 5.1 Introduction The 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, RAM and flash memory. The clock generation logic also implements module-specific clock gating to allow granular shutoff of modules. #### NOTE Refer to SCGCx register in SIM chapter for granular shutoff of modules 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 trade-offs between performance and power dissipation. 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 High-Level clocking diagram The following diagram shows how the overall clock generation structure operates. KM Family Reference Manual, Rev. 5, Oct 2013 119 #### підп-Level clocking diagram Note: See subsequent sections for details on where these clocks are used. Clock path from 32k kHz IRC to PLL should not be used for metering use cases. Clock from PLL or Oscillator should be used for high accuracy application (metering). Figure 5-1. Clocking Diagram Device's clocking architecture comprises of the following clock generators: - 4 MHz and 32 kHz IRC Oscillators - FLL - PLL - 1 kHz LPO Additionally, the clocking logic provides for selecting any of the clock source or bypassing them to use the clocks directly from the oscillator. More details on configuring this logic is provided in the individual block chapters. **AFE Modulator Clock Generation:** The PLL will drive the AFE modulator clock for metering applications and optionally drive the core, flash and system clocks for non-metering applications. When PLL is driving AFE clock, this clock should not be used for any other module including the core, bus, flash and other peripherals as this is necessary to ensure good accuracy from AFE. If PLL clock is driving core, bus and flash clocks, there could be some degradation in performance from AFE. The AFE can optionally be clocked from MHz oscillator clock (provided it is less than 32 MHz - for crystal clock and 50 MHz - externally supplied clock) and FLL clock when AFE accuracy is not important (PLL can be disabled to save power in these cases). The final clock output (MCGPLLCLK for AFE) is prescaled (from 1 to 256) inside the AFE Wrapper to generate a clock with 50% duty cycle (must for AFE). See AFE section for more details. #### **NOTE** The 32 kHz IRC is not preferred to drive the PLL input reference when device is used for metering applications (IRC & FLL clocks are inaccurate clock sources for AFE). For general purpose use, this IRC & FLL can be used. For neutral disconnect case, FLL & PLL can be optionally disabled to save power and IRC clock can be divided down to drive the AFE at reduced accuracy. **System Clocks Generation:** The core, flash and bus clocks are generated using either clock source that is generating the MCGOUTCLK (PLL can optionally drive both MCGCLKOUT and clock to AFE; however for best accuracy in AFE, PLL should drive clock to AFE only). ## 5.3 Clock definitions The following table describes the clocks in the previous block diagram. | Clock name | Description | |--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Core clock | MCGOUTCLK divided by SYSDIV clocks the ARM Cortex-M0+ core | | System clock | MCGOUTCLK divided by SYSDIV clocks the crossbar switch and bus masters directly connected to the crossbar. In addition, this clock is used for UART1 and UART3. | | Bus clock | MCGOUTCLK divided by SYSDIV*(SYSCLKMODE+1) clocks the bus slaves and peripheral (excluding memories) | | Flash clock | MCGOUTCLK divided by SYSDIV*(SYSCLKMODE+1) clocks the flash memory | | MCGIRCLK | MCG output of the slow or fast internal reference clock | | MCGOUTCLK | MCG output of either IRC, MCGFLLCLK, MCGPLLCLK, or MCG's external reference clock (Mhz OSC clock or iRTC OSC clock) that sources the core, system, bus and flash clock. It is also an option for the debug trace clock. | | MCGPLLCLK | MCG output for AFE. Either of PLL clock, MHz OSC clock or FLL clock can be used to drive this clock output. | #### CIUCK definitions | Clock name | Description | |------------|---------------------------------------------------------------------------------------------------| | OSCCLK | System oscillator output of the internal Mhz oscillator or sourced directly from EXTAL | | OSCERCLK | System oscillator output sourced from OSCCLK that may clock some on-chip modules (e.g. WDOG, etc) | | OSC32KCLK | RTC Oscillator 32kHz output for iRTC | | ERCLK32K | System oscillator 32 kHz output for low range operation | | LPO | PMC 1kHz output | # 5.3.1 Device clock summary The following table provides more information regarding the on-chip clocks. **Table 5-1. 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 | Up to 50 MHz | Up to 2 MHz | MCGOUTCLK clock divider | In all wait and stop modes | | System clock | Up to 50 MHz | Up to 2 MHz | MCGOUTCLK clock divider | In all stop modes | | Bus clock | Up to 25 MHz | Up to 1MHz | MCGOUTCLK clock divider | In all stop modes | | Flash clock | Up to 25 MHz | Up to 1 MHz | MCGOUTCLK clock divider | In all stop modes | | AFE Modulator Clock | 30 kHz to 6.5 MHz | 30 kHz to 6.5 MHz <sup>1, 2</sup> | Output of Prescaler in<br>AFE Wrapper. See AFE<br>section for details on all<br>sources | AFE is disabled | | AFE Clock (Externally supplied clock) | 30 kHz to 50 MHz | 30 kHz to 50 MHz | AFE_CLK pin | AFE is disabled | | Internal reference<br>(MCGIRCLK) | 4 MHz/32 kHz <sup>3</sup> | 4 MHz/32 kHz <sup>3</sup> | MCG | MCG_C1[IRCLKEN] cleared, (clock disabled in any mode) or Stop mode and MCG_C1[IREFSTEN] cleared, or | | External reference | Lin to FO Milia (hymono) | Lin to C Milia (hungas) | Custom OCC | VLLS mode | | External reference<br>(OSCERCLK) | Up to 50 MHz (bypass),<br>32-40 kHz (crystal), or<br>4 -32 MHz (crystal) | Up to 8 MHz (bypass),<br>32-40 kHz (low-range<br>crystal) | System OSC | System OSC's OSC_CR[ERCLKEN] cleared (clock disabled in any mode), or | | | | | | Stop mode and OSC_CR[EREFSTEN] cleared | | Clock name | Run mode | VLPR mode | Clock source | Clock is disabled | |-------------------------------------------|-----------------|-----------------|--------------|--------------------------------------------| | | clock frequency | clock frequency | | when | | External reference<br>32kHz<br>(ERCLK32K) | 30-40 kHz | | 1 - | System OSC's<br>OSC_CR[ERCLKEN]<br>cleared | | LPO | 1 kHz | 1 kHz | PMC | in VLLS0 | - 1. When AFE is in low power mode, the maximum modulator clock can be 1 MHz - 2. When AFE clock source is IRCLK, max frequency is 4 MHz. - 3. Clock selectable by software. Default: 4 MHz (internally divided by 2 after reset) ## 5.4 Internal clocking requirements The clock dividers are programmed via the SIM module's CLKDIV registers. Each divider is programmable from a divide-by-1 through divide-by-16 setting. The following requirements must be met when configuring the clocks for this device: - 1. The core and system clock frequencies must be 50 MHz or slower. - 2. The bus/flash clock frequency must be programmed to 25 MHz or less and an integer divide of the core clock. - 3. The lowest frequency configured for bus clock should always be more than 32.768 kHz clock (preferably twice or more). - 4. The PLL clock will be 14.65 MHz or less for the AFE. This clock is prescaled internal to AFE before being used. The clock ratio of core:bus:flash that will be support is 2:1:1 when core clock > 25 MHz and 2:1:1 or 1:1:1 when core clock is <= 25 MHz. ## 5.4.1 Clock divider values after reset Each clock divider is programmed via the SIM module's CLKDIV*n* registers. The flash memory's FTFL\_FOPT[LPBOOT] bit controls the reset value of the core clock, system clock, bus clock, and flash clock dividers as shown below: | FTFL_FOPT<br>[LPBOOT] | Core/system clock | Bus clock | Flash clock | Description | |-----------------------|-------------------|--------------------|--------------------|-----------------| | 0 | 0x7 (divide by 8) | 0xF (divide by 16) | 0xF (divide by 16) | Low power boot | | 1 | 0x0 (divide by 1) | 0x1 (divide by 2) | 0x1 (divide by 2) | Fast clock boot | KM Family Reference Manual, Rev. 5, Oct 2013 #### muernal clocking requirements This gives the user flexibility for a fast boot with higher power consumption vs lower frequency and low-power boot option. The flash erased state defaults to fast clocking mode, because where the low power boot (FTFL\_FOPT[LPBOOT]) bit resides in flash is at logic 1 in the flash erased state. To enable the slow boot option program FTFL\_FOPT[LPBOOT] to zero. After power up LPBOOT can be configured. Upon any system reset, the clock dividers return to this configurable reset state. • Clock divider setting can be user-programmed on-the-fly without clock glitches. Control logic handles stalling and restarting the clocks. Supports divide-by-1 through divide-by-16. ## 5.4.2 VLPR mode clocking They must be programmed prior to entering VLPR mode to guarantee: - the core/system clocks are less than or equal to 2 MHz, and - the flash memory and bus clocks are less than or equal to 1 MHz ### 5.4.3 Enable PLL in VLPR or VLPR and PSTOP1 The following steps are used to enable PLL in VLPR mode (after VLPR boot): - Device boots in VLPR mode. - Enable PMC band-gap by configuring corresponding register in D\_PMC. - Set SIM\_CTRL\_REG[PLL\_VLP\_EN] - CLEAR the MCG LP bit MCG\_C2[1]=0 and set the MCG PLLCLKEN bit - Wait for MCG LOCK bit to set - Once PLL clock is available configure AFE and start conversion ## Steps to enable PLL in VLPR mode (after RUN boot): - Device boots in RUN mode. - Program SMC to enter VLPR mode - Enable PMC band-gap by configuring corresponding register in D\_PMC. - Set SIM\_CTRL\_REG[PLL\_VLP\_EN] field - CLEAR the MCG LP bit MCG\_C2[1]=0 and set the MCG PLLCLKEN bit - Wait for MCG LOCK bit to set - Once PLL clock is available configure AFE and start conversion ## Steps to keep PLL enabled in Partial Stop 2 mode: - Set PLL\_STPEN bit in MCG before entering Stop mode. - Program STOPM = 000 and PSTOPO = 01 in SMC - Set SLEEPDEEP bit in ARM to enter Partial stop Mode. - Use Async. DMA feature for the use-case if required to read result registers of AFE #### NOTE - If PLL is already enabled in RUN and MCU is made to enter VLPR mode, the PLL will remain active. - Some restrictions that the user software needs to care about: - If SIM\_CTRL\_REG[PLL\_VLP\_EN] field is set software should ensure proper clock configuration before entering VLP mode as hardware checking is overridden. - In case user wants to switch to any low power mode(VLLSx, VLPS) from VLP mode, SIM\_CTRL\_REG[PLL\_VLP\_EN] field need to be cleared prior to mode transtion to VLLSx, VLPS mode. - In VLP mode when PLL is enabled user should not disable the PMC bandgap - RUN->VLPR(also with PSTOP1)->RUN - RUN->VLPR(+PSTOP1)->RESET are valid transition with the feature enabled. - If the feature is not required or if FLL needs to be enabled "SIM\_CTRL\_REG[PLL\_VLP\_EN]" needs to be cleared. # 5.5 Clock Gating The clock to each module can be individually gated on and off using the SIM module'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, make sure to disable the module. Any bus access to a peripheral that has its clock disabled generates an error termination. ## 5.6 Module clocks The following table summarizes the clocks associated with each module. KM Family Reference Manual, Rev. 5, Oct 2013 #### woulle clocks Table 5-2. Module clocks | Module | Bus interface clock | Internal clocks/ | I/O interface clocks | |----------------------------|---------------------|-----------------------------------------------------------|----------------------| | | | Protocol clocks | | | | Core | modules | | | ARM Cortex-M0+ core | System clock | Core clock | | | NVIC | System clock | | | | Single Wire Debug | — | _ | SWD_CLK | | Single Wile Bobug | System | modules | 0WD_0ER | | DMA | System clock | _ | | | DMA Mux | Bus clock | _ | _ | | Port control | Bus clock | LPO | _ | | Crossbar Switch | System clock | _ | _ | | Peripheral bridges | System clock | Bus clock | | | MPU | System clock | _ | | | LLWU, PMC, SIM | Bus Clock | LPO | | | Mode controller | Bus Clock | _ | | | EWM | Bus clock | LPO/MCGIRCLK/ | | | | Duo olook | OSC32KCLK/ERCLK32K | | | Watchdog timer | Bus clock | LPO/OSC32KCLK/<br>MCGIRCLK/ERCLK32K | _ | | Peripheral Crossbar (XBAR) | Bus clock | _ | _ | | | CI | ocks | | | MCG | Bus clock | MCGOUTCLK, MCGPLLCLK,<br>MCGFLLCLK, MCGIRCLK,<br>OSCERCLK | - | | OSC | Bus clock | OSCERCLK | _ | | | Memory and m | emory interfaces | | | Flash Controller | System clock | Flash clock | _ | | Flash memory | Flash clock | Flash Oscillator Clock <sup>1</sup> | _ | | | Sec | curity | | | PCRC | Bus clock | _ | - | | RNGA | Bus clock | _ | - | | | Ar | alog | | | AFE | Bus clock | MCGPLLCLK, MCGFLLCLK, MCGIRCLK, TMR_0 output <sup>2</sup> | AFE_CLK | | CMP | Bus clock | _ | - | | VREF | Bus clock | _ | _ | | SAR ADC | Bus Clock | OSCERCLK | <del>_</del> | | | Tir | ners | | | PIT | Bus clock | _ | _ | | LPTMR | Bus clock | LPO, OSCERCLK,<br>MCGIRCLK, ERCLK32K | _ | # Table 5-2. Module clocks (continued) | Module | Bus interface clock | Internal clocks/ | I/O interface clocks | | | | | |------------------|--------------------------|--------------------------------------------------|----------------------|--|--|--|--| | | | Protocol clocks | | | | | | | iRTC | Bus clock | EXTAL32, Fine<br>Compensation Clock <sup>3</sup> | _ | | | | | | Quad Timer | Bus clock | Selectable via XBAR | _ | | | | | | | Communicat | ion interfaces | | | | | | | SPI | System clock | _ | SCK | | | | | | I <sup>2</sup> C | Bus clock | _ | SCL | | | | | | UART1, UART3 | System clock | _ | _ | | | | | | UART0, UART2 | Bus clock | _ | _ | | | | | | | Human-machine interfaces | | | | | | | | GPIO | System clock | _ | _ | | | | | | Segment LCD | Bus Clock | OSC32KCLK, MCGIRCLK | _ | | | | | <sup>1.</sup> Internal clock switches to Flash Clock when booting in VLPR and/or NVOPT[5] bit is asserted. In this case Flash clock is 1 MHz - 2. Selection done inside AFE Wrapper - 3. This clock can be 2 MHz or 4 MHz. Selection done via register bit in MCG woule clocks # Chapter 6 Reset and Boot #### 6.1 Reset This section discusses basic reset mechanisms and sources. Some modules that cause resets can be configured to cause interrupts instead. Consult the individual peripheral chapters for more information. ## 6.1.1 System resets and sources Resetting the MCU provides a way to start processing from a known set of initial conditions. System reset begins with the on-chip regulator in full regulation and system clocking generation from an internal reference. When the processor exits reset, it performs the following: - Reads the start SP (SP\_main) from vector-table offset 0 - Reads the start PC from vector-table offset 4 - LR is set to 0xFFFF\_FFFF All on-chip peripheral modules are disabled and the non-analog I/O pins are initially configured as disabled. Refer to Pinouts and Packaging chapter for exceptions. The pins with analog functions assigned to them default to their analog function after reset. The various system reset sources are discussed in the following sub-sections. ## 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 ( $V_{POR}$ ), the POR circuit causes a POR reset condition. KM Family Reference Manual, Rev. 5, Oct 2013 129 nese As the supply voltage rises, the LVD circuit holds the MCU in reset until the supply has risen above the LVD low threshold ( $V_{LVLD}$ ). The POR and LVD bits in SRSL register are set following a POR. ## 6.1.1.2 External pin reset (RESET) On this device, $\overline{RESET}$ is a dedicated pin. This pin is open drain and has an internal pull-up device. Asserting $\overline{RESET}$ wakes the device from any low power mode. #### **NOTE** Using the LLWU module, RESET is always enabled as a wakeup source in VLLS mode (if RESET pin is not configured as GPIO). The wakeup will always cause a CPU reset flow on exit from these power modes. ### 6.1.1.2.1 Reset pin filter The RESET pin supports digital filtering in all modes of operation. For VLLS3/2/1 modes, the LLWU provides an optional fixed digital filter running off the 1 kHz LPO clock. See the LLWU chapter for operation of this filter. During non-low leakage operation, there are two clock options for the RESET pin filter – the 1kHz LPO clock and the bus clock. This RESET pin filter implemented in RCM logic includes a separate filter for each clock source. In Stop and VLPS operation this logic either switches to bypass operation or has continued filtering operation depending on the filtering mode selected. There are several modes defined – See the RCM\_RPFC register description in RCM module for more details. Both filters are reset on POR, LVD, and wakeup from VLLS. The reset value for each filter defaults to off (non-detect). The LPO filter is simple with a fixed filter value count of 3. There is also a synchronizer on the input signal that results in an associated latency (2 cycles). As such, it takes 5 cycles to complete a transition from low-to-high or high-to-low. The LPO Filter initializes to off (logic 1) when the LPO filter is not enabled. The Bus Filter initializes to off (logic 1) when the Bus Filter not enabled. When the Bus Filter is enabled, the number of counts is controlled by RCM\_RPFW[RSTFLTSEL[4:0]]. ## 6.1.1.3 Low-voltage detect (LVD) reset 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 low-voltage detect (LVD) circuit with a user-selectable trip voltage, either high ( $V_{LVDH}$ ) or low ( $V_{LVDL}$ ). The trip voltage is selected by the LVDSC1[LVDV] bits. The LVD system is always enabled in normal run, wait, and stop modes. The LVD system is disabled in VLPx, and VLLSx modes. Refer to Power Management Controller (PMC) chapter for more details. The LVD can be configured to generate a reset upon detection of a low voltage condition by setting LVDSC1[LVDRE]. After an LVD reset has occurred, the LVD system holds the MCU in reset until the supply voltage rises above the low voltage detection threshold. The SRSL[LVD] bit is set following an LVD reset or POR. ## 6.1.1.4 Watchdog reset The watchdog timer monitors the operation of the system by expecting periodic communication from the software, generally known as servicing (or refreshing) the watchdog. If this periodic refreshing does not occur, the watchdog issues a system reset. The WDOG reset causes the SRSL[WDOG] bit to set. ## 6.1.1.5 Low leakage wakeup (LLWU) reset The LLWU allows 16 external pins, the $\overline{RESET}$ and NMI pin, and up to five internal peripherals to wake the MCU from VLLSx power modes. The LLWU module is only functional in VLLSx power modes. In these modes, any VLLS mode exits via a wakeup or reset event, the SRSL[WAKEUP] bit in mode controller module is set indicating the low leakage mode was active prior to the last system reset flow. Using the $\overline{RESET}$ pin to trigger an exit from VLLS results in the SRSL[PIN] bit being set as well. Refer to the mode controller chapter for more details. After a system reset, the LLWU retains the flags to indicate the source of the last wakeup until the user clears them. #### **NOTE** Pin wakeup and error condition flags are cleared in the LLWU and module wakeup flags are required to be cleared in the peripheral module. Refer to the individual peripheral specifications for more information. KM Family Reference Manual, Rev. 5, Oct 2013 ## 6.1.1.6 Stop acknowledgement reset Prior to entering any low power mode where module clocks are being gated, the SMC expects every module to provide a stop\_ack signal which indicates that the module can be put into low power mode. If such a response is expected from a module and is not received till a certain timeout period, a reset is generated and the reset sequence is executed and chip starts over again. This reset generation due to non-receipt of stop\_ack is call the "stop ack reset". Stop acknowledgement is generated by modules that want to delay entry into low power mode until their current operation is complete. Peripherals that may generate stop\_ack signal are: - AFE—Optionally active in low power mode, however if stopped, module must complete the current conversion before entering low power mode - SAR—Optionally active in low power mode, however if stopped, module must complete the current conversion before entering low power mode - I2C—Will complete current transfer and enter low power mode if configured to halt in the low power mode - Other modules include—Flash, Port control blocks, PIT, DMA ## 6.1.1.7 Multipurpose clock generator loss-of-clock (LOC) reset The MCG includes a clock monitor. The clock monitor resets the device when the following conditions are met: - The clock monitor is enabled (MCG\_C6[CME] = 1) - The MCG's external reference clock falls outside of the expected frequency range, depending on the MCG\_C2[RANGE] bit The RCM\_SRSL[LOC] bit is set to indicate the error. ## 6.1.1.8 Software reset (SW) The SYSRESETREQ bit in the NVIC application interrupt and reset control register can be set to force a software reset on the device. (See ARM's NVIC documentation for the full description of the register fields, especially the VECTKEY field requirements.) Setting SYSRESETREQ generates a software reset request. This reset forces a system reset of all major components except for the debug module. A software reset causes SRS1[SW] bit to set. ## 6.1.1.9 Lockup reset (LOCKUP) The LOCKUP gives immediate indication of seriously errant kernel software. This is the result of the core being locked because of an unrecoverable exception following the activation of the processor's built in system state protection hardware. The LOCKUP condition causes a system reset and also causes SRSH[LOCKUP] bit to set. # 6.1.1.10 Debug reset (DAP reset) The chip can be reset while in debug mode by generating a DAP reset. The reset command is sent to the DAP (Debug Access Port) which when decoded generates a system reset and the chip executes the reset sequence. Refer to Debug chapter for more details on this reset. #### 6.2 Boot This section describes the boot sequence, including sources and options. ## 6.2.1 Boot sources This device only supports booting from internal flash. Any secondary boot must go through an initialization sequence in flash. ## 6.2.2 Boot options The device boots up in functional mode by default after any reset or power up. The device boots up using the internal flash as the boot source. ## 6.2.3 FOPT boot options The flash option register (FOPT) in 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 DUU 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, refer to the flash memory chapter. The MCU uses the FTFL\_FOPT register bits to configure the device at reset as shown in the following table. Table 6-1. Flash Option Register (FTFL\_FOPT) Bit Definitions | Bit<br>Num | Field | Value | Definition | |------------|-----------------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7-6 | Reserved | - | Reserved for future expansion | | 5 | CLK_SRC <sup>1</sup> | 1 | Internal clock source used by Flash | | | | 0 | Externally supplied clock used by Flash | | 4 | Reserved | - | Reserved for future expansion | | 3 | EXE_MODE <sup>2</sup> | 1 | Execution Mode is VLPR Mode | | | | 0 | Execution Mode is RUN Mode | | 2 | NMI_EN | 1 | NMI_B pin is enabled. NMI functionality is enabled | | | | 0 | NMI_B pin is disabled. NMI functionality is disabled | | 1 | Reserved | - | Reserved for future expansion | | 0 | LPBOOT | 0 | Slow boot: SYSDIV and SYSCLKMODE values in SIM_CLKDIV1 register are autoconfigured at reset exit for higher divide values that produce lower power consumption at reset exit. • Core and system clock divider (SYS_DIV) is set to 0x7 (divide by 8) | | | | 1 | Fast boot: SYSDIV and SYSCLKMODE values in SIM_CLKDIV1 register are auto-<br>configured at reset exit for higher frequency values that produce faster operating<br>frequencies at reset exit. | | | | | Core and system clock divider (SYS_DIV) is set to 0x0 (divide by 1) | <sup>1.</sup> This bit has effect only in RUN mode boot up. Ignored in VLPR boot. # 6.2.4 Boot sequence ## 6.2.4.1 Boot Up Process #### NOTE The steps described are common to boot in RUN or boot in VLPR unless explicitly mentioned for that step. #### NOTE Boot will happen in RUN mode unless overridden using RTC bit (Hardware override - takes effect from next reset) or <sup>2.</sup> This bit will not change mode for boot automatically and is different from the RTC Boot Override bit. This bit is for software so that a startup code can change mode based on setting of this bit whenever it is executed on every boot up NVOPT bit (EXE\_MODE—Software override). EXE\_MODE does not change mode automatically but software can check the setting of this bit and change mode accordingly. 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 $\overline{RESET}$ pin is driven out low - 2. SMC enters RUN or VLPR mode (depending on override bit in RTC) keeping LVD enabled in either case. - 3. The MCG is enabled in its default clocking mode in which this is needed to ensure low startup current during Missing Neutral Scenario Recommendations. - System will boot-up in BLPI (Bypass Low Power Internal) with 4 MHz IRC being used and FLL disabled. - 4. All module clocks except RTC clock are disabled. iRTC is the only module that can function after POR as it is in separate power domain (VBAT). SMC and modules needed for boot will be active. - 5. The system reset on internal logic continues to be held, but the Flash Controller is released from reset and begins initialization operation while the Reset Control logic continues to drive the RESET pin out low - 6. Early in reset sequencing the NVM option byte is read and stored to FOPT. If the CLK\_SRC bit is programmed clear, the Flash initialization switches to slower clock (when in RUN mode). When in VLPR mode, the Flash initialization happens on slower clock from beginning and does not depend on CLK\_SRC bit value. If the bits associated with LPBOOT are programmed for an alternate clock divider reset value, the system/core clock is switched to an even slower clock speed. - 7. When Flash Initialization completes, the RESET pin is observed. If RESET continues to be asserted (an indication of a slow rise time on the RESET pin or external drive in low), the system continues to be held in reset. Once the RESET pin is detected high, the system is released from reset. - 8. At release of system reset, LVD is disabled provided boot happens in VLPR mode (LVD not disabled in RUN mode boot). - 9. When the system exits reset, the processor sets up the stack, program counter (PC), and link register (LR). The processor reads the start SP (SP\_main) from vector-table offset 0. The core reads the start PC from vector-table offset 4. LR is set to 0xFFFF\_FFFF. - 10. If the NMI input is low and the NMI\_EN bit equals 1, this results in an NMI interrupt. The processor executes an Exception Entry and reads the NMI interrupt handler address from vector-table offset 8. The CPU begins execution at the NMI interrupt handler. DUU 11. If NMI input is high when the system exits reset then the CPU begins execution at the PC location. Subsequent system resets follow this reset and boot flow. # **Chapter 7 Power Management** #### 7.1 Introduction This chapter describes the various chip power modes and functionality of the individual modules in these modes. #### 7.2 Power Modes The system mode controller (SMC) provides multiple power options to allow the user to optimize power consumption for the level of functionality needed. The three primary modes of operation are run, wait and stop. The WFI instruction invokes both wait and stop modes for the chip. The primary modes are augmented in a number of ways to provide lower power based on application needs. For each run mode there is a corresponding wait and stop mode. Wait modes are similar to ARM sleep modes. Stop modes (VLPS, STOP) are similar to ARM sleep deep mode. The very low power run (VLPR) operating mode can drastically reduce runtime power when the maximum bus frequency is not required to handle the application needs. Depending on the stop requirements of the user application, a variety of stop modes are available that provide state freeze (by clock gating), 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. Chip power modes | Chip mode | Description | Core mode | Normal<br>recovery<br>method | |-----------|-----------------------------------------------------------------------------------------------------|-----------|------------------------------| | | Allows maximum performance of chip. Default mode out of reset; on-<br>chip voltage regulator is on. | Run | - | Table continues on the next page... KM Family Reference Manual, Rev. 5, Oct 2013 #### FOWER Modes Table 7-1. Chip power modes (continued) | Chip mode | Description | Core mode | Normal recovery method | |--------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|---------------------------| | Normal Wait<br>(WAIT) - via WFI | Allows peripherals to function while the core is in sleep mode, thus reducing power. NVIC remains sensitive to interrupts; peripherals continue to be clocked. Flash can be optionally kept off to reduce leakage current further. | Sleep | Interrupt | | Partial STOP2<br>(PSTOP2) | Core and System clocks are gated while Bus clock is active. Allows peripherals to function. Clock generators and regulators are fully functional. AWIC is used to wake up from async. interrupt. Less power consumption than WAIT. Can be entered from both RUN & VLPR modes. | Sleep Deep | Interrupt | | Partial STOP1<br>(PSTOP1) | Core, System and Bus clocks are gated. Peripherals working on different clock source will continue to operate. Clock generators and regulators are fully active. AWIC is used to wake up from async. interrupt. Less power consumption than PSTOP2 but higher than STOP. Can be entered from both RUN & VLPR modes. | Sleep Deep | Interrupt | | Normal Stop<br>(STOP) - via<br>WFI | Places chip in static state. Lowest power mode that retains all registers while maintaining LVD protection. NVIC is disabled; AWIC is used to wake up from interrupt; peripheral clocks are stopped. | Sleep Deep | Interrupt | | Very Low Power<br>Run (VLPR) | On-chip voltage regulator is in a low power mode that supplies only enough power to run the chip at a reduced frequency. Reduced frequency Flash access mode (1 MHz); LVD off; internal oscillator provides a low power 2 MHz source for the core, the bus and the peripheral clocks. | Run | Interrupt | | Very Low Power<br>Wait (VLPW) -<br>via WFI | Same as VLPR but with the core in sleep mode to further reduce power; NVIC remains sensitive to interrupts (FCLK = ON). On-chip voltage regulator is in a low power mode that supplies only enough power to run the chip at a reduced frequency. | Sleep | Interrupt | | Very Low Power<br>Stop (VLPS) -<br>via WFI | Places chip in static state with LVD operation off. Lowest power mode with ADC and pin interrupts functional. Peripheral clocks are stopped, but LPTimer, iRTC, CMP, can be used. NVIC is disabled (FCLK = OFF); AWIC is used to wake up from interrupt. On-chip voltage regulator is in a low power mode that supplies only enough power to run the chip at a reduced frequency. All SRAM is operating (content retained and I/O states held). | Sleep Deep | Interrupt | | VLLS3 (Very<br>Low Leakage<br>Stop3) | Most peripherals are powered off but LLWU, LPTMR, iRTC, CMP can be used. NVIC is disabled; LLWU is used to wake up. Full SRAM remains powered on (content retained and I/O states held). | Sleep Deep | Wakeup Reset <sup>1</sup> | | VLLS2 (Very<br>Low Leakage<br>Stop2) | Most peripherals are powered off but LLWU, LPTMR, iRTC, CMP can be used. NVIC is disabled; LLWU is used to wake up. 4 kB of SRAM is powered on (content retained and I/O states held). | Sleep Deep | Wakeup Reset <sup>1</sup> | | VLLS1 (Very<br>Low Leakage<br>Stop1) | Most peripherals are powered off but LLWU, LPTMR, iRTC, CMP can<br>be used. NVIC is disabled; LLWU is used to wake up; Internal<br>regulator is disabled; LPO & Brown-out are powered | Sleep Deep | Wakeup Reset <sup>1</sup> | | | All of SRAM is powered off. The 32-byte VBAT register file remain powered for customer-critical data. | | | | VLLS0 (Very<br>Low Leakage<br>Stop 0) | LLWU, iRTC can be used. All SRAM powered off. NVIC disabled;<br>Internal regulator is disabled; LPO is OFF. Brown-out detection is<br>configurable | Sleep Deep | Wakeup Reset <sup>1</sup> | #### Table 7-1. Chip power modes (continued) | Chip mode | Description | Core mode | Normal<br>recovery<br>method | |------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|------------------------------| | BAT (backup<br>battery only) | The chip is powered down except for the VBAT supply. The iRTC and the 32-byte VBAT register file for customer-critical data remain powered. This mode can be entered when VDD gets removed or by using the Wakeup FeatureExternal LDO Wakeup Control in RTC. | Off | Power-up<br>Sequence | <sup>1.</sup> Follows the reset flow with the LLWU interrupt flag set for the NVIC. # 7.3 Entering and exiting power modes The WFI instruction invokes wait and stop modes for the chip. The processor exits the low-power mode via an interrupt (Reset causes chip to go into Run/VLPR mode - current boot-up power mode). The NVIC controls what peripherals can cause interrupts. Recovery from VLLSx is through the wake-up Reset event. The chip wake-ups from VLLSx by means of reset, an enabled pin or enabled module. See the table "LLWU inputs" in the LLWU configuration section for a list of the sources. The wake-up flow from VLLSx is through reset. The wakeup bit in the SRS registers in the Mode Controller is set indicating that the chip is recovering from a low power mode. Code execution begins; however, the I/O pins are held in their pre-low-power mode entry states, and the oscillator is disabled (even if EREFSTEN had been set before entering VLLSx). Software must clear this hold by writing a 1 to the ACKISO bit in the Control and Status register in the LLWU module Regulator Status and Control Register in the PMC module. #### **NOTE** To avoid unwanted transitions on the pins, software must reinitialize the I/O pins to their pre-low-power mode entry states *before* releasing the hold. The oscillator cannot be re-enabled before the ACKISO bit is cleared and must be reconfigured after the hold is released. #### 7.4 Power mode transitions The following figure shows the power mode transitions. Any reset always brings the chip back to the normal run state. In run, wait, and stop modes active power regulation is enabled. The VLPx modes are limited in frequency, but offer a lower power operating mode than normal modes. The VLLSx modes are the lowest power stop modes based on amount of logic or memory that is required to be retained by the application . Figure 7-1. Power mode state transition diagram # 7.5 Power modes shutdown sequencing When entering stop or other low-power modes, the clocks are shut off in an orderly sequence to safely place the chip in the targeted low-power state. All low-power entry sequences are initiated by the core executing an WFI instruction. The ARM core's outputs, SLEEPDEEP and SLEEPING, trigger entry to the various low-power modes: - System level wait and VLPW modes equate to: SLEEPING & SLEEPDEEP - All other low power modes equate to: SLEEPING & SLEEPDEEP When entering the non-wait modes, the chip performs the following sequence: - Shuts off Core Clock and System Clock to the ARM Cortex-M0+ core immediately. - Polls stop acknowledge indications from the non-core crossbar master (DMA), supporting peripherals and the Flash Controller for indications that System Clock, Bus Clock and/or Flash Clock need to be left enabled to complete a previously initiated operation, effectively stalling entry to the targeted low power mode. When all acknowledges are detected, System Clock, Bus Clock and Flash Clock are turned off at the same time. - MCG and Mode Controller shut off clock sources and/or the internal supplies driven from the on-chip regulator as defined for the targeted low power mode. In wait modes, most of the system clocks are not affected by the low power mode entry. The Core Clock to the ARM Cortex-M0+ core is shut off. Some modules support stop-in-wait functionality and have their clocks disabled under these configurations. # 7.6 Module Operation in Low Power Modes The following table illustrates the functionality of each module while the chip is in each of the low power modes. Number ratings (such as 2 MHz and 1 Mbps) represent the maximum frequencies or maximum data rates per mode. Also, these terms are used: - FF = Full functionality. In VLPR and VLPW the system frequency is limited, limited peripherals can be chosen to work and hence mentioned as Optionally Active. - static = Module register states and associated memories are retained (clock to those blocks are gated). - powered = Memory is powered to retain contents. - low power = Flash/Memory or Regulator has a low power state that retains configuration registers to support faster wakeup. KM Family Reference Manual, Rev. 5, Oct 2013 #### **woulde Operation in Low Power Modes** - OFF = Modules are powered off; module is in reset state upon wakeup (VLLSx modes) - ON = Modules are powered on (VLLSx modes) - wakeup = Modules can serve as a wakeup source for the chip. - Optionally Active = Software can configure if module will be "FF" or "static" in particular low power mode Table 7-2. Module operation in low power modes | Modules | WAIT/PSTOP2 | STOP/PSTOP1 | VLPR | VLPW | VLPS | VLLSx | | | |----------------------------|----------------------------|---------------------------------------------------------------|-------------------------------|-------------------------------|--------------------------------|---------------------------------------------------------------------------------|--|--| | | | | Core modules | | | | | | | NVIC | FF | static | FF | FF | static | OFF | | | | SWD | Optionally Active | Optionally Active | Optionally Active | Optionally Active | Optionally Active | OFF | | | | System modules | | | | | | | | | | Mode Controller | FF | FF | FF | FF | FF | ON | | | | AWIC | static | FF | static | static | FF | OFF | | | | LLWU <sup>1</sup> | static | static | static | static | static | ON <sup>2</sup> | | | | Regulator | ON | ON | low power | low power | low power | low power in<br>VLLS2/3, OFF in<br>VLLS0/1 | | | | LVD | ON | ON | disabled | disabled | disabled | disabled | | | | Brown-out<br>Detection | ON | ON | ON | ON | ON | ON in<br>VLLS1/2/3,<br>optionally<br>disabled in<br>VLLS0 <sup>3</sup> | | | | DMA <sup>4</sup> | Optionally active | Optionally active <sup>5</sup> | Optionally active | Optionally active | Optionally active <sup>5</sup> | OFF | | | | Watchdog | FF | Optionally active | FF | Optionally active | Optionally active | OFF | | | | EWM | Optionally active | static | Optionally active | static | static | OFF | | | | XBAR | Optionally active | static <sup>6</sup> | Optionally active | Optionally Active | static <sup>6</sup> | OFF | | | | | | | Clocks | | | | | | | 1kHz LPO | FF | FF | FF | FF | FF | ON in<br>VLLS1/2/3, OFF<br>in VLLS0 | | | | System<br>Oscillator (OSC) | Optionally active OSCERCLK | Optionally active<br>OSCERCLK | Optionally active<br>OSCERCLK | Optionally active<br>OSCERCLK | Optionally active<br>OSCERCLK | limited to low<br>range/low power<br>in VLLS1/2/3,<br>OFF in VLLS0 <sup>7</sup> | | | | MCG <sup>8</sup> | FF | static - IRCLK<br>optional; FLL<br>optionally on but<br>gated | 2 MHz IRC | 2 MHz IRC | static - no clock<br>output | OFF | | | | PLL 32k | Optionally active | Optionally active | Optionally active | Optionally active | Optionally active | OFF | | | | Core clock | static | static | 2 MHz max | static | static | OFF | | | | System clock | FF <sup>9</sup> | static | 2 MHz max | 2 MHz max | static | OFF | | | | Bus clock | FF | static | 1 MHz max | 1 MHz max | static | OFF | | | 143 # Table 7-2. Module operation in low power modes (continued) | Modules | WAIT/PSTOP2 | STOP/PSTOP1 | VLPR | VLPW | VLPS | VLLSx | |-----------------------------------------|--------------------------------------------|--------------------------------------------|------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|--------------------------------------------|----------------------------------------------------| | | | Memor | y and Memory Int | erfaces | | | | Flash | Optionally in low power or FF (no program) | powered | 1 MHz max<br>access - no<br>program | low power | low power | OFF | | SRAM | low power | low power | low power | low power | low power | low power in<br>VLLS3, 4kB<br>powered in<br>VLLS2, | | | | | | | | OFF in<br>VLLS0/1 | | iRTC register file <sup>10</sup> | powered | powered | powered | powered | powered | powered | | | | Com | munication interf | aces | | | | UART | Optionally active | static, wakeup<br>on edge | Optionally active 125 kbps for UART1/UART3 if active 62.5 kbps for UART0/UART2 if active | Optionally active 125 kbps for UART1/UART3 if active 62.5 kbps for UART0/UART2 if active | static, wakeup<br>on edge | OFF | | SPI | Optionally active | static | Optionally active 1 Mbps if active | Optionally active 1 Mbps if active | static | OFF | | I <sup>2</sup> C | Optionally active | static, address<br>match wakeup | Optionally active 100 kbps if active | Optionally active 100 kbps if active | static, address<br>match wakeup | OFF | | | | | Security | | | | | CRC | Optionally active | static | Optionally active | Optionally active | static | OFF | | RNGA | static | static | Optionally active | static | static | OFF | | | | | Timers | | | | | PIT | Optionally active | static | Optionally active | Optionally active | static | OFF | | LPTMR | Optionally active | Optionally active | Optionally active | Optionally active | Optionally active | FF <sup>11</sup> | | TMR | Optionally active | static | Optionally active | Optionally active | static | OFF | | RTC, POR and<br>32kHz OSC <sup>10</sup> | FF | FF | FF | FF | FF | FF | | | | | Analog | | | | | 16-bit SAR ADC | Optionally active | Optionally active ADC internal clock only | Optionally active | Optionally active | Optionally active ADC internal clock only | OFF | | CMP <sup>12</sup> | Optionally active | HS or LS<br>compare | Optionally active | Optionally active | HS or LS<br>compare | LS compare in<br>VLLS1/2/3, OFF<br>in VLLS0 | | AFE | Optionally active | Optionally active <sup>13</sup> | Optionally active <sup>14</sup> | Optionally active | Optionally active <sup>15</sup> | OFF | #### Clocking modes #### Table 7-2. Module operation in low power modes (continued) | Modules | WAIT/PSTOP2 | STOP/PSTOP1 | VLPR | VLPW | VLPS | VLLSx | | |---------------------------|--------------------------|---------------------------------|---------------------------------|---------------------------------|---------------------------------|---------------------------|--| | VREF <sup>16</sup> | Optionally active | Optionally active <sup>17</sup> | Optionally active <sup>17</sup> | Optionally active <sup>17</sup> | Optionally active <sup>17</sup> | OFF | | | | Human-machine interfaces | | | | | | | | GPIO | wakeup | wakeup | Optionally active | wakeup | wakeup | OFF, pins<br>latched | | | Segment LCD <sup>18</sup> | Optionally active | Optionally active | Optionally active | Optionally active | Optionally active | Optionally active. 19, 20 | | - Using the LLWU module, the external pins available for this chip do not require the associated peripheral function to be enabled. It only requires the function controlling the pin (GPIO or peripheral) to be configured as an input to allow a transition to occur to the LLWU. - 2. Since LPO clock source is disabled, filters will be bypassed during VLLS0 - 3. The VLLSCTRL[PORPO] bit in the SMC module controls this option. - 4. Async DMA request allows DMA to operate in low power modes without waking up CPU. - 5. DMA can be used if a module generates Async DMA request (for e.g. AFE) - 6. Configured signal paths are fully functional but register states are retained. - 7. In VLLSx mode, design does not guarantee operation of system oscillator in high freq/gain. - 8. SOC cannot enter in VLPR mode until the LP bit in MCG\_C2 register is set to 1. - 9. System clock, clock used by core will be gated. Enabled only for active peripherals - 10. These components remain powered in VBAT power mode. - 11. System OSC and LPO clock sources are not available in VLLS0 - 12. CMP in stop or VLPS supports high speed or low speed external pin to pin or external pin to DAC compares. CMP in VLLSx only supports low speed external pin to pin or external pin to DAC compares. Windowed, sampled & filtered modes of operation are not available while in stop, VLPS, or VLLSx modes. - 13. As long as modulator clock is not gated, AFE can work. - 14. Will operate in low power mode of AFE for missing neutral scenario. - 15. PLL is not available in VLPS. AFE can run off other clock sources. - 16. VREF can be configured to operate in low power buffer mode (cannot drive VREF pin) - 17. Can be configured to work in low power buffer mode - 18. LCD IOs will continue to drive last value being driven before entering low power mode - 19. End of Frame wakeup not supported in VLLSx - 20. In VLPS and VLLSx modes, SLCD can be configured to continue displaying the current LCD panel contents. ## 7.7 Clocking modes Information found here describes the various clocking modes supported on this device. ## 7.7.1 Partial Stop Partial Stop is a clocking option that can be taken instead of entering Stop mode and is configured in the SMC Stop Control Register (SMC\_STOPCTRL). The Stop mode is only partially entered, which leaves some additional functionality alive at the expense of higher power consumption. Partial Stop can be entered from either Run mode or VLP Run mode. When configured for PSTOP2, only the core and system clocks are gated and the bus clock remains active. The bus masters and bus slaves clocked by the system clock enter Stop mode, but the bus slaves clocked by bus clock remain in Run (or VLP Run) mode. The clock generators in the MCG and the on-chip regulator in the PMC also remain in Run (or VLP Run) mode. Exit from PSTOP2 can be initiated by a reset, an asynchronous interrupt from a bus master or bus slave clocked by the system clock, or a synchronous interrupt from a bus slave clocked by the bus clock. If configured, a DMA request (using the asynchronous DMA wakeup) can also be used to exit Partial Stop for the duration of a DMA transfer before the device is transitioned back into PSTOP2. When configured for PSTOP1, both the system clock and bus clock are gated. All bus masters and bus slaves enter Stop mode, but the clock generators in the MCG and the on-chip regulator in the PMC remain in Run (or VLP Run) mode. Exit from PSTOP1 can be initiated by a reset or an asynchronous interrupt from a bus master or bus slave. If configured, an asynchronous DMA request can also be used to exit Partial Stop for the duration of a DMA transfer before the device is transitioned back into PSTOP1. PSTOP1 is functionally similar to Stop mode, but offers faster wake-up at the expense of higher power consumption. Another benefit is that it keeps all of the MCG clocks enabled, which can be useful for some of the asynchronous peripherals that can remain functional in Stop modes. ### 7.7.2 DMA Wakeup The DMA can be configured to wake the device on a DMA request whenever it is placed in Stop mode. The wake-up is configured per DMA channel and is supported in Compute Operation, PSTOP, STOP, and VLPS low power modes. When a DMA wake-up is detected in PSTOP, STOP or VLPS then the device will initiate a normal exit from the low power mode. This can include restoring the on-chip regulator and internal power switches, enabling the clock generators in the MCG, enabling the system and bus clocks (but not the core clock) and negating the stop mode signal to the bus masters and bus slaves. The only difference is that the CPU will remain in the low power mode with the CPU clock disabled. During Compute Operation, a DMA wake-up will initiate a normal exit from Compute Operation. This includes enabling the clocks and negating the stop mode signal to the bus masters and bus slaves. The core clock always remains enabled during Compute Operation. #### Ciocking modes Since the DMA wakeup will enable the clocks and negate the stop mode signals to all bus masters and slaves, software needs to ensure that bus masters and slaves that are not involved with the DMA wake-up and transfer remain in a known state. That can be accomplished by disabling the modules before entry into the low power mode or by setting the Doze enable bit in selected modules. Once the DMA request that initiated the wake-up negates and the DMA completes the current transfer, the device will transition back to the original low-power mode. This includes requesting all non-CPU bus masters to enter Stop mode and then requesting bus slaves to enter Stop mode. In STOP and VLPS modes the MCG and PMC would then also enter their appropriate modes. #### NOTE If the requested DMA transfer cannot cause the DMA request to negate then the device will remain in a higher power state until the low power mode is fully exited. An enabled DMA wake-up can cause an aborted entry into the low power mode, if the DMA request asserts during the stop mode entry sequence (or reentry if the request asserts during a DMA wake-up) and can cause the SMC to assert its Stop Abort flag. Once the DMA wake-up completes, entry into the low power mode will restart. An interrupt that occurs during a DMA wake-up will cause an immediate exit from the low power mode (this is optional for Compute Operation) without impacting the DMA transfer. A DMA wake-up can be generated by either a synchronous DMA request or an asynchronous DMA request. Not all peripherals can generate an asynchronous DMA request in stop modes, although in general if a peripheral can generate synchronous DMA requests and also supports asynchronous interrupts in stop modes, then it can generate an asynchronous DMA request. ### 7.7.3 Compute Operation Compute Operation is an execution or compute-only mode of operation that keeps the CPU enabled with full access to the SRAM and Flash read port, but places all other bus masters and bus slaves into their stop mode. Compute Operation can be enabled in either Run mode or VLP Run mode. #### NOTE Do not enter any Stop mode without first exiting Compute Operation. Because Compute Operation reuses the Stop mode logic (including the staged entry with bus masters disabled before bus slaves), any bus master or bus slave that can remain functional in Stop mode also remains functional in Compute Operation, including generation of asynchronous interrupts and DMA requests. When enabling Compute Operation in Run mode, module functionality for bus masters and slaves is the equivalent of STOP mode. When enabling Compute Operation in VLP Run mode, module functionality for bus masters and slaves is the equivalent of VLPS mode. The MCG, PMC, SRAM, and Flash read port are not affected by Compute Operation, although the Flash register interface is disabled. During Compute Operation, the AIPS peripheral space is disabled and attempted accesses generate bus errors. The private peripheral space remains accessible during Compute Operation, including the MCM, NVIC, IOPORT, and SysTick. Although access to the GPIO registers via the IOPORT is supported, the GPIO Port Data Input registers do not return valid data since clocks are disabled to the Port Control and Interrupt modules. By writing to the GPIO Port Data Output registers, it is possible to control those GPIO ports that are configured as output pins. Compute Operation is controlled by the CPO register in the MCM (MCM\_CPO), which is only accessible to the CPU. Setting or clearing MCM\_CPO[CPOREQ] initiates entry or exit into Compute Operation. Compute Operation can also be configured to exit automatically on detection of an interrupt, which is required in order to service most interrupts. Only the core system interrupts (exceptions, including NMI and SysTick) and any edge-sensitive interrupts can be serviced without exiting Compute Operation. - When entering Compute Operation, the CPOACK status field in the CPO register of MCM module (MCM\_CPO[CPOACK]) indicates when entry has completed. - When exiting Compute Operation in Run mode, MCM\_CPO[CPOACK] negates immediately. - When exiting Compute Operation in VLP Run mode, the exit is delayed to allow the PMC to handle the change in power consumption. This delay means that MCM\_CPO[CPOACK] is polled to determine when the AIPS peripheral space can be accessed without generating a bus error. The DMA wake-up is also supported during Compute Operation and causes MCM\_CPO[CPOACK] to clear and the AIPS peripheral space to be accessible for the duration of the DMA wake-up. At the completion of the DMA wake-up, the device transitions back into Compute Operation. **Ciocking modes** # 7.7.4 Peripheral Doze Several peripherals support a Peripheral Doze mode, where a register bit can be used to disable the peripheral for the duration of a low-power mode. The flash memory can also be placed in a low-power state during Peripheral Doze via a register bit in the SIM. Peripheral Doze is defined to include all of the modes of operation listed below. - The CPU is in Wait mode. - The CPU is in Stop mode, including the entry sequence and for the duration of a DMA wakeup. - The CPU is in Compute Operation, including the entry sequence and for the duration of a DMA wakeup. Peripheral Doze can therefore be used to disable selected bus masters or slaves for the duration of WAIT or VLPW mode. It can also be used to disable selected bus slaves immediately on entry into any stop mode (or Compute Operation), instead of waiting for the bus masters to acknowledge the entry as part of the stop entry sequence. Finally, it can be used to disable selected bus masters or slaves that should remain inactive during a DMA wakeup. If the flash memory is not being accessed during WAIT and PSTOP modes, then the Flash Doze mode can be used to reduce power consumption, at the expense of a slightly longer wake-up when executing code and vectors from flash. It can also be used to reduce power consumption during Compute Operation when executing code and vectors from SRAM. ### 7.7.5 Clock gating To conserve power, the clocks to most modules can be turned off using the SCGCx registers in the SIM module. The bits of these registers are cleared after any reset, which disables the clock to the corresponding module. Prior to initializing a module, set the corresponding bit in the SCGCx register to enable the clock. Before turning off the clock, make sure to disable the module. For more details, see the Clock Distribution and SIM chapters. # Chapter 8 Security #### 8.1 Introduction This device has been designed to consider aspects of system reliability that includes robust watchdog mechanism with enhanced features to satisfy safely standards IEC 60730 for the appliance market. These are also useful for other applications like medical where fault tolerance is important. This micro-controller also includes an external watchdog monitor that can monitor external events like power supply. ## 8.2 External Watchdog Monitor Device includes additional watchdog Monitor apart from the main Watchdog (WDOG) to monitor external circuits as well as the MCU software flow. This provides a back-up mechanism to the internal watchdog that resets the MCU's CPU and peripherals. The EWM differs from the internal watchdog in that it does not reset the MCU's CPU and peripherals. The EWM if allowed to time-out, provides an independent output pin(EWM\_out) that when asserted resets or places an external circuit into a safe mode. This can be very useful for example to monitor external supplies if they don't behave in a specific way, switch off a relay to make a critical signal line go open circuit. EWM in conjunction with the standard internal watchdog that is included on the MCU, provides additional safety for critical circuits KM Family Reference Manual, Rev. 5, Oct 2013 149 #### 8.2.1 EWM Counter The 8-bit EWM counter if fed from a clock source that is independent of the CPU clock source. As the preferred time-out is between 1 ms and 100 mS the actual clock source should be in the khZ range. The clock source comes from the same 1 KHz LPO clock that feeds the independent clocked watchdog. The 8-bit ripple counter is reset to 0x00 after a CPU reset or an EWM refresh cycle. The 8-bit ripple counter value is not accessible to the CPU. The EWM 8-bit compare registers are write once after a CPU reset and cannot be modified until another CPU reset occurs. The EWM compare registers are used to create a time window, when the CPU services/refreshes the EWM module. If the CPU services the EWM when the counter value lies between EWM Compare Low Value(EWMxCMPL) and EWM Compare High Value (EWMxCMPH) value, the counter is reset to 0x00. If the CPU executes a EWM service/refresh outside this time window, EWM\_out is asserted. ## 8.2.2 EWM\_out Signal The EWM\_out is a digital output signal used to gate an external circuit (application specific) that control safety critical functions. For example, the EWM\_out can be connected to the high voltage transistors circuits that control an AC motor in large appliance or to the power supply on board. The EWM\_out signal is de-asserted when the EWM is being regularly serviced by the CPU, indicating that the application code is executing as expected. When an error condition occurs, the EWM\_out is asserted. Once the EWM\_out pin is asserted, it can only be de-asserted by forcing a MCU reset. ## 8.2.3 EWM\_In Signal The EWM\_in is a digital input signal that allows an external circuit to control the EWM\_out signal. For example, in the application, an external circuit monitors a safety specific feature, and if there is fault with this circuit's behavior, it can then actively initiate the EWM\_out signal that controls the gating circuit. If the EWM is connected to external Power supply, EWM\_In can indicate failure or problem with the supply thus asserting the feedback signal (EWM\_out). Application may choose to reset in this case. ## 8.3 Robust Watchdog for Improved System Reliability For the metering application, it is of utmost importance that the system must display a high degree of fault tolerance, so that if and when faults like software crashes happen, it is able to recover quickly and bring itself into a safe state. With the introduction of the IEC 60730 standards, it is required that even automatic electronic controls in household appliances ensure safe and reliable operation of their component. Applications like metering, factory automation, and appliance can have severe EMI or noisy environment that can result in data corruption or even system failure. When such data corruption occurs, program execution can be affected as the program counter might have been modified. Modification of the program code memory or a read of wrong data from code memory can result in a totally different and unintended instruction getting executed. Thus, program flow or the program code itself gets modified, i.e. code runaway, and the system can enter an unknown state where its behavior is unpredictable. Once the program flow takes an unexpected branch, the system can start behaving unpredictably, which is unacceptable for a safety critical system. Thus a lot of standards now require system operation to be immune to EMI so as to have reliable system operation. Watchdog needs to monitor the system so as to detect such system failures and take action to bring the system into a safe/known state. There have been some unique features added to the WDOG timer. ## 8.3.1 32-bit programmable timeout Period For system flexibility it is important to have programmable timeout period. To generate timeout values ranging from 1ms to 1 second, the length of the watchdog timer has to be chosen carefully. The frequency of the clock source for the watchdog could vary widely from a few KHz (say an on-chip RTC oscillator) to hundreds of MHz (system clock) that may affect the width of counter. The following figure shows timeout values possible with 8, 16, 24 and 32 bit timers, for different, practical clock frequencies. Figure 8-1. Possible Timeouts(Log scale) The vertical green band marks out a range of timeouts which cover the 1ms to 1 second range. As can be observed, a 32 bit counter is required to cover all clock frequencies and the expected range of watchdog timeouts. ### 8.3.2 Independent Clock Source The Watchdog module clock can be sourced from either 1Khz LPO clock or bus clock. #### 8.3.3 Write Protection Watchdogs generally have several control and configuration register bits, which are used to influence its operation, for example a bit to disable or enable the watchdog. Since these bits have a direct impact on the watchdog's operation, it is of prime interest to make sure they are not modified unintentionally. To achieve this objective a write protection scheme is implemented. One of the better write-protection schemes is to have a password style protection on the register bits, where the password is a sequence of two particular values. However, this scheme allows any amount of time to elapse in between the write of the two values, which means that the chances of runaway code managing to accidentally replicate the password are high. If the writes of the two values are spaced far apart in the code, it could happen that after the write of the first value the code runs away in an unintended direction, causes havoc, and then after enough number of iterations, branches to the location of the write of the second value. The WDOG places a restriction on the time gap between the writes of the two values, thereby reducing chances of runaway code being able to "unlock" the registers for writing and possibly disabling the watchdog. By placing a limit on the time gap, where the limit is just equal to the time it takes for the CPU to fetch and execute the write instruction for the second value, the user is forced to place the write instructions for the two values one after the other in the code (as assembly instructions). Now if there is a runaway after the execution of the first write, there is no time left for the code to possibly return and execute the instruction writing the second value of the sequence. This makes the refresh sequence more unique because it minimizes the chance of the sequence being replicated by runaway code. If the gap between the two words of the password is more than the programmable number (default 10) of system bus clock cycles, the watchdog infers an exception and resets the system. In addition, the amount of time for which the registers stay "unlocked" is limited too and roughly equal to the time it takes for these registers to be configured once, after which they are "locked" again. This write protection is in effect from right after system reset, leaving no room for runaway code to "sneak in" and change the watchdog's configuration. #### NOTE To prevent unintended modification of the watchdog's control and configuration register bits, the user is allowed to update them only within a period of N bus clock cycles after unlocking. This window period is known as the Watchdog Configuration Time (WCT). #### 8.3.4 Robust Refresh Mechanism The WDOG's refresh scheme is a sequence of two values (0xA602 followed by 0xB480), but the difference from watchdogs being used on existing S08/Coldfire parts is that it places a limit on the time that can elapse between the write of the two values. If the first #### **nobust Watchdog for Improved System Reliability** value of the sequence is written and not followed by the second one within a certain number of system bus clock cycles, the watchdog infers an exception and resets the system. #### 8.3.5 Windowed Refresh The WDOG has an option for a windowed refresh, as opposed to the normal refresh. The principle behind the windowed refresh is that watchdog can be refreshed only in a particular window of its timeout period. This window is defined by points in time, in between the timeout period and at the end of the timeout period. If the refresh takes place outside the window, this is a sign that the program code execution is taking place faster than expected and hence points to something abnormal in program code execution. The following figure illustrates the concept of windowed refreshing. Figure 8-2. Windowed Refresh Mode ### 8.3.6 Fast Response to Code Runaway As has been emphasized before, it is imperative that the response of the watchdog to a runaway code be as fast as possible. Code runaway is a state in which the system acts indeterministically and so it should be brought out of that state as fast as possible. The WDOG takes a proactive approach to this problem. While the method of running a timer in the watchdog and interpreting its timeout as a sign of system failure (due to runaway code or system clock failure) is time tested; it does however have one shortcoming. If code runaway happens in the early stages of the watchdog timer period, it takes a lot of time before safety measures (like resetting the system) kick in, because the watchdog waits for its timer to timeout. In some applications, this delay in the watchdog reacting, might be as large as 1 second (the watchdog's timeout period). The WDOG seeks to do this by recognizing the signs of runaway code early on and resetting the system immediately, without waiting for a timeout of its internal timer. These signs are: - Presence of a value, other than the two bonafide values of the refresh sequence or the register-unlock password, in the watchdog's refresh or unlock register The user's software code would only contain instruction writing the said sets of two values to these registers. Thus, the presence of a third value indicates something abnormal happening in the code, probably due to a runaway. - Failure to write to configuration registers within a small, fixed amount of time after unlocking them Again, this indicates something abnormal as a normal user code would contain at least one watchdog configuration operation following the instructions which unlock the registers. - Failure to write to at least one of the configuration registers within a small, fixed amount of time after system reset de-assertion This might seem an overkill but by forcing the user to do so, it is ensured that the user doesn't forget to properly configure the watchdog and get it up and running, as per the system's needs, as soon as possible after reset, in the midst all the other boot up tasks that are required by the system. When a timeout takes place, the logic generating a reset to the system is run off the fast system clock (in the range of tens to hundreds of MHz), rather than the watchdog's dedicated, slow clock (in the range of a few KHz to a few MHz). If the reset were to be generated off the slow clock, say 1 kHz (LPO clock), it could take the watchdog almost 1ms to reset the system, after timeout, leaving too much time for run away code to cause havoc. One risk in generating the reset off the system clock is that in the event this clock fails, the watchdog timer's timeout would go unacknowledged and wouldn't reset the system. To take care of such a situation, a backup circuit in the WDOG waits for second consecutive timeout of timer and passes it on as reset to the system, as shown in the following figure. Figure 8-3. Reset Generation Logic # 8.4 Watchdog configuration Table 8-1. Watchdog configuration | Description | Value | |-----------------------------------------------------------------------------|--------| | Default Value for WDOG Timer High | 0x004C | | Default Value for WDOG Timer High | 0x4B40 | | Watchdog Configuration Time (in number of bus clocks) | 256 | | Time allowed in between the two writes of the unlock and refresh sequences. | 20 | ## 8.5 iRTC Write Protect State Machine For additional system reliability, the iRTC includes a state machine that protects iRTC registers and standby RAM from any spurious updates that can happen due to run-away code. After a power on reset, the write-protect mechanism is disabled, allowing the user code to calibrate the iRTC clock, set the time in the clock registers, and set the date in the calendar registers. Once calibration and time & date settings are done, the user code should enable write protection mode. If not, the registers are put into write protect mode 15 seconds after power on. In case the write protect mode is unlocked to update registers, then the write protect mode is automatically enabled 2 seconds after unlock, if not already done by CPU. The protection mechanism works on the values written to write enable bits of the iRTC control register. By default unconditional write access is allowed to these bits only. To enable write protection, write 0b10 to these bits. To disable write protection, write the sequence 00, 01, 11, 10 to these bits. Any access made to the register space when write protection is enabled (i.e. registers in locked mode) will cause the transfer error signal to be asserted. # 8.6 iRTC Tamper Detection Mechanism NOTE This section will be updated once Tamper related enhancements on iRTC are completed. This section explains the tamper detection mechanism, conceptually. iRTC supports various tamper detection mechanisms as described below. These tampers can be classified as internal and external tampers. External tampers are detected outside the MCU while Internal tampers are detected within the MCU. All tamper events are recored with the time stamp to indicate the time and date of the tamper event. # 8.6.1 Internal Tamper Condition 1: Battery removed when MCU is powered OFF The detection of battery removal during system power off is done using a flop that is asserted on power-on reset. Since there is no difference between a proper shutdown and this tamper condition, this is considered as a tamper always. It is up to the firmware to differentiate between the tamper condition and normal power up. One way is to ignore this tamper interrupt when the SoC or application is in Service mode and simply reset the tamper interrupt. For other conditions it will be taken as a tamper. # 8.6.2 Internal Tamper Condition 2: Battery removed when MCU is powered ON The analog circuitry monitoring the battery voltage indicates when the battery voltage is removed. This signal is used by the tamper circuit to indicate a tamper provided MCU power in ON. ## 8.6.3 External Tamper Condition: Off Chip Tamper Indication An external off chip tamper switch is also used to monitor tampering external to the SoC. For example, a signal can be used to indicate that the case housing the SoC/board is opened or not. Since these events are detected off chip, these tamper inputs are precondition in the SoC logic (i.e. conversion to digital or level shifting, etc) before being input to RTC. External tamper switches are prone to noise and can cause false tamper indication if not filtered. Noise filtering is present in RTC for all external tamper inputs. The duration for which a tamper signal should be asserted to be indicated as tamper is programmable by user software in the register space. This duration is programmable from $64 \, \mu s$ to $125 \, ms$ to support a variety of tamper switches. The filtered signals are then used to generate the tamper status and interrupt signals. The polarity of the tamper inputs can be configured to be active high or active low. ### 8.6.4 Tamper Detection Flow Following steps describe how tamper is logged in the registers and how should software acknowledge the tamper status indication: - POR asserts tamper status bit 8 in register space (RTC\_TTSR\_SCR[11]) and tamper interrupt status bit (in RTC\_ISR) to indicate tamper on power up of device. - Tamper Interrupt Enable bit is also asserted on POR and an interrupt indication to CPU. - When CPU acknowledges the tamper interrupt by writing 1'b1 to the tamper interrupt status bit (RTC\_TTSR\_SCR[11]), the tamper status bits are cleared. - Internal tamper event (detected by SoC logic) are simply stored in their corresponding status bits and time stamp is captured. - Any tamper signal asserted externally are filtered in the tamper block. - Tamper detect signal is asserted when the filter counter matches the programmed filter duration. - Based on the tamper detect signal the appropriate status bit is asserted in the tamper status register (RTC\_TTSR\_SCR[15:8]) irrespective the tamper control bit is enabled or not. Time stamp is also logged for the latest tamper event. The time stamp does not indicate which tamper occured but the time when the latest tamper event took place. - The tamper interrupt status bit is asserted for the tamper status bits that are enabled by asserting the corresponding tamper control bit in RTC\_TTSR\_SCR[7:0]. - If interrupt is enabled CPU is interrupted by assertion of the interrupt signal. - Tamper interrupt status bit (in RTC\_ISR) is cleared when all tamper status bits (in RTC\_TTSR\_SCR[15:8]) are cleared by writing 1 to them. - Tamper interrupt can be armed or disabled by writing to the interrupt enable register bit (in RTC\_IER[0]) or the individual tamper control bits (RTC\_TTSR\_SCR[7:0]) through the CPU register programming interface. ## 8.6.5 Active Tamper Detection Active Tamper detection introduces a feedback loop providing more advanced method of monitoring external tampers and also ensuring extended life of anti-tamper switches. Normal passive tamper switches tend to get oxidized over a long period of time due to inactivity. Active tampering solves this problem by incorporating tamper switches which are normally closed and open when a tamper happens. Unlike passive tampers that are input, active tamper mechanism includes pair of one of more input/output switches. Chip outputs a known sequence (fixed or generated by Linear Feedback Shift Register) on the output anti-tamper switch while monitoring the input tamper switches for the same sequence. Figure 8-4. iRTC Active Tamper Detection INIC Tamper Detection Mechanism # Chapter 9 Debug #### 9.1 Introduction This device's debug is based on the ARM CoreSight<sup>TM</sup> architecture and is configured to provide the maximum flexibility as allowed by the restrictions of the pinout and other available resources. It provides register and memory accessibility from the external debugger interface, basic run/halt control plus 2 breakpoints and 2 watchpoints. Only one debug interface is supported: • Serial Wire Debug (SWD) ## 9.2 Debug Port Pin Descriptions The debug port pins default after POR to their SWD functionality. Table 9-1. Serial wire debug pin description | Pin Name | Туре | Description | |----------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------| | SWD_CLK | Input | Serial Wire Clock. This pin is the clock for debug logic when in the Serial Wire Debug mode. This pin is pulled down internally. | | SWD_IO | Input / Output | Serial wire debug data input/output. The SWD_IO pin is used by an external debug tool for communication and device control. This pin is pulled up internally. | ## 9.3 SWD status and control registers Through the ARM Debug Access Port (DAP), the debugger has access to the status and control elements, implemented as registers on the DAP bus as shown in the following figure. These registers provide additional control and status for low power mode recovery and typical run-control scenarios. The status register bits also provide a means for the debugger to get updated status of the core without having to initiate a bus transaction across the crossbar switch, thus remaining less intrusive during a debug session. It is important to note that these DAP control and status registers are not memory mapped within the system memory map and are only accessible via the Debug Access Port using SWD. The MDM-AP is accessible as Debug Access Port 1 with the available registers shown in the table below. Table 9-2. MDM-AP Register Summary | Address | Register | Description | |-------------|----------|--------------------------------------------------------------------| | 0x0100_0000 | Status | See MDM-AP Status Register | | 0x0100_0004 | Control | See MDM-AP Control Register | | 0x0100_00FC | | Read-only identification register that always reads as 0x001C_0020 | Figure 9-1. MDM AP Addressing ## 9.3.1 MDM-AP Control Register Table 9-3. MDM-AP Control register assignments | Bit | Name | Secure <sup>1</sup> | Description | |-----|------------------------------|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Flash Mass Erase in Progress | Υ | Set to cause mass erase. Cleared by hardware after mass erase operation completes. | | | | | When mass erase is disabled (via MEEN and SEC settings), the erase request does not occur and the Flash Mass Erase in Progress bit continues to assert until the next system reset. | | 1 | Debug Disable | N | Set to disable debug. Clear to allow debug operation. When set it overrides the C_DEBUGEN bit within the DHCSR and force disables Debug logic. | Table continues on the next page... #### שיש status and control registers ## Table 9-3. MDM-AP Control register assignments (continued) | Bit | Name | Secure <sup>1</sup> | Description | |-----------|------------------------------------|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 2 | Debug Request | N | Set to force the Core to halt. | | | | | If the Core is in a stop or wait mode, this bit can be used to wakeup the core and transition to a halted state. | | 3 | System Reset Request | Υ | Set to force a system reset. The system remains held in reset until this bit is cleared. | | 4 | Core Hold Reset | N | Configuration bit to control Core operation at the end of system reset sequencing. | | | | | 0 Normal operation - release the Core from reset along with the rest of the system at the end of system reset sequencing. | | | | | 1 Suspend operation - hold the Core in reset at the end of reset sequencing. Once the system enters this suspended state, clearing this control bit immediately releases the Core from reset and CPU operation begins. | | 5 | VLLSx Debug Request<br>(VLLDBGREQ) | N | Set to configure the system to be held in reset after the next recovery from a VLLSx mode. This bit is ignored on a VLLS wakeup via the Reset pin. During a VLLS wakeup via the Reset pin, the system can be held in reset by holding the reset pin asserted allowing the debugger to re-initialize the debug modules. | | | | | This bit holds the system in reset when VLLSx modes are exited to allow the debugger time to re-initialize debug IP before the debug session continues. | | | | | The Mode Controller captures this bit logic on entry to VLLSx modes. Upon exit from VLLSx modes, the Mode Controller will hold the system in reset until VLLDBGACK is asserted. | | | | | The VLLDBGREQ bit clears automatically due to the POR reset generated as part of the VLLSx recovery. | | 6 | VLLSx Debug Acknowledge | N | Set to release a system being held in reset following a VLLSx recovery | | | (VLLDBGACK) | | This bit is used by the debugger to release the system reset when it is being held on VLLSx mode exit. The debugger re-initializes all debug IP and then assert this control bit to allow the Mode Controller to release the system from reset and allow CPU operation to begin. | | | | | The VLLDBGACK bit is cleared by the debugger or can be left set because it clears automatically due to the POR reset generated as part of the next VLLSx recovery. | | 7 | VLLSx Status Acknowledge | N | Set this bit to acknowledge the DAP VLLS Status bits have been read. This acknowledge automatically clears the status bits. | | | | | This bit is used by the debugger to clear the sticky VLLSx mode entry status bits. This bit is asserted and cleared by the debugger. | | 8 –<br>31 | Reserved for future use | N - | | 1. Command available in secure mode # 9.3.2 MDM-AP Status Register Table 9-4. MDM-AP Status register assignments | Bit | Name | Description | |-----|------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Flash Mass Erase Acknowledge | The Flash Mass Erase Acknowledge bit is cleared after any system reset. The bit is also cleared at launch of a mass erase command due to write of Flash Mass Erase in Progress bit in MDM AP Control Register. The Flash Mass Erase Acknowledge is set after Flash control logic has started the mass erase operation. | | | | When mass erase is disabled (via MEEN and SEC settings), an erase request due to seting of Flash Mass Erase in Progress bit is not acknowledged. | | 1 | Flash Ready | Indicate Flash has been initialized and debugger can be configured even if system is continuing to be held in reset via the debugger. | | 2 | System Security | Indicates the security state. When secure, the debugger does not have access to the system bus or any memory mapped peripherals. This bit indicates when the part is locked and no system bus access is possible. | | 3 | System Reset | Indicates the system reset state. | | | | 0 System is in reset | | | | 1 System is not in reset | | 4 | Reserved | | | 5 | Mass Erase Enable | Indicates if the MCU can be mass erased or not | | | | 0 Mass erase is disabled | | | | 1 Mass erase is enabled | | 6 | Backdoor Access Key Enable | Indicates if the MCU has the backdoor access key enabled. | | | | 0 Disabled | | | | 1 Enabled | | 7 | LP Enabled | Decode of LPLLSM control bits to indicate that VLPS, LLS, or VLLSx are the selected power mode the next time the ARM Core enters Deep Sleep. | | | | 0 Low Power Stop Mode is not enabled | | | | 1 Low Power Stop Mode is enabled | | | | Usage intended for debug operation in which Run to VLPS is attempted. Per debug definition, the system actually enters the Stop state. A debugger should interpret deep sleep indication (with SLEEPDEEP and SLEEPING asserted), in conjuntion with this bit asserted as the debugger-VLPS status indication. | | 8 | Very Low Power Mode | Indicates current power mode is VLPx. This bit is not 'sticky' and should always represent whether VLPx is enabled or not. | | | | This bit is used to throttle SWD_CLK frequency up/down. | | 9 | Reserved | Always read 0. | Table continues on the next page... #### **Debug Resets** Table 9-4. MDM-AP Status register assignments (continued) | Bit | Name | Description | |---------|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 10 | VLLSx Modes Exit | This bit indicates an exit from VLLSx mode has occurred. The debugger will lose communication while the system is in VLLSx (including access to this register). Once communication is reestablished, this bit indicates that the system had been in VLLSx. Since the debug modules lose their state during VLLSx modes, they need to be reconfigured. | | | | This bit is set during the VLLSx recovery sequence. The VLLSx Mode Exit bit is held until the debugger has had a chance to recognize that a VLLS mode was exited and is cleared by a write of 1 to the LLS, VLLSx Status Acknowledge bit in MDM AP Control register. | | 11 – 15 | Reserved for future use | Always read 0. | | 16 | Core Halted | Indicates the Core has entered debug halt mode | | 17 | Core SLEEPDEEP | Indicates the Core has entered a low power mode | | 18 | Core SLEEPING | SLEEPING==1 and SLEEPDEEP==0 indicates wait or VLPW mode. | | | | SLEEPING==1 and SLEEPDEEP==1 indicates stop or VLPS mode. | | 19 – 31 | Reserved for future use | Always read 0. | ## 9.4 Debug Resets The debug system receives the following sources of reset: - Debug reset (CDBGRSTREQ bit within the DP CTRL/STAT register) that allows the debugger to reset the debug logic. - System POR reset Conversely the debug system is capable of generating system reset using the following mechanism: - A system reset in the DAP control register which allows the debugger to hold the system in reset. - SYSRESETREQ bit in the NVIC application interrupt and reset control register - A system reset in the DAP control register which allows the debugger to hold the Core in reset. ## 9.5 Micro Trace Buffer (MTB) The Micro Trace Buffer (MTB) provides a simple execution trace capability for the Cortex-M0+ processor. When enabled, the MTB records changes in program flow reported by the Cortex-M0+ processor, via the execution trace interface, into a configurable region of the SRAM. Subsequently an off-chip debugger may extract the trace information, which would allow reconstruction of an instruction flow trace. The MTB does not include any form of load/store data trace capability or tracing of any other information. In addition to providing the trace capability, the MTB also operates as a simple AHB-Lite SRAM controller. The system bus masters (including the processor) have read/write access to all of the SRAM via the AHB-Lite interface, allowing the memory to also be used to store program and data information. The MTB simultaneously stores the trace information into an attached SRAM and allows bus masters to access the memory. The MTB ensures that trace information write accesses to the SRAM take priority over accesses from the AHB-Lite interface. The MTB includes trace control registers for configuring and triggering the MTB functions. The MTB also supports triggering via TSTART and TSTOP control functions in the MTB DWT module. ## 9.6 Debug in Low Power Modes In low power modes in which the debug modules are kept static or powered off, the debugger cannot gather any debug data for the duration of the low power mode. In the case that the debugger is held static, the debug port returns to full functionality as soon as the low power mode exits and the system returns to a state with active debug. In the case that the debugger logic is powered off, the debugger is reset on recovery and must be reconfigured once the low power mode is exited. ## 9.7 Debug & Security When flash security is enabled, the debug port capabilities are limited in order to prevent exploitation of secure data. In the secure state the debugger still has access to the status register and can determine the current security state of the device. In the case of a secure device, the debugger only has the capability of performing a mass erase operation. ບebug & Security # **Chapter 10 Pinouts and Packaging** ## 10.1 Package Types KM family of devices shall support the following packages options: - 100-pin LQFP (14 x 14 mm<sup>2</sup>) - 64-pin LQFP (10 x 10 mm<sup>2</sup>) - 44-pin LGA (5 x 5 mm<sup>2</sup>) #### NOTE Pin muxing selection between TAMPER0 and WKUP is done using control bit in RTC registers. #### NOTE All pin muxing configurations reset to default value on any reset assertion (reset asserts on VLLSx mode exit). When RESET pin is used as GPIO and pulled low; an internal reset (e.g. VLLSx mode exit or WDOG reset, etc) will make this pin function as RESET (default function) and since it is pulled low, it will appear as if pin reset is asserted and will cause full chip reset. # 10.2 Photon Signal Multiplexing and Pin Assignments | 100<br>QFP | 64<br>QFP | 44<br>LGA | DEFAULT | ALT0 | ALT1 | ALT2 | ALT3 | ALT4 | ALT5 | ALT6 | ALT7 | |------------|-----------|-----------|----------|-------|------|----------|------|------|------|------|-------| | 1 | 1 | _ | Disabled | LCD23 | PTA0 | | | | | | | | 2 | 2 | - | Disabled | LCD24 | PTA1 | | | | | | | | 3 | 3 | _ | Disabled | LCD25 | PTA2 | | | | | | | | 4 | _ | - | Disabled | LCD26 | PTA3 | | | | | | | | 5 | 4 | 1 | NMI_B | LCD27 | PTA4 | LLWU_P15 | | | | | NMI_B | | 6 | 5 | 2 | Disabled | LCD28 | PTA5 | CMP0OUT | | | | | | #### **FIIOION Signal Multiplexing and Pin Assignments** | 100<br>QFP | 64<br>QFP | 44<br>LGA | DEFAULT | ALT0 | ALT1 | ALT2 | ALT3 | ALT4 | ALT5 | ALT6 | ALT7 | |------------|-----------|-----------|-------------------|-------------------|------|------------|------------|------|------|------|------| | 7 | 6 | 3 | Disabled | LCD29 | PTA6 | PXBAR_IN0 | LLWU_P14 | | | | | | 8 | 7 | 4 | Disabled | LCD30 | PTA7 | PXBAR_OUT0 | | | | | | | 9 | _ | _ | Disabled | LCD31 | PTB0 | | | | | | | | 10 | 8 | 5 | VDD | VDD | | | | | | | | | 11 | 9 | 6 | VSS | VSS | | | | | | | | | 12 | _ | - | Disabled | LCD32 | PTB1 | | | | | | | | 13 | _ | - | Disabled | LCD33 | PTB2 | | | | | | | | 14 | _ | - | Disabled | LCD34 | PTB3 | | | | | | | | 15 | _ | - | Disabled | LCD35 | PTB4 | | | | | | | | 16 | _ | _ | Disabled | LCD36 | PTB5 | | | | | | | | 17 | - | - | Disabled | LCD37/<br>CMP1P0 | PTB6 | | | | | | | | 18 | 10 | _ | Disabled | LCD38 | PTB7 | AFE_CLK | | | | | | | 19 | 11 | _ | Disabled | LCD39 | PTC0 | SCI3_RTS | PXBAR_IN1 | | | | | | 20 | 12 | - | Disabled | LCD40/<br>CMP1P1 | PTC1 | SCI3_CTS | | | | | | | 21 | 13 | _ | Disabled | LCD41 | PTC2 | SCI3_TxD | PXBAR_OUT1 | | | | | | 22 | 14 | - | Disabled | LCD42/<br>CMP0P3 | PTC3 | SCI3_RxD | LLWU_P13 | | | | | | 23 | _ | _ | Disabled | LCD43 | PTC4 | | | | | | | | 24 | 15 | 7 | VBAT | VBAT | | | | | | | | | 25 | 16 | 8 | XTAL32K | XTAL32K | | | | | | | | | 26 | 17 | 9 | EXTAL32K | EXTAL32K | | | | | | | | | 27 | 18 | 10 | VSS | VSS | | | | | | | | | 28 | 18 | 10 | TAMPER2 | TAMPER2 | | | | | | | | | 29 | 18 | 10 | TAMPER1 | TAMPER1 | | | | | | | | | 30 | 19 | 11 | WKUP | TAMPER0 | | | | | | | | | 31 | 20 | 12 | VDDA | VDDA | | | | | | | | | 32 | 21 | 13 | VSSA | VSSA | | | | | | | | | 33 | 22 | 14 | SDADP0 | SDADP0 | | | | | | | | | 34 | 23 | 15 | SDADM0 | SDADM0 | | | | | | | | | 35 | 24 | 16 | SDADP1 | SDADP1 | | | | | | | | | 36 | 25 | 17 | SDADM1 | SDADM1 | | | | | | | | | 37 | 26 | 18 | VREFH | VREFH | | | | | | | | | 38 | 27 | 19 | VREFL | VREFL | | | | | | | | | 39 | 28 | 20 | SDADP2/<br>CMP1P2 | SDADP2/<br>CMP1P2 | | | | | | | | | 40 | 29 | 21 | SDADM2/<br>CMP1P3 | SDADM2/<br>CMP1P3 | | | | | | | | | 41 | 30 | 22 | VREF | VREF | | | | | | | | | 42 | _ | 24 | SDADP3/<br>CMP1P4 | SDADP3/<br>CMP1P4 | | | | | | | | #### **Chapter 10 Pinouts and Packaging** | 100<br>QFP | 64<br>QFP | 44<br>LGA | DEFAULT | ALT0 | ALT1 | ALT2 | ALT3 | ALT4 | ALT5 | ALT6 | ALT7 | |------------|-----------|-----------|-------------------|-------------------|------|------------|------------|------------|----------|------|---------| | 43 | - | 23 | SDADM3/<br>CMP1P5 | SDADM3/<br>CMP1P5 | | | | | | | | | 44 | _ | - | Disabled | AD0 | PTC5 | SCIO_RTS | LLWU_P12 | | | | | | 45 | _ | _ | Disabled | AD1 | PTC6 | SCI0_CTS | QT1 | | | | | | 46 | _ | _ | Disabled | AD2 | PTC7 | SCI0_TxD | PXBAR_OUT2 | | | | | | 47 | _ | _ | Disabled | CMP0P0 | PTD0 | SCI0_RxD | PXBAR_IN2 | LLWU_P11 | | | | | 48 | 31 | _ | Disabled | | PTD1 | SCI1_TxD | SPI0_SS_B | PXBAR_OUT3 | QT3 | | | | 49 | 32 | _ | Disabled | CMP0P1 | PTD2 | SCI1_RxD | SPI0_SCK | PXBAR_IN3 | LLWU_P10 | | | | 50 | 33 | _ | Disabled | | PTD3 | SCI1_CTS | SPI0_MOSI | | | | | | 51 | 34 | _ | Disabled | AD3 | PTD4 | SCI1_RTS | SPI0_MISO | LLWU_P9 | | | | | 52 | _ | _ | Disabled | AD4 | PTD5 | LPTIM2 | QT0 | SCI3_CTS | | | | | 53 | _ | _ | Disabled | AD5 | PTD6 | LPTIM1 | CMP10UT | SCI3_RTS | LLWU_P8 | | | | 54 | - | - | Disabled | CMP0P4 | PTD7 | I2C0_SCL | PXBAR_IN4 | SCI3_RxD | LLWU_P7 | | | | 55 | _ | _ | Disabled | | PTE0 | I2CO_SDA | PXBAR_OUT4 | SCI3_TxD | CLKOUT | | | | 56 | 35 | 25 | RESET_B | | PTE1 | | | | | | RESET_B | | 57 | _ | 26 | EXTAL1 | EXTAL1 | PTE2 | EWM_IN | PXBAR_IN6 | I2C1_SDA | | | | | 58 | _ | 27 | XTAL1 | XTAL1 | PTE3 | EWM_OUT | AFE_CLK | I2C1_SCL | | | | | 59 | 36 | 28 | VSS | VSS | | | | | | | | | 60 | 36 | 29 | SAR_VSSA | SAR_VSSA | | | | | | | | | 61 | 37 | 30 | SAR_VDDA | SAR_VDDA | | | | | | | | | 62 | 37 | 31 | VDD | VDD | | | | | | | | | 63 | _ | - | Disabled | | PTE4 | LPTIM0 | SCI2_CTS | EWM_IN | | | | | 64 | _ | _ | Disabled | | PTE5 | QT3 | SCI2_RTS | EWM_OUT | LLWU_P6 | | | | 65 | 38 | 32 | SWD_IO | CMP0P2 | PTE6 | PXBAR_IN5 | SCI2_RxD | LLWU_P5 | I2CO_SCL | | SWD_IO | | 66 | 39 | 33 | SWD_CLK | AD6 | PTE7 | PXBAR_OUT5 | SCI2_TxD | | I2CO_SDA | | SWD_CLK | | 67 | 40 | _ | Disabled | AD7 | PTF0 | RTCCLKOUT | QT2 | CMP0OUT | LLWU_P4 | | | | 68 | 41 | 34 | Disabled | LCD0/<br>AD8 | PTF1 | QT0 | PXBAR_OUT6 | | | | | | 69 | 42 | 35 | Disabled | LCD1/<br>AD9 | PTF2 | CMP1OUT | RTCCLKOUT | | | | | | 70 | 43 | - | Disabled | LCD2 | PTF3 | SPI1_SS_B | LPTIM1 | SCI0_RxD | | | | | 71 | 44 | _ | Disabled | LCD3 | PTF4 | SPI1_SCK | LPTIM0 | SCI0_TxD | | | | | 72 | 45 | _ | Disabled | LCD4 | PTF5 | SPI1_MISO | I2C1_SCL | | | | | | 73 | 46 | _ | Disabled | LCD5 | PTF6 | SPI1_MOSI | I2C1_SDA | LLWU_P3 | | | | | 74 | 47 | _ | Disabled | LCD6 | PTF7 | QT2 | CLKOUT | | | | | | 75 | 48 | - | Disabled | LCD7 | PTG0 | QT1 | LPTIM2 | | | | | | 76 | 49 | 36 | Disabled | LCD8/<br>AD10 | PTG1 | LLWU_P2 | LPTIM0 | | | | | | 77 | 50 | 37 | Disabled | LCD9/<br>AD11 | PTG2 | SPI0_SS_B | LLWU_P1 | | | | | | 78 | 51 | 38 | Disabled | LCD10 | PTG3 | SPI0_SCK | I2C0_SCL | | | | | | 79 | 52 | 39 | Disabled | LCD11 | PTG4 | SPI0_MOSI | I2CO_SDA | | | | | #### ⊾w ramily Pinouts | 100<br>QFP | 64<br>QFP | 44<br>LGA | DEFAULT | ALT0 | ALT1 | ALT2 | ALT3 | ALT4 | ALT5 | ALT6 | ALT7 | |------------|-----------|-----------|----------|--------|------|-----------|------------|------------|-----------|------|------| | | | | Disabled | 10010 | PTG5 | CDIO MICO | I DTIM4 | | | | | | 80 | 53 | 40 | Disabled | LCD12 | | SPI0_MISO | LPTIM1 | | | | | | 81 | 54 | - | Disabled | LCD13 | PTG6 | LLWU_P0 | LPTIM2 | | | | | | 82 | _ | _ | Disabled | LCD14 | PTG7 | | | | | | | | 83 | _ | - | Disabled | LCD15 | PTH0 | | | | | | | | 84 | _ | - | Disabled | LCD16 | PTH1 | | | | | | | | 85 | _ | _ | Disabled | LCD17 | PTH2 | | | | | | | | 86 | _ | _ | Disabled | LCD18 | PTH3 | | | | | | | | 87 | _ | _ | Disabled | LCD19 | PTH4 | | | | | | | | 88 | _ | _ | Disabled | LCD20 | PTH5 | | | | | | | | 89 | _ | 41 | Disabled | | PTH6 | SCI1_CTS | SPI1_SS_B | PXBAR_IN7 | | | | | 90 | _ | 42 | Disabled | | PTH7 | SCI1_RTS | SPI1_SCK | PXBAR_OUT7 | | | | | 91 | 55 | 43 | Disabled | CMP0P5 | PTI0 | SCI1_RxD | PXBAR_IN8 | SPI1_MISO | SPI1_MOSI | | | | 92 | 56 | 44 | Disabled | | PTI1 | SCI1_TxD | PXBAR_OUT8 | SPI1_MOSI | SPI1_MISO | | | | 93 | 57 | - | Disabled | LCD21 | PTI2 | | | | | | | | 94 | 58 | - | Disabled | LCD22 | PTI3 | | | | | | | | 95 | 59 | _ | VSS | VSS | | | | | | | | | 96 | 60 | _ | VLL3 | VLL3 | | | | | | | | | 97 | 61 | - | VLL2 | VLL2 | | | | | | | | | 98 | 62 | _ | VLL1 | VLL1 | | | | | | | | | 99 | 63 | _ | VCAP2 | VCAP2 | | | | | | | | | 100 | 64 | _ | VCAP1 | VCAP1 | | | | | | | | # **10.3 KM Family Pinouts** # 10.3.1 100-pin LQFP Figure below shows the KM 100 LQFP pinouts. Figure 10-1. 100-pin LQFP Pinout Diagram ## 10.3.2 64-pin LQFP Figure below shows the 64-pin LQFP pinouts. #### KIVI Family Pinouts Figure 10-2. 64-pin LQFP Pinout Diagram ## 10.3.3 44-pin LGA Figure below shows the 44-pin LGA pinouts. Figure 10-3. 44-pin LGA Pinout Diagram #### **NOTE** VSS also connects to flag on 44 LGA. הואו ramily Pinouts # **Chapter 11 Port Control and Interrupts (PORT)** #### 11.1 Introduction #### **NOTE** For the chip-specific implementation details of this module's instances, see the chip configuration information. #### 11.2 Overview The Port Control and Interrupt (PORT) module provides support for port control, digital filtering, and external interrupt functions. Most functions can be configured independently for each pin in the 32-bit port and affect the pin regardless of its pin muxing state. There is one instance of the PORT module for each port. Not all pins within each port are implemented on a specific device. #### 11.2.1 Features The PORT module has the following features: - Pin interrupt on selected pins - Interrupt flag and enable registers for each pin - Support for edge sensitive (rising, falling, both) or level sensitive (low, high) configured per pin - Support for interrupt or DMA request configured per pin - Asynchronous wake-up in low-power modes - Pin interrupt is functional in all digital pin muxing modes - Digital input filter #### Overview - Digital input filter for each pin, usable by any digital peripheral muxed onto the pin - Individual enable or bypass control field per pin - Selectable clock source for digital input filter with a five bit resolution on filter size - Functional in all digital pin multiplexing modes - Port control - Individual pull control fields with pullup, pulldown, and pull-disable enable support on selected pins - Individual drive strength field supporting high and low drive strength on selected pins - Individual slew rate field supporting fast and slow slew rates on selected pins - Individual input passive filter field supporting enable and disable of the individual input passive filter on selected pins - Individual mux control field supporting analog or pin disabled, GPIO, and up to six chip-specific digital functions - Pad configuration fields are functional in all digital pin muxing modes. ## 11.2.2 Modes of operation #### 11.2.2.1 Run mode In Run mode, the PORT operates normally. #### 11.2.2.2 Wait mode In Wait mode, PORT continues to operate normally and may be configured to exit the Low-Power mode if an enabled interrupt is detected. DMA requests are still generated during the Wait mode, but do not cause an exit from the Low-Power mode. ### 11.2.2.3 Stop mode In Stop mode, the PORT can be configured to exit the Low-Power mode via an asynchronous wake-up signal if an enabled interrupt is detected. In Stop mode, the digital input filters are bypassed unless they are configured to run from the 1 kHz LPO clock source. #### **11.2.2.4** Debug mode In Debug mode, PORT operates normally. ## 11.3 External signal description The table found here describes the PORT external signal. Table 11-1. Signal properties | Name | Functio | n I/O | Reset | Pull | |-----------|------------------|------------|-------|------| | PORTx[31: | 0] External inte | errupt I/O | 0 | - | #### NOTE Not all pins within each port are implemented on each device. ## 11.4 Detailed signal description The table found here contains the detailed signal description for the PORT interface. Table 11-2. PORT interface—detailed signal description | Signal | I/O | Description | | | | | |-------------|-----|---------------------|------------------------------------------------------------------------------------|--|--|--| | PORTx[31:0] | I/O | External interrupt. | | | | | | | | State meaning | Asserted—pin is logic 1. | | | | | | | | Negated—pin is logic 0. | | | | | | | Timing | Assertion—may occur at any time and can assert asynchronously to the system clock. | | | | | | | | Negation—may occur at any time and can assert asynchronously to the system clock. | | | | ## 11.5 Memory map and register definition Any read or write access to the PORT memory space that is outside the valid memory map results in a bus error. All register accesses complete with zero wait states. #### NOTE Digital filter capability is only on PORTE. Ignore DFER, DFCR and DFWR registers on ports A, B, C, D, F, G, H, and I. ## **PORT** memory map | Absolute<br>address<br>(hex) | Register name | Width<br>(in bits) | Access | Reset value | Section/<br>page | |------------------------------|------------------------------------------------|--------------------|--------------------------|-------------|------------------| | 4004_6000 | Pin Control Register n (PORTA_PCR0) | 32 | R/W | See section | 11.5.1/184 | | 4004_6004 | Pin Control Register n (PORTA_PCR1) | 32 | R/W | See section | 11.5.1/184 | | 4004_6008 | Pin Control Register n (PORTA_PCR2) | 32 | R/W | See section | 11.5.1/184 | | 4004_600C | Pin Control Register n (PORTA_PCR3) | 32 | R/W | See section | 11.5.1/184 | | 4004_6010 | Pin Control Register n (PORTA_PCR4) | 32 | R/W | See section | 11.5.1/184 | | 4004_6014 | Pin Control Register n (PORTA_PCR5) | 32 | R/W | See section | 11.5.1/184 | | 4004_6018 | Pin Control Register n (PORTA_PCR6) | 32 | R/W | See section | 11.5.1/184 | | 4004_601C | Pin Control Register n (PORTA_PCR7) | 32 | R/W | See section | 11.5.1/184 | | 4004_6080 | Global Pin Control Low Register (PORTA_GPCLR) | 32 | W<br>(always<br>reads 0) | 0000_0000h | 11.5.2/186 | | 4004_6084 | Global Pin Control High Register (PORTA_GPCHR) | 32 | W<br>(always<br>reads 0) | 0000_0000h | 11.5.3/187 | | 4004_60A0 | Interrupt Status Flag Register (PORTA_ISFR) | 32 | w1c | 0000_0000h | 11.5.4/187 | | 4004_60C0 | Digital Filter Enable Register (PORTA_DFER) | 32 | R/W | 0000_0000h | 11.5.5/188 | | 4004_60C4 | Digital Filter Clock Register (PORTA_DFCR) | 32 | R/W | 0000_0000h | 11.5.6/189 | | 4004_60C8 | Digital Filter Width Register (PORTA_DFWR) | 32 | R/W | 0000_0000h | 11.5.7/189 | | 4004_7000 | Pin Control Register n (PORTB_PCR0) | 32 | R/W | See section | 11.5.1/184 | | 4004_7004 | Pin Control Register n (PORTB_PCR1) | 32 | R/W | See section | 11.5.1/184 | | 4004_7008 | Pin Control Register n (PORTB_PCR2) | 32 | R/W | See section | 11.5.1/184 | | 4004_700C | Pin Control Register n (PORTB_PCR3) | 32 | R/W | See section | 11.5.1/184 | | 4004_7010 | Pin Control Register n (PORTB_PCR4) | 32 | R/W | See section | 11.5.1/184 | | 4004_7014 | Pin Control Register n (PORTB_PCR5) | 32 | R/W | See section | 11.5.1/184 | | 4004_7018 | Pin Control Register n (PORTB_PCR6) | 32 | R/W | See section | 11.5.1/184 | | 4004_701C | Pin Control Register n (PORTB_PCR7) | 32 | R/W | See section | 11.5.1/184 | | 4004_7080 | Global Pin Control Low Register (PORTB_GPCLR) | 32 | W<br>(always<br>reads 0) | 0000_0000h | 11.5.2/186 | | 4004_7084 | Global Pin Control High Register (PORTB_GPCHR) | 32 | W<br>(always<br>reads 0) | 0000_0000h | 11.5.3/187 | | 4004_70A0 | Interrupt Status Flag Register (PORTB_ISFR) | 32 | w1c | 0000_0000h | 11.5.4/187 | | 4004_70C0 | Digital Filter Enable Register (PORTB_DFER) | 32 | R/W | 0000_0000h | 11.5.5/188 | | 4004_70C4 | Digital Filter Clock Register (PORTB_DFCR) | 32 | R/W | 0000_0000h | 11.5.6/189 | | 4004_70C8 | Digital Filter Width Register (PORTB_DFWR) | 32 | R/W | 0000_0000h | 11.5.7/189 | | 4004_8000 | Pin Control Register n (PORTC_PCR0) | 32 | R/W | See section | 11.5.1/184 | | 4004_8004 | Pin Control Register n (PORTC_PCR1) | 32 | R/W | See section | 11.5.1/184 | | 4004_8008 | Pin Control Register n (PORTC_PCR2) | 32 | R/W | See section | 11.5.1/184 | | 4004_800C | Pin Control Register n (PORTC_PCR3) | 32 | R/W | See section | 11.5.1/184 | Table continues on the next page... # PORT memory map (continued) | Absolute<br>address<br>(hex) | Register name | Width<br>(in bits) | Access | Reset value | Section/<br>page | |------------------------------|------------------------------------------------|--------------------|--------------------------|-------------|------------------| | 4004_8010 | Pin Control Register n (PORTC_PCR4) | 32 | R/W | See section | 11.5.1/184 | | 4004_8014 | Pin Control Register n (PORTC_PCR5) | 32 | R/W | See section | 11.5.1/184 | | 4004_8018 | Pin Control Register n (PORTC_PCR6) | 32 | R/W | See section | 11.5.1/184 | | 4004_801C | Pin Control Register n (PORTC_PCR7) | 32 | R/W | See section | 11.5.1/184 | | 4004_8080 | Global Pin Control Low Register (PORTC_GPCLR) | 32 | W<br>(always<br>reads 0) | 0000_0000h | 11.5.2/186 | | 4004_8084 | Global Pin Control High Register (PORTC_GPCHR) | 32 | W<br>(always<br>reads 0) | 0000_0000h | 11.5.3/187 | | 4004_80A0 | Interrupt Status Flag Register (PORTC_ISFR) | 32 | w1c | 0000_0000h | 11.5.4/187 | | 4004_80C0 | Digital Filter Enable Register (PORTC_DFER) | 32 | R/W | 0000_0000h | 11.5.5/188 | | 4004_80C4 | Digital Filter Clock Register (PORTC_DFCR) | 32 | R/W | 0000_0000h | 11.5.6/189 | | 4004_80C8 | Digital Filter Width Register (PORTC_DFWR) | 32 | R/W | 0000_0000h | 11.5.7/189 | | 4004_9000 | Pin Control Register n (PORTD_PCR0) | 32 | R/W | See section | 11.5.1/184 | | 4004_9004 | Pin Control Register n (PORTD_PCR1) | 32 | R/W | See section | 11.5.1/184 | | 4004_9008 | Pin Control Register n (PORTD_PCR2) | 32 | R/W | See section | 11.5.1/184 | | 4004_900C | Pin Control Register n (PORTD_PCR3) | 32 | R/W | See section | 11.5.1/184 | | 4004_9010 | Pin Control Register n (PORTD_PCR4) | 32 | R/W | See section | 11.5.1/184 | | 4004_9014 | Pin Control Register n (PORTD_PCR5) | 32 | R/W | See section | 11.5.1/184 | | 4004_9018 | Pin Control Register n (PORTD_PCR6) | 32 | R/W | See section | 11.5.1/184 | | 4004_901C | Pin Control Register n (PORTD_PCR7) | 32 | R/W | See section | 11.5.1/184 | | 4004_9080 | Global Pin Control Low Register (PORTD_GPCLR) | 32 | W<br>(always<br>reads 0) | 0000_0000h | 11.5.2/186 | | 4004_9084 | Global Pin Control High Register (PORTD_GPCHR) | 32 | W<br>(always<br>reads 0) | 0000_0000h | 11.5.3/187 | | 4004_90A0 | Interrupt Status Flag Register (PORTD_ISFR) | 32 | w1c | 0000_0000h | 11.5.4/187 | | 4004_90C0 | Digital Filter Enable Register (PORTD_DFER) | 32 | R/W | 0000_0000h | 11.5.5/188 | | 4004_90C4 | Digital Filter Clock Register (PORTD_DFCR) | 32 | R/W | 0000_0000h | 11.5.6/189 | | 4004_90C8 | Digital Filter Width Register (PORTD_DFWR) | 32 | R/W | 0000_0000h | 11.5.7/189 | | 4004_A000 | Pin Control Register n (PORTE_PCR0) | 32 | R/W | See section | 11.5.1/184 | | 4004_A004 | Pin Control Register n (PORTE_PCR1) | 32 | R/W | See section | 11.5.1/184 | | 4004_A008 | Pin Control Register n (PORTE_PCR2) | 32 | R/W | See section | 11.5.1/184 | | 4004_A00C | Pin Control Register n (PORTE_PCR3) | 32 | R/W | See section | 11.5.1/184 | | 4004_A010 | Pin Control Register n (PORTE_PCR4) | 32 | R/W | See section | 11.5.1/184 | | 4004_A014 | Pin Control Register n (PORTE_PCR5) | 32 | R/W | See section | 11.5.1/184 | | 4004_A018 | Pin Control Register n (PORTE_PCR6) | 32 | R/W | See section | 11.5.1/184 | | 4004_A01C | Pin Control Register n (PORTE_PCR7) | 32 | R/W | See section | 11.5.1/184 | #### wemory map and register definition # PORT memory map (continued) | Absolute<br>address<br>(hex) | Register name | Width<br>(in bits) | Access | Reset value | Section/<br>page | |------------------------------|------------------------------------------------|--------------------|--------------------------|-------------|------------------| | 4004_A080 | Global Pin Control Low Register (PORTE_GPCLR) | 32 | W<br>(always<br>reads 0) | 0000_0000h | 11.5.2/186 | | 4004_A084 | Global Pin Control High Register (PORTE_GPCHR) | 32 | W<br>(always<br>reads 0) | 0000_0000h | 11.5.3/187 | | 4004_A0A0 | Interrupt Status Flag Register (PORTE_ISFR) | 32 | w1c | 0000_0000h | 11.5.4/187 | | 4004_A0C0 | Digital Filter Enable Register (PORTE_DFER) | 32 | R/W | 0000_0000h | 11.5.5/188 | | 4004_A0C4 | Digital Filter Clock Register (PORTE_DFCR) | 32 | R/W | 0000_0000h | 11.5.6/189 | | 4004_A0C8 | Digital Filter Width Register (PORTE_DFWR) | 32 | R/W | 0000_0000h | 11.5.7/189 | | 4004_B000 | Pin Control Register n (PORTF_PCR0) | 32 | R/W | See section | 11.5.1/184 | | 4004_B004 | Pin Control Register n (PORTF_PCR1) | 32 | R/W | See section | 11.5.1/184 | | 4004_B008 | Pin Control Register n (PORTF_PCR2) | 32 | R/W | See section | 11.5.1/184 | | 4004_B00C | Pin Control Register n (PORTF_PCR3) | 32 | R/W | See section | 11.5.1/184 | | 4004_B010 | Pin Control Register n (PORTF_PCR4) | 32 | R/W | See section | 11.5.1/184 | | 4004_B014 | Pin Control Register n (PORTF_PCR5) | 32 | R/W | See section | 11.5.1/184 | | 4004_B018 | Pin Control Register n (PORTF_PCR6) | 32 | R/W | See section | 11.5.1/184 | | 4004_B01C | Pin Control Register n (PORTF_PCR7) | 32 | R/W | See section | 11.5.1/184 | | 4004_B080 | Global Pin Control Low Register (PORTF_GPCLR) | 32 | W<br>(always<br>reads 0) | 0000_0000h | 11.5.2/186 | | 4004_B084 | Global Pin Control High Register (PORTF_GPCHR) | 32 | W<br>(always<br>reads 0) | 0000_0000h | 11.5.3/187 | | 4004_B0A0 | Interrupt Status Flag Register (PORTF_ISFR) | 32 | w1c | 0000_0000h | 11.5.4/187 | | 4004_B0C0 | Digital Filter Enable Register (PORTF_DFER) | 32 | R/W | 0000_0000h | 11.5.5/188 | | 4004_B0C4 | Digital Filter Clock Register (PORTF_DFCR) | 32 | R/W | 0000_0000h | 11.5.6/189 | | 4004_B0C8 | Digital Filter Width Register (PORTF_DFWR) | 32 | R/W | 0000_0000h | 11.5.7/189 | | 4004_C000 | Pin Control Register n (PORTG_PCR0) | 32 | R/W | See section | 11.5.1/184 | | 4004_C004 | Pin Control Register n (PORTG_PCR1) | 32 | R/W | See section | 11.5.1/184 | | 4004_C008 | Pin Control Register n (PORTG_PCR2) | 32 | R/W | See section | 11.5.1/184 | | 4004_C00C | Pin Control Register n (PORTG_PCR3) | 32 | R/W | See section | 11.5.1/184 | | 4004_C010 | Pin Control Register n (PORTG_PCR4) | 32 | R/W | See section | 11.5.1/184 | | 4004_C014 | Pin Control Register n (PORTG_PCR5) | 32 | R/W | See section | 11.5.1/184 | | 4004_C018 | Pin Control Register n (PORTG_PCR6) | 32 | R/W | See section | 11.5.1/184 | | 4004_C01C | Pin Control Register n (PORTG_PCR7) | 32 | R/W | See section | 11.5.1/184 | | 4004_C080 | Global Pin Control Low Register (PORTG_GPCLR) | 32 | W<br>(always<br>reads 0) | 0000_0000h | 11.5.2/186 | # PORT memory map (continued) | Absolute<br>address<br>(hex) | Register name | Width<br>(in bits) | Access | Reset value | Section/<br>page | |------------------------------|------------------------------------------------|--------------------|--------------------------|-------------|------------------| | 4004_C084 | Global Pin Control High Register (PORTG_GPCHR) | 32 | W<br>(always<br>reads 0) | 0000_0000h | 11.5.3/187 | | 4004_C0A0 | Interrupt Status Flag Register (PORTG_ISFR) | 32 | w1c | 0000_0000h | 11.5.4/187 | | 4004_C0C0 | Digital Filter Enable Register (PORTG_DFER) | 32 | R/W | 0000_0000h | 11.5.5/188 | | 4004_C0C4 | Digital Filter Clock Register (PORTG_DFCR) | 32 | R/W | 0000_0000h | 11.5.6/189 | | 4004_C0C8 | Digital Filter Width Register (PORTG_DFWR) | 32 | R/W | 0000_0000h | 11.5.7/189 | | 4004_D000 | Pin Control Register n (PORTH_PCR0) | 32 | R/W | See section | 11.5.1/184 | | 4004_D004 | Pin Control Register n (PORTH_PCR1) | 32 | R/W | See section | 11.5.1/184 | | 4004_D008 | Pin Control Register n (PORTH_PCR2) | 32 | R/W | See section | 11.5.1/184 | | 4004_D00C | Pin Control Register n (PORTH_PCR3) | 32 | R/W | See section | 11.5.1/184 | | 4004_D010 | Pin Control Register n (PORTH_PCR4) | 32 | R/W | See section | 11.5.1/184 | | 4004_D014 | Pin Control Register n (PORTH_PCR5) | 32 | R/W | See section | 11.5.1/184 | | 4004_D018 | Pin Control Register n (PORTH_PCR6) | 32 | R/W | See section | 11.5.1/184 | | 4004_D01C | Pin Control Register n (PORTH_PCR7) | 32 | R/W | See section | 11.5.1/184 | | 4004_D080 | Global Pin Control Low Register (PORTH_GPCLR) | 32 | W<br>(always<br>reads 0) | 0000_0000h | 11.5.2/186 | | 4004_D084 | Global Pin Control High Register (PORTH_GPCHR) | 32 | W<br>(always<br>reads 0) | 0000_0000h | 11.5.3/187 | | 4004_D0A0 | Interrupt Status Flag Register (PORTH_ISFR) | 32 | w1c | 0000_0000h | 11.5.4/187 | | 4004_D0C0 | Digital Filter Enable Register (PORTH_DFER) | 32 | R/W | 0000_0000h | 11.5.5/188 | | 4004_D0C4 | Digital Filter Clock Register (PORTH_DFCR) | 32 | R/W | 0000_0000h | 11.5.6/189 | | 4004_D0C8 | Digital Filter Width Register (PORTH_DFWR) | 32 | R/W | 0000_0000h | 11.5.7/189 | | 4004_E000 | Pin Control Register n (PORTI_PCR0) | 32 | R/W | See section | 11.5.1/184 | | 4004_E004 | Pin Control Register n (PORTI_PCR1) | 32 | R/W | See section | 11.5.1/184 | | 4004_E008 | Pin Control Register n (PORTI_PCR2) | 32 | R/W | See section | 11.5.1/184 | | 4004_E00C | Pin Control Register n (PORTI_PCR3) | 32 | R/W | See section | 11.5.1/184 | | 4004_E010 | Pin Control Register n (PORTI_PCR4) | 32 | R/W | See section | 11.5.1/184 | | 4004_E014 | Pin Control Register n (PORTI_PCR5) | 32 | R/W | See section | 11.5.1/184 | | 4004_E018 | Pin Control Register n (PORTI_PCR6) | 32 | R/W | See section | 11.5.1/184 | | 4004_E01C | Pin Control Register n (PORTI_PCR7) | 32 | R/W | See section | 11.5.1/184 | | 4004_E080 | Global Pin Control Low Register (PORTI_GPCLR) | 32 | W<br>(always<br>reads 0) | 0000_0000h | 11.5.2/186 | | 4004_E084 | Global Pin Control High Register (PORTI_GPCHR) | 32 | W<br>(always<br>reads 0) | 0000_0000h | 11.5.3/187 | | 4004_E0A0 | Interrupt Status Flag Register (PORTI_ISFR) | 32 | w1c | 0000_0000h | 11.5.4/187 | | 4004_E0C0 | Digital Filter Enable Register (PORTI_DFER) | 32 | R/W | 0000_0000h | 11.5.5/188 | #### memory map and register definition #### **PORT memory map (continued)** | Absolute address (hex) | Register name | Width<br>(in bits) | Access | Reset value | Section/<br>page | |------------------------|--------------------------------------------|--------------------|--------|-------------|------------------| | 4004_E0C4 | Digital Filter Clock Register (PORTI_DFCR) | 32 | R/W | 0000_0000h | 11.5.6/189 | | 4004_E0C8 | Digital Filter Width Register (PORTI_DFWR) | 32 | R/W | 0000_0000h | 11.5.7/189 | ## 11.5.1 Pin Control Register n (PORTx\_PCRn) #### NOTE See the Signal Multiplexing and Pin Assignment chapter for the reset value of this device. See the GPIO Configuration section for details on the available functions for each pin. Do not modify pin configuration registers associated with pins not available in your selected package. All unbonded pins not available in your package will default to DISABLE state for lowest power consumption. Address: Base address + 0h offset + (4d × i), where i=0d to 7d <sup>\*</sup> Notes: - MUX field: Varies by port. See Signal Multiplexing and Signal Descriptions chapter for reset values per port. - SRE field: Varies by port. See Signal Multiplexing and Signal Descriptions chapter for reset values per port. - PE field: Varies by port. See Signal Multiplexing and Signal Descriptions chapter for reset values per port. - PS field: Varies by port. See Signal Multiplexing and Signal Descriptions chapter for reset values per port. # PORTx\_PCRn field descriptions | Field | Description | |-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31–25<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 24 | Interrupt Status Flag | | ISF | This field is read-only for pins that do not support interrupt generation. | | | The pin interrupt configuration is valid in all digital pin muxing modes. | | | | | | <ul> <li>Configured interrupt is not detected.</li> <li>Configured interrupt is detected. If the pin is configured to generate a DMA request, then the corresponding flag will be cleared automatically at the completion of the requested DMA transfer. Otherwise, the flag remains set until a logic 1 is written to the flag. If the pin is configured for a level sensitive interrupt and the pin remains asserted, then the flag is set again immediately after it is cleared.</li> </ul> | | 23–20<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 19–16 | Interrupt Configuration | | IRQC | This field is read-only for pins that do not support interrupt generation. | | | The pin interrupt configuration is valid in all digital pin muxing modes. The corresponding pin is configured to generate interrupt/DMA request as follows: | | | 0000 Interrupt/DMA request disabled. | | | 0001 DMA request on rising edge. | | | 0010 DMA request on falling edge. | | | 0011 DMA request on either edge. | | | 1000 Interrupt when logic 0. | | | <ul><li>1001 Interrupt on rising-edge.</li><li>1010 Interrupt on falling-edge.</li></ul> | | | 1011 Interrupt on either edge. | | | 1100 Interrupt when logic 1. | | | Others Reserved. | | 15 | Lock Register | | LK | 0 Pin Control Register fields [15:0] are not locked. | | | 1 Pin Control Register fields [15:0] are locked and cannot be updated until the next system reset. | | 14–11<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 10–8 | Pin Mux Control | | MUX | Not all pins support all pin muxing slots. Unimplemented pin muxing slots are reserved and may result in configuring the pin for a different pin muxing slot. | | | The corresponding pin is configured in the following pin muxing slot as follows: | | | 000 Pin disabled (analog). | | | 001 Alternative 1 (GPIO). | | | 010 Alternative 2 (chip-specific). | | | 011 Alternative 3 (chip-specific). | | | 100 Alternative 4 (chip-specific). | | | 101 Alternative 5 (chip-specific). | #### wemory map and register definition # PORTx\_PCRn field descriptions (continued) | Field | Description | |---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | 110 Alternative 6 (chip-specific). 111 Alternative 7 (chip-specific). | | 7<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 6<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 5<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 4<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 3<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 2<br>SRE | Slew Rate Enable This field is read-only for pins that do not support a configurable slew rate. Slew rate configuration is valid in all digital pin muxing modes. O Fast slew rate is configured on the corresponding pin, if the pin is configured as a digital output. | | 1<br>PE | <ul> <li>Slow slew rate is configured on the corresponding pin, if the pin is configured as a digital output.</li> <li>Pull Enable</li> <li>This field is read-only for pins that do not support a configurable pull resistor. Refer to the Chapter of Signal Multiplexing and Signal Descriptions for the pins that support a configurable pull resistor.</li> <li>Pull configuration is valid in all digital pin muxing modes.</li> <li>Internal pullup or pulldown resistor is not enabled on the corresponding pin.</li> <li>Internal pullup or pulldown resistor is enabled on the corresponding pin, if the pin is configured as a digital input.</li> </ul> | | 0<br>PS | Pull Select This bit is read only for pins that do not support a configurable pull resistor direction. Pull configuration is valid in all digital pin muxing modes. O Internal pulldown resistor is enabled on the corresponding pin, if the corresponding PE field is set. Internal pullup resistor is enabled on the corresponding pin, if the corresponding PE field is set. | # 11.5.2 Global Pin Control Low Register (PORTx\_GPCLR) Only 32-bit writes are supported to this register. Address: Base address + 80h offset #### PORTx\_GPCLR field descriptions | Field | Description | |---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31–16<br>GPWE | Global Pin Write Enable | | | Selects which Pin Control Registers (15 through 0) bits [15:0] update with the value in GPWD. If a selected Pin Control Register is locked then the write to that register is ignored. | | | 0 Corresponding Pin Control Register is not updated with the value in GPWD. | | | 1 Corresponding Pin Control Register is updated with the value in GPWD. | | 15–0<br>GPWD | Global Pin Write Data | | | Write value that is written to all Pin Control Registers bits [15:0] that are selected by GPWE. | ## 11.5.3 Global Pin Control High Register (PORTx\_GPCHR) Only 32-bit writes are supported to this register. Address: Base address + 84h offset #### PORTx\_GPCHR field descriptions | Field | Description | |---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31–16<br>GPWE | Global Pin Write Enable | | | Selects which Pin Control Registers (31 through 16) bits [15:0] update with the value in GPWD. If a selected Pin Control Register is locked then the write to that register is ignored. | | | 0 Corresponding Pin Control Register is not updated with the value in GPWD. | | | 1 Corresponding Pin Control Register is updated with the value in GPWD. | | 15–0<br>GPWD | Global Pin Write Data | | | Write value that is written to all Pin Control Registers bits [15:0] that are selected by GPWE. | ## 11.5.4 Interrupt Status Flag Register (PORTx\_ISFR) The corresponding bit is read only for pins that do not support interrupt generation. The pin interrupt configuration is valid in all digital pin muxing modes. The Interrupt Status Flag for each pin is also visible in the corresponding Pin Control Register, and each flag can be cleared in either location. #### memory map and register definition Address: Base address + A0h offset ## PORTx\_ISFR field descriptions | Field | Description | |-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | ISF | <ul> <li>Interrupt Status Flag</li> <li>Each bit in the field indicates the detection of the configured interrupt of the same number as the field.</li> <li>Configured interrupt is not detected.</li> <li>Configured interrupt is detected. If the pin is configured to generate a DMA request, then the corresponding flag will be cleared automatically at the completion of the requested DMA transfer. Otherwise, the flag remains set until a logic 1 is written to the flag. If the pin is configured for a level sensitive interrupt and the pin remains asserted, then the flag is set again immediately after it is cleared.</li> </ul> | # 11.5.5 Digital Filter Enable Register (PORTx\_DFER) The digital filter configuration is valid in all digital pin muxing modes. Address: Base address + C0h offset ## PORTx\_DFER field descriptions | Field | Description | |-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31–0<br>DFE | Digital Filter Enable | | | The digital filter configuration is valid in all digital pin muxing modes. The output of each digital filter is reset to zero at system reset and whenever the digital filter is disabled. Each bit in the field enables the digital filter of the same number as the field. | | | <ul> <li>Digital filter is disabled on the corresponding pin and output of the digital filter is reset to zero.</li> <li>Digital filter is enabled on the corresponding pin, if the pin is configured as a digital input.</li> </ul> | ## 11.5.6 Digital Filter Clock Register (PORTx\_DFCR) The digital filter configuration is valid in all digital pin muxing modes. ## PORTx\_DFCR field descriptions | Field | Description | |------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31–1<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 0<br>CS | Clock Source The digital filter configuration is valid in all digital pin muxing modes. Configures the clock source for the digital input filters. Changing the filter clock source must be done only when all digital filters are disabled. O Digital filters are clocked by the bus clock. | | | 1 Digital filters are clocked by the 1 kHz LPO clock. | ## 11.5.7 Digital Filter Width Register (PORTx\_DFWR) The digital filter configuration is valid in all digital pin muxing modes. Address: Base address + C8h offset #### PORTx\_DFWR field descriptions | Field | Description | |-------|--------------------------------------------------------------------------------------| | | This field is reserved. This read-only field is reserved and always has the value 0. | Table continues on the next page... #### runctional description #### PORTx\_DFWR field descriptions (continued) | Field | Description | |-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | Filter Length The digital filter configuration is valid in all digital pin muxing modes. Configures the maximum size of the glitches, in clock cycles, that the digital filter absorbs for the enabled digital filters. Glitches that are longer than this register setting will pass through the digital filter, and glitches that are equal to or less than this register setting are filtered. Changing the filter length must be done only after all filters are disabled. | # 11.6 Functional description #### 11.6.1 Pin control Each port pin has a corresponding Pin Control register, PORT\_PCRn, associated with it. The upper half of the Pin Control register configures the pin's capability to either interrupt the CPU or request a DMA transfer, on a rising/falling edge or both edges as well as a logic level occurring on the port pin. It also includes a flag to indicate that an interrupt has occurred. The lower half of the Pin Control register configures the following functions for each pin within the 32-bit port. - Pullup or pulldown enable on selected pins - Drive strength and slew rate configuration on selected pins - Passive input filter enable on selected pins - Pin Muxing mode The functions apply across all digital pin muxing modes and individual peripherals do not override the configuration in the Pin Control register. For example, if an I<sup>2</sup>C function is enabled on a pin, that does not override the pullup configuration for that pin. When the Pin Muxing mode is configured for analog or is disabled, all the digital functions on that pin are disabled. This includes the pullup and pulldown enables, digital output buffer enable, digital input buffer enable, and passive filter enable. A lock field also exists that allows the configuration for each pin to be locked until the next system reset. When locked, writes to the lower half of that pin control register are ignored, although a bus error is not generated on an attempted write to a locked register. The configuration of each Pin Control register is retained when the PORT module is disabled. ## 11.6.2 Global pin control The two global pin control registers allow a single register write to update the lower half of the pin control register on up to 16 pins, all with the same value. Registers that are locked cannot be written using the global pin control registers. The global pin control registers are designed to enable software to quickly configure multiple pins within the one port for the same peripheral function. However, the interrupt functions cannot be configured using the global pin control registers. The global pin control registers are write-only registers, that always read as 0. ## 11.6.3 External interrupts The external interrupt capability of the PORT module is available in all digital pin muxing modes provided the PORT module is enabled. Each pin can be individually configured for any of the following external interrupt modes: - Interrupt disabled, default out of reset - Active high level sensitive interrupt - Active low level sensitive interrupt - Rising edge sensitive interrupt - Falling edge sensitive interrupt - Rising and falling edge sensitive interrupt - Rising edge sensitive DMA request - Falling edge sensitive DMA request - Rising and falling edge sensitive DMA request The interrupt status flag is set when the configured edge or level is detected on the pin or at the output of the digital input filter, if the digital input digital filter is enabled. When not in Stop mode, the input is first synchronized to the bus clock to detect the configured level or edge transition. The PORT module generates a single interrupt that asserts when the interrupt status flag is set for any enabled interrupt for that port. The interrupt negates after the interrupt status flags for all enabled interrupts have been cleared by writing a logic 1 to the ISF flag in either the PORT\_ISFR or PORT\_PCRn registers. #### runctional description The PORT module generates a single DMA request that asserts when the interrupt status flag is set for any enabled DMA request in that port. The DMA request negates after the DMA transfer is completed, because that clears the interrupt status flags for all enabled DMA requests. During Stop mode, the interrupt status flag for any enabled interrupt is asynchronously set if the required level or edge is detected. This also generates an asynchronous wake-up signal to exit the Low-Power mode. ## 11.6.4 Digital filter The digital filter capabilities of the PORT module are available in all digital Pin Muxing modes if the PORT module is enabled. The clock used for all digital filters within one port can be configured between the bus clock or the 1 kHz LPO clock. This selection must be changed only when all digital filters for that port are disabled. If the digital filters for a port are configured to use the bus clock, then the digital filters are bypassed for the duration of Stop mode. While the digital filters are bypassed, the output of each digital filter always equals the input pin, but the internal state of the digital filters remains static and does not update due to any change on the input pin. The filter width in clock size is the same for all enabled digital filters within one port and must be changed only when all digital filters for that port are disabled. The output of each digital filter is logic zero after system reset and whenever a digital filter is disabled. After a digital filter is enabled, the input is synchronized to the filter clock, either the bus clock or the 1 kHz LPO clock. If the synchronized input and the output of the digital filter remain different for a number of filter clock cycles equal to the filter width register configuration, then the output of the digital filter updates to equal the synchronized filter input. The minimum latency through a digital filter equals two or three filter clock cycles plus the filter width configuration register. # **Chapter 12 System Integration Module (SIM)** ## 12.1 Introduction The System Integration Module (SIM) provides system control and chip configuration registers. The module is divided into two power domains: Low-Power SIM (SIM\_LP) and High-Power SIM (SIM\_HP). The SIM\_HP registers are invalid during VLLSx modes and reset on exit from VLLSx modes, POR or LVD. Whereas, SIM\_LP registers retain their content throughout VLLSx modes but reset on POR or LVD events. The register space belonging to $4003\_E000h - 4003\_EFFFh$ is part of SIM\_LP and from $4003\_F000h - 4003\_FFFFh$ is part of SIM\_HP. ## 12.2 Features - System clocking configuration - System clock divider values - Architectural clock gating control - LPTimer clock selection - Flash size configuration - System RAM power mode controls - LPTMR external clock and input capture selection - CLKOUT Selection - Peripheral XBAR Input Selection for scenarios where multiple peripheral exist to be used as input sources - System Device Identification through SDID field - ADC Compensation values for -40 °C, 25 °C and 85 °C KM Family Reference Manual, Rev. 5, Oct 2013 193 # 12.3 Memory map and register definition The SIM module contains many fields to select clock source and dividers for various module clocks. ## SIM memory map | Absolute<br>address<br>(hex) | Register name | Width<br>(in bits) | Access | Reset value | Section/<br>page | |------------------------------|----------------------------------------------------|--------------------|--------|-------------|------------------| | 4003_E000 | System Options Register 1 (SIM_SOPT1) | 32 | R/W | See section | 12.3.1/195 | | 4003_E004 | SOPT1 Configuration Register (SIM_SOPT1_CFG) | 32 | R/W | 0000_0000h | 12.3.2/196 | | 4003_F004 | System Control Register (SIM_CTRL_REG) | 32 | R/W | 0000_0000h | 12.3.3/197 | | 4003_F024 | System Device Identification Register (SIM_SDID) | 32 | R | Undefined | 12.3.4/198 | | 4003_F034 | System Clock Gating Control Register 4 (SIM_SCGC4) | 32 | R/W | 7800_8070h | 12.3.5/200 | | 4003_F038 | System Clock Gating Control Register 5 (SIM_SCGC5) | 32 | R/W | 000B_0000h | 12.3.6/203 | | 4003_F03C | System Clock Gating Control Register 6 (SIM_SCGC6) | 32 | R/W | C000_0001h | 12.3.7/207 | | 4003_F040 | System Clock Gating Control Register 7 (SIM_SCGC7) | 32 | R/W | 0000_0003h | 12.3.8/210 | | 4003_F044 | System Clock Divider Register 1 (SIM_CLKDIV1) | 32 | R/W | 0800_0000h | 12.3.9/211 | | 4003_F04C | Flash Configuration Register 1 (SIM_FCFG1) | 32 | R/W | See section | 12.3.10/213 | | 4003_F050 | Flash Configuration Register 2 (SIM_FCFG2) | 32 | R | 1000_0000h | 12.3.11/215 | | 4003_F054 | Unique Identification Register 0 (SIM_UID0) | 32 | R | Undefined | 12.3.12/215 | | 4003_F058 | Unique Identification Register 1 (SIM_UID1) | 32 | R | Undefined | 12.3.13/216 | | 4003_F05C | Unique Identification Register 2 (SIM_UID2) | 32 | R | Undefined | 12.3.14/216 | | 4003_F060 | Unique Identification Register 3 (SIM_UID3) | 32 | R | Undefined | 12.3.15/217 | | 4003_F06C | Miscellaneous Control Register (SIM_MISC_CTL) | 32 | R/W | 8000_0000h | 12.3.16/217 | # 12.3.1 System Options Register 1 (SIM\_SOPT1) #### **NOTE** The SOPT1 register is only reset on POR or LVD. <sup>\*</sup> Notes: #### SIM\_SOPT1 field descriptions | Field | Description | | | |--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | 31–20<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | | | 19–18<br>OSC32KSEL | 32K oscillator clock select Selects the 32 kHz clock source for LPTMR, CLKOUT, LCD, EWM, WDOG. This bit is reset only on POR/LVD. 00 OSC32KCLK 01 ERCLK32K 10 MCGIRCLK 11 LPO | | | | 17–16<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | | | 15–12<br>SRAMSIZE | Returns the size of the system RAM 0101 16kB System RAM | | | | 11–0<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | | <sup>•</sup> x = Undefined at reset. # 12.3.2 SOPT1 Configuration Register (SIM\_SOPT1\_CFG) The SOPT1CFG register is reset on system reset not VLLS. #### SIM\_SOPT1\_CFG field descriptions | Field | Description | | | | |--------------------|-------------------------------------------------------------------------------|--|--|--| | 31–10 | This field is reserved. | | | | | Reserved | This read-only field is reserved and always has the value 0. | | | | | 9<br>RAMBPEN | RAM Bitline Precharge Enable | | | | | | Enable System SRAM bitline precharge during VLPR and VLPW modes. | | | | | | 0 Bitline precharge of system SRAM disabled during VLPR and VLPW modes. | | | | | | 1 Bitline precharge of system SRAM enabled during VLPR and VLPW modes. | | | | | 8<br>RAMSBDIS | Disable source bias of System SRAM arrays during VLPR and VLPW modes. | | | | | | Source bias of System SRAM enabled during VLPR and VLPW modes. | | | | | | Source bias of System SRAM disabled during VLPR and VLPW modes. | | | | | 7 | This field is reserved. | | | | | Reserved | This read-only field is reserved and always has the value 0. | | | | | 6<br>CMPOLPTMR0SEL | Comparator output selection for LPTMR channel0 | | | | | | This field is used to select CMP outputs as the source for LP timer channel0. | | | | | | 0 CMP[1] output selected as LPTMR input[0] | | | | | | 1 CMP[0] output selected as LPTMR input[0] | | | | | 5–4<br>LPTMR3SEL | LP timer Channel3 Select | | | | | | This field is used to select source for LP timer channel3. | | | | ## SIM\_SOPT1\_CFG field descriptions (continued) | Field | Description | |------------------|------------------------------------------------------------| | | 00 Pad PTD5 | | | 01 Pad PTG0 | | | 10 Pad PTG6 | | | 11 Reserved | | 3–2<br>LPTMR2SEL | LP timer Channel2 Select | | LF IWIN2SEL | This field is used to select source for LP timer channel2. | | | 00 Pad PTD6 | | | 01 Pad PTF3 | | | 10 Pad PTG5 | | | 11 Reserved | | 1–0 | LP timer Channel1 Select | | LPTMR1SEL | This field is used to select source for LP timer channel1. | | | 00 Pad PTE4 | | | 01 Pad PTF4 | | | 10 Pad PTG1 | | | 11 Reserved | # 12.3.3 System Control Register (SIM\_CTRL\_REG) #### **NOTE** Writes to this register can only be performed in Supervisor mode #### wemory map and register definition # SIM\_CTRL\_REG field descriptions | Field | Description | | | |---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | 31–8 | This field is reserved. | | | | Reserved | This read-only field is reserved and always has the value 0. | | | | 7–5 | Clock out Select | | | | CLKOUTSEL | This field can be used to select one of the following clocks for CLKOUT pin. | | | | | 000 Disabled | | | | | 001 Gated Core Clk | | | | | 010 Bus/Flash Clk | | | | | 011 LPO clock from PMC | | | | | 100 IRC clock from MCG | | | | | 101 Muxed 32Khz source (please refer SOPT1[19:18] for possible options) | | | | | 110 MHz Oscillator external reference clock | | | | | 111 PLL clock output from MCG | | | | 4–3 | SAR ADC Trigger Clk Select | | | | SAR_TRG_CLK_<br>SEL | Selects the clock used to generate the ADC triggers. | | | | | 00 Bus Clock (During Low Power Modes such as stop, the Bus clock is not available for conversion and should not be selected in case a conversion needs to be performed while in stop) | | | | | 01 ADC asynchronous Clock | | | | | 10 ERCLK32K | | | | | 11 OSCCLK | | | | 2 | PTC2 HighDrive Enable | | | | PTC2_HD_EN | Enables the High Drive on pad PTC[2] when set | | | | 1 | PLL VLP Enable | | | | PLL_VLP_EN | When set, this bit enables the PLL in VLP modes. | | | | | | | | | 0<br>NMIDIS | NMI Disable This field is used as an alternate to FTFL_FOPT[2] to disable the NMI temporarily. It is also advised to | | | | | program this bit while changing the state of the NMI pin from NMI to GPIO functionality. | | | | | 0 NMI enabled | | | | | 1 NMI disabled | | | # 12.3.4 System Device Identification Register (SIM\_SDID) Address: 4003\_E000h base + 1024h offset = 4003\_F024h \* Notes: • x = Undefined at reset. # SIM\_SDID field descriptions | Field | Description | |-------------------|-----------------------------------------------------------------------------------| | 31–28 | Metering family ID | | FAMID | Indicates Presence of LCD module | | | 0001 Device derivatives without LCD | | | 0011 Device derivatives with LCD | | 27–24 | Sub-Family ID | | SUBFAMID | Specifies the number of AFE channels supported | | | 0010 Device derivatives with 2 AFE enabled (AFE Channels 0 and 2 are enabled) | | | 0011 Device derivatives with 3 AFE enabled (AFE Channels 0, 1, and 2 are enabled) | | | 0100 Device derivatives with 4 AFE enabled | | 23–20<br>SERIESID | Series ID | | | Metering Series | | | 0011 Metering Series | | 19–16<br>ATTR | Attribute ID | | Alin | Specifies type of Core on the device | | | 0000 M0+ core | | 15–12 | SRAM Size | | SRAMSIZE | Indicates the size of SRAM present on the device | | | 0101 16kB SRAM | | 11–8 | Revision ID | | REVID | Marks the changes with every Mask Set | | | 0001 Second Cut | | 7–4 | Die ID | | DIEID | Marks the change in Base Layer | | | 0000 First cut | | 3–0 | Pincount identification | | PINID | Specifies the pincount of the device. | | | 0000-0010 Reserved | | | 0011 44-pin | | | 0100 Reserved | | | 0101 64-pin | | | 0110 Reserved | | | 0111 Reserved | | | 1000 100-pin | | | 1001 Reserved<br>1010 Reserved | | | 1010 Reserved<br>1011 Reserved | | 1 | 1011 Hoseived | #### wemory map and register definition ## SIM\_SDID field descriptions (continued) | Field | | Desc | ription | |-------|------|----------|---------| | | 1100 | Reserved | | | | 1101 | Reserved | | | | 1110 | Reserved | | | | 1111 | Reserved | | ## 12.3.5 System Clock Gating Control Register 4 (SIM\_SCGC4) #### **NOTE** Writes to this register can only be performed in Supervisor mode Address: 4003\_E000h base + 1034h offset = 4003\_F034h #### SIM\_SCGC4 field descriptions | Field | Description | |-------------------|-----------------------------------------------------------------------------------------------------------------| | 31<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 30–27<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 1. | | 26–23<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 22<br>SPI1 | SPI1 Clock Gate Control This bit controls the clock gate to the SPI1 module. 0 Clock disabled 1 Clock enabled | # SIM\_SCGC4 field descriptions (continued) | Field | Description | |-------------------|--------------------------------------------------------------------------------------| | 21 | SPI0 Clock Gate Control | | SPI0 | This bit controls the clock gate to the SPI0 module. | | | 0 Clock disabled | | | 1 Clock enabled | | 20<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 19<br>CMP1 | High Speed Comparator1 Clock Gate Control. | | | This bit controls the clock gate to the CMP1 module. | | | 0 Clock disabled | | | 1 Clock enabled | | 18<br>CMP0 | High Speed Comparator0 Clock Gate Control. | | OWI 0 | This bit controls the clock gate to the CMP0 module. | | | 0 Clock disabled | | | 1 Clock enabled | | 17–16<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 15 | VREF Clock Gate Control | | VREF | This bit controls the clock gate to the VREF module. | | | 0 Clock disabled | | | 1 Clock enabled | | 14<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 13 | UART3 Clock Gate Control | | UART3 | This bit controls the clock gate to the UART3 module. | | | 0 Clock disabled | | | 1 Clock enabled | | 12<br>UART2 | UART2 Clock Gate Control | | UARIZ | This bit controls the clock gate to the UART2 module. | | | 0 Clock disabled | | | 1 Clock enabled | | 11<br>UART1 | UART1 Clock Gate Control | | JAHH | This bit controls the clock gate to the UART1 module. | | | 0 Clock disabled | | | 1 Clock enabled | | 10<br>UART0 | UART0 Clock Gate Control | | JAITIO | This bit controls the clock gate to the UART0 module. | #### memory map and register definition # SIM\_SCGC4 field descriptions (continued) | Field | Description | |---------------|--------------------------------------------------------------| | | 0 Clock disabled | | | 1 Clock enabled | | 9 | This field is reserved. | | Reserved | This read-only field is reserved and always has the value 0. | | 8<br>I2C1 | I2C1 Clock Gate Control | | | This bit controls the clock gate to the I2C1 module. | | | 0 Clock disabled | | | 1 Clock enabled | | 7<br>I2C0 | I2C0 Clock Gate Control | | 1200 | This bit controls the clock gate to the I2C0 module. | | | 0 Clock disabled | | | 1 Clock enabled | | 6 | Oscillator (Mhz) Clock Gate Control | | OSC | This bit controls the clock gate to the Oscillator(Mhz). | | | 0 Clock disabled | | | 1 Clock enabled | | 5<br>Reserved | Reserved for Future Expansion. | | | This field is reserved. | | | This read-only field is reserved and always has the value 0. | | 4 | MCG clock gate control. | | MCG | This bit controls the clock gate to the MCG Module. | | | 0 Clock disabled | | | 1 Clock enabled | | 3–2 | This field is reserved. | | Reserved | This read-only field is reserved and always has the value 0. | | 1<br>EWM | External Watchdog Monitor Clock gate control | | | This bit controls the clock gate to the EWM module. | | | 0 Clock disabled | | | 1 Clock enabled | | 0 | This field is reserved. | | Reserved | This read-only field is reserved and always has the value 0. | # 12.3.6 System Clock Gating Control Register 5 (SIM\_SCGC5) #### **NOTE** Writes to this register can only be performed in Supervisor mode #### SIM\_SCGC5 field descriptions | Field | Description | | |------------|--------------------------------------------------------------|--| | 31–27 | This field is reserved. | | | Reserved | This read-only field is reserved and always has the value 0. | | | 26<br>TMR3 | Quadtimer3 Clock Gate Control | | | 1111116 | This bit controls the clock gate to the QTMR3 | | | | 0 Clock disabled | | | | 1 Clock enabled | | | 25 | Quadtimer2 Clock Gate Control | | | TMR2 | This bit controls the clock gate to the QTMR2 | | | | 0 Clock disabled | | | | 1 Clock enabled | | | 24 | Quadtimer1 Clock Gate Control | | | TMR1 | This bit controls the clock gate to the QTMR1 | | | | 0 Clock disabled | | | | 1 Clock enabled | | #### memory map and register definition # SIM\_SCGC5 field descriptions (continued) | Field | Description | |----------------|---------------------------------------------------------------------------------------| | 23 | Quadtimer0 Clock Gate Control | | TMR0 | This bit controls the clock gate to the QTMR0 | | | 0 Clock disabled | | | 1 Clock enabled | | 22<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 21<br>XBAR | Peripheral Crossbar Clock Gate Control | | | This bit controls the clock gate to the XBAR Module. | | | 0 Clock disabled | | | 1 Clock enabled | | 20<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 19<br>WDOG | Watchdog Clock Gate Control | | WDOG | This bit controls the clock gate to the WatchDog Module. | | | 0 Clock disabled | | | 1 Clock enabled | | 18<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 17 | IRTC_REG_FILE Clock Gate Control | | IRTCREGFILE | This bit controls the clock gate to the IRTC_REG_FILE . | | | 0 Clock disabled | | | 1 Clock enabled | | 16<br>IRTC | IRTC Clock Gate Control | | | This bit controls the clock gate to the IRTC Module. | | | 0 Clock disabled | | | 1 Clock enabled | | 15<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 14<br>PORTI | PCTLI Clock Gate Control | | | This bit controls the clock gate to the PCTLI Module. | | | 0 Clock disabled | | | 1 Clock enabled | | 13<br>PORTH | PCTLH Clock Gate Control This bit control along the clock mate to the PCTLH Mediale. | | | This bit controls the clock gate to the PCTLH Module. | | | 0 Clock disabled | | | 1 Clock enabled | # SIM\_SCGC5 field descriptions (continued) | Field | Description | |-----------------|--------------------------------------------------------------------------------------| | 12 | PCTLG Clock Gate Control | | PORTG | This bit controls the clock gate to the PCTLG Module. | | | 0 Clock disabled | | | 1 Clock enabled | | 11 | PCTLF Clock Gate Control | | PORTF | This bit controls the clock gate to the PCTLF Module. | | | 0 Clock disabled | | | 1 Clock enabled | | 10<br>PORTE | PCTLE Clock Gate Control | | PORTE | This bit controls the clock gate to the PCTLE Module. | | | 0 Clock disabled | | | 1 Clock enabled | | 9<br>PORTD | PCTLD Clock Gate Control | | FORTD | This bit controls the clock gate to the PCTLD Module. | | | 0 Clock disabled | | | 1 Clock enabled | | 8<br>PORTC | PCTLC Clock Gate Control | | TOMO | This bit controls the clock gate to the PCTLC Module. | | | 0 Clock disabled | | | 1 Clock enabled | | 7<br>PORTB | PCTLB Clock Gate Control | | FORTB | This bit controls the clock gate to the PCTLB Module. | | | 0 Clock disabled | | | 1 Clock enabled | | 6<br>PORTA | PCTLA Clock Gate Control | | IONIA | This bit controls the clock gate to the PCTLA Module. | | | 0 Clock disabled | | | 1 Clock enabled | | 5–4<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 3<br>SLCD | Segmented LCD Clock Gate Control | | | This bit controls the clock gate to the SGLCD Module. | | | 0 Clock disabled | | | 1 Clock enabled | #### memory map and register definition # SIM\_SCGC5 field descriptions (continued) | Field | Description | |---------------|--------------------------------------------------------------------------------------| | 2<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 1<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 0<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | # 12.3.7 System Clock Gating Control Register 6 (SIM\_SCGC6) #### **NOTE** Writes to this register can only be performed in Supervisor mode #### wemory map and register definition ## SIM\_SCGC6 field descriptions | Field | Description | |---------------|---------------------------------------------------------------| | | · | | 31<br>CIM LID | SIM_HP Clock Gate Control | | SIM_HP | This bit controls the clock gate to the SIM High Power Logic. | | | | | | 1 Clock is always enabled to SIM | | 30 | SIM_LP Clock Gate Control | | SIM_LP | This bit controls the clock gate to the SIM Low Power logic. | | | | | | 1 Clock is enabled | | | 0 Clock is disabled | | 29 | This field is reserved. | | Reserved | This read-only field is reserved and always has the value 0. | | 28<br>LPTMR | LPTMR Clock Gate Control | | LI TIVII ( | This bit controls the clock gate to the LPTMR Module. | | | 0 Clock disabled | | | 1 Clock enabled | | 27–21 | This field is reserved. | | Reserved | This read-only field is reserved and always has the value 0. | | 20 | Programmable CRC Clock Gate Control | | CRC | This bit controls the clock gate to the PCRC Module. | | | This bit controls the clock gate to the Forto Module. | | | 0 Clock disabled | | | 1 Clock enabled | | 19–17 | Reserved for future expansion | | Reserved | | Table continues on the next page... # SIM\_SCGC6 field descriptions (continued) | Field | Description | |-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | This field is reserved. | | 16<br>AFE | AFE Clock Gate Control | | | This bit controls the clock to all four AFE channels. | | | 0 Clock disabled | | | 1 Clock enabled | | 15<br>Reserved | Reserved. | | | This field is reserved. This field is reserved and should always be written a value 0. This is reserved for future expansion and writing a 1 will cause unexpected behavior. | | 14<br>PIT1 | PIT1 Clock Gate Control | | | This bit controls the clock gate to the PIT1 Module. | | | 0 Clock disabled | | | 1 Clock enabled | | 13<br>PIT0 | PIT0 Clock Gate Control | | | This bit controls the clock gate to the PIT0 Module. | | | 0 Clock disabled | | | 1 Clock enabled | | 12<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 11<br>ADC | SAR ADC Clock Gate Control | | | This bit controls the clock gate to the SAR ADC Module. | | | 0 Clock disabled | | | 1 Clock enabled | | 10<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 9<br>RNGA | RNGA Clock Gate Control | | HINGA | This bit controls the clock gate to the RNGA Module. | | | 0 Clock disabled | | | 1 Clock enabled | | 8–5<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 4<br>DMAMUX3 | DMA MUX3 Clock Gate Control | | DIVIAIVIUX3 | This bit controls the clock gate to the DMA MUX3 Module. | | | 0 Clock disabled | | | 1 Clock enabled | | 3<br>DMAMUX2 | DMA MUX2 Clock Gate Control | | DIVIN (IVIOAL | This bit controls the clock gate to the DMA MUX2 Module. | #### wemory map and register definition ## SIM\_SCGC6 field descriptions (continued) | Field | Description | |---------|----------------------------------------------------------| | | 0 Clock disabled | | | 1 Clock enabled | | 2 | DMA MUX1 Clock Gate Control | | DMAMUX1 | This bit controls the clock gate to the DMA MUX1 Module. | | | 0 Clock disabled | | | 1 Clock enabled | | 1 | DMA MUX0 Clock Gate Control | | DMAMUX0 | This bit controls the clock gate to the DMA MUX0 Module. | | | 0 Clock disabled | | | 1 Clock enabled | | 0 | FTFA Clock Gate Control | | FTFA | This bit controls the clock gate to the FTFA Module. | | | 0 Clock disabled | | | 1 Clock enabled | # 12.3.8 System Clock Gating Control Register 7 (SIM\_SCGC7) #### NOTE Writes to this register can only be performed in Supervisor mode Address: 4003\_E000h base + 1040h offset = 4003\_F040h #### SIM\_SCGC7 field descriptions | Field | Description | |-------|--------------------------------------------------------------------------------------| | | This field is reserved. This read-only field is reserved and always has the value 0. | ## SIM\_SCGC7 field descriptions (continued) | Field | Description | |-------|-----------------------------------------------------| | 1 | DMA Clock Gate control. | | DMA | This bit controls the clock gate to the DMA module. | | | 0 Clock disabled | | | 1 Clock enabled | | 0 | MPU Clock Gate control. | | MPU | This bit controls the clock gate to the MPU module. | | | 0 Clock disabled | | | 1 Clock enabled | # 12.3.9 System Clock Divider Register 1 (SIM\_CLKDIV1) ## **NOTE** Writes to this register can only be performed in Supervisor mode Address: 4003\_E000h base + 1044h offset = 4003\_F044h ## SIM\_CLKDIV1 field descriptions | Field | Description | |-----------------|----------------------------------------------------------| | 31–28<br>SYSDIV | System Clock divider | | 0.05.1 | This field can be used to program Core/Platform divider. | | | 0000 Divide by 1 | | | 0001 Divide by 2 | Table continues on the next page... #### memory map and register definition # SIM\_CLKDIV1 field descriptions (continued) | Field | Description | |------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | 0010 Divide by 3 0011 Divide by 4 and so on If FOPT[0] is 0, the divider is set to div-by-8 after system reset is deasserted (after completion of system initialization sequence) | | 27<br>SYSCLKMODE | System Clock Mode This field is used to select the System clock: Bus clock: Flash clock ratio. 0 1:1:1 1 2:1:1 | | 26–0<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | 212 Preliminary Freescale Semiconductor, Inc. # 12.3.10 Flash Configuration Register 1 (SIM\_FCFG1) #### **NOTE** Writes to this register can only be performed in Supervisor mode Reset \* Notes: 0 0 0 0 0 ## SIM\_FCFG1 field descriptions 0 0 0 0 | Field | Description | |--------|--------------------------------------------------------------------------------------------------------------------------------------| | | This field is reserved. This read-only field is reserved and always has the value 0. | | PFSIZE | Program flash size This field specifies the amount of program flash memory available on the device . Undefined values are reserved. | <sup>•</sup> x = Undefined at reset. #### memory map and register definition # SIM\_FCFG1 field descriptions (continued) | Field | Description | |------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | 0000 Reserved | | | 0001 Reserved | | | 0011 Reserved | | | 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 | | | 1000 Reserved | | | 1001 Reserved | | | 1111 (Default) | | 23–2<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 1<br>FLASHDOZE | Flash Doze When set, Flash memory is disabled for the duration of Wait mode. An attempt by the DMA or other bus master to access the Flash when the Flash is disabled will result in a bus error. This bit should be clear during VLP modes. The Flash will be automatically enabled again at the end of Wait mode so interrupt vectors do not need to be relocated out of Flash memory. The wakeup time from Wait mode is extended when this bit is set. O Flash remains enabled during Wait mode 1 Flash is disabled for the duration of Wait mode | | 0<br>FLASHDIS | Flash Disable Flash accesses are disabled (and generate a bus error) and the Flash memory is placed in a low power state. This bit should not be changed during VLP modes. Relocate the interrupt vectors out of Flash memory before disabling the Flash. O Flash is enabled 1 Flash is disabled | ## 12.3.11 Flash Configuration Register 2 (SIM\_FCFG2) #### NOTE Writes to this register can only be performed in Supervisor mode Address: 4003\_E000h base + 1050h offset = 4003\_F050h #### SIM\_FCFG2 field descriptions | Field | Description | |------------------|--------------------------------------------------------------------------------------------------------------------| | 31<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 30–24<br>MAXADDR | Max address block This field concatenated with leading zeros indicates the first invalid address of program flash. | | 23–0<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | # 12.3.12 Unique Identification Register 0 (SIM\_UID0) Address: 4003\_E000h base + 1054h offset = 4003\_F054h <sup>\*</sup> Notes • x = Undefined at reset. #### wemory map and register definition ## SIM\_UID0 field descriptions | Field | Description | |-------------|---------------------------------------| | 31–0<br>UID | Unique Identification | | 0.2 | Unique identification for the device. | ## 12.3.13 Unique Identification Register 1 (SIM\_UID1) Address: 4003\_E000h base + 1058h offset = 4003\_F058h <sup>\*</sup> Notes: x = Undefined at reset. ## SIM\_UID1 field descriptions | Field | Description | |-------------|---------------------------------------| | 31–0<br>UID | Unique Identification | | | Unique identification for the device. | # 12.3.14 Unique Identification Register 2 (SIM\_UID2) Address: 4003\_E000h base + 105Ch offset = 4003\_F05Ch <sup>\*</sup> Notes: • x = Undefined at reset. #### SIM\_UID2 field descriptions | Field | Description | |-------------|---------------------------------------| | 31–0<br>UID | Unique Identification | | | Unique identification for the device. | # 12.3.15 Unique Identification Register 3 (SIM\_UID3) Address: 4003\_E000h base + 1060h offset = 4003\_F060h - \* Notes: - x = Undefined at reset. ## SIM\_UID3 field descriptions | Field | Description | | | | |-------------|---------------------------------------|--|--|--| | 31–0<br>UID | Unique Identification | | | | | | Unique identification for the device. | | | | # 12.3.16 Miscellaneous Control Register (SIM\_MISC\_CTL) This register contains various fields to control miscellaneous features such as receive/ transmit select for UART, PIT output selection, EWM input selection, ClkOut selection etc. ### **NOTE** Writes to this register can only be performed in Supervisor mode Address: 4003\_E000h base + 106Ch offset = 4003\_F06Ch ## wemory map and register definition | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|---------|------|---------|-----------------------|-------|--------|-------|-------|--------|--------|-------|-------|-----------|------|---------|----| | R | -CLKSEL | NSEL | OLITSEL | )<br>-<br>-<br>-<br>1 | IRSEL | 2IRSEL | IRSEL | IRSEL | ODTYPE | PADDIR | AFECI | KGEI | II O II N | <br> | NODOM | | | w | TMROPLI | EWMI | XRARPIT | | UART3 | UART2 | UART1 | UARTO | UARTMO | AFECLK | AILO | LNOLL | DMAD | | XBARAFE | SL | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | # SIM\_MISC\_CTL field descriptions | Field | Description | |---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31<br>VREFBUFPD | VrefBuffer Power Down Powers down VrefBuffer when set | | | 1 Owers down vicibalist when set | | | 0 Buffer Enabled | | | 1 Buffer Powered Down | | 30<br>VREFBUFINSEL | VrefBuffer Input Select | | | Selects Between Internal 1.2v reference and external reference for SAR and DAC | | | 0 Internal Reference selected as Buffer Input | | | 1 External Reference selected as Buffer Input | | 29 | VrefBuffer Output Enable | | VREFBUFOUTEN | Operates switch in VrefBuffer to enable the internal 1.2v reference to be driven to VREF pad. | | | 0 Buffer does not drive PAD | | | Buffer drives selected voltage (selected by vref_buffer_sel) on pad | | 28<br>RTCCLKSEL | RTC Clock select | | | Selects between 32K IRC and OSC_32K clk for RTC operation | | | 0 RTC OSC_32K clock selected | | | 1 32K IRC Clock selected | | 27–26<br>TMR3PCSSEL | Quadtimer Channel3 Primary Count Source Select | | TIVITION GOODE | This is used to select primary count source (clock) for Quadtimer Channel3. Configure TMR_3_CTRL_PCS = 1xxxb to route selected primary clock source to the timer Channel3. | | | 00 Bus Clock | | | 01 Peripheral Crossbar Output [9] | | | 10 Peripheral Crossbar Output [10] | | | 11 Disabled | | 25–24<br>TMR2PCSSEL | Quadtimer Channel2 Primary Count Source Select | | | This is used to select primary count source (clock) for Quadtimer Channel2. Configure TMR_2_CTRL_PCS = 1xxxb to route selected primary clock source to the timer Channel2. | | | 00 Bus Clock | | | 01 Peripheral Crossbar Output [9] | Table continues on the next page... ## KM Family Reference Manual, Rev. 5, Oct 2013 218 Preliminary Freescale Semiconductor, Inc. # SIM\_MISC\_CTL field descriptions (continued) | Field | Description | |---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | 10 Peripheral Crossbar Output [10] | | | 11 Disabled | | 23–22 | Quadtimer Channel1 Primary Count Source Select | | TMR1PCSSEL | This is used to select primary count source (clock) for Quadtimer Channel1. Configure TMR_1_CTRL_PCS = 1xxxb to route selected primary clock source to the timer Channel1. | | | 00 Bus Clock | | | 01 Peripheral Crossbar Output [9] | | | 10 Peripheral Crossbar Output [10] | | | 11 Disabled | | 21-20<br>TMR0PCSSEL | Quadtimer Channel0 Primary Count Source Select | | TIVITOI COSEE | This is used to select primary count source (clock) for Quadtimer Channel0. Configure TMR_0_CTRL_PCS = 1xxxb to route selected primary clock source to the timer Channel0. | | | 00 Bus Clock | | | 01 Peripheral Crossbar Output [9] | | | 10 Peripheral Crossbar Output [10] | | | 11 Disabled | | 19 | Quadtimer Channel3 Secondary Count Source Select | | TMR3SCSSEL | This field is used to select secondary count input source for Quadtimer Channel3. Configure TMR_3_CTRL_SCS = 11b to route selected secondary source to the timer Channel3. | | | 0 Pad PTE5 or PTD1, depending upon PCTL configuration. | | | 1 Peripheral Crossbar (XBAR) Output[8] | | 18 | Quadtimer Channel2 Secondary Count Source Select | | TMR2SCSSEL | This field is used to select secondary count input source for Quadtimer Channel2. Configure TMR_2_CTRL_SCS = 10b to route selected secondary source to the timer Channel2. | | | Pad PTF7 or PTF0, depending upon PCTL configuration. | | | 1 Peripheral Crossbar (XBAR) Output[7] | | 17<br>TMR1SCSSEL | Quadtimer Channel1 Secondary Count Source Select | | | This field is used to select secondary count input source for Quadtimer Channel1. Configure TMR_1_CTRL_SCS = 01b to route selected secondary source to the timer Channel1. | | | 0 Pad PTG0 or PTC6, depending upon PCTL configuration. | | | 1 Peripheral Crossbar (XBAR) Output[6] | | 16<br>TMR0SCSSEL | Quadtimer Channel0 Secondary Count Source Select | | | This field is used to select secondary count input source for Quadtimer Channelo. Configure TMR_0_CTRL_SCS = 00b to route selected secondary source to the timer Channelo. | | | 0 Pad PTF1 or PTD5, depending upon PCTL configuration. | | | 1 Peripheral Crossbar (XBAR) Output[5] | | 15 | Timer CH0 PLL clock select | | TMR0PLLCLKSEL | | ## memory map and register definition # SIM\_MISC\_CTL field descriptions (continued) | Field | Description | |------------------|------------------------------------------------------------------------------------------------------------------------------------------------| | | 0 Selects Bus Clock as source for the Timer CH0 | | | 1 Selects the PLL_AFE clock as the source for Timer CH0. The PLL_AFE clock source is itself selected using the MISC_CTL[5:4] | | 14 | External Watchdog Monitor Input Select | | EWMINSEL | This field is used to select input for external watchdog monitor. | | | 0 Input from PAD (PTE[2] or PTE[4] as selected from Pinmux control ) | | | 1 Peripheral Crossbar (XBAR) Output[32] | | 13–12 | XBAR PIT Output select | | XBARPITOUTSEL | This field selects PIT timer and timer channel to drive XBAR_IN[16]. | | | 00 PIT0[0] (default) | | | 01 PIT0[1] | | | 10 PIT1[0] | | | 11 PIT1[1] | | 11<br>UART3IRSEL | UART3 IRDA Select | | UAITTOITISEE | Exclusive selection with other UARTs. Do not select while another UART is selected for the same functionality | | | 0 Pad RX input (PTC[3] or PTD[7], as selected in Pinmux control) selected for RX input of UART3 and UART3 TX signal is not used for modulation | | | 1 UART3 selected for IRDA modulation. UART3 TX modulated by XBAR_OUT[14] and UART3 RX input connected to XBAR_OUT[13]. | | 10 | UART2 IRDA Select | | UART2IRSEL | Exclusive selection with other UARTs. Do not select while another UART is selected for the same functionality | | | 0 Pad RX input PTE[6] selected for RX input of UART2 and UART2 TX signal is not used for modulation | | | 1 UART2 selected for IRDA modulation. UART2 TX modulated by XBAR_OUT[14] and UART2 RX input connected to XBAR_OUT[13]. | | 9<br>UART1IRSEL | UART1 IRDA Select | | | Exclusive selection with other UARTs. Do not select while another UART is selected for the same functionality | | | 0 Pad RX input (PTD[2] or PTI[0], as selected in Pinmux control) selected for RX input of UART1 and UART1 TX signal is not used for modulation | | | UART1 selected for IRDA modulation. UART1 TX modulated by XBAR_OUT[14] and UART1 RX input connected to XBAR_OUT[13] | | 8 | UART0 IRDA Select | | UART0IRSEL | Exclusive selection with other UARTs. Do not select while another UART is selected for the same functionality | # SIM\_MISC\_CTL field descriptions (continued) | Field | Description | |-------------------------|--------------------------------------------------------------------------------------------------------------------------| | | Pad RX input (PTD[0] or PTF[3], as selected in Pinmux control) selected for RX input of | | | UART0 and UART0 TX signal is not used for modulation | | | 1 UART0 selected for IRDA modulation. UART0 TX modulated by XBAR_OUT[14] and UART0 | | _ | RX input connected to XBAR_OUT[13] | | 7<br>UARTMODTYPE | UART Modulation Type | | OARTMODITE | Selects between TypeA and TypeB modulation for IRDA support | | | TypeA (ORed) Modulation selected for IRDA | | | 1 TypeB (ANDed) Modulation selected for IRDA | | 6 | AFE Clock Pad Direction | | AFECLKPADDIR | Octobrollo the editor of the AFF OLIVING | | | Controls the direction of the AFE CLK pin | | | 0 AFE CLK PAD is input | | | 1 AFE CLK PAD is output | | 5–4 | AFE Clock Source Select | | AFECLKSEL | October to the second DLL SLL and OOO also to a the accuracy facility DLL also to the second facility of the AFF Olso to | | | Selects between PLL, FLL and OSC clock as the source for the PLL clock branch for AFE Clock Mux | | | | | | 00 MCG PLL Clock selected | | | 01 MCG FLL Clock selected | | | 10 OSC Clock selected | | | 11 Disabled | | 3–2 | DMA Done select | | DMADONESEL | This field can be used to select the DMA Done flag to drive XBAR_IN[32] | | | | | | 00 DMA0 | | | 01 DMA1 | | | 10 DMA2<br>11 DMA3 | | 1.0 | | | 1–0<br>XBARAFEMODOUTSEL | XBAR AFE Modulator Output Select | | | This field selects modulator data output of the respective AFE channel to drive XBAR_IN[3]. | | | 00 Sigma Delta Modulator 0 data output | | | 01 Sigma Delta Modulator 1 data output | | | 10 Sigma Delta Modulator 2 data output | | | 11 Sigma Delta Modulator 3 data output | # 12.4 Functional description See Introduction section. runctional description # **Chapter 13 Miscellaneous Control Module (MCM)** ## 13.1 Introduction #### **NOTE** For the chip-specific implementation details of this module's instances, see the chip configuration information. The Miscellaneous Control Module (MCM) provides a myriad of miscellaneous control functions. ## **13.1.1 Features** The MCM includes the following features: - Program-visible information on the platform configuration - Crossbar master arbitration policy selection - Flash controller speculation buffer and cache configurations - Master attributes configurations # 13.2 Memory map/register descriptions The memory map and register descriptions found here describe the registers using byte addresses. The registers can be written only when in supervisor mode. #### NOTE For MCM registers, any of these behaviors will cause hardfault exception- access any register in user mode, access PID register by halfword or byte, write to read-only registers. KM Family Reference Manual, Rev. 5, Oct 2013 223 ## **MCM** memory map | Absolute<br>address<br>(hex) | Register name | | Access | Reset value | Section/<br>page | |------------------------------|---------------------------------------------------------|----|--------|-------------|------------------| | F000_3008 | Crossbar Switch (AXBS) Slave Configuration (MCM_PLASC) | 16 | R | 0007h | 13.2.1/224 | | F000_300A | Crossbar Switch (AXBS) Master Configuration (MCM_PLAMC) | 16 | R | 0005h | 13.2.2/225 | | F000_300C | Platform Control Register (MCM_PLACR) | 32 | R/W | | 13.2.3/225 | | F000_3030 | Process ID register (MCM_PID) | 32 | R/W | 0000_0000h | 13.2.4/228 | | F000_3040 | Compute Operation Control Register (MCM_CPO) | 32 | R/W | 0000_0000h | 13.2.5/229 | | F000_3080 | Master Attribute Configuration Register (MCM_MATCR0) | | R/W | 0000_0000h | 13.2.6/230 | #### 13.2.1 **Crossbar Switch (AXBS) Slave Configuration (MCM\_PLASC)** PLASC is a 16-bit read-only register identifying the presence/absence of bus slave connections to the device's crossbar switch. Address: F000 3000h base + 8h offset = F000 3008h # MCM\_PLASC field descriptions | Field | Description | |------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------| | 15–8<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 7–0<br>ASC | Each bit in the ASC field indicates whether there is a corresponding connection to the crossbar switch's slave input port. | | | <ul> <li>A bus slave connection to AXBS input port <i>n</i> is absent.</li> <li>A bus slave connection to AXBS input port <i>n</i> is present.</li> </ul> | # 13.2.2 Crossbar Switch (AXBS) Master Configuration (MCM\_PLAMC) PLAMC is a 16-bit read-only register identifying the presence/absence of bus master connections to the device's crossbar switch. Address: F000\_3000h base + Ah offset = F000\_300Ah ## MCM\_PLAMC field descriptions | Field | Description | | | | | |------------------|---------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | 15–8<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | | | | | 7–0<br>AMC | Each bit in the AMC field indicates whether there is a corresponding connection to the AXBS master input port. | | | | | | | <ul> <li>A bus master connection to AXBS input port n is absent</li> <li>A bus master connection to AXBS input port n is present</li> </ul> | | | | | # 13.2.3 Platform Control Register (MCM\_PLACR) The PLACR register selects the arbitration policy for the crossbar masters and configures the flash memory controller. The speculation buffer and cache in the flash memory controller is configurable via PLACR[15:10]. The speculation buffer is enabled only for instructions after reset. It is possible to have these states for the speculation buffer: | DFCS | EFDS | Description | |------|------|------------------------------------------------------------| | 0 | 0 | Speculation buffer is on for instruction and off for data. | | 0 | 1 | Speculation buffer is on for instruction and on for data. | | 1 | Х | Speculation buffer is off. | ### wemory map/register descriptions The cache in flash controller is enabled and caching both instruction and data type fetches after reset. It is possible to have these states for the cache: | DFCC | DFCIC | DFCDA | Description | |------|-------|-------|-----------------------------------------------| | 0 | 0 | 0 | Cache is on for both instruction and data. | | 0 | 0 | 1 | Cache is on for instruction and off for data. | | 0 | 1 | 0 | Cache is off for instruction and on for data. | | 0 | 1 | 1 | Cache is off for both instruction and data. | | 1 | X | X | Cache is off. | Address: F000\_3000h base + Ch offset = F000\_300Ch ## MCM\_PLACR field descriptions | Field | Description | | | |-------------------|-----------------------------------------------------------------------------------------------------------------------------------------|--|--| | 31–17<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | | | 16<br>ESFC | Enable Stalling Flash Controller Enables stalling flash controller when flash is busy. | | | | | <ul> <li>Disable stalling flash controller when flash is busy.</li> <li>Enable stalling flash controller when flash is busy.</li> </ul> | | | Table continues on the next page... ## KM Family Reference Manual, Rev. 5, Oct 2013 226 Preliminary Freescale Semiconductor, Inc. # MCM\_PLACR field descriptions (continued) | Field | Description | |-------------|-----------------------------------------------------------------------------------------------------------------| | 15<br>DFCS | Disable Flash Controller Speculation | | | Disables flash controller speculation. | | | 0 Enable flash controller speculation. | | | 1 Disable flash controller speculation. | | 14<br>EFDS | Enable Flash Data Speculation | | | Enables flash data speculation. | | | 0 Disable flash data speculation. | | | 1 Enable flash data speculation. | | 13<br>DFCC | Disable Flash Controller Cache | | | Disables flash controller cache. | | | 0 Enable flash controller cache. | | | 1 Disable flash controller cache. | | 12<br>DFCIC | Disable Flash Controller Instruction Caching | | | Disables flash controller instruction caching. | | | 0 Enable flash controller instruction caching. | | | 1 Disable flash controller instruction caching. | | 11<br>DFCDA | Disable Flash Controller Data Caching | | | Disables flash controller data caching. | | | 0 Enable flash controller data caching | | | 1 Disable flash controller data caching. | | 10<br>CFCC | Clear Flash Controller Cache | | CFCC | Writing a 1 to this field clears the cache. Writing a 0 to this field is ignored. This field always reads as 0. | | 9 | Arbitration select | | ARB | 0 Fixed-priority arbitration for the crossbar masters | | | 1 Round-robin arbitration for the crossbar masters | | 8–0 | This field is reserved. | | Reserved | This read-only field is reserved and always has the value 0. | # 13.2.4 Process ID register (MCM\_PID) This register drives the M0\_PID value in the Memory Protection Unit (MPU). System software loads this register before passing control to a given user mode process. If the PID of the process does not match the value in this register, a bus error occurs. See the MPU chapter for more details. Address: F000\_3000h base + 30h offset = F000\_3030h ## MCM\_PID field descriptions | Field | Description | | | | |------------------|---------------------------------------------------------------------------------------------------------------------------------|--|--|--| | 31–8<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | | | | 7–0<br>PID | M0_PID For MPU Drives the M0_PID value in the MPU. | | | | | | 00h Reserved for privileged secure tasks 01h - 7Fh Allocated for user secure tasks 80h - FFh Allocated for user nonsecure tasks | | | | # 13.2.5 Compute Operation Control Register (MCM\_CPO) This register controls the Compute Operation. ## **MCM\_CPO** field descriptions | Field | Description | | | | |-------------|--------------------------------------------------------------------------------------|--|--|--| | 31–3 | This field is reserved. | | | | | Reserved | This read-only field is reserved and always has the value 0. | | | | | 2<br>CPOWOI | Compute Operation Wake-up on Interrupt | | | | | | 0 No effect. | | | | | | 1 When set, the CPOREQ is cleared on any interrupt or exception vector fetch. | | | | | 1 | Compute Operation Acknowledge | | | | | CPOACK | O Compute operation entry has not completed or compute operation exit has completed. | | | | | | 1 Compute operation entry has completed or compute operation exit has not completed. | | | | | 0 | Compute Operation Request | | | | | CPOREQ | This bit is auto-cleared by vector fetching if CPOWOI = 1. | | | | Table continues on the next page... #### wemory map/register descriptions ## MCM\_CPO field descriptions (continued) | Field | Description | | |-------|------------------------------|--| | | 0 Request is cleared. | | | | 1 Request Compute Operation. | | # 13.2.6 Master Attribute Configuration Register (MCM\_MATCRn) This 32-bit register consists of four 8-bit attribute configuration register fields for each system bus master. Each MATCRn register field allows the corresponding bus master's secure/nonsecure and privileged/user attributes to be forced to a static state, or simply enable the attributes generated by the master module. This information is then used on a per bus transaction basis to control access. See the MPU chapter for more details. For all ATCn values, if the state indicates privileged (either statically or via the master module's attribute), then the other state indicator is forced to secure. ## NOTE Writes to ATC0 configure the processor's master attributes, and software must take special care with this value. Typically, the processor would use an ATC0 value of {0b11- or 0b00-} because the other values can create a configuration where access to system level resources is not allowed. Each MATCRn register field also contains a lock bit (RO) that may be set to disable writes to the register, preserving the configured state until the next system reset. Address: F000\_3000h base + 80h offset + (1d $\times$ i), where i=0d to 0d #### MCM\_MATCRn field descriptions | Field | Description | | | | |-------------------|--------------------------------------------------------------------------------------|--|--|--| | 31–24<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | | | | 23<br>RO2 | Read-Only Master n | | | | # MCM\_MATCRn field descriptions (continued) | Field | Description | | | | | |-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | | This register bit provides a mechanism to lock the configuration state defined by ATCn. Once asserted, this bit remains set and attempted writes to the ATCn are ignored until the next system reset clears the flag. | | | | | | | 0 Writes to the ATCn are allowed. | | | | | | | 1 Writes to the ATCn are ignored. | | | | | | 22–19<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | | | | | 18–16 | Attribute Configuration Master n | | | | | | ATC2 | This 3-bit field defines the privileged/user and secure/nonsecure attribute configurations. | | | | | | | 00x Master attributes are statically forced to {privileged, secure}. | | | | | | | 010 Master attributes are statically forced to {user, secure}. | | | | | | | 011 Master attributes are statically forced to {user, nonsecure}. | | | | | | | 100 Enable master attribute {privileged or user} and statically force {secure}. | | | | | | | 101 Enable master attribute {privileged or user} and statically force {nonsecure}. | | | | | | | 11x Enable master attribute {privileged or user, secure or nonsecure} | | | | | | 15–8<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | | | | | 7<br>RO0 | Read-Only Master n This register bit provides a mechanism to lock the configuration state defined by ATCn. Once asserted, this bit remains set and attempted writes to the ATCn register are ignored until the next system reset clears the flag. Writes to the ATCn are allowed. Writes to the ATCn are ignored. | | | | | | 0.0 | | | | | | | 6–3<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | | | | | 2–0 | Attribute Configuration Master n | | | | | | ATC0 | This 3-bit field defines the privileged/user and secure/nonsecure attribute configurations. | | | | | | | 00x Master attributes are statically forced to {privileged, secure}. | | | | | | | 010 Master attributes are statically forced to {user, secure}. | | | | | | | 011 Master attributes are statically forced to {user, nonsecure}. | | | | | | | 100 Enable master attribute {privileged or user} and statically force {secure}. | | | | | | | 101 Enable master attribute {privileged or user} and statically force {nonsecure}. | | | | | | | 11x Enable master attribute {privileged or user, secure or nonsecure} | | | | | wemory map/register descriptions # **Chapter 14 Reset Control Module (RCM)** ## 14.1 Introduction Information found here describes the registers of the Reset Control Module (RCM). The RCM implements many of the reset functions for the chip. See the chip's reset chapter for more information. See AN4503: Power Management for Kinetis and ColdFire+ MCUs for further details on using the RCM. # 14.2 Reset memory map and register descriptions The RCM Memory Map/Register Definition can be found here. The Reset Control Module (RCM) registers provide reset status information and reset filter control. ## **NOTE** The RCM registers can be written only in supervisor mode. Write accesses in user mode are blocked and will result in a bus error. ## **RCM** memory map | Absolute address (hex) | '' I Width I I | | Reset value | Section/<br>page | | |------------------------|----------------------------------------------|---|-------------|------------------|------------| | 4007_B000 | System Reset Status Register 0 (RCM_SRS0) | 8 | R | 82h | 14.2.1/234 | | 4007_B001 | System Reset Status Register 1 (RCM_SRS1) | 8 | R | 00h | 14.2.2/235 | | 4007_B004 | Reset Pin Filter Control register (RCM_RPFC) | 8 | R/W | 00h | 14.2.3/236 | | 4007_B005 | Reset Pin Filter Width register (RCM_RPFW) | 8 | R/W | 00h | 14.2.4/237 | # 14.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 - VLLS mode wakeup due to RESET pin assertion 0x41 - VLLS mode wakeup due to other wakeup sources 0x01 - Other reset a bit is set if its corresponding reset source caused the reset Address: 4007\_B000h base + 0h offset = 4007\_B000h ## RCM\_SRS0 field descriptions | Field | Description | | | |-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | 7<br>POR | Power-On Reset | | | | . 5 | Indicates a reset has been 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 has been caused by an active-low level on the external RESET pin. | | | | | 0 Reset not caused by external reset pin | | | | | 1 Reset caused by external reset pin | | | | 5<br>WDOG | Watchdog | | | | | Indicates a reset has been caused by the watchdog timer timing out. This reset source can be blocked by disabling the watchdog. | | | | | 0 Reset not caused by watchdog timeout | | | | | 1 Reset caused by watchdog timeout | | | | 4 | This field is reserved. | | | | Reserved | This read-only field is reserved and always has the value 0. | | | 235 ## RCM\_SRS0 field descriptions (continued) | Field | Description | | | | |-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | 3<br>LOL | Loss-of-Lock Reset | | | | | | Indicates a reset has been caused by a loss of lock in the MCG PLL. See the MCG description for information on the loss-of-clock event. | | | | | | 0 Reset not caused by a loss of lock in the PLL | | | | | | 1 Reset caused by a loss of lock in the PLL | | | | | 2<br>LOC | Loss-of-Clock Reset | | | | | | Indicates a reset has been 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. | | | | | | 0 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 PMC_LVDSC1[LVDRE] is set and the supply drops below the LVD trip voltage, an LVD reset occurs. This field 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 | | | | | | Indicates a reset has been caused by an enabled wakeup source while the chip was in a low leakage mode. Any enabled wakeup source in a VLLSx mode causes a reset. This bit is cleared by any reset except WAKEUP. | | | | | | 0 Reset not caused by wakeup source | | | | | | 1 Reset caused by wakeup source | | | | # 14.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 - VLLS mode wakeup 0x00 - Other reset a bit is set if its corresponding reset source caused the reset #### neset memory map and register descriptions Address: 4007\_B000h base + 1h offset = 4007\_B001h ## **RCM\_SRS1** field descriptions | Field | Description | | | | |---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | 7<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | | | | 6<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | | | | 5<br>SACKERR | Stop Mode Acknowledge Error Reset Indicates that after an attempt to enter Stop mode, a reset has been caused 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 | | | | | 4<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | | | | 3<br>MDM_AP | MDM-AP System Reset Request Indicates a reset has been caused by the host debugger system setting of the System Reset Request bit in the MDM-AP Control Register. O Reset not caused by host debugger system setting of the System Reset Request bit Reset caused by host debugger system setting of the System Reset Request bit | | | | | 2<br>SW | Software Indicates a reset has been caused by software setting of SYSRESETREQ bit in Application Interrupt and Reset Control Register in the ARM core. 0 Reset not caused by software setting of SYSRESETREQ bit 1 Reset caused by software setting of SYSRESETREQ bit | | | | | 1<br>LOCKUP | Core Lockup Indicates a reset has been caused by the ARM core indication of a LOCKUP event. O Reset not caused by core LOCKUP event Reset caused by core LOCKUP event | | | | | 0<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | | | # 14.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 . Address: 4007\_B000h base + 4h offset = 4007\_B004h ## RCM\_RPFC field descriptions | Field | Description | | | | |------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | 7–3 | This field is reserved. | | | | | Reserved | This read-only field is reserved and always has the value 0. | | | | | 2<br>RSTFLTSS | Reset Pin Filter Select in Stop Mode | | | | | | Selects how the reset pin filter is enabled in Stop and VLPS modes , and also during LLS and VLLS modes. On exit from VLLS mode, this bit should be reconfigured before clearing PMC_REGSC[ACKISO]. | | | | | | 0 All filtering disabled | | | | | | 1 LPO clock filter enabled | | | | | 1–0<br>RSTFLTSRW | Reset Pin Filter Select in Run and Wait Modes | | | | | | 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 | | | | # 14.2.4 Reset Pin Filter Width register (RCM\_RPFW) ### NOTE The reset values of the bits in the RSTFLTSEL field are for Chip POR only. They are unaffected by other reset types. Address: 4007\_B000h base + 5h offset = 4007\_B005h ## neset memory map and register descriptions # **RCM\_RPFW** field descriptions | Field | Description | | | | | | |-----------|--------------------------------------------------------------|---------------------------------------|--|--|--|--| | 7–5 | This field is reserved. | | | | | | | Reserved | This read-only field is reserved and always has the value 0. | | | | | | | 4–0 | Reset Pin Filter Bus Clock Select | | | | | | | RSTFLTSEL | | | | | | | | | 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 | | | | | | | 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 | | | | | # **Chapter 15 System Mode Controller (SMC)** ## 15.1 Introduction #### **NOTE** For the chip-specific implementation details of this module's instances, see the chip configuration information. 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. See AN4503: Power Management for Kinetis and ColdFire+ MCUs for further details on using the SMC. # 15.2 Modes of operation The ARM CPU has three primary modes of operation: - Run - Sleep - Deep Sleep The WFI or WFE instruction is used to invoke Sleep and Deep Sleep modes. Run, Wait, and Stop are the common terms used for the primary operating modes of Freescale microcontrollers. KM Family Reference Manual, Rev. 5, Oct 2013 239 #### woues of operation The following table shows the translation between the ARM CPU modes and the Freescale MCU power modes. | ARM CPU mode | MCU mode | | |--------------|----------|--| | Sleep | Wait | | | Deep Sleep | Stop | | Accordingly, the ARM CPU documentation refers to sleep and deep sleep, while the Freescale MCU documentation normally uses wait and stop. 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 in 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) field can be modified to change 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. 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 15-1. Power modes | Mode | Description | |------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | RUN | The MCU can be run at full speed and the internal supply is fully regulated, that is, in run regulation. This mode is also referred to as Normal Run mode. | | WAIT | The core clock is gated off. The system clock continues to operate. Bus clocks, if enabled, continue to operate. Run regulation is maintained. | | STOP | The core clock is gated off. System clocks to other masters and bus clocks are gated off 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 the maximum allowable frequencies. | | VLPS | The core clock is gated off. System clocks to other masters and bus clocks are gated off after all stop acknowledge signals from supporting peripherals are valid. | ## Table 15-1. Power modes (continued) | Mode | Description | |-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | VLLS3 | The core clock is gated off. System clocks to other masters and bus clocks are gated off after all stop acknowledge signals from supporting peripherals are valid. The MCU is placed in a low leakage mode by powering down the internal logic. All system RAM contents are retained and I/O states are held. Internal logic states are not retained. | | VLLS2 | The core clock is gated off. System clocks to other masters and bus clocks are gated off after all stop acknowledge signals from supporting peripherals are valid. The MCU is placed in a low leakage mode by powering down the internal logic and the system RAM2 partition. The system RAM1 partition contents are retained in this mode. Internal logic states are not retained. 1 | | VLLS1 | The core clock is gated off. System clocks to other masters and bus clocks are gated off after all stop acknowledge signals from supporting peripherals are valid. The MCU is placed in a low leakage mode by powering down the internal logic and all system RAM. I/O states are held. Internal logic states are not retained. | | VLLS0 | The core clock is gated off. System clocks to other masters and bus clocks are gated off after all stop acknowledge signals from supporting peripherals are valid. The MCU is placed in a low leakage mode by powering down the internal logic and all system RAM. I/O states are held. Internal logic states are not retained. The 1kHz LPO clock is disabled and the power on reset (POR) circuit can be optionally enabled using STOPCTRL[PORPO]. | <sup>1.</sup> See the devices' chip configuration details for the size and location of the system RAM partitions. # 15.3 Memory map and register descriptions Information about the registers related to the system mode controller can be found here. 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 section details. ### NOTE The SMC registers can be written only in supervisor mode. Write accesses in user mode are blocked and will result in a bus error. #### **SMC** memory map | Absolute<br>address<br>(hex) | Register name | Width<br>(in bits) | Access | Reset value | Section/<br>page | |------------------------------|---------------------------------------------|--------------------|--------|-------------|------------------| | 4007_E000 | Power Mode Protection register (SMC_PMPROT) | 8 | R/W | See section | 15.3.1/242 | | 4007_E001 | Power Mode Control register (SMC_PMCTRL) | 8 | R/W | 40h | 15.3.2/243 | | 4007_E002 | Stop Control Register (SMC_STOPCTRL) | 8 | R/W | 03h | 15.3.3/244 | | 4007_E003 | Power Mode Status register (SMC_PMSTAT) | 8 | R | 01h | 15.3.4/245 | # 15.3.1 Power Mode Protection register (SMC\_PMPROT) This register provides protection for entry into any low-power run or stop mode. The 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 PMCTRL[RUNM] remains 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 section details for more information. Address: 4007\_E000h base + 0h offset = 4007\_E000h | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|---|---|------|---|---|---|-------|---| | Read | 0 | 0 | AVLP | 0 | 0 | 0 | AVLLS | 0 | | Write | | | | | | | | | | Reset | 0 | 0 | * | 0 | 0 | 0 | 0 | 0 | <sup>\*</sup> Notes: ### SMC\_PMPROT field descriptions | Field | Description | |---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 6<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 5<br>AVLP | Allow Very-Low-Power Modes Provided the appropriate control bits are set up in PMCTRL, this write-once field allows the MCU to enter | | | <ul> <li>any very-low-power mode (VLPR, VLPW, and VLPS).</li> <li>VLPR, VLPW, and VLPS are not allowed.</li> <li>VLPR, VLPW, and VLPS are allowed.</li> </ul> | | 4<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 3<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | <sup>•</sup> AVLP field: When booting in run mode, the reset value is 0. When booting in VLPR mode, the reset value is 1. ## **SMC\_PMPROT** field descriptions (continued) | Field | Description | |---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 2<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 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 (VLLSx). O Any VLLSx mode is not allowed Any VLLSx mode is allowed | | 0<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | # 15.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** All bits of this register, except the RUNM field, are reset on Chip POR not VLLS and by reset types that trigger Chip POR not VLLS. The RUNM field is reset on Chip Reset not VLLS and by reset types that trigger Chip Reset not VLLS. See the Reset section details for more information. Address: 4007\_E000h base + 1h offset = 4007\_E001h ## SMC\_PMCTRL field descriptions | Field | Description | | | | | |---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | 7<br>Reserved | This field is reserved. This bit is reserved for future expansion and should always be written zero for deterministic operation. | | | | | | 6–5<br>RUNM | Run Mode Control When written, 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 resets to VLPR in order to minimize power consumption during a reset recovery sequence. | | | | | | | NOTE: RUNM must be set to VLPR only when PMSTAT=RUN. After being written to VLPR, RUNM should not be written back to RUN until PMSTAT=VLPR. | | | | | Table continues on the next page... #### wemory map and register descriptions ## **SMC\_PMCTRL** field descriptions (continued) | Field | Description | | | | | |---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | | 00 Normal Run mode (RUN) | | | | | | | 01 Reserved | | | | | | | 10 Very-Low-Power Run mode (VLPR) | | | | | | | 11 Reserved | | | | | | 4<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | | | | | 3 | Stop Aborted | | | | | | STOPA | When set, this read-only status field indicates an interrupt or reset occured during the previous stop mode entry sequence, preventing the system from entering that mode. This field 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<br>STOPM | Stop Mode Control | | | | | | | When written, controls entry into the selected stop mode when Sleep-Now or Sleep-On-Exit mode is entered with SLEEPDEEP=1. 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. | | | | | | | <b>NOTE:</b> When set to VLLSx, the VLLSM bits bits in the STOPCTRL register is used to further select the particular VLLS submode which will be entered. | | | | | | | <b>NOTE:</b> When set to STOP, the PSTOPO bits in the STOPCTRL register can be used to select a Partial Stop mode if desired. | | | | | | | 000 Normal Stop (STOP) | | | | | | | 001 Reserved | | | | | | | 010 Very-Low-Power Stop (VLPS) | | | | | | | 011 Reserved | | | | | | | 100 Very-Low-Leakage Stop (VLLSx) | | | | | | | 101 Reserved | | | | | | | 110 Reseved | | | | | | | 111 Reserved | | | | | # 15.3.3 Stop Control Register (SMC\_STOPCTRL) The STOPCTRL register provides various control bits allowing the user to fine tune power consumption during the stop mode selected by the STOPM field. ### 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 section details for more information. Address: 4007\_E000h base + 2h offset = 4007\_E002h ## SMC\_STOPCTRL field descriptions | Field | Description | |---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7–6<br>PSTOPO | Partial Stop Option These bits control whether a Partial Stop mode is entered when STOPM=STOP. When entering a Partial Stop mode from RUN mode, the PMC, MCG and flash remain fully powered, allowing the device to wakeup almost instantaneously at the expense of higher power consumption. In PSTOP2, only system clocks are gated allowing peripherals running on bus clock to remain fully functional. In PSTOP1, both system and bus clocks are gated. O STOP - Normal Stop mode PSTOP1 - Partial Stop with both system and bus clocks disabled PSTOP2 - Partial Stop with system clock disabled and bus clock enabled | | 5<br>PORPO | POR Power Option This bit controls whether the POR detect circuit is enabled in VLLS0 mode. 0 POR detect circuit is enabled in VLLS0 1 POR detect circuit is disabled in VLLS0 | | 4<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 3<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 2–0<br>VLLSM | VLLS Mode Control This field controls which VLLS sub-mode to enter if STOPM=VLLSx. 000 VLLS0 001 VLLS1 010 VLLS2 011 VLLS3 100 Reserved 101 Reserved 110 Reserved 111 Reserved | # 15.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. ### **runctional description** ## **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 section details for more information. ## **SMC\_PMSTAT** field descriptions | Field | Description | | | | | | |---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | 7 | This field is reserved. | | | | | | | Reserved | This read-only field is reserved and always has the value 0. | | | | | | | 6–0<br>PMSTAT | NOTE: When debug is enabled, the PMSTAT will not update to STOP or VLPS NOTE: When a PSTOP mode is enabled, the PMSTAT will not update to STOP or VLPS NOTE: Since the RUNM bits in the PMCTRL register are reset to VLPR on any Chip Reset not VLLS, the PMSTAT will update to VLPR shortly after the reset sequence is complete. | | | | | | | | 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. | | | | | | | | 001_0000 Current power mode is VLPS. | | | | | | | | 010_0000 Reserved | | | | | | | | 100_0000 Current power mode is VLLS. | | | | | | # 15.4 Functional description ## 15.4.1 Power mode transitions The following figure shows the power mode state transitions available on the chip. Any reset will initially bring the MCU back to the normal RUN state. However, in order to minimize peak power consumption, the RUNM bits in the PMCTRL register are reset to VLPR and the SMC will begin transitioning the MCU into VLPR mode during the reset recovery sequence. Figure 15-5. Power mode state diagram The following table defines triggers for the various state transitions shown in the previous figure. Table 15-7. Power mode transition triggers | Transition # | From | То | Trigger conditions | |--------------|------|------|-------------------------------------------------------------------------------------------------------------------------------------------| | 1 | RUN | WAIT | Sleep-now or sleep-on-exit modes entered with SLEEPDEEP clear, controlled in System Control Register in ARM core. See note. <sup>1</sup> | | | WAIT | RUN | Interrupt or Reset | ## runctional description # Table 15-7. Power mode transition triggers (continued) | Transition # | From | То | Trigger conditions | |--------------|-------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 2 | RUN | STOP | PMCTRL[RUNM]=00, PMCTRL[STOPM]=000 <sup>2</sup> | | | | | Sleep-now or sleep-on-exit modes entered with SLEEPDEEP set, which is controlled in System Control Register in ARM core. | | | | | See note. <sup>1</sup> | | | STOP | RUN | Interrupt or Reset | | 3 | RUN | VLPR | The core, system, bus and flash clock frequencies and MCG clocking mode are restricted in this mode. See the Power Management chapter for the maximum allowable frequencies and MCG modes supported. | | | | | Set PMPROT[AVLP]=1, PMCTRL[RUNM]=10. | | | | | NOTE: In order to limit peak current, PMPROT[AVLP] and PMCTRL[RUNM] bits are set on any Reset, causing the SMC to transition the MCU from RUN->VLPR during the reset recovery sequence. | | | VLPR | RUN | Set PMCTRL[RUNM]=00 or | | | | | Reset. | | 4 | VLPR | VLPW | Sleep-now or sleep-on-exit modes entered with SLEEPDEEP clear, which is controlled in System Control Register in ARM core. | | | | | See note. <sup>1</sup> | | | VLPW | VLPR | Interrupt | | 5 | VLPW | RUN | Reset | | 6 | VLPR | VLPS | PMCTRL[STOPM]=000 <sup>3</sup> or 010, | | | | | Sleep-now or sleep-on-exit modes entered with SLEEPDEEP set, which is controlled in System Control Register in ARM core. | | | | | See note. <sup>1</sup> | | | VLPS | VLPR | Interrupt | | | | | 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, | | | | | Sleep-now or sleep-on-exit modes entered with SLEEPDEEP set, which is controlled in System Control Register in ARM core. | | | | | See note. <sup>1</sup> | | | VLPS | RUN | Interrupt and VLPS mode was entered directly from RUN or | | | | | Reset | | 8 | RUN | VLLSx | PMPROT[AVLLS]=1, PMCTRL[STOPM]=100,<br>STOPCTRL[VLLSM]=x (VLLSx), Sleep-now or sleep-on-exit<br>modes entered with SLEEPDEEP set, which is controlled in<br>System Control Register in ARM core. | | | VLLSx | RUN | Wakeup from enabled input source or RESET pin | | | L | l . | I . | ## Table 15-7. Power mode transition triggers (continued) | Transition # | From | То | Trigger conditions | |--------------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 9 | VLPR | VLLSx | PMPROT[AVLLS]=1, PMCTRL[STOPM]=100,<br>STOPCTRL[VLLSM]=x (VLLSx), Sleep-now or sleep-on-exit<br>modes entered with SLEEPDEEP set, which is controlled in<br>System Control Register in ARM core. | - 1. If debug is enabled, the core clock remains to support debug. - 2. If PMCTRL[STOPM]=000 and STOPCTRL[PSTOPO]=01 or 10, then only a Partial Stop mode is entered instead of STOP - 3. If PMCTRL[STOPM]=000 and STOPCTRL[PSTOPO]=00, then VLPS mode is entered instead of STOP. If PMCTRL[STOPM]=000 and STOPCTRL[PSTOPO]=01 or 10, then only a Partial Stop mode is entered instead of VLPS runctional description # 15.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 into and exit from all power modes. This 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 15-6. Low-power system components and connections # 15.4.2.1 Stop mode entry sequence Entry into a low-power stop mode (Stop, VLPS, VLLSx) is initiated by CPU execution of the WFI instruction. After the 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. ## 15.4.2.2 Stop mode exit sequence Exit from a low-power stop mode is initiated either by 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. ## 15.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 possible only 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, SMC\_PMCTRL[STOPA] is set to 1. ## 15.4.2.4 Transition to wait modes For wait modes (WAIT and VLPW), the CPU clock is gated off while all other clocking continues, as in RUN and VLPR mode operation. Some modules that support stop-in-wait functionality have their clocks disabled in these configurations. runctional description # 15.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. As part of this transition, system clocking is re-established and is equivalent to the normal RUN and VLPR mode clocking configuration. ## **15.4.3 Run modes** The run modes supported by this device can be found here. - Run (RUN) - Very Low-Power Run (VLPR) ## 15.4.3.1 RUN mode This mode is selected after any reset. In order to reduce peak power consumption, however, the SMC will begin transitioning the MCU into VLPR mode during the reset recovery sequence. When the ARM processor exits reset, it sets up the stack, program counter (PC), and link register (LR): - 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 the clocks to unused modules using their corresponding clock gating control bits in the SIM's registers. # 15.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 their 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. - All clock monitors in the MCG must be disabled. - 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, that is, PMPROT[AVLP] is 1. - PMCTRL[RUNM] is set to 10b to enter VLPR. - Flash programming/erasing is not allowed. #### **NOTE** Do not change the clock frequency while in VLPR mode, because the regulator is slow responding and cannot manage fast load transitions. In addition, do not modify the clock source in the MCG module, the module clock enables in the SIM, or any clock divider registers. To reenter Normal Run mode, clear PMCTRL[RUNM]. PMSTAT 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 and the MCU can run at full speed in any clock mode. If a higher execution frequency is desired, poll PMSTAT until it is set to RUN when returning from VLPR mode. Any reset will temporarily cause the device to exit to RUN mode before returning to VLPR during the MCU reset flow. ## 15.4.4 Wait modes This device contains two different wait modes which are listed here. - Wait - Very-Low Power Wait (VLPW) #### 15.4.4.1 WAIT mode WAIT mode is entered when the ARM core enters the Sleep-Now or Sleep-On-Exit modes while SLEEDEEP is cleared. The ARM CPU enters a low-power state in which it is not clocked, but peripherals continue to be clocked provided they are enabled. Clock gating to the peripheral is enabled via the SIM module. 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, temporarily returning the device to RUN mode before transitioning into VLPR during the MCU reset flow. unctional description #### Very-Low-Power Wait (VLPW) mode 15.4.4.2 VLPW is entered by the entering the Sleep-Now or Sleep-On-Exit mode while SLEEPDEEP is cleared and the MCU is in VLPR mode. 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. 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 VLPW mode, temporarily returning the device to RUN mode before transitioning into VLPR during the MCU reset flow. #### 15.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, and 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, and how power usage and state retention versus functional needs and recovery time may be traded off. #### NOTE All clock monitors must be disabled before entering these lowpower modes: Stop, VLPS, VLPR, VLPW, and VLLSx. The various stop modes are selected by setting the appropriate fields in PMPROT and PMCTRL. The selected stop mode is entered during the sleep-now or sleep-on-exit entry with the SLEEPDEEP bit set in the System Control Register in the ARM core. The available stop modes are: 255 - Normal Stop (STOP) - Very-Low Power Stop (VLPS) - Very-Low-Leakage Stop (VLLSx) #### 15.4.5.1 STOP mode STOP mode is entered via the sleep-now or sleep-on-exit with the SLEEPDEEP bit set in the System Control Register in the ARM core. The MCG module can be configured to leave the reference clocks running. 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, temporarily returning the device to RUN mode before transitioning into VLPR during the MCU reset flow. ## 15.4.5.2 Very-Low-Power Stop (VLPS) mode The two ways in which VLPS mode can be entered are listed here. - Entry into stop via the sleep-now or sleep-on-exit with the SLEEPDEEP bit set in the System Control Register in the ARM core while the MCU is in VLPR mode and PMCTRL[STOPM] = 010 or 000. - Entry into stop via the sleep-now or sleep-on-exit with the SLEEPDEEP bit set in the System Control Register in the ARM core while the MCU is in normal RUN mode and PMCTRL[STOPM] = 010. 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. A system reset will cause an exit from VLPS mode, temporarily returning the device to RUN mode before transitioning into VLPR during the MCU reset flow. runctional description ## 15.4.5.3 Very-Low-Leakage Stop (VLLSx) modes This device contains these very low leakage modes: - VLLS3 - VLLS2 - VLLS1 - VLLS0 VLLSx is often used in this document to refer to all of these modes. All VLLSx modes can be entered from normal RUN or VLPR modes. The MCU enters the configured VLLS mode if: - In Sleep-Now or Sleep-On-Exit mode, the SLEEPDEEP bit is set in the System Control Register in the ARM core, and - The device is configured as shown in Table 15-7. In VLLS, the on-chip voltage regulator is in its stop-regulation state while most digital logic is powered off. When entering VLLS, each I/O pin is latched as configured before executing VLLS. Because all digital logic in the MCU is powered off, all port and peripheral data is lost during VLLS. This information must be restored before PMC\_REGSC[ACKISO] is set. An asserted RESET pin will cause an exit from any VLLS mode, temporarily returning the device to normal RUN mode before transitioning into VLPR during the MCU reset flow. When exiting VLLS via the RESET pin, RCM\_SRS0[PIN] and RCM\_SRS0[WAKEUP] are set. # 15.4.6 Debug in low power modes When the MCU is secure, the device disables/limits debugger operation. When the MCU is unsecure, the ARM debugger can assert two power-up request signals: - System power up, via SYSPWR in the Debug Port Control/Stat register - Debug power up, via CDBGPWRUPREQ in the Debug Port Control/Stat register When asserted while in RUN, WAIT, VLPR, or VLPW, the mode controller drives a corresponding acknowledge for each signal, that is, both CDBGPWRUPACK and CSYSPWRUPACK. When both requests are asserted, the mode controller handles attempts to enter STOP and VLPS by entering an emulated stop state. In this emulated stop state: • the regulator is in run regulation, - the MCG-generated clock source is enabled, - all system clocks, except the core clock, are disabled, - the debug module has access to core registers, and - access to the on-chip peripherals is blocked. No debug is available while the MCU is in VLLS modes. Entering into a VLLS mode causes all of the debug controls and settings to be powered off. To give time to the debugger to sync with the MCU, the MDM AP Control Register includes a Very-Low-Leakage Debug Request (VLLDBGREQ) bit that is set to configure the Reset Controller logic to hold the system in reset after the next recovery from a VLLS mode. This bit allows the debugger time to reinitialize the debug module before the debug session continues. The MDM AP Control Register also includes a Very Low Leakage Debug Acknowledge (VLLDBGACK) bit that is set to release the ARM core being held in reset following a VLLS recovery. The debugger reinitializes all debug IP, and then asserts the VLLDBGACK control bit to allow the RCM to release the ARM core from reset and allow CPU operation to begin. The VLLDBGACK bit is cleared by the debugger (or can be left set as is) or clears automatically due to the reset generated as part of the next VLLS recovery. runctional description # **Chapter 16 Inter-Peripheral Crossbar Switch (XBAR)** ## 16.1 Introduction #### **NOTE** For the chip-specific implementation details of this module's instances, see the chip configuration information. #### 16.1.1 Overview This module implements an array of M N-input combinational muxes. All muxes share the same N inputs in the same order, but each mux has its own independent select field. The intended application of this module is to provide a flexible crossbar switch function that allows any input (typically from external GPIO or internal module outputs) to be connected to any output (typically to external GPIO or internal module inputs) under user control. This is used to allow user configuration of data paths between internal modules and between internal modules and GPIO. A subset of the muxes can be configured to support edge detection and either interrupt or DMA request generation based on detected signal edges on the mux output. This allows signal transitions on the signals feeding the crossbar to trigger interrupts or initiate data transfers via DMA into or out of other system modules. # 16.1.2 Features The XBAR module design includes these distinctive features: - M identical N-input muxes with individual select fields. - Edge detection with associated interrupt or DMA request generation for a subset of mux outputs. #### muroduction - Memory mapped registers with IPBus interface for select and control fields. - Register write protection input signal. # 16.1.3 Modes of Operation The XBAR module design operates in only a single mode of operation: Functional Mode. The various counting modes are detailed in Functional Mode. # 16.1.4 Block Diagram The block diagram for XBAR is shown in Figure 16-1. Note: Control field support can be restricted to a subset of outputs. CTRLn represents the memory mapped control fields in the XBAR\_CTRL registers for each corresponding XBAR\_OUT output. Control fields provide edge status, edge selection, and interrupt/DMA generation controls. Figure 16-1. XBAR Block Diagram # 16.2 Signal Descriptions The following table summarizes the module's external signals. Table 16-1. Control Signal Properties | Name | I/O Type | Function | Reset State | Notes | |--------------------------|----------|-------------------------------------|-------------|-------| | XBAR_OUT<br>[0:NUMOUT-1] | 0 | Mux Outputs with configurable width | * | | | XBAR_IN [0:NUMIN-1] | I | Mux Inputs with configurable width | * | | | DMA_REQ | 0 | DMA request | 0 | | | INT_REQ | 0 | Interrupt request | 0 | | | DMA_ACK | I | DMA acknowledge | 0 | | At reset, each output XBAR\_OUT[\*] contains the reset value of the signal driving XBAR\_IN[0]. # 16.2.1 XBAR\_OUT[0:NUM\_OUT-1] - MUX Outputs This is a one-dimensional array of the mux outputs. The value on each output $XBAR\_OUT[n]$ is determined by the setting of the corresponding memory mapped register SELn such that $XBAR\_OUT[n] = XBAR\_IN[SELn]$ . # 16.2.2 XBAR\_IN[0:NUM\_IN-1] - MUX Inputs This is a one-dimensional array consisting of the inputs shared by each mux. All muxes share the same inputs in the same order. # 16.2.3 DMA\_REQ[n] - DMA Request Output(s) DMA\_REQ[n] is a DMA request to the DMA controller. # 16.2.4 DMA\_ACK[n] - DMA Acknowledge Input(s) DMA\_ACK[n] is a DMA acknowledge input from the DMA controller. KM Family Reference Manual, Rev. 5, Oct 2013 261 # 16.2.5 INT\_REQ[n] - Interrupt Request Output(s) INT\_REQ[n] is an interrupt request output to the interrupt controller. # 16.3 Memory Map and Register Descriptions The XBAR module has select registers and control registers. In the XBAR select registers, the SELn fields select which of the shared inputs (XBAR\_IN[\*]) is muxed to each mux output (XBAR\_OUT[\*]). There is one SELn field per mux and therefore one per XBAR\_OUT output. Crossbar output XBAR\_OUT[n] presents the value of XBAR\_IN[SELn]. Each select register contains two SELn fields. In the first select register, the LSBs contain the select field for mux 0, and the MSBs contain the select field for mux 1. The pattern repeats in subsequent select registers. The actual signals connected to XBAR\_IN and XBAR\_OUT are application specific and are described in the Chip Configuration details. The XBAR control register configures edge detection, interrupt, and DMA features for the XBAR\_OUT[0] output. #### **XBAR** memory map | Absolute<br>address<br>(hex) | Register name | Width<br>(in bits) | Access | Reset value | Section/<br>page | |------------------------------|------------------------------------------|--------------------|--------|-------------|------------------| | 4005_5000 | Crossbar Select Register 0 (XBAR_SEL0) | 16 | R/W | 0000h | 16.3.1/263 | | 4005_5002 | Crossbar Select Register 1 (XBAR_SEL1) | 16 | R/W | 0000h | 16.3.2/263 | | 4005_5004 | Crossbar Select Register 2 (XBAR_SEL2) | 16 | R/W | 0000h | 16.3.3/264 | | 4005_5006 | Crossbar Select Register 3 (XBAR_SEL3) | 16 | R/W | 0000h | 16.3.4/264 | | 4005_5008 | Crossbar Select Register 4 (XBAR_SEL4) | 16 | R/W | 0000h | 16.3.5/265 | | 4005_500A | Crossbar Select Register 5 (XBAR_SEL5) | 16 | R/W | 0000h | 16.3.6/265 | | 4005_500C | Crossbar Select Register 6 (XBAR_SEL6) | 16 | R/W | 0000h | 16.3.7/266 | | 4005_500E | Crossbar Select Register 7 (XBAR_SEL7) | 16 | R/W | 0000h | 16.3.8/266 | | 4005_5010 | Crossbar Select Register 8 (XBAR_SEL8) | 16 | R/W | 0000h | 16.3.9/267 | | 4005_5012 | Crossbar Select Register 9 (XBAR_SEL9) | 16 | R/W | 0000h | 16.3.10/267 | | 4005_5014 | Crossbar Select Register 10 (XBAR_SEL10) | 16 | R/W | 0000h | 16.3.11/268 | | 4005_5016 | Crossbar Select Register 11 (XBAR_SEL11) | 16 | R/W | 0000h | 16.3.12/268 | | 4005_5018 | Crossbar Select Register 12 (XBAR_SEL12) | 16 | R/W | 0000h | 16.3.13/269 | | 4005_501A | Crossbar Select Register 13 (XBAR_SEL13) | 16 | R/W | 0000h | 16.3.14/269 | Table continues on the next page... ## **XBAR** memory map (continued) | Absolute<br>address<br>(hex) | Register name | Width<br>(in bits) | Access | Reset value | Section/<br>page | |------------------------------|------------------------------------------|--------------------|--------|-------------|------------------| | 4005_501C | Crossbar Select Register 14 (XBAR_SEL14) | 16 | R/W | 0000h | 16.3.15/270 | | 4005_501E | Crossbar Select Register 15 (XBAR_SEL15) | 16 | R/W | 0000h | 16.3.16/270 | | 4005_5020 | Crossbar Select Register 16 (XBAR_SEL16) | 16 | R/W | 0000h | 16.3.17/271 | | 4005_5022 | Crossbar Control Register 0 (XBAR_CTRL0) | 16 | R/W | 0000h | 16.3.18/271 | # 16.3.1 Crossbar Select Register 0 (XBAR\_SEL0) Address: 4005\_5000h base + 0h offset = 4005\_5000h #### XBAR\_SEL0 field descriptions | Field | Description | |-------------------|-----------------------------------------------------------------------------------------------------------------| | 15–14<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 13–8<br>SEL1 | Input (XBAR_INn) to be muxed to XBAR_OUT1 (refer to Functional Description section for input/output assignment) | | 7–6<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 5–0<br>SEL0 | Input (XBAR_INn) to be muxed to XBAR_OUT0 (refer to Functional Description section for input/output assignment) | # 16.3.2 Crossbar Select Register 1 (XBAR\_SEL1) Address: 4005\_5000h base + 2h offset = 4005\_5002h ## XBAR\_SEL1 field descriptions | Field | Description | |-------------------|-----------------------------------------------------------------------------------------------------------------| | 15–14<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | | Input (XBAR_INn) to be muxed to XBAR_OUT3 (refer to Functional Description section for input/output assignment) | Table continues on the next page... #### wemory Map and Register Descriptions ## **XBAR\_SEL1** field descriptions (continued) | Field | Description | |-----------------|-----------------------------------------------------------------------------------------------------------------| | 7–6<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 5–0<br>SEL2 | Input (XBAR_INn) to be muxed to XBAR_OUT2 (refer to Functional Description section for input/output assignment) | # 16.3.3 Crossbar Select Register 2 (XBAR\_SEL2) Address: 4005\_5000h base + 4h offset = 4005\_5004h #### XBAR\_SEL2 field descriptions | Field | Description | |-------------------|-----------------------------------------------------------------------------------------------------------------| | 15–14<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 13–8<br>SEL5 | Input (XBAR_INn) to be muxed to XBAR_OUT5 (refer to Functional Description section for input/output assignment) | | 7–6<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 5–0<br>SEL4 | Input (XBAR_INn) to be muxed to XBAR_OUT4 (refer to Functional Description section for input/output assignment) | # 16.3.4 Crossbar Select Register 3 (XBAR\_SEL3) Address: 4005\_5000h base + 6h offset = 4005\_5006h ## XBAR\_SEL3 field descriptions | Field | Description | |-------------------|-----------------------------------------------------------------------------------------------------------------| | 15–14<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 13–8<br>SEL7 | Input (XBAR_INn) to be muxed to XBAR_OUT7 (refer to Functional Description section for input/output assignment) | | 7–6<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | Table continues on the next page... #### KM Family Reference Manual, Rev. 5, Oct 2013 264 **Preliminary** Freescale Semiconductor, Inc. ## XBAR\_SEL3 field descriptions (continued) | Field | Description | |-------|-----------------------------------------------------------------------------------------------------------------| | | Input (XBAR_INn) to be muxed to XBAR_OUT6 (refer to Functional Description section for input/output assignment) | # 16.3.5 Crossbar Select Register 4 (XBAR\_SEL4) Address: 4005\_5000h base + 8h offset = 4005\_5008h ## XBAR\_SEL4 field descriptions | Field | Description | |-------------------|-----------------------------------------------------------------------------------------------------------------| | 15–14<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 13–8<br>SEL9 | Input (XBAR_INn) to be muxed to XBAR_OUT9 (refer to Functional Description section for input/output assignment) | | 7–6<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 5–0<br>SEL8 | Input (XBAR_INn) to be muxed to XBAR_OUT8 (refer to Functional Description section for input/output assignment) | # 16.3.6 Crossbar Select Register 5 (XBAR\_SEL5) Address: 4005\_5000h base + Ah offset = 4005\_500Ah #### XBAR\_SEL5 field descriptions | Field | Description | |-------------------|------------------------------------------------------------------------------------------------------------------| | 15–14<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 13–8<br>SEL11 | Input (XBAR_INn) to be muxed to XBAR_OUT11 (refer to Functional Description section for input/output assignment) | | 7–6<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 5–0<br>SEL10 | Input (XBAR_INn) to be muxed to XBAR_OUT10 (refer to Functional Description section for input/output assignment) | # 16.3.7 Crossbar Select Register 6 (XBAR\_SEL6) Address: 4005\_5000h base + Ch offset = 4005\_500Ch #### XBAR\_SEL6 field descriptions | Field | Description | |-------------------|------------------------------------------------------------------------------------------------------------------| | 15–14<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 13–8<br>SEL13 | Input (XBAR_INn) to be muxed to XBAR_OUT13 (refer to Functional Description section for input/output assignment) | | 7–6<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 5–0<br>SEL12 | Input (XBAR_INn) to be muxed to XBAR_OUT12 (refer to Functional Description section for input/output assignment) | # 16.3.8 Crossbar Select Register 7 (XBAR\_SEL7) Address: 4005\_5000h base + Eh offset = 4005\_500Eh ## XBAR\_SEL7 field descriptions | Field | Description | |-------------------|------------------------------------------------------------------------------------------------------------------| | 15–14<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 13–8<br>SEL15 | Input (XBAR_INn) to be muxed to XBAR_OUT15 (refer to Functional Description section for input/output assignment) | | 7–6<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 5–0<br>SEL14 | Input (XBAR_INn) to be muxed to XBAR_OUT14 (refer to Functional Description section for input/output assignment) | # 16.3.9 Crossbar Select Register 8 (XBAR\_SEL8) Address: 4005\_5000h base + 10h offset = 4005\_5010h ## XBAR\_SEL8 field descriptions | Field | Description | |-------------------|------------------------------------------------------------------------------------------------------------------| | 15–14<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 13–8<br>SEL17 | Input (XBAR_INn) to be muxed to XBAR_OUT17 (refer to Functional Description section for input/output assignment) | | 7–6<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 5–0<br>SEL16 | Input (XBAR_INn) to be muxed to XBAR_OUT16 (refer to Functional Description section for input/output assignment) | # 16.3.10 Crossbar Select Register 9 (XBAR\_SEL9) Address: 4005\_5000h base + 12h offset = 4005\_5012h ## XBAR\_SEL9 field descriptions | Field | Description | |-------------------|------------------------------------------------------------------------------------------------------------------| | 15–14<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 13–8<br>SEL19 | Input (XBAR_INn) to be muxed to XBAR_OUT19 (refer to Functional Description section for input/output assignment) | | 7–6<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 5–0<br>SEL18 | Input (XBAR_INn) to be muxed to XBAR_OUT18 (refer to Functional Description section for input/output assignment) | # 16.3.11 Crossbar Select Register 10 (XBAR\_SEL10) Address: 4005\_5000h base + 14h offset = 4005\_5014h ## XBAR\_SEL10 field descriptions | Field | Description | |-------------------|------------------------------------------------------------------------------------------------------------------| | 15–13<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 12–8<br>SEL21 | Input (XBAR_INn) to be muxed to XBAR_OUT21 (refer to Functional Description section for input/output assignment) | | 7–5<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 4–0<br>SEL20 | Input (XBAR_INn) to be muxed to XBAR_OUT20 (refer to Functional Description section for input/output assignment) | # 16.3.12 Crossbar Select Register 11 (XBAR\_SEL11) Address: 4005\_5000h base + 16h offset = 4005\_5016h ## XBAR\_SEL11 field descriptions | Field | Description | |-------------------|------------------------------------------------------------------------------------------------------------------| | 15–14<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 13–8<br>SEL23 | Input (XBAR_INn) to be muxed to XBAR_OUT23 (refer to Functional Description section for input/output assignment) | | 7–6<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 5–0<br>SEL22 | Input (XBAR_INn) to be muxed to XBAR_OUT22 (refer to Functional Description section for input/output assignment) | 269 # 16.3.13 Crossbar Select Register 12 (XBAR\_SEL12) Address: 4005\_5000h base + 18h offset = 4005\_5018h #### XBAR\_SEL12 field descriptions | Field | Description | |-------------------|------------------------------------------------------------------------------------------------------------------| | 15–13<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 12–8<br>SEL25 | Input (XBAR_INn) to be muxed to XBAR_OUT25 (refer to Functional Description section for input/output assignment) | | 7–5<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 4–0<br>SEL24 | Input (XBAR_INn) to be muxed to XBAR_OUT24 (refer to Functional Description section for input/output assignment) | # 16.3.14 Crossbar Select Register 13 (XBAR\_SEL13) Address: 4005\_5000h base + 1Ah offset = 4005\_501Ah ## XBAR\_SEL13 field descriptions | Field | Description | |-------------------|------------------------------------------------------------------------------------------------------------------| | 15–14<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 13–8<br>SEL27 | Input (XBAR_INn) to be muxed to XBAR_OUT27 (refer to Functional Description section for input/output assignment) | | 7–6<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 5–0<br>SEL26 | Input (XBAR_INn) to be muxed to XBAR_OUT26 (refer to Functional Description section for input/output assignment) | # 16.3.15 Crossbar Select Register 14 (XBAR\_SEL14) Address: 4005\_5000h base + 1Ch offset = 4005\_501Ch ## XBAR\_SEL14 field descriptions | Field | Description | |-------------------|------------------------------------------------------------------------------------------------------------------| | 15–14<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 13–8<br>SEL29 | Input (XBAR_INn) to be muxed to XBAR_OUT29 (refer to Functional Description section for input/output assignment) | | 7–6<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 5–0<br>SEL28 | Input (XBAR_INn) to be muxed to XBAR_OUT28 (refer to Functional Description section for input/output assignment) | # 16.3.16 Crossbar Select Register 15 (XBAR\_SEL15) Address: 4005\_5000h base + 1Eh offset = 4005\_501Eh ## XBAR\_SEL15 field descriptions | Field | Description | |-------------------|------------------------------------------------------------------------------------------------------------------| | 15–13<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 12–8<br>SEL31 | Input (XBAR_INn) to be muxed to XBAR_OUT31 (refer to Functional Description section for input/output assignment) | | 7–5<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 4–0<br>SEL30 | Input (XBAR_INn) to be muxed to XBAR_OUT30 (refer to Functional Description section for input/output assignment) | # 16.3.17 Crossbar Select Register 16 (XBAR\_SEL16) Address: 4005\_5000h base + 20h offset = 4005\_5020h #### XBAR\_SEL16 field descriptions | Field | Description | |-------------------|------------------------------------------------------------------------------------------------------------------| | 15–14<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 13–8<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 7–6<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 5–0<br>SEL32 | Input (XBAR_INn) to be muxed to XBAR_OUT32 (refer to Functional Description section for input/output assignment) | # 16.3.18 Crossbar Control Register 0 (XBAR\_CTRL0) Use this register to configure edge detection, interrupt, and DMA features for the XBAR\_OUT0 output. Address: 4005\_5000h base + 22h offset = 4005\_5022h #### XBAR\_CTRL0 field descriptions | Field | Description | |----------|--------------------------------------------------------------| | 15–5 | This field is reserved. | | Reserved | This read-only field is reserved and always has the value 0. | Table continues on the next page... #### runctional Description # XBAR\_CTRL0 field descriptions (continued) | Field | Description | |-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 4 | Edge detection status for XBAR_OUT0 | | STS0 | This bit reflects the results of edge detection for XBAR_OUT0. | | | This field is set to 1 when an edge consistent with the current setting of EDGE0 is detected on XBAR_OUT0. This field is cleared by writing 1 to it or by a DMA_ACK0 reception when DEN0 is set. Writing 0 to the field has no effect. | | | When interrupt or DMA functionality is enabled for XBAR_OUT0, this field is 1 when the interrupt or DMA request is asserted and 0 when the interrupt or DMA request has been cleared. | | | 0 Active edge not yet detected on XBAR_OUT0 | | | 1 Active edge detected on XBAR_OUT0 | | 3–2 | Active edge for edge detection on XBAR_OUT0 | | EDGE0 | This field selects which edges on XBAR_OUT0 cause STS0 to assert. | | | 00 STS0 never asserts | | | 01 STS0 asserts on rising edges of XBAR_OUT0 | | | 10 STS0 asserts on falling edges of XBAR_OUT0 | | | 11 STS0 asserts on rising and falling edges of XBAR_OUT0 | | 1 | Interrupt Enable for XBAR_OUT0 | | IEN0 | This bit enables the interrupt function on the corresponding XBAR_OUT0 output. When the interrupt is enabled, the output INT_REQ0 reflects the value STS0. When the interrupt is disabled, INT_REQ0 remains low. The interrupt request is cleared by writing a 1 to STS0. | | | Restriction: IEN0 and DEN0 should not both be set to 1. | | | 0 Interrupt disabled | | | 1 Interrupt enabled | | 0 | DMA Enable for XBAR_OUT0 | | DEN0 | This bit enables the DMA function on the corresponding XBAR_OUT0 output. When enabled, DMA_REQ presents the value STS0. When disabled, the DMA_REQ0 output remains low. | | | Restriction: IEN0 and DEN0 should not both be set to 1. | | | 0 DMA disabled | | | 1 DMA enabled | # 16.4 Functional Description # **16.4.1 General** The XBAR module has only one mode of operation, functional mode. #### 16.4.2 Functional Mode The value of each mux output is XBAR\_OUT[n] = XBAR\_IN[SELn]. The SELn select values are configured in the XBAR\_SEL registers. All muxes share the same inputs in the same order. A subset of XBAR\_OUT[\*] outputs has dedicated control fields in a Crossbar Control (XBAR\_CTRL) register. Control fields provide the ability to perform edge detection on the corresponding XBAR\_OUT output. Edge detection in turn can optionally be used to trigger an interrupt or DMA request. The intention is that, by detecting specified edges on signals propagating through the Crossbar, interrupts or DMA requests can be triggered to perform data transfers to or from other system components. Control fields include an edge status field (STS), an detected edge type field (EDGE), and interrupt and DMA enable fields (DEN and IEN). STSn is set to 1 when an edge consistent with EDGEn occurs on XBAR\_OUT[n]. STSn is cleared by writing 1 to it. Writing 0 as no effect. See Interrupts and DMA Requests for details on the use of STSn for DMA and interrupt request generation. ## 16.5 Resets The XBAR module can be reset by only a hard reset, which forces all registers to their reset state. # 16.6 Clocks All sequential functionality is controlled by the Bus Clock. # 16.7 Interrupts and DMA Requests For each XBAR\_OUT[\*] output with XBAR\_CTRL register support, DMA or interrupt functionality can be enabled by setting the corresponding XBAR\_CTRL register bit DENn or IENn to 1. DENn and IENn should not be set to 1 at the same time for the same output XBAR\_OUT[n]. #### **interrupts and DMA Requests** Setting DENn to 1 enables DMA functionality for XBAR\_OUT[n]. When DMA functionality is enabled, the output DMA\_REQ[n] reflects the value of STSn. Thus the DMA request asserts when the edge specified by EDGEn is detected on XBAR\_OUT[n]. Also, a rising edge on DMA\_ACK[n] sets STSn to zero and thus clears the DMA request. When DEN is 0, DMA\_REQ[n] is held low and DMA\_ACK[n] is ignored. Setting IENn to 1 enables interrupt functionality for XBAR\_OUT[n]. When interrupt functionality is enabled, the output INT\_REQ[n] reflects the value of STSn. Thus the interrupt request asserts when the edge specified by EDGEDENn is detected on XBAR\_OUT[n]. The interrupt request is cleared by writing a 1 to STSn. When IENn is 0, INT\_REQ[n] is held low. DENn and IENn should not be set to 1 at the same time for the same output XBAR\_OUT[n]. # **Chapter 17 Low-Leakage Wakeup Unit (LLWU)** ## 17.1 Introduction #### **NOTE** For the chip-specific implementation details of this module's instances, see the chip configuration information. The LLWU module allows the user to select up to 16 external pin sources and up to 8 internal modules as a wake-up source from low-leakage power modes. The input sources are described in the device's chip configuration details. Each of the available wake-up sources can be individually enabled. The LLWU module also includes two optional digital pin filters for the external wakeup pins. See AN4503: Power Management for Kinetis and ColdFire+ MCUs for further details on using the LLWU. ## 17.1.1 Features The LLWU module features include: - Support for 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 VLLS. See the chip configuration information for wakeup input sources for this device. - External pin wake-up inputs, each of which is programmable as falling-edge, rising-edge, or any change KM Family Reference Manual, Rev. 5, Oct 2013 275 #### ınıroduction - Wake-up inputs that are activated if enabled after MCU enters a low-leakage power mode - Optional digital filters provided to qualify an external pin detect. Note that when the LPO clock is disabled, the filters are disabled and bypassed. # 17.1.2 Modes of operation The LLWU module becomes functional on entry into a low-leakage power mode. After recovery from VLLS, the LLWU continues to detect wake-up events until the user has acknowledged the wake-up via a write to PMC\_REGSC[ACKISO]. #### 17.1.2.1 VLLS modes All wakeup events result in VLLS exit via a reset flow. ## 17.1.2.2 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 wake-up pin filters are enabled, filter operation begins immediately. If a low leakage mode is entered within five LPO clock cycles of an active edge, the edge event will be detected by the LLWU. # 17.1.2.3 Debug mode When the chip is in Debug mode and then enters a VLLSx mode, no debug logic works in the fully-functional low-leakage mode. Upon an exit from the VLLSx mode, the LLWU becomes inactive. # 17.1.3 Block diagram The following figure is the block diagram for the LLWU module. #### Chapter 17 Low-Leakage Wakeup Unit (LLWU) Figure 17-1. LLWU block diagram # 17.2 LLWU signal descriptions The signal properties of LLWU are shown in the table found here. The external wakeup input pins can be enabled to detect either rising-edge, falling-edge, or on any change. Table 17-1. LLWU signal descriptions | Signal | Description | I/O | |---------|--------------------------|-----| | LLWU_Pn | Wakeup inputs (n = 0-15) | I | # 17.3 Memory map/register definition The LLWU includes the following registers: - Wake-up source enable registers - Enable external pin input sources - Enable internal peripheral sources - Wake-up flag registers - Indication of wakeup source that caused exit from a low-leakage power mode includes external pin or internal module interrupt - Wake-up pin filter enable registers #### **NOTE** The LLWU registers can be written only in supervisor mode. Write accesses in user mode are blocked and will result in a bus error. 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 Introduction details. #### **LLWU** memory map | Absolute<br>address<br>(hex) | Register name | Width<br>(in bits) | Access | Reset value | Section/<br>page | |------------------------------|-----------------------------------------|--------------------|--------|-------------|------------------| | 4007_C000 | LLWU Pin Enable 1 register (LLWU_PE1) | 8 | R/W | 00h | 17.3.1/279 | | 4007_C001 | LLWU Pin Enable 2 register (LLWU_PE2) | 8 | R/W | 00h | 17.3.2/280 | | 4007_C002 | LLWU Pin Enable 3 register (LLWU_PE3) | 8 | R/W | 00h | 17.3.3/281 | | 4007_C003 | LLWU Pin Enable 4 register (LLWU_PE4) | 8 | R/W | 00h | 17.3.4/282 | | 4007_C004 | LLWU Module Enable register (LLWU_ME) | 8 | R/W | 00h | 17.3.5/283 | | 4007_C005 | LLWU Flag 1 register (LLWU_F1) | 8 | R/W | 00h | 17.3.6/285 | | 4007_C006 | LLWU Flag 2 register (LLWU_F2) | 8 | R/W | 00h | 17.3.7/286 | | 4007_C007 | LLWU Flag 3 register (LLWU_F3) | 8 | R | 00h | 17.3.8/288 | | 4007_C008 | LLWU Pin Filter 1 register (LLWU_FILT1) | 8 | R/W | 00h | 17.3.9/290 | | 4007_C009 | LLWU Pin Filter 2 register (LLWU_FILT2) | 8 | R/W | 00h | 17.3.10/291 | # 17.3.1 LLWU Pin Enable 1 register (LLWU\_PE1) LLWU\_PE1 contains the 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 Introduction details for more information. Address: 4007\_C000h base + 0h offset = 4007\_C000h ## LLWU\_PE1 field descriptions | Description | | | | | | |---------------------------------------------------------------|--|--|--|--|--| | Wakeup Pin Enable For LLWU_P3 | | | | | | | 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 | | | | | | | 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 | | | | | | | Wakeup Pin Enable For LLWU_P1 | | | | | | | 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 | | | | | | | Wakeup Pin Enable For LLWU_P0 | | | | | | | 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... #### wemory map/register definition ## LLWU\_PE1 field descriptions (continued) | Field | Description | | | | | | |-------|-------------|--------------------------------------------------------|--|--|--|--| | | 10 | External input pin enabled with falling edge detection | | | | | | | 11 | External input pin enabled with any change detection | | | | | # 17.3.2 LLWU Pin Enable 2 register (LLWU\_PE2) LLWU\_PE2 contains the 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 Introduction details for more information. Address: 4007\_C000h base + 1h offset = 4007\_C001h | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|-------|---|----------|---|-------|---|-------|---| | Read<br>Write | WUPE7 | | E7 WUPE6 | | WUPE5 | | WUPE4 | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | #### 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 | | | | | | | 3–2<br>WUPE5 | Wakeup Pin Enable For LLWU_P5 | | | | | | | VVOI LO | 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\_PE2 field descriptions (continued) | Field | Description | | | | | | |--------------|---------------------------------------------------------------|--|--|--|--|--| | | 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 | | | | | | | | 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 | | | | | | # 17.3.3 LLWU Pin Enable 3 register (LLWU\_PE3) LLWU\_PE3 contains the 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 Introduction details for more information. Address: 4007\_C000h base + 2h offset = 4007\_C002h #### 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 | | | 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 | Table continues on the next page... #### wemory map/register definition ## 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 | | | | | | | 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 | Wakeup Pin Enable For LLWU_P8 | | | | | | | WUPE8 | 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 | | | | | | # 17.3.4 LLWU Pin Enable 4 register (LLWU\_PE4) LLWU\_PE4 contains the 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 Introduction details for more information. Address: 4007\_C000h base + 3h offset = 4007\_C003h #### 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 | Table continues on the next page... 283 ## LLWU\_PE4 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>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 | | | | | | | WOI LIS | 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 | | | | | | | WOILIZ | 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 | | | | | | # 17.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 Introduction details for more information. Address: 4007\_C000h base + 4h offset = 4007\_C004h | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|-------|-------|-------|-------|-------|-------|-------|-------| | Read<br>Write | WUME7 | WUME6 | WUME5 | WUME4 | WUME3 | WUME2 | WUME1 | WUME0 | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | #### wemory map/register definition # **LLWU\_ME** field descriptions | Field | Description | |------------|------------------------------------------------------| | 7 | Wakeup Module Enable For Module 7 | | WUME7 | Enables an internal module as a wakeup source input. | | | 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 | | VVOIVILO | 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 | Wakeup Module Enable For Module 5 | | WUME5 | 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 | Wakeup Module Enable For Module 3 | | WUME3 | 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 | Wakeup Module Enable For Module 2 | | WUME2 | 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 | | WOME | 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 | | 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 | # 17.3.6 LLWU Flag 1 register (LLWU\_F1) LLWU\_F1 contains the wakeup flags indicating which wakeup source caused the MCU to exit VLLS mode. For VLLS, this is 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 1 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 Introduction details for more information. Address: 4007\_C000h base + 5h offset = 4007\_C005h | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|------|------|------|------|------|------|------|------| | Read | WUF7 | WUF6 | WUF5 | WUF4 | WUF3 | WUF2 | WUF1 | WUF0 | | Write | w1c | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | #### 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 1 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 | | | Indicates that an enabled external wakeup pin was a source of exiting a low-leakage power mode. To clear the flag, write a 1 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 1 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 | Table continues on the next page... #### wemory map/register definition #### LLWU\_F1 field descriptions (continued) | Field | Description | |-----------|----------------------------------------------------------------------------------------------------------------------------------------| | | Indicates that an enabled external wake-up pin was a source of exiting a low-leakage power mode. To clear the flag, write a 1 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 1 to WUF3. | | | 0 LLWU_P3 input was not a wake-up source | | | 1 LLWU_P3 input was a wake-up 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 1 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 1 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 wake-up pin was a source of exiting a low-leakage power mode. To clear the flag, write a 1 to WUF0. | | | 0 LLWU_P0 input was not a wakeup source | | | 1 LLWU_P0 input was a wakeup source | # 17.3.7 LLWU Flag 2 register (LLWU\_F2) LLWU\_F2 contains the wakeup flags indicating which wakeup source caused the MCU to exit or VLLS mode. For VLLS, this is 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 1 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 Introduction details for more information. Address: 4007\_C000h base + 6h offset = 4007\_C006h | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|-------|-------|-------|-------|-------|-------|------|------| | Read | WUF15 | WUF14 | WUF13 | WUF12 | WUF11 | WUF10 | WUF9 | WUF8 | | Write | w1c | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ## **LLWU\_F2** field descriptions | Field | Description | |-----------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------| | 7<br>WUF15 | Wakeup Flag For LLWU_P15 | | WOI 13 | Indicates that an enabled external wakeup pin was a source of exiting a low-leakage power mode. To clear the flag, write a 1 to WUF15. | | | LLWU_P15 input was not a wakeup source LLWU_P15 input was a wakeup source | | 6 | Wakeup Flag For LLWU_P14 | | WUF14 | Wakeup Flag For LLWO_F14 | | | Indicates that an enabled external wakeup pin was a source of exiting a low-leakage power mode. To clear the flag, write a 1 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 | | 7761 16 | Indicates that an enabled external wakeup pin was a source of exiting a low-leakage power mode. To clear the flag, write a 1 to WUF13. | | | 0 LLWU_P13 input was not a wakeup source | | | 1 LLWU_P13 input was a wakeup source | | 4 | Wakeup Flag For LLWU_P12 | | WUF12 | Indicates that an enabled external wakeup pin was a source of exiting a low-leakage power mode. To clear the flag, write a 1 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 1 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 1 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 | Table continues on the next page... #### wemory map/register definition #### LLWU\_F2 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 1 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 1 to WUF8. | | | | | | | 0 LLWU_P8 input was not a wakeup source | | | | | | | 1 LLWU_P8 input was a wakeup source | | | | | # 17.3.8 LLWU Flag 3 register (LLWU\_F3) LLWU\_F3 contains the wakeup flags indicating which internal wakeup source caused the MCU to exit VLLS mode. For VLLS, this is the source causing the MCU reset flow. For internal peripherals that are capable of running in a low-leakage power mode, such as a real time clock module or CMP module, the flag from the associated peripheral is accessible as the MWUFx bit. The flag will need to be cleared in the peripheral instead of writing a 1 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 Introduction details for more information. Address: 4007\_C000h base + 7h offset = 4007\_C007h #### LLWU\_F3 field descriptions | Field | Description | |-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | Wakeup flag For module 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. | Table continues on the next page... # LLWU\_F3 field descriptions (continued) | Field | Description | | | |------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | | 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 | | | | WWW. | 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 | | | | 2 | Wakeup flag For module 2 | | | | MWUF2 | 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 | | | ## 17.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 Introduction details for more information. Address: 4007\_C000h base + 8h offset = 4007\_C008h ## LLWU\_FILT1 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 1 was not a wakeup source | | | 1 Pin Filter 1 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 | This field is reserved. | | Reserved | This read-only field is reserved and always has the value 0. | | 3–0<br>FILTSEL | Filter Pin Select | | FILISEL | 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 | ## 17.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 Introduction details for more information. Address: 4007\_C000h base + 9h offset = 4007\_C009h ## 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. | | | <ul><li>0 Pin Filter 2 was not a wakeup source</li><li>1 Pin Filter 2 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 field is reserved. This read-only field is reserved and always has the value 0. | | 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 | KM Family Reference Manual, Rev. 5, Oct 2013 # 17.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 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-edge - Rising-edge - 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. A detected external pin 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 for selected external pins. 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. ## 17.4.1 **VLLS** modes In the case of a wakeup due to external pin or internal module wakeup, recovery is always via a reset flow and RCM\_SRS[WAKEUP] is set indicating the low-leakage mode was active. State retention data is lost and I/O will be restored after PMC\_REGSC[ACKISO] has been written. ## 17.4.2 Initialization For an enabled peripheral wakeup input, the peripheral flag must be cleared by software before entering VLLSx mode to avoid an immediate exit from the mode. Flags associated with external input pins, filtered and unfiltered, must also be cleared by software prior to entry to VLLSx mode. After enabling an external pin filter or changing the source pin, wait at least five LPO clock cycles before entering VLLSx mode to allow the filter to initialize. ### **NOTE** After recovering from a VLLS mode, user must restore chip configuration before clearing PMC\_REGSC[ACKISO]. In particular, pin configuration for enabled LLWU wake-up pins must be restored to avoid any LLWU flag from being falsely set when PMC\_REGSC[ACKISO] is cleared. The signal selected as a wake-up source pin must be a digital pin, as selected in the pin mux control. runctional description # Chapter 18 DMA Controller Module ## 18.1 Introduction #### **NOTE** For the chip-specific implementation details of this module's instances, see the chip configuration information. Information found here 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. An example of using several features of the DMA module is described in AN4631: Using the Asynchronous DMA features of the Kinetis L Series. #### **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. ## 18.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 8-bit, 16-bit, or 32-bit data transfers. Each channel has a dedicated Source Address register (SAR*n*), Destination Address register (DAR*n*), Status register (DSR*n*), Byte Count register (BCR*n*), and Control register (DCR*n*). Collectively, the combined program-visible registers associated with each channel define a transfer control descriptor (TCD). All transfers are dual address, moving KM Family Reference Manual, Rev. 5, Oct 2013 #### muroduction 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. Figure 18-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. ## 18.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 - 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 - Programmable support for channel access control and attribute generation ## 18.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. As soon as a 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]. 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. #### wemory Map/Register Definition • 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 18-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). # 18.3 Memory Map/Register Definition Information about the registers related to the DMA controller module can be found here. 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 create 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 | Width (in bits) | Access | Reset value | Section/<br>page | |------------------------------|----------------------------------------------------------|-----------------|--------|-------------|------------------| | 4000_8100 | Source Address Register (DMA_SAR0) | 32 | R/W | 0000_0000h | 18.3.1/300 | | 4000_8104 | Destination Address Register (DMA_DAR0) | 32 | R/W | 0000_0000h | 18.3.2/301 | | 4000_8108 | DMA Status Register / Byte Count Register (DMA_DSR_BCR0) | 32 | R/W | 0000_0000h | 18.3.3/301 | | 4000_810C | DMA Control Register (DMA_DCR0) | 32 | R/W | 0000_0000h | 18.3.4/304 | | 4000_8110 | Source Address Register (DMA_SAR1) | 32 | R/W | 0000_0000h | 18.3.1/300 | | 4000_8114 | Destination Address Register (DMA_DAR1) | 32 | R/W | 0000_0000h | 18.3.2/301 | | 4000_8118 | DMA Status Register / Byte Count Register (DMA_DSR_BCR1) | 32 | R/W | 0000_0000h | 18.3.3/301 | | 4000_811C | DMA Control Register (DMA_DCR1) | 32 | R/W | 0000_0000h | 18.3.4/304 | | 4000_8120 | Source Address Register (DMA_SAR2) | 32 | R/W | 0000_0000h | 18.3.1/300 | | 4000_8124 | Destination Address Register (DMA_DAR2) | 32 | R/W | 0000_0000h | 18.3.2/301 | | 4000_8128 | DMA Status Register / Byte Count Register (DMA_DSR_BCR2) | 32 | R/W | 0000_0000h | 18.3.3/301 | | 4000_812C | DMA Control Register (DMA_DCR2) | 32 | R/W | 0000_0000h | 18.3.4/304 | | 4000_8130 | Source Address Register (DMA_SAR3) | 32 | R/W | 0000_0000h | 18.3.1/300 | | 4000_8134 | Destination Address Register (DMA_DAR3) | 32 | R/W | 0000_0000h | 18.3.2/301 | | 4000_8138 | DMA Status Register / Byte Count Register (DMA_DSR_BCR3) | 32 | R/W | 0000_0000h | 18.3.3/301 | | 4000_813C | DMA Control Register (DMA_DCR3) | 32 | R/W | 0000_0000h | 18.3.4/304 | ## 18.3.1 Source Address Register (DMA\_SARn) #### Restriction For this register: - Only 32-bit writes are allowed. 16-bit and 8-bit writes result in a bus error. - Only four values are allowed to be written to bits 31-20 of this register. A write of any other value to these bits causes a configuration error when the channel starts to execute. For more information about the configuration error, see the description of the CE field of DSR. Address: $4000_8000h$ base + 100h offset + $(16d \times i)$ , where i=0d to 3d ## DMA\_SARn field descriptions | Field | Description | | | |-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | 31–0<br>SAR | 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. | | | | | Restriction: Bits 31-20 of this register must be written with one of only four allowed values. Each of these four allowed values corresponds to a valid region of the device's memory map. The allowed values are: • 0x000x_xxxx • 0x1FFx_xxxx • 0x200x_xxxx • 0x400x_xxxx | | | | | After being written with one of the allowed values, bits 31-20 read back as the written value. After being written with any other value, bits 31-20 read back as an indeterminate value. | | | ## 18.3.2 Destination Address Register (DMA\_DARn) #### Restriction For this register: - Only 32-bit writes are allowed. 16-bit and 8-bit writes result in a bus error. - Only four values are allowed to be written to bits 31-20 of this register. A write of any other value to these bits causes a configuration error when the channel starts to execute. For more information about the configuration error, see the description of the CE field of DSR. Address: $4000_8000h$ base + 104h offset + $(16d \times i)$ , where i=0d to 3d ## 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. | | | | | Restriction: Bits 31-20 of this register must be written with one of only four allowed values. Each of these four allowed values corresponds to a valid region of the device's memory map. The allowed values are: • 0x000x_xxxx • 0x1FFx_xxxx • 0x200x_xxxx • 0x400x_xxxx | | | | | After being written with one of the allowed values, bits 31-20 read back as the written value. After being written with any other value, bits 31-20 read back as an indeterminate value. | | | ## 18.3.3 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 8-bit, 16-bit, or 32-bit accesses, respectively. BCRn is cleared if a 1 is written to DSR[DONE]. KM Family Reference Manual, Rev. 5, Oct 2013 #### wemory Map/Register Definition 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 32-bit or 16-bit transfers, respectively, DSRn[CE] is set and no transfer occurs. ## DMA\_DSR\_BCRn field descriptions | Field | Description | |----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 30<br>CE | Configuration Error | | | <ul> <li>Any of the following conditions causes a configuration error:</li> <li>BCR, SAR, or DAR does not match the requested transfer size.</li> <li>A value greater than 0F_FFFFh is written to BCR.</li> <li>Bits 31-20 of SAR or DAR are written with a value other than one of the allowed values. See SAR and DAR.</li> </ul> | | | <ul> <li>SSIZE or DSIZE is set to an unsupported value.</li> <li>BCR equals 0 when the DMA receives a start condition.</li> </ul> CE is cleared at hardware reset or by writing a 1 to DONE. | | | <ul><li>0 No configuration error exists.</li><li>1 A configuration error has occurred.</li></ul> | Table continues on the next page... #### KM Family Reference Manual, Rev. 5, Oct 2013 302 Preliminary Freescale Semiconductor, Inc. # DMA\_DSR\_BCRn field descriptions (continued) | Field | Description | |----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 29<br>BES | Bus Error on Source | | | BES is cleared at hardware reset or by writing a 1 to DONE. | | | <ul> <li>No bus error occurred.</li> <li>The DMA channel terminated with a bus error during the read portion of a transfer.</li> </ul> | | 28 | Bus Error on Destination | | BED | BED is cleared at hardware reset or by writing a 1 to DONE. | | | 0 No bus error occurred. | | | 1 The DMA channel terminated with a bus error during the write portion of a transfer. | | 27<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 26<br>REQ | Request | | REQ | <ul> <li>No request is pending or the channel is currently active. Cleared when the channel is selected.</li> <li>The DMA channel has a transfer remaining and the channel is not selected.</li> </ul> | | 25<br>BSY | Busy | | 201 | 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 | | 33.1.2 | Set when all DMA controller transactions complete as determined by transfer count, or based on error conditions. When BCR reaches 0, 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. | | BUN | Restriction: BCR must be written with a value equal to or less than 0F_FFFFh. After being written with a value in this range, bits 23-20 of BCR read back as 0000b. A write to BCR of a value greater than 0F_FFFFh causes a configuration error when the channel starts to execute. After being written with a value in this range, bits 23-20 of BCR read back as 0001b. | # 18.3.4 DMA Control Register (DMA\_DCRn) Address: $4000_8000h$ base + 10Ch offset + $(16d \times i)$ , where i=0d to 3d ## DMA\_DCRn field descriptions | Field | Description | |-----------|--------------------------------------------------------------------------------------------------------------------| | 31 | Enable Interrupt on Completion of Transfer | | EINT | Determines whether an interrupt is generated by completing a transfer or by the occurrence of an error condition. | | | 0 No interrupt is generated. | | | 1 Interrupt signal is enabled. | | 30<br>ERQ | Enable Peripheral Request | | | CAUTION: Be careful: a collision can occur between START and D_REQ when ERQ is 1. | | | 0 Peripheral request is ignored. | | | 1 Enables peripheral request to initiate transfer. A software-initiated request (setting START) is always enabled. | | 29<br>CS | Cycle Steal | | | 0 DMA continuously makes read/write transfers until the BCR decrements to 0. | | | 1 Forces a single read/write transfer per request. | | 28 | Auto-align Auto-align | | AA | | # DMA\_DCRn field descriptions (continued) | Field | Description | | | | | |----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------|--| | | AA and SIZE bits determine whether the source or destination is auto-aligned; that is, transfers are optimized based on the address and size. | | | | | | | 0 Auto-align disabled | | | | | | | If SSIZE indicates a tra<br>destination accesses a | IZE indicates a transfer no smaller than DSIZE, source accesses are auto-aligned; otherw nation accesses are auto-aligned. Source alignment takes precedence over destination ment. If auto-alignment is enabled, the appropriate address register increments, regardles | | | | | 27–26 | Channel Access Control | | | | | | CHACR | This 2-bit field defines the access control mode needed to reference the channel's transfer channel descriptor (TCDn). When a read or write access occurs to any fields in the TCDn, if the system mode has sufficient privileges as defined by CHACR, the access completes. Otherwise, the access aborts and terminates in an error. | | | | | | | <b>Restriction:</b> The CHACR field can be changed only during operation in privileged secure mode. In any other mode, attempted changes to this field are not performed, and the access terminates with an error. | | | | | | | CHACR field | s the access of each mode | allowed to each process | | | | | OHAON HEIG | Privileged, Secure | User, Secure | User, Nonsecure | | | | 00 | Read + Write | Read + Write | Read + Write | | | | 01 | Read + Write | Read + Write | — (none) | | | | 1x | Read + Write | — (none) | — (none) | | | | | | | | | | 25–24<br>UMNSM | User Mode, Nonsecure Mode This 2-bit field defines the privileged/user and secure/nonsecure attributes for the DMA channel as it executes. The contents of the write data operand selects how the value is to be loaded into this field. When a given channel is activated and executes, the DMA generates the appropriate privileged/user and | | | | | | | executes. The contents of When a given channel is a | ctivated and executes, the | DMA generates the appro | priate privileged/user a | | | | executes. The contents of When a given channel is a secure/nonsecure attribute. The following table defines the resulting "next state" o | ectivated and executes, the es for all source reads and source the association between the funds. | DMA generates the approdestination writes using Ul | ppriate privileged/user a<br>MNSM.<br>e initial system mode, ar | | | | executes. The contents of When a given channel is a secure/nonsecure attribute. The following table defines | activated and executes, the es for all source reads and is the association between the function of the control | DMA generates the approdestination writes using UI he write data operand, the | opriate privileged/user a<br>MNSM.<br>e initial system mode, ar<br>UMNSM write | | | | executes. The contents of When a given channel is a secure/nonsecure attribute The following table defines the resulting "next state" o Write to UMNSM field | ectivated and executes, the es for all source reads and es the association between the fumnsm. Initial proce Privileged, Secure | DMA generates the approdestination writes using UI he write data operand, the ssor mode and result of User, Secure | ppriate privileged/user a MNSM. e initial system mode, ar UMNSM write User, Nonsecure | | | | executes. The contents of When a given channel is a secure/nonsecure attribute The following table defines the resulting "next state" o Write to UMNSM field 00 | ctivated and executes, the es for all source reads and the association between the full three th | DMA generates the approduction writes using UI he write data operand, the ssor mode and result of User, Secure 10 = {User, Secure} | opriate privileged/user a MNSM. e initial system mode, ar UMNSM write User, Nonsecure 11 = {User, Nonsecure | | | | executes. The contents of When a given channel is a secure/nonsecure attribute The following table defines the resulting "next state" o Write to UMNSM field | ctivated and executes, the es for all source reads and is the association between the fumnsm. Initial proce Privileged, Secure 00 = {Privileged, Secure} 00 = {Privileged, Secure} | DMA generates the approdestination writes using Uline write data operand, the ssor mode and result of User, Secure 10 = {User, Secure} No change; error terminated | ppriate privileged/user a MNSM. e initial system mode, ar UMNSM write User, Nonsecure | | | | executes. The contents of When a given channel is a secure/nonsecure attribute The following table defines the resulting "next state" o Write to UMNSM field 00 | ctivated and executes, the es for all source reads and the association between the full three th | DMA generates the approdestination writes using UI he write data operand, the ssor mode and result of User, Secure 10 = {User, Secure} No change; error | ppriate privileged/user a MNSM. e initial system mode, ar UMNSM write User, Nonsecure 11 = {User, Nonsecure No change; error | | ## wemory Map/Register Definition # DMA\_DCRn field descriptions (continued) | Field | Description | |----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | <ul> <li>If the current mode is privileged and secure or if the current mode is user and secure, then attributes are set to {user, secure}. Otherwise, writing this value terminates in an error.</li> <li>If the current mode is privileged and secure, user and secure, or user and nonsecure, then attributes are set to {user, nonsecure}.</li> </ul> | | 23 | Enable asynchronous DMA requests | | EADREQ | Enables the channel to support asynchronous DREQs while the MCU is in Stop mode. | | | <ul><li>0 Disabled</li><li>1 Enabled</li></ul> | | 22 | Source Increment | | SINC | Controls whether the source address increments after each successful transfer. | | | 0 No change to SAR after a successful transfer. | | | 1 The SAR increments by 1, 2, 4 as determined by the transfer size. | | 21–20<br>SSIZE | Source Size | | SSIZE | Determines the data size of the source bus cycle for the DMA controller. | | | 00 32-bit | | | 01 8-bit | | | <ul> <li>10 16-bit</li> <li>11 Reserved (generates a configuration error (DSRn[CE]) if incorrectly specified at time of channel</li> </ul> | | | activation) | | 19 | Destination Increment | | DINC | Controls whether the destination address increments after each successful transfer. | | | 0 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 | | DOILL | Determines the data size of the destination bus cycle for the DMA controller. | | | 00 32-bit | | | 01 8-bit | | | 10 16-bit | | | 11 Reserved (generates a configuration error (DSRn[CE]) if incorrectly specified at time of channel activation) | | 16<br>START | Start Transfer | | SIAMI | 0 DMA inactive | | | 1 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. | | | | # 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. | | | | | | 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<br>DMOD | Destination Address Modulo | | | | | DIVIOD | 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. | | | | | | value determined by the apper address bits in the new selection. | | | | | | 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 | | | | | | 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 16 KB | | | | | | 1101 Circular buffer size is 64 KB | | | | | | 1110 Circular buffer size is 128 KB | | | | | | 1111 Circular buffer size is 256 KB | | | | | 7 | Disable Request | | | | | D_REQ | Disable Heduest | | | | | | DMA hardware automatically clears the corresponding DCRn[ERQ] bit when the byte count register | | | | | | reaches 0. | | | | | | 0 ERQ bit is not affected. | | | | | | 1 ERQ bit is cleared when the BCR is exhausted. | | | | | 6 | This field is reserved. | | | | | Reserved | This read-only field is reserved and always has the value 0. | | | | | | I . | | | | #### runctional Description ### DMA\_DCRn field descriptions (continued) | Field | Description | | | | | |-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | 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. | | | | | | | 00 No channel-to-channel linking | | | | | | | O1 Perform a link to channel LCH1 after each cycle-steal transfer followed by a link to LCH2 after the BCR decrements to 0. | | | | | | | 10 Perform a link to channel LCH1 after each cycle-steal transfer | | | | | | | 11 Perform a link to channel LCH1 after the BCR decrements to 0. | | | | | | 3–2<br>LCH1 | Link Channel 1 | | | | | | | 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 | | | | | | 1–0 | Link Channel 2 | | | | | | LCH2 | 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 | | | | | # 18.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. DCR*n*[START] 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. # 18.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 0. 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. ## 18.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. # 18.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. ## 18.4.2.2 DMA Access Control For the transfer channel descriptor (TCDn) of each channel, the DMA Controller can specify the required access control state needed to read or write contents. The system architecture defines functionality that extends the traditional concept of user and privileged access modes by adding an access attribute indicating a *secure/nonsecure* state. A total of three access states are supported, where the relative "priority" is defined as: Privileged Secure > User Secure > User Nonsecure In this model, the privileged state explicitly implies the secure state. The DMA Controller can manage privileged/user and secure/nonsecure attributes on an accessby- access basis. Each channel's DMA Control Register (DCR*n*) contains two fields for controlling the attributes: CHACR and UMNSM. The value of DCRn[CHACR] specifies the access rights for the corresponding TCDn. This mechanism allows system software to "allocate" a given DMA channel to a specific operating mode. DCRn[CHACR] can be written only when the system is in privileged secure mode. DCR*n*[UMNSM] defines the privileged/user and secure/nonsecure attributes for the DMA channel as it executes. For an allowed write, an update to DCR*n*[UMNSM] results either in preserving the attributes of the current system mode or in changing the attributes to a lower-level mode. After the CHACR and UMNSM fields are configured and the TCDn is initialized: When a given channel is activated and executes, the DMA Controller uses the UMNSM values and generates the appropriate privileged/user and secure/nonsecure attributes for all source reads and destination writes. # **18.4.2.3 Programming the DMA Controller Module** #### **CAUTION** During a channel's execution, writes to programming model registers can corrupt the data transfer. The DMA module itself does not have a mechanism to prevent writes to registers during a channel's execution. General guidelines for programming the DMA are: - TCDn is initialized. - SAR*n* is loaded with the source (read) address. If the transfer is from a peripheral device to memory or to another peripheral, the source address is the location of the peripheral data register. If the transfer is from memory to a peripheral device or to memory, the source address is the starting address of the data block. This can be any appropriately aligned address. - DAR*n* is initialized with the destination (write) address. If the transfer is from a peripheral device to memory, or from memory to memory, 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, or from a peripheral device 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, or 4 for 8-bit, 16-bit, or 32-bit 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. - DCRn[CHACR, UMNSM] can be programmed as the TCDn is initialized to allocate the channel to an access control state and define its access attributes while executing. - After 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 32 bits 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. #### **Functional Description** - The hardware can automatically clear DCR*n*[ERQ], disabling the peripheral request, when BCR*n* 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 DSR*n*[DONE] to stop the DMA channel. ## 18.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. ## 18.4.4 Advanced Data Transfer Controls: Auto-Alignment Typically, auto-alignment for DMA transfers applies for transfers of large blocks of data. As a result, it does not apply 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 DCR*n*[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 BCR*n* is greater than 16, the address determines transfer size. Transfers of 8 bits, 16 bits, or 32 bits are transferred until the address is aligned to the programmed size boundary, at which time accesses begin using the programmed size. If BCR*n* is less than 16 at the start of a transfer, the number of bytes remaining dictates transfer size. Consider this example: - AA equals 1. - SAR*n* equals 0x2000\_0001. - BCR*n* equals 0x00\_00F0. - SSIZE equals 00 (32 bits). - DSIZE equals 01 (8 bits). Because SSIZE > DSIZE, the source is auto-aligned. Error checking is performed on destination registers. The access sequence is as follows: - 1. Read 1 byte from 0x2000\_0001, increment SARn, write 1 byte (using DARn). - 2. Read 2 bytes from 0x2000\_0002, increment SARn, write 2 bytes. - 3. Read 4 bytes from 0x2000\_0004, increment SARn, write 4 bytes. - 4. Repeat 4-byte operations until SAR*n* equals 0x2000\_00F0. - 5. Read byte from 0x2000\_00F0, increment SARn, 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. ## 18.4.5 Termination An unsuccessful transfer can terminate for one of the following reasons: #### runctional Description - 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 1 to clear the interrupt, DSR*n*[DONE], and error status bits. # **Chapter 19 Direct Memory Access Multiplexer (DMAMUX)** ## 19.1 Introduction #### **NOTE** For the chip-specific implementation details of this module's instances, see the chip configuration information. ## **19.1.1 Overview** The Direct Memory Access Multiplexer (DMAMUX) routes DMA sources, called slots, to any of the one DMA channels. This process is illustrated in the following figure. KM Family Reference Manual, Rev. 5, Oct 2013 315 #### muroduction Figure 19-1. DMAMUX block diagram ## 19.1.2 Features The DMAMUX module provides these features: - Up to 16 peripheral slots and up to always-on slots can be routed to one channels. - one independently selectable DMA channel routers. - The first four channels additionally provide a trigger functionality. - Each channel router can be assigned to one of the possible peripheral DMA slots or to one of the always-on slots. ## 19.1.3 Modes of operation The following operating modes are available: Disabled mode R/W R/W 8 00h 00h 19.3.1/317 19.3.1/317 In this mode, the DMA channel is disabled. Because disabling and enabling of DMA channels is done primarily via the DMA configuration registers, this mode is used mainly as the reset state for a DMA channel in the DMA channel MUX. It may also be used to temporarily suspend a DMA channel while reconfiguration of the system takes place, for example, changing the period of a DMA trigger. #### Normal mode In this mode, a DMA source is routed directly to the specified DMA channel. The operation of the DMAMUX in this mode is completely transparent to the system. ## • Periodic Trigger mode In this mode, a DMA source may only request a DMA transfer, such as when a transmit buffer becomes empty or a receive buffer becomes full, periodically. Configuration of the period is done in the registers of the periodic interrupt timer (PIT). This mode is available only for channels 0–3. # 19.2 External signal description The DMAMUX has no external pins. 4002\_3000 4002\_4000 # 19.3 Memory map/register definition Channel Configuration register (DMAMUX2\_CHCFG) Channel Configuration register (DMAMUX3\_CHCFG) This section provides a detailed description of all memory-mapped registers in the DMAMUX. | Absolute<br>address<br>(hex) | Register name | Width<br>(in bits) | Access | Reset value | Section/<br>page | |------------------------------|------------------------------------------------|--------------------|--------|-------------|------------------| | 4002_1000 | Channel Configuration register (DMAMUX0_CHCFG) | 8 | R/W | 00h | 19.3.1/317 | | 4002_2000 | Channel Configuration register (DMAMUX1_CHCFG) | 8 | R/W | 00h | 19.3.1/317 | #### **DMAMUX** memory map # 19.3.1 Channel Configuration register (DMAMUXx\_CHCFG) Each of the DMA channels can be independently enabled/disabled and associated with one of the DMA slots (peripheral slots or always-on slots) in the system. KM Family Reference Manual, Rev. 5, Oct 2013 ## **NOTE** Setting multiple CHCFG registers with the same source value will result in unpredictable behavior. Before changing the trigger or source settings, a DMA channel must be disabled via CHCFGn[ENBL]. Address: Base address + 0h offset | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|------|------|--------|---|---|---|---|---| | Read<br>Write | ENBL | TRIG | SOURCE | | | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ### DMAMUXx\_CHCFG field descriptions | Field | Description | |---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7<br>ENBL | DMA Channel Enable | | LINDL | Enables the DMA channel. | | | 0 DMA channel is disabled. This mode is primarily used during configuration of the DMAMux. The DMA has separate channel enables/disables, which should be used to disable or reconfigure a DMA channel. | | | 1 DMA channel is enabled | | 6 | DMA Channel Trigger Enable | | TRIG | Enables the periodic trigger capability for the triggered DMA channel. | | | Triggering is disabled. If triggering is disabled and ENBL is set, the DMA Channel will simply route the specified source to the DMA channel. (Normal mode) | | | 1 Triggering is enabled. If triggering is enabled and ENBL is set, the DMAMUX is in Periodic Trigger mode. | | 5–0<br>SOURCE | DMA Channel Source (Slot) | | | Specifies which DMA source, if any, is routed to a particular DMA channel. See your device's chip configuration details for information about the peripherals and their slot numbers. | # 19.4 Functional description The primary purpose of the DMAMUX is to provide flexibility in the system's use of the available DMA channels. As such, configuration of the DMAMUX is intended to be a static procedure done during execution of the system boot code. However, if the procedure outlined in Enabling and configuring sources is followed, the configuration of the DMAMUX may be changed during the normal operation of the system. Functionally, the DMAMUX channels may be divided into two classes: - Channels that implement the normal routing functionality plus periodic triggering capability - Channels that implement only the normal routing functionality # 19.4.1 DMA channels with periodic triggering capability Besides the normal routing functionality, the first 4 channels of the DMAMUX provide a special periodic triggering capability that can be used to provide an automatic mechanism to transmit bytes, frames, or packets at fixed intervals without the need for processor intervention. The trigger is generated by the periodic interrupt timer (PIT); as such, the configuration of the periodic triggering interval is done via configuration registers in the PIT. See the section on periodic interrupt timer for more information on this topic. #### **Note** Because of the dynamic nature of the system (due to DMA channel priorities, bus arbitration, interrupt service routine lengths, etc.), the number of clock cycles between a trigger and the actual DMA transfer cannot be guaranteed. Figure 19-7. DMAMUX triggered channels KM Family Reference Manual, Rev. 5, Oct 2013 #### runctional description The DMA channel triggering capability allows the system to schedule regular DMA transfers, usually on the transmit side of certain peripherals, without the intervention of the processor. This trigger works by gating the request from the peripheral to the DMA until a trigger event has been seen. This is illustrated in the following figure. Figure 19-8. DMAMUX channel triggering: normal operation After the DMA request has been serviced, the peripheral will negate its request, effectively resetting the gating mechanism until the peripheral reasserts its request and the next trigger event is seen. This means that if a trigger is seen, but the peripheral is not requesting a transfer, then that trigger will be ignored. This situation is illustrated in the following figure. Figure 19-9. DMAMUX channel triggering: ignored trigger This triggering capability may be used with any peripheral that supports DMA transfers, and is most useful for two types of situations: • Periodically polling external devices on a particular bus As an example, the transmit side of an SPI is assigned to a DMA channel with a trigger, as described above. After it has been set up, the SPI will request DMA transfers, presumably from memory, as long as its transmit buffer is empty. By using a trigger on this channel, the SPI transfers can be automatically performed every 5 µs (as an example). On the receive side of the SPI, the SPI and DMA can be configured to transfer receive data into memory, effectively implementing a method to periodically read data from external devices and transfer the results into memory without processor intervention. • Using the GPIO ports to drive or sample waveforms By configuring the DMA to transfer data to one or more GPIO ports, it is possible to create complex waveforms using tabular data stored in on-chip memory. Conversely, using the DMA to periodically transfer data from one or more GPIO ports, it is possible to sample complex waveforms and store the results in tabular form in on-chip memory. A more detailed description of the capability of each trigger, including resolution, range of values, and so on, may be found in the periodic interrupt timer section. # 19.4.2 DMA channels with no triggering capability The other channels of the DMAMUX provide the normal routing functionality as described in Modes of operation. # 19.4.3 Always-enabled DMA sources In addition to the peripherals that can be used as DMA sources, there are additional DMA sources that are always enabled. Unlike the peripheral DMA sources, where the peripheral controls the flow of data during DMA transfers, the sources that are always enabled provide no such "throttling" of the data transfers. These sources are most useful in the following cases: - Performing DMA transfers to/from GPIO—Moving data from/to one or more GPIO pins, either unthrottled (that is, as fast as possible), or periodically (using the DMA triggering capability). - Performing DMA transfers from memory to memory—Moving data from memory to memory, typically as fast as possible, sometimes with software activation. - Performing DMA transfers from memory to the external bus, or vice-versa—Similar to memory to memory transfers, this is typically done as quickly as possible. - Any DMA transfer that requires software activation—Any DMA transfer that should be explicitly started by software. # 19.5 Initialization/application information This section provides instructions for initializing the DMA channel MUX. ## 19.5.1 Reset The reset state of each individual bit is shown in Memory map/register definition. In summary, after reset, all channels are disabled and must be explicitly enabled before use. ## 19.5.2 Enabling and configuring sources To enable a source with periodic triggering: - 1. Determine with which DMA channel the source will be associated. Note that only the first 4 DMA channels have periodic triggering capability. - 2. Clear the CHCFG[ENBL] and CHCFG[TRIG] fields of the DMA channel. - 3. Ensure that the DMA channel is properly configured in the DMA. The DMA channel may be enabled at this point. - 4. Configure the corresponding timer. - 5. Select the source to be routed to the DMA channel. Write to the corresponding CHCFG register, ensuring that the CHCFG[ENBL] and CHCFG[TRIG] fields are set. #### NOTE The following is an example. See the chip configuration details for the number of this device's DMA channels that have triggering capability. To configure source #5 transmit for use with DMA channel 1, with periodic triggering capability: - 1. Write 0x00 to CHCFG1 (base address + 0x01). - 2. Configure channel 1 in the DMA, including enabling the channel. - 3. Configure a timer for the desired trigger interval. - 4. Write 0xC5 to CHCFG1 (base address + 0x01). The following code example illustrates steps 1 and 4 above: #### Chapter 19 Direct Memory Access Multiplexer (DMAMUX) ``` volatile unsigned char *CHCONFIG11= (volatile unsigned char *) (DMAMUX_BASE_ADDR+0x000B); volatile unsigned char *CHCONFIG12= (volatile unsigned char *) (DMAMUX_BASE_ADDR+0x000C); volatile unsigned char *CHCONFIG13= (volatile unsigned char *) (DMAMUX_BASE_ADDR+0x000D); volatile unsigned char *CHCONFIG14= (volatile unsigned char *) (DMAMUX_BASE_ADDR+0x000E); volatile unsigned char *CHCONFIG15= (volatile unsigned char *) (DMAMUX_BASE_ADDR+0x000F); In File main.c: #include "registers.h" : : : *CHCONFIG1 = 0x00; *CHCONFIG1 = 0x05; ``` To enable a source without periodic triggering: - 1. Determine with which DMA channel the source will be associated. Note that only the first 4 DMA channels have periodic triggering capability. - 2. Clear the CHCFG[ENBL] and CHCFG[TRIG] fields of the DMA channel. - 3. Ensure that the DMA channel is properly configured in the DMA. The DMA channel may be enabled at this point. - 4. Select the source to be routed to the DMA channel. Write to the corresponding CHCFG register, ensuring that CHCFG[ENBL] is set while CHCFG[TRIG] is cleared. #### NOTE The following is an example. See the chip configuration details for the number of this device's DMA channels that have triggering capability. To configure source #5 transmit for use with DMA channel 1, with no periodic triggering capability: - 1. Write 0x00 to CHCFG1 (base address + 0x01). - 2. Configure channel 1 in the DMA, including enabling the channel. - 3. Write 0x85 to CHCFG1 (base address + 0x01). The following code example illustrates steps 1 and 3 above: ``` In File registers.h: #define DMAMUX BASE ADDR 0xFC084000/* Example only ! */ /* Following example assumes char is 8-bits */ volatile unsigned char *CHCONFIG0 = (volatile unsigned char *) (DMAMUX_BASE_ADDR+0x0000); volatile unsigned char *CHCONFIG1 = (volatile unsigned char *) (DMAMUX_BASE_ADDR+0x0001); volatile unsigned char *CHCONFIG2 = (volatile unsigned char *) (DMAMUX_BASE_ADDR+0x0002); volatile unsigned char *CHCONFIG3 = (volatile unsigned char *) (DMAMUX_BASE_ADDR+0x0003); volatile unsigned char *CHCONFIG4 = (volatile unsigned char *) (DMAMUX BASE ADDR+0x0004); volatile unsigned char *CHCONFIG5 = (volatile unsigned char *) (DMAMUX BASE ADDR+0x0005); volatile unsigned char *CHCONFIG6 = (volatile unsigned char *) (DMAMUX_BASE_ADDR+0x0006); volatile unsigned char *CHCONFIG7 = (volatile unsigned char *) (DMAMUX_BASE_ADDR+0x0007); volatile unsigned char *CHCONFIG8 = (volatile unsigned char *) (DMAMUX_BASE_ADDR+0x0008); volatile unsigned char *CHCONFIG9 = (volatile unsigned char *) (DMAMUX BASE ADDR+0x0009); volatile unsigned char *CHCONFIG10= (volatile unsigned char *) (DMAMUX_BASE_ADDR+0x000A); volatile unsigned char *CHCONFIG11= (volatile unsigned char *) (DMAMUX BASE ADDR+0x000B); volatile unsigned char *CHCONFIG12= (volatile unsigned char *) (DMAMUX BASE ADDR+0x000C); volatile unsigned char *CHCONFIG13= (volatile unsigned char *) (DMAMUX_BASE_ADDR+0x000D); volatile unsigned char *CHCONFIG14= (volatile unsigned char *) (DMAMUX_BASE_ADDR+0x000E); volatile unsigned char *CHCONFIG15= (volatile unsigned char *) (DMAMUX BASE ADDR+0x000F); ``` KM Family Reference Manual, Rev. 5, Oct 2013 323 #### mualization/application information ``` In File main.c: #include "registers.h" : : *CHCONFIG1 = 0x00; *CHCONFIG1 = 0x85; ``` #### To disable a source: A particular DMA source may be disabled by not writing the corresponding source value into any of the CHCFG registers. Additionally, some module-specific configuration may be necessary. See the appropriate section for more details. To switch the source of a DMA channel: - 1. Disable the DMA channel in the DMA and reconfigure the channel for the new source. - 2. Clear the CHCFG[ENBL] and CHCFG[TRIG] bits of the DMA channel. - 3. Select the source to be routed to the DMA channel. Write to the corresponding CHCFG register, ensuring that the CHCFG[ENBL] and CHCFG[TRIG] fields are set. To switch DMA channel 8 from source #5 transmit to source #7 transmit: - 1. In the DMA configuration registers, disable DMA channel 8 and reconfigure it to handle the transfers to peripheral slot 7. This example assumes channel 8 doesn't have triggering capability. - 2. Write 0x00 to CHCFG8 (base address + 0x08). - 3. Write 0x87 to CHCFG8 (base address + 0x08). (In this example, setting CHCFG[TRIG] would have no effect due to the assumption that channel 8 does not support the periodic triggering functionality). The following code example illustrates steps 2 and 3 above: ``` In File registers.h: #define DMAMUX BASE ADDR 0xFC084000/* Example only ! */ /* Following example assumes char is 8-bits */ volatile unsigned char *CHCONFIG0 = (volatile unsigned char *) (DMAMUX BASE ADDR+0x0000); volatile unsigned char *CHCONFIG1 = (volatile unsigned char *) (DMAMUX BASE ADDR+0x0001); volatile unsigned char *CHCONFIG2 = (volatile unsigned char *) (DMAMUX BASE ADDR+0x0002); volatile unsigned char *CHCONFIG3 = (volatile unsigned char *) (DMAMUX BASE ADDR+0x0003); volatile unsigned char *CHCONFIG4 = (volatile unsigned char *) (DMAMUX_BASE_ADDR+0x0004); volatile unsigned char *CHCONFIG5 = (volatile unsigned char *) (DMAMUX_BASE_ADDR+0x0005); volatile unsigned char *CHCONFIG6 = (volatile unsigned char *) (DMAMUX_BASE_ADDR+0x0006); volatile unsigned char *CHCONFIG7 = (volatile unsigned char *) (DMAMUX_BASE_ADDR+0x0007); volatile unsigned char *CHCONFIG8 = (volatile unsigned char *) (DMAMUX_BASE_ADDR+0x0008); volatile unsigned char *CHCONFIG9 = (volatile unsigned char *) (DMAMUX BASE ADDR+0x0009); volatile unsigned char *CHCONFIG10= (volatile unsigned char *) (DMAMUX_BASE_ADDR+0x000A); volatile unsigned char *CHCONFIG11= (volatile unsigned char *) (DMAMUX_BASE_ADDR+0x000B); volatile unsigned char *CHCONFIG12= (volatile unsigned char *) (DMAMUX_BASE_ADDR+0x000C); volatile unsigned char *CHCONFIG13= (volatile unsigned char *) (DMAMUX BASE ADDR+0x000D); volatile unsigned char *CHCONFIG14= (volatile unsigned char *) (DMAMUX_BASE_ADDR+0x000E); volatile unsigned char *CHCONFIG15= (volatile unsigned char *) (DMAMUX BASE ADDR+0x000F); In File main.c: #include "registers.h" ``` ``` : *CHCONFIG8 = 0x00; *CHCONFIG8 = 0x87; ``` mualization/application information # **Chapter 20 Peripheral Bridge (AIPS-Lite)** #### 20.1 Introduction #### **NOTE** For the chip-specific implementation details of this module's instances, see the chip configuration information. The peripheral bridge converts the crossbar switch interface to an interface that can access most of the slave peripherals on this chip. The peripheral bridge occupies 64 MB of the address space, which is divided into peripheral slots of 4 KB. (It might be possible that all the peripheral slots are not used. See the memory map chapter for details on slot assignments.) The bridge includes separate clock enable inputs for each of the slots to accommodate slower peripherals. #### 20.1.1 Features Key features of the peripheral bridge are: - Supports peripheral slots with 8-, 16-, and 32-bit datapath width - Supports a pair of 32-bit transactions for selected 64-bit memory accesses - Programming model provides memory protection functionality ## 20.1.2 General operation The slave devices connected to the peripheral bridge are modules which contain a programming model of control and status registers. The system masters read and write these registers through the peripheral bridge. The peripheral bridge performs a bus protocol conversion of the master transactions and generates the following as inputs to the peripherals: - Module enables - Module addresses - Transfer attributes - Byte enables - Write data The peripheral bridge selects and captures read data from the peripheral interface and returns it to the crossbar switch. The register maps of the peripherals are located on 4-KB boundaries. Each peripheral is allocated one or more 4-KB block(s) of the memory map. The AIPS-Lite module uses the data width of accessed peripheral to perform proper data byte lane routing; bus decomposition (bus sizing) is performed when the access size is larger than the peripheral's data width. ## 20.2 Memory map/register definition The 32-bit peripheral bridge registers can be accessed only in secure, privileged mode. Additionally, these registers must be read from or written to only by a 32-bit aligned access. The peripheral bridge registers are mapped into the PACRA[PACR0] address space. #### **AIPS memory map** | Absolute address (hex) | Register name | Width<br>(in bits) | Access | Reset value | Section/<br>page | |------------------------|-------------------------------------------------|--------------------|--------|-------------|------------------| | 4000_0020 | Peripheral Access Control Register (AIPS_PACRA) | 32 | R/W | See section | 20.2.1/329 | | 4000_0024 | Peripheral Access Control Register (AIPS_PACRB) | 32 | R/W | See section | 20.2.1/329 | | 4000_0040 | Peripheral Access Control Register (AIPS_PACRE) | 32 | R/W | See section | 20.2.2/332 | | 4000_0044 | Peripheral Access Control Register (AIPS_PACRF) | 32 | R/W | See section | 20.2.2/332 | | 4000_0048 | Peripheral Access Control Register (AIPS_PACRG) | 32 | R/W | See section | 20.2.2/332 | | 4000_004C | Peripheral Access Control Register (AIPS_PACRH) | 32 | R/W | See section | 20.2.2/332 | | 4000_0050 | Peripheral Access Control Register (AIPS_PACRI) | 32 | R/W | See section | 20.2.2/332 | | 4000_0054 | Peripheral Access Control Register (AIPS_PACRJ) | 32 | R/W | See section | 20.2.2/332 | #### AIPS memory map (continued) | Absolute address (hex) | Register name | Width<br>(in bits) | Access | Reset value | Section/<br>page | |------------------------|-------------------------------------------------|--------------------|--------|-------------|------------------| | 4000_0058 | Peripheral Access Control Register (AIPS_PACRK) | 32 | R/W | See section | 20.2.2/332 | | 4000_005C | Peripheral Access Control Register (AIPS_PACRL) | 32 | R/W | See section | 20.2.2/332 | | 4000_0060 | Peripheral Access Control Register (AIPS_PACRM) | 32 | R/W | See section | 20.2.2/332 | | 4000_0064 | Peripheral Access Control Register (AIPS_PACRN) | 32 | R/W | See section | 20.2.2/332 | | 4000_0068 | Peripheral Access Control Register (AIPS_PACRO) | 32 | R/W | See section | 20.2.2/332 | | 4000_006C | Peripheral Access Control Register (AIPS_PACRP) | 32 | R/W | See section | 20.2.2/332 | ## 20.2.1 Peripheral Access Control Register (AIPS\_PACRn) Each peripheral on this chip has a 4-bit PACR field which includes a read-only "lock" bit plus a 3-bit attribute check field which defines the access rights (privileged/user, secure/nonsecure) needed to reference the slave peripheral's address space. Access to these registers is allowed using only 32-bit privileged, secure reads and writes. Each 32-bit register controls eight peripherals. A peripheral's assignment to a PACR field is defined by the memory map slot to which the peripheral is assigned. See this chip's peripheral bridge memory map information for the assignment of a particular peripheral. The following table shows the top-level structure of PACRs. | Offset | Register | [31:28] | [27:24] | [23:20] | [19:16] | [15:12] | [11:8] | [7:4] | [3:0] | |--------|----------|---------|---------|---------|---------|---------|--------|--------|--------| | 0x20 | PACRA | PACR0 | PACR1 | PACR2 | PACR3 | PACR4 | PACR5 | PACR6 | PACR7 | | 0x24 | PACRB | PACR8 | PACR9 | PACR10 | PACR11 | PACR12 | PACR13 | PACR14 | PACR15 | The following table defines the attribute check values for each AC field. #### NOTE For access to peripherals that have their own access attribute checks, such as GPIO, refer also to their attributes checks definitions. Table 20-3. Attribute check (AC) values | AC | User<br>nonsecure | User secure | Privileged secure | |-------|-------------------|-------------|-------------------| | 0b000 | Read/Write | Read/Write | Read/Write | | 0b001 | Read | Read/Write | Read/Write | wemory map/register definition Table 20-3. Attribute check (AC) values (continued) | AC | User<br>nonsecure | User secure | Privileged secure | |-------|-------------------|-------------|-------------------| | 0b010 | None | Read/Write | Read/Write | | 0b011 | Read | Read | Read/Write | | 0b100 | None | Read | Read/Write | | 0b101 | None | None | Read/Write | | 0b110 | None | None | Read | | 0b111 | None | None | None | Address: $4000\_0000h$ base + 20h offset + $(4d \times i)$ , where i=0d to 1d | Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |--------|-----|----|-----|----|-----|----|-----|----|-----|----|-----|----|-----|----|-----|----| | R<br>W | RO0 | | AC0 | | RO1 | | AC1 | | RO2 | | AC2 | | RO3 | | AC3 | | | 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<br>W | RO4 | | AC4 | | RO5 | | AC5 | | RO6 | | AC6 | | RO7 | | AC7 | | | Reset | 0* | 0* | 0* | 0* | 0* | 0* | 0* | 0* | 0* | 0* | 0* | 0* | 0* | 0* | 0* | 0* | <sup>\*</sup> Notes: #### AIPS\_PACRn field descriptions | Field | Description | |--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31<br>RO0 | Read Only | | | Indicates the lock status of this register's AC0 field. After this field is set to 1, it cannot be changed and attempted writes to AC0 are ignored until the next system reset clears this field. | | | 0 Writes to corresponding AC field are allowed. | | | 1 Writes to corresponding AC field are ignored. | | 30–28<br>AC0 | Attribute Check | | | Defines the attributes required to access the corresponding slave peripheral's memory space. See Table 20-3, "Attribute check (AC) values" for details. | | 27<br>RO1 | Read Only | | | Indicates the lock status of this register's AC1 field. After this field is set to 1, it cannot be changed and attempted writes to AC1 are ignored until the next system reset clears this field. | | | 0 Writes to corresponding AC field are allowed. | | | 1 Writes to corresponding AC field are ignored. | | 26–24<br>AC1 | Attribute Check | | | Defines the attributes required to access the corresponding slave peripheral's memory space. See Table 20-3, "Attribute check (AC) values" for details. | | 23<br>RO2 | Read Only | Table continues on the next page... <sup>•</sup> The reset value is chip-dependent and can be found in the AIPS chip-specific information. ## AIPS\_PACRn field descriptions (continued) | Field | Description | | | | | | | | | |--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--| | | Indicates the lock status of this register's AC2 field. After this field is set to 1, it cannot be changed and attempted writes to AC2 are ignored until the next system reset clears this field. | | | | | | | | | | | 0 Writes to corresponding AC field are allowed. | | | | | | | | | | | Writes to corresponding AC field are ignored. | | | | | | | | | | 22–20<br>AC2 | Attribute Check | | | | | | | | | | AUZ | Defines the attributes required to access the corresponding slave peripheral's memory space. See Table 20-3, "Attribute check (AC) values" for details. | | | | | | | | | | 19 | Read Only | | | | | | | | | | RO3 | Indicates the lock status of this register's AC3 field. After this field is set to 1, it cannot be changed and attempted writes to AC3 are ignored until the next system reset clears this field. | | | | | | | | | | | 0 Writes to corresponding AC field are allowed. | | | | | | | | | | | 1 Writes to corresponding AC field are ignored. | | | | | | | | | | 18–16 | Attribute Check | | | | | | | | | | AC3 | Defines the attributes required to access the corresponding slave peripheral's memory space. See Table | | | | | | | | | | | 20-3, "Attribute check (AC) values" for details. | | | | | | | | | | 15 | Read Only | | | | | | | | | | RO4 | Indicates the lock status of this register's AC4 field. After this field is set to 1, it cannot be changed and | | | | | | | | | | | attempted writes to AC4 are ignored until the next system reset clears this field. | | | | | | | | | | | 0 Writes to corresponding AC field are allowed. | | | | | | | | | | | 1 Writes to corresponding AC field are ignored. | | | | | | | | | | 14–12<br>AC4 | Attribute Check | | | | | | | | | | 7.04 | Defines the attributes required to access the corresponding slave peripheral's memory space. See Table 20-3, "Attribute check (AC) values" for details. | | | | | | | | | | 11 | Read Only | | | | | | | | | | RO5 | Indicates the lock status of this register's AC5 field. After this field is set to 1, it cannot be changed and attempted writes to AC5 are ignored until the next system reset clears this field. | | | | | | | | | | | 0 Writes to corresponding AC field are allowed. | | | | | | | | | | | 1 Writes to corresponding AC field are ignored. | | | | | | | | | | 10–8 | Attribute Check | | | | | | | | | | AC5 | Defines the attributes required to access the corresponding slave peripheral's memory space. See Table 20-3, "Attribute check (AC) values" for details. | | | | | | | | | | 7<br>RO6 | Read Only | | | | | | | | | | 1100 | Indicates the lock status of this register's AC6 field. After this field is set to 1, it cannot be changed and attempted writes to AC6 are ignored until the next system reset clears this field. | | | | | | | | | | | 0 Writes to corresponding AC field are allowed. | | | | | | | | | | | 1 Writes to corresponding AC field are ignored. | | | | | | | | | | 6–4 | Attribute Check | | | | | | | | | | AC6 | | | | | | | | | | #### wemory map/register definition #### AIPS\_PACRn field descriptions (continued) | Field | Description | |------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | Defines the attributes required to access the corresponding slave peripheral's memory space. See Table 20-3, "Attribute check (AC) values" for details. | | 3<br>RO7 | Read Only Indicates the lock status of this register's AC7 field. After this field is set to 1, it cannot be changed and attempted writes to AC7 are ignored until the next system reset clears this field. | | | <ul><li>0 Writes to corresponding AC field are allowed.</li><li>1 Writes to corresponding AC field are ignored.</li></ul> | | 2–0<br>AC7 | Attribute Check | | | Defines the attributes required to access the corresponding slave peripheral's memory space. See Table 20-3, "Attribute check (AC) values" for details. | ## 20.2.2 Peripheral Access Control Register (AIPS\_PACRn) Each peripheral on this chip has a 4-bit PACR field which includes a read-only "lock" bit plus a 3-bit attribute check field which defines the access rights (privileged/user, secure/nonsecure) needed to reference the slave peripheral's address space. Access to these registers is allowed using only 32-bit privileged, secure reads and writes. Each 32-bit register controls eight peripherals. PACRE-PACR P control access to the 96 off-platform peripherals. A peripheral's assignment to a PACR field is defined by the memory map slot to which the peripheral is assigned. See this device's peripheral bridge memory map information for the assignment of a particular peripheral. The following table shows the top-level structure of PACRs. | Offset | Register | [31:28] | [27:24] | [23:20] | [19:16] | [15:12] | [11:8] | [7:4] | [3:0] | |--------|----------|---------|---------|---------|---------|---------|---------|---------|---------| | 0x40 | PACRE | PACR32 | PACR33 | PACR34 | PACR35 | PACR36 | PACR37 | PACR38 | PACR39 | | 0x44 | PACRF | PACR40 | PACR41 | PACR42 | PACR43 | PACR44 | PACR45 | PACR46 | PACR47 | | 0x48 | PACRG | PACR48 | PACR49 | PACR50 | PACR51 | PACR52 | PACR53 | PACR54 | PACR55 | | 0x4C | PACRH | PACR56 | PACR57 | PACR58 | PACR59 | PACR60 | PACR61 | PACR62 | PACR63 | | 0x50 | PACRI | PACR64 | PACR65 | PACR66 | PACR67 | PACR68 | PACR69 | PACR70 | PACR71 | | 0x54 | PACRJ | PACR72 | PACR73 | PACR74 | PACR75 | PACR76 | PACR77 | PACR78 | PACR79 | | 0x58 | PACRK | PACR80 | PACR81 | PACR82 | PACR83 | PACR84 | PACR85 | PACR86 | PACR87 | | 0x5C | PACRL | PACR88 | PACR89 | PACR90 | PACR91 | PACR92 | PACR93 | PACR94 | PACR95 | | 0x60 | PACRM | PACR96 | PACR97 | PACR98 | PACR99 | PACR100 | PACR101 | PACR102 | PACR103 | | 0x64 | PACRN | PACR104 | PACR105 | PACR106 | PACR107 | PACR108 | PACR109 | PACR110 | PACR111 | | 0x68 | PACRO | PACR112 | PACR113 | PACR114 | PACR115 | PACR116 | PACR117 | PACR118 | PACR119 | | 0x6C | PACRP | PACR120 | PACR121 | PACR122 | PACR123 | PACR124 | PACR125 | PACR126 | PACR127 | Address: $4000\_0000h$ base + 40h offset + $(4d \times i)$ , where i=0d to 11d | Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |--------|-----|----|-----|----|-----|----|-----|----|-----|----|-----|----|-----|----|-----|----| | R<br>W | RO0 | | AC0 | | RO1 | | AC1 | | RO2 | | AC2 | | RO3 | | AC3 | | | 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<br>W | RO4 | | AC4 | | RO5 | | AC5 | | RO6 | | AC6 | | RO7 | | AC7 | | | Reset | 0* | 0* | 0* | 0* | 0* | 0* | 0* | 0* | 0* | 0* | 0* | 0* | 0* | 0* | 0* | 0* | <sup>\*</sup> Notes: ## AIPS\_PACRn field descriptions | Field | Description | |--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31<br>RO0 | Read Only Indicates the lock status of this register's AC0 field. After this field is set to 1, it cannot be changed and attempted writes to AC0 are ignored until the next system reset clears this field. O Writes to corresponding AC field are allowed. 1 Writes to corresponding AC field are ignored. | | 30–28<br>AC0 | Attribute Check Defines the attributes required to access the corresponding slave peripheral's memory space. See Table 20-3, "Attribute check (AC) values" for details. | | 27<br>RO1 | Read Only Indicates the lock status of this register's AC1 field. After this field is set to 1, it cannot be changed and attempted writes to AC1 are ignored until the next system reset clears this field. O Writes to corresponding AC field are allowed. The Writes to corresponding AC field are ignored. | | 26–24<br>AC1 | Attribute Check Defines the attributes required to access the corresponding slave peripheral's memory space. See Table 20-3, "Attribute check (AC) values" for details. | | 23<br>RO2 | Read Only Indicates the lock status of this register's AC2 field. After this field is set to 1, it cannot be changed and attempted writes to AC2 are ignored until the next system reset clears this field. O Writes to corresponding AC field are allowed. Writes to corresponding AC field are ignored. | | 22–20<br>AC2 | Attribute Check Defines the attributes required to access the corresponding slave peripheral's memory space. See Table 20-3, "Attribute check (AC) values" for details. | | 19<br>RO3 | Read Only Indicates the lock status of this register's AC3 field. After this field is set to 1, it cannot be changed and attempted writes to AC3 are ignored until the next system reset clears this field. | Table continues on the next page... <sup>•</sup> The reset value is chip-dependent and can be found in the AIPS chip-specific information. #### wemory map/register definition ## AIPS\_PACRn field descriptions (continued) | Field | Description | |--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | 0 Writes to corresponding AC field are allowed. | | | 1 Writes to corresponding AC field are ignored. | | 18–16<br>AC3 | Attribute Check | | | Defines the attributes required to access the corresponding slave peripheral's memory space. See Table 20-3, "Attribute check (AC) values" for details. | | 15<br>RO4 | Read Only | | | Indicates the lock status of this register's AC4 field. After this field is set to 1, it cannot be changed and attempted writes to AC4 are ignored until the next system reset clears this field. | | | 0 Writes to corresponding AC field are allowed. | | | 1 Writes to corresponding AC field are ignored. | | 14–12<br>AC4 | Attribute Check | | | Defines the attributes required to access the corresponding slave peripheral's memory space. See Table 20-3, "Attribute check (AC) values" for details. | | 11<br>RO5 | Read Only | | 1103 | Indicates the lock status of this register's AC5 field. After this field is set to 1, it cannot be changed and attempted writes to AC5 are ignored until the next system reset clears this field. | | | 0 Writes to corresponding AC field are allowed. | | | 1 Writes to corresponding AC field are ignored. | | 10–8<br>AC5 | Attribute Check | | AOS | Defines the attributes required to access the corresponding slave peripheral's memory space. See Table 20-3, "Attribute check (AC) values" for details. | | 7<br>RO6 | Read Only | | HOU | Indicates the lock status of this register's AC6 field. After this field is set to 1, it cannot be changed and attempted writes to AC6 are ignored until the next system reset clears this field. | | | 0 Writes to corresponding AC field are allowed. | | | 1 Writes to corresponding AC field are ignored. | | 6–4<br>AC6 | Attribute Check | | ACO | Defines the attributes required to access the corresponding slave peripheral's memory space. See Table 20-3, "Attribute check (AC) values" for details. | | 3<br>RO7 | Read Only | | no/ | Indicates the lock status of this register's AC7 field. After this field is set to 1, it cannot be changed and attempted writes to AC7 are ignored until the next system reset clears this field. | | | 0 Writes to corresponding AC field are allowed. | | | 1 Writes to corresponding AC field are ignored. | | 2-0<br>AC7 | Attribute Check | | AO7 | Defines the attributes required to access the corresponding slave peripheral's memory space. See Table 20-3, "Attribute check (AC) values" for details. | ## 20.3 Functional description The peripheral bridge functions as a bus protocol translator between the crossbar switch and the slave peripheral bus. Support is provided for generating a pair of 32-bit slave accesses when performing certain 64-bit peripheral accesses. The peripheral bridge manages all transactions destined for the attached slave devices and generates select signals for modules on the peripheral bus by decoding accesses within the attached address space. ## 20.3.1 Access support All combinations of access size and peripheral data port width are supported. An access that is larger than the target peripheral's data width will be decomposed to multiple, smaller accesses. Bus decomposition is terminated by a transfer error caused by an access to an empty register area. runctional description # **Chapter 21 Memory Protection Unit (MPU)** #### 21.1 Introduction #### **NOTE** For the chip-specific implementation details of this module's instances, see the chip configuration information. The memory protection unit (MPU) provides hardware access control for all memory references generated in the device. #### 21.2 Overview The MPU concurrently monitors all system bus transactions and evaluates their appropriateness using pre-programmed region descriptors that define memory spaces and their access rights. Memory references that have sufficient access control rights are allowed to complete, while references that are not mapped to any region descriptor or have insufficient rights are terminated with a protection error response. ## 21.2.1 Block diagram A simplified block diagram of the MPU module is shown in the following figure. KM Family Reference Manual, Rev. 5, Oct 2013 337 Figure 21-1. MPU block diagram The hardware's two-dimensional connection matrix is clearly visible with the basic access evaluation macro shown as the replicated submodule block. The crossbar switch slave ports are shown on the left, the region descriptor registers in the middle, and the peripheral bus interface on the right side. The evaluation macro contains two magnitude comparators connected to the start and end address registers from each region descriptor as well as the combinational logic blocks to determine the region hit and the access protection error. For details of the access evaluation macro, see Access evaluation macro. #### 21.2.2 Features The MPU implements a two-dimensional hardware array of memory region descriptors and the crossbar slave ports to continuously monitor the legality of every memory reference generated by each bus master in the system. The feature set includes: - 8 program-visible 128-bit region descriptors, accessible by four 32-bit words each - Each region descriptor defines a modulo-32 byte space, aligned anywhere in memory 339 - Region sizes can vary from 32 bytes to 4 Gbytes - Two access control permissions defined in a single descriptor word - Masters 0–3: read, write, and execute attributes for supervisor and user accesses - Masters 4–7: read and write attributes - Hardware-assisted maintenance of the descriptor valid bit minimizes coherency issues - Alternate programming model view of the access control permissions word - Priority given to granting permission over denying access for overlapping region descriptors - Detects access protection errors if a memory reference does not hit in any memory region, or if the reference is illegal in all hit memory regions. If an access error occurs, the reference is terminated with an error response, and the MPU inhibits the bus cycle being sent to the targeted slave device. - Error registers, per slave port, capture the last faulting address, attributes, and other information - Global MPU enable/disable control bit ## 21.3 Memory map/register definition The programming model is partitioned into three groups: - Control/status registers - The data structure containing the region descriptors - The alternate view of the region descriptor access control values The programming model can only be referenced using 32-bit accesses. Attempted references using different access sizes, to undefined, that is, reserved, addresses, or with a non-supported access type, such as a write to a read-only register, or a read of a write-only register, generate an error termination. The programming model can be accessed only in supervisor mode. #### **NOTE** See the chip configuration details for any chip-specific register information in this module. #### wemory map/register definition ## **MPU** memory map | Absolute<br>address<br>(hex) | Register name | Width<br>(in bits) | Access | Reset value | Section/<br>page | | |------------------------------|-------------------------------------------------|---------------------------|-----------|-------------|------------------|--| | 4000_A000 | Control/Error Status Register (MPU_CESR) | 32 | R/W | 0081_2001h | 21.3.1/341 | | | 4000_A010 | Error Address Register, slave port n (MPU_EAR0) | R | Undefined | 21.3.2/343 | | | | 4000_A014 | Error Detail Register, slave port n (MPU_EDR0) | 32 | R | Undefined | 21.3.3/344 | | | 4000_A018 | Error Address Register, slave port n (MPU_EAR1) | 32 | R | Undefined | 21.3.2/343 | | | 4000_A01C | Error Detail Register, slave port n (MPU_EDR1) | 32 | R | Undefined | 21.3.3/344 | | | 4000_A400 | Region Descriptor n, Word 0 (MPU_RGD0_WORD0) | 32 | R/W | 0000_0000h | 21.3.4/345 | | | 4000_A404 | Region Descriptor n, Word 1 (MPU_RGD0_WORD1) | 32 | R/W | See section | 21.3.5/345 | | | 4000_A408 | Region Descriptor n, Word 2 (MPU_RGD0_WORD2) | 32 | R/W | See section | 21.3.6/346 | | | 4000_A40C | Region Descriptor n, Word 3 (MPU_RGD0_WORD3) | 32 | R/W | See section | 21.3.7/349 | | | 4000_A410 | Region Descriptor n, Word 0 (MPU_RGD1_WORD0) | 32 | R/W | 0000_0000h | 21.3.4/345 | | | 4000_A414 | Region Descriptor n, Word 1 (MPU_RGD1_WORD1) | 32 | R/W | See section | 21.3.5/345 | | | 4000_A418 | Region Descriptor n, Word 2 (MPU_RGD1_WORD2) | 32 | R/W | See section | 21.3.6/346 | | | 4000_A41C | Region Descriptor n, Word 3 (MPU_RGD1_WORD3) | 32 | R/W | See section | 21.3.7/349 | | | 4000_A420 | Region Descriptor n, Word 0 (MPU_RGD2_WORD0) | 32 | R/W | 0000_0000h | 21.3.4/345 | | | 4000_A424 | Region Descriptor n, Word 1 (MPU_RGD2_WORD1) | 32 | R/W | See section | 21.3.5/345 | | | 4000_A428 | Region Descriptor n, Word 2 (MPU_RGD2_WORD2) | 32 | R/W | See section | 21.3.6/346 | | | 4000_A42C | Region Descriptor n, Word 3 (MPU_RGD2_WORD3) | 3 (MPU_RGD2_WORD3) 32 R/W | | | | | | 4000_A430 | Region Descriptor n, Word 0 (MPU_RGD3_WORD0) | 32 | R/W | 0000_0000h | 21.3.4/345 | | | 4000_A434 | Region Descriptor n, Word 1 (MPU_RGD3_WORD1) | 32 | R/W | See section | 21.3.5/345 | | | 4000_A438 | Region Descriptor n, Word 2 (MPU_RGD3_WORD2) | 32 | R/W | See section | 21.3.6/346 | | | 4000_A43C | Region Descriptor n, Word 3 (MPU_RGD3_WORD3) | 32 | R/W | See section | 21.3.7/349 | | | 4000_A440 | Region Descriptor n, Word 0 (MPU_RGD4_WORD0) | 32 | R/W | 0000_0000h | 21.3.4/345 | | | 4000_A444 | Region Descriptor n, Word 1 (MPU_RGD4_WORD1) | 32 | R/W | See section | 21.3.5/345 | | | 4000_A448 | Region Descriptor n, Word 2 (MPU_RGD4_WORD2) | 32 | R/W | See section | 21.3.6/346 | | | 4000_A44C | Region Descriptor n, Word 3 (MPU_RGD4_WORD3) | 32 | R/W | See section | 21.3.7/349 | | | 4000_A450 | Region Descriptor n, Word 0 (MPU_RGD5_WORD0) | 32 | R/W | 0000_0000h | 21.3.4/345 | | | 4000_A454 | Region Descriptor n, Word 1 (MPU_RGD5_WORD1) | 32 | R/W | See section | 21.3.5/345 | | | 4000_A458 | Region Descriptor n, Word 2 (MPU_RGD5_WORD2) | 32 | R/W | See section | 21.3.6/346 | | | 4000_A45C | Region Descriptor n, Word 3 (MPU_RGD5_WORD3) | 32 | R/W | See section | 21.3.7/349 | | | 4000_A460 | Region Descriptor n, Word 0 (MPU_RGD6_WORD0) | 32 | R/W | 0000_0000h | 21.3.4/345 | | | 4000_A464 | Region Descriptor n, Word 1 (MPU_RGD6_WORD1) | 32 | R/W | See section | 21.3.5/345 | | | 4000_A468 | Region Descriptor n, Word 2 (MPU_RGD6_WORD2) | 32 | R/W | See section | 21.3.6/346 | | | 4000_A46C | Region Descriptor n, Word 3 (MPU_RGD6_WORD3) | 32 | R/W | See section | 21.3.7/349 | | | 4000_A470 | Region Descriptor n, Word 0 (MPU_RGD7_WORD0) | 32 | R/W | 0000_0000h | 21.3.4/345 | | | 4000_A474 | Region Descriptor n, Word 1 (MPU_RGD7_WORD1) | 32 | R/W | See section | 21.3.5/345 | | | 4000_A478 | Region Descriptor n, Word 2 (MPU_RGD7_WORD2) | 32 | R/W | See section | 21.3.6/346 | | | 4000_A47C | Region Descriptor n, Word 3 (MPU_RGD7_WORD3) | 32 | R/W | See section | 21.3.7/349 | | ### MPU memory map (continued) | Absolute<br>address<br>(hex) | Register name | Width<br>(in bits) | Access | Reset value | Section/<br>page | |------------------------------|------------------------------------------------------------|--------------------|------------|-------------|------------------| | 4000_A800 | Region Descriptor Alternate Access Control n (MPU_RGDAAC0) | 32 | R/W | See section | 21.3.8/350 | | 4000_A804 | Region Descriptor Alternate Access Control n (MPU_RGDAAC1) | See section | 21.3.8/350 | | | | 4000_A808 | Region Descriptor Alternate Access Control n (MPU_RGDAAC2) | 32 | R/W | See section | 21.3.8/350 | | 4000_A80C | Region Descriptor Alternate Access Control n (MPU_RGDAAC3) | 32 | R/W | See section | 21.3.8/350 | | 4000_A810 | Region Descriptor Alternate Access Control n (MPU_RGDAAC4) | 32 | R/W | See section | 21.3.8/350 | | 4000_A814 | Region Descriptor Alternate Access Control n (MPU_RGDAAC5) | 32 | R/W | See section | 21.3.8/350 | | 4000_A818 | Region Descriptor Alternate Access Control n (MPU_RGDAAC6) | 32 | R/W | See section | 21.3.8/350 | | 4000_A81C | Region Descriptor Alternate Access Control n (MPU_RGDAAC7) | 32 | R/W | See section | 21.3.8/350 | ## 21.3.1 Control/Error Status Register (MPU\_CESR) Address: 4000\_A000h base + 0h offset = 4000\_A000h #### MPU\_CESR field descriptions | Field | Description | |----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31–30<br>SPERR | Slave Port n Error Indicates a captured error in EARn and EDRn. This bit is set when the hardware detects an error and records the faulting address and attributes. It is cleared by writing one to it. If another error is captured at the exact same cycle as the write, the flag remains set. A find-first-one instruction or equivalent can detect the presence of a captured error. | | | The following shows the correspondence between the bit number and slave port number: • Bit 31 corresponds to slave port 0. • Bit 30 corresponds to slave port 1. | Table continues on the next page... #### wemory map/register definition ## MPU\_CESR field descriptions (continued) | Field | Description | | | | | | | |-------------------|---------------------------------------------------------------------------------------------------------|--|--|--|--|--|--| | | 0 No error has occurred for slave port n. | | | | | | | | | 1 An error has occurred for slave port n. | | | | | | | | 29–24 | This field is reserved. | | | | | | | | Reserved | This read-only field is reserved and always has the value 0. | | | | | | | | 23 | This field is reserved. | | | | | | | | Reserved | This read-only field is reserved and always has the value 1. | | | | | | | | 22–20<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | | | | | | | 19–16 | Hardware Revision Level | | | | | | | | HRL | Hardware Revision Level | | | | | | | | | Specifies the MPU's hardware and definition revision level. It can be read by software to determine the | | | | | | | | | functional definition of the module. | | | | | | | | 15–12 | Number Of Slave Ports | | | | | | | | NSP | Specifies the number of slave ports connected to the MPU. | | | | | | | | 11–8 | Number Of Region Descriptors | | | | | | | | NRGD | Indicates the number of region descriptors implemented in the MPU. | | | | | | | | | indicates the number of region descriptors implemented in the IVII o. | | | | | | | | | 0000 8 region descriptors | | | | | | | | | 0001 12 region descriptors | | | | | | | | | 0010 16 region descriptors | | | | | | | | 7–1 | This field is reserved. | | | | | | | | Reserved | This read-only field is reserved and always has the value 0. | | | | | | | | 0<br>VLD | Valid | | | | | | | | VLD | Global enable/disable for the MPU. | | | | | | | | | | | | | | | | | | 0 MPU is disabled. All accesses from all bus masters are allowed. | | | | | | | | | 1 MPU is enabled | | | | | | | ## 21.3.2 Error Address Register, slave port n (MPU\_EARn) When the MPU detects an access error on slave port n, the 32-bit reference address is captured in this read-only register and the corresponding bit in CESR[SPERR] set. Additional information about the faulting access is captured in the corresponding EDRn at the same time. This register and the corresponding EDRn contain the most recent access error; there are no hardware interlocks with CESR[SPERR], as the error registers are always loaded upon the occurrence of each protection violation. <sup>\*</sup> Notes: x = Undefined at reset. #### MPU\_EARn field descriptions | Field | Description | |---------------|-----------------------------------------------------------------------------------| | 31–0<br>EADDR | Error Address | | | Indicates the reference address from slave port n that generated the access error | ## 21.3.3 Error Detail Register, slave port n (MPU\_EDRn) When the MPU detects an access error on slave port n, 32 bits of error detail are captured in this read-only register and the corresponding bit in CESR[SPERR] is set. Information on the faulting address is captured in the corresponding EARn register at the same time. This register and the corresponding EARn register contain the most recent access error; there are no hardware interlocks with CESR[SPERR] as the error registers are always loaded upon the occurrence of each protection violation. <sup>\*</sup> Notes: #### MPU\_EDRn field descriptions | Field | Description | |---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31–16<br>EACD | Error Access Control Detail Indicates the region descriptor with the access error. | | | If EDRn contains a captured error and EACD is cleared, an access did not hit in any region descriptor. | | | <ul> <li>If only a single EACD bit is set, the protection error was caused by a single non-overlapping region<br/>descriptor.</li> </ul> | | | <ul> <li>If two or more EACD bits are set, the protection error was caused by an overlapping set of region<br/>descriptors.</li> </ul> | | 15–8<br>EPID | Error Process Identification | | | Records the process identifier of the faulting reference. The process identifier is typically driven only by processor cores; for other bus masters, this field is cleared. | | 7–4<br>EMN | Error Master Number | | | Indicates the bus master that generated the access error. | | 3–1<br>EATTR | Error Attributes | | LAIIN | Indicates attribute information about the faulting reference. | | | NOTE: All other encodings are reserved. | x = Undefined at reset. #### MPU\_EDRn field descriptions (continued) | Field | Description | | | | | | | | | | |-------|------------------------------------------------------|--|--|--|--|--|--|--|--|--| | | 000 User mode, instruction access | | | | | | | | | | | | 001 User mode, data access | | | | | | | | | | | | 010 Supervisor mode, instruction access | | | | | | | | | | | | 011 Supervisor mode, data access | | | | | | | | | | | 0 | Error Read/Write | | | | | | | | | | | ERW | Indicates the access type of the faulting reference. | | | | | | | | | | | | 0 Read | | | | | | | | | | | | 1 Write | | | | | | | | | | ## 21.3.4 Region Descriptor n, Word 0 (MPU\_RGDn\_WORD0) The first word of the region descriptor defines the 0-modulo-32 byte start address of the memory region. Writes to this register clear the region descriptor's valid bit (RGDn\_WORD3[VLD]). #### **NOTE** RGD0\_WORD0 register is read-only. Write access to RGD0\_WORD0 generates error. #### MPU\_RGDn\_WORD0 field descriptions | Field | Description | |-----------------|-----------------------------------------------------------------------------------------------| | 31–5<br>SRTADDR | Start Address | | | Defines the most significant bits of the 0-modulo-32 byte start address of the memory region. | | 4–0<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | ## 21.3.5 Region Descriptor n, Word 1 (MPU\_RGDn\_WORD1) The second word of the region descriptor defines the 31-modulo-32 byte end address of the memory region. Writes to this register clear the region descriptor's valid bit (RGDn\_WORD3[VLD]). #### NOTE RGD0\_WORD1 register is read-only. Write access to RGD0\_WORD1 generates error. Address: $4000\_A000h$ base + 404h offset + $(16d \times i)$ , where i=0d to 7d - \* Notes: - Reset value for MPU\_RGD0\_WORD1 is FFFF\_FFFFh Reset value for MPU\_RGD[1:7]\_WORD1 is 0000\_001Fh #### MPU\_RGDn\_WORD1 field descriptions | Field | Description | | | | | | |-----------------|----------------------------------------------------------------------------------------------|--|--|--|--|--| | 31–5 | End Address | | | | | | | ENDADDR | Defines the most significant bits of the 31-modulo-32 byte end address of the memory region. | | | | | | | | NOTE: The MPU does not verify that ENDADDR ≥ SRTADDR. | | | | | | | 4–0<br>Reserved | This field is reserved. | | | | | | ## 21.3.6 Region Descriptor n, Word 2 (MPU\_RGDn\_WORD2) The third word of the region descriptor defines the access control rights of the memory region. The access control privileges depend on two broad classifications of bus masters: - Bus masters 0–3 have a 5-bit field defining separate privilege rights for user and supervisor mode accesses, as well as the optional inclusion of a process identification field within the definition. - Bus masters 4–7 are limited to separate read and write permissions. For the privilege rights of bus masters 0–3, there are three flags associated with this function: - Read (r) refers to accessing the referenced memory address using an operand (data) fetch - Write (w) refers to updating the referenced memory address using a store (data) instruction - Execute (x) refers to reading the referenced memory address using an instruction fetch Writes to RGDn\_WORD2 clear the region descriptor's valid bit (RGDn\_WORD3[VLD]). If only updating the access controls, write to RGDAACn instead because stores to these locations do not affect the descriptor's valid bit. Address: $4000\_A000h$ base + 408h offset + $(16d \times i)$ , where i=0d to 7d | Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |--------|----------|------|------|------|------|----------------|------|------|------|----|------|----|------|----|------|----------| | R<br>W | M7RE | M7WE | MGRE | M6WE | M5RE | M5WE | M4RE | M4WE | M3PE | МЗ | SM | | мзим | | M2PE | M2S<br>M | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | R<br>W | M2S<br>M | | M2UM | | M1PE | M1SM M1UM Bd0W | | MC | )SM | | MOUM | | | | | | | Reset | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | <sup>\*</sup> Notes: Reset value for MPU\_RGD[1:7]\_WORD2 is 0000\_0000h ## MPU\_RGDn\_WORD2 field descriptions | Field | Description | |------------|-------------------------------------------------------------------------------------| | 31<br>M7RE | Bus Master 7 Read Enable | | | 0 Bus master 7 reads terminate with an access error and the read is not performed | | | 1 Bus master 7 reads allowed | | 30<br>M7WE | Bus Master 7 Write Enable | | | 0 Bus master 7 writes terminate with an access error and the write is not performed | | | 1 Bus master 7 writes allowed | | 29<br>M6RE | Bus Master 6 Read Enable | | | 0 Bus master 6 reads terminate with an access error and the read is not performed | | | 1 Bus master 6 reads allowed | | 28<br>M6WE | Bus Master 6 Write Enable | | | 0 Bus master 6 writes terminate with an access error and the write is not performed | | | 1 Bus master 6 writes allowed | | 27<br>M5RE | Bus Master 5 Read Enable | | | 0 Bus master 5 reads terminate with an access error and the read is not performed | | | 1 Bus master 5 reads allowed | | 26<br>M5WE | Bus Master 5 Write Enable | | | 0 Bus master 5 writes terminate with an access error and the write is not performed | | | 1 Bus master 5 writes allowed | Table continues on the next page... Reset value for MPU\_RGD0\_WORD2 is 0001\_F01Fh #### wemory map/register definition ## MPU\_RGDn\_WORD2 field descriptions (continued) | Field | Description | |---------------|------------------------------------------------------------------------------------------------------| | 25 | Bus Master 4 Read Enable | | M4RE | Bus master 4 reads terminate with an access error and the read is not performed | | | 1 Bus master 4 reads allowed | | 24 | Bus Master 4 Write Enable | | M4WE | Bus master 4 writes terminate with an access error and the write is not performed | | | 1 Bus master 4 writes allowed | | 23 | Bus Master 3 Process Identifier Enable | | M3PE | 0 Do not include the process identifier in the evaluation | | | 1 Include the process identifier and mask (RGDn_WORD3) in the region hit evaluation | | 22–21<br>M2CM | Bus Master 3 Supervisor Mode Access Control | | M3SM | Defines the access controls for bus master 3 in Supervisor mode. | | | 00 r/w/x; read, write and execute allowed | | | 01 r/x; read and execute allowed, but no write | | | 10 r/w; read and write allowed, but no execute | | | 11 Same as User mode defined in M3UM | | 20–18 | Bus Master 3 User Mode Access Control | | МЗИМ | Defines the access controls for bus master 3 in User mode. M3UM consists of three independent bits, | | | enabling read (r), write (w), and execute (x) permissions. | | | 0 An attempted access of that mode may be terminated with an access error (if not allowed by another | | | descriptor) and the access not performed. | | | 1 Allows the given access type to occur | | 17<br>M2PE | Bus Master 2 Process Identifier Enable | | IVIZPE | See M3PE description. | | 16–15 | Bus Master 2 Supervisor Mode Access Control | | M2SM | See M3SM description. | | 14–12 | Bus Master 2 User Mode Access control | | M2UM | See M3UM description. | | 11 | Bus Master 1 Process Identifier enable | | M1PE | See M1PE description. | | 10–9 | Bus Master 1 Supervisor Mode Access Control | | M1SM | | | | See M3SM description. | | 8–6<br>M1UM | Bus Master 1 User Mode Access Control | | | See M3UM description. | | 5 | Bus Master 0 Process Identifier enable | | M0PE | See M0PE description. | | | | #### MPU\_RGDn\_WORD2 field descriptions (continued) | Field | Description | |-------------|---------------------------------------------| | 4–3<br>M0SM | Bus Master 0 Supervisor Mode Access Control | | | See M3SM description. | | 2–0<br>M0UM | Bus Master 0 User Mode Access Control | | | See M3UM description. | ## 21.3.7 Region Descriptor n, Word 3 (MPU\_RGDn\_WORD3) The fourth word of the region descriptor contains the optional process identifier and mask, plus the region descriptor's valid bit. #### **NOTE** RGD0\_WORD3 register is read-only. Write access to RGD0\_WORD3 generates error. Address: $4000\_A000h$ base + 40Ch offset + $(16d \times i)$ , where i=0d to 7d | Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |--------|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|-----| | R<br>W | | | | P | ID | | | | | | | PIDM | IASK | | | | | 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 | | | | | | | | 0 | | | | | | | | VLD | | w | | | | | | | | | | | | | | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | <sup>\*</sup> Notes: Reset value for MPU\_RGD[1:7]\_WORD3 is 0000\_0000h #### MPU\_RGDn\_WORD3 field descriptions | Field | Description | |------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31–24<br>PID | Process Identifier | | | Specifies the process identifier that is included in the region hit determination if RGDn_WORD2[MxPE] is set. PIDMASK can mask individual bits in this field. | | 23–16<br>PIDMASK | Process Identifier Mask | | | Provides a masking capability so that multiple process identifiers can be included as part of the region hit determination. If a bit in PIDMASK is set, then the corresponding PID bit is ignored in the comparison. This field and PID are included in the region hit determination if RGDn_WORD2[MxPE] is set. For more information on the handling of the PID and PIDMASK, see "Access Evaluation - Hit Determination." | | 15–1<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | Table continues on the next page... <sup>•</sup> Reset value for MPU\_RGD0\_WORD3 is 0000\_0001h #### wemory map/register definition #### MPU\_RGDn\_WORD3 field descriptions (continued) | Field | Description | |-------|------------------------------------------------------------------------------------| | 0 | Valid | | VLD | Cinnale the maries described in called Associate to DODs WODDO O cleans this hit | | | Signals the region descriptor is valid. Any write to RGDn_WORD0–2 clears this bit. | | | 0 Region descriptor is invalid | | | 1 Region descriptor is valid | ## 21.3.8 Region Descriptor Alternate Access Control n (MPU\_RGDAACn) Because software may adjust only the access controls within a region descriptor (RGDn\_WORD2) as different tasks execute, an alternate programming view of this 32-bit entity is available. Writing to this register does not affect the descriptor's valid bit. Address: $4000\_A000h$ base + 800h offset + $(4d \times i)$ , where i=0d to 7d | Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |--------|----------|------|------|------|------|------|------|------|------|----|------|----|------|----|------|----------| | R<br>W | M7RE | M7WE | MGRE | M6WE | M5RE | M5WE | M4RE | M4WE | M3PE | МЗ | SM | | МЗИМ | | M2PE | M2S<br>M | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | R<br>W | M2S<br>M | | M2UM | | M1PE | M1 | SM | M1UM | | | MOPE | МС | )SM | | MOUM | | | Reset | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | <sup>\*</sup> Notes: #### MPU\_RGDAACn field descriptions | Field | Description | |------------|---------------------------------------------------------------------------------| | 31<br>M7RE | Bus Master 7 Read Enable | | | Bus master 7 reads terminate with an access error and the read is not performed | | | 1 Bus master 7 reads allowed | | 30<br>M7WE | Bus Master 7 Write Enable | Reset value for MPU\_RGDAAC0 is 0001\_F01Fh Reset value for MPU\_RGDAAC[1:7] is 0000\_0000h ## MPU\_RGDAACn field descriptions (continued) | Field | Description | |---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------| | | 0 Bus master 7 writes terminate with an access error and the write is not performed | | | 1 Bus master 7 writes allowed | | 29<br>M6RE | Bus Master 6 Read Enable | | IVIONE | Bus master 6 reads terminate with an access error and the read is not performed | | | 1 Bus master 6 reads allowed | | 28<br>M6WE | Bus Master 6 Write Enable | | | Bus master 6 writes terminate with an access error and the write is not performed Bus master 6 writes allowed | | 07 | | | 27<br>M5RE | Bus Master 5 Read Enable | | | 0 Bus master 5 reads terminate with an access error and the read is not performed 1 Bus master 5 reads allowed | | 26 | Bus Master 5 Write Enable | | M5WE | Bus Master 3 Write Enable | | | 0 Bus master 5 writes terminate with an access error and the write is not performed | | | 1 Bus master 5 writes allowed | | 25<br>M4RE | Bus Master 4 Read Enable | | IVI4NC | 0 Bus master 4 reads terminate with an access error and the read is not performed | | | 1 Bus master 4 reads allowed | | 24<br>M4WE | Bus Master 4 Write Enable | | M4WE | 0 Bus master 4 writes terminate with an access error and the write is not performed | | | 1 Bus master 4 writes allowed | | 23<br>M3PE | Bus Master 3 Process Identifier Enable | | | 0 Do not include the process identifier in the evaluation | | | 1 Include the process identifier and mask (RGDn.RGDAAC) in the region hit evaluation | | 22–21<br>M3SM | Bus Master 3 Supervisor Mode Access Control | | IVICCIVI | Defines the access controls for bus master 3 in Supervisor mode. | | | 00 r/w/x; read, write and execute allowed | | | 01 r/x; read and execute allowed, but no write | | | 10 r/w; read and write allowed, but no execute | | | 11 Same as User mode defined in M3UM | | 20–18 | Bus Master 3 User Mode Access Control | | M3UM | Defines the access controls for bus master 3 in user mode. M3UM consists of three independent bits, enabling read (r), write (w), and execute (x) permissions. | | | O An attempted access of that mode may be terminated with an access error (if not allowed by another descriptor) and the access not performed. | | | 1 Allows the given access type to occur | | 17<br>MODE | Bus Master 2 Process Identifier Enable | | M2PE | See M3PE description. | #### runctional description #### MPU\_RGDAACn field descriptions (continued) | Field | Description | |---------------|---------------------------------------------| | 16–15<br>M2SM | Bus Master 2 Supervisor Mode Access Control | | | See M3SM description. | | 14–12<br>M2UM | Bus Master 2 User Mode Access Control | | | See M3UM description. | | 11<br>M1PE | Bus Master 1 Process Identifier Enable | | | See M3PE description. | | 10-9<br>M1SM | Bus Master 1 Supervisor Mode Access Control | | | See M3SM description. | | 8–6<br>M1UM | Bus Master 1 User Mode Access Control | | | See M3UM description. | | 5<br>M0PE | Bus Master 0 Process Identifier Enable | | | See M3PE description. | | 4–3<br>M0SM | Bus Master 0 Supervisor Mode Access Control | | | See M3SM description. | | 2–0<br>M0UM | Bus Master 0 User Mode Access Control | | IVIUUIVI | See M3UM description. | ## 21.4 Functional description In this section, the functional operation of the MPU is detailed, including the operation of the access evaluation macro and the handling of error-terminated bus cycles. ## 21.4.1 Access evaluation macro The basic operation of the MPU is performed in the access evaluation macro, a hardware structure replicated in the two-dimensional connection matrix. As shown in the following figure, the access evaluation macro inputs the crossbar bus address phase signals and the contents of a region descriptor (RGDn) and performs two major functions: - Region hit determination - Detection of an access protection violation The following figure shows a functional block diagram. 353 Figure 21-54. MPU access evaluation macro #### 21.4.1.1 Hit determination To determine whether the current reference hits in the given region, two magnitude comparators are used with the region's start and end addresses. The boolean equation for this portion of the hit determination is: ``` \label{eq:region_hit} $$ region_hit = ((addr[31:5] >= RGDn_Word0[SRTADDR]) & (addr[31:5] <= RGDn_Word1[ENDADDR])) & RGDn_Word3[VLD] \\ ``` where addr is the current reference address, RGD*n*\_Word0[SRTADDR] and RGD*n*\_Word1[ENDADDR] are the start and end addresses, and RGD*n*\_Word3[VLD] is the valid bit. #### NOTE The MPU does not verify that ENDADDR ≥ SRTADDR. In addition to the comparison of the reference address versus the region descriptor's start and end addresses, the optional process identifier is examined against the region descriptor's PID and PIDMASK fields. A process identifier hit term is formed as follows: where the current\_pid is the selected process identifier from the current bus master, and RGDn\_Word3[PID] and RGDn\_Word3[PIDMASK] are the process identifier fields from region descriptor *n*. For bus masters that do not output a process identifier, the MPU forces the pid\_hit term to assert. #### NOTE In the supervisor mode pid\_hit term is always asserted. ## 21.4.1.2 Privilege violation determination While the access evaluation macro is determining region hit, the logic is also evaluating if the current access is allowed by the permissions defined in the region descriptor. Using the master and supervisor/user mode signals, a set of effective permissions is generated from the appropriate fields in the region descriptor. The protection violation logic then evaluates the access against the effective permissions using the specification shown below. | | | MxUM | | Protection | | | |------------------------|---|------|---|----------------------------|--|--| | Description | r | w | х | violation? | | | | Instruction fetch read | _ | _ | 0 | Yes, no execute permission | | | | mstruction letch read | _ | _ | 1 | No, access is allowed | | | | Data read | 0 | _ | _ | Yes, no read permission | | | | Data read | 1 | _ | _ | No, access is allowed | | | | Data write | _ | 0 | _ | Yes, no write permission | | | | Data while | _ | 1 | _ | No, access is allowed | | | Table 21-54. Protection violation definition ## 21.4.2 Putting it all together and error terminations For each slave port monitored, the MPU performs a reduction-AND of all the individual terms from each access evaluation macro. This expression then terminates the bus cycle with an error and reports a protection error for three conditions: - If the access does not hit in any region descriptor, a protection error is reported. - If the access hits in a single region descriptor and that region signals a protection violation, a protection error is reported. - If the access hits in multiple (overlapping) regions and all regions signal protection violations, a protection error is reported. As shown in the third condition, granting permission is a higher priority than denying access for overlapping regions. This approach is more flexible to system software in region descriptor assignments. For an example of the use of overlapping region descriptors, see Application information. ## 21.4.3 Power management Disabling the MPU by clearing CESR[VLD] minimizes power dissipation. To minimize the power dissipation of an enabled MPU, invalidate unused region descriptors by clearing the associated RGDn\_Word3[VLD] bits. #### 21.5 Initialization information At system startup, load the appropriate number of region descriptors, including setting RGD*n*\_Word3[VLD]. Setting CESR[VLD] enables the module. If the system requires that all the loaded region descriptors be enabled simultaneously, first ensure that the entire MPU is disabled (CESR[VLD]=0). #### Note A region descriptor must be set to allow access to the MPU registers if further changes are needed. ## 21.6 Application information In an operational system, interfacing with the MPU is generally classified into the following activities: - Creating a new memory region—Load the appropriate region descriptor into an available RGDn, using four sequential 32-bit writes. The hardware assists in the maintenance of the valid bit, so if this approach is followed, there are no coherency issues with the multi-cycle descriptor writes. (Clearing RGDn\_Word3[VLD] deletes/removes an existing memory region.) - Altering only access privileges—To not affect the valid bit, write to the alternate version of the access control word (RGDAACn), so there are no coherency issues involved with the update. When the write completes, the memory region's access rights switch instantaneously to the new value. - Changing a region's start and end addresses—Write a minimum of three words to the region descriptor (RGDn\_Word{0,1,3}). Word 0 and 1 redefine the start and end addresses, respectively. Word 3 re-enables the region descriptor valid bit. In most situations, all four words of the region descriptor are rewritten. - Accessing the MPU—Allocate a region descriptor to restrict MPU access to supervisor mode from a specific master. #### **Application information** - Detecting an access error—The current bus cycle is terminated with an error response and EAR*n* and EDR*n* capture information on the faulting reference. The error-terminated bus cycle typically initiates an error response in the originating bus master. For example, a processor core may respond with a bus error exception, while a data movement bus master may respond with an error interrupt. The processor can retrieve the captured error address and detail information simply by reading E{A,D}R*n*. CESR[SPERR] signals which error registers contain captured fault data. - Overlapping region descriptors—Applying overlapping regions often reduces the number of descriptors required for a given set of access controls. In the overlapping memory space, the protection rights of the corresponding region descriptors are logically summed together (the boolean OR operator). The following dual-core system example contains four bus masters: - The two processors: CP0, CP1 - Two DMA engines: DMA1, a traditional data movement engine transferring data between RAM and peripherals and DMA2, a second engine transferring data to/ from the RAM only Consider the following region descriptor assignments: **Region description RGDn** CP<sub>0</sub> CP1 DMA<sub>1</sub> DMA2 CP0 code 0 rwx r--Flash CP1 code 1 r-rwx 2 CP0 data & stack rw-CP0 → CP1 shared data 2 3 r--**RAM** CP1 → CP0 shared data CP1 data & stack 4 rw-Shared DMA data 5 rwrwrw rw MPU 6 rwrw-Peripheral 7 space Peripherals rwrwrw Table 21-55. Overlapping region descriptor example In this example, there are eight descriptors used to span nine regions in the three main spaces of the system memory map: flash, RAM, and peripheral space. Each region indicates the specific permissions for each of the four bus masters and this definition provides an appropriate set of shared, private and executable memory spaces. Of particular interest are the two overlapping spaces: region descriptors 2 & 3 and 3 & 4. The space defined by RGD2 with no overlap is a private data and stack area that provides read/write access to CP0 only. The overlapping space between RGD2 and RGD3 defines a shared data space for passing data from CP0 to CP1 and the access controls are defined by the logical OR of the two region descriptors. Thus, CP0 has (rw-|r--)=(rw-) permissions, while CP1 has (---|r--)=(r--) permission in this space. Both DMA engines are excluded from this shared processor data region. The overlapping spaces between RGD3 and RGD4 defines another shared data space, this one for passing data from CP1 to CP0. For this overlapping space, CP0 has (r--|---)=(r--) permission, while CP1 has (rw-|r--)=(rw-) permission. The non-overlapped space of RGD4 defines a private data and stack area for CP1 only. The space defined by RGD5 is a shared data region, accessible by all four bus masters. Finally, the slave peripheral space mapped onto the IPS bus is partitioned into two regions: - One containing the MPU's programming model accessible only to the two processor cores - The remaining peripheral region accessible to both processors and the traditional DMA1 master This example shows one possible application of the capabilities of the MPU in a typical system. Application information # **Chapter 22 Power Management Controller (PMC)** #### 22.1 Introduction #### **NOTE** For the chip-specific implementation details of this module's instances, see the chip configuration information. The power management controller (PMC) contains the internal voltage regulator, power on reset (POR), and low voltage detect system. See AN4503: Power Management for Kinetis and ColdFire+ MCUs for further details on using the PMC. ## 22.2 Features A list of included PMC features can be found here. - 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 ## 22.3 Low-voltage detect (LVD) system This device includes a system to guard against low-voltage conditions. This protects memory contents and controls 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 LVDSC1[LVDV]. The LVD is disabled upon entering VLPx and VLLSx modes. KM Family Reference Manual, Rev. 5, Oct 2013 359 #### Low-voltage detect (LVD) system Two flags are available to indicate the status of the low-voltage detect system: - The Low Voltage Detect Flag in the Low Voltage Status and Control 1 Register (LVDSC1[LVDF]) operates in a level sensitive manner. LVDSC1[LVDF] is set when the supply voltage falls below the selected trip point (VLVD). LVDSC1[LVDF] is cleared by writing 1 to LVDSC1[LVDACK], but only if the internal supply has returned above the trip point; otherwise, LVDSC1[LVDF] remains set. - The Low Voltage Warning Flag (LVWF) in the Low Voltage Status and Control 2 Register (LVDSC2[LVWF]) operates in a level sensitive manner. LVDSC2[LVWF] is set when the supply voltage falls below the selected monitor trip point (VLVW). LVDSC2[LVWF] is cleared by writing one to LVDSC2[LVWACK], but only if the internal supply has returned above the trip point; otherwise, LVDSC2[LVWF] remains set. ## 22.3.1 LVD reset operation By setting LVDSC1[LVDRE], the LVD generates a reset upon detection of a low-voltage condition. The low-voltage detection threshold is determined by LVDSC1[LVDV]. After an LVD reset occurs, the LVD system holds the MCU in reset until the supply voltage rises above this threshold. The LVD field in the SRS register of the RCM module (RCM\_SRS0[LVD]) is set following an LVD or power-on reset. ## 22.3.2 LVD interrupt operation By configuring the LVD circuit for interrupt operation (LVDSC1[LVDIE] set and LVDSC1[LVDRE] clear), LVDSC1[LVDF] is set and an LVD interrupt request occurs upon detection of a low voltage condition. LVDSC1[LVDF] is cleared by writing 1 to LVDSC1[LVDACK]. ## 22.3.3 Low-voltage warning (LVW) interrupt operation The LVD system contains a Low-Voltage Warning Flag (LVWF) in the Low Voltage Detect Status and Control 2 Register 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 LVDSC2[LVWIE]. If enabled, an LVW interrupt request occurs when LVDSC2[LVWF] is set. LVDSC2[LVWF] is cleared by writing 1 to LVDSC2[LVWACK]. LVDSC2[LVWV] selects one of the 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> ## 22.4 I/O retention When in VLLS modes, the I/O states are held on a wake-up event (with the exception of wake-up by reset event) until the wake-up has been acknowledged via a write to REGSC[ACKISO]. 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 REGSC[ACKISO] is needed. # 22.5 Memory map and register descriptions Details about the PMC registers can be found here. #### **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 section details. The PMC registers can be written only in supervisor mode. Write accesses in user mode are blocked and will result in a bus error. ## **PMC** memory map | Absolute<br>address<br>(hex) | Register name | Width<br>(in bits) | Access | Reset value | Section/<br>page | |------------------------------|---------------------------------------------------------------|--------------------|--------|-------------|------------------| | 4007_D000 | Low Voltage Detect Status And Control 1 register (PMC_LVDSC1) | 8 | R/W | 10h | 22.5.1/362 | | 4007_D001 | Low Voltage Detect Status And Control 2 register (PMC_LVDSC2) | 8 | R/W | 00h | 22.5.2/363 | | 4007_D002 | Regulator Status And Control register (PMC_REGSC) | 8 | R/W | 04h | 22.5.3/364 | # 22.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 Power Mode Protection (PMPROT) register of the SMC module (SMC\_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 section details. ### PMC\_LVDSC1 field descriptions | Field | Description | |-------------|--------------------------------------------------------------------------------------------------------------------------| | 7 | Low-Voltage Detect Flag | | LVDF | This read-only status field 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 field is used to acknowledge low voltage detection errors. Write 1 to clear LVDF. Reads always return 0. | | 5 | Low-Voltage Detect Interrupt Enable | | LVDIE | 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 field is reserved. | | Reserved | This read-only field is reserved and always has the value 0. | | 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 <sub>LVD</sub> = V <sub>LVDL</sub> ) | | | 01 High trip point selected (V <sub>LVD</sub> = V <sub>LVDH</sub> ) | | | 10 Reserved | | | 11 Reserved | # 22.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. #### **NOTE** LVWV is reset solely on a POR Only event. The other fields of the register are reset on Chip Reset Not VLLS. For more information about these reset types, refer to the Reset section details. Address: 4007\_D000h base + 1h offset = 4007\_D001h #### memory map and register descriptions ## PMC\_LVDSC2 field descriptions | Field | Description | | | | | | | |-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--| | 7<br>LVWF | Low-Voltage Warning Flag | | | | | | | | LVWF | This read-only status field indicates a low-voltage warning event. LVWF is set when $V_{Supply}$ transitions below the trip point, or after reset and $V_{Supply}$ is already below $V_{LVW}$ . LVWF may be 1 after power-on reset, therefore, to use LVW interrupt function, before enabling LVWIE, LVWF must be cleared by writing LVWACK first. | | | | | | | | | 0 Low-voltage warning event not detected | | | | | | | | | 1 Low-voltage warning event detected | | | | | | | | 6<br>LVWACK | Low-Voltage Warning Acknowledge | | | | | | | | | This write-only field 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 | This field is reserved. | | | | | | | | Reserved | This read-only field is reserved and always has the value 0. | | | | | | | | 1–0<br>LVWV | Low-Voltage Warning Voltage Select | | | | | | | | | 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 <sub>LVW</sub> = V <sub>LVW1</sub> ) | | | | | | | | | 01 Mid 1 trip point selected (V <sub>LVW</sub> = V <sub>LVW2</sub> ) | | | | | | | | | 10 Mid 2 trip point selected (V <sub>LVW</sub> = V <sub>LVW3</sub> ) | | | | | | | | | 11 High trip point selected (V <sub>LVW</sub> = V <sub>LVW4</sub> ) | | | | | | | # 22.5.3 Regulator Status And Control register (PMC\_REGSC) The PMC 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 section details for more information. Address: 4007\_D000h base + 2h offset = 4007\_D002h ## PMC\_REGSC field descriptions | Field | Description | | | | | | | |-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--| | | · | | | | | | | | 7–6<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | | | | | | | 5<br>Reserved | This field is reserved. | | | | | | | | 4<br>BGEN | Bandgap Enable In VLPx Operation BGEN controls whether the bandgap is enabled in lower power modes of operation (VLPx, and VLLSx). When on-chip peripherals require the bandgap voltage reference in low power modes of operation, set BGEN to continue to enable the bandgap operation. | | | | | | | | | NOTE: When the bandgap voltage reference is not needed in low power modes, clear BGEN to avoid excess power consumption. | | | | | | | | | <ul> <li>Bandgap voltage reference is disabled in VLPx, and VLLSx modes.</li> <li>Bandgap voltage reference is enabled in VLPx, and VLLSx modes.</li> </ul> | | | | | | | | 3 | Acknowledge Isolation | | | | | | | | ACKISO | Reading this field 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 1 to this field 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. | | | | | | | | | 0 Peripherals and I/O pads are in normal run state. | | | | | | | | | 1 Certain peripherals and I/O pads are in an isolated and latched state. | | | | | | | | 2<br>REGONS | Regulator In Run Regulation Status | | | | | | | | | This read-only field provides the current status of the internal voltage regulator. | | | | | | | | | 0 Regulator is in stop regulation or in transition to/from it | | | | | | | | | 1 Regulator is in run regulation | | | | | | | | 1<br>BGBDS | Bandgap Buffer Drive Select | | | | | | | | BODDS | Selects the bandgap buffer drive. | | | | | | | | | NOTE: If the bandgap buffer is disabled (BGBE is clear), clear BGBDS. | | | | | | | | | 0 Low drive 1 High drive | | | | | | | | 0 | Bandgap Buffer Enable | | | | | | | | BGBE | Enables the bandgap buffer. | | | | | | | | | Bandgap buffer not enabled Bandgap buffer enabled | | | | | | | | | | | | | | | | wemory map and register descriptions # **Chapter 23 Watchdog Timer (WDOG)** ## 23.1 Introduction #### **NOTE** For the chip-specific implementation details of this module's instances, see the chip configuration information. The Watchdog Timer (WDOG) keeps a watch on the system functioning and resets it in case of its failure. Reasons for failure include run-away software code and the stoppage of the system clock that in a safety critical system can lead to serious consequences. In such cases, the watchdog brings the system into a safe state of operation. The watchdog monitors the operation of the system by expecting periodic communication from the software, generally known as servicing or refreshing the watchdog. If this periodic refreshing does not occur, the watchdog resets the system. ## 23.2 Features The features of the Watchdog Timer (WDOG) include: - Clock source input independent from CPU/bus clock. Choice between two clock sources: - Low-power oscillator (LPO) - External system clock - Unlock sequence for allowing updates to write-once WDOG control/configuration bits. - All WDOG control/configuration bits are writable once only within 256 bus clock cycles of being unlocked. #### reautres - You need to always update these bits after unlocking within 256 bus clock cycles. Failure to update these bits resets the system. - Programmable time-out period specified in terms of number of WDOG clock cycles. - Ability to test WDOG timer and reset with a flag indicating watchdog test. - Quick test—Small time-out value programmed for quick test. - Byte test—Individual bytes of timer tested one at a time. - Read-only access to the WDOG timer—Allows dynamic check that WDOG timer is operational. #### NOTE Reading the watchdog timer counter while running the watchdog on the bus clock might not give the accurate counter value. - Windowed refresh option - Provides robust check that program flow is faster than expected. - Programmable window. - Refresh outside window leads to reset. - Robust refresh mechanism - Write values of 0xA602 and 0xB480 to WDOG Refresh Register within 20 bus clock cycles. - Count of WDOG resets as they occur. - Configurable interrupt on time-out to provide debug breadcrumbs. This is followed by a reset after 256 bus clock cycles. ## 23.3 Functional overview Figure 23-1. WDOG operation The preceding figure shows the operation of the watchdog. The values for N and K are: - N = 256 - K = 20 The watchdog is a fail safe mechanism that brings the system into a known initial state in case of its failure due to CPU clock stopping or a run-away condition in code execution. In its simplest form, the watchdog timer runs continuously off a clock source and expects #### runctional overview to be serviced periodically, failing which it resets the system. This ensures that the software is executing correctly and has not run away in an unintended direction. Software can adjust the period of servicing or the time-out value for the watchdog timer to meet the needs of the application. You can select a windowed mode of operation that expects the servicing to be done only in a particular window of the time-out period. An attempted servicing of the watchdog outside this window results in a reset. By operating in this mode, you can get an indication of whether the code is running faster than expected. The window length is also user programmable. If a system fails to update/refresh the watchdog due to an unknown and persistent cause, it will be caught in an endless cycle of resets from the watchdog. To analyze the cause of such conditions, you can program the watchdog to first issue an interrupt, followed by a reset. In the interrupt service routine, the software can analyze the system stack to aid debugging. To enhance the independence of watchdog from the system, it runs off an independent LPO oscillator clock. You can also switch over to an alternate clock source if required, through a control register bit. # 23.3.1 Unlocking and updating the watchdog As long as ALLOW\_UPDATE in the watchdog control register is set, you can unlock and modify the write-once-only control and configuration registers: - 1. Write 0xC520 followed by 0xD928 within 20 bus clock cycles to a specific unlock register (WDOG\_UNLOCK). - 2. Wait one bus clock cycle. You cannot update registers on the bus clock cycle immediately following the write of the unlock sequence. - 3. An update window equal in length to the watchdog configuration time (WCT) opens. Within this window, you can update the configuration and control register bits. These register bits can be modified only once after unlocking. If none of the configuration and control registers is updated within the update window, the watchdog issues a reset, that is, interrupt-then-reset, to the system. Trying to unlock the watchdog within the WCT after an initial unlock has no effect. During the update operation, the watchdog timer is not paused and continues running in the background. After the update window closes, the watchdog timer restarts and the watchdog functions according to the new configuration. The update feature is useful for applications that have an initial, non-safety critical part, where the watchdog is kept disabled or with a conveniently long time-out period. This means the application coder does not have to frequently service the watchdog. After the critical part of the application begins, the watchdog can be reconfigured as needed. The watchdog issues a reset, that is, interrupt-then-reset if enabled, to the system for any of these invalid unlock sequences: - Write any value other than 0xC520 or 0xD928 to the unlock register. - ALLOW\_UPDATE is set and a gap of more than 20 bus clock cycles is inserted between the writing of the unlock sequence values. An attempted refresh operation between the two writes of the unlock sequence and in the WCT time following a successful unlock, goes undetected. Also, see Watchdog Operation with 8-bit access for guidelines related to 8-bit accesses to the unlock register. #### Note A context switch during unlocking and refreshing may lead to a watchdog reset. # 23.3.2 Watchdog configuration time (WCT) To prevent unintended modification of the watchdog's control and configuration register bits, you are allowed to update them only within a period of 256 bus clock cycles after unlocking. This period is known as the watchdog configuration time (WCT). In addition, these register bits can be modified only once after unlocking them for editing, even after reset. You must unlock the registers within WCT after system reset, failing which the WDOG issues a reset to the system. In other words, you must write at least the first word of the unlocking sequence within the WCT after reset. After this is done, you have a further 20 bus clock cycles, the maximum allowed gap between the words of the unlock sequence, to complete the unlocking operation. Thereafter, to make sure that you do not forget to configure the watchdog, the watchdog issues a reset if none of the WDOG control and configuration registers is updated in the WCT after unlock. After the close of this window or after the first write, these register bits are locked out from any further changes. The watchdog timer keeps running according to its default configuration through unlocking and update operations that can extend up to a maximum total of 2xWCT + 20 bus clock cycles. Therefore, it must be ensured that the time-out value for the watchdog is always greater than 2xWCT time + 20 bus clock cycles. #### **runctional** overview Updates in the write-once registers take effect only after the WCT window closes with the following exceptions for which changes take effect immediately: - Stop and Debug mode enable - IRQ\_RST\_EN The operations of refreshing the watchdog goes undetected during the WCT. ## 23.3.3 Refreshing the watchdog A robust refreshing mechanism has been chosen for the watchdog. A valid refresh is a write of 0xA602 followed by 0xB480 within 20 bus clock cycles to watchdog refresh register. If these two values are written more than 20 bus cycles apart or if something other than these two values is written to the register, a watchdog reset, or interrupt-then-reset if enabled, is issued to the system. A valid refresh makes the watchdog timer restart on the next bus clock. Also, an attempted unlock operation in between the two writes of the refresh sequence goes undetected. See Watchdog Operation with 8-bit access for guidelines related to 8-bit accesses to the refresh register. # 23.3.4 Windowed mode of operation In this mode of operation, a restriction is placed on the point in time within the time-out period at which the watchdog can be refreshed. The refresh is considered valid only when the watchdog timer increments beyond a certain count as specified by the watchdog window register. This is known as refreshing the watchdog within a window of the total time-out period. If a refresh is attempted before the timer reaches the window value, the watchdog generates a reset, or interrupt-then-reset if enabled. If there is no refresh at all, the watchdog times out and generates a reset or interrupt-then-reset if enabled. # 23.3.5 Watchdog disabled mode of operation When the watchdog is disabled through the WDOG\_EN bit in the watchdog status and control register, the watchdog timer is reset to zero and is disabled from counting until you enable it or it is enabled again by the system reset. In this mode, the watchdog timer cannot be refreshed—there is no requirement to do so while the timer is disabled. However, the watchdog still generates a reset, or interrupt-then-reset if enabled, on a non- time-out exception. See Generated Resets and Interrupts. You need to unlock the watchdog before enabling it. A system reset brings the watchdog out of the disabled mode. ## 23.3.6 Low-power modes of operation The low-power modes of operation of the watchdog are described in the following table: | Mode | Behavior | |------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Wait | If the WDOG is enabled (WAIT_EN = 1), it can run on bus clock or low-power oscillator clock (CLK_SRC = x) to generate interrupt (IRQ_RST_EN=1) followed by a reset on time-out. After reset the WDOG reset counter increments by one. | | Stop | Where the bus clock is gated, the WDOG can run only on low-power oscillator clock (CLK_SRC=0) if it is enabled in stop (STOP_EN=1). In this case, the WDOG runs to time-out twice, and then generates a reset from its backup circuitry. Therefore, if you program the watchdog to time-out after 100 ms and then enter such a stop mode, the reset will occur after 200 ms. Also, in this case, no interrupt will be generated irrespective of the value of IRQ_RST_EN bit. After WDOG reset, the WDOG reset counter will also not increment. | | Power-Down | The watchdog is powered off. | Table 23-1. Low-power modes of operation # 23.3.7 Low-power and Debug modes of operation You can program the watchdog to disable in system stop, wait, and debug modes through STOP\_EN, WAIT\_EN, DBG\_EN in the watchdog control register. This results in the watchdog timer pausing for the duration of the mode. Register read/writes are still allowed, which means that operations like refresh, unlock, and so on are allowed. Upon exit from the mode, the timer resumes its operation from the point of pausing. The entry of the system into the debugabove mentioned modes does not excuse it from compulsorily configuring the watchdog in the WCT time after unlock, unless the system bus clock is gated off, in which case the internal state machine pauses too. Failing to do so still results in a reset, or interrupt-then-reset, if enabled, to the system. Also, all of the exception conditions that result in a reset to the system, as described in Generated Resets and Interrupts, are still valid in this these modes. So, if an exception condition occurs and the system bus clock is on, a reset occurs, or interrupt-then-reset, if enabled. The entry into Debug mode within WCT after reset is treated differently. The WDOG timer is kept reset to zero and there is no need to unlock and configure it within WCT. You must not try to refresh or unlock the WDOG in this state or unknown behavior may result. Upon exit from this these modes, the WDOG timer restarts and the WDOG has to be unlocked and configured within WCT. # 23.4 Testing the watchdog For IEC 60730 and other safety standards, the expectation is that anything that monitors a safety function must be tested, and this test is required to be fault tolerant. To test the watchdog, its main timer and its associated compare and reset logic must be tested. To this end, two tests are implemented for the watchdog, as described in Quick Test and Byte Test. A control bit is provided to put the watchdog into functional test mode. There is also an overriding test-disable control bit which allows the functional test mode to be disabled permanently. After it is set, this test-disable bit can only be cleared by a reset. These two tests achieve the overall aim of testing the counter functioning and the compare and reset logic. #### **Note** Do not enable the watchdog interrupt during these tests. If required, you must ensure that the effective time-out value is greater than WCT time. See Generated Resets and Interrupts for more details. To run a particular test: - 1. Select either quick test or byte test.. - 2. Set a certain test mode bit to put the watchdog in the functional test mode. Setting this bit automatically switches the watchdog timer to a fast clock source. The switching of the clock source is done to achieve a faster time-out and hence a faster test. In a successful test, the timer times out after reaching the programmed time-out value and generates a system reset. #### **Note** After emerging from a reset due to a watchdog test, unlock and configure the watchdog. The refresh and unlock operations and interrupt are not automatically disabled in the test mode. ## 23.4.1 Quick test In this test, the time-out value of watchdog timer is programmed to a very low value to achieve quick time-out. The only difference between the quick test and the normal mode of the watchdog is that TESTWDOG is set for the quick test. This allows for a faster test of the watchdog reset mechanism. ## **23.4.2** Byte test The byte test is a more thorough a test of the watchdog timer. In this test, the timer is split up into its constituent byte-wide stages that are run independently and tested for time-out against the corresponding byte of the time-out value register. The following figure explains the splitting concept: Figure 23-2. Watchdog timer byte splitting Each stage is an 8-bit synchronous counter followed by combinational logic that generates an overflow signal. The overflow signal acts as an enable to the N + 1th stage. In the test mode, when an individual byte, N, is tested, byte N-1 is loaded forcefully with 0xFF, and both these bytes are allowed to run off the clock source. By doing so, the overflow signal from stage N-1 is generated immediately, enabling counter stage N. The Nth stage runs and compares with the Nth byte of the time-out value register. In this way, the byte N is also tested along with the link between it and the preceding stage. No #### packup reset generator other stages, N - 2, N - 3... and N + 1, N + 2... are enabled for the test on byte N. These disabled stages, except the most significant stage of the counter, are loaded with a value of 0xFF. # 23.5 Backup reset generator The backup reset generator generates the final reset which goes out to the system. It has a backup mechanism which ensures that in case the bus clock stops and prevents the main state machine from generating a reset exception/interrupt, the watchdog timer's time-out is separately routed out as a reset to the system. Two successive timer time-outs without an intervening system reset result in the backup reset generator routing out the time-out signal as a reset to the system. # 23.6 Generated resets and interrupts The watchdog generates a reset in the following events, also referred to as exceptions: - A watchdog time-out - Failure to unlock the watchdog within WCT time after system reset deassertion - No update of the control and configuration registers within the WCT window after unlocking. At least one of the following registers must be written to within the WCT window to avoid reset: - WDOG\_ST\_CTRL\_H, WDOG\_ST\_CTRL\_L - WDOG\_TO\_VAL\_H, WDOG\_TO\_VAL\_L - WDOG\_WIN\_H, WDOG\_WIN\_L - WDOG\_PRESCALER - A value other than the unlock sequence or the refresh sequence is written to the unlock and/or refresh registers, respectively. - A gap of more than 20 bus cycles exists between the writes of two values of the unlock sequence. - A gap of more than 20 bus cycles exists between the writes of two values of the refresh sequence. The watchdog can also generate an interrupt. If IRQ\_RST\_EN is set, then on the above mentioned events WDOG\_ST\_CTRL\_L[INT\_FLG] is set, generating an interrupt. A watchdog reset is also generated WCT time later to ensure the watchdog is fault tolerant. The interrupt can be cleared by writing 1 to INT\_FLG. The gap of WCT between interrupt and reset means that the WDOG time-out value must be greater than WCT. Otherwise, if the interrupt was generated due to a time-out, a second consecutive time-out will occur in that WCT gap. This will trigger the backup reset generator to generate a reset to the system, prematurely ending the interrupt service routine execution. Also, jobs such as counting the number of watchdog resets would not be done. # 23.7 Memory map and register definition This section consists of the memory map and register descriptions. ### **WDOG** memory map | Absolute<br>address<br>(hex) | Register name | Width<br>(in bits) | Access | Reset value | Section/<br>page | |------------------------------|----------------------------------------------------------|--------------------|--------|-------------|------------------| | 4005_3000 | Watchdog Status and Control Register High (WDOG_STCTRLH) | 16 | R/W | 01D1h | 23.7.1/378 | | 4005_3002 | Watchdog Status and Control Register Low (WDOG_STCTRLL) | 16 | R/W | 0001h | 23.7.2/379 | | 4005_3004 | Watchdog Time-out Value Register High (WDOG_TOVALH) | 16 | R/W | 004Ch | 23.7.3/380 | | 4005_3006 | Watchdog Time-out Value Register Low (WDOG_TOVALL) | 16 | R/W | 4B40h | 23.7.4/380 | | 4005_3008 | Watchdog Window Register High (WDOG_WINH) | 16 | R/W | 0000h | 23.7.5/381 | | 4005_300A | Watchdog Window Register Low (WDOG_WINL) | 16 | R/W | 0010h | 23.7.6/381 | | 4005_300C | Watchdog Refresh register (WDOG_REFRESH) | 16 | R/W | B480h | 23.7.7/382 | | 4005_300E | Watchdog Unlock register (WDOG_UNLOCK) | 16 | R/W | D928h | 23.7.8/382 | | 4005_3010 | Watchdog Timer Output Register High (WDOG_TMROUTH) | 16 | R/W | 0000h | 23.7.9/382 | | 4005_3012 | Watchdog Timer Output Register Low (WDOG_TMROUTL) | 16 | R/W | 0000h | 23.7.10/383 | | 4005_3014 | Watchdog Reset Count register (WDOG_RSTCNT) | 16 | R/W | 0000h | 23.7.11/383 | | 4005_3016 | Watchdog Prescaler register (WDOG_PRESC) | 16 | R/W | 0400h | 23.7.12/384 | # 23.7.1 Watchdog Status and Control Register High (WDOG\_STCTRLH) Address: 4005\_3000h base + 0h offset = 4005\_3000h ## WDOG\_STCTRLH field descriptions | Field | Description | | | | | | | | | | |-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--| | 15<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | | | | | | | | | | 14<br>DISTESTWDOG | Allows the WDOG's functional test mode to be disabled permanently. After it is set, it can only be cleared by a reset. It cannot be unlocked for editing after it is set. | | | | | | | | | | | | 0 WDOG functional test mode is not disabled. | | | | | | | | | | | | 1 WDOG functional test mode is disabled permanently until reset. | | | | | | | | | | | 13–12<br>BYTESEL[1:0] | This 2-bit field selects the byte to be tested when the watchdog is in the byte test mode. | | | | | | | | | | | | 00 Byte 0 selected | | | | | | | | | | | | 01 Byte 1 selected | | | | | | | | | | | | <ul><li>10 Byte 2 selected</li><li>11 Byte 3 selected</li></ul> | | | | | | | | | | | | , | | | | | | | | | | | 11<br>TESTSEL | Effective only if TESTWDOG is set. Selects the test to be run on the watchdog timer. | | | | | | | | | | | TEGTOLL | 0 Quick test. The timer runs in normal operation. You can load a small time-out value to do a quick test. | | | | | | | | | | | | 1 Byte test. Puts the timer in the byte test mode where individual bytes of the timer are enabled for operation and are compared for time-out against the corresponding byte of the programmed time-out value. Select the byte through BYTESEL[1:0] for testing. | | | | | | | | | | | 10<br>TESTWDOG | Puts the watchdog in the functional test mode. In this mode, the watchdog timer and the associated compare and reset generation logic is tested for correct operation. The clock for the timer is switched from the main watchdog clock to the fast clock input for watchdog functional test. The TESTSEL bit selects the test to be run. | | | | | | | | | | | 9<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | | | | | | | | | | 8<br>Reserved | This field is reserved. | | | | | | | | | | | 7 | This field is reserved. | | | | | | | | | | | Reserved | This read-only field is reserved and always has the value 0. | | | | | | | | | | | 6<br>STOPEN | Enables or disables WDOG in Stop mode. | | | | | | | | | | | | 0 WDOG is disabled in CPU Stop mode. | | | | | | | | | | | | 1 WDOG is enabled in CPU Stop mode. | | | | | | | | | | Table continues on the next page... # WDOG\_STCTRLH field descriptions (continued) | Field | Description | |------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 5<br>DBGEN | Enables or disables WDOG in Debug mode. | | | 0 WDOG is disabled in CPU Debug mode. | | | 1 WDOG is enabled in CPU Debug mode. | | 4<br>ALLOWUPDATE | Enables updates to watchdog write-once registers, after the reset-triggered initial configuration window (WCT) closes, through unlock sequence. | | | No further updates allowed to WDOG write-once registers. | | | 1 WDOG write-once registers can be unlocked for updating. | | 3<br>WINEN | Enables Windowing mode. | | | 0 Windowing mode is disabled. | | | 1 Windowing mode is enabled. | | 2<br>IRQRSTEN | Used to enable the debug breadcrumbs feature. A change in this bit is updated immediately, as opposed to updating after WCT. | | | 0 WDOG time-out generates reset only. | | | 1 WDOG time-out initially generates an interrupt. After WCT, it generates a reset. | | 1<br>CLKSRC | Selects clock source for the WDOG timer and other internal timing operations. | | | 0 WDOG clock sourced from LPO . | | | 1 WDOG clock sourced from alternate clock source. | | 0<br>WDOGEN | Enables or disables the WDOG's operation. In the disabled state, the watchdog timer is kept in the reset state, but the other exception conditions can still trigger a reset/interrupt. A change in the value of this bit must be held for more than one WDOG_CLK cycle for the WDOG to be enabled or disabled. | | | <ul><li>0 WDOG is disabled.</li><li>1 WDOG is enabled.</li></ul> | # 23.7.2 Watchdog Status and Control Register Low (WDOG\_STCTRLL) Address: 4005\_3000h base + 2h offset = 4005\_3002h | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | |-----------------|--------|----------|----|----|----|----|---|---|--|--|--| | Read [<br>Write | INTFLG | Reserved | | | | | | | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | Read<br>Write | | Reserved | | | | | | | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | | | | #### wemory map and register definition ## WDOG\_STCTRLL field descriptions | Field | Description | |------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15<br>INTFLG | Interrupt flag. It is set when an exception occurs. IRQRSTEN = 1 is a precondition to set this flag. INTFLG = 1 results in an interrupt being issued followed by a reset, WCT later. The interrupt can be cleared by writing 1 to this bit. It also gets cleared on a system reset. | | 14–0<br>Reserved | This field is reserved. NOTE: Do not modify this field value. | ## 23.7.3 Watchdog Time-out Value Register High (WDOG\_TOVALH) Address: 4005 3000h base + 4h offset = 4005 3004h | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|----|----|----|----|----|----|---|------|-------|---|---|---|---|---|---|---| | Read<br>Write | | | | | | | | TOVA | LHIGH | | | | | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | ## WDOG\_TOVALH field descriptions | Field | Description | |-------|----------------------------------------------------------------------------------------------------------------------------------------| | | Defines the upper 16 bits of the 32-bit time-out value for the watchdog timer. It is defined in terms of cycles of the watchdog clock. | ## 23.7.4 Watchdog Time-out Value Register Low (WDOG\_TOVALL) The time-out value of the watchdog must be set to a minimum of four watchdog clock cycles. This is to take into account the delay in new settings taking effect in the watchdog clock domain. Address: 4005\_3000h base + 6h offset = 4005\_3006h ## WDOG\_TOVALL field descriptions | Field | Description | |-------|----------------------------------------------------------------------------------------------------------------------------------------| | | Defines the lower 16 bits of the 32-bit time-out value for the watchdog timer. It is defined in terms of cycles of the watchdog clock. | 381 # 23.7.5 Watchdog Window Register High (WDOG\_WINH) ### NOTE You must set the Window Register value lower than the Timeout Value Register. Address: 4005\_3000h base + 8h offset = 4005\_3008h | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|----|----|----|----|----|----|---|------|------|---|---|---|---|---|---|---| | Read<br>Write | | | | | | | | WINI | HIGH | | | | | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ## WDOG\_WINH field descriptions | Field | Description | |---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | WINHIGH | Defines the upper 16 bits of the 32-bit window for the windowed mode of operation of the watchdog. It is defined in terms of cycles of the watchdog clock. In this mode, the watchdog can be refreshed only when the timer has reached a value greater than or equal to this window length. A refresh outside this window resets the system or if IRQRSTEN is set, it interrupts and then resets the system. | # 23.7.6 Watchdog Window Register Low (WDOG\_WINL) #### NOTE You must set the Window Register value lower than the Timeout Value Register. Address: 4005\_3000h base + Ah offset = 4005\_300Ah ## WDOG\_WINL field descriptions | Field | Description | |--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | WINLOW | Defines the lower 16 bits of the 32-bit window for the windowed mode of operation of the watchdog. It is defined in terms of cycles of the pre-scaled watchdog clock. In this mode, the watchdog can be refreshed only when the timer reaches a value greater than or equal to this window length value. A refresh outside of this window resets the system or if IRQRSTEN is set, it interrupts and then resets the system. | ## 23.7.7 Watchdog Refresh register (WDOG\_REFRESH) Address: 4005\_3000h base + Ch offset = 4005\_300Ch | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|----|----|----|----|----|----|---|-------|-------|---|---|---|---|---|---|---| | Read<br>Write | | | | | | | V | /DOGR | EFRES | Н | | | | | | | | Reset | 1 | 0 | 1 | 1 | 0 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ## WDOG\_REFRESH field descriptions | Field | Description | |-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15–0 | Watchdog refresh register. A sequence of 0xA602 followed by 0xB480 within 20 bus clock cycles written | | | to this register refreshes the WDOG and prevents it from resetting the system. Writing a value other than the above mentioned sequence or if the sequence is longer than 20 bus cycles, resets the system, or if IRQRSTEN is set, it interrupts and then resets the system. | ## 23.7.8 Watchdog Unlock register (WDOG\_UNLOCK) Address: 4005\_3000h base + Eh offset = 4005\_300Eh | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|----|----|----|----|----|----|---|-------|-------|---|---|---|---|---|---|---| | Read<br>Write | | | | | | | ٧ | WDOGL | JNLOC | < | | | | | | | | Reset | 1 | 1 | 0 | 1 | 1 | 0 | 0 | 1 | 0 | 0 | 1 | 0 | 1 | 0 | 0 | 0 | ## WDOG\_UNLOCK field descriptions | Field | Description | |--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15–0<br>WDOGUNLOCK | Writing the unlock sequence values to this register to makes the watchdog write-once registers writable again. The required unlock sequence is 0xC520 followed by 0xD928 within 20 bus clock cycles. A valid unlock sequence opens a window equal in length to the WCT within which you can update the registers. Writing a value other than the above mentioned sequence or if the sequence is longer than 20 bus cycles, resets the system or if IRQRSTEN is set, it interrupts and then resets the system. The unlock sequence is effective only if ALLOWUPDATE is set. | # 23.7.9 Watchdog Timer Output Register High (WDOG\_TMROUTH) Address: 4005\_3000h base + 10h offset = 4005\_3010h ## WDOG\_TMROUTH field descriptions | Field | Description | |----------------------|-------------------------------------------------------------| | 15–0<br>TIMEROUTHIGH | Shows the value of the upper 16 bits of the watchdog timer. | ## 23.7.10 Watchdog Timer Output Register Low (WDOG\_TMROUTL) During Stop mode, the WDOG\_TIMER\_OUT will be caught at the pre-stop value of the watchdog timer. After exiting Stop mode, a maximum delay of 1 WDOG\_CLK cycle + 3 bus clock cycles will occur before the WDOG\_TIMER\_OUT starts following the watchdog timer. Address: 4005\_3000h base + 12h offset = 4005\_3012h | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------|----|----|----|----|----|----|---|-------|-------|---|---|---|---|---|---|---| | Read Write | | | | | | | Т | IMERC | UTLOV | V | | | | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ## WDOG\_TMROUTL field descriptions | Field | Description | |-------------|-------------------------------------------------------------| | 15–0 | Shows the value of the lower 16 bits of the watchdog timer. | | TIMEROUTLOW | | ## 23.7.11 Watchdog Reset Count register (WDOG\_RSTCNT) Address: 4005\_3000h base + 14h offset = 4005\_3014h ## WDOG\_RSTCNT field descriptions | Field | Description | |-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | Counts the number of times the watchdog resets the system. This register is reset only on a POR. Writing 1 to the bit to be cleared enables you to clear the contents of this register. | ## 23.7.12 Watchdog Prescaler register (WDOG\_PRESC) Address: 4005\_3000h base + 16h offset = 4005\_3016h ## WDOG\_PRESC field descriptions | Field | Description | |-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15–11<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 10–8<br>PRESCVAL | 3-bit prescaler for the watchdog clock source. A value of zero indicates no division of the input WDOG clock. The watchdog clock is divided by (PRESCVAL + 1) to provide the prescaled WDOG_CLK. | | 7–0<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | # 23.8 Watchdog operation with 8-bit access # 23.8.1 General guideline When performing 8-bit accesses to the watchdog's 16-bit registers where the intention is to access both the bytes of a register, place the two 8-bit accesses one after the other in your code. # 23.8.2 Refresh and unlock operations with 8-bit access One exception condition that generates a reset to the system is the write of any value other than those required for a legal refresh/update sequence to the respective refresh and unlock registers. For an 8-bit access to these registers, writing a correct value requires at least two bus clock cycles, resulting in an invalid value in the registers for one cycle. Therefore, the system is reset even if the intention is to write a correct value to the refresh/unlock register. Keeping this in mind, the exception condition for 8-bit accesses is slightly modified. Whereas the match for a correct value for a refresh/unlock sequence is as according to the original definition, the match for an incorrect value is done byte-wise on the refresh/unlock rather than for the whole 16-bit value. This means that if the high byte of the refresh/unlock register contains any value other than high bytes of the two values that make up the sequence, it is treated as an exception condition, leading to a reset or interrupt-then-reset. The same holds true for the lower byte of the refresh or unlock register. Take the refresh operation that expects a write of 0xA602 followed by 0xB480 to the refresh register, as an example. Sequence value1 or **Mismatch** WDOG\_REFRESH[15:8] WDOG\_REFRESH[7:0] value2 match exception **Current Value** 0xB4 Value2 match 0x80 No Write 1 0x02 0xB4 No match No Write 2 0xA6 0x02 Value1 match No Write 3 0xB4 0x02 No match No Write 4 Value2 match. 0xB4 0x80 No Sequence complete. Write 5 0x02 0x80 No match Yes Table 23-15. Refresh for 8-bit access As shown in the preceding table, the refresh register holds its reset value initially. Thereafter, two 8-bit accesses are performed on the register to write the first value of the refresh sequence. No mismatch exception is registered on the intermediate write, Write1. The sequence is completed by performing two more 8-bit accesses, writing in the second value of the sequence for a successful refresh. It must be noted that the match of value2 takes place only when the complete 16-bit value is correctly written, write4. Hence, the requirement of writing value2 of the sequence within 20 bus clock cycles of value1 is checked by measuring the gap between write2 and write4. It is reiterated that the condition for matching values 1 and 2 of the refresh or unlock sequence remains unchanged. The difference for 8-bit accesses is that the criterion for detecting a mismatch is less strict. Any 16-bit access still needs to adhere to the original guidelines, mentioned in the sections Refreshing the Watchdog. # 23.9 Restrictions on watchdog operation This section mentions some exceptions to the watchdog operation that may not be apparent to you. #### nescrictions on watchdog operation - Restriction on unlock/refresh operations—In the period between the closure of the WCT window after unlock and the actual reload of the watchdog timer, unlock and refresh operations need not be attempted. - The update and reload of the watchdog timer happens two to three watchdog clocks after WCT window closes, following a successful configuration on unlock. - Clock Switching Delay—The watchdog uses glitch-free multiplexers at two places one to choose between the LPO oscillator input and alternate clock input, and the other to choose between the watchdog functional clock and fast clock input for watchdog functional test. A maximum time period of ~2 clock A cycles plus ~2 clock B cycles elapses from the time a switch is requested to the occurrence of the actual clock switch, where clock A and B are the two input clocks to the clock mux. - For the windowed mode, there is a two to three bus clock latency between the watchdog counter going past the window value and the same registering in the bus clock domain. - For proper operation of the watchdog, the watchdog clock must be at least five times slower than the system bus clock at all times. An exception is when the watchdog clock is synchronous to the bus clock wherein the watchdog clock can be as fast as the bus clock. - WCT must be equivalent to at least three watchdog clock cycles. If not ensured, this means that even after the close of the WCT window, you have to wait for the synchronized system reset to deassert in the watchdog clock domain, before expecting the configuration updates to take effect. - The time-out value of the watchdog should be set to a minimum of four watchdog clock cycles. This is to take into account the delay in new settings taking effect in the watchdog clock domain. - You must take care not only to refresh the watchdog within the watchdog timer's actual time-out period, but also provide enough allowance for the time it takes for the refresh sequence to be detected by the watchdog timer, on the watchdog clock. - Updates cannot be made in the bus clock cycle immediately following the write of the unlock sequence, but one bus clock cycle later. - It should be ensured that the time-out value for the watchdog is always greater than 2xWCT time + 20 bus clock cycles. - An attempted refresh operation, in between the two writes of the unlock sequence and in the WCT time following a successful unlock, will go undetected. - Trying to unlock the watchdog within the WCT time after an initial unlock has no effect. - The refresh and unlock operations and interrupt are not automatically disabled in the watchdog functional test mode. - After emerging from a reset due to a watchdog functional test, you are still expected to go through the mandatory steps of unlocking and configuring the watchdog. The watchdog continues to be in its functional test mode and therefore you should pull the watchdog out of the functional test mode within WCT time of reset. - After emerging from a reset due to a watchdog functional test, you still need to go through the mandatory steps of unlocking and configuring the watchdog. - You must ensure that both the clock inputs to the glitchless clock multiplexers are alive during the switching of clocks. Failure to do so results in a loss of clock at their outputs. - There is a gap of two to three watchdog clock cycles from the point that stop mode is entered to the watchdog timer actually pausing, due to synchronization. The same holds true for an exit from the stop mode, this time resulting in a two to three watchdog clock cycle delay in the timer restarting. In case the duration of the stop mode is less than one watchdog clock cycle, the watchdog timer is not guaranteed to pause. - Consider the case when the first refresh value is written, following which the system enters stop mode with system bus clk still on. If the second refresh value is not written within 20 bus cycles of the first value, the system is reset, or interrupt-thenreset if enabled. nestrictions on watchdog operation # **Chapter 24 External Watchdog Monitor (EWM)** ## 24.1 Introduction #### **NOTE** For the chip-specific implementation details of this module's instances, see the chip configuration information. The watchdog is generally used to monitor the flow and execution of embedded software within an MCU. The watchdog consists of a counter that if allowed to overflow, forces an internal reset (asynchronous) to all on-chip peripherals and optionally assert the RESET pin to reset external devices/circuits. The overflow of the watchdog counter must not occur if the software code works well and services the watchdog to re-start the actual counter. For safety, a redundant watchdog system, External Watchdog Monitor (EWM), is designed to monitor external circuits, as well as the MCU software flow. This provides a back-up mechanism to the internal watchdog that resets the MCU's CPU and peripherals. The EWM differs from the internal watchdog in that it does not reset the MCU's CPU and peripherals. The EWM if allowed to time-out, provides an independent EWM\_out pin that when asserted resets or places an external circuit into a safe mode. The CPU resets the EWM counter that is logically ANDed with an external digital input pin. This pin allows an external circuit to influence the reset\_out signal. # 24.1.1 Features Features of EWM module include: - Independent LPO clock source - Programmable time-out period specified in terms of number of EWM LPO clock cycles. #### muroduction - Windowed refresh option - Provides robust check that program flow is faster than expected. - Programmable window. - Refresh outside window leads to assertion of EWM\_out. - Robust refresh mechanism - Write values of 0xB4 and 0x2C to EWM Refresh Register within 15 (EWM\_service\_time) peripheral bus clock cycles. - One output port, <u>EWM\_out</u>, when asserted is used to reset or place the external circuit into safe mode. - One Input port, EWM\_in, allows an external circuit to control the EWM\_out signal. ## 24.1.2 Modes of Operation This section describes the module's operating modes. ## 24.1.2.1 Stop Mode When the EWM is in stop mode, the CPU services to the EWM cannot occur. On entry to stop mode, the EWM's counter freezes. There are two possible ways to exit from Stop mode: - On exit from stop mode through a reset, the EWM remains disabled. - On exit from stop mode by an interrupt, the EWM is re-enabled, and the counter continues to be clocked from the same value prior to entry to stop mode. Note the following if the EWM enters the stop mode during CPU service mechanism: At the exit from stop mode by an interrupt, refresh mechanism state machine starts from the previous state which means, if first service command is written correctly and EWM enters the stop mode immediately, the next command has to be written within the next 15 (EWM\_service\_time) peripheral bus clocks after exiting from stop mode. User must mask all interrupts prior to executing EWM service instructions. ## 24.1.2.2 Wait Mode The EWM module treats the stop and wait modes as the same. EWM functionality remains the same in both of these modes. ## 24.1.2.3 **Debug Mode** Entry to debug mode has no effect on the EWM. - If the EWM is enabled prior to entry of debug mode, it remains enabled. - If the EWM is disabled prior to entry of debug mode, it remains disabled. # 24.1.3 Block Diagram This figure shows the EWM block diagram. <sup>&</sup>lt;sup>1</sup>Compare High > Counter > Compare Low Figure 24-1. EWM Block Diagram # 24.2 EWM Signal Descriptions The EWM has two external signals, as shown in the following table. **Table 24-1. EWM Signal Descriptions** | Signal | Description | I/O | |---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----| | EWM_in | EWM input for safety status of external safety circuits. The polarity of EWM_in is programmable using the EWM_CTRL[ASSIN] bit. The default polarity is active-low. | I | | EWM_out | EWM reset out signal | 0 | # 24.3 Memory Map/Register Definition This section contains the module memory map and registers. ## **EWM** memory map | Absolute<br>address<br>(hex) | Register name | Width<br>(in bits) | Access | Reset value | Section/<br>page | |------------------------------|----------------------------------|--------------------|--------------------------|-------------|------------------| | 4006_1000 | Control Register (EWM_CTRL) | 8 | R/W | 00h | 24.3.1/392 | | 4006_1001 | Service Register (EWM_SERV) | 8 | W<br>(always<br>reads 0) | 00h | 24.3.2/393 | | 4006_1002 | Compare Low Register (EWM_CMPL) | 8 | R/W | 00h | 24.3.3/393 | | 4006_1003 | Compare High Register (EWM_CMPH) | 8 | R/W | FFh | 24.3.4/394 | ## 24.3.1 Control Register (EWM\_CTRL) The CTRL register is cleared by any reset. #### NOTE INEN, ASSIN and EWMEN bits can be written once after a CPU reset. Modifying these bits more than once, generates a bus transfer error. Address: 4006\_1000h base + 0h offset = 4006\_1000h ## **EWM\_CTRL** field descriptions | Field | Description | |-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7–4<br>Reserved | This field is reserved. | | neserveu | This read-only field is reserved and always has the value 0. | | 3<br>INTEN | Interrupt Enable. | | | This bit when set and EWM_out is asserted, an interrupt request is generated. To de-assert interrupt request, user should clear this bit by writing 0. | | 2<br>INEN | Input Enable. | | | This bit when set, enables the EWM_in port. | | 1<br>ASSIN | EWM_in's Assertion State Select. | | | Default assert state of the EWM_in signal is logic zero. Setting ASSIN bit inverts the assert state to a logic one. | | 0<br>EWMEN | EWM enable. | | | This bit when set, enables the EWM module. This resets the EWM counter to zero and deasserts the EWM_out signal. Clearing EWMEN bit disables the EWM, and therefore it cannot be enabled until a reset occurs, due to the write-once nature of this bit. | # 24.3.2 Service Register (EWM\_SERV) The SERV register provides the interface from the CPU to the EWM module. It is write-only and reads of this register return zero. ## **EWM\_SERV** field descriptions | Field | Description | |----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7–0<br>SERVICE | The EWM service mechanism requires the CPU to write two values to the SERV register: a first data byte of 0xB4, followed by a second data byte of 0x2C. The EWM service is illegal if either of the following conditions is true. • The first or second data byte is not written correctly. • The second data byte is not written within a fixed number of peripheral bus cycles of the first data byte. This fixed number of cycles is called <i>EWM_service_time</i> . | # 24.3.3 Compare Low Register (EWM\_CMPL) The CMPL register is reset to zero after a CPU reset. This provides no minimum time for the CPU to service the EWM counter. #### wemory Map/Register Definition ### NOTE This register can be written only once after a CPU reset. Writing this register more than once generates a bus transfer error. Address: 4006\_1000h base + 2h offset = 4006\_1002h ## **EWM\_CMPL** field descriptions | Field | Description | |-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------| | | To prevent runaway code from changing this field, software should write to this field after a CPU reset even if the (default) minimum service time is required. | # 24.3.4 Compare High Register (EWM\_CMPH) The CMPH register is reset to 0xFF after a CPU reset. This provides a maximum of 256 clocks time, for the CPU to service the EWM counter. ### NOTE This register can be written only once after a CPU reset. Writing this register more than once generates a bus transfer error. #### NOTE The valid values for CMPH are up to 0xFE because the EWM counter never expires when CMPH = 0xFF. The expiration happens only if EWM counter is greater than CMPH. Address: 4006\_1000h base + 3h offset = 4006\_1003h #### **EWM\_CMPH** field descriptions | Field | Description | |-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7–0<br>COMPAREH | To prevent runaway code from changing this field, software should write to this field after a CPU reset even if the (default) maximum service time is required. | 395 # 24.4 Functional Description The following sections describe functional details of the EWM module. # 24.4.1 The EWM\_out Signal The EWM\_out is a digital output signal used to gate an external circuit (application specific) that controls critical safety functions. For example, the EWM\_out could be connected to the high voltage transistors circuits that control an AC motor in a large appliance. The EWM\_out signal remains deasserted when the EWM is being regularly serviced by the CPU within the programmable service window, indicating that the application code is executed as expected. The EWM\_out signal is asserted in any of the following conditions: - Servicing the EWM when the counter value is less than CMPL value. - If the EWM counter value reaches the CMPH value, and no EWM service has occurred. - Servicing the EWM when the counter value is more than CMPL and less than CMPH values and EWM\_in signal is asserted. - If functionality of EWM\_in pin is enabled and EWM\_in pin is asserted while servicing the EWM. - After any reset (by the virtue of the external pull-down mechanism on the EWM\_out pin) On a normal reset, the $\overline{EWM}$ \_out is asserted. To deassert the $\overline{EWM}$ \_out, set EWMEN bit in the CTRL register to enable the EWM. If the EWM\_out signal shares its pad with a digital I/O pin, on reset this actual pad defers to being an input signal. It takes the EWM\_out output condition only after you enable the EWM by the EWMEN bit in the CTRL register. When the EWM\_out pin is asserted, it can only be deasserted by forcing a MCU reset. #### **Note** EWM\_out pad must be in pull down state when EWM functionality is used and when EWM is under Reset. # 24.4.2 The EWM\_in Signal The EWM\_in is a digital input signal that allows an external circuit to control the EWM\_out signal. For example, in the application, an external circuit monitors a critical safety function, and if there is fault with this circuit's behavior, it can then actively initiate the EWM\_out signal that controls the gating circuit. The EWM\_in signal is ignored if the EWM is disabled, or if INEN bit of CTRL register is cleared, as after any reset. On enabling the EWM (setting the CTRL[EWMEN] bit) and enabling EWM\_in functionality (setting the CTRL[INEN] bit), the EWM\_in signal must be in the deasserted state prior to the CPU servicing the EWM. This ensures that the EWM\_out stays in the deasserted state; otherwise, the EWM\_out pin is asserted. #### **Note** You must update the CMPH and CMPL registers prior to enabling the EWM. After enabling the EWM, the counter resets to zero, therefore providing a reasonable time after a power-on reset for the external monitoring circuit to stabilize and ensure that the EWM\_in pin is deasserted. ## 24.4.3 EWM Counter It is an 8-bit ripple counter fed from a clock source that is independent of the peripheral bus clock source. As the preferred time-out is between 1 ms and 100 ms the actual clock source should be in the kHz range. The counter is reset to zero, after a CPU reset, or a EWM refresh cycle. The counter value is not accessible to the CPU. # 24.4.4 EWM Compare Registers The compare registers CMPL and CMPH are write-once after a CPU reset and cannot be modified until another CPU reset occurs. The EWM compare registers are used to create a service window, which is used by the CPU to service/refresh the EWM module. - If the CPU services the EWM when the counter value lies between CMPL value and CMPH value, the counter is reset to zero. This is a legal service operation. - If the CPU executes a EWM service/refresh action outside the legal service window, EWM\_out is asserted. It is illegal to program CMPL and CMPH with same value. In this case, as soon as counter reaches (CMPL + 1), $\overline{EWM}$ \_out is asserted. #### 24.4.5 EWM Refresh Mechanism Other than the initial configuration of the EWM, the CPU can only access the EWM by the EWM Service Register. The CPU must access the EWM service register with correct write of unique data within the windowed time frame as determined by the CMPL and CMPH registers. Therefore, three possible conditions can occur: A unique EWM service occurs when CMPL < Counter < CMPH. The software behaves as expected and the counter of the EWM is reset to zero, and EWM\_out pin remains in the deasserted state. Note: EWM\_in pin is also assumed to be in the deasserted state. The software services the EWM and therefore resets the counter to zero and asserts the EWM\_out pin (irrespective of the EWM\_in pin). The EWM\_out pin is expected to gate critical safety circuits. Counter value reaches CMPH prior to a The counter value reaches the CMPH value and no service of the EWM resets the counter to zero and assert the EWM\_out pin (irrespective of the EWM\_in pin). The EWM\_out pin is expected to gate critical safety circuits. Table 24-7. EWM Refresh Mechanisms Any illegal service on EWM has no effect on EWM\_out. # 24.4.6 EWM Interrupt unique EWM service When EWM\_out is asserted, an interrupt request is generated to indicate the assertion of the EWM reset out signal. This interrupt is enabled when CTRL[INTEN] is set. Clearing this bit clears the interrupt request but does not affect EWM\_out. The EWM\_out signal can be deasserted only by forcing a system reset. **runctional Description** # **Chapter 25 Analog Front End (AFE)** ### 25.1 Introduction The Analog Front End or AFE is an integrated module that is comprised of four sigmadelta ADCs referred to as channels (two with PGA) and input voltage reference. The converters are based on second-order oversampling sigma-delta modulators and digital decimation filters with selectable over sampling ratio up to 2048. Additional filtering can be done in software. ### 25.2 Features - Two 24-bit (after averaging) sigma-delta ADC with PGA - Two 24-bit (after averaging) sigma delta without PGA - Option to bypass/disable the PGA - PGA with 7μV sensitivity (PGA gain = 1 V/V), 7 μV sensitivity (PGA gain = 32 V/V) - Voltage measurement can operate in both differential and single ended mode. For single ended operation, the differential pin shall be grounded externally on board. - Input common-mode voltage range of 0 to 0.8V - Full Operating Voltage Range 2.7V to 3.3V - Output sampling rates 3 KHz, 6 KHz, 12 KHz, 24 KHz, 48 KHz, and 96 KHz. - Software selectable analog gain 1x, 2x, 4x, 8x, 16x, 32x - Software selectable on-chip reference voltage and common mode voltage generation (1.2 V) - Software selectable internal or external reference - ±250 mVp (1 Vpp differential, 0.5 Vpp single ended) input range for all AFE inputs - Support for interfacing to external modulators when AFE bypass option is enabled. - Digital logic enables synchronized start of all AFE blocks - Interrupt and DMA request on Conversion Complete. - Asynchronous DMA request generation to transfer data in deep sleep(STOP) mode. #### סוטכות Diagram - Both Hardware and software trigger can be used to initiate data conversion. - 30kHz to 6.5 MHz Modulator input frequency. - Selectable low-power conversion mode. - Implements phase compensation Upto 0-6.0 degree @(OSR = 2048 & 50 Hz input) - Allows dynamic change of phase shift without interrupting sampling cycles - Software selectable clock option for modulator clock. # 25.3 Block Diagram The figure below shows the block diagram of AFE. #### **NOTE** Decimators doesn't get mod\_clk directly. In Modulator engage mode the clock is provided by corresponding modulator which is properly aligned with the modulator output data. In bypass mode the clock can come from external interface too.Please see AFE BYPASS mode diagram for detailed clocking. # 25.4 AFE Clocking The maximum operational frequency of the AFE modulator clock is 6.5 MHz. For optimum performance the clock should have minimum jitter with 50% (approx) duty cycle. Four possible clock sources (selected by programming CLS[1:0]) are provided to be used as MOD\_CLK.A clock divider is in place to further divide down the MOD\_CLK frequency for low power application. The AFE\_CKR[DIV] field selects the divide ratio to generate final mod\_clk to AFE. Fmod\_clk = Fclk / $2^$ DIV where Fclk is the input clock to divider. The modulator clock frequency must be in the range of 30KHz -6.5 MHz. The clock divide ratio has a range from 1 - 256 Below digram depicts the AFE clocking implementation. #### NOTE Refer AFE Chip configuration chapter for more information on Clock Sources #### 25.5 OSR Select The oversampling ratio (OSR) is the ratio of the modulator clock frequency (fSDMCK) to the output sample frequency. For example: a 6.144 MHz modulator clock with an OSR = 256 yields an output sample rate of 24 kHz. The OSR field selects the OSR which can be 64, 128, 256, 512, 1024, or 2048. A higher OSR produces a lower sample rate and narrower bandwidth. # 25.6 Analog Gain Select The AGN field selects the front end analog gain applied to the input signal. The selectable gains are x1, x2, x4, x8, x16, x32. Higher gain settings reduce the full scale input of the converter. # 25.7 Memory Map and Register Definition #### **AFE** memory map | Absolute address (hex) | Register name | Width<br>(in bits) | Access | Reset value | Section/<br>page | |------------------------|-----------------------------------------------|--------------------|--------|-------------|------------------| | 4003_0000 | Channel0 Configuration Register (AFE_CH0_CFR) | 32 | R/W | 0008_0000h | 25.7.1/404 | | 4003_0004 | Channel1 Configuration Register (AFE_CH1_CFR) | 32 | R/W | 0008_0000h | 25.7.2/406 | | 4003_0008 | Channel2 Configuration Register (AFE_CH2_CFR) | 32 | R/W | 0000_0000h | 25.7.3/409 | | 4003_000C | Channel3 Configuration Register (AFE_CH3_CFR) | 32 | R/W | 0000_0000h | 25.7.4/411 | | 4003_0018 | Control Register (AFE_CR) | 32 | R/W | 0040_FA00h | 25.7.5/413 | | 4003_001C | Clock Configuration Register (AFE_CKR) | 32 | R/W | 1000_0000h | 25.7.6/415 | | 4003_0020 | DMA and Interrupt Register (AFE_DI) | 32 | R/W | 0000_0000h | 25.7.7/416 | | 4003_002C | Channel0 Delay Register (AFE_CH0_DR) | 32 | R/W | 0000_0000h | 25.7.8/417 | | 4003_0030 | Channel1 Delay Register (AFE_CH1_DR) | 32 | R/W | 0000_0000h | 25.7.9/417 | | 4003_0034 | Channel2 Delay Register (AFE_CH2_DR) | 32 | R/W | 0000_0000h | 25.7.10/418 | | 4003_0038 | Channel3 Delay Register (AFE_CH3_DR) | 32 | R/W | 0000_0000h | 25.7.11/418 | | 4003_0044 | Channel0 Result Register (AFE_CH0_RR) | 32 | R | 0000_0000h | 25.7.12/419 | | 4003_0048 | Channel1 Result Register (AFE_CH1_RR) | 32 | R | 0000_0000h | 25.7.13/419 | | 4003_004C | Channel2 Result Register (AFE_CH2_RR) | 32 | R | 0000_0000h | 25.7.14/420 | | 4003_0050 | Channel3 Result Register (AFE_CH3_RR) | 32 | R | 0000_0000h | 25.7.15/420 | | 4003_005C | Status Register (AFE_SR) | 32 | R | 0000_0000h | 25.7.16/422 | # 25.7.1 Channel0 Configuration Register (AFE\_CH0\_CFR) Channel Configuration Register has various fields to configure channel of AFE. Any changes done in this register while the conversion is in progress will come into effect from next conversion only. #### AFE\_CH0\_CFR field descriptions | Field | Description | |------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31–29<br>DEC_OSR | Decimator OverSampling Ratio select | | ] 223_33.1 | This field selects the oversampling ratio. It should not be modified while the filter is operating. The Sinc filter output is scaled based on the OSR to produce a 24 bit signed, two's complement output | | | 000 64 | | | 001 128 | | | 010 256 | | | 011 512 | | | 100 1024 | | | 101 2048 | | | 110-111 reserved | | 28–25 | This field is reserved. | | Reserved | This read-only field is reserved and always has the value 0. | | 24 | PGA enable | | PGA_EN | It enables the PGA gain stage. | | | 0 PGA disabled | | | 1 PGA enabled | Table continues on the next page... # AFE\_CH0\_CFR field descriptions (continued) | Field | Description | |----------------|-----------------------------------------------------------------------------------------------------------------| | 23–22 | This field is reserved. | | Reserved | This read-only field is reserved and always has the value 0. | | 21–19 | PGA Gain Select | | PGA_GAIN_SEL | This field selects the analog gain applied to the input signal. | | | 000 reserved | | | 001 1x (default) | | | 010 2x | | | 011 4x | | | 100 8x | | | 101 16x | | | 110 32x | | | 111 reserved | | 18<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 17 | AFE Channel0 bypass mode | | BYP_MODE | This field is used to disable internal modulators of channel0. External modulators will be used. | | | 0 Normal mode | | | 1 Bypass mode where ADC and PGA of channel0 are disabled. | | 16–15 | This field is reserved. | | Reserved | This read-only field is reserved and always has the value 0. | | 14 | Sigma Delta Modulator enable | | SD_MOD_EN | This is used to enable SD ADC1. | | | 0 SD ADC1 is disabled | | | 1 SD ADC1 is enabled | | 13 | Decimation Filter enable | | DEC_EN | This is used to enable decimation filter. | | | | | | <ul><li>Decimation filter is disabled.</li><li>Decimation filter is enabled.</li></ul> | | 10 | | | 12<br>CC | Continuous Conversion/Single Conversion Mode Select | | | 0 One conversion following a triggering event | | | 1 Continuous conversions following a triggering event. | | 11 | Decimator Clock Edge Select | | DEC_CLK_ | This field is used to select rising edge or falling edge for registering input data by the decimation filter in | | EDGE_SEL | case of by-pass mode. | | | 0 Posedge will be used. | | | 1 Negedge will be used. | | 10 | Decimator Clock Input Select | | DEC_CLK_INP_ | | | SEL | | Table continues on the next page... #### wemory Map and Register Definition #### AFE\_CH0\_CFR field descriptions (continued) | Field | Description | | |-----------------|-------------------------------------------------------------------------------------------------------------------------|--| | | This field is used to select on the chip modulator clock or an external clock for the decimator in case of bypass mode. | | | | <ul><li>On the chip modulator clock will be used</li><li>External clock will be used.</li></ul> | | | 9<br>HW TRG | Hardware Trigger Select | | | _ | This field is used to select trigger source for conversion. O Software trigger select Hardware trigger select | | | 8–0<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | # 25.7.2 Channel1 Configuration Register (AFE\_CH1\_CFR) Channel1 Configuration Register has various fields to configure channel1 of AFE. Any changes done in this register while the conversion is in progress will come into effect from next conversion only. #### AFE\_CH1\_CFR field descriptions | Field | Description | |------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31–29<br>DEC_OSR | Decimator OverSampling Ratio select | | | This field selects the oversampling ratio. It should not be modified while the filter is operating. The Sinc filter output is scaled based on the OSR to produce a 24 bit signed, two's complement output | Table continues on the next page... # AFE\_CH1\_CFR field descriptions (continued) | Field | Description | |-----------------------|--------------------------------------------------------------------------------------------------| | | 000 64 | | | 001 128 | | | 010 256<br>011 512 | | | 100 1024 | | | 101 2048 | | | 110-111 reserved | | 28–25 | This field is reserved. | | Reserved | This read-only field is reserved and always has the value 0. | | 24 | PGA enable | | PGA_EN | It enables the PGA gain stage. | | | 0 PGA disabled | | | 1 PGA enabled | | 23–22 | This field is reserved. | | Reserved | This read-only field is reserved and always has the value 0. | | 21–19<br>PGA_GAIN_SEL | PGA Gain Select | | . art_artiiv_oll | This field selects the analog gain applied to the input signal. | | | 000 reserved | | | 001 1x (default) | | | 010 2x | | | 011 4x | | | 100 8x<br>101 16x | | | 110 16x | | | 111 reserved | | 18 | This field is reserved. | | Reserved | This read-only field is reserved and always has the value 0. | | 17<br>BYP_MODE | AFE Channel1 bypass mode | | | This field is used to disable internal modulators of channel1. External modulators will be used. | | | 0 Normal mode | | 10.1- | 1 Bypass mode where ADC and PGA of channel1 are disabled. | | 16–15<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 14 | Sigma Delta Modulator enable | | SD_MOD_EN | This is used to enable SD ADC1. | | | 0 SD ADC1 is disabled | | | 1 SD ADC1 is enabled | | 13<br>DEC_EN | Decimation Filter enable | | DLO_EIN | This is used to enable decimation filter. | Table continues on the next page... #### wemory Map and Register Definition # AFE\_CH1\_CFR field descriptions (continued) | Field | Description | |---------------------|---------------------------------------------------------------------------------------------------------------------------------------| | | 0 Decimation filter is disabled. | | | 1 Decimation filter is enabled. | | 12<br>CC | Continuous Conversion/Single Conversion Mode Select | | | One conversion following a triggering event | | | 1 Continuous conversions following a triggering event. | | 11<br>DEC_CLK_ | Decimator Clock Edge Select | | EDGE_SEL | This field is used to select rising edge or falling edge for registering input data by the decimation filter in case of by-pass mode. | | | 0 Posedge will be used. | | | 1 Negedge will be used. | | 10 | Decimator Clock Input Select | | DEC_CLK_INP_<br>SEL | This field is used to select on the chip modulator clock or an external clock for the decimator in case of bypass mode. | | | 0 On the chip modulator clock will be used | | | 1 External clock will be used. | | 9<br>HW_TRG | Hardware Trigger Select | | | This field is used to select trigger source for conversion. | | | 0 Software trigger select | | | 1 Hardware trigger select | | 8–0 | This field is reserved. | | Reserved | This read-only field is reserved and always has the value 0. | ### 25.7.3 Channel2 Configuration Register (AFE\_CH2\_CFR) Channel2 Configuration Register has various fields to configure Channel2 of AFE. Any changes done in this register while the conversion is in progress will come into effect from next conversion only. AFE\_CH2\_CFR field descriptions | Field | Description | |------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31–29<br>DEC_OSR | Decimator OverSampling Ratio select | | 323_33 | This field selects the oversampling ratio. It should not be modified while the filter is operating. The Sinc filter output is scaled based on the OSR to produce a 24 bit signed, two's complement output. | | | 000 64 | | | 001 128 | | | 010 256 | | | 011 512 | | | 100 1024 | | | 101 2048 | | | 110-111 reserved | | 28–18 | This field is reserved. | | Reserved | This read-only field is reserved and always has the value 0. | | 17<br>BYP MODE | AFE Channel2 bypass mode | | _ | This field is used to disable internal modulators of channel2. External modulators will be used. | | | 0 Normal mode | | | 1 Bypass mode where ADC and PGA of channel2 are disabled. | Table continues on the next page... #### wemory Map and Register Definition # AFE\_CH2\_CFR field descriptions (continued) | Field | Description | |-------------------|---------------------------------------------------------------------------------------------------------------------------------------| | 16–15<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 14 | Sigma Delta Modulator enable | | SD_MOD_EN | This is used to enable SD ADC3. | | | 0 SD ADC3 is disabled | | | 1 SD ADC3 is enabled | | 13<br>DEC_EN | Decimation Filter enable | | DEC_EN | This is used to enable decimation filter. | | | 0 Decimation filter is disabled. | | | 1 Decimation filter is enabled. | | 12<br>CC | Continuous Conversion/Single Conversion Mode Select | | | One conversion following a triggering event | | | 1 Continuous conversions following a triggering event. | | 11<br>DEC_CLK_ | Decimator Clock Edge Select | | EDGE_SEL | This field is used to select rising edge or falling edge for registering input data by the decimation filter in case of by-pass mode. | | | Posedge will be used. | | | 1 Negedge will be used. | | 10 | Decimator Clock Input Select | | DEC_CLK_INP_ | This field is used to select on the chip modulator clock or an external clock for the decimator in case of | | SEL | bypass mode. | | | 0 On the chip modulator clock will be used. | | | 1 External clock will be used. | | 9 | Hardware Trigger Select | | HW_TRG | This field is used to select trigger source for conversion. | | | 0 Software trigger select | | | 1 Hardware trigger select | | 8–0 | This field is reserved. | | Reserved | This read-only field is reserved and always has the value 0. | # 25.7.4 Channel3 Configuration Register (AFE\_CH3\_CFR) Channel3 Configuration Register has various fields to configure Channel3 of AFE. Any changes done in this register while the conversion is in progress will come into effect from next conversion only. AFE\_CH3\_CFR field descriptions | Field | Description | |------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31–29<br>DEC_OSR | Decimator OverSampling Ratio select | | | This field selects the oversampling ratio. It should not be modified while the filter is operating. The Sinc filter output is scaled based on the OSR to produce a 24 bit signed, two's complement output. | | | 000 64 | | | 001 128 | | | 010 256 | | | 011 512 | | | 100 1024 | | | 101 2048 | | | 110-111 reserved | | 28–18 | This field is reserved. | | Reserved | This read-only field is reserved and always has the value 0. | | 17<br>BYP MODE | AFE Channel3 bypass mode | | _ | This field is used to disable internal modulators of channel3. External modulators will be used. | | | 0 Normal mode | | | 1 Bypass mode where ADC and PGA of channel3 are disabled. | Table continues on the next page... #### wemory Map and Register Definition # AFE\_CH3\_CFR field descriptions (continued) | Field | Description | |---------------------|---------------------------------------------------------------------------------------------------------------------------------------| | 16–15<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 14 | Sigma Delta Modulator enable | | SD_MOD_EN | This is used to enable SD ADC3. | | | 0 SD ADC3 is disabled | | | 1 SD ADC3 is enabled | | 13<br>DEC_EN | Decimation Filter enable | | DEC_EIN | This is used to enable decimation filter. | | | 0 Decimation filter is disabled. | | | 1 Decimation filter is enabled. | | 12<br>CC | Continuous Conversion/Single Conversion Mode Select | | | 0 One conversion following a triggering event | | | 1 Continuous conversions following a triggering event. | | 11<br>DEC_CLK_ | Decimator Clock Edge Select | | EDGE_SEL | This field is used to select rising edge or falling edge for registering input data by the decimation filter in case of by-pass mode. | | | Posedge will be used. | | | 1 Negedge will be used. | | 10 | Decimator Clock Input Select | | DEC_CLK_INP_<br>SEL | This field is used to select on the chip modulator clock or an external clock for the decimator in case of bypass mode. | | | On the chip modulator clock will be used. | | | 1 External clock will be used. | | 9 | Hardware Trigger Select | | HW_TRG | This field is used to select trigger source for conversion. | | | 0 Software trigger select | | | 1 Hardware trigger select | | 8–0 | This field is reserved. | | Reserved | This read-only field is reserved and always has the value 0. | 412 **Preliminary** Freescale Semiconductor, Inc. # 25.7.5 Control Register (AFE\_CR) AFE Control Register has fields to control the global features of all channels of AFE. ### AFE\_CR field descriptions | Field | Description | |-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 | AFE Master Enable | | MSTR_EN | | | | Setting this bit enables all ADCs and filters simultaneously whose SD_MOD_EN and DEC_EN is asserted. If AFE bypass mode is enabled SD_MOD_EN bit will be ignored. | | | 0 All ADCs are disabled. | | | 1 All ADCs and filters will get simultaneously enabled . | | 30<br>SOFT_TRG0 | Software Trigger0 | | 3011_11100 | This field is set to trigger conversion on AFE Channel0. | | 29<br>SOFT TRG1 | Software Trigger1 | | 30F1_INGT | This field is set to trigger conversion on AFE Channel1. | Table continues on the next page... #### wemory Map and Register Definition # AFE\_CR field descriptions (continued) | Field | Description | |--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 28<br>SOFT_TRG2 | Software Trigger2 | | | This field is set to trigger conversion on AFE Channel2. | | 27<br>SOFT_TRG3 | Software Trigger3 | | | This field is set to trigger conversion on AFE Channel3. | | 26<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 25<br>LPM_EN | Low power Mode enable | | | 0 AFE will be in normal mode | | | AFE will be in low power mode. Setting this bit reduce the current consumption of ADC and Buffer Amplifier , the max modulator clock frequency is below 1Mhz. | | 24–23<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 22 | Software Reset | | RST_B | RST_B field is used to reset all ADCs, PGAs , Decimation filters and Clock configuration bits. | | | 0 All ADCs, PGAs and Decimation filters are disabled. Clock Configuration bits will be reset. | | | 1 .= All ADCs, PGAs and Decimation filters are enabled. | | 21 | Delay OK | | DLY_OK | This field should be asserted after all the four delay registers are loaded. DLY values in CHx_DR will become active when DLY_OK =1 and "a new conversion starts". This bit is self clearing. | | 20–19<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 18 | Result Format | | RESULT_<br>FORMAT | This field can be used to select AFE Result Register formating. | | | Left justified 2's complement 32-bit : SVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVV | | | 1 Right justified 2's complement 32-bit : SSSSSSSSVVVVVVVVVVVVVVVVVVVVVVVVVVVV | | 17–16<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 15–9<br>STRTUP_CNT | Start up count | | | This field is used to program the start up delay of modulators. Minimum value is two. if set less than that it would be converted to two. | | 8–0<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | # 25.7.6 Clock Configuration Register (AFE\_CKR) AFE Clock Configuration Register has fields to control the source of clock, DIV factor and gating of clocks to AFEs. Address: 4003\_0000h base + 1Ch offset = 4003\_001Ch #### AFE\_CKR field descriptions | Field | Description | |-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31–28<br>DIV | Clock Divider Select | | Biv | The DIV selects the clock divider ratio for the modulator clock. The modulator clock frequency is the source clock divided by division factor. The default value of DIV is 2. | | | 0000 divide by 1 | | | 0001 divide by 2 (default) | | | 0010 divide by 4 | | | 0011 divide by 8 | | | 0100 divide by 16 | | | 0101 divide by 32 | | | 0110 divide by 64 | | | 0111 divide by 128 | | | 1xxx divide by 256 | | 27–23<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 22–21 | Clock Source Select | | CLS | | | | The CLS bits are used to select one of the four clock sources for modulator clk. | | | 00 mod_clk0 | | | 01 mod_clk1 | | | 10 mod_clk2 | | | 11 mod_clk3 | | 20–0 | This field is reserved. | | Reserved | This read-only field is reserved and always has the value 0. | # 25.7.7 DMA and Interrupt Register (AFE\_DI) DMA and Interrupt Register has fields to enable DMA and Interrupt requests. Address: 4003\_0000h base + 20h offset = 4003\_0020h ### AFE\_DI field descriptions | Field | Description | |--------------|--------------------------------------------------------------------------------------------------------| | 31<br>DMAEN0 | DMA Enable0 | | | The DMA request is asserted for channel0 when the DMAEN0 and COC0 bits are set. | | 30<br>DMAEN1 | DMA Enable1 | | | The DMA request is asserted for channel1 when the DMAEN1 and COC1 bits are set. | | 29<br>DMAEN2 | DMA Enable2 | | | The DMA request is asserted for channel2 when the DMAEN2 and COC2 bits are set. | | 28<br>DMAEN3 | DMA Enable3 | | | The DMA request is asserted for channel3 when the DMAEN3 and COC3 bits are set. | | 27 | This field is reserved. | | Reserved | This read-only field is reserved and always has the value 0. | | 26<br>INTEN0 | Interrupt Enable 0 | | | The conversion complete interrupt request is asserted for channel 0 when INTEN0 and COC0 bits are set. | | 25<br>INTEN1 | Interrupt Enable 1 | | INIENI | The conversion complete interrupt request is asserted for channel 1 when INTEN1 and COC1 bits are set. | | 24<br>INTEN2 | Interrupt Enable 2 | | | The conversion complete interrupt request is asserted for channel 2 when INTEN2 and COC2 bits are set. | | 23<br>INTEN3 | Interrupt Enable 3 | | | The conversion complete interrupt request is asserted for channel 3 when INTEN3 and COC3 bits are set. | | 22–0 | This field is reserved. | | Reserved | This read-only field is reserved and always has the value 0. | # 25.7.8 Channel0 Delay Register (AFE\_CH0\_DR) Channel Delay Register contains a 11-bit field used to insert a delay into the trigger response of the decimation filters in order to provide phase compensation between four channels. Address: 4003\_0000h base + 2Ch offset = 4003\_002Ch #### AFE\_CH0\_DR field descriptions | Field | Description | |-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31–11<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 10–0<br>DLY | Delay This field can be used to provide phase compensation between four AFE Channels in step of prescaled modulator clock periods. This delay will be seen in every subsequent change to sampling phase after initial sampling. | ### 25.7.9 Channel1 Delay Register (AFE\_CH1\_DR) Channel Delay Register contains a 11-bit field used to insert a delay into the trigger response of the decimation filters in order to provide phase compensation between four channels. Address: 4003\_0000h base + 30h offset = 4003\_0030h #### AFE\_CH1\_DR field descriptions | Field | Description | |-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31–11<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 10–0<br>DLY | Delay This field can be used to provide phase compensation between four AFE Channels in step of prescaled modulator clock periods. This delay will be seen in every subsequent change to sampling phase after initial sampling. | # 25.7.10 Channel2 Delay Register (AFE\_CH2\_DR) Channel2 Delay Register contains a 11-bit field used to insert a delay into the trigger response of the decimation filters in order to provide phase compensation between four channels. Address: 4003\_0000h base + 34h offset = 4003\_0034h #### AFE\_CH2\_DR field descriptions | Field | Description | |-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31–11<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 10–0<br>DLY | Delay This field can be used to provide phase compensation between four AFE Channels in step of prescaled modulator clock periods. This delay will be seen in every subsequent change to sampling phase after initial sampling. | ### 25.7.11 Channel3 Delay Register (AFE\_CH3\_DR) Channel3 Delay Register contains a 11-bit field used to insert a delay into the trigger response of the decimation filters in order to provide phase compensation between four channels. Address: 4003\_0000h base + 38h offset = 4003\_0038h #### AFE\_CH3\_DR field descriptions | Field | Description | |-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31–11<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 10–0<br>DLY | Delay The DLY field can be used to provide phase compensation between four AFE Channels in step of prescaled modulator clock periods. This delay will be seen in every subsequent change to sampling phase after initial sampling. | ### 25.7.12 Channel0 Result Register (AFE\_CH0\_RR) Depending upon AFE\_CR[RESULT\_FORMAT] field result can be represented in following ways: where (S= sign bit, V=valid result value, 0=zero) Left justified 2's complement 32-bit : Right justified 2's complement 32-bit: Address: 4003\_0000h base + 44h offset = 4003\_0044h #### AFE\_CH0\_RR field descriptions | Field | Description | |--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31–23<br>SIGN_BITS | Sign Bits | | | This field represents sign bits (bits 31 to 23 are filled with sign bits) if result is right justified or else 31-bit will be signbit and the lowest 8LSBs will be zeroes in case result is left justified. The formatting option can be selected from AFE_CR[RESULT_FORMAT]. | | 22–0<br>SDR | Sample Data Result | | 0511 | This field represents valid sample value in 2's complement form. | ### 25.7.13 Channel1 Result Register (AFE\_CH1\_RR) Depending upon AFE\_CR[RESULT\_FORMAT] field result can be represented in following ways: where (S= sign bit , V=valid result value, 0=zero) Left justified 2's complement 32-bit : Right justified 2's complement 32-bit : Address: 4003\_0000h base + 48h offset = 4003\_0048h #### wemory Map and Register Definition #### AFE\_CH1\_RR field descriptions | Field | Description | |--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31–23<br>SIGN_BITS | Sign Bits This field represents sign bits (bits 31 to 23 are filled with sign bits) if result is right justified or else 31-bit will be signbit and the lowest 8LSBs will be zeroes in case result is left justified. The formatting option can be selected from AFE_CR[RESULT_FORMAT]. | | 22-0<br>SDR | Sample Data Result This field represents valid sample value in 2's complement form. | ### 25.7.14 Channel2 Result Register (AFE\_CH2\_RR) Depending upon AFE\_CR[RESULT\_FORMAT] field result can be represented in following ways: where (S= sign bit, V=valid result value, 0=zero) Left justified 2's complement 32-bit : SVVVVVVVVVVVVVVVVVVVVVVVVVVV000000000 Right justified 2's complement 32-bit : Address: 4003\_0000h base + 4Ch offset = 4003\_004Ch #### AFE\_CH2\_RR field descriptions | Field | Description | |--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------| | 31–23<br>SIGN_BITS | Sign Bits This field represents sign bits (bits 31 to 23 are filled with sign bits) if result is right justified or else 31-bit | | | will be signbit and the lowest 8LSBs will be zeroes in case result is left justified. The formatting option can be selected from AFE_CR[RESULT_FORMAT]. | | 22–0<br>SDR | Sample Data result | | SBIT | This field represents valid sample value in 2's complement form. | ### 25.7.15 Channel3 Result Register (AFE\_CH3\_RR) Depending upon AFE\_CR[RESULT\_FORMAT] field result can be represented in following ways: where (S= sign bit, V=valid result value, 0=zero) ### ### Address: 4003\_0000h base + 50h offset = 4003\_0050h #### AFE\_CH3\_RR field descriptions | Field | Description | |--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31–23<br>SIGN_BITS | Sign Bits | | | This field represents sign bits (bits 31 to 23 are filled with sign bits) if result is right justified or else 31-bit will be signbit and the lowest 8LSBs will be zeroes in case result is left justified. The formatting option can be selected from AFE_CR[RESULT_FORMAT]. | | 22–0<br>SDR | Sample Data result | | 2511 | This field represents valid sample value in 2's complement form. | # 25.7.16 Status Register (AFE\_SR) AFE Status Register has three types of flags COC, OVR, RDY that indicate the status of each channel of AFE. #### AFE\_SR field descriptions | Field | Description | |------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31<br>COC0 | Conversion Complete | | | The COC flag is set when a conversion is completed and cleared on a read of the result register CH0_AFE_RR. Since modulators take some time to start up, this field is set at third sample and first two samples are ignored. | | 30<br>COC1 | Conversion Complete | | | The COC flag is set when a conversion is completed and cleared on a read of the result register CH1_AFE_RR. Since modulators take some time to start up, this field is set at third sample and first two samples are ignored. | | 29<br>COC2 | Conversion Complete | | 0002 | The COC flag is set when a conversion is completed and cleared on a read of the result register CH2_AFE_RR. Since modulators take some time to start up, this field is set at third sample and first two samples are ignored. | | 28<br>COC3 | Conversion Complete | Table continues on the next page... # AFE\_SR field descriptions (continued) | Field | Description | |-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | The COC flag is set when a conversion is completed and cleared on a read of the result register CH3_AFE_RR. Since modulators take some time to start up, this field is set at third sample and first two samples are ignored. | | 27–25<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 24<br>OVR0 | Overflow Flag This bit is set when the previous data has not been read and new data has already been arrived to be loaded in result register of the AFE Channel0 and cleared on a read of the result register. | | 23<br>OVR1 | Overflow Flag This bit is set when the previous data has not been read and new data has already been arrived to be loaded in result register of the AFE Channel1 and cleared on a read of the result register | | 22<br>OVR2 | Overflow Flag This bit is set when the previous data has not been read and new data has already been arrived to be loaded in result register of the AFE Channel2 and cleared on a read of the result register | | 21<br>OVR3 | Overflow Flag This bit is set when the previous data has not been read and new data has already been arrived to be loaded in result register of the AFE Channel3 and cleared on a read of the result register | | 20<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 19<br>RDY0 | AFE Ready1 It indicates that AFE Channel0 is ready for conversion. 0 AFE Channel0 is disabled or has not completed its start up period 1 AFE Channel0 is ready to initiate conversions. | | 18<br>RDY1 | AFE Ready2 It indicates that AFE Channel1 is ready for conversion. 0 AFE Channel1 is disabled or has not completed its start up period 1 AFE Channel1 is ready to initiate conversions. | | 17<br>RDY2 | AFE Ready3 It indicates that AFE Channel2 is ready for conversion. 0 AFE Channel2 is disabled or has not completed its start up period 1 AFE Channel2 is ready to initiate conversions. | | 16<br>RDY3 | AFE Ready4 It indicates that AFE Channel3 is ready for conversion. 0 AFE Channel3 is disabled or has not completed its start up period 1 AFE Channel3 is ready to initiate conversions. | | 15–0<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | #### 25.8 Power Modes AFE supports four power modes - Normal Run Mode - Low Power Run Mode - Wait Mode - Stop Mode #### 25.8.1 Normal Run Mode In Normal run mode AFE is fully functional and maximum clock frequency of operation can be up to 6.5 MHz.In this mode PGA can be optionally bypassed to achieve further low power. #### **25.8.2 Wait Mode** Operation of the AFE is not affected by the MCU entering wait mode. If conversions have already been initiated before entering wait mode, conversions will continue in wait. Conversions can be initiated while the MCU is in wait mode by means of the hardware trigger. Since the CPU is inactive in wait, a software trigger cannot initiate conversions while in wait. The system must continue to produce the modulator clock in order for conversions to continue during wait. If enabled, the AFE interrupt will wake the MCU from wait mode. ### 25.8.3 Low Power Run Mode When the LPM\_EN bit is set the AFE enters Low power run mode. In this mode the maximum frequency of the mod\_clk should be less than equal to 1.6 MHz where 768 KHz is the nominal value. Setting this mode reduces the current consumption of ADC. When the device enters Very Low power mode(VLP) then AFE automatically enters into low power mode. #### **25.8.4 STOP Mode** When the device enters stop mode the ADC can be fully operational if the mod\_clk is present. AFE is capable to wakeup the device from STOP mode through asynchronous interrupt. AFE is also capable to generate asynchronous DMA request to DMA controller in absence of bus clk. The asynchronous DMA request only gets asserted in STOP mode and remains asserted until synchronous DMA gets asserted in presence of system clock enabled by System Wake-up unit. # 25.9 Functional Description The main components of AFE are analog modulators, programmable gain amplifiers, decimation filters and digital logic comprised of programming model to configure AFE, store result register, clock generation, trigger generation logic and interrupt, dma capability. Modulator clock is provided by the system or external source which is internally prescaled to the correct operating range for AFE. The modulator samples the analog input signal and generates a digital output code at this clock rate. The high rate modulator output is filtered and decimated by the decimation filters which produce 24-bit output samples at a lower rate. Due to the latency of the decimation filter, each time decimation filter is enabled or resynchronization happens it takes three output samples to reach steady state in which fully valid samples are produced. This is the first valid AFE conversion data after it is enabled or re-synchronized. ### 25.9.1 Start Up The AFE is disabled by default or when the enable bit in corresponding AFEx\_CFR register is cleared. After reset user should enable all required SD-ADCs (SD\_MOD\_ENx =1), PGAs and Decimation filter and then enbale the global control by setting MSTR\_EN bit. Once the configuration is done, AFE will wait for the conversion trigger to start conversion. Once software/hardware (according to TRGx bit) trigger is received the enabled ADC modules go through a 'n' modulator clock cycle start-up period where 'n' should be programmed (AFE\_CR[STARTUP\_CNT]) to achieve at-least 20 µs startup time. Once this start-up has completed the RDY flag is set and conversions begins. The software/hardware trigger signal is ignored during the start-up period. **runctional Description** ### 25.9.2 Conversion Control Once a conversion is triggered, the modulator, decimation filters are enabled and the COCx flag is set after the conversion completes. In continuous conversion mode (CC=1), conversions continue after the first sample. Using continuous conversion mode, a series of conversions can be made on at the rate of one sample per OSR modulator clock cycles. In single conversion mode each conversion requires a conversion trigger. ### 25.9.2.1 Triggering Conversions Both software and hardware trigger mode is supported to initiate conversion. - In software trigger mode (TRG=0), writing to AFE\_CR[SFT\_TRGx] bit will cause a conversion to initiate or restart while a conversion is already in progress. - In hardware trigger mode (TRG=1), a conversion is initiated/restarted by the assertion of the hardware trigger input signal. The hardware trigger input is ignored during the start-up period. The hardware trigger source is device specific. #### NOTE Conversion modes are mentioned in details in later section. ### 25.9.2.2 Conversion Complete When a conversion completes, the new sample value is transferred to the AFEx\_RR register and the corresponding COCx bit is set. Several other actions can also be enabled when a conversion completes, for example if the INT\_EN bit is set, the interrupt request is asserted, if the DMA bit is set the DMA request is asserted. The COC bit and interrupt request are all cleared by reading the AFEx\_RR register. If the COC bit is still set when a conversion completes and the new sample comes it will overwrite the old sample and set the overflow flag. #### 25.9.2.3 Total Conversion Time - In Single conversion mode the total conversion time for a single conversion is (AFE\_STARTUP+ 3 x OSR x MOD\_CLK) after the trigger event. - In Continuous conversion mode the conversion time for the first 24 bit sample is (AFE\_STARTUP + 3 x OSR x MOD\_CLK) after the trigger event, however the subsequent 24bit samples are available after (OSR x MOD\_CLK) cycle. - During any continuous conversion if user opts to resync any conversion by providing trigger, the first conversion result after the resync operation will be available after (AFE\_STARTUP time + 3xOSRxMOD\_CLK) cycle. - However if user opts for run time phase compensation for any channel after the current conversion by adjusting Phase delay registers and setting dly\_ok signal,the conversion result won't take 3 decimator clock cycle(3xOSRxMOD\_CLK).Instead the sampled data will be available after OSRxMOD\_CLK cycle. #### NOTE There can be latency of 2-3 mod\_clk cycle in conversion time due to synchronization of asynchronous trigger. ### 25.9.2.4 Timing Diagram **Single conversion:** Conversion result (Val1 or Val2) available after (STARTUP\_TIME + 3xOSR) mod\_clk cycle Figure 25-17. Single conversion **Continuous conversion**: Val1 is available after (STARTUP\_TIME + 3xOSR) mod\_clk cycle Val2 to Val5 are available after OSR mod\_clk cycle. #### runctional Description Figure 25-18. Continuous conversion Continuous conversion with phase delay: Val1 of channel0, 1 are available after (STARTUP\_TIME + 3xOSR) mod\_clk cycle Val2 of channel0, 1 are available after OSR mod\_clk cycle. Val3 of channel1 is available after (OSR+5) mod\_clk cycle which signifies input sample of second channel is delayed by 5 mod\_clk cycle w.r.t channel0. Val4, Val5 of channel1 are available after(OSR+8) mod\_clk cycle which signifies input sample of second channel is delayed by 8 mod\_clk cycle w.r.t channel0. Figure 25-19. Continuous conversion with phase delay **Resynchronization of conversion:** In case user initiates trigger during any conversion in progress, system will restart the conversion and first valid data after resynchronization will be available after 3xOSR mod\_clk cycle. Figure 25-20. Resynchronization of conversion # 25.9.2.5 Aborting Conversion To abort a conversion in progress, disable the ADC by clearing SD\_MOD\_ENx bit.To abort/disable all the conversions globally ,clear MSTR\_EN register.The AFEx\_RR register will retain the value of the last completed conversion. ### 25.9.3 Modes of Conversion AFE supports both single and continuous conversion mode where each channel can independently be either in single or continuous conversion mode. Below are the steps needed to initiate various conversion supported by AFE. ### 25.9.3.1 Single Conversion By default AFE is in single conversion(AFE\_CR[CC]=0) mode. After each single conversion modulators, PGAs and Filters get automatically disabled. User should set SW\_TRG or hardware trigger to re-initiate another single conversion. Due to latency of decimation filter the valid conversion data becomes available after (AFE\_STRUP + 3\*OSR) mod\_clk cycle. The different approaches to trigger a single conversions are mentioned below. ### 25.9.3.1.1 Software Trigger If software trigger is enabled (HW\_TRG = 0) then conversion is initiated by setting SW\_TRGx bit. The steps are #### runctional Description - Enable and configure the ADCs by programming CHx\_CFR register. - Select AFE mod\_clk by configuring AFE\_CKR register - Configure 20us startup delay counter by programming AFE\_CR[STRTUP\_CNT] register w.r.t mod\_clk period. - If phase compensation is required between the channels, configure the phase difference (in terms of mod\_clk cycle) by programming CHx\_DR register. - Once CHx\_DR are programmed, set AFE\_CR[DLY\_OK] bit. - Set AFE\_CR[MSTR\_EN] bit. - Set SOFT\_TRGx bit.Setting the bit will initiate conversion after AFE startup delay programmed . - In single conversion mode due to the latency of AFE filter, the valid result will be available after 3 \* OSR modulator clock cycle. - If Conversion complete DMA is enabled then AFE will generate dma\_request to DMA controller after each valid conversion. - If DMA is disabled and Conversion complete interrupt is enabled AFE will generate interrupt and set COCx flag after each valid conversion. - While clearing AFE\_CR[MSTR\_EN] the last conversion result may give invalid result. #### **NOTE** All the configuration registers should be programmed before setting AFE\_CR[MSTR\_EN] bit. While the bit is set user should not change or disable any configuration. ### 25.9.3.1.2 Hardware Trigger If hardware trigger is enabled ( $HW\_TRG = 1$ ), a single conversion is initiated by external trigger event. The steps to initiate single conversion using hardware trigger are mentioned below - Enable and configure the ADCs by programming CHx\_CFR register. - Select AFE mod\_clk by configuring AFE\_CKR register - Configure 20us startup delay counter by programming AFE\_CR[STARTUP\_CNT] w.r.t mod\_clk period. - If phase compensation is required between the channels, configure the phase difference (in terms of mod\_clk cycle) by programming CHx\_DR register. - Set DLY\_OK flag. - If already not set ,set AFE\_CHX\_CFR[HW\_TRG] bit. - Set AFE\_CR[MSTR\_EN] bit. - Once the AFE is configured properly, an external pulse trigger will enable all Modulators, PGAs, Filters and its startup period. After the startup period the conversion result will be available after 3\*OSR mod clock cycle. - If Conversion complete DMA is enabled then AFE will generate dma\_request to DMA controller. - If DMA is disabled and Conversion complete interrupt is enabled AFE will generate interrupt and set COCx flag - All the ADCs,PGA and Filter will be automatically disabled after a valid conversion. - However for subsequent transfer user doesn't have to re-program CHx\_CFR register. - The subsequent hardware trigger will automatically enable modulators, PGAs and decimation filters for the next conversion. #### NOTE All the configuration registers should be programmed before setting AFE\_CR[MSTR\_EN] bit. While the bit is set user should not change or disable any configuration. #### 25.9.3.2 Continuous Conversion Setting AFE\_CR[CC] bit prior to any conversion, initiates continuous conversion. The different approaches to trigger a continuous conversions are mentioned below. #### 25.9.3.2.1 Soft Trigger If software trigger is enabled (HW\_TRG= 0) then conversion is initiated by SW\_TRGx bit. The steps are : - Enable and configure the channels by programming CHx\_CFR register. - Select AFE mod\_clk by configuring AFE\_CR register - Configure 20us startup delay counter by programming AFE\_CR[STRTUP\_CNT] filed w.r.t mod\_clk period. - If phase compensation is required between the channels, configure the phase difference (in terms of mod\_clk cycle) by programming CHx\_DR register. - Set AFE\_CR[MSTR\_EN] bit.Setting the bit will enable all ADCs and filters after AFE startup delay programmed . - Set AFE\_CR[DLY\_OK] filed. - Set SOFT\_TRGx bit. Setting this bit will initiate conversion after AFE start up delay pogrammed. - Software trigger event during this start up period will be ignored. - In continuous conversion mode due to the latency of AFE filter, the first valid result will be available after 3 \* OSR modulator clock cycle. Subsequent results will be available after OSR modulator clock cycle. - If Conversion complete DMA is enabled then AFE will generate dma\_request to DMA controller after each valid conversion. #### runctional Description - If DMA is disabled and Conversion complete interrupt is enabled AFE will generate interrupt and set COCx flag after each valid conversion. - To disable continuous conversion globally for all channels, clear AFE\_CR[MSTR\_EN] bit or disable individual channels Filter(DEC\_ENx = 0 or SD\_MOD\_EN = 0). - While clearing AFE\_CR[MSTR\_EN] the last conversion result may give invalid result. #### NOTE All the configuration registers should be programmed before setting AFE\_CR[MSTR\_EN] bit. While the bit is set user should not change or disable any configuration otherwise it will abort the current conversion. ### 25.9.3.2.2 Hardware Trigger If hardware trigger is enabled (HW\_TRG = 1) then conversion is initiated by an external trigger pulse. The steps are - Enable and configure the channels by programming CHx\_CFR register. - Select AFE mod\_clk by configuring AFE\_CR register - Configure 20us startup delay counter by programming AFE\_CR[STRTUP\_CNT] filed w.r.t mod\_clk period. - If phase compensation is required between the channels, configure the phase difference (in terms of mod\_clk cycle) by programming CHx\_DR register. - SET AFE\_CHX\_CFR[HW\_TRG] bit(if not already set) to recognize hardware trigger event. - Set AFE\_CR[MSTR\_EN] bit.Setting the bit will enable all ADCs and filters after AFE startup delay programmed . - Set AFE\_CR[DLY\_OK] filed. - An external trigger pulse will initiate conversion after the startup period. - External trigger event during this start-up period will be ignored. - In continuous conversion mode due to the latency of AFE filter, the first valid result will be available after 3 \* OSR modulator clock cycle. Subsequent results will be available after OSR modulator clock cycle. - While the conversion is in progress any hardware trigger event will restart the conversion and the first conversion data will be available after (AFE STARTUP +3xOSR) mod\_clk cycle following the trigger event. - If Conversion complete DMA is enabled then AFE will generate dma\_request to DMA controller after each valid conversion. - If DMA is disabled and Conversion complete interrupt is enabled AFE will generate interrupt and set COCx flag after each valid conversion. - To disable continuous conversion globally for all channels, clear AFE\_CR[MSTR\_EN] bit or disable individual channels Filter(DEC\_ENx = 0 or SD\_MOD\_EN = 0). - While clearing AFE\_CR[MSTR\_EN] the last conversion result may give invalid result. #### NOTE All the configuration registers should be programmed before setting AFE\_CR[MSTR\_EN] bit. While the bit is set user should not change or disable any configuration. ## 25.9.3.2.3 On-the-fly Phase Delay Adjustment While continuous conversion is in progress, on-the-fly delay adjustment between channels can be done using these steps. - If phase compensation is required between the channels, configure the phase difference (in terms of mod\_clk cycle) by programming CHx\_DR register. - Select AFE\_CR[DLY\_OK] bit. - Internal phase synchronization will be initiated for the next sample with the adjusted delay programmed in CHx\_DR register. - If Conversion complete DMA is enabled then AFE will generate dma\_request to DMA controller after each valid conversion. - If DMA is disabled and Conversion complete interrupt is enabled AFE will generate interrupt and set COCx flag after each valid conversion. - To disable continuous conversion globally for all channels, clear AFE\_CR[MSTR\_EN] bit or disable individual channels Filter(DEC\_ENx = 0 or SD\_MOD\_EN = 0). - While clearing AFE\_CR[MSTR\_EN] the last conversion result may give invalid result. #### NOTE All the configuration registers should be programmed before setting AFE\_CR[MSTR\_EN] bit. While the bit is set user should not change or disable any configuration otherwise it will abort the current conversion. **Decimation Filter** ## 25.9.4 Independent Control for Conversion Conversion control configuration for all channels are completely independent to each other to enhance the flexibility of AFE functionality. Hence user can configure one channel for single conversion with software trigger mode where the other channels are in continuous conversion mode triggered by either software or external hardware source. Each channel has independent conversion complete indicator to the system. ## 25.10 Decimation Filter The decimation filter is a digital block that low-pass filters and decimates the high rate, single bit sigma-delta modulator output to generate a lower rate 24-bit output signal. The decimation filter supports over-sampling ratios (OSR) from 64 to 2048. It includes a third order sinc filter. The sinc filter down samples the signal by the selected OSR. The sinc filter output it scaled based on the OSR and then limited to produce a 24-bit signed, two's complement output which is stored in corresponding channel's result register. ## 25.10.1 Sampling Phase Control When conversion is either HW or SW triggered, regardless of the operation mode, or in continuous mode when new conversion starts then the phase between two or more channels may be adjusted ,if user opts to adjust the sampling phase during filtering operation to allow a precise sampling phase offset to be established and adjusted between two or more channels it is required to update the delay register and set dly\_ok at the end to indicate the update of delay register. The delay registers set the initial phase offsets for the channels when they are enabled. When the channels are running, the delay registers are used to add delay to a channel. However the value of the delay register comes into effect from the next sampling period after the current conversion is completed. For example, the set of initial values in delay register are 0,5,10 and 8 for the four channels and we want the final sampling phase delays to be 0,4,12,10. The delays of 1,0,3,3 are updated in corresponding channel's delay register which yield the 1,5,13,11 as absolute delays and have the desired relative delay of 0,4,12,10 respectively. ## 25.10.2 Frequency response The overall filter frequency response scales with the output sample rate which is a function of the modulator clock (mod\_clk) frequency and the OSR. If the FIR filter is disabled, the frequency response is a sinc3 response which is H(z) = ((1 - z-OSR) / (1 - z-1))3 An example of the frequency response with a modulator clock of 6.144 MHz and an OSR=256 is shown in Figure . In this, case the sample frequency is 24 kHz, so frequency components above 12 kHz are aliased back into the band from 0 to 12 kHz. Additional decimation and droop compensation filtering can done in software. Figure 25-21. Frequency Response ,6.144MHz,OSR=256 ## 25.11 Modulator Bypass Mode Modulator bypass mode is set by setting CHn\_CR[BYP\_MOD] bit. When set, the analog part of the corresponding channel gets automatically disabled. The SINC3 Filter and phase shift compensation block can be used in connection with an external sigma delta modulator. The clock to external sigma delta modulator can be derived from on-chip modulator clock. On the contrary, external sigma delta modulator binary output stream is routed to internal decimation filter. In such a way, any external sigma delta modulator can be used for the measurement along with other built-in sigma delta modulators. The clock is provided either by on-chip mod\_clk source or any external clock input which after division fed to decimation filter as well as external Modulator through mod\_clk\_out port. The module also supports independent control for each channel. So one channel can be used in bypass mode, while the others are in modulator engage mode. #### woulator Bypass Mode Figure 25-22. Data and Clock Flow in Modulator Bypass Mode ## **NOTE** The above diagram depicts the data/clock flow for one channel. The same is replicated for each channel. # Chapter 26 Analog-to-Digital Converter (ADC) ## 26.1 Introduction #### **NOTE** For the chip-specific implementation details of this module's instances, see the chip configuration information. The 16-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, see the power management information of the device. ## 26.1.1 Features Following are the features of the ADC module. - Linear successive approximation algorithm with up to 16-bit resolution - Up to 24 single-ended external analog inputs - Output modes: - single-ended 16-bit, 12-bit, 10-bit, and 8-bit modes - Output in right-justified unsigned format for single-ended - Single or continuous conversion, that is, automatic return to idle after single conversion - Configurable sample time and conversion speed/power - Conversion complete/hardware average complete flag and interrupt #### muroduction - Input clock selectable from up to four sources - Operation in low-power modes for lower noise - Asynchronous clock source for lower noise operation with option to output the clock - Selectable hardware conversion trigger with hardware channel select - 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 ## 26.1.2 Block diagram The following figure is the ADC module block diagram. Figure 26-1. ADC block diagram ## 26.2 ADC signal descriptions The ADC module supports up to 24 single-ended inputs. The ADC also requires four supply/reference/ground connections. #### **NOTE** Refer to ADC configuration section in chip configuration chapter for the number of channels supported on this device. #### Table 26-1. ADC signal descriptions | Signal | Description | I/O | |------------------|------------------------------------|-----| | AD <i>n</i> | Single-Ended Analog Channel Inputs | I | | $V_{DDA}$ | Analog Power Supply | I | | V <sub>SSA</sub> | Analog Ground | I | ## 26.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. ## 26.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}$ . ## 26.2.3 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 SC1[ADCH] channel select bits. ## 26.3 Memory map and register definitions This section describes the ADC registers. ## ADC memory map | Absolute address (hex) | Register name | Width<br>(in bits) | Access | Reset value | Section/<br>page | |------------------------|-----------------------------------------------|--------------------|--------|-------------|------------------| | 4002_B000 | ADC Status and Control Registers 1 (ADC_SC1A) | 32 | R/W | 0000_001Fh | 26.3.1/441 | | 4002_B004 | ADC Status and Control Registers 1 (ADC_SC1B) | 32 | R/W | 0000_001Fh | 26.3.1/441 | | 4002_B008 | ADC Status and Control Registers 1 (ADC_SC1C) | 32 | R/W | 0000_001Fh | 26.3.1/441 | | 4002_B00C | ADC Status and Control Registers 1 (ADC_SC1D) | 32 | R/W | 0000_001Fh | 26.3.1/441 | Table continues on the next page... #### **ADC** memory map (continued) | Absolute<br>address<br>(hex) | Register name | Width<br>(in bits) | Access | Reset value | Section/<br>page | |------------------------------|-------------------------------------------------------------|--------------------|--------|-------------|------------------| | 4002_B010 | ADC Configuration Register 1 (ADC_CFG1) | 32 | R/W | 0000_0000h | 26.3.2/445 | | 4002_B014 | ADC Configuration Register 2 (ADC_CFG2) | 32 | R/W | 0000_0000h | 26.3.3/446 | | 4002_B018 | ADC Data Result Register (ADC_RA) | 32 | R | 0000_0000h | 26.3.4/447 | | 4002_B01C | ADC Data Result Register (ADC_RB) | 32 | R | 0000_0000h | 26.3.4/447 | | 4002_B020 | ADC Data Result Register (ADC_RC) | 32 | R | 0000_0000h | 26.3.4/447 | | 4002_B024 | ADC Data Result Register (ADC_RD) | 32 | R | 0000_0000h | 26.3.4/447 | | 4002_B028 | Compare Value Registers (ADC_CV1) | 32 | R/W | 0000_0000h | 26.3.5/448 | | 4002_B02C | Compare Value Registers (ADC_CV2) | 32 | R/W | 0000_0000h | 26.3.5/448 | | 4002_B030 | Status and Control Register 2 (ADC_SC2) | 32 | R/W | 0000_0000h | 26.3.6/449 | | 4002_B034 | Status and Control Register 3 (ADC_SC3) | 32 | R/W | 0000_0000h | 26.3.7/451 | | 4002_B038 | ADC Offset Correction Register (ADC_OFS) | 32 | R/W | 0000_0004h | 26.3.8/453 | | 4002_B03C | ADC Plus-Side Gain Register (ADC_PG) | 32 | R/W | 0000_8200h | 26.3.9/453 | | 4002_B044 | ADC Plus-Side General Calibration Value Register (ADC_CLPD) | 32 | R/W | 0000_000Ah | 26.3.10/454 | | 4002_B048 | ADC Plus-Side General Calibration Value Register (ADC_CLPS) | 32 | R/W | 0000_0020h | 26.3.11/454 | | 4002_B04C | ADC Plus-Side General Calibration Value Register (ADC_CLP4) | 32 | R/W | 0000_0200h | 26.3.12/455 | | 4002_B050 | ADC Plus-Side General Calibration Value Register (ADC_CLP3) | 32 | R/W | 0000_0100h | 26.3.13/455 | | 4002_B054 | ADC Plus-Side General Calibration Value Register (ADC_CLP2) | 32 | R/W | 0000_0080h | 26.3.14/456 | | 4002_B058 | ADC Plus-Side General Calibration Value Register (ADC_CLP1) | 32 | R/W | 0000_0040h | 26.3.15/456 | | 4002_B05C | ADC Plus-Side General Calibration Value Register (ADC_CLP0) | 32 | R/W | 0000_0020h | 26.3.16/457 | ## 26.3.1 ADC Status and Control Registers 1 (ADC\_SC1n) SC1A is used for both software and hardware trigger modes of operation. 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. The SC1B–SC1n registers indicate potentially multiple SC1 registers for use only in hardware trigger mode. See 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, when SC2[ADTRG]=0, writes to SC1A subsequently initiate a new conversion, if SC1[ADCH] contains a value other than all 1s. 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. ## ADC\_SC1n field descriptions | Field | Description | |------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31–8<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 7<br>COCO | Conversion Complete Flag This is a read-only field that is set each time a conversion is completed when the compare function is | | | disabled, or SC2[ACFE]=0 and the hardware average function is disabled, or SC3[AVGE]=0. When the compare function is enabled, or SC2[ACFE]=1, COCO is set upon completion of a conversion only if the compare result is true. When the hardware average function is enabled, or SC3[AVGE]=1, COCO is set upon completion of the selected number of conversions (determined by AVGS). COCO in SC1A is also set at the completion of a calibration sequence. COCO is cleared when the respective SC1n register is written or when the respective Rn register is read. | | | <ul><li>0 Conversion is not completed.</li><li>1 Conversion is completed.</li></ul> | | 6<br>AIEN | Interrupt Enable Enables conversion complete interrupts. When COCO becomes set while the respective AIEN is high, an | | | <ul><li>interrupt is asserted.</li><li>Conversion complete interrupt is disabled.</li><li>Conversion complete interrupt is enabled.</li></ul> | Table continues on the next page... ## ADC\_SC1n field descriptions (continued) | Field | Description | |----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 5 | This field is reserved. | | Reserved | This reserved bit should not be changed. | | 4–0 | Input channel select | | ADCH | Selects one of the input channels. | | | <b>NOTE:</b> Some of the input channel options in the bitfield-setting descriptions might not be available for | | | your device. For the actual ADC channel assignments for your device, see the Chip Configuration | | | details. | | | The successive approximation converter subsystem is turned off when the channel select bits are all set, that is, ADCH = 11111. This feature allows 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 ADCH to all 1s 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. | | | 00000 AD0 is selected as input. | | | 00000 AD0 is selected as input. | | | 00010 AD2 is selected as input. | | | 00011 AD3 is selected as input. | | | 00100 AD4 is selected as input. | | | 00101 AD5 is selected as input. | | | 00110 AD6 is selected as input. | | | 00111 AD7 is selected as input. | | | 01000 AD8 is selected as input. | | | 01001 AD9 is selected as input. | | | 01010 AD10 is selected as input. 01011 AD11 is selected as input. | | | 01011 AD11 is selected as input. 01100 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. | | | 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 V <sub>REFSH</sub> is selected as input. Voltage reference selected is determined by SC2[REFSEL]. | | | 11110 V <sub>REFSL</sub> is selected as input. Voltage reference selected is determined by SC2[REFSEL]. | | | 11111 Module is disabled. | ## 26.3.2 ADC Configuration Register 1 (ADC\_CFG1) The configuration Register 1 (CFG1) selects the mode of operation, clock source, clock divide, and configuration for low power or long sample time. ### **ADC\_CFG1** field descriptions | Field | Description | |------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31–8<br>Reserved | This field is reserved. | | Reserved | This read-only field is reserved and always has the value 0. | | 7<br>ADLPC | Low-Power Configuration | | | 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<br>ADIV | Clock Divide Select | | | 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. | Table continues on the next page... ## **ADC\_CFG1** field descriptions (continued) | Field | Description | |---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | 0 Short sample time. | | | 1 Long sample time. | | 3–2<br>MODE | Conversion mode selection | | WODE | Selects 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 It is single-ended 16-bit conversion. | | 1–0<br>ADICLK | Input Clock Select | | ADIOLIC | Selects 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, when CFG2[ADACKEN]=0, the asynchronous clock is activated at the start of a conversion and deactivated 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)/2 | | | 10 Alternate clock (ALTCLK) | | | 11 Asynchronous clock (ADACK) | ## 26.3.3 ADC Configuration Register 2 (ADC\_CFG2) Configuration Register 2 (CFG2) selects the special high-speed configuration for very high speed conversions and selects the long sample time duration during long sample mode. ## ADC\_CFG2 field descriptions | Field | Description | |------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31–8<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 7–5<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 4<br>MUXSEL | ADC Mux Select Changes the ADC mux setting to select between alternate sets of ADC channels. | | | 0 ADxxa channels are selected. | | | | | 3<br>ADACKEN | Asynchronous Clock Output Enable | | ABAGNEN | Enables the asynchronous clock source and the clock source output regardless of the conversion and status of CFG1[ADICLK]. Based on MCU configuration, the asynchronous clock may be used by other modules. See chip configuration information. Setting this field 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 because the ADACK clock is already operational. | | | O Asynchronous clock output disabled; Asynchronous clock is enabled only if selected by ADICLK and a conversion is active. | | | 1 Asynchronous clock and clock output is enabled regardless of the state of the ADC. | | 2<br>ADHSC | High-Speed Configuration | | ADITISC | Configures the ADC for very high-speed operation. The conversion sequence is altered with 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 with 2 additional ADCK cycles to total conversion time. | | 1-0<br>ADLSTS | Long Sample Time Select | | | Selects between the extended sample times when long sample time is selected, that is, when CFG1[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. | ## 26.3.4 ADC Data Result Register (ADC\_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 R n 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 26-11. Data result register description | Conversion mode | D15 | D14 | D13 | D12 | D11 | D10 | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | Format | |-------------------------|-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----|------------------------------| | 16-bit single-<br>ended | D | D | D | D | D | D | D | D | D | D | D | D | D | D | D | D | Unsigned right justified | | 12-bit single-<br>ended | 0 | 0 | 0 | 0 | D | D | D | D | D | D | D | D | D | D | D | D | Unsigned right-<br>justified | | 10-bit single-<br>ended | 0 | 0 | 0 | 0 | 0 | 0 | D | D | D | D | D | D | D | D | D | D | Unsigned right-<br>justified | | 8-bit single-<br>ended | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | D | D | D | D | D | D | D | D | Unsigned right-<br>justified | #### **NOTE** S: Sign bit or sign bit extension; D: Data, which is 2's complement data if indicated Address: $4002\_B000h$ base + 18h offset + $(4d \times i)$ , where i=0d to 3d #### ADC\_Rn field descriptions | Field | Description | |-----------|--------------------------------------------------------------------------------------| | | This field is reserved. This read-only field is reserved and always has the value 0. | | 15–0<br>D | Data result | ## 26.3.5 Compare Value Registers (ADC\_CVn) The compare value registers (CV1 and CV2) contain a compare value used to compare the conversion result when the compare function is enabled, that is, SC2[ACFE]=1. This register is formatted in the same way as the Rn registers in different modes of operation for both bit position definition and value format using unsigned or sign-extended 2's complement. Therefore, the compare function uses only the CVn fields that are related to the ADC mode of operation. The compare value 2 register (CV2) is used only when the compare range function is enabled, that is, SC2[ACREN]=1. 449 #### ADC\_CVn field descriptions | Field | Description | |-------------------|--------------------------------------------------------------------------------------| | 31–16<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 15–0<br>CV | Compare Value. | ## 26.3.6 Status and Control Register 2 (ADC\_SC2) The status and control register 2 (SC2) contains the conversion active, hardware/software trigger select, compare function, and voltage reference select of the ADC module. ## **ADC\_SC2** field descriptions | Field | Description | |------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31–8<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 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. | | | <ul><li>0 Conversion not in progress.</li><li>1 Conversion in progress.</li></ul> | | 6<br>ADTRG | Conversion Trigger Select | | ADING | Selects the type of trigger used for initiating a conversion. Two types of trigger are selectable: • Software trigger: When software trigger is selected, a conversion is initiated following a write to SC1A. | | | <ul> <li>Hardware trigger: When hardware trigger is selected, a conversion is initiated following the assertion of the ADHWT input after a pulse of the ADHWTSn input.</li> </ul> | | | 0 Software trigger selected. | | | 1 Hardware trigger selected. | | 5<br>ACFE | Compare Function Enable | | | Enables the compare function. | | | 0 Compare function disabled. | | | 1 Compare function enabled. | | 4<br>ACFGT | Compare Function Greater Than Enable | | | Configures the compare function to check the conversion result relative to the CV1 and CV2 based upon the value of ACREN. ACFE must be set for ACFGT to have any effect. | | | O Configures less than threshold, outside range not inclusive and inside range not inclusive; functionality based on the values placed in CV1 and CV2. | | | 1 Configures greater than or equal to threshold, outside and inside ranges inclusive; functionality based on the values placed in CV1 and CV2. | | 3<br>ACREN | Compare Function Range Enable | | AUNEIN | Configures the compare function to check if the conversion result of the input being monitored is either between or outside the range formed by CV1 and CV2 determined by the value of ACFGT. ACFE must be set for ACFGT to have any effect. | | | 0 Range function disabled. Only CV1 is compared. | | | 1 Range function enabled. Both CV1 and CV2 are compared. | | 2<br>DMAEN | DMA Enable | | DMAEN | 0 DMA is disabled. | | | 1 DMA is enabled and will assert the ADC DMA request during an ADC conversion complete event noted when any of the SC1n[COCO] flags is asserted. | | 1-0 | Voltage Reference Selection | | REFSEL | Selects the voltage reference source used for conversions. | | | 00 Default voltage reference pin pair, that is, external pins $V_{REFH}$ and $V_{REFL}$ | Table continues on the next page... ## ADC\_SC2 field descriptions (continued) | Field | Description | |-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | O1 Alternate reference pair, that is, V <sub>ALTH</sub> and V <sub>ALTL</sub> . This pair may be additional external pins or internal sources depending on the MCU configuration. See the chip configuration information for details specific to this MCU | | | <ul> <li>Internal bandgap reference and associated ground reference (V <sub>BGH</sub> and V <sub>BGL</sub>). Consult the Chip Configuration information for details specific to this MCU.</li> <li>Reserved</li> </ul> | ## 26.3.7 Status and Control Register 3 (ADC\_SC3) The Status and Control Register 3 (SC3) controls the calibration, continuous convert, and hardware averaging functions of the ADC module. ## ADC\_SC3 field descriptions | Field | Description | |----------|--------------------------------------------------------------| | | This field is reserved. | | Reserved | This read-only field is reserved and always has the value 0. | Table continues on the next page... ## ADC\_SC3 field descriptions (continued) | Field | Description | |----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | Calibration | | CAL | Begins the calibration sequence when set. This field stays set while the calibration is in progress and is cleared when the calibration sequence is completed. CALF 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 CALF will set. Setting CAL will abort any current conversion. | | 6 | Calibration Failed Flag | | CALF | Displays the result of the calibration sequence. The calibration sequence will fail if SC2[ADTRG] = 1, any ADC register is written, or any stop mode is entered before the calibration sequence completes. Writing 1 to CALF clears it. | | | 0 Calibration completed normally. | | | 1 Calibration failed. ADC accuracy specifications are not guaranteed. | | 5–4 | This field is reserved. | | Reserved | This read-only field is reserved and always has the value 0. | | 3 | Continuous Conversion Enable | | ADCO | Enables continuous conversions. | | | One conversion or one set of conversions if the hardware average function is enabled, that is, AVGE=1, after initiating a conversion. | | | 1 Continuous conversions or sets of conversions if the hardware average function is enabled, that is, AVGE=1, after initiating a conversion. | | 2 | Hardware Average Enable | | AVGE | Enables the hardware average function of the ADC. | | | 0 Hardware average function disabled. | | | 1 Hardware average function enabled. | | 1–0 | 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. | 452 **Preliminary** Freescale Semiconductor, Inc. ## 26.3.8 ADC Offset Correction Register (ADC\_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 OFS is subtracted from the conversion and the result is transferred into the result registers, Rn. If the result is greater than the maximum or less than the minimum result value, it is forced to the appropriate limit for the current mode of operation. Address: 4002\_B000h base + 38h offset = 4002\_B038h #### ADC\_OFS field descriptions | Field | Description | |-------------------|--------------------------------------------------------------------------------------| | 31–16<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 15–0<br>OFS | Offset Error Correction Value | ## 26.3.9 ADC Plus-Side Gain Register (ADC\_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. Otherwise, the gain error specifications may not be met. Address: 4002\_B000h base + 3Ch offset = 4002\_B03Ch #### **ADC\_PG** field descriptions | Field | Description | |-------------------|--------------------------------------------------------------------------------------| | 31–16<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 15–0<br>PG | Plus-Side Gain | ## 26.3.10 ADC Plus-Side General Calibration Value Register (ADC\_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 when the self-calibration sequence is done, that is, CAL is cleared. If these registers are written by the user after calibration, the linearity error specifications may not be met. Address: 4002\_B000h base + 44h offset = 4002\_B044h #### ADC\_CLPD field descriptions | Field | Description | |------------------|--------------------------------------------------------------------------------------| | 31–6<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 5–0<br>CLPD | Calibration Value | ## 26.3.11 ADC Plus-Side General Calibration Value Register (ADC\_CLPS) For more information, see CLPD register description. Address: 4002\_B000h base + 48h offset = 4002\_B048h #### **ADC\_CLPS** field descriptions | Field | Description | |------------------|--------------------------------------------------------------------------------------| | 31–6<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 5–0<br>CLPS | Calibration Value | ## 26.3.12 ADC Plus-Side General Calibration Value Register (ADC\_CLP4) For more information, see CLPD register description. Address: 4002\_B000h base + 4Ch offset = 4002\_B04Ch ### **ADC\_CLP4** field descriptions | Field | Description | |-------------------|--------------------------------------------------------------------------------------| | 31–10<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 9–0<br>CLP4 | Calibration Value | ## 26.3.13 ADC Plus-Side General Calibration Value Register (ADC\_CLP3) For more information, see CLPD register description. Address: 4002\_B000h base + 50h offset = 4002\_B050h #### ADC\_CLP3 field descriptions | Field | Description | |------------------|--------------------------------------------------------------------------------------| | 31–9<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 8–0<br>CLP3 | Calibration Value | ## 26.3.14 ADC Plus-Side General Calibration Value Register (ADC CLP2) For more information, see CLPD register description. Address: 4002\_B000h base + 54h offset = 4002\_B054h #### ADC\_CLP2 field descriptions | Field | Description | |-------------|--------------------------------------------------------------------------------------| | | This field is reserved. This read-only field is reserved and always has the value 0. | | 7–0<br>CLP2 | Calibration Value | ## 26.3.15 ADC Plus-Side General Calibration Value Register (ADC\_CLP1) For more information, see CLPD register description. Address: 4002\_B000h base + 58h offset = 4002\_B058h #### ADC\_CLP1 field descriptions | Field | Description | |-------------|--------------------------------------------------------------------------------------| | - | This field is reserved. This read-only field is reserved and always has the value 0. | | 6–0<br>CLP1 | Calibration Value | 457 ## 26.3.16 ADC Plus-Side General Calibration Value Register (ADC\_CLP0) For more information, see CLPD register description. Address: 4002\_B000h base + 5Ch offset = 4002\_B05Ch #### ADC\_CLP0 field descriptions | Field | Description | |------------------|--------------------------------------------------------------------------------------| | 31–6<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 5–0<br>CLP0 | Calibration Value | ## 26.4 Functional description The ADC module is disabled during reset, in Low-Power Stop mode, or when SC1n[ADCH] are all high; see the power management information for details. 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, or CFG2[ADACKEN]= 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 Rn data registers. The respective SC1n[COCO] is then set and an interrupt is generated if the respective conversion complete interrupt has been enabled, or, when SC1n[AIEN]=1. The ADC module has the capability of automatically comparing the result of a conversion with the contents of the CV1 and CV2 registers. The compare function is enabled by setting SC2[ACFE] and operates in any of the conversion modes and configurations. #### runctional description The ADC module has the capability of automatically averaging the result of multiple conversions. The hardware average function is enabled by setting SC3[AVGE] and operates in any of the conversion modes and configurations. #### NOTE For the chip specific modes of operation, see the power management information of this MCU. #### 26.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 ADCK, to the module. The clock is selected from one of the following sources by means of CFG1[ADICLK]. - Bus clock. This is the default selection following reset. - Bus clock divided by two. For higher bus clock rates, this allows a maximum divideby-16 of the bus clock using CFG1[ADIV]. - ALTCLK: As defined for this MCU. See the chip configuration information. - Asynchronous clock (ADACK): This clock is generated from a clock source within the ADC module. 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 CFG2[ADACKEN]=0, ADACK is activated at the start of a conversion and deactivated 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 CFG2[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. See 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 CFG1[ADIV] and can be divide-by 1, 2, 4, or 8. ## 26.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 SC2[REFSEL]. The alternate ( $V_{ALTH}$ and $V_{ALTL}$ ) voltage reference pair may select additional external pins or internal sources depending on MCU configuration. See the chip configuration information on the voltage references specific to this MCU. ## 26.4.3 Hardware trigger and channel selects The ADC module has a selectable asynchronous hardware conversion trigger, ADHWT, that is enabled when SC2[ADTRG] is set and a hardware trigger select event, ADHWTSn, has occurred. This source is not available on all MCUs. See the Chip Configuration chapter for information on the ADHWT source and the ADHWTSn configurations specific to this MCU. When an ADHWT source is available and hardware trigger is enabled, that is SC2[ADTRG]=1, a conversion is initiated on the rising-edge of ADHWT after a hardware trigger select event, that is, 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 is aborted, the ADC continues to do conversions on the same SCn 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 is 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 Rn registers associated with the ADHWTSn received. For example: - ADHWTSA active selects RA register - ADHWTSn active selects Rn register The conversion complete flag associated with the ADHWTSn received, that is, SC1n[COCO], is then set and an interrupt is generated if the respective conversion complete interrupt has been enabled, that is, SC1[AIEN]=1. ## 26.4.4 Conversion control Conversions can be performed as determined by CFG1[MODE] 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 - Automatic compare of the conversion result to a software determined compare value ## 26.4.4.1 Initiating conversions A conversion is initiated: - Following a write to SC1A, with SC1n[ADCH] not all 1's, if software triggered operation is selected, that is, when SC2[ADTRG]=0. - Following a hardware trigger, or ADHWT event, if hardware triggered operation is selected, that is, SC2[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. - ADHWTSn active selects SC1n. - if neither is active, the off condition is selected #### **Note** Selecting more than one ADHWTSn prior to a conversion completion will result in unknown results. To avoid this, select only one ADHWTSn prior to a conversion completion. • Following the transfer of the result to the data registers when continuous conversion is enabled, that is, when SC3[ADCO] = 1. If continuous conversions are enabled, a new conversion is automatically initiated after the completion of the current conversion. In software triggered operation, that is, when SC2[ADTRG] = 0, continuous conversions begin after SC1A is written and continue until aborted. In hardware triggered operation, that is, when SC2[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 are completed. In software triggered operation, conversions begin after SC1A is 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. ## 26.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 setting of SC1n[COCO]. If hardware averaging is enabled, the respective SC1n[COCO] sets only if the last of the selected number of conversions is completed. If the compare function is enabled, the respective SC1n[COCO] 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 SC1n[COCO] 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 SC1n[AIEN] is high at the time that the respective SC1n[COCO] is set. runctional description ## 26.4.4.3 Aborting conversions Any conversion in progress is aborted when: - Writing to SC1A while it is actively controlling a conversion, aborts the current conversion. In Software Trigger mode, when SC2[ADTRG]=0, a write to SC1A initiates a new conversion if SC1A[ADCH] is equal to a value other than all 1s. Writing to any of the SC1B–SC1n registers while that specific SC1B–SC1n 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 that a change in mode of operation 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 Rn return to their reset states. ### 26.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, that is CFG2[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, that is, CFG2[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 CFG1[ADLPC]. This results in a lower maximum value for $f_{ADCK}$ . 463 ## 26.4.4.5 Sample time and total conversion time For short sample, that is, when CFG1[ADLSMP]=0, there is a 2-cycle adder for first conversion over the base sample time of four ADCK cycles. For high-speed conversions, that is, when CFG2[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 ( | ADCK cycles) | |-------------------|--------------|-------------|----------------------------|--------------| | CFG1[ADLSMP] | CFG2[ADLSTS] | CFG2[ADHSC] | First or Single Subsequent | | | 0 | Х | 0 | 6 | 4 | | 1 | 00 | 0 | 2 | 4 | | 1 | 01 | 0 | 16 | | | 1 | 10 | 0 | 10 | | | 1 | 11 | 0 | 6 | | | 0 | X | 1 | 8 6 | | | 1 | 00 | 1 | 26 | | | 1 | 01 | 1 | 18 | | | 1 | 10 | 1 | 12 | | | 1 | 11 | 1 | 8 | | The total conversion time depends upon: - The sample time as determined by CFG1[ADLSMP] and CFG2[ADLSTS] - The MCU bus frequency - The conversion mode, as determined by CFG1[MODE] - The high-speed configuration, that is, CFG2[ADHSC] - The frequency of the conversion clock, that is, f<sub>ADCK</sub>. CFG2[ADHSC] is used to configure a higher clock input frequency. This will allow faster overall conversion times. To meet internal ADC timing requirements, CFG2[ADHSC] adds additional ADCK cycles. Conversions with CFG2[ADHSC]=1 take two more ADCK cycles. CFG2[ADHSC] must be used when the ADCLK exceeds the limit for CFG2[ADHSC]=0. After the module becomes active, sampling of the input begins. - 1. CFG1[ADLSMP] and CFG2[ADLSTS] select between sample times based on the conversion mode that is selected. - 2. When sampling is completed, the converter is isolated from the input channel and a successive approximation algorithm is applied to determine the digital value of the analog signal. - 3. The result of the conversion is transferred to Rn upon completion of the conversion algorithm. #### runctional description If the bus frequency is less than $f_{ADCK}$ , precise sample time for continuous conversions cannot be guaranteed when short sample is enabled, that is, when CFG1[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 CFG1[ADICLK], and the divide ratio is specified by CFG1[ADIV]. The maximum total conversion time for all configurations is summarized in the equation below. See the following tables for the variables referenced in the equation. $Conversion Time = SFCAdder + Average Num \times \big(BCT + LSTAdder + HSCAdder\big)$ ## Figure 26-28. Conversion time equation Table 26-34. Single or first continuous time adder (SFCAdder) | CFG1[AD<br>LSMP] | CFG2[AD<br>ACKEN] | CFG1[ADICLK] | Single or first continuous time adder (SFCAdder) | | |------------------|-------------------|--------------|--------------------------------------------------|--| | 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 cycles | | | 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 | | 1. To achieve this time, CFG2[ADACKEN] must be 1 for at least 5 µs prior to the conversion is initiated. Table 26-35. Average number factor (AverageNum) | SC3[AVGE] | SC3[AVGS] | Average number factor (AverageNum) | |-----------|-----------|------------------------------------| | 0 | XX | 1 | | 1 | 00 | 4 | | 1 | 01 | 8 | | 1 | 10 | 16 | | 1 | 11 | 32 | ### Table 26-36. Base conversion time (BCT) | Mode | Base conversion time (BCT) | | |------------------|----------------------------|--| | 8b single-ended | 17 ADCK cycles | | | 10b single-ended | 20 ADCK cycles | | | 12b single-ended | 20 ADCK cycles | | | 16b single-ended | 25 ADCK cycles | | #### Table 26-37. Long sample time adder (LSTAdder) | CFG1[ADLSMP] | CFG2[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 26-38. High-speed conversion time adder (HSCAdder) | CFG2[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. ## 26.4.4.6 Conversion time examples The following examples use the Figure 26-28, and the information provided in Table 26-34 through Table 26-38. ## 26.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 - Bus frequency of 8 MHz - Long sample time disabled - High-speed conversion disabled The conversion time for a single conversion is calculated by using the Figure 26-28, and the information provided in Table 26-34 through Table 26-38. The table below lists the variables of Figure 26-28. Table 26-39. Typical conversion time | Variable | Time | | |----------|------------------------------------|--| | SFCAdder | 5 ADCK cycles + 5 bus clock cycles | | Table continues on the next page... #### Table 26-39. Typical conversion time (continued) | Variable | Time | | |------------|----------------|--| | AverageNum | 1 | | | ВСТ | 20 ADCK cycles | | | LSTAdder | 0 | | | HSCAdder | 0 | | The resulting conversion time is generated using the parameters listed in the preceding table. Therefore, for a bus clock and an ADCK frequency equal to 8 MHz, the resulting conversion time is 3.75 µs. ## 26.4.4.6.2 Long conversion time configuration A configuration for long ADC conversion is: - The input clock divide-by-8 ratio selected - Bus frequency of 8 MHz - Long sample time enabled - Configured for longest adder - High-speed conversion disabled - Average enabled for 32 conversions The conversion time for this conversion is calculated by using the Figure 26-28, and the information provided in Table 26-34 through Table 26-38. The following table lists the variables of the Figure 26-28. Table 26-40. Typical conversion time | Variable | Time | | |------------|------------------------------------|--| | SFCAdder | 3 ADCK cycles + 5 bus clock cycles | | | AverageNum | 32 | | | ВСТ | 34 ADCK cycles | | | LSTAdder | 20 ADCK cycles | | | HSCAdder | 0 | | The resulting conversion time is generated using the parameters listed in the preceding table. Therefore, for bus clock equal to 8 MHz and ADCK equal to 1 MHz, the resulting conversion time is $57.625 \, \mu s$ , that is, AverageNum. This results in a total conversion time of $1.844 \, ms$ . ## 26.4.4.6.3 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 467 - The input clock divide-by-1 ratio selected - Bus frequency of 20 MHz - Long sample time disabled - High-speed conversion enabled The conversion time for this conversion is calculated by using the Figure 26-28, and the information provided in Table 26-34 through Table 26-38. The table below lists the variables of Figure 26-28. | Variable | Time | | |------------|------------------------------------|--| | SFCAdder | 5 ADCK cycles + 5 bus clock cycles | | | AverageNum | 1 | | | BCT | 17 ADCK cycles | | | LSTAdder | 0 ADCK cycles | | | HSCAdder | 2 | | Table 26-41. Typical conversion time The resulting conversion time is generated using the parameters listed in in the preceding table. Therefore, for bus clock and ADCK frequency equal to 20 MHz, the resulting conversion time is $1.45 \, \mu s$ . ## 26.4.4.7 Hardware average function The hardware average function can be enabled by setting SC3[AVGE]=1 to perform a hardware average of multiple conversions. The number of conversions is determined by the AVGS[1:0] bits, which can select 4, 8, 16, or 32 conversions to be averaged. While the hardware average function is in progress, SC2[ADACT] 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 have been completed. When hardware averaging is selected, the completion of a single conversion will not set SC1n[COCO]. 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 SC1n[COCO] is set. An ADC interrupt is generated upon the setting of SC1n[COCO] if the respective ADC interrupt is enabled, that is, SC1n[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] is set. ## 26.4.5 Automatic compare function The compare function can be configured to check whether 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 SC2[ACFGT], SC2[ACREN], and the values in the compare value registers, CV1 and CV2. After the input is sampled and converted, the compare values in CV1 and CV2 are used as described in the following table. There are six Compare modes as shown in the following table. | SC2[AC<br>FGT] | SC2[AC<br>REN] | ADCCV1<br>relative to<br>ADCCV2 | Function | Compare mode description | |----------------|----------------|---------------------------------|------------------------------------|----------------------------------------------------------------------------------------------------------------| | 0 | 0 | _ | Less than threshold | Compare true if the result is less than the CV1 registers. | | 1 | 0 | | Greater than or equal to threshold | Compare true if the result is greater than or equal to CV1 registers. | | 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. | Table 26-42. Compare modes With SC2[ACREN] =1, and if the value of CV1 is less than or equal to the value of CV2, then setting SC2[ACFGT] will select a trigger-if-inside-compare-range inclusive-of-endpoints function. Clearing SC2[ACFGT] will select a trigger-if-outside-compare-range, not-inclusive-of-endpoints function. If CV1 is greater than CV2, setting SC2[ACFGT] will select a trigger-if-outside-compare-range, inclusive-of-endpoints function. Clearing SC2[ACFGT] will select a trigger-if-inside-compare-range, not-inclusive-of-endpoints function. If the condition selected evaluates true, SC1n[COCO] is set. Upon completion of a conversion while the compare function is enabled, if the compare condition is not true, SC1n[COCO] is not set and the conversion result data will not be transferred to the result register, Rn. 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 when SC1n[COCO] is set and the respective ADC interrupt is enabled, that is, SC1n[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. ### 26.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 registers, CLPx. 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: - Set hardware averaging to maximum, that is, SC3[AVGE]=1 and SC3[AVGS]=11 for an average of 32 - ullet Set ADC clock frequency $f_{ADCK}$ less than or equal to 4 MHz - $V_{REFH} = V_{DDA}$ - 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. #### runctional description To initiate calibration, the user sets SC3[CAL] and the calibration will automatically begin if the SC2[ADTRG] is 0. If SC2[ADTRG] is 1, SC3[CAL] will not get set and SC3[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 SC3[CAL] to clear and SC3[CALF] to set. At the end of a calibration sequence, SC1n[COCO] will be set. SC1n[AIEN] can be used to allow an interrupt to occur at the end of a calibration sequence. At the end of the calibration routine, if SC3[CALF] is not set, the automatic calibration routine is completed successfully. To complete calibration, the user must generate the gain calibration values using the following procedure: - 1. Initialize or clear a 16-bit variable in RAM. - 2. Add the plus-side calibration results CLP0, CLP1, CLP2, CLP3, CLP4, and CLPS to the variable. - 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 SC3[CAL]. 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, which are 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 can reduce the calibration latency to 20 register store operations on all subsequent power, reset, or Low-Power Stop mode recoveries. Further information on the calibration procedure can be found in the Calibration section of AN3949: ADC16 Calibration Procedure and Programmable Delay Block Synchronization. # 26.4.7 User-defined offset function OFS contains the user-selected or calibration-generated offset error correction value. This register is a 2's complement, left-justified. The value in OFS is subtracted from the conversion and the result is transferred into the result registers, Rn. If the result is greater than the maximum or less than the minimum result value, it is forced to the appropriate limit for the current mode of operation. The formatting of the OFS 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, OFS[14:7] are subtracted from D[7:0]; OFS[15] indicates the sign (negative numbers are effectively added to the result) and OFS[6:0] are ignored. In 16-bit single-ended mode, there is no field in the OFS corresponding to the least significant result D[0], so odd values, such as -1 or +1, cannot be subtracted from the result. OFS is automatically set according to calibration requirements once the self-calibration sequence is done, that is, SC3[CAL] is cleared. The user may write to OFS to override the calibration result if desired. If the OFS is written by the user to a value that is different from the calibration value, the ADC error specifications may not be met. Storing the value generated by the calibration function in memory before overwriting with a user-specified value is recommended. #### **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 high, 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. 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 OFS must be added to the user-defined offset. For applications that may change the offset repeatedly during operation, 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 OFS. # 26.4.8 Temperature sensor The ADC module includes a temperature sensor whose output is connected to one of the ADC analog channel inputs. #### **runctional** description The following equation provides an approximate transfer function of the temperature sensor. Temp = $$25 - ((V_{TEMP} - V_{TEMP25}) \div m)$$ Figure 26-29. Approximate transfer function of the temperature sensor #### where: - $V_{TEMP}$ is the voltage of the temperature sensor channel at the ambient temperature. - V<sub>TEMP25</sub> is the voltage of the temperature sensor channel at 25 °C. - m is referred as temperature sensor slope in the device data sheet. It is the hot or cold voltage versus temperature slope in V/°C. For temperature calculations, use the $V_{TEMP25}$ and temperature sensor slope values from the ADC Electricals table. 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. ADC Electricals table may only specify one temperature sensor slope value. In that case, the user could use the same slope for the calculation across the operational temperature range. For more information on using the temperature sensor, see the application note titled *Temperature Sensor for the HCS08 Microcontroller Family* (document AN3031). # 26.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. See the Chip Configuration information on ALTCLK specific to this MCU. If the compare and hardware averaging functions are disabled, a conversion complete event sets SC1n[COCO] and generates an ADC interrupt to wake the MCU from Wait mode if the respective ADC interrupt is enabled, that is, when SC1n[AIEN]=1. If the hardware averaging function is enabled, SC1n[COCO] will set, and generate an interrupt if enabled, when the selected number of conversions are completed. If the compare function is enabled, SC1n[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. # 26.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. # 26.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. # 26.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. See 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 SC1n[COCO] and generates an ADC interrupt to wake the MCU from Normal Stop mode if the respective ADC interrupt is enabled, that is, when SC1n[AIEN]=1. The result register, Rn, will contain the data from the first completed conversion that occurred during Normal Stop mode. If the hardware averaging function is enabled, SC1n[COCO] will set, and generate an interrupt if enabled, when the selected number of conversions are completed. If the compare function is enabled, SC1n[COCO] will set, and generate an #### unualization information 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. # 26.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, see the power management information for the device. ### 26.5 Initialization information This section gives an example that provides some basic direction on how to initialize and configure the ADC module. The user can configure the module for 16-bit, 12-bit, 10-bit, or 8-bit single-ended resolution, single or continuous conversion, and a polled or interrupt approach, among many other options. For information used in this example, refer to Table 26-37, Table 26-38, and Table 26-39. #### **Note** Hexadecimal values are designated by a preceding 0x, binary values designated by a preceding %, and decimal values have no preceding character. # 26.5.1 ADC module initialization example # 26.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: - 1. Calibrate the ADC by following the calibration instructions in Calibration function. - 2. Update CFG to select the input clock source and the divide ratio used to generate ADCK. This register is also used for selecting sample time and low-power configuration. - 3. Update SC2 to select the conversion trigger, hardware or software, and compare function options, if enabled. - 4. Update SC3 to select whether conversions will be continuous or completed only once (ADCO) and whether to perform hardware averaging. - 5. Update SC1:SC1n registers to enable or disable conversion complete interrupts. Also, select the input channel which can be used to perform conversions. # 26.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 ADCK is derived from the bus clock divided by 1. # CFG1 = 0x98 (%10011000) ``` Bit 7 ADLPC 1 Configures for low power, lowers maximum clock speed. Bit 6:5 ADIV 00 Sets the ADCK to the input clock ÷ 1. Bit 4 ADLSMP 1 Configures for long sample time. Bit 3:2 MODE 10 Selects the single-ended 10-bit conversion. Bit 1:0 ADICLK 00 Selects the bus clock. ``` ### SC2 = 0x00 (%00000000) ``` Bit 7 ADACT Flag indicates if a conversion is in progress. Bit 6 ADTRG 0 Software trigger selected. Bit 5 ACFE Compare function disabled. Bit 4 ACFGT 0 Not used in this example. Bit 3 ACREN 0 Compare range disabled. Bit 2 DMAEN 0 DMA request disabled. Selects default voltage reference pin pair (External pins V_{\text{REFH}} Bit 1:0 REFSEL 00 and \textbf{V}_{\text{REFL}}) . ``` # 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 4:0 ADCH 00001 Input channel 1 selected as ADC input channel. ``` #### RA = 0xxx #### **Application information** Holds results of conversion. #### CV = 0xxx Holds compare value when compare function enabled. Figure 26-30. Initialization flowchart example # 26.6 Application information The ADC has been designed to be integrated into a microcontroller for use in embedded control applications requiring an ADC. For guidance on selecting optimum external component values and converter parameters see AN4373: Cookbook for SAR ADC Measurements. # 26.6.1 External pins and routing 477 # 26.6.1.1 Analog supply pins Depending on the device, the analog power and ground supplies, $V_{DDA}$ and $V_{SSA}$ , of the ADC module are available as: - V<sub>DDA</sub> and V<sub>SSA</sub> available as separate pins—When available on a separate pin, both V<sub>DDA</sub> and V<sub>SSA</sub> must be connected to the same voltage potential as their corresponding MCU digital supply, V<sub>DD</sub> and V<sub>SS</sub>, and must be routed carefully for maximum noise immunity and bypass capacitors placed as near as possible to the package. - $V_{SSA}$ is shared on the same pin as the MCU digital $V_{SS}$ . - $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. 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 must be the only ground connection between these supplies, if possible. $V_{SSA}$ makes a good single point ground location. # 26.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<sub>REFSH</sub> is the high reference voltage for the converter. - V<sub>REESL</sub> 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 SC2[REFSEL]. The alternate voltage reference pair, $V_{ALTH}$ and $V_{ALTL}$ , may select additional external pins or internal sources based on MCU configuration. See 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. #### **Application information** 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-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, that is, parasitic only. # 26.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, which is full scale 12-bit representation, 0x3FF, which is full scale 10-bit representation, or 0xFF, which is 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 must not be transitioning during conversions. ### 26.6.2 Sources of error # 26.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 26-31. 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 or 16 in 16-bit mode Higher source resistances or higher-accuracy sampling is possible by setting CFG1[ADLSMP] and changing CFG2[ADLSTS] to increase the sample window, or decreasing ADCK frequency to increase sample time. # 26.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 × $I_{LEAK}$ × $2^N$ ) for less than 1/4 LSB leakage error, where N=8 in 8-bit mode, 10 in 10-bit mode, 12 in 12-bit mode, or 16 in 16-bit mode. ### 26.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 SC1 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 mode, or I/O activity cannot be halted, the following 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, that is, ADACK, and averaging. Noise that is synchronous to ADCK cannot be averaged out. # 26.6.2.4 Code width and quantization error The ADC quantizes the ideal straight-line transfer function into 65536 steps in the 16-bit mode). Each step ideally has the same height, that is, 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, where N can be 16, 12, 10, or 8, defined as 1 LSB, is: $$1LSB = (V_{REFH})/2^N$$ # Figure 26-32. 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. 481 For 16-bit conversions, the code transitions only after the full code width is present, so the quantization error is -1 LSB to 0 LSB and the code width of each step is 1 LSB. # 26.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 must be aware of these errors because they affect overall accuracy: - 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. This is 1/2 LSB in 8-bit, 10-bit, or 12-bit modes and 1 LSB in 16-bit mode. 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. This is 1.5 LSB in 8-bit, 10-bit, or 12-bit modes and 1 LSB in 16-bit mode. 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 or absolute value that 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. # 26.6.2.6 Code jitter, non-monotonicity, and missing codes Analog-to-digital converters are susceptible to three special forms of error: • Code jitter: Code jitter is when, at certain points, a given input voltage converts to one of the 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: Non-monotonicity is defined as when, except for code jitter, the converter converts to a lower code for a higher input voltage. - Missing codes: 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 27 Comparator (CMP)** ### 27.1 Introduction #### **NOTE** For the chip-specific implementation details of this module's instances, see the chip configuration information. The comparator (CMP) module provides a circuit for comparing two analog input voltages. The comparator circuit is designed to operate across the full range of the supply voltage, known as rail-to-rail operation. The Analog MUX (ANMUX) provides a circuit for selecting an analog input signal from eight channels. One signal is provided by the 6-bit digital-to-analog converter (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 $V_{in}$ into 64 voltage levels. A 6-bit digital signal input selects the output voltage level, which varies from $V_{in}$ to $V_{in}/64$ . $V_{in}$ 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. # 27.1.1 CMP features The CMP has the following features: - Operational over the entire supply range - Inputs may range from rail to rail - Programmable hysteresis control #### muroduction - Selectable interrupt on rising-edge, falling-edge, or both rising or falling edges of the comparator output - Selectable inversion on comparator output - Capability to produce a wide range of outputs such as: - Sampled - Windowed, which is 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 - DMA transfer support - 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 the following modes: - Stop - VLPS - LLS - VLLSx # 27.1.2 6-bit DAC key features - 6-bit resolution - Selectable supply reference source - Power Down mode to conserve power when not in use - Option to route the output to internal comparator input # 27.1.3 ANMUX key features - Two 8-to-1 channel mux - Operational over the entire supply range # 27.1.4 CMP, DAC and ANMUX diagram The following figure shows the block diagram for the High-Speed Comparator, DAC, and ANMUX modules. #### muroduction Figure 27-1. CMP, DAC and ANMUX block diagram # 27.1.5 CMP block diagram The following figure shows the block diagram for the CMP module. Figure 27-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 #### wemory map/register definitions - If enabled, the Filter block will incur up to one 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. # 27.2 Memory map/register definitions ### **CMP** memory map | Absolute address (hex) | Register name | Width<br>(in bits) | Access | Reset value | Section/<br>page | |------------------------|--------------------------------------------|--------------------|--------|-------------|------------------| | 4007_2000 | CMP Control Register 0 (CMP0_CR0) | 8 | R/W | 00h | 27.2.1/488 | | 4007_2001 | CMP Control Register 1 (CMP0_CR1) | 8 | R/W | 00h | 27.2.2/489 | | 4007_2002 | CMP Filter Period Register (CMP0_FPR) | 8 | R/W | 00h | 27.2.3/491 | | 4007_2003 | CMP Status and Control Register (CMP0_SCR) | 8 | R/W | 00h | 27.2.4/491 | | 4007_2004 | DAC Control Register (CMP0_DACCR) | 8 | R/W | 00h | 27.2.5/492 | | 4007_2005 | MUX Control Register (CMP0_MUXCR) | 8 | R/W | 00h | 27.2.6/493 | | 4007_2008 | CMP Control Register 0 (CMP1_CR0) | 8 | R/W | 00h | 27.2.1/488 | | 4007_2009 | CMP Control Register 1 (CMP1_CR1) | 8 | R/W | 00h | 27.2.2/489 | | 4007_200A | CMP Filter Period Register (CMP1_FPR) | 8 | R/W | 00h | 27.2.3/491 | | 4007_200B | CMP Status and Control Register (CMP1_SCR) | 8 | R/W | 00h | 27.2.4/491 | | 4007_200C | DAC Control Register (CMP1_DACCR) | 8 | R/W | 00h | 27.2.5/492 | | 4007_200D | MUX Control Register (CMP1_MUXCR) | 8 | R/W | 00h | 27.2.6/493 | # 27.2.1 CMP Control Register 0 (CMPx\_CR0) Address: Base address + 0h offset ### CMPx\_CR0 field descriptions | Field | Description | |------------|--------------------------------------------------------------| | 7 | This field is reserved. | | Reserved | This read-only field is reserved and always has the value 0. | | 6–4 | Filter Sample Count | | FILTER_CNT | | Table continues on the next page... # CMPx\_CR0 field descriptions (continued) | Field | Description | |----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | Represents 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, see the Functional description. | | | 000 Filter is disabled. If SE = 1, then COUT is a logic 0. This is not a legal state, and is not recommended. If SE = 0, COUT = COUTA. | | | One sample must agree. The 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. | | | 110 6 consecutive samples must agree. | | | 111 7 consecutive samples must agree. | | 3<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 2<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 1–0<br>HYSTCTR | Comparator hard block hysteresis control | | | Defines the programmable hysteresis level. The hysteresis values associated with each level are device-specific. See the Data Sheet of the device for the exact values. | | | 00 Level 0 | | | 01 Level 1 | | | 10 Level 2 | | | 11 Level 3 | # 27.2.2 CMP Control Register 1 (CMPx\_CR1) Address: Base address + 1h offset | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|----|----|-------|-------|-----|-----|-----|----| | Read<br>Write | SE | WE | TRIGM | PMODE | INV | cos | OPE | EN | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ### CMPx\_CR1 field descriptions | Field | Description | |-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | Sample Enable | | SE | At any given time, either SE or WE can be set. | | | 0 Sampling mode is not selected. | | | 1 Sampling mode is selected. | | 6 | Windowing Enable | | WE | At the state of th | | | At any given time, either SE or WE can be set. | Table continues on the next page... #### wemory map/register definitions # CMPx\_CR1 field descriptions (continued) | Field | Description | |----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | 0 Windowing mode is not selected. | | | 1 Windowing mode is selected. | | 5 | Trigger Mode Enable | | TRIGM | CMP and DAC are configured to CMP Trigger mode when CMP_CR1[TRIGM] is set to 1. In addition, the CMP should be enabled. If the DAC is to be used as a reference to the CMP, it should also be enabled. | | | CMP Trigger mode depends on an external timer resource to periodically enable the CMP and 6-bit DAC in order to generate a triggered compare. | | | Upon setting TRIGM, the CMP and DAC are placed in a standby state until an external timer resource trigger is received. | | | See the chip configuration chapter for details about the external timer resource. | | | 0 Trigger mode is disabled. | | | 1 Trigger mode is enabled. | | 4 | Power Mode Select | | PMODE | See the electrical specifications table in the device Data Sheet for details. | | | 0 Low-Speed (LS) Comparison mode selected. In this mode, CMP has slower output propagation delay | | | and lower current consumption. | | | 1 High-Speed (HS) Comparison mode selected. In this mode, CMP has faster output propagation delay and higher current consumption. | | 3 | Comparator INVERT | | INV | Allows selection of 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 OPE=0. | | | 0 Does not invert the comparator output. | | | 1 Inverts the comparator output. | | 2<br>COS | Comparator Output Select | | | 0 Set the filtered comparator output (CMPO) to equal COUT. | | | 1 Set the unfiltered comparator output (CMPO) to equal COUTA. | | 1<br>OPE | Comparator Output Pin Enable | | | 0 CMPO is not available on the associated CMPO output pin. | | | 1 CMPO is available on the associated CMPO output pin. | | 0 | Comparator Module Enable | | EN | Enables the Analog Comparator module. When the module is not enabled, it remains in the off state, and consumes no power. When the user selects the same input from analog mux to the positive and negative port, the comparator is disabled automatically. | | | 0 Analog Comparator is disabled. | | | | # 27.2.3 CMP Filter Period Register (CMPx\_FPR) Address: Base address + 2h offset ### CMPx\_FPR field descriptions | Field | Description | |----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | FILT_PER | Filter Sample Period Specifies the sampling period, in bus clock cycles, of the comparator output filter, when CR1[SE]=0. 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]=1. In that case, the external SAMPLE signal is used to determine the sampling period. | # 27.2.4 CMP Status and Control Register (CMPx\_SCR) Address: Base address + 3h offset ### CMPx\_SCR field descriptions | Field | Description | |------------|-----------------------------------------------------------------------------------------------------------------------------------| | 7 | This field is reserved. | | Reserved | This read-only field is reserved and always has the value 0. | | 6<br>DMAEN | DMA Enable Control | | | Enables the DMA transfer triggered from the CMP module. When this field is set, a DMA request is asserted when CFR or CFF is set. | | | 0 DMA is disabled. | | | 1 DMA is enabled. | | 5 | This field is reserved. | | Reserved | This read-only field is reserved and always has the value 0. | | 4<br>IER | Comparator Interrupt Enable Rising | | 1211 | Enables the CFR interrupt from the CMP. When this field is set, an interrupt will be asserted when CFR is set. | Table continues on the next page... #### wemory map/register definitions # CMPx\_SCR field descriptions (continued) | Field | Description | |-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | 0 Interrupt is disabled. | | | 1 Interrupt is enabled. | | 3<br>IEF | Comparator Interrupt Enable Falling | | | Enables the CFF interrupt from the CMP. When this field is set, an interrupt will be asserted when CFF is set. | | | 0 Interrupt is disabled. | | | 1 Interrupt is enabled. | | 2<br>CFR | Analog Comparator Flag Rising | | Orn | Detects a rising-edge on COUT, when set, during normal operation. CFR is cleared by writing 1 to it. During Stop modes, CFR is level sensitive . | | | 0 Rising-edge on COUT has not been detected. | | | 1 Rising-edge on COUT has occurred. | | 1 | Analog Comparator Flag Falling | | CFF | Detects a falling-edge on COUT, when set, during normal operation. CFF is cleared by writing 1 to it. During Stop modes, CFF is level sensitive . | | | 0 Falling-edge on COUT has not been detected. | | | 1 Falling-edge on COUT has occurred. | | 0<br>COUT | Analog Comparator Output | | | Returns the current value of the Analog Comparator output, when read. The field is reset to 0 and will read as CR1[INV] when the Analog Comparator module is disabled, that is, when CR1[EN] = 0. Writes to this field are ignored. | # 27.2.5 DAC Control Register (CMPx\_DACCR) Address: Base address + 4h offset ### CMPx\_DACCR field descriptions | Field | Description | |------------|-------------------------------------------------------------------------------------------------------------------------------------| | 7<br>DACEN | DAC Enable Enables 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 | Table continues on the next page... # CMPx\_DACCR field descriptions (continued) | Field | Description | |--------------|-----------------------------------------------------------------------------------------------------| | | 0 V is selected as resistor ladder network supply reference V. in1in | | | 1 V is selected as resistor ladder network supply reference V. <sub>in2in</sub> | | 5–0<br>VOSEL | DAC Output Voltage Select | | | Selects an output voltage from one of 64 distinct levels. | | | DACO = $(V_{in} / 64)$ * $(VOSEL[5:0] + 1)$ , so the DACO range is from $V_{in} / 64$ to $V_{in}$ . | # 27.2.6 MUX Control Register (CMPx\_MUXCR) Address: Base address + 5h offset # CMPx\_MUXCR field descriptions | Field | Description | | | |---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | 7<br>Reserved | Bit can be programmed to zero only . | | | | | This field is reserved. | | | | 6<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | | | 5–3<br>PSEL | Plus Input Mux Control Determines which input is selected for the plus input of the comparator. For INx inputs, see CMP, DAC, and ANMUX block diagrams. | | | | | 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 CMPx_IN0 pin | | | | | 001 CMPx_IN1 | | | | | 010 CMPx_IN2 | | | | | 011 CMPx_IN3 | | | | | 100 Internally connected to 12-bit DAC | | | | | 101 Connected to CMP_REF pin | | | | | 110 Reserved | | | | | 111 Internally connected to 6-bit DAC | | | | 2-0<br>MSEL | Minus Input Mux Control | | | | | Determines which input is selected for the minus input of the comparator. For INx inputs, see CMP, DAC and ANMUX block diagrams. | | | | | <b>NOTE:</b> 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 CMPx_IN0 pin | | | Table continues on the next page... #### runctional description #### CMPx\_MUXCR field descriptions (continued) | Field | Description | | | | | | |-------|-------------|------------------------------------|--|--|--|--| | | 001 | CMPx_IN1 pin | | | | | | | 010 | CMPx_IN2 pin | | | | | | | 011 | CMPx_IN3 pin | | | | | | | 100 | Internally connected to 12-bit DAC | | | | | | | 101 | CMP_REF pin | | | | | | | 110 | Reserved | | | | | | | 111 | Internally connected to 6-bit DAC | | | | | # 27.3 Functional description The CMP module can be used to compare two analog input voltages applied to INP and INM. 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. SCR[IER] and SCR[IEF] are used to select the condition which will cause the CMP 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 CMPO can be read directly through SCR[COUT]. # 27.3.1 CMP functional modes There are three main sub-blocks to the CMP module: - The comparator itself - The window function - The filter function The filter, CR0[FILTER\_CNT], can be clocked from an internal or external clock source. The filter is programmable with respect to the number of samples that must agree before a change in the output is registered. In the simplest case, only one 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 WINDOW=1. 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 27-22. Comparator sample/filter controls | Mode # | CR1[EN] | CR1[WE] | CR1[SE] | CR0[FILTER_C<br>NT] | FPR[FILT_PER] | Operation | | | | |--------|------------------------------------------------------------------------------------------------------|---------|---------|---------------------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | 1 | 0 | Х | Х | Х | Х | Disabled | | | | | | | | | | | See the Disabled mode (# 1). | | | | | 2A | 1 | 0 | 0 | 0x00 | Х | Continuous Mode | | | | | 2B | 1 | 0 | 0 | Х | 0x00 | See the Continuous mode (#s 2A & 2B). | | | | | 3A | 1 | 0 | 1 | 0x01 | Х | Sampled, Non-Filtered mode | | | | | 3B | 1 | 0 | 0 | 0x01 | > 0x00 | See the Sampled, Non-Filtered mode (#s 3A & 3B). | | | | | 4A | 1 | 0 | 1 | > 0x01 | Х | Sampled, Filtered mode | | | | | 4B | 1 | 0 | 0 | > 0x01 | > 0x00 | See the Sampled, Filtered mode (#s 4A & 4B). | | | | | 5A | 1 | 1 | 0 | 0x00 | X | Windowed mode | | | | | 5B | 1 | 1 | 0 | Х | 0x00 | Comparator output is sampled on every rising bus clock edge when SAMPLE=1 to generate COUTA. | | | | | | | | | | | See 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. | | | | | | | | | | | See 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. | | | | | | | | | | | See the Windowed/Filtered mode (#7). | | | | | All | All other combinations of CR1[EN], CR1[WE], CR1[SE], CR0[FILTER_CNT], and FPR[FILT_PER] are illegal. | | | | | | | | | #### runctional description For cases where a comparator is used to drive a fault input, for example, for a motor-control module such as FTM, it must 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 must be changed only after setting CR1[SE]=0 and CR0[FILTER\_CNT]=0x00. This resets the filter to a known state. # 27.3.1.1 Disabled mode (# 1) In Disabled mode, the analog comparator is non-functional and consumes no power. CMPO is 0 in this mode. # 27.3.1.2 Continuous mode (#s 2A & 2B) Figure 27-21. Comparator operation in Continuous mode #### NOTE See 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 input 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, see the Filter Block Bypass Logic diagram. # 27.3.1.3 Sampled, Non-Filtered mode (#s 3A & 3B) Figure 27-22. 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. #### runctional description 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 27-23. Sampled, Non-Filtered (# 3B): sampling interval internally derived # 27.3.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, now, CR0[FILTER\_CNT]>1, which activates filter operation. Figure 27-24. Sampled, Filtered (# 4A): sampling point externally driven Figure 27-25. Sampled, Filtered (# 4B): sampling point internally derived The only difference in operation between Sampled, Non-Filtered (# 3B) and Sampled, Filtered (# 4B) is that now, CR0[FILTER\_CNT]>1, which activates filter operation. # 27.3.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 state. #### **NOTE** 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. Figure 27-26. Windowed mode operation Figure 27-27. Windowed mode For control configurations which result in disabling the filter block, see Filter Block Bypass Logic diagram. #### runctional description 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. # 27.3.1.6 Windowed/Resampled mode (# 6) The following figure uses the same input stimulus shown in Figure 27-26, and adds resampling of COUTA to generate COUT. Samples are taken at the time points indicated by the arrows in the figure. Again, prop delays and latency are ignored for the sake of clarity. This example was generated solely to demonstrate operation of the comparator in windowed/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 27-28. 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 1. # 27.3.1.7 Windowed/Filtered mode (#7) This is the most complex mode of operation for the comparator block, as it uses 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] \* FPR[FILT\_PER]) + 1) \* 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 27-29. Windowed/Filtered mode # 27.3.2 Power modes # 27.3.2.1 Wait mode operation During Wait and VLPW modes, the CMP, if enabled, continues to operate normally and a CMP interrupt can wake the MCU. # 27.3.2.2 Stop mode operation Depending on clock restrictions related to the MCU core or core peripherals, 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 when CR1[PMODE] = 1 - Low-Speed (LS) Comparison mode when CR1[PMODE] = 0 It is recommended to use the LS mode to minimize power consumption. If stop is exited with a reset, all comparator registers are put into their reset state. # 27.3.2.3 Low-Leakage mode operation When the chip is in Low-Leakage modes: - The CMP module is partially functional and is limited to Low-Speed mode, regardless of CR1[PMODE] 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 supplied 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 wakeup from low-leakage modes, the CMP module is in the reset state except for SCR[CFF] and SCR[CFR]. # 27.3.3 Startup and operation A typical startup sequence is listed here. - 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. See the Data Sheets for power-on delays of the comparators. The windowing function has a maximum of one bus clock period delay. The filter delay is specified in the Low-pass filter. - During operation, the propagation delay of the selected data paths must always be considered. It may take many bus clock cycles for COUT and SCR[CFR]/SCR[CFF] 505 - 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 0, until sufficient clock cycles have elapsed to fill all stages of the filter. This occurs even if COUTA is at a logic 1. ### 27.3.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. ### 27.3.4.1 Enabling filter modes Filter modes can be enabled by: - Setting CR0[FILTER\_CNT] > 0x01 and - Setting FPR[FILT\_PER] to a nonzero 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 0 when first initalized, and will subsequently change when all the consecutive CR0[FILTER\_CNT] samples agree that the output value has changed. In other words, SCR[COUT] will be 0 for some initial period, even when COUTA is at logic 1. 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 all the consecutive CR0[FILTER\_CNT] samples agree that the output value has changed. ### 27.3.4.2 Latency issues The value of FPR[FILT\_PER] or SAMPLE period must be set such that the sampling period is just longer than the period of the expected noise. This way a noise spike will corrupt only one sample. The value of CR0[FILTER\_CNT] must 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 power of CR0[FILTER\_CNT]. 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 power of CR0[FILTER\_CNT]. 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. | 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 <sub>PD</sub> | | 2B | 1 | 0 | 0 | Х | 0x00 | | | | 3A | 1 | 0 | 1 | 0x01 | Х | Sampled, Non-Filtered mode | T <sub>PD</sub> + T <sub>SAMPLE</sub> + T <sub>per</sub> | | 3B | 1 | 0 | 0 | 0x01 | > 0x00 | | $T_{PD}$ + (FPR[FILT_PER] * $T_{per}$ ) + $T_{per}$ | | 4A | 1 | 0 | 1 | > 0x01 | Х | Sampled, Filtered mode | $T_{PD}$ + (CR0[FILTER_CNT] * $T_{SAMPLE}$ ) + $T_{per}$ | | 4B | 1 | 0 | 0 | > 0x01 | > 0x00 | | T <sub>PD</sub> + (CR0[FILTER_CNT] * FPR[FILT_PER] x T <sub>per</sub> ) + T <sub>per</sub> | Table 27-23. Comparator sample/filter maximum latencies Table continues on the next page... 2T<sub>per</sub> | | | | | • | • | | , | |--------|-------------|-------------|-------------|------------------|-------------------|---------------------------|------------------------------------------------------------------------------| | Mode # | CR1[<br>EN] | CR1[<br>WE] | CR1[<br>SE] | CR0[FILTER _CNT] | FPR[FILT_P<br>ER] | Operation | Maximum latency <sup>1</sup> | | 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] *<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] * FPR[FILT_PER] x T <sub>per</sub> ) + | Table 27-23. Comparator sample/filter maximum latencies (continued) # 27.4 CMP interrupts The CMP module is capable of generating an interrupt on either the rising- or fallingedge of the comparator output, or both. The following table gives the conditions in which the interrupt request is asserted and deasserted. | When | Then | |----------------------------------------------------------------|-------------------------------------| | SCR[IER] and SCR[CFR] are set | The interrupt request is asserted | | SCR[IEF] and SCR[CFF] are set | The interrupt request is asserted | | SCR[IER] and SCR[CFR] are cleared for a rising-edge interrupt | The interrupt request is deasserted | | SCR[IEF] and SCR[CFF] are cleared for a falling-edge interrupt | The interrupt request is deasserted | # 27.5 DMA support Normally, the CMP generates a CPU interrupt if there is a change on the COUT. When DMA support is enabled by setting SCR[DMAEN] and the interrupt is enabled by setting SCR[IER], 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 transfer completing indicator that deasserts the DMA transfer request and clears the flag to allow a subsequent change on comparator output to occur and force another DMA request. The comparator can remain functional in STOP modes. 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. #### **CIVIP Asyncrhonous DMA support** When DMA support is enabled by setting SCR[DMAEN] and the interrupt is enabled by setting SCR[IER], SCR[IEF], or both, the corresponding change on COUT forces a DMA transfer request to wake up the system from STOP modes. After the data transfer has finished, system will go back to STOP modes. Refer to DMA chapters in the device reference manual for the asynchronous DMA function for details. # 27.6 CMP Asyncrhonous DMA support The comparator can remain functional in STOP modes. When DMA support is enabled by setting SCR[DMAEN] and the interrupt is enabled by setting SCR[IER], SCR[IEF], or both, the corresponding change on COUT forces a DMA transfer request to wake up the system from STOP modes. After the data transfer has finished, system will go back to STOP modes. Refer to DMA chapters in the device reference manual for the asynchronous DMA function for details. # 27.7 Digital-to-analog converter The figure found here 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 the 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 or disabled when not in use. When in Disabled mode, DACO is connected to the analog ground. Figure 27-30. 6-bit DAC block diagram ## 27.8 DAC functional description This section provides DAC functional description information. ### 27.8.1 Voltage reference source select - V<sub>in1</sub> connects to the primary voltage source as supply reference of 64 tap resistor ladder - $\bullet\ V_{in2}$ connects to an alternate voltage source #### 27.9 DAC resets This module has a single reset input, corresponding to the chip-wide peripheral reset. #### 27.10 DAC clocks This module has a single clock input, the bus clock. # 27.11 DAC interrupts This module has no interrupts. # 27.12 CMP Trigger Mode CMP and DAC are configured to CMP Trigger mode when CMP\_CR1[TRIGM] is set to 1. In addition, the CMP must be enabled. If the DAC is to be used as a reference to the CMP, it must also be enabled. CMP Trigger mode depends on an external timer resource to periodically enable the CMP and 6-bit DAC in order to generate a triggered compare. Upon setting TRIGM, the CMP and DAC are placed in a standby state until an external timer resource trigger is received. See the chip configuration chapter for details about the external timer resource. # **Chapter 28 Voltage Reference (VREF)** ### 28.1 Introduction #### **NOTE** For the chip-specific implementation details of this module's instances, see the chip configuration information. The VREF can be used in applications to provide reference voltages to external devices or used internally as a reference to analog peripherals such as the ADC, DAC, or CMP. The VREF block provides three reference voltages — 1.2 V, 0.8 V, and 0.4 V. VREFH, 1.2 V reference, can be used as an external or internal reference. VREFL, 0.4 V reference, can only be used as a reference for AFE. The 1.2 V and 0.4 V can be combined to provide a differential reference to the AFE. The 0.8 V reference is internal only and is typically used to define the common mode for PGA and Sigma Delta Modulators. In addition it provides a 4µA p-bias source to be used in AFE. VREFH and VREFL references are output on dedicated output pins when VREF is enabled. VREFH reference output can be trimmed with a resolution of 0.5 mV and the VREFL reference output can be trimmed with a resolution of 10 mV. VREFH\_TRIM[5:0] and VREFL\_TRIM[2:0] can be used for the purpose respectively. The following figure is a block diagram of the Voltage Reference. KM Family Reference Manual, Rev. 5, Oct 2013 511 #### muroduction Figure 28-1. Voltage reference block diagram ### 28.1.1 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 enabled/standby (output buffer disabled) - Low power buffer mode (output buffer enabled) - High power buffer mode (output buffer enabled) - 1.2 V output at room temperature - Dedicated output pin, VREFH (1.2 V), and VREFL (0.4 V) ### 28.1.2 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), Very Low Power Wait (VLPW) and Very Low Power Stop (VLPS). If it is desired to use the VREF regulator in the very low power modes, the system reference voltage must be enabled in these modes. Refer to the chip configuration chapter for information on enabling this mode of operation. Having the VREF regulator enabled does increase current consumption. In very low power modes it may be desirable to disable the VREF regulator to minimize current consumption. Note however that the accuracy of the output voltage will be reduced (by as much as several mVs) when the VREF regulator is not used. #### 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. ### 28.1.3 VREF Signal Descriptions The following table shows the Voltage Reference signals properties. Table 28-1. VREF Signal Descriptions | Signal | Description | I/O | |--------|-----------------------------------------------------|-----| | VREFH | Internally-generated 1.2 V Voltage Reference output | 0 | | VREFL | Internally-generated 0.4 V Voltage Reference output | 0 | #### NOTE When the VREF output buffers are disabled, the status of the VREFH and VREFL signals is high-impedance. ## 28.2 Memory Map and Register Definition ### **VREF** memory map | Absolute<br>address<br>(hex) | Register name | Width<br>(in bits) | Access | Reset value | Section/<br>page | |------------------------------|--------------------------------------------------|--------------------|--------|-------------|------------------| | 4006_F000 | VREF Trim Register (VREF_VREFH_TRM) | 8 | R/W | See section | 28.2.1/514 | | 4006_F001 | VREF Status and Control Register (VREF_VREFH_SC) | 8 | R/W | 00h | 28.2.2/515 | | 4006_F005 | VREFL TRIM Register (VREF_VREFL_TRM) | 8 | R/W | See section | 28.2.3/516 | # 28.2.1 VREF Trim Register (VREF\_VREFH\_TRM) This register contains bits that contain the trim data for the Voltage Reference. Address: 4006\_F000h base + 0h offset = 4006\_F000h | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|------------|--------|------------|------------|----|------------|------------|----| | Read <br>Write | Reserved | CHOPEN | | | TF | RIM | | | | Reset | <b>x</b> * | 0 | <b>x</b> * | <b>x</b> * | x* | <b>x</b> * | <b>x</b> * | x* | <sup>\*</sup> Notes: #### **VREF\_VREFH\_TRM** field descriptions | Field | Description | |---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7<br>Reserved | This field is reserved. Upon reset this value is loaded with a factory trim value. | | 6<br>CHOPEN | Chop oscillator enable. When set, internal chopping operation is enabled and the internal analog offset will be minimized. | | | This bit is set during factory trimming of the VREF voltage. This bit should be written to 1 to achieve the performance stated in the data sheet. | | | 0 Chop oscillator is disabled. | | | 1 Chop oscillator is enabled. | | 5–0 | Trim bits | | TRIM | 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 | <sup>•</sup> x = Undefined at reset. # 28.2.2 VREF Status and Control Register (VREF\_VREFH\_SC) This register contains the control bits used to enable the internal voltage reference and to select the buffer mode to be used. Address: 4006\_F000h base + 1h offset = 4006\_F001h #### VREF\_VREFH\_SC field descriptions | Field | Description | | | | | | |---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | 7 | Internal Voltage Reference enable | | | | | | | VREFEN | This bit is used to enable the bandgap reference within the 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. | | | | | | | | 0 The module is disabled. | | | | | | | | 1 The module is enabled. | | | | | | | 6 | Regulator enable | | | | | | | REGEN | This bit is used to enable the internal 1.75 V regulator to produce a constant internal voltage supply in order to reduce the sensitivity to external supply noise and variation. If it is desired to keep the regulator enabled in very low power modes, refer to the Chip Configuration chapter for a description on how this can be achieved. | | | | | | | | This bit is set during factory trimming of the VREF voltage. This bit should be written to 1 to achieve the performance stated in the data sheet. | | | | | | | | 0 Internal 1.75 V regulator is disabled. | | | | | | | | 1 Internal 1.75 V regulator is enabled. | | | | | | | 5<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | | | | | | 4<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | | | | | | 3<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | | | | | | 2 | Internal Voltage Reference stable | | | | | | | VREFST | This bit indicates that the bandgap reference within the Voltage Reference module has completed its startup and stabilization. | | | | | | | | 0 The module is disabled or not stable. | | | | | | | | 1 The module is stable. | | | | | | Table continues on the next page... #### wemory Map and Register Definition ### **VREF\_VREFH\_SC** field descriptions (continued) | Field | Description | |---------|----------------------------------------------------------------------| | 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 High power buffer mode enabled | | | 10 Low-power buffer mode enabled | | | 11 Reserved | # 28.2.3 VREFL TRIM Register (VREF\_VREFL\_TRM) This register contains bits that contain enable and trim data for VREFL (0.4 V) reference. It also contains a bit to select between internal and external 1.2 V reference. Address: 4006\_F000h base + 5h offset = 4006\_F005h <sup>\*</sup> Notes: #### **VREF\_VREFL\_TRM** field descriptions | Field | Description | |-------------------|----------------------------------------------------------------------------------------------------------------------------------------| | 7–5<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 4<br>VREFL_SEL | This bit selects between internal and external 1.2 V reference. | | _ | Internal reference External reference | | 3<br>VREFL_EN | This bit enables the VREFL (0.4 V) reference buffer. | | _ | <ul><li>0 Disable</li><li>1 Enable</li></ul> | | 2–0<br>VREFL_TRIM | These bits trim the VREFL reference voltage in steps of 10 mV. The mid voltage of the trim range is 0.4 V at the trim value of 3'b011. | | | NOTE: Value of VREFL_TRIM (default 011) is determined by ifr. | <sup>•</sup> x = Undefined at reset. # 28.3 Functional Description The Voltage Reference is a bandgap buffer system. Unity gain amplifiers are used to buffer the outputs. The VREFH signal can be used by both internal and external peripherals in low and high power buffer mode. The VREFH and VREFL references together provide a differential referential voltage to the internal ADC. Two 100 nF capacitor must always be connected between VREFH and VREFL and VSSA if the VREF is being used. The following table shows all possible function configurations of the Voltage Reference. | SC[VREFEN] | SC[MODE_LV] | Configuration | Functionality | |------------|-------------|----------------------------------------------------|------------------------------------------------------------------------------| | 0 | X | Voltage Reference disabled | Off | | 1 | 00 | Voltage Reference enabled,<br>bandgap on only | Startup and standby | | 1 | 01 | Voltage Reference enabled,<br>high-power buffer on | VREFH available for internal and external use. 100 nF capacitor is required. | | 1 | 10 | Voltage Reference enabled,<br>low power buffer on | VREFH available for internal and external use. 100 nF capacitor is required. | | 1 | 11 | Reserved | Reserved | Table 28-6. Voltage Reference function configurations ## 28.3.1 Voltage Reference Disabled, SC[VREFEN] = 0 When SC[VREFEN] = 0, the Voltage Reference is disabled, the bandgap and the output buffers are disabled. The Voltage Reference is in off mode. ### 28.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. VREFL reference buffer is enabled by setting VREF EN bit. **runctional Description** # 28.3.2.1 SC[MODE\_LV]=00 The internal VREF bandgap is enabled to generate an accurate 1.2 V output that can be trimmed with the TRM register's VREFH\_TRIM[5:0] bitfield. The bandgap requires some time for startup and stabilization. SC[VREFST] can be monitored to determine if the stabilization and startup is complete. The output buffer is disabled in this mode, and there is no buffered voltage output. The Voltage Reference is in standby mode. If this mode is first selected and the low power or high power buffer mode is subsequently enabled, there will be a delay before the buffer output is settled at the final value. This is the buffer start up delay (Tstup) and the value is specified in the appropriate device data sheet. ### 28.3.2.2 SC[MODE\_LV] = 01 The internal VREF bandgap is on. The high power buffer is enabled to generate a buffered 1.2 V voltage to VREFH. It can also be used as a reference to internal analog peripherals such as an ADC channel or analog comparator input. If this mode is entered from the standby mode (SC[MODE\_LV] = 00, SC[VREFEN] = 1) there will be a delay before the buffer output is settled at the final value. This is the buffer start up delay (Tstup) and the value is specified in the appropriate device data sheet. If this mode is entered when the VREF module is enabled then you must wait the longer of Tstup or until SC[VREFST] = 1. In this mode, a 100 nF capacitor is required to connect between the VREFH pin and VSSA. ### 28.3.2.3 SC[MODE\_LV] = 10 The internal bandgap is on. The low power buffer is enabled to generate a buffered 1.2 V voltage to VREFH. It can also be used as a reference to internal analog peripherals such as an ADC channel or analog comparator inpu0t. If this mode is entered from the standby mode (SC[MODE\_LV] = 00, SC[VREFEN] = 1) there will be a delay before the buffer output is settled at the final value. This is the buffer start up delay (Tstup) and the value is specified in the appropriate device data sheet. If this mode is entered when the VREF module is enabled then you must wait the longer of Tstup or until SC[VREFST] = 1. In this mode, a 100 nF capacitor is required to connect between the VREFH pin and VSSA. ### 28.3.2.4 SC[MODE\_LV] = 11 Reserved # 28.4 Initialization/Application Information The Voltage Reference requires some time for startup and stabilization. After SC[VREFEN] = 1, wait for 40ms for startup and stabilization. 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 at the VREFH pin has settled. This is the buffer start up delay (Tstup) and the value is specified in the appropriate device data sheet. Also, there will be some settling time when a step change of the load current is applied to the VREFH pin. When the 1.75V VREF regulator is disabled, the VREFH voltage will be more sensitive to supply voltage variation. It is recommended to use this regulator to achieve optimum VREFH performance. The TRM[CHOPEN] and SC[REGEN] bits are written to 1 during factory trimming of the VREF voltage. These bits should be written to 1 to achieve the performance stated in the device data sheet. To enable the VREFL reference buffer the bit VREFL\_EN should be set to 1. The mid value of 011 should be written to the bits VREFL\_TRIM[2:0] mualization/Application Information # **Chapter 29 Multipurpose Clock Generator (MCG)** ### 29.1 Introduction #### **NOTE** For the chip-specific implementation details of this module's instances, see the chip configuration information. 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. ### 29.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. KM Family Reference Manual, Rev. 5, Oct 2013 521 #### muroduction - 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): - Voltage-controlled oscillator (VCO) - Selectable 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 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 are provided - Reference dividers for the Fast Internal Reference Clock are provided - 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 This figure presents the block diagram of the MCG module. #### muroduction Figure 29-1. Multipurpose Clock Generator (MCG) block diagram #### **NOTE** Refer to the chip configuration chapter to identify the oscillator used in this MCU. ### 29.1.2 Modes of Operation The MCG has the following modes of operation: FEI, FEE, FBI, FBE, PEE, PEI, PBI, BLPI, BLPE, and Stop. For details, see MCG modes of operation. # 29.2 External Signal Description There are no MCG signals that connect off chip. # 29.3 Memory Map/Register Definition This section includes the memory map and register definition. ### MCG memory map | Absolute address (hex) | Register name | Width<br>(in bits) | Access | Reset value | Section/<br>page | |------------------------|-------------------------------------------------------|--------------------|--------|-------------|------------------| | 4006_4000 | MCG Control 1 Register (MCG_C1) | 8 | R/W | 44h | 29.3.1/526 | | 4006_4001 | MCG Control 2 Register (MCG_C2) | 8 | R/W | 83h | 29.3.2/527 | | 4006_4002 | MCG Control 3 Register (MCG_C3) | 8 | R/W | Undefined | 29.3.3/528 | | 4006_4003 | MCG Control 4 Register (MCG_C4) | 8 | R/W | Undefined | 29.3.4/528 | | 4006_4004 | MCG Control 5 Register (MCG_C5) | 8 | R/W | 00h | 29.3.5/530 | | 4006_4005 | MCG Control 6 Register (MCG_C6) | 8 | R/W | 08h | 29.3.6/530 | | 4006_4006 | MCG Status Register (MCG_S) | 8 | R | 15h | 29.3.7/531 | | 4006_4008 | MCG Status and Control Register (MCG_SC) | 8 | R/W | 02h | 29.3.8/533 | | 4006_400A | MCG Auto Trim Compare Value High Register (MCG_ATCVH) | 8 | R/W | 00h | 29.3.9/534 | | 4006_400B | MCG Auto Trim Compare Value Low Register (MCG_ATCVL) | 8 | R/W | 00h | 29.3.10/<br>534 | | 4006_400C | MCG Control 7 Register (MCG_C7) | 8 | R/W | 00h | 29.3.11/<br>535 | | 4006_400D | MCG Control 8 Register (MCG_C8) | 8 | R/W | 80h | 29.3.12/<br>536 | | 4006_400E | MCG Control 9 Register (MCG_C9) | 8 | R/W | 00h | 29.3.13/<br>537 | # 29.3.1 MCG Control 1 Register (MCG\_C1) Address: 4006\_4000h base + 0h offset = 4006\_4000h ### MCG\_C1 field descriptions | Field | Description | |---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7–6 | Clock Source Select | | CLKS | 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. | | 5–3<br>FRDIV | FLL External Reference Divider | | | 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 = 0, Divide Factor is 1; for all other RANGE 0 values, Divide Factor is 32. | | | 001 If RANGE 0 = 0, Divide Factor is 2; for all other RANGE 0 values, Divide Factor is 64. | | | 010 If RANGE 0 = 0, Divide Factor is 4; for all other RANGE 0 values, Divide Factor is 128. | | | 011 If RANGE 0 = 0, Divide Factor is 8; for all other RANGE 0 values, Divide Factor is 256. | | | 100 If RANGE 0 = 0, Divide Factor is 16; for all other RANGE 0 values, Divide Factor is 512. | | | 101 If RANGE 0 = 0, Divide Factor is 32; for all other RANGE 0 values, Divide Factor is 1024. | | | 110 If RANGE 0 = 0, Divide Factor is 64; for all other RANGE 0 values, Divide Factor is 1280. | | | 111 If RANGE 0 = 0, Divide Factor is 128; for all other RANGE 0 values, Divide Factor is 1536. | | 2<br>IREFS | Internal Reference Select | | IIILI 3 | 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 | | | Controls whether or not the internal reference clock remains enabled when the MCG enters Stop mode. | | | 0 Internal reference clock is disabled in Stop mode. | | | 1 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. | # 29.3.2 MCG Control 2 Register (MCG\_C2) Address: 4006\_4000h base + 1h offset = 4006\_4001h ### MCG\_C2 field descriptions | Field | Description | |---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7<br>LOCRE0 | Loss of Clock Reset Enable | | | Determines whether an interrupt or a reset request is made following a loss of OSC0 external reference clock. The LOCRE0 only has an affect when CME0 is set. | | | 0 Interrupt request is generated on a loss of OSC0 external reference clock. | | | 1 Generate a reset request on a loss of OSC0 external reference clock. | | 6<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 5–4 | Frequency Range Select | | RANGE0 | | | | Selects the frequency range for the crystal oscillator or external clock source. See the Oscillator (OSC) chapter for more details and the device data sheet for the frequency ranges used. | | | 00 Encoding 0 — Low frequency range selected for the crystal oscillator . | | | 01 Encoding 1 — High frequency range selected for the crystal oscillator . | | | 1X Encoding 2 — Very high frequency range selected for the crystal oscillator . | | 3<br>HGO0 | High Gain Oscillator Select | | | Controls the crystal oscillator mode of operation. See the Oscillator (OSC) chapter for more details. | | | 0 Configure crystal oscillator for low-power operation. | | | 1 Configure crystal oscillator for high-gain operation. | | 2 | External Reference Select | | EREFS0 | Selects the source for the external reference clock. See the Oscillator (OSC) chapter for more details. | | | 0 External reference clock requested. | | | 1 Oscillator requested. | | 1<br>LP | Low Power Select | | | 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) | | 0 | Internal Reference Clock Select | | IRCS | Selects between the fast or slow internal reference clock source. | Table continues on the next page... #### wemory Map/Register Definition ### MCG\_C2 field descriptions (continued) | Field | Description | |-------|-------------------------------------------| | | 0 Slow internal reference clock selected. | | | 1 Fast internal reference clock selected. | ### 29.3.3 MCG Control 3 Register (MCG\_C3) Address: 4006\_4000h base + 2h offset = 4006\_4002h | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|------------|------------|------------|------------|----|------------|------------|------------| | Read<br>Write | SCTRIM | | | | | | | | | Reset | <b>x</b> * | <b>x</b> * | <b>x</b> * | <b>x</b> * | x* | <b>x</b> * | <b>x</b> * | <b>x</b> * | <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. | <sup>1.</sup> A value for SCTRIM is loaded during reset from a factory programmed location. # 29.3.4 MCG Control 4 Register (MCG\_C4) #### NOTE Reset values for DRST and DMX32 bits are 0. Address: 4006\_4000h base + 3h offset = 4006\_4003h <sup>\*</sup> Notes: - x = Undefined at reset. - A value for FCTRIM is loaded during reset from a factory programmed location. x = Undefined at reset. <sup>•</sup> x = Undefined at reset. # MCG\_C4 field descriptions | Field | Description | | | | | |---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|-----------------------|-------------------------| | 7 | DCO Maximum Freque | ency with 32.768 | kHz Reference | | | | DMX32 | The DMX32 bit controls whether the DCO frequency range is narrowed to its maximum frequency with a 32.768 kHz reference. | | | | | | | The following table ide | ntifies settings fo | or the DCO frequency range | e. | | | | NOTE: The system of | ocks derived from | m this source should not ex | xceed 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 | | | DRST field does not up between clock domain: 00 Encoding 0 — Lo 01 Encoding 1 — Mi 10 Encoding 2 — Mi | odate immediate<br>s. See the DCO<br>w range (reset d<br>d range.<br>d-high range. | ead field indicates the curre<br>ly after a write to the DRS t<br>Frequency Range table for<br>efault). | field due to internal | | | | 11 Encoding 3 — Hi | | | | | | 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. Increasin the binary value increases the period, and decreasing the value decreases the period. | | | | | | | If an FCTRIM[3:0] value value from the nonvola | | olatile memory is to be use ation to this register. | d, it is your respon | sibility to copy that | | 0 | Slow Internal Reference | e Clock Fine Tri | m | | | | SCFTRIM | | | tment of the slow internal re<br>aring SCFTRIM decreases | | | | | If an SCFTRIM value s | | tile memory is to be used, i | it is your responsib | ility to copy that valu | - 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 . # 29.3.5 MCG Control 5 Register (MCG\_C5) Address: 4006\_4000h base + 4h offset = 4006\_4004h ### MCG\_C5 field descriptions | Field | Description | |-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 6<br>PLLCLKEN0 | PLL Clock Enable Enables the PLL independent of PLLS and enables the PLL clock for use as MCGPLLCLK. Setting PLLCLKEN 0 will enable the external oscillator if not already enabled. Whenever the PLL is being enabled by means of the PLLCLKEN 0 bit, and the external oscillator is being used as the reference clock, the OSCINIT 0 bit should be checked to make sure it is set. | | | MCGPLLCLK is inactive. MCGPLLCLK is active. | | 5<br>PLLSTEN0 | PLL Stop Enable Enables the PLL Clock during Normal Stop. In Low Power Stop mode, the PLL clock gets disabled even if PLLSTEN 0 =1. All other power modes, PLLSTEN 0 bit has no affect and does not enable the PLL Clock to run if it is written to 1. 0 MCGPLLCLK is disabled in any of the Stop modes. 1 MCGPLLCLK is enabled if system is in Normal Stop mode. | | 4–0<br>Reserved | Reserved This field is reserved. This read-only field is reserved and always has the value 0. | # 29.3.6 MCG Control 6 Register (MCG\_C6) Address: 4006\_4000h base + 5h offset = 4006\_4005h #### MCG\_C6 field descriptions | Field | Description | |-------------|--------------------------------| | 7<br>LOLIE0 | Loss of Lock Interrrupt Enable | Table continues on the next page... ### MCG\_C6 field descriptions (continued) | Field | Description | |-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | Determines if an interrupt request is made following a loss of lock indication. This bit only has an effect when LOLS 0 is set. | | | 0 No interrupt request is generated on loss of lock. | | | 1 Generate an interrupt request on loss of lock. | | 6<br>PLLS | PLL Select Controls whether the PLL or FLL output is selected as the MCG source when CLKS[1:0]=00. If the PLLS bit is cleared and PLLCLKEN 0 is not set, the PLL is disabled in all modes. If the PLLS is set, the FLL is disabled in all modes. | | | 0 FLL is selected. | | | PLL is selected (PLL reference clock must be in the range of 31.25–39.0625 KHz prior to setting the PLLS bit). | | 5<br>CME0 | Clock Monitor Enable | | CIMEO | Enables the loss of clock monitoring circuit for the OSC0 external reference mux select. The LOCRE0 bit will determine if a interrupt or a reset request is generated following a loss of OSC0 indication. The CME0 bit must only be set to a logic 1 when the MCG is in an operational mode that uses the external clock (FEE, FBE, PEE, PBE, or BLPE). Whenever the CME0 bit is set to a logic 1, the value of the RANGE0 bits in the C2 register should not be changed. CME0 bit should be set to a logic 0 before the MCG enters any Stop mode. Otherwise, a reset request may occur while in Stop mode. CME0 should also be set to a logic 0 before entering VLPR or VLPW power modes if the MCG is in BLPE mode. | | | <ul><li>0 External clock monitor is disabled for OSC0.</li><li>1 External clock monitor is enabled for OSC0.</li></ul> | | 4–0<br>Reserved | Directly controls the PLL Charge Pump Current. Appropriate selection of this value is imperative to ensure stable operation of the PLL closed loop system. The default value for this field is set to 5'b01000 out of reset which generates a nominal 750nA charge pump current (lcp). | | | This read-only field is reserved and always has the value 0. | # 29.3.7 MCG Status Register (MCG\_S) Address: 4006\_4000h base + 6h offset = 4006\_4006h #### MCG\_S field descriptions | Field | Description | |-------|---------------------------------------------------------------------------------------------------------------| | 7 | Loss of Lock Status | | LOLS0 | | | | 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 unl . LOLIE determines whether an | | | interrupt request is made when LOLS is set. LOLRE determines whether a reset request is made when | Table continues on the next page... #### wemory Map/Register Definition # MCG\_S field descriptions (continued) | Field | Description | |---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | LOLS is set. This bit is cleared by reset or by writing a logic 1 to it when set. Writing a logic 0 to this bit has no effect. | | | 0 PLL has not lost lock since LOLS 0 was last cleared. | | | 1 PLL has lost lock since LOLS 0 was last cleared. | | 6<br>LOCK0 | Lock Status | | 250110 | This bit indicates whether the PLL has acquired lock. Lock detection is only enabled when the PLL is enabled (either through clock mode selection or PLLCLKEN0=1 setting). 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. Loss of PLL reference clock will also cause the LOCK0 bit to clear until the PLL has reacquired lock. Entry into VLPS, or regular Stop with PLLSTEN=0 also causes the lock status bit to clear and stay cleared until the Stop mode is exited and the PLL has reacquired lock. Any time the PLL is enabled and the LOCK0 bit is cleared, the MCGPLLCLK will be gated off until the LOCK0 bit is asserted again. | | | 0 PLL is currently unlocked. | | _ | 1 PLL is currently locked. | | 5<br>PLLST | PLL Select Status | | 1 2231 | 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. | | | 0 Source of PLLS clock is FLL clock. | | | 1 Source of PLLS clock is PLL output 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. | | | 0 Source of FLL reference clock is the external reference clock. | | | 1 Source of FLL reference clock is the internal reference clock. | | 3–2<br>CLKST | Clock Mode Status | | CLRST | 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>OSCINITO | OSC Initialization | | | This bit, which resets to 0, is set to 1 after the initialization cycles of the crystal oscillator clock have completed. After being set, the bit is cleared to 0 if the OSC is subsequently disabled. See the OSC module's detailed description for more information. | | 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. | Table continues on the next page... 532 **Preliminary** Freescale Semiconductor, Inc. ### MCG\_S field descriptions (continued) | Field | Description | |-------|----------------------------------------------------------------------| | | O Source of internal reference clock is the slow clock (32 kHz IRC). | | | 1 Source of internal reference clock is the fast clock (4 MHz IRC). | # 29.3.8 MCG Status and Control Register (MCG\_SC) Address: 4006\_4000h base + 8h offset = 4006\_4008h #### MCG\_SC field descriptions | Field | Description | |---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | Automatic Trim Machine Enable | | ATME | 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 SC registers or entering Stop mode aborts the auto trim operation and clears this bit. | | | 0 Auto Trim Machine disabled. | | | 1 Auto Trim Machine enabled. | | 6 | Automatic Trim Machine Select | | ATMS | 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 SC 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<br>FLTPRSRV | FLL Filter Preserve Enable | | | This bit will prevent the FLL filter values from resetting allowing the FLL output frequency to remain the | | | same during clock mode changes where the FLL/DCO output is still valid. (Note: This requires that the FLL reference frequency to remain the same as what it was prior to the new clock mode switch. Otherwise | | | FLL filter and frequency values will change.) | | | 0 FLL filter and FLL frequency will reset on changes to currect clock mode. | | | 1 FII filter and FLL frequency retain their previous values during new clock mode change. | Table continues on the next page... #### wemory Map/Register Definition ### MCG\_SC field descriptions (continued) | Field | Description | |---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 3–1<br>FCRDIV | Fast Clock Internal Reference Divider | | TOTIDIV | Selects the amount to divide down the fast internal reference clock. The resulting frequency will be in the range 31.25 kHz to 4 MHz (Note: Changing the divider when the Fast IRC is enabled is not supported). | | | 000 Divide Factor is 1 | | | 001 Divide Factor is 2. | | | 010 Divide Factor is 4. | | | 011 Divide Factor is 8. | | | 100 Divide Factor is 16 | | | 101 Divide Factor is 32 | | | 110 Divide Factor is 64 | | | 111 Divide Factor is 128. | | 0<br>LOCS0 | OSC0 Loss of Clock Status | | | The LOCS0 indicates when a loss of OSC0 reference clock has occurred. The LOCS0 bit only has an effect when CME0 is set. This bit is cleared by writing a logic 1 to it when set. | | | 0 Loss of OSC0 has not occurred. | | | 1 Loss of OSC0 has occurred. | # 29.3.9 MCG Auto Trim Compare Value High Register (MCG\_ATCVH) Address: 4006\_4000h base + Ah offset = 4006\_400Ah #### 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. | ### 29.3.10 MCG Auto Trim Compare Value Low Register (MCG\_ATCVL) Address: 4006\_4000h base + Bh offset = 4006\_400Bh ### 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. | # 29.3.11 MCG Control 7 Register (MCG\_C7) Address: 4006\_4000h base + Ch offset = 4006\_400Ch ### MCG\_C7 field descriptions | Field | Description | |--------------|--------------------------------------------------------------------------------------| | 7–6 | MCG PLL 32Khz Reference Clock Select | | PLL32KREFSEL | Selects the 32kHz PLL reference clock. | | | 00 Selects 32 kHz RTC Oscillator. | | | 01 Selects 32 kHz IRC. | | | 10 Selects FLL FRDIV clock. | | | 11 Reserved. | | 5–2 | Reserved | | Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 1 | Reserved | | Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 0 | MCG OSC Clock Select | | OSCSEL | Selects the MCG FLL external reference clock | | | 0 Selects Oscillator (OSCCLK). | | | 1 Selects 32 kHz RTC Oscillator. | # 29.3.12 MCG Control 8 Register (MCG\_C8) Address: 4006\_4000h base + Dh offset = 4006\_400Dh #### MCG\_C8 field descriptions | | wod_co nela descriptions | | |--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | Field | Description | | | 7<br>LOCRE1 | Loss of Clock Reset Enable | | | EGGNET | Determines if a interrupt or a reset request is made following a loss of RTC external reference clock. The LOCRE1 only has an affect when CME1 is set. | | | | 0 Interrupt request is generated on a loss of RTC external reference clock. | | | | Generate a reset request on a loss of RTC external reference clock | | | 6<br>LOLRE | PLL Loss of Lock Reset Enable | | | | Determines if an interrupt or a reset request is made following a PLL loss of lock. | | | | 0 Interrupt request is generated on a PLL loss of lock indication. The PLL loss of lock interrupt enable bit must also be set to generate the interrupt request. | | | | 1 Generate a reset request on a PLL loss of lock indication. | | | 5<br>CME1 | Clock Monitor Enable1 | | | | Enables the loss of clock monitoring circuit for the output of the RTC external reference clock. The LOCRE1 bit will determine whether an interrupt or a reset request is generated following a loss of RTC clock indication. The CME1 bit should be set to a logic 1 when the MCG is in an operational mode that uses the RTC as its external reference clock or if the RTC is operational. CME1 bit must be set to a logic 0 before the MCG enters any Stop mode. Otherwise, a reset request may occur when in Stop mode. CME1 should also be set to a logic 0 before entering VLPR or VLPW power modes. | | | | External clock monitor is disabled for RTC clock. | | | | 1 External clock monitor is enabled for RTC clock. | | | 4 | Loss of Coarse Lock Interrrupt Enable | | | COARSE_LOLIE | Determines if an interrupt request is made following a coarse loss of lock indication. This bit only has an effect when COARSE_LOLS is set. | | | | 0 No interrupt request is generated on coarse loss of lock. | | | | 1 Generate an interrupt request on coarse loss of lock. | | | 3–1 | This field is reserved. | | | Reserved | This read-only field is reserved and always has the value 0. | | | 0<br>LOCS1 | RTC Loss of Clock Status | | | 2000. | This bit indicates when a loss of clock has occurred. This bit is cleared by writing a logic 1 to it when set. | | | | 0 Loss of RTC has not occur. | | | | 1 Loss of RTC has occur | | | | | | # 29.3.13 MCG Control 9 Register (MCG\_C9) Address: 4006\_4000h base + Eh offset = 4006\_400Eh ### MCG\_C9 field descriptions | Field | Description | |------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7<br>COARSE_LOLS | Coarse Loss of Lock Status This bit is a sticky bit indicating the coarse lock status for the PLL. COARSE_LOLS is set if after acquiring a coarse lock, the PLL output frequency has fallen outside the lock exit frequency tolerance, D unl. COARSE_LOLIE determines whether an interrupt request is made when COARSE_LOLS is set. This bit is cleared by reset or by writing a logic 1 to it when set. Writing a logic 0 to this bit has no effect. O PLL has not lost lock since COARSE_LOLS was last cleared. 1 PLL has lost lock since COARSE_LOLS was last cleared. | | 6<br>COARSE_LOCK | Coarse Lock Status This bit indicates whether the PLL has acquired coarse lock after the first lock sample (Note: LOCK bit asserts after three lock samples and CRS_LOCK will assert after first lock sample). Lock detection is disabled when not operating in either PEI, PBI, PBE or PEE mode unless PLLCLKEN0 =1 and the MCG is not configured in BLPI or BLPE mode. Loss of PLL reference clock will also cause the COARSE LOCK PLL has reacquired lock. Entry into LLS, VLPS, or regular Stop with PLLSTEN0=0 also causes the coarse lock status bit to clear and stay cleared until the Stop mode is exited and the PLL has reacquired lock after the first sample. 0 PLL is currently unlocked. 1 PLL is currently locked after first sample. | | 5–4<br>Reserved | Reserved This field is reserved. This read-only field is reserved and always has the value 0. | | 3–1<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 0<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | # 29.4 Functional description ## 29.4.1 MCG mode state diagram The eleven states of the MCG are shown in the following figure and are described in Table 29-15. The arrows indicate the permitted MCG mode transitions. Figure 29-15. MCG mode state diagram #### **NOTE** • During exits from 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. During exits from VLPS when the MCG is in PEI mode, the MCG will reset to PBI clock mode and the C1[CLKS] and S[CLKST] will automatically be set to 2'b01 and C5[PLLSTEN0] will automatically be set to 1'b0. • If entering Normal Stop mode when the MCG is in PEE mode with PLLSTEN=0, the MCG will reset to PBE clock mode and C1[CLKS] and S[CLKST] will automatically be set to 2'b10. If entering Normal Stop mode when the MCG is in PEI mode with C5[PLLSTEN]=0, the MCG will reset to PBI clock mode and C1[CLKS] and S[CLKST] will automatically be set to 2'b01. ### 29.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 29-15. Table 29-15. MCG modes of operation | Mode | Description | |----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | FLL Engaged Internal | FLL engaged internal (FEI) is entered when all the following condtions occur: | | (FEI) | 00 is written to C1[CLKS]. | | | 1 is written to C1[IREFS]. | | | 0 is written to C6[PLLS]. | | | In FEI mode, MCGOUTCLK 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 C4[DRST_DRS] and C4[DMX32] bits, times the internal reference frequency. See 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 . | Table continues on the next page... #### runctional description # Table 29-15. MCG modes of operation (continued) | Mode | Description | |-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | FLL Engaged External | FLL engaged external (FEE) mode is entered when all the following conditions occur: | | (FEE) | 00 is written to C1[CLKS]. | | | 0 is written to C1[IREFS]. | | | C1[FRDIV] must be written to divide external reference clock to be within the range of 31.25 kHz to 39.0625 kHz | | | 0 is written to C6[PLLS]. | | | In FEE mode, MCGOUTCLK 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 C1[FRDIV] and C2[RANGE]. See 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) | 01 is written to C1[CLKS]. | | | 1 is written to C1[IREFS]. | | | 0 is written to C6[PLLS] | | | 0 is written to C2[LP]. | | | In FBI mode, the MCGOUTCLK is derived either from the slow (32 kHz IRC) or fast (4 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 MCGOUTCLK 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 C4[DRST_DRS] and C4[DMX32] bits, times the internal reference frequency. See 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 . | | PLL Engaged Internal | PLL Engaged Internal (PEI) mode is entered when all the following conditions occur: | | (PEI) | 00 is written to C1[CLKS]. | | | 1 is written to C1[IREFS]. | | | 1 is written to C6[PLLS]. | | | 01 is written to C7[PLL32KREFSEL]. | | | In PEI mode, the MCGOUTCLK is derived from the PLL clock, which is controlled by the 32 kHz IRC reference clock. The PLL clock frequency locks to a multiplication factor times the internal reference frequency. The FLL is disabled in a low-power state. | Table continues on the next page... # Table 29-15. MCG modes of operation (continued) | Mode | Description | |-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | PLL Bypassed Internal | PLL Bypassed Internal (PBI) mode is entered when all the following conditions occur: | | (PBI) | 01 is written to C1[CLKS]. | | | 1 is written to C1[IREFS]. | | | 1 is written to C6[PLLS]. | | | 01 is written to C7[PLL32KREFSEL]. | | | 0 is written to C2[LP]. | | | In PBI mode, MCGOUTCLK is derived from the IRCS clock select; 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 MCGOUTCLK is driven from the IRCS selected reference clock. The PLL clock frequency locks to a multiplication factor times the PLL reference frequency. In preparation for transition to PEI, the PLL's programmable reference divider must be configured to produce a valid PLL reference clock. The FLL is disabled in a low-power state. | | FLL Bypassed External | FLL bypassed external (FBE) mode is entered when all the following conditions occur: | | (FBE) | 10 is written to C1[CLKS]. | | | 0 is written to C1[IREFS]. | | | <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> | | | 0 is written to C6[PLLS]. | | | 0 is written to C2[LP]. | | | In FBE mode, the MCGOUTCLK 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 MCGOUTCLK 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 C4[DRST_DRS] and C4[DMX32] bits, times the divided external reference frequency. See 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 . | | PLL Engaged External | PLL Engaged External (PEE) mode is entered when all the following conditions occur: | | (PEE) | 00 is written to C1[CLKS]. | | | 0 is written to C1[IREFS]. | | | 1 is written to C6[PLLS]. | | | 00 or 10 is written to C7[PLL32KREFSEL]. | | | In PEE mode, the MCGOUTCLK is derived from the output of PLL which is controlled by a selectable external or internal reference clock. The PLL clock frequency locks to a multiplication factor of 375 times the selected PLL reference frequency. The PLL's programmable reference divider must be configured to produce a valid PLL reference clock. The FLL is disabled in a low-power state. | Table continues on the next page... #### runctional description # Table 29-15. MCG modes of operation (continued) | Mode | Description | | | | |-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | PLL Bypassed External | PLL Bypassed External (PBE) mode is entered when all the following conditions occur: | | | | | (PBE) | 10 is written to C1[CLKS]. | | | | | | 0 is written to C1[IREFS]. | | | | | | 1 is written to C6[PLLS]. | | | | | | 10 is written to C7[PLL32KREFSEL] | | | | | | 0 is written to C2[LP]. | | | | | | In PBE mode, MCGOUTCLK is derived from the 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 MCGOUTCLK is driven from the external reference clock. The PLL clock frequency locks to a multiplication factor of 375 times the PLL reference frequency. 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 | 01 is written to C1[CLKS]. | | | | | | 1 is written to C1[IREFS]. | | | | | | 0 is written to C6[PLLS]. | | | | | | 1 is written to C2[LP]. | | | | | | In BLPI mode, MCGOUTCLK is derived from the internal reference clock. The FLL is disabled and PLL is disabled even if C5[PLLCLKEN] is set to 1. | | | | | Bypassed Low Power | Bypassed Low Power External (BLPE) mode is entered when all the following conditions occur: | | | | | External (BLPE) | 10 is written to C1[CLKS]. | | | | | | 0 is written to C1[IREFS]. | | | | | | 1 is written to C2[LP]. | | | | | | In BLPE mode, MCGOUTCLK is derived from the external reference clock. The FLL is disabled and PLL is disabled even if the C5[PLLCLKEN] is set to 1. | | | | Table continues on the next page... #### Table 29-15. 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 behavior 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 Normal Stop mode when all the following conditions become true: | | | • C1[IRCLKEN] = 1 | | | • C1[IREFSTEN] = 1 | | | NOTE: • In VLPS Stop Mode, the MCGIRCLK can be programmed to stay enabled and continue running if C1[IRCLKEN] = 1, C1[IREFSTEN]=1, and Fast IRC clock is selected (C2[IRCS] = 1) | | | • When entering Low Power Stop mode (VLPS) from a PLL Enganged mode (PEE or PEI), on exit the MCG clock mode is forced to PBE clock mode if entering from PEE mode or to PBI if entering from PEI mode. C1[CLKS] and S[CLKST] will be configured to 2'b10if entering from PEE mode or to 2'b01 if entering from PEI mode, C5[PLLSTEN0] will be force to 1'b0 and S[LOCK] bit will be cleared without setting S[LOLS]. | | | <ul> <li>When entering Normal Stop mode from a PLL Engaged mode (PEE or PEI) and if<br/>C5[PLLSTEN0]=0, on exit the MCG clock mode is forced to PBE mode if entered<br/>from PEE mode or PBI if entered from PBI mode,, the C1[CLKS] and S[CLKST] will<br/>be configured to 2'b10 if entering from PEE mode or to 2'b01 if entering from PEI<br/>mode and S[LOCK] bit will clear without setting S[LOLS]. If C5[PLLSTEN]=1, the<br/>S[LOCK] bit will not get cleared and on exit the MCG will continue to run in PEE<br/>mode.</li> </ul> | 1. If entering VLPR mode, MCG has to be configured and enter BLPE mode or BLPI mode with the Fast IRC clock selected (C2[IRCS]=1). After it enters VLPR mode, writes to any of the MCG control registers that can cause an MCG clock mode switch to a non low power clock mode must be avoided. #### NOTE For the chip-specific modes of operation, see the power management chapter of this MCU. ### 29.4.1.2 MCG mode switching C1[IREFS] can be changed at any time, but the actual switch to the newly selected reference clocks is shown by S[IREFST]. When switching between engaged internal and engaged external modes, the FLL will begin locking again after the switch is completed. C1[CLKS] can also be changed at any time, but the actual switch to the newly selected clock is shown by S[CLKST]. If the newly selected clock is not available, the previous clock will remain selected. #### runctional description The C4[DRST\_DRS] write bits can be changed at any time except when C2[LP] bit is 1. If C4[DRST\_DRS] write bits are changed while in FLL engaged internal (FEI) or FLL engaged external (FEE), the MCGOUTCLK 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. ## 29.4.2 Low-power bit usage C2[LP] is provided to allow the FLL or PLL to be disabled and thus conserve power when these systems are not being used. C4[DRST\_DRS] can not be written while C2[LP] 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 0 to C2[LP]. #### 29.4.3 MCG Internal Reference Clocks This module supports two internal reference clocks with nominal frequencies of 32 kHz (slow IRC) and 4 MHz (fast IRC). The fast IRC frequency can be divided down by programming of the FCRDIV to produce a frequency range of 32 kHz to 4 MHz. #### 29.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 (4 MHz IRC which can be divided down by the FRDIV factors) 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 C4[FCTRIM] 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 MCGOUTCLK frequency if the MCG is in FBI or BLPI modes. C3[SCTRIM]:C4[SCFTRIM] (if C2[IRCS]=0) bits also affect the MCGOUTCLK 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. #### 29.4.4 External Reference Clock The MCG module can support an external reference clock in all modes. See 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 any of the CME bits are asserted the slow internal reference clock is enabled along with the enabled external clock monitor. For the case when C6[CME0]=1, a loss of clock is detected if the OSC0 external reference falls below a minimum frequency ( $f_{loc\_high}$ or $f_{loc\_low}$ depending on C2[RANGE0]). #### **NOTE** All clock monitors must be disabled before entering these low-power modes: Stop, VLPS, VLPR, VLPW, and VLLSx. On detecting a loss-of-clock event, the MCU generates a system reset if the respective LOCRE bit is set. Otherwise the MCG sets the respective LOCS bit and the MCG generates a LOCS interrupt request. # 29.4.5 MCG Fixed Frequency Clock The MCG Fixed Frequency Clock (MCGFFCLK) provides a fixed frequency clock source for other on-chip peripherals; see the block diagram. 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]. This clock is synchronized to the peripheral bus clock and is valid only when its frequency is not more than 1/8 of the MCGOUTCLK frequency. When it is not valid, it is disabled and held high. The MCGFFCLK is not available when the MCG is in BLPI mode. This clock is also disabled in Stop mode. The FLL reference clock must be set within the valid frequency range for the MCGFFCLK. **runctional description** #### 29.4.6 MCG PLL clock The MCG PLL available depending on the device's configuration of the MCG module. For more details, see the clock distribution chapter of this MCU. The MCGPLLCLK is prevented from coming out of the MCG until it is enabled and S[LOCK0] is set. # 29.4.7 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, The 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 an abort occurs. The MCG ATM is aborted if a write to any of the following control registers is detected: C1, C3, C4, or ATC or if Stop mode is entered. If an abort occurs, ATC[ATMF] fail flag is 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. Before the ATM can be enabled, the ATM expected count needs to be derived and stored into the ATCV register. The ATCV expected count is derived based on the required target Internal Reference Clock (IRC) frequency, and the frequency of the external reference clock using the following formula: 547 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 formula. Expected Count Value = (Fe/Fr) \*21\*(128) # 29.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. # 29.5.1 MCG module initialization sequence The MCG comes out of reset configured for BLPI with Fast IRC selected mode. The internal reference will stabilize in t<sub>irefsts</sub> microseconds. # 29.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 29-15). 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 C1[IREFS] bit to switch to the external reference, and leave C1[CLKS] at 2'b00 so that the output of the FLL is selected as the system clock source. KM Family Reference Manual, Rev. 5, Oct 2013 #### mualization / Application information - If entering FBE, clear C1[IREFS] to switch to the external reference and change C1[CLKS] 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 C1[IRCLKEN]. 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[EREFS0] was also set in step 1, wait here for S[OSCINIT0] 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 S[IREFST] is cleared before moving on. - If in FBE mode, check to make sure S[IREFST] 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. - 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] to 1 for a IRCS clock derived from the 4 MHz IRC source. ### 29.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. #### **ınınalization / Application information** 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. # 29.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[EREFS0]), 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]) is set properly for the mode being switched to. For instance, . 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 MCGOUTCLK frequency calculations using C1[FRDIV] for each clock mode. **Clock Mode** f<sub>MCGOUTCLK</sub>1 Note FEI (FLL engaged internal) (fint \* F) Typical f<sub>MCGOUTCLK</sub> = 21 MHz immediately after reset. f<sub>ext</sub> / FLL\_R must be in the range of FEE (FLL engaged external) (f<sub>ext</sub> / FLL\_R) \*F 31.25 kHz to 39.0625 kHz **OSCCLK** OSCCLK / FLL\_R must be in the FBE (FLL bypassed external) range of 31.25 kHz to 39.0625 kHz FBI (FLL bypassed internal) **MCGIRCLK** Selectable between slow and fast **IRC** OSCCLK / PLL R must be in the PEE (PLL engaged external) (OSCCLK / PLL\_R) \* M range of Table 29-16. MCGOUTCLK Frequency Calculation Options Table continues on the next page... 551 # Table 29-16. MCGOUTCLK Frequency Calculation Options (continued) | Clock Mode | f <sub>MCGOUTCLK</sub> 1 | Note | |------------------------------------|--------------------------|--------------------------------------------------------| | PBE (PLL bypassed external) | OSCCLK | OSCCLK / PLL_R must be in the range of | | PEI (PLL engaged internal) | (MCGIRCLK) * 375 | MCGIRCLK must be in the range of 32.125 to 39.0625 KHz | | PBI (PLL bypassed internal) | MCGIRCLK | MCGIRCLK must be in the range of 32.125 to 39.0625 KHz | | BLPI (Bypassed low power internal) | MCGIRCLK | Selectable between slow and fast IRC | | BLPE (Bypassed low power external) | OSCCLK | | FLL\_R is the reference divider selected by the C1[FRDIV] bits, PLL\_R is the reference divider selected by C5[PRDIV0] bits, F is the FLL factor selected by C4[DRST\_DRS] and C4[DMX32] bits, and M is the multiplier selected by C6[VDIV0] bits. This section will include three mode switching examples using an MHz external crystal. If using an external clock source less than MHz, the MCG must not be configured for any of the PLL modes (PEE and PBE). # 29.5.3.1 Example 1: Moving from BLPI to PEE mode with OSC0 as the source for the external crystal clock: External Crystal = 32 KHz, MCGOUTCLK frequency = 12 MHz In this example, the MCG will move through the proper operational modes from BLPI to PEE to achieve 12 MHz MCGOUTCLK frequency from 32 KHz external crystal reference. First, the code sequence will be described. Then there is a flowchart that illustrates the sequence. - 1. First, BLPI must transition to FBI mode: - a. C2 = 0x81 - C2[LP] set to 0. - 2. Then, FBI must transition directly to FBE mode: - a. C1 = 0x80 - C1[CLKS] set to 2'b10. #### mualization / Application information - C1[IREFS] set to 1'b0 to select the output of the OSCSEL mux as the external reference clock. In this example because OSCSEL is set to 1'b0, the OSC0 will be the selected as the reference clock. - FBE: Loop until S[CLKST] are set to 2'b10 and S[IREFST] is set to 1'b0. - 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 = 0x44 - C6[PLLS] set to 1, selects the PLL. In BLPE mode, changing the C6[PLLS] bit only prepares the MCG for PLL usage in PBE mode. - C6[CHGPMP\_BIAS] set to 5'b0\_0100. Appropriate selection of this value is imperative to ensure stable operation of the PLL closed loop system. It is recommended to keep the reset value and not change them. - c. BLPE: If transitioning through BLPE mode, clear C2[LP] to 0 here to switch to PBE mode. - 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 MCG\_C9[COARSE\_LOCK] is set, indicating that the PLL has aquired a coarse lock status or loop until S[LOCK] is set, indicating that the PLL has acquired lock for three samples. - 4. Lastly, PBE mode transitions into PEE mode: - a. C1 = 0x00 - C1[CLKS] set to 2'b00 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 MCGOUTCLK in the current clock mode. - Now MCGOUTCLK = [(32 kHz) \* 375] = 12 MHz. Figure 29-16. Flowchart of BLPI to PEE mode transition using an 32 KHz crystal KM Family Reference Manual, Rev. 5, Oct 2013 Freescale Semiconductor, Inc. Preliminary 553 # 29.5.3.2 Example 2: Moving from PEE to BLPI mode: MCGOUTCLK frequency =32 kHz In this example, the MCG will move through the proper operational modes from PEE mode with a MHz crystal configured for a MHz MCGOUTCLK frequency (see previous example) to BLPI mode with a 32 kHz MCGOUTCLK frequency. First, the code sequence will be described. Then there is a flowchart that illustrates the sequence. - 1. First, PEE must transition to PBE mode: - a. C1 = - C1[CLKS] set to 2'b10 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 MCGOUTCLK. - 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 - C6[PLLS] clear to 0 to select the FLL. At this time, with C1[FRDIV] value of 3'b, the FLL divider is set to, resulting in a reference frequency of = 31.25 kHz. If C1[FRDIV] was not previously set to (necessary to achieve required 31.25–39.06 kHz FLL reference frequency with an 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. - 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 = - C1[CLKS] set to 2'b01 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 MCGOUTCLK. - 4. Lastly, FBI transitions into BLPI mode. - a. C2 = - 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. Figure 29-17. Flowchart of PEE to BLPI mode transition using an MHz crystal mualization / Application information # **Chapter 30 Oscillator (OSC)** #### 30.1 Introduction #### **NOTE** For the chip-specific implementation details of this module's instances, see the chip configuration information. The OSC module is a crystal oscillator. The module, in conjunction with an external crystal or resonator, generates a reference clock for the MCU. #### 30.2 Features and Modes Key features of the module are listed here. - Supports 32 kHz crystals (Low Range mode) - Supports 1–8 MHz, crystals and resonators (High Range mode) - Automatic Gain Control (AGC) to optimize power consumption in high frequency ranges 1–8 MHz, using low-power mode - High gain option in frequency ranges: 32 kHz, 1–8 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. KM Family Reference Manual, Rev. 5, Oct 2013 # 30.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 figure found here shows the block diagram of the OSC module. Figure 30-1. OSC Module Block Diagram # 30.4 OSC Signal Descriptions The table found here shows the user-accessible signals available for the OSC module. Refer to signal multiplexing information for this MCU for more details. Table 30-1. OSC Signal Descriptions | Signal | Description | I/O | |--------|---------------------------------|-----| | EXTAL | External clock/Oscillator input | I | | XTAL | Oscillator output | 0 | # 30.5 External Crystal / Resonator Connections The connections for a crystal/resonator frequency reference are shown in the figures found here. 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 30-2. External Caystal/Resonator Connections | Oscillator Mode | Connections | |--------------------------------------|-----------------------------------------------------------------------| | Low-frequency (32 kHz), low-power | Connection 1 <sup>1</sup> | | Low-frequency (32 kHz), high-gain | Connection 2/Connection 4 <sup>2</sup> /<br>Connection 3 <sup>3</sup> | | High-frequency (1~32 MHz), low-power | Connection 3 <sup>1</sup> | | High-frequency (1~32 MHz), high-gain | Connection 3/Connection 4 <sup>2</sup> | - 1. 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. - 2. When the frequency of the crystal is less than 2 MHz and the load capacitors (Cx, Cy) are less than 16 pF, use Connection 4. - 3. When the load capacitors (Cx, Cy) are greater than 30 pF, use Connection 3. Figure 30-2. Crystal/Ceramic Resonator Connections - Connection 1 KM Family Reference Manual, Rev. 5, Oct 2013 Figure 30-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 30-4. Crystal/Ceramic Resonator Connections - Connection 3 Figure 30-5. Crystal/Ceramic Resonator Connections - Connection 4 #### 30.6 External Clock Connections In external clock mode, the pins can be connected as shown in the figure found here. #### NOTE XTAL can be used as a GPIO when the GPIO alternate function is configured for it. Figure 30-6. External Clock Connections # 30.7 Memory Map/Register Definitions Some oscillator module register bits are typically incorporated into other peripherals such as MCG or SIM. KM Family Reference Manual, Rev. 5, Oct 2013 # 30.7.1 OSC Memory Map/Register Definition #### **OSC** memory map | Absolute address (hex) | Register name | Width<br>(in bits) | Access | Reset value | Section/<br>page | |------------------------|-------------------------------|--------------------|--------|-------------|------------------| | 4006_6000 | OSC Control Register (OSC_CR) | 8 | R/W | 00h | 30.71.1/<br>562 | # 30.71.1 OSC Control Register (OSC\_CR) #### NOTE After OSC is enabled and starts generating the clocks, the configurations such as low power and frequency range, must not be changed. Address: 4006\_6000h base + 0h offset = 4006\_6000h #### OSC\_CR field descriptions | Field | Description | |-----------|------------------------------------------------------------------------------------------------------------| | 7 | External Reference Enable | | ERCLKEN | Enables external reference clock (OSCERCLK). | | | 0 External reference clock is inactive. | | | 1 External reference clock is enabled. | | 6 | This field is reserved. | | Reserved | This read-only field is reserved and always has the value 0. | | 5 | External Reference Stop Enable | | EREFSTEN | 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 | This field is reserved. | | Reserved | This read-only field is reserved and always has the value 0. | | 3<br>SC2P | Oscillator 2 pF Capacitor Load Configure | Table continues on the next page... #### **OSC\_CR** field descriptions (continued) | Field | Description | |------------|-----------------------------------------------| | | Configures the oscillator load. | | | 0 Disable the selection. | | | 1 Add 2 pF capacitor to the oscillator load. | | 2 | Oscillator 4 pF Capacitor Load Configure | | SC4P | Configures the oscillator load. | | | 0 Disable the selection. | | | 1 Add 4 pF capacitor to the oscillator load. | | 1 | Oscillator 8 pF Capacitor Load Configure | | SC8P | 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 | | 33131 | Configures the oscillator load. | | | 0 Disable the selection. | | | 1 Add 16 pF capacitor to the oscillator load. | # 30.8 Functional Description Functional details of the module can be found here. # 30.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. #### **runctional Description** Figure 30-8. OSC Module state diagram #### NOTE XTL\_CLK is the clock generated internally from OSC circuits. #### 30.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. #### 30.8.1.2 Oscillator startup The OSC enters startup 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. #### 30.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. #### 30.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, see 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. #### 30.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 30-5. 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). Table 30-5. Oscillator modes | Mode | Frequency Range | | |--------------------------|----------------------------------------------------------------|--| | Low-frequency, high-gain | $f_{\rm osc\_lo}$ (1 kHz) up to $f_{\rm osc\_lo}$ (32.768 kHz) | | Table continues on the next page... #### **runctional Description** #### Table 30-5. Oscillator modes (continued) | Mode | Frequency Range | | |---------------------------------|--------------------------------------------------------------------|--| | High-frequency mode1, high-gain | f (1 MHz) up to f (0 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 (9 MHz) up to f (22 MHz) | | | High-frequency mode2, low-power | f <sub>osc_hi_2</sub> (8 MHz) up to f <sub>osc_hi_2</sub> (32 MHz) | | #### **NOTE** For information about low power modes of operation used in this chip and their alignment with some OSC modes, see the chip's Power Management details. ### 30.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. ### 30.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. ### 30.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. ### 30.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, 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. #### **30.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 timeout is used to guarantee output clock stability. ## 30.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. #### **30.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. # 30.10 Low power modes operation When the MCU enters Stop modes, the OSC is functional depending on CR[ERCLKEN] and CR[EREFSETN] bit settings. If both these bits are set, the OSC is in operation. After waking up from Very Low Leakage Stop (VLLSx) modes, all OSC register bits are reset and initialization is required through software. # 30.11 Interrupts The OSC module does not generate any interrupts. # Chapter 31 RTC Oscillator (OSC32K) #### 31.1 Introduction #### **NOTE** For the chip-specific implementation details of this module's instances, see the chip configuration information. The RTC oscillator module provides the clock source for the RTC. The RTC oscillator module, in conjunction with an external crystal, generates a reference clock for the RTC. #### 31.1.1 Features and Modes The key features of the RTC oscillator are as follows: - Supports 32 kHz crystals with very low power - Consists of internal feed back resistor - $\bullet$ Consists of internal programmable capacitors as the $C_{\text{load}}$ of the oscillator - Automatic Gain Control (AGC) to optimize power consumption The RTC oscillator operations are described in detail in Functional Description. # 31.1.2 Block Diagram The following is the block diagram of the RTC oscillator. KM Family Reference Manual, Rev. 5, Oct 2013 569 Figure 31-1. RTC Oscillator Block Diagram # 31.2 RTC Signal Descriptions The following table shows the user-accessible signals available for the RTC oscillator. See the chip-level specification to find out which signals are actually connected to the external pins. Table 31-1. RTC Signal Descriptions | Signal | Description | I/O | |---------|-------------------|-----| | EXTAL32 | Oscillator Input | I | | XTAL32 | Oscillator Output | 0 | # 31.2.1 EXTAL32 — Oscillator Input This signal is the analog input of the RTC oscillator. # 31.2.2 XTAL32 — Oscillator Output This signal is the analog output of the RTC oscillator module. # 31.3 External Crystal Connections The connections with a crystal is shown in the following figure. External load capacitors and feedback resistor are not required. Figure 31-2. Crystal Connections # 31.4 Functional Description As shown in Figure 31-1, the module includes an amplifier which supplies the negative resistor for the RTC oscillator. The gain of the amplifier is controlled by the amplitude detector, which optimizes the power consumption. A schmitt trigger is used to translate the sine-wave generated by this oscillator to a pulse clock out, which is a reference clock for the RTC digital core. The oscillator includes an internal feedback resistor of approximately 100 M $\Omega$ between EXTAL32 and XTAL32. In addition, there are two programmable capacitors with this oscillator, which can be used as the Cload of the oscillator. The programmable range is from 0pF to 30pF. ## 31.5 Reset Overview There is no reset state associated with the RTC oscillator. # 31.6 Interrupts The RTC oscillator does not generate any interrupts. KM Family Reference Manual, Rev. 5, Oct 2013 ınterrupts # **Chapter 32 Independent Real Time Clock (iRTC)** #### 32.1 Introduction #### **NOTE** For the chip-specific implementation details of this module's instances, see the chip configuration information. This block is a low power module that provides time keeping and calendaring functions and additionally provides protection against tampering (external or internal tamper events), protection against spurious memory/register updates and battery operation. A Standby RAM is provided if the CPU wants to store any data that has to be retained when in battery operation mode. #### 32.1.1 Features This block supports the following features: - Designed for low power - Time and Date counters are rippled with respect to each other to prevent simultaneous toggling - Basic Clock functions - Separate counters for Days, Hour, Minutes and Seconds - Calendaring support Separate counters for Months, Year and Day of the Week - Automatic adjustment for Day Light Saving with user defined parameters - Automatic month and leap year adjustment - External clock support to run the counters in the case user wishes to provide externally compensated 1Hz clock. KM Family Reference Manual, Rev. 5, Oct 2013 573 #### muroduction - RTC utilizes 'local time' which implicitly contains the time zone offset - Programmable alarm with interrupt. Alarm is output from RTC in case MCU wants to use it as a wake up event - 8 periodic interrupts (Sampling Timer Interrupts) - Hardware Compensation to compensate 1 Hz clock (to the counters) against frequency variations in oscillator clock due to temperature or crystal characteristics. Correction factor calculated by firmware. (Programmable correction factor). - 16-bit CPU register programming interface with protection against run-away code - Reset to the RTC block is generated when battery supply is removed and powered up later. - Battery operation (Standby Mode) ensures seamless RTC operation when CPU power is removed - Option to output the buffered 32.768 kHz clock or the compensated 1 Hz clock. - 32 Bytes of Battery Backed Up RAM - Enhanced Tamper Detection - Tamper Detection to detect illegal access into the system. - Tampers can be defined as both active and passive. Active tampers have a random pattern generator module which sends and receives this sequence to check for any intrusion. - Tamper sources can be individually enabled/disabled and polarity can be controlled - External tamper sources are filtered for noise & glitches by the RTC. Internal tamper events are not filtered. - A tamper queue of depth "4" is implemented in the design to store the tamper type and time stamp (excluding the year value) of the tampers. - Configurable width of noise or glitch pulses that can be filtered out - Minimum 488 µs to 2 s depending on the tamper filter clock that is chosen. # 32.1.2 Modes of Operation This section describes the RTC modes of operation. 575 #### 32.1.2.1 Wait Mode In Wait mode, the RTC is fully operational. Since the RTC runs off a 32.768 kHz clock, which is not gated in Wait mode; RTC 's time keeping functions and other functions that depend on the 32.768 kHz clock, continue to operate independent of CPU. Only the register block's clock is gated. No register contents are lost. #### 32.1.2.2 Stop Mode In Stop mode, the RTC is fully operational and behaves in the same way as in Wait mode. #### 32.1.2.3 VBAT mode In the VBAT mode, the RTC is fully operational. This is because the RTC runs off a 32.768 kHz clock, which is not gated in VBAT mode. The RTC 's time keeping functions and other functions that depend on the 32.768 kHz clock continue to operate independent of the CPU. Only the register block's clock is gated. No register contents are lost. After coming out of VBAT mode, the register content is not accessible for two osc\_clk cycles due to synchronization. # 32.1.3 Design Overview The RTC block provides basic time keeping functions through seconds, minutes, hours counters, and calendaring functions via date, day-of-week, month and year counters; along with automatic adjustments for leap year and day light saving. Reading these counters indicates the current date and time and writing to these registers sets the date and time as provided by the user. The alarm is set for specific hour, minute and second. When the time counters match the configured alarm hour, minute and second settings, the alarm is set and an interrupt to CPU is generated, if the alarm interrupt is enabled. The alarm can additionally be configured to match days, months and year to generate the alarm interrupt. The alarm signal has been brought out on an MCU pin to allow wake up or control of external devices on board. RTC module also provides 8 sampling timer interrupts. #### Signal Description The registers in the RTC module are configured via the CPU register programming interface. A protection mechanism is built in to the RTC to protect its registers against spurious writes by any run-away code. The protection mechanism requires the CPU to write a specific sequence of codes to the STATUS[7:6] bits to allows write access to the registers. On completing the update of registers the CPU should write "10" to STATUS[7:6] bits to enable the write protection. After unlocking the registers, the CPU has a window of 2 seconds for updating the register space. On power on reset a window of 15 seconds is allowed for the CPU to configure the RTC after which the registers are locked. Any updates beyond the unlock window would require the CPU to unlock the registers, again. The RTC battery supply maintains normal RTC functionality when the MCU power (VDD) is removed. The battery supply allows RTC to keep functioning in case CPU is completely turned off. Reset to the RTC block is generated only when the battery supply is removed and powered up again. RTC can detect intrusion via its tamper detection and logging mechanism. RTC supports 4 tamper events all individually configurable and any change of state will indicate a tamper that will get stored in the RTC tamper status and control register. Removal of battery after power up is also considered as a tamper event. The tampers can be declared as Active/Passive. The active tampers have a random signal generator logic which sends a random sequence out from RTC through the tamper pad configured as outputs for the active tamper and expects the same sequence through its tamper pins configured as inputs for active tamper. Any mismatch between the output and input is logged as a tamper. The external tamper inputs pass through a low pass filter (digital) to prevent accidental assertion by noise or glitch pulses. The duration of pulses to be filtered out is configurable. Any tamper detected will cause an interrupt to the CPU. RTC has a FIFO based queue structure implemented in the design to support the logging of up to 4 tamper time stamp entries. Tamper detection logic and its interrupt are enabled on reset. Once a tamper is detected and event stored, a new event for the same tamper will not be stored until the CPU acknowledges the tamper status. For detailed description on the complete functionality of RTC, refer to Functional Description. # 32.2 Signal Description This section lists all pad inputs to the RTC block. # 32.2.1 EXTAL32K, XTAL32K These pins serve as the connection pins to the external 32.768 kHz crystal. # 32.2.2 TAMPER[2:0] This device contains three external tamper pins. Each pin can act as an input or output depending upon whether active or passive tamper is enabled. ## 32.2.3 VBAT The external battery or standby supply is provided via this pin. # 32.3 Memory Map and Registers 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. #### NOTE Initially, a 32 kHz clock is needed to initialize the RTC. This clock can later be gated while programming the RTC registers. ### **NOTE** The use of the fields of the General Purpose Data Register (RTC\_GP\_DATA\_REG) is specific to the MCU. See the Chip Configuration chapter for a description of this register. Software reset has no effect on the contents of this register. ## RTC memory map | Absolute<br>address<br>(hex) | Register name | Width<br>(in bits) | Access | Reset value | Section/<br>page | |------------------------------|-------------------------------------------------------|--------------------|--------|-------------|------------------| | 4005_0000 | RTC Year and Month Counters Register (RTC_YEARMON) | 16 | R/W | 0001h | 32.3.1/579 | | 4005_0002 | RTC Days and Day-of-Week Counters Register (RTC_DAYS) | 16 | R/W | 0001h | 32.3.2/580 | | 4005_0004 | RTC Hours and Minutes Counters Register (RTC_HOURMIN) | 16 | R/W | 0000h | 32.3.3/581 | | 4005_0006 | RTC Seconds Counters Register (RTC_SECONDS) | 16 | R/W | 0000h | 32.3.4/582 | # RTC memory map (continued) | Absolute address (hex) | Register name | Width<br>(in bits) | Access | Reset value | Section/<br>page | |------------------------|----------------------------------------------------------------|--------------------|--------|-------------|------------------| | 4005_0008 | RTC Year and Months Alarm Register (RTC_ALM_YEARMON) | 16 | R/W | 0000h | 32.3.5/582 | | 4005_000A | RTC Days Alarm Register (RTC_ALM_DAYS) | 16 | R/W | 0000h | 32.3.6/583 | | 4005_000C | RTC Hours and Minutes Alarm Register (RTC_ALM_HOURMIN) | 16 | R/W | 0000h | 32.3.7/583 | | 4005_000E | RTC Seconds Alarm Register (RTC_ALM_SECONDS) | 16 | R/W | 0000h | 32.3.8/584 | | 4005_0010 | RTC Control Register (RTC_CTRL) | 16 | R/W | See section | 32.3.9/585 | | 4005_0012 | RTC Status Register (RTC_STATUS) | 16 | R/W | 0008h | 32.3.10/<br>587 | | 4005_0014 | RTC Interrupt Status Register (RTC_ISR) | 16 | w1c | 0001h | 32.3.11/<br>589 | | 4005_0016 | RTC Interrupt Enable Register (RTC_IER) | 16 | R/W | 0001h | 32.3.12/<br>592 | | 4005_0020 | RTC General Purpose Data Register (RTC_GP_DATA_REG) | 16 | R/W | 0000h | 32.3.13/<br>594 | | 4005_0022 | RTC Daylight Saving Hour Register (RTC_DST_HOUR) | 16 | R/W | 0000h | 32.3.14/<br>595 | | 4005_0024 | RTC Daylight Saving Month Register (RTC_DST_MONTH) | 16 | R/W | 0000h | 32.3.15/<br>596 | | 4005_0026 | RTC Daylight Saving Day Register (RTC_DST_DAY) | 16 | R/W | 0000h | 32.3.16/<br>597 | | 4005_0028 | RTC Compensation Register (RTC_COMPEN) | 16 | R/W | 0000h | 32.3.17/<br>597 | | 4005_002C | Tamper Direction Register (RTC_TAMPER_DIRECTION) | 16 | R/W | See section | 32.3.18/<br>598 | | 4005_002E | Tamper Queue Status and Control Register (RTC_TAMPER_QSCR) | 16 | R/W | See section | 32.3.19/<br>599 | | 4005_0032 | RTC Tamper Status and Control Register (RTC_TAMPER_SCR) | 16 | R/W | See section | 32.3.20/<br>600 | | 4005_0034 | RTC Tamper 01 Filter Configuration Register (RTC_FILTER01_CFG) | 16 | R/W | 0000h | 32.3.21/<br>601 | | 4005_0036 | RTC Tamper 2 Filter Configuration Register (RTC_FILTER2_CFG) | 16 | R/W | 0000h | 32.3.22/<br>602 | | 4005_0040 | Tamper Queue Register (RTC_TAMPER_QUEUE) | 16 | R | 0000h | 32.3.23/<br>603 | | 4005_0042 | RTC Control 2 Register (RTC_CTRL2) | 16 | R/W | See section | 32.3.24/<br>604 | # 32.3.1 RTC Year and Month Counters Register (RTC\_YEARMON) This register stores the value of the month and year counters. The year field does not store the actual year value but the offset in years from a hardcoded BASE YEAR taken as the year 2112. This is a signed value and the ranges from –128 to +127. The software should program the offset from that base year into this register. For example, if the current year is 2007, then this will be represented in this register as –105 or 0x97. The actual year value can be found by adding the BASE YEAR and the offset in the YEARMON[15:8] register. Hence the range of year supported will be 1984 (2112 – 128) to 2239 (2112 + 127). Hence for year calculation: Actual Year = Base Year (for example, 2112) + Offset Year The month register stores the count value of the months register. Writing to this register loads the months counter with this new value. The valid values are mentioned in table below. Both month and year are unaffected on software reset. User software should first determine the state of the INVAL bit in the STATUS (bit 0) to determine that the counters are stable before their value can be read or changed. The assertion of INVAL bit ensures that no operation is done at the boundary of a second when counters change value. ## RTC\_YEARMON field descriptions | Field | Description | |----------------|------------------------------------------------------------------------------------------------------------------------------------------------| | 15–8<br>YROFST | Year Offset Count Value | | 1110101 | These bits indicate the offset in years from the base year (hard coded as 2112) and do not show the actual year value. This is a signed value. | | | Valid values are -128 to 127. | | | With the Base Year as 2112 and if the value of YEAR field is 0x10, the actual year will be 2112 + 16 = 2128. | | 7–4 | This field is reserved. | | Reserved | This read-only field is reserved and always has the value 0. | | 3–0 | These bits give the value of the Months Counter . | | MON_CNT | Valid Values are: | ## RTC\_YEARMON field descriptions (continued) | Field | Description | |-------|-----------------| | 0 | Illegal Value | | 1 | January | | 2 | February | | 3 | March | | 4 | April | | 5 | May | | 6 | June | | 7 | July | | 8 | August | | 9 | September | | 10 | October October | | 11 | November | | 12 | 2 December | | 13 | B Illegal Value | | 14 | Illegal Value | | 15 | i Illegal Value | # 32.3.2 RTC Days and Day-of-Week Counters Register (RTC\_DAYS) This read/write register shows the current value of the day-of-week counter and days counter. Reading this register returns the latest value of the counter s. Writing to this register loads the value to the day-of-week and days counters and the counters continue to count from this new value. The day-of-week is not calculated automatically and should be written by CPU. This register is unaffected by software reset. User software should first determine the state of the INVAL bit in the STATUS (bit 0) to determine that the counters are stable before their value can be read or changed. The assertion of INVAL bit ensures that no operation is done at the boundary of a second when counters change value. Address: 4005\_0000h base + 2h offset = 4005\_0002h ## RTC\_DAYS field descriptions | Field | Description | |-------------------|--------------------------------------------------------------------------------------| | 15–11<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 10–8<br>DOW | Day of Week Counter Value. | ## RTC\_DAYS field descriptions (continued) | Field | Description | |----------|--------------------------------------------------------------| | | 0 Sunday | | | 1 Monday | | | 2 Tuesday | | | 3 Wednesday | | | 4 Thrusday | | | 5 Friday | | | 6 Saturday | | | 7 Reserved | | 7–5 | This field is reserved. | | Reserved | This read-only field is reserved and always has the value 0. | | 4–0 | Days Counter Value. | | DAY_CNT | Valid values are '1' to '31'. | # 32.3.3 RTC Hours and Minutes Counters Register (RTC\_HOURMIN) This register is used to program the hours and minutes counter. It can be read anytime to get the current value of the counters. Only power-on reset can reset this register. Hours counter can be set anything between 0 and 23. Minutes counter can be set anything between 0 and 59. This register is unaffected by software reset. User software should first determine the state of the INVAL bit in the STATUS (bit 0) to determine that the counters are stable before their value can be read or changed. The assertion of INVAL bit ensures that no operation is done at the boundary of a second when counters change value. Address: 4005\_0000h base + 4h offset = 4005\_0004h ## RTC\_HOURMIN field descriptions | Field | Description | |-------------------|--------------------------------------------------------------------------------------| | 15–13<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 12-8<br>HOUR_CNT | Hours Counter Value. Valid count values are 0 to 23. | | 7–6<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 5–0<br>MIN_CNT | Minutes Counter Value. Valid count values are 0 to 59. | # 32.3.4 RTC Seconds Counters Register (RTC\_SECONDS) This register is used to program the seconds counter. It can be read anytime to get the current value of the counter. Only power-on reset can reset this register. Seconds counter can be set anything between 0 and 59 both included. This register is unaffected by software reset. User software should first determine the state of the INVAL bit in the STATUS (bit 0) to determine that the counters are stable before their value can be read or changed. The assertion of INVAL bit ensures that no operation is done at the boundary of a second when counters change value. ## RTC\_SECONDS field descriptions | Field | Description | |------------------|--------------------------------------------------------------------------------------| | 15–8<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 7–6<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 5–0<br>SEC_CNT | Seconds Counter Value. Valid count values are 0 to 59. | # 32.3.5 RTC Year and Months Alarm Register (RTC\_ALM\_YEARMON) This register is used to configure the months and year setting of the alarm. The alarm setting can be read or written anytime. This register is reset to its default state on software reset. Alarm interrupt bit is set when all values of alarm seconds, minutes, hours, days, month, and year match their respective counter values. User software can configure the type of alarm using the ALM\_TYPE bits in the CTRL register. Address: 4005\_0000h base + 8h offset = 4005\_0008h 583 ## RTC\_ALM\_YEARMON field descriptions | Field | Description | |----------|--------------------------------------------------------------------------------------| | 15–8 | Year Value for Alarm. | | ALM_YEAR | Same as Years Offset Value in RTC Year and Month Counters Register (RTC_YEARMON) . | | 7–4 | This field is reserved. | | Reserved | This read-only field is reserved and always has the value 0. | | 3–0 | Months Value for Alarm. | | ALM_MON | Same as Months Counter Value in RTC Year and Month Counters Register (RTC_YEARMON) . | # 32.3.6 RTC Days Alarm Register (RTC\_ALM\_DAYS) The days alarm register is used to configure the day setting of the alarm. The alarm setting can be read or written anytime. This register is reset to its default state on software reset. Alarm interrupt bit is set when all values of alarm seconds, minutes, hours, days, month and year match their respective counter values. User software can configure the type of alarm using the ALM\_TYPE bits in the CTRL register. Address: 4005\_0000h base + Ah offset = 4005\_000Ah ## RTC\_ALM\_DAYS field descriptions | Field | Description | |------------------|--------------------------------------------------------------------------------------------------------------| | 15–8<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 7–5<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 4–0<br>ALM_DAY | Days Value for Alarm. Same as Days Counter Value in RTC Days and Day-of-Week Counters Register (RTC_DAYS) . | # 32.3.7 RTC Hours and Minutes Alarm Register (RTC\_ALM\_HOURMIN) The hours and minutes alarm register is used to configure the hour and minute setting of the alarm. The alarm setting can be read or written anytime. This register is reset to default state on software reset. User software can configure the type of alarm using the ALM\_TYPE bits in the CTRL register. Address: 4005\_0000h base + Ch offset = 4005\_000Ch ### RTC\_ALM\_HOURMIN field descriptions | Field | Description | |-------------------|--------------------------------------------------------------------------------------------------------------------| | 15–13<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 12–8<br>ALM_HOUR | Hours Value for Alarm. Same as Hours Counter Value in RTC Hours and Minutes Counters Register (RTC_HOURMIN). | | 7–6<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 5–0<br>ALM_MIN | Minutes Value for Alarm. Same as Minutes Counter Value in RTC Hours and Minutes Counters Register (RTC_HOURMIN) . | # 32.3.8 RTC Seconds Alarm Register (RTC\_ALM\_SECONDS) The seconds alarm register is used to configure the seconds setting of the alarm. The alarm setting can be read or written anytime. This register is reset to default value on software reset. Bits 9:8 provide option to the user software to perform correction on seconds counter to compensate for the leap seconds. Write to these bits adds or subtracts 1 from the seconds counter and read returns zeros. User software should first determine the state of the INVAL bit in the STATUS (bit 0) to determine that the counters are stable before they can be incremented or decremented. The assertion of INVAL bit ensures that no operation is done at the boundary of a second when counters change value. User software can configure the type of alarm using the ALM\_TYPE bits in the CTRL register. Address: 4005\_0000h base + Eh offset = 4005\_000Eh KM Family Reference Manual, Rev. 5, Oct 2013 584 **Preliminary** Freescale Semiconductor, Inc. ## RTC\_ALM\_SECONDS field descriptions | Field | Description | |-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15–10<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 9<br>INC_SEC | Increment Seconds Counter by 1. This bit controls the increment of seconds counter incase the software wants to make corrections to the seconds counter to compensate for the leap seconds or to perform fine trimming of time when needed. Write to this bit increments the seconds counter and then the bit gets cleared on next posedge. | | 8<br>DEC_SEC | Decrement Seconds Counter by 1. This bit controls the decrement of seconds counter incase the software wants to make corrections to the seconds counter to compensate for the leap seconds or to perform fine trimming of time when needed. Write to this bit has decrements the seconds counter and then the bit gets cleared on next posedge of bus clock. | | 7–6<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 5-0<br>ALM_SEC | Seconds Value for Alarm. Same as Seconds Counter Value in RTC Seconds Counters Register (RTC_SECONDS) . | # 32.3.9 RTC Control Register (RTC\_CTRL) This is the control register and governs all operations being done inside the RTC. This register is used to specify the software reset, daylight controls, and the type of alarm function needed. Address: 4005\_0000h base + 10h offset = 4005\_0010h # RTC\_CTRL field descriptions | Field | Description | | | | | |------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | 15<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | | | | | 14–13 | RTC Clock Output Selection. | | | | | | CLKOUT | Selects which clock to output from SoC for use outside RTC. | | | | | | | 00 No Output Clock | | | | | | | Fine 1 Hz Clock | | | | | | | 10 32.768 kHz Clock | | | | | | | Coarse 1 Hz Clock | | | | | | 12–9<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | | | | | 8<br>SWR | Software Reset bit. | | | | | | SWIT | Self clearing bit. Asserting this field clears the contents of alarm, interrupt (status and enable except tamper interrupt enable bit) registers, STATUS[CMP_DONE], and STATUS[BUS_ERR] and has no effect on DST, calendaring, Standby time and tamper detect registers. | | | | | | | 0 Software Reset cleared. | | | | | | | Software Reset asserted. | | | | | | 7<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | | | | | 6<br>DST_EN | Daylight Saving Enable. | | | | | | _ | The date and time for daylight saving changes are stored in the Daylight Saving Registers. These registers can be changed when this bit is 0. Once this bit is set, those registers cannot be changed and when time and date match the values in those registers, daylight adjustment will happen. To disable Daylight Saving function, this bit should be set to 0. | | | | | | | 0 Disabled. Daylight saving changes are not applied. Daylight saving registers can be modified. | | | | | | | Enabled. Daylight saving changes are applied. | | | | | | 5<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | | | | | 4<br>TIMER_STB_ | Sampling timer clocks mask | | | | | | MASK | 1 Sampling clocks are gated in standby mode | | | | | | 0.0 | O Sampling clocks are not gated when in standby mode | | | | | | 3–2<br>ALM_MATCH | Alarm Match bits. | | | | | | | These bits define the type of alarm function. These bits select which time and calendar counters will be used for matching and generate an alarm. | | | | | | | 00 Only Seconds, Minutes, and Hours matched. | | | | | | | Only Seconds, Minutes, Hours, and Days matched. | | | | | | | Only Seconds, Minutes, Hours, Days, and Months matched. | | | | | | | Only Seconds, Minutes, Hours, Days, Months, and Year (offset) matched. | | | | | ## RTC\_CTRL field descriptions (continued) | Field | Description | |--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1<br>COMP_EN | Compensation enable bit 1'b0:- Coarse Compensation is disabled. 1'b1:- Coarse Compensation is enabled. Note:- If both the bits are meant to be set "1'b1" hardware will not let the COMP_EN bit to be written 1. | | 0<br>FINEEN | Fine compensation enable bit | | | <ul><li>1 Fine compensation is enabled.</li><li>0 Fine compensation is disabled</li></ul> | # 32.3.10 RTC Status Register (RTC\_STATUS) This register indicates the status of various processes going inside the RTC. This register also helps the user software to read time or date register when their values are stable and not changing. Bus Error bit get cleared by writing '1' to them. Software Reset resets the whole register (except the RST\_SRC bit) to its default state. All memory mapped registers are protected against spurious updates by the write protect mechanism. To unlock the registers, a specific pattern (as mentioned in above table) has to be written in the write enable bits (WE[1:0]) to enable or disable write protection.. The WE[1:0] bits are the only bits that are freely writeable by user software. The write enable bits are self clearing bits that always return zeros on read. Address: 4005\_0000h base + 12h offset = 4005\_0012h #### **RTC STATUS field descriptions** | Field | Description | |-------------------|----------------------------------------------------------------------------------------------------------------------------------| | 15–12<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | CMP DONE | Compensation Done bit. This bit indicates that current compensation cycle is complete. The bit gets cleared by writing 1 to it. | Table continues on the next page... # RTC\_STATUS field descriptions (continued) | Field | Description | | | | | |----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | | Done bit is asserted seven 32.768 kHz clock cycles before actual compensation interval completes so that back to back compensation can be enabled. | | | | | | | 0 Compensation busy or not enabled. | | | | | | | 1 Compensation completed. | | | | | | 10<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | | | | | 9<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | | | | | 8 | Bus Error bit. | | | | | | BUS_ERR | This bit indicates that a read or write cycle was initiated by software when the INVAL_BIT was set. Write access to time /date registers gets nullified (terminate normally) and no register value gets changed. Read during INVAL bit asserted returns 16'hFFFF. No Transfer Error is asserted. This bit gets cleared by writing 1 to it. | | | | | | | 0 Read and Write accesses are normal. | | | | | | | Read or Write accesses occurred when INVAL_BIT was asserted. | | | | | | 7–6 | Write Enable bits. | | | | | | WE | These bits control the entry and exit of the write protection mode. Both registers are protected by the write protection mechanism. These are self clearing bits. Reads will return zeros. | | | | | | | NOTE: When the registers are unlocked, they remain in this unlocked state for a time of 2 seconds after which they get locked automatically. After power-on-reset, the registers come out as unlocked but they get locked automatically 15 seconds after power on. | | | | | | | 00, 01, 11, 10 Disable Write Protection - Registers are unlocked. | | | | | | | 10 Enable Write Protection – Registers are locked. | | | | | | 5 | Compensation Interval bit. | | | | | | CMP_INT | This read-only status bit is asserted for a time equal to compensation interval seconds (as configured by user). This bit is used by MCU to calculate the interrupts serviced during this interval and perform corrections in case of deviations (i.e. Calibration). This bit toggles on every start of new compensation interval and is either 0 or 1 during the entire duration. This bit will not toggle if compensation logic has been disabled by MCU. | | | | | | 4<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | | | | | 3 | Reset Source bit. | | | | | | RST_SRC | This bit indicates to the user software the cause for reset to the part and subsequent boot up of CPU. | | | | | | | This bit is asserted only on the power on reset that is generated within RTC (that is Power On Reset when both VBAT and VDD are powered up) and this indicates that part has been reset. On entering standby mode, this bit is cleared which indicates the part is booting after Standby Mode Exit, when the standby mode is actually exited. | | | | | | | Part was reset due to Standby Mode Exit (that is when VDD is powered up and VBAT was not powered down at all). | | | | | | | Part was reset due to Power-On Reset (that is Power On Reset when both VBAT and VDD are powered up). | | | | | Table continues on the next page... 588 **Preliminary** Freescale Semiconductor, Inc. ## RTC\_STATUS field descriptions (continued) | Field | Description | | | | | |-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | 2 | CPU Low Voltage Warning status bit. | | | | | | CPU_LOW_<br>VOLT | This bit is asserted when the MCU/CPU power falls below the read only threshold when all write cycles are terminated normally and no change is done to the registers. Registers are read only. Transfer Error is not asserted on write access. | | | | | | | 0 CPU in Normal Operating Voltage. | | | | | | | CPU Voltage is below Normal Operating Voltage. RTC Registers in read-only mode. | | | | | | 1 | Write Protect Enable status bit. | | | | | | WRITE_PROT_<br>EN | This read-only bit indicates that registers are in locked mode and write to them is disabled. Any write access made to the register space when write protection is enabled (that is in locked mode) will cause the transfer error signal to be asserted. | | | | | | | 0 Registers are unlocked and can be accessed. | | | | | | | Registers are locked and in read-only mode. | | | | | | 0 | Invalidate CPU read/write access bit. | | | | | | INVAL_BIT | This read-only bit indicates the time /date counters are invalid or changing and thus should not be read/written to. This bit is asserted for 1 oscillator clock cycle before and after the 1 Hz (seconds clock) boundary/edge. Write access to time /date registers gets nullified (terminate normally) and no register value gets changed. Read during INVAL bit asserted returns 0xFFFF. No Transfer Error is asserted. | | | | | | | 0 Time /Date Counters can be read/written. Time /Date is valid. | | | | | | | Time /Date Counter values are changing or Time /Date is invalid and cannot be read or written. | | | | | # 32.3.11 RTC Interrupt Status Register (RTC\_ISR) NOTE For the sampling timer interrupt status bits [14:6], refer to chip configuration chapter for the applicable sampling timer frequencies. This register indicates the status of the various real-time clock interrupts. When an event of the types included in this register occurs then the bit will be set in this register regardless of its corresponding interrupt enable bit being set. The status bits are cleared by writing a value of 1, which also clears the interrupt. Interrupts may occur while the system clock is idle or in standby mode. When the system enters the active power mode, interrupt will be indicated to the CPU. The first event of the Sampling Timer interrupts after Power-on-Reset should not used to qualify any periodic interval. However, the correct periodic interval (that is 512 Hz or 256 Hz, and so on) should be determined using two sampling timer interrupts. The time between two interrupt would always be the correct time period. Tamper Interrupt Status is set on reset as POR is generated when battery and CPU power are unavailable and either is powered up. Removal of battery is considered as a tamper and hence this bit is set on reset. The status register is also cleared on software reset except for the tamper status which remains unaffected . #### NOTE Sampling interrupts from 512 Hz to 2 Hz are generated using uncompensated clock. Only 1 Hz is compensated. Address: 4005\_0000h base + 14h offset = 4005\_0014h | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |-------|----------|----------|----------|---------|---------|---------|--------|-----------| | Read | IS_512HZ | IS_256HZ | IS_128HZ | IS_64HZ | IS_32HZ | IS_16HZ | IS_8HZ | IS_4HZ | | Write | w1c | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Read | IS_2HZ | IS_1HZ | MIN_IS | HOUR_IS | DAY_IS | ALM_IS | 0 | TAMPER_IS | | Write | w1c | w1c | w1c | w1c | w1c | w1c | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | ## RTC\_ISR field descriptions | Field | Description | |----------------|---------------------------------------| | 15<br>IS_512HZ | 512 Hz Interval Interrupt Status bit. | | _ | 0 Interrupt is de-asserted. | | | 1 Interrupt is asserted. | | 14<br>IS_256HZ | 256 Hz Interval Interrupt Status bit. | | _ | 0 Interrupt is de-asserted. | | | 1 Interrupt is asserted. | | 13<br>IS_128HZ | 128 Hz Interval Interrupt Status bit. | | _ | 0 Interrupt is de-asserted. | | | 1 Interrupt is asserted. | | 12<br>IS_64HZ | 64 Hz Interval Interrupt Status bit. | | 10_04112 | 0 Interrupt is de-asserted. | | | 1 Interrupt is asserted. | | 11<br>IS_32HZ | 32 Hz Interval Interrupt Status bit. | | | 0 Interrupt is de-asserted. | | | 1 Interrupt is asserted. | # RTC\_ISR field descriptions (continued) | Field | Description | |----------------|--------------------------------------------------------------------------------| | 10<br>IS_16HZ | 16 Hz Interval Interrupt Status bit. | | 15_16HZ | 0 Interrupt is de-asserted. | | | 1 Interrupt is asserted. | | 9 | 8 Hz Interval Interrupt Status bit. | | IS_8HZ | 0 Interrupt is de-asserted. | | | 1 Interrupt is asserted. | | 8 | 4 Hz Interval Interrupt Status bit. | | IS_4HZ | 0 Interrupt is de-asserted. | | | 1 Interrupt is asserted. | | 7 | 2 Hz Interval Interrupt Status bit. | | IS_2HZ | 0 Interrupt is de-asserted. | | | 1 Interrupt is asserted. | | 6 | 1 Hz Interval Interrupt Status bit. | | IS_1HZ | 0 Interrupt is de-asserted. | | | 1 Interrupt is asserted. | | 5 | Minutes Interrupt Status bit. | | MIN_IS | 0 Interrupt is de-asserted. | | | 1 Interrupt is asserted. | | 4 | Hours Interrupt Status bit. | | HOUR_IS | 0 Interrupt is de-asserted. | | | 1 Interrupt is asserted. | | 3 | Days Interrupt Status bit. | | DAY_IS | 0 Interrupt is de-asserted. | | | 1 Interrupt is asserted. | | 2 | Alarm Interrupt Status bit. | | ALM_IS | This bit indicates that the alarm value programmed matches the counter values. | | | 0 Interrupt is de-asserted. | | | 1 Interrupt is asserted. | | 1 | This field is reserved. | | Reserved | This read-only field is reserved and always has the value 0. | | 0<br>TAMPER_IS | Tamper Interrupt Status bit. | | | This field is cleared when TAMPER_SCR[TMPR_STS] is cleared. | ## RTC\_ISR field descriptions (continued) | Field | Description | | | |-------|----------------------------------------------|--|--| | | 0 Interrupt is de-asserted. | | | | | 1 Interrupt is asserted (Default on reset) . | | | # 32.3.12 RTC Interrupt Enable Register (RTC\_IER) For the sampling timer interrupt enable bits [14:6], refer to chip configuration chapter for the applicable sampling timer frequencies. The real-time clock interrupt enable register (IER) is used to enable/disable the various real-time clock interrupts. De-asserting an interrupt enable bit has no effect on the assertion of its corresponding status bit. Alarm interrupt is asserted on counters matching the alarm setting done in the memory map. The counters matched for the alarm interrupt are selected based on the Alarm Type set in CTRL[3:2] bits. The various types of alarm available are as per the following table. Only one alarm type can be used at a time. Table 32-14. Alarm Match Table | ALM_MATCH[1:0] (CTRL[3:2]) | Counters Matched | Alarm Type | |----------------------------|-------------------------------------------------|------------| | 00 | Seconds, Minutes, and Hours | Daily | | 01 | Seconds, Minutes, Hours, and Days | Monthly | | 10 | Seconds, Minutes, Hours, Days, and Months | Yearly | | 11 | Seconds, Minutes, Hours, Days, Months, and Year | One Time | A common interrupt is generated by the block. The user software should read the status register in the interrupt service routine to determine which interrupt has occurred. The tamper detect interrupt enable is an exception as it is enabled after power on reset. All interrupts enables except tamper interrupt enable are reset to default state on software reset. Address: 4005\_0000h base + 16h offset = 4005\_0016h | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|--------|--------|--------|---------|--------|--------|---|-----------| | Read<br>Write | IE_2HZ | IE_1HZ | MIN_IE | HOUR_IE | DAY_IE | ALM_IE | 0 | TAMPER_IE | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | ## RTC\_IER field descriptions | Field | Description | |----------------|---------------------------------------| | 15 | 512 Hz Interval Interrupt Enable bit. | | IE_512HZ | | | | 1 | | | Interrupt is enabled. | | 14<br>IE_256HZ | 256 Hz Interval Interrupt Enable bit. | | | 0 Interrupt is disabled. | | | 1 Interrupt is enabled. | | 13<br>IE_128HZ | 128 Hz Interval Interrupt Enable bit. | | | 0 Interrupt is disabled. | | | 1 Interrupt is enabled. | | 12<br>IE_64HZ | 64 Hz Interval Interrupt Enable bit. | | | 0 Interrupt is disabled. | | | 1 Interrupt is enabled. | | 11<br>IE_32HZ | 32 Hz Interval Interrupt Enable bit. | | | 0 Interrupt is disabled. | | | 1 Interrupt is enabled. | | 10<br>IE_16HZ | 16 Hz Interval Interrupt Enable bit. | | 12_10112 | 0 Interrupt is disabled. | | | 1 Interrupt is enabled. | | 9<br>IE_8HZ | 8 Hz Interval Interrupt Enable bit. | | _ | 0 Interrupt is disabled. | | | 1 Interrupt is enabled. | | 8<br>IE_4HZ | 4 Hz Interval Interrupt Enable bit. | | | 0 Interrupt is disabled. | | | 1 Interrupt is enabled. | | 7<br>IE_2HZ | 2 Hz Interval Interrupt Enable bit. | | | 0 Interrupt is disabled. | | | 1 Interrupt is enabled. | | 6<br>IE_1HZ | 1 Hz Interval Interrupt Enable bit. | ## RTC\_IER field descriptions (continued) | Field | Description | |-------------|--------------------------------------------------------------------------------| | | 0 Interrupt is disabled. | | | 1 Interrupt is enabled. | | 5<br>MIN_IE | Minutes Interrupt Enable bit. | | IVIII V_IL | 0 Interrupt is disabled. | | | 1 Interrupt is enabled. | | 4 | Hours Interrupt Enable bit. | | HOUR_IE | 0 Interrupt is disabled. | | | 1 Interrupt is enabled. | | 3<br>DAY_IE | Days Interrupt Enable bit. | | _ | 0 Interrupt is disabled. | | | 1 Interrupt is enabled. | | 2<br>ALM_IE | Alarm Interrupt Enable bit. | | ALIVI_IE | This bit indicates that the alarm value programmed matches the counter values. | | | 0 Interrupt is disabled. | | | 1 Interrupt is enabled. | | 1 | This field is reserved. | | Reserved | This read-only field is reserved and always has the value 0. | | 0 | Tamper Interrupt Enable bit. | | TAMPER_IE | 0 Interrupt is disabled. | | | 1 Interrupt is enabled (Default on reset). | # 32.3.13 RTC General Purpose Data Register (RTC\_GP\_DATA\_REG) The use of the bits in this register are specific to the MCU. See the Chip Configuration chapter for description of this register. Software reset has no effect on the contents of this register. Address: 4005\_0000h base + 20h offset = 4005\_0020h ## RTC\_GP\_DATA\_REG field descriptions | Field | Description | | | | | | |---------------------|------------------------------------------------------------------------------------|--|--|--|--|--| | 15–0<br>GP_DATA_REG | General Purpose Data bits for use by MCU. These bits are directly output from MCU. | | | | | | # 32.3.14 RTC Daylight Saving Hour Register (RTC\_DST\_HOUR) This register stores the time in hours when the Daylight Saving has to be applied or reversed. This register is programmable when the DST\_EN bit in CTRL register is 'Zero'. When DST\_EN bit is set, the contents of this register cannot be changed. The user software should program the correct hour value (0-23) as per the regional settings. For example, if the Daylight Saving starts at 2:00 AM on March 25 and ends at 2:00 AM on October 28 in 2007 then the time at which the RTC advances or falls back is actually 1:59 AM. Hence the user software should program 1 for the hour count value (and not 2!) i.e. write 0x0101 in this register. 59 minute count is automatically checked inside RTC and hence not required to be programmed. This register has no effect on software reset. Address: 4005\_0000h base + 22h offset = 4005\_0022h ## RTC\_DST\_HOUR field descriptions | Field | Description | |----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15–13<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 12–8<br>DST_START_<br>HOUR | Daylight Saving Time (DST) Hours Start Value. This is the hour value for the time when DST comes into effect. Same as Hours Counter Value in the RTC Hours and Minutes Counters Register (RTC_HOURMIN). | | 7–5<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 4-0<br>DST_END_<br>HOUR | Daylight Saving Time (DST) Hours End Value. This is the hour value for the time when DST is reversed. Same as Hours Counter Value in the RTC Hours and Minutes Counters Register (RTC_HOURMIN). | # 32.3.15 RTC Daylight Saving Month Register (RTC\_DST\_MONTH) This register stores the month when the Daylight Saving has to be applied or reversed. This register is programmable when the DST\_EN bit in CTRL register is Zero. When DST\_EN bit is set, the contents of this register cannot be changed. The CPU should program the correct month value (1-12) as per the regional settings. For example, if the Daylight Saving starts at March 25 and ends at October 28 in 2007. Hence the CPU should write 0x030A in this register. This register has no effect on software reset. Address: 4005\_0000h base + 24h offset = 4005\_0024h ## RTC\_DST\_MONTH field descriptions | Field | Description | |-----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15–12<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 11–8<br>DST_START_<br>MONTH | Daylight Saving Time (DST) Month Start Value. This is the month value for the time when DST comes in to effect. See the RTC Year and Month Counters Register (RTC_YEARMON). | | 7–4<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 3-0<br>DST_END_<br>MONTH | Daylight Saving Time (DST) Month End Value. This is the month value for the time when DST is reversed. See the RTC Year and Month Counters Register (RTC_YEARMON). | 597 # 32.3.16 RTC Daylight Saving Day Register (RTC\_DST\_DAY) This register stores the day when the Daylight Saving has to be applied or reversed. This register is programmable when the DST\_EN bit in CTRL register is Zero. When DST\_EN bit is set, the contents of this register cannot be changed. The CPU should program the correct day value (1-31) as per the regional settings. For example, if the Daylight Saving starts at March 25 and ends at October 28 in 2007. Hence the CPU should write 0x191C in this register. This register is unaffected by software reset. Address: 4005\_0000h base + 26h offset = 4005\_0026h ## RTC\_DST\_DAY field descriptions | Field | Description | |---------------------------|-------------------------------------------------------------------------------------------------------------| | 15–13<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 12–8<br>DST_START_<br>DAY | Daylight Saving Time (DST) Day Start Value. This is the day value for the time when DST comes into effect. | | 7–5<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 4–0<br>DST_END_DAY | Daylight Saving Time (DST) Day End Value. This is the day value for the time when DST is reversed. | # 32.3.17 RTC Compensation Register (RTC\_COMPEN) The compensation register stores the compensation value that will be used by the compensation block to correct the 1 Hz clock. Address: 4005\_0000h base + 28h offset = 4005\_0028h | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|----|----|----|----|----|----|---|-------|-------|---|---|---|---|---|---|---| | Read<br>Write | | | | | | | | СОМРЕ | N_VAL | • | | | | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ## RTC\_COMPEN field descriptions | Field | Description | |--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15–0<br>COMPEN_VAL | Compensation Value | | | This register stores the compensation parameters. The definition of this field is dependent on the setting of RTC_CTRL[FINEEN]. | | | If FINEEN = 0: | | | <ul> <li>Compensation/Correction Value (COMPEN[7:0]) - Compensation/Correction Value is a 2's complement value by which the 1 Hz Clock is modified (during its generation) by either adding or removing RTC Oscillator clock cycles.</li> <li>Compensation Interval (COMPEN[15:8]) - Compensation Interval is the duration in seconds over which the correction is applied. This is the time in which the addition or removal of 32.768 kHz clock cycles is done thereby ensuring that the compensation interval is close to the interval obtained with an ideal 1 Hz clock.</li> </ul> | | | If FINEEN = 1 | | | <ul> <li>Integral Compensation Value (COMPEN[15:12])- This is a 2's complement value of the integer part of correction or compensation value that has to be adjusted in every 1 second period. This value is expressed in terms of number of clock cycles of the RTC Oscillator clock.</li> <li>COMPEN[11:7] Should be zero</li> <li>Fraction Compensation Value (COMPEN[6:0]) - This is the fractional part of the correction or compensation value that has to be adjusted. This value is expressed as number of clock cycles of a fixed 4.194304 MHz clock. This value is always a positive number.</li> </ul> | # 32.3.18 Tamper Direction Register (RTC\_TAMPER\_DIRECTION) This register defines the I/O selection of the Tamper pins and also the selection between the active and passive types of tamper for each pin. Address: 4005\_0000h base + 2Ch offset = 4005\_002Ch ## RTC\_TAMPER\_DIRECTION field descriptions | Field | Description | | | | | | |-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | 15–12<br>Reserved | This field is reserved. Reserved | | | | | | | 11–8<br>I_O_TAMP | Defines the I/O capability of tamper pins. NOTE: When the corresponding A_P_TAMP field, that is, bit 0 is set to passive mode, this field is only readable and always reads as "0". 1'b1 Output 1'b0 Input | | | | | | | 7–4<br>Reserved | This field is reserved. Reserved | | | | | | Table continues on the next page... #### KM Family Reference Manual, Rev. 5, Oct 2013 598 Preliminary Freescale Semiconductor, Inc. ## RTC\_TAMPER\_DIRECTION field descriptions (continued) | Field | Description | |-----------------|----------------------------------------------------------| | 3–0<br>A_P_TAMP | Defines the active/passive selection of the tamper pins. | | | 1'b0 Passive | | | 1'b1 Active | # 32.3.19 Tamper Queue Status and Control Register (RTC\_TAMPER\_QSCR) Address: 4005\_0000h base + 2Eh offset = 4005\_002Eh ## RTC\_TAMPER\_QSCR field descriptions | Field | Description | | | | | | | | |----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--| | 15–12<br>LFSR_<br>DURATION | FSR Filter duration period:- Denotes the LFSR clocks after which the LFSR shifts its value. This value hould be the same value used for all the Active tamper filter duration period (defined for the input pin). | | | | | | | | | 11<br>Reserved | his field is reserved. Reserved | | | | | | | | | 10-8<br>LFSR_CLK_SEL | This field defines the clock selection for LFSR module. This value should be the same for all the active tamper filter clock selects (defined for the input pin). | | | | | | | | | | NOTE: LFSR is only enabled if user defines atleast one of the tamper pins as ACTIVE. | | | | | | | | | | 3'b000 32 KHz<br>3'b001 512 Hz | | | | | | | | | | 3'b010 128 Hz | | | | | | | | | | 3'b011 64 Hz | | | | | | | | | | 3'b100 16 Hz | | | | | | | | | | 3'b101 8 Hz | | | | | | | | | | 3'b110 4 Hz | | | | | | | | | | 3'b111 2 Hz | | | | | | | | | 7–3<br>Reserved | This field is reserved. | | | | | | | | | 2<br>Q_CLEAR | This field when set clears the Tamper Queue. This is an auto clear bit. It gets cleared in the next cycle. | | | | | | | | ## RTC\_TAMPER\_QSCR field descriptions (continued) | Field | Description | | | | | | |--------------------|----------------------------------------|--|--|--|--|--| | 1<br>Q_FULL_INT_EN | Queue full interrupt enable bit. | | | | | | | \( \( \) \( \) | 1'b1 Queue full interrupt is enabled. | | | | | | | | 1'b0 Queue full interrupt is disabled. | | | | | | | 0 | Tamper Queue full status bit. | | | | | | | Q_FULL | | | | | | | | | 1'b1 The tamper queue is full. | | | | | | | | 1'b0 The tamper queue is not full. | | | | | | # 32.3.20 RTC Tamper Status and Control Register (RTC\_TAMPER\_SCR) For the implementation of this register in the MCU, refer to chip configuration chapter. This register stores the tamper event and provides control to the user to enable or disable each tamper individually. No tamper is disabled automatically unless corresponding control bit is de-asserted by software. The tamper statuses are stored as active high. The tamper status bits store the tamper event irrespective of their corresponding control bit being asserted or not. The control bits gate the assertion of tamper interrupt bit in ISR. These status and controls bits combined assert the tamper interrupt in the ISR register. The tamper interrupt will be cleared when all above Status bits are cleared. Address: 4005\_0000h base + 32h offset = 4005\_0032h ## RTC\_TAMPER\_SCR field descriptions | Field | Description | |-------------------|------------------------------------------------------------------------------------------------------------------------| | 15–12<br>Reserved | This field is reserved. | | 11-8<br>TMPR_STS | Tamper Status Bit Indicates if a tamper event was detected or not. Writing '1' to this field clears the tamper status. | | 7–4<br>Reserved | This field is reserved. | | 3–0<br>TMPR_EN | Tamper Control Controls the generation of tamper interrupt from corresponding tamper status bit. Enabled on reset. | # 32.3.21 RTC Tamper 01 Filter Configuration Register (RTC\_FILTER01\_CFG) This register must be configured once during the initial startup of application and must not be changed on the fly to avoid any erratic behavior. Changing the register on the fly might lead to missing of tamper events or assertion of false tamper events. Address: 4005\_0000h base + 34h offset = 4005\_0034h | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|------|----------|----|----|----------|----|---|------|---|--------|----|---|-------|------|---|---| | Read<br>Write | POL0 | CLK_SEL0 | | | FIL_DUR0 | | | POL1 | С | LK_SEL | _1 | | FIL_C | DUR1 | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ## RTC\_FILTER01\_CFG field descriptions | Field | Description | | | | | | | | |-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--| | 15 | Tamper Detect Input Bit 0 Polarity Control | | | | | | | | | POL0 | This bit controls the polarity of tamper detect input bit 0 (TAMPER[0]). | | | | | | | | | | | | | | | | | | | | 0 Tamper detect input bit 0 is active high. | | | | | | | | | | 1 Tamper detect input bit 0 is active low. | | | | | | | | | 14–12<br>CLK_SEL0 | Tamper Filter 0 Clock Select | | | | | | | | | | This bit is a write once bit and selects the clock source for tamper filter for tamper detect input bit 0. | | | | | | | | | | 000 32 kHz clock | | | | | | | | | | 001 512 Hz clock | | | | | | | | | | 010 128 Hz clock | | | | | | | | | | 011 64 Hz clock | | | | | | | | | | 100 16 Hz clock | | | | | | | | | | 101 8 Hz clock | | | | | | | | | | 110 4 Hz clock | | | | | | | | | 11.0 | 111 2 Hz clock | | | | | | | | | 11–8<br>FIL_DUR0 | Tamper Detect Bit 0 Filter Duration | | | | | | | | | TIL_DONO | This bit indicates the number of tamper filter clock cycles for which the TAMPER[0] signal should remains stable before being detected as a tamper. These bits are used by the tamper filtering operation. | | | | | | | | | | With the tamper duration set to Zero any tamper detected on the tamper pins will directly set the tamper status and interrupt bits. Caution is required when making the tamper filter duration equal to 0 as any glitches on the tamper pins will cause a tamper interrupt. | | | | | | | | | | 0 Filtering operation disabled. | | | | | | | | | | 1-1111 Number of tamper filter clock cycles to be counted when tamper is asserted. | | | | | | | | | 7 | Tamper Detect Input Bit 1 Polarity Control | | | | | | | | | POL1 | This his controls the melevity of terror or detect innut his 4 (TAMPERIAL) | | | | | | | | | | This bit controls the polarity of tamper detect input bit 1 (TAMPER[1]). | | | | | | | | ## RTC\_FILTER01\_CFG field descriptions (continued) | Field | Description | | | | | | | |-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--| | | 0 Tamper detect input bit 1 is active high. | | | | | | | | | 1 Tamper detect input bit 1 is active low. | | | | | | | | 6–4<br>CLK_SEL1 | Tamper Filter 1 Clock Select | | | | | | | | OLK_SELT | This bit is a write once bit and selects the clock source for tamper filter for tamper detect input bit 1. | | | | | | | | | 000 32 kHz clock | | | | | | | | | 001 512 Hz clock | | | | | | | | | 010 128 Hz clock | | | | | | | | | 011 64 Hz clock | | | | | | | | | 100 16 Hz clock | | | | | | | | | 101 8 Hz clock | | | | | | | | | 110 4 Hz clock | | | | | | | | | 111 2 Hz clock | | | | | | | | 3–0 | Tamper Detect Bit 1 Filter Duration | | | | | | | | FIL_DUR1 | This bit indicates the number of tamper filter clock cycles for which the TAMPER[1] signal should remains stable before being detected as a tamper. These bits are used by the tamper filtering operation. | | | | | | | | | With the tamper duration set to Zero any tamper detected on the tamper pins will directly set the tamper status and interrupt bits. Caution is required when making the tamper filter duration equal to 0 as any glitches on the tamper pins will cause a tamper interrupt. | | | | | | | | | 0 Filtering operation disabled. | | | | | | | | | 1 to 1111 Number of tamper filter clock cycles to be counted when tamper is asserted. | | | | | | | # 32.3.22 RTC Tamper 2 Filter Configuration Register (RTC\_FILTER2\_CFG) This register must be configured once during the initial startup of application and must not be changed on the fly to avoid any erratic behavior. Changing the register on the fly might lead to missing of tamper events or assertion of false tamper events. Tamper 3 is an internal tamper detect bit and hence does not require any filtering. Address: 4005\_0000h base + 36h offset = 4005\_0036h ## RTC\_FILTER2\_CFG field descriptions | Field | Description | |------------|--------------------------------------------------------------------------| | 15<br>POL2 | Tamper Detect Input Bit 2 Polarity Control | | _ | This bit controls the polarity of tamper detect input bit 2 (TAMPER[2]). | Table continues on the next page... #### KM Family Reference Manual, Rev. 5, Oct 2013 602 Preliminary Freescale Semiconductor, Inc. ## RTC\_FILTER2\_CFG field descriptions (continued) | Field | Description | | | | | | | |----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--| | | 0 Tamper detect input bit 2 is active high. | | | | | | | | | 1 Tamper detect input bit 2 is active low. | | | | | | | | 14–12 | Tamper Filter 2 Clock Select | | | | | | | | CLK_SEL2 | This bit is a write once bit and selects the clock source for tamper filter for tamper detect input bit 2. | | | | | | | | | 000 32 kHz clock | | | | | | | | | 001 512 Hz clock | | | | | | | | | 010 128 Hz clock | | | | | | | | | 011 64 Hz clock | | | | | | | | | 100 16 Hz clock | | | | | | | | | 101 8 Hz clock | | | | | | | | | 110 4 Hz clock | | | | | | | | | 111 2 Hz clock | | | | | | | | 11–8 | Tamper Detect Bit 2 Filter Duration | | | | | | | | FIL_DUR2 | This bit indicates the number of tamper filter clock cycles for which the TAMPER[2] signal should remains stable before being detected as a tamper. These bits are used by the tamper filtering operation. | | | | | | | | | With the tamper duration set to Zero any tamper detected on the tamper pins will directly set the tamper status and interrupt bits. Caution is required when making the tamper filter duration equal to 0 as any glitches on the tamper pins will cause a tamper interrupt. | | | | | | | | | 0 Filtering operation disabled. | | | | | | | | | 1 to 1111 Number of tamper filter clock cycles to be counted when tamper is asserted. | | | | | | | | 7–0 | This field is reserved. | | | | | | | | Reserved | This read-only field is reserved and always has the value 0. | | | | | | | # 32.3.23 Tamper Queue Register (RTC\_TAMPER\_QUEUE) Tamper queue register provides the Time stamp and the Pin number on which the tamper occured. #### NOTE Reading beyond the depth of FIFO when the FIFO is full or empty returns random data. See the Chip Configuration chapter for the depth of the Tamper FIFO. Address: 4005\_0000h base + 40h offset = 4005\_0040h # RTC\_TAMPER\_QUEUE field descriptions | Field | Description | |-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-0 | Tamper type stamp and pin number information register | | TAMPER_DATA | The complete tamper time stamp and status information can be obtained by making two read accesses to this register: | | | The first read gives the following information: | | | <ul> <li>TAMPER_DATA[4:0] = Hour</li> <li>TAMPER_DATA[9:5] = Day</li> <li>TAMPER_DATA[13:10] = Month</li> <li>TAMPER_DATA[15:14] = 2'b0</li> </ul> | | | The second read gives the remaining information, that is: | | | <ul> <li>TAMPER_DATA[5:0] = seconds</li> <li>TAMPER_DATA[11:6] = minutes</li> <li>TAMPER_DATA[14:12] = Tamper Index, that is, index of tamper status bits from 0 to 3</li> <li>TAMPER_DATA[15] = 1'b0</li> </ul> | | | NOTE: The year value can be obtained by reading the year counter register | # 32.3.24 RTC Control 2 Register (RTC\_CTRL2) RTC control 2 register defines the attributes for the configuration of tamper pins. Address: 4005\_0000h base + 42h offset = 4005\_0042h ## RTC\_CTRL2 field descriptions | Field | Description | | | | | |-------------------|---------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | 15–8<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | | | | | | Wakeup Mode | | | | | | WAKEUP_<br>STATUS | Wakeup Status O The wakeup/hibernation pin is in HiZ mode. O1 The wakeup/hibernation pin is at logic 0. MCU is in sleep mode. | | | | | ## RTC\_CTRL2 field descriptions (continued) | Field | Description | | | | | | |------------------------|-----------------------------------------------------------------------------------------------------------|--|--|--|--|--| | | <ul><li>10 The wakeup/ hibernation pin is at logic 1. MCU is in sleep mode.</li><li>11 Reserved</li></ul> | | | | | | | 4<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | | | | | | 3–1<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | | | | | | 0<br>TAMP_CFG_<br>OVER | NOTE: Set this field to 1 only when all the tamper_cfg registers are programmed. | | | | | | | | <ul><li>Tamper filter processing disabled.</li><li>Tamper filter processing enabled.</li></ul> | | | | | | # 32.4 Functional Description # 32.4.1 Time and Calendaring Functions RTC performs and controls all chronological functions as mentioned below: - Implements all counters for date and time and their related control logic - Leap Year calculation and adjusting the day count accordingly - Increment/Decrement of counters for adjustment of leap seconds - Tracking the number of days in a month - Automatic Daylight adjustment for time - Alarm generation with selectable matching of different counters Dynamic modifications to the date counters are done based on a) Leap Year b) Month and c) Daylight Saving. Additionally, the user software can add or subtract a second to take care of Leap Seconds Adjustment. All changes are hardware controlled and triggered by software. A leap year is defined as a year in which the year value is divisible by 4 and 400 and will have an extra day in February. Daylight savings are done in different regions of the world to shift the local time according to summer or winters. Time is shifted at a pre-defined time decided by the regional conditions and programmed by the user software into the RTC and RTC automatically adjusts the time using hardware alarms for daylight saving. Day counter is also adjusted for months having 28/29/30/31 days. #### **runctional Description** Alarm generation is done by the RTC block. The matching of counters is controlled by ALM\_MATCH bits inside the control register to give various alarm options of daily, monthly, yearly or one-time alarms. #### **Note** Setting an hour alarm value that coincides with the Daylight Saving Start Hour value will not generate an alarm as when Daylight Saving comes into effect, the hour counter is incremented by 2 instead or normal 1. For example, setting ALM\_HOURMIN = 0x1500 (hour alarm value = 15 or 3 PM) and DST\_HOUR = 0x1411 (DST Start Hour value = 14 or 2 PM), will cause the hour counter to go from 14 to 16. The hour counter will not be 15 and hence the alarm which was set for 15 (or 3 PM) will not trigger. User software must take into account Daylight Saving changes when setting alarm values. ### NOTE The user software must program an alarm time equal to the daylight saving end time that is fallback time and when the alarm interrupt comes, the user software must clear the DSTEN bit in control register, else correct operation might not occur. # 32.4.2 RTC Compensation Logic The Compensation Logic provides an accurate and wide range of compensation which is suitable for many crystals, and can correct a wide range crystal offsets with offsets being as low as 0.119 PPM. The same hardware logic supports both temperature compensation and frequency compensation. There are two important components in the compensation logic viz., Coarse Compensation and Fine Compensation. The coarse compensation provides accurate clock to RTC's internal time & date counters while fine compensation generate an accurate 1 Hz clock output (via MCU pin) with high resolution clock edge placement (up to 0.88 ppm) and near 50% duty cycle. # 32.4.2.1 Enabling the required compensation logic Coarse compensation is enabled by writing to RTC\_CTRL[COMPEN] and Fine compensation is enabled by writing to RTC\_CTRL[FINEEN]. However, when FINEEN = '1', COMPEN must be equal to '1'. Setting both bits to '0' will disable all compensation and this is the default state out of reset. In addition, compensation parameters need to be provided to allow required compensation logic to run. The parameters are provided by writing to the RTC\_COMPEN register. #### NOTE In RTC\_CTRL, if FINEEN = 0, then before changing RTC\_COMPEN for the first time, disable the compensation using RTC\_CTRL[COMP\_EN]. Successive changes can be done without disabling compensation. If FINEEN =1, then there is an option to either clear previously accumulated fractional compensation value by disabling compensation from RTC\_CTRL, program new values, and re-enable compensation and start afresh or to overwrite the current values which leads to adding of previously accumulated fractional compensation value to programmed fractional compensation value. The integer part is always overwritten. # 32.4.2.2 Compensation Parameters Compensation logic requires the user software to provide compensation parameters in the RTC\_COMPEN register in order to generate accurate 1 Hz clock. These parameters are defined depending on the type of compensation enabled. The compensation parameters (when FINEEN = '0') are defined as: - Compensation/Correction Value: Compensation/Correction Value is a 2's complement value by which the 1 Hz Clock is modified (during its generation) by either adding or removing RTC Oscillator clock cycles. - Compensation Interval: Compensation Interval is the duration in seconds over which the correction is applied. This is the time in which the addition or removal of 32.768 kHz clock cycles is done thereby ensuring that the compensation interval is close to the interval obtained with an ideal 1 Hz clock. The compensation parameters (when FINEEN = '1') are defined as: • Integral Compensation Value: This is a 2's complement value of the integer part of correction or compensation value that has to be adjusted in every 1 second period. This value is expressed in terms of number of clock cycles of the RTC Oscillator clock #### runctional Description • **Fraction Compensation Value:** This is the fractional part of the correction or compensation value that has to be adjusted. This value is expressed as number of clock cycles of a fixed 4.194304 MHz clock that have to be added. This value is always a positive number. #### NOTE When FINEEN = '1', the compensation interval is by default set to "1" indicating that the compensation will be done at every second. # 32.4.2.3 Coarse Compensation Logic The coarse compensation logic provides the accurate 1 Hz clock pulses to the time and date counters and the coarse 1 Hz clock to the fine compensation logic. <u>When FINEEN = '0':</u> RTC compensates the clock over the provided compensation interval. The addition or removal of clocks is done in a single 1 Hz period, leaving the other 1 Hz periods of the compensation interval same. This addition or removal of RTC Oscillator clock cycles adjusts the 1 Hz clock in a way to keep the overall compensation interval time close to the same interval being measured with an ideal clock. <u>When FINEN = '1'</u>: The integral part of compensation value (or correction value) is added or removed every 1 Hz period while the fraction part is accumulated and adjusted when accumulated value equals 1 RTC Oscillator clock cycle period. To perform crystal offset compensation, the user software computes the compensation parameters external to RTC and using the details about crystal characteristics (ageing, drift, etc), computes the correction factor and programs it in the two's complement format in the RTC Compensation Register (RTC\_COMPEN). Based on the values written in the RTC\_COMPEN register, the compensation is performed. To perform temperature compensation the user software can maintain a look-up-table in its memory which lists the change in frequency of 32.768 kHz crystal clock for each degree change in temperature. The CPU wakes up periodically to measure the external temperature via a temperature sensor connected to an A/D converter. The user software uses the look-up-table to determine the compensation factor and writes the value to be compensated (in terms of number of 32.768 kHz clock cycles in 2's complement format) in the RTC Compensation Register (COMPEN). Based on the new values written the compensation logic adjusts the clock from the next compensation interval. The user software must compute a common compensation factor if it detects a variation in 32.768 kHz clock due to both temperature and crystal characteristics. ### **Vital Statistics** - Range of Compensation Interval: 1 second to 255 seconds. If FINEEN=0, programming a 0 disables compensation. If FINEEN=1, this interval is always 1 second. - Range of Compensation: -128 to +127 (number of 32.768 kHz clock cycles) - Selection Criteria: Compensation is done only when enabled by user software. User software can disable compensation by programming a zero compensation interval or setting RTC\_CTRL[COMPEN] = '0' # 32.4.2.4 Fine Compensation Logic The fine compensation logic takes the coarse 1 Hz clock (from coarse compensation block) and generates accurate 1 Hz clock output with accurate clock edge placement and near 50% duty cycle. The fine compensation runs when FINEEN = '1' and uses the MCU's IRC clock to adjust the fractional part of the compensation value every 1 Hz period. This provides an accurate edge placement on 1 Hz clock. The fine compensation module automatically adjusts the fractional compensation value for any variation in the IRC clock. #### NOTE Since the IRC clock is generated on MCU, this clock will get disabled when MCU power is OFF or in certain low power modes. In this case, the coarse 1 Hz clock is output from the MCU. The coarse 1 Hz clock is not a 50% duty cycle clock. ## 32.4.3 Write Protection Mechanism This logic protects the RTC Registers from any spurious updates that can happen from a run-away code. The logic monitors the values written to WE[1:0] bits of the STATUS register. By default unconditional write access is allowed to these bits only. For writing the locking and unlocking sequence, 8-bit access should be given on RTC\_STATUS[7:0]. To enable write protection, "10" is written on these bits. To disable write protection, the sequence "00 - 01 - 11 - 10" is written onto these bits. #### **runctional Description** After a power on reset, the write-protect mechanism is disabled, allowing the user software to configure the RTC block. Once configuration is complete, the user code should enable the write protection mode. If this is not done by the user software, the registers are put into write protect mode 15 seconds after power on. In case the write protect mode is unlocked to update registers, then the write protect mode is enabled automatically 2 seconds after unlock, if not locked by user software. Any write access made to the registers when write protection is enabled (i.e. registers in locked mode) will cause the transfer error signal to be asserted. Reads are allowed at all times. #### NOTE - 1. Always check RTC\_STATUS[WRITE\_ PROT\_EN] after running unlocking and locking sequence and re-run the sequence if RTC\_STATUS[WRITE\_ PROT\_EN] is not in the required state. - 2. Two consecutive unlocking sequences will lock the registers. Once unlocked, running an unlock sequence before the timeout will lock RTC registers. # 32.4.4 Tamper Detection and Logging A mechanism has been provided in RTC to detect and log any intrusion made to the system. The tamper logic supports up to 4 tamper signal inputs which can be used for detecting either internal tamper events (i.e. battery removal, etc) or external tamper events (i.e. off chip tamper switches). RTC stores these individual and unique tamper events in the RTC tamper queue along with the time stamp of the tamper event and generates a common interrupt when any tamper event occurs. The tamper queue does not store the year field as this value can be read from RTC\_YEARMON. It is expected that the queue will be read at least once in a year. **Internal Tamper Events:** Battery removal when MCU is powered OFF The detection of battery removal during system power off is done using a flop that is asserted on power-on reset. Since there is no difference between a proper shutdown and this tamper condition, this is considered as a tamper always. The firmware needs to differentiate between the tamper condition and normal power up. One way is to ignore this tamper interrupt when the SoC or application is in Service mode and simply reset the tamper interrupt. For other conditions it will be taken as a tamper. External Tamper Events: Off-Chip Tamper Indication 611 An external off-chip tamper switch is also used to monitor tampering external to the SoC. For example, a signal can be used to indicate that the case housing the SoC/board is opened or not. Since these events are detected off chip, these tamper inputs are precondition in the SoC logic (i.e. conversion to digital or level shifting, etc) before being input to RTC. The tampers are further divided into two tamper types - Active and Passive. All the tamper pins have to programmed as either Input or Output and Active/Passive through the tamper direction register. Only the Active tampers can be defined as Outputs for Passive the tampers can be only programmed as inputs. The Active tampers have an LFSR (line following shift register) system enabled for them, which has a programmable clock and duration field in the TAMPER\_QSCR register. The clock field provides the clock at which the LFSR runs and the duration field specifies the clocks after which it shifts it value. For all the active tampers there is a common LFSR which acts as a source for the output pins of tampers. The value floated through the output of LFSR has to be received in the same sequence at the tamper input pins to be detected as a NO TAMPER. Any variation on the sequence which is not filtered out by the tamper filter will be registered as a tamper. External tamper switches are prone to noise and can cause false tamper indication if not filtered. Noise filtering is present in RTC for all external tamper inputs. The duration for which a tamper signal should be asserted to be indicated as tamper is programmable by user software in the register space. This duration is programmable to support a variety of tamper switches. The filtered signals are then used to generate the tamper status and interrupt signals. The polarity of the tamper inputs can be configured to be active high or active low. Figure 32-25. External Tamper Detection ## **Time Stamping:** RTC can record the date (day and month) and time (hour, minute, second) in the queue if the tamper is detected by RTC. **runctional Description** # 32.4.4.1 Tamper Detection Flow A tamper queue is present in RTC to store up to a maximum of 4 unique tamper events (no priority to any tamper), every tamper entry stores the following information:- - the tamper time-stamp i.e. month, day, hour, minute, and seconds. - the tamper type or the tamper pin number. The tamper data stored in the tamper queue has to be read via two read accesses. - the first access gives the tamper\_month, the tamper\_day and the tamper\_hour value. - the second access gives the information about the tamper\_type,tamper\_minute and tamper\_second value. The tampering logic stores only the first occurrence of tamper from a pin till that tamper status is acknowledged by the CPU. As soon as the CPU reads the queue entry it has to clear the status of the corresponding pin to enable logging of subsequent tampers from that pin. It may choose to disable that tamper bit if it does not want further tamper logging from that tamper pin. The tamper queue also generates a full indication (both as a status bit and a maskable interrupt to the core) to the software, indicating the software that the maximum number of tampers that can be stored in the FIFO has been reached. The user has the capability to clear the tamper queue at one go by asserting TAMPER\_QSCR[Q\_CLEAR]. Following steps describe how tamper is logged in the registers and tamper queue, and how the software acknowledges the tamper status indication: - Tamper Interrupt Enable bit is also asserted on POR and an interrupt indication to CPU. - When CPU acknowledges the tamper interrupt by writing 1'b1 to the tamper interrupt status bit (TTSR\_SCR[8]), the tamper status bits are cleared. - Internal tamper event (detected by SoC logic) are simply stored in their corresponding status bits and time stamp is captured. - All tamper signals asserted externally are filtered inside the tamper block. - Tamper status bit is asserted when the filter counter matches the programmed filter duration. - Tamper status bit is asserted in the tamper status and control register irrespective the tamper control bit is enabled or not. Time stamp is also logged for the first occurrence of the tamper event. The first occurrence of each tamper along with time stamp get pushed into the tamper queue. Until current tamper status bit is acknowledged by CPU, next status and time stamp for that tamper is ignored. - The tamper interrupt is asserted for the tamper status bits that have the corresponding interrupt enable bits set. - Tamper interrupt status bit (in ISR) is cleared when all tamper status bits (in TTSR\_SCR) are cleared by writing 1 to them. - The software must read the tamper queue entry first and then clear the corresponding status bit from the TAMPER\_SCR register. #### NOTE When programing the tamper parameters such as filter duration, clock selection, polarity, etc, the user software must gate the 32k clock to RTC, program these parameters and then enable clock. While programming the parameters, the clock selection must be changed at the last. It is assumed that time and date will be set after this and tamper parameters will not be required to be changed again later. #### 32.4.5 RTC Isolation To prevent leakage and erratic behavior, RTC isolates its CPU register programming interface and other control signals. There are two levels of isolation provided: - CPU is in certain low power modes where LVD is disabled (except VLPR). - When VDD < LVD, both read and writes to all registers are blocked. Isolation is enabled to prevent leakage from signals coming from the powered off domain of SoC. The voltage threshold detection is done by an analog block (outside digital RTC) which monitors the voltage levels. ### 32.4.6 Wakeup Mode To enable the wakeup functionality of RTC, set CTRL2[WAKEUP\_MODE]. If this field is set to "1", the tamper\_out[0] pin is by default set to the wakeup functionality. This pin is driven by CTRL2[WAKEUP\_STATUS]. #### NOTE If the tamper pin is in HiZ mode, the CPU is in normal functioning mode. If CTRL2[WAKEUP\_STATUS] is changed #### runctional Description to 01 or 10, then the CPU needs to put the system in the sleep mode. The use case scenario is as follows: - 1. Set the required wakeup interrupt sources from the RTC\_IER register. Select the required event, that is, {(Alarm & select) OR (Tamper & select) OR (1sec period & select)}. - 2. The CTRL2[WAKEUP\_STATUS] field is by default in HiZ mode. - 3. Based on whether LDO or PMOS is used, switch the CTRL2[WAKEUP\_STATUS] field to 0 or 1. - 4. When the selected event(interrupt) is detected, the wakeup/hibernation pin (tamper\_out[0]) changes back to HiZ mode. ## **Chapter 33 Low-Power Timer (LPTMR)** #### 33.1 Introduction #### **NOTE** For the chip-specific implementation details of this module's instances, see the chip configuration information. 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. #### **33.1.1 Features** The features of the LPTMR module 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 ## 33.1.2 Modes of operation The following table describes the operation of the LPTMR module in various modes. KM Family Reference Manual, Rev. 5, Oct 2013 615 #### Table 33-1. Modes of operation | Modes | Description | |-------------|------------------------------------------------------------------------------------------------------------------------------| | Run | The LPTMR operates normally. | | Wait | The LPTMR continues to operate normally and may be configured to exit the low-power mode by generating an interrupt request. | | Stop | The LPTMR continues to operate normally and may be configured to exit the low-power mode by generating an interrupt request. | | Low-Leakage | The LPTMR continues to operate normally and may be configured to exit the low-power mode by generating an interrupt request. | | Debug | The LPTMR operates normally in Pulse Counter mode, but counter does not increment in Time Counter mode. | ## 33.2 LPTMR signal descriptions Table 33-2. LPTMR signal descriptions | Signal | I/O | Description | |------------|-----|-------------------------| | LPTMR_ALTn | I | Pulse Counter Input pin | ## 33.2.1 Detailed signal descriptions Table 33-3. LPTMR interface—detailed signal descriptions | Signal | I/O | Description | | | |------------|-----|-----------------------------|-----------------------------------------------------------------------------------------------------------------------|--| | LPTMR_ALTn | I | Pulse Counter Input | | | | | | The LPTMR can select one of | 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 CNR to increment. | | | | | | Deassertion—If configured for pulse counter mode with active-low input, then deassertion causes the CNR to increment. | | | | | Timing | Assertion or deassertion may occur at any time; input may assert asynchronously to the bus clock. | | ## 33.3 Memory map and register definition ### **LPTMR** memory map | Absolute address (hex) | Register name | | Access | Reset value | Section/<br>page | |------------------------|-----------------------------------------------------|----|--------|-------------|------------------| | 4003_C000 | Low Power Timer Control Status Register (LPTMR_CSR) | 32 | R/W | 0000_0000h | 33.3.1/617 | | 4003_C004 | Low Power Timer Prescale Register (LPTMR_PSR) | 32 | R/W | 0000_0000h | 33.3.2/618 | | 4003_C008 | Low Power Timer Compare Register (LPTMR_CMR) | 32 | R/W | 0000_0000h | 33.3.3/620 | | 4003_C00C | Low Power Timer Counter Register (LPTMR_CNR) | 32 | R | 0000_0000h | 33.3.4/620 | ## 33.3.1 Low Power Timer Control Status Register (LPTMR\_CSR) #### LPTMR\_CSR field descriptions | Field | Description | |------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31–8<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 7<br>TCF | Timer Compare Flag | | | TCF is set when the LPTMR is enabled and the CNR equals the CMR and increments. TCF is cleared when the LPTMR is disabled or a logic 1 is written to it. | | | 0 The value of CNR is not equal to CMR and increments. | | | 1 The value of CNR is equal to CMR and increments. | | 6<br>TIE | Timer Interrupt Enable | | | When TIE is set, the LPTMR Interrupt is generated whenever TCF is also set. | | | 0 Timer interrupt disabled. | | | 1 Timer interrupt enabled. | | 5–4<br>TPS | Timer Pin Select | | | Configures the input source to be used in Pulse Counter mode. TPS must be altered only when the LPTMR is disabled. The input connections vary by device. See the chip configuration details for information on the connections to these inputs. | | | 00 Pulse counter input 0 is selected. | Table continues on the next page... #### wemory map and register definition ## LPTMR\_CSR field descriptions (continued) | Field | Description | |----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | 01 Pulse counter input 1 is selected. | | | 10 Pulse counter input 2 is selected. | | | 11 Pulse counter input 3 is selected. | | 3<br>TPP | Timer Pin Polarity | | | Configures the polarity of the input source in Pulse Counter mode. TPP must be changed only when the LPTMR is disabled. | | | <ul> <li>Pulse Counter input source is active-high, and the CNR will increment on the rising-edge.</li> <li>Pulse Counter input source is active-low, and the CNR will increment on the falling-edge.</li> </ul> | | 2 | Timer Free-Running Counter | | TFC | Miles ales TEO configures the OND to receive the CND | | | When clear, TFC configures the CNR to reset whenever TCF is set. When set, TFC configures the CNR reset on overflow. TFC must be altered only when the LPTMR is disabled. | | | 0 CNR is reset whenever TCF is set. | | | 1 CNR is reset on overflow. | | 1 | Timer Mode Select | | TMS | Configures the mode of the LPTMR. TMS must be altered only when the LPTMR is disabled. | | | 0 Time Counter mode. | | | 1 Pulse Counter mode. | | 0<br>TEN | Timer Enable | | | When TEN is clear, it resets the LPTMR internal logic, including the CNR and TCF. When TEN is set, the | | | LPTMR is enabled. While writing 1 to this field, CSR[5:1] must not be altered. | | | LPTMR is disabled and internal logic is reset. | | | 1 LPTMR is enabled. | ## 33.3.2 Low Power Timer Prescale Register (LPTMR\_PSR) Address: 4003\_C000h base + 4h offset = 4003\_C004h ## LPTMR\_PSR field descriptions | Field | Description | | | |------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | 31–7<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | | | 6–3 | Prescale Value | | | | PRESCALE | Configures the size of the Prescaler in Time Counter mode or width of the glitch filter in Pulse Counter mode. PRESCALE must be altered only 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. | | | | | O010 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 16,384; glitch filter recognizes change on input pin after 8192 rising clock edges. | | | | | Prescaler divides the prescaler clock by 32,768; glitch filter recognizes change on input pin after 16,384 rising clock edges. | | | | | Prescaler divides the prescaler clock by 65,536; glitch filter recognizes change on input pin after 32,768 rising clock edges. | | | | 2<br>PBYP | Prescaler Bypass | | | | | When PBYP is set, the selected prescaler clock in Time Counter mode or selected input source in Pulse Counter mode directly clocks the CNR. When PBYP is clear, the CNR is clocked by the output of the prescaler/glitch filter. PBYP must be altered only when the LPTMR is disabled. | | | | | <ul><li>0 Prescaler/glitch filter is enabled.</li><li>1 Prescaler/glitch filter is bypassed.</li></ul> | | | | 1–0 | Prescaler Clock Select | | | | PCS | Selects the clock to be used by the LPTMR prescaler/glitch filter. PCS must be altered only when the LPTMR is disabled. The clock connections vary by device. | | | | | NOTE: See the chip configuration details for information on the connections to these inputs. | | | Table continues on the next page... #### wemory map and register definition #### LPTMR\_PSR field descriptions (continued) | Field | | Description | | | |-------|----|-------------------------------------------|--|--| | | 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. | | | ## 33.3.3 Low Power Timer Compare Register (LPTMR\_CMR) Address: 4003\_C000h base + 8h offset = 4003\_C008h #### LPTMR\_CMR field descriptions | Field | Description | |-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31–16<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 15–0<br>COMPARE | Compare Value When the LPTMR is enabled and the CNR equals the value in the CMR and increments, TCF is set and the hardware trigger asserts until the next time the CNR increments. If the CMR is 0, the hardware trigger will remain asserted until the LPTMR is disabled. If the LPTMR is enabled, the CMR must be altered only when TCF is set. | ## 33.3.4 Low Power Timer Counter Register (LPTMR\_CNR) Address: 4003\_C000h base + Ch offset = 4003\_C00Ch #### LPTMR\_CNR field descriptions | Field | Description | |-----------------|--------------------------------------------------------------| | 31–16 | This field is reserved. | | Reserved | This read-only field is reserved and always has the value 0. | | 15–0<br>COUNTER | Counter Value | | | The CNR returns the current value of the LPTMR counter. | ## 33.4 Functional description ## 33.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 must be disabled before entering the mode. The LPTMR is reset only on global Power On Reset (POR) or Low Voltage Detect (LVD). When configuring the LPTMR registers, the CSR must be initially written with the timer disabled, before configuring the PSR and CMR. Then, CSR[TIE] must 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. ## 33.4.2 LPTMR clocking The LPTMR prescaler/glitch filter can be clocked by one of the four clocks. The clock source must 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 CNR 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. #### NOTE The clock source or pulse input source selected for the LPTMR should not exceed the frequency f<sub>LPTMR</sub> defined in the device datasheet. ## 33.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. #### NOTE The prescaler/glitch filter configuration must not be altered when the LPTMR is enabled. #### 33.4.3.1 Prescaler enabled In Time Counter mode, when the prescaler is enabled, the output of the prescaler directly clocks the CNR. When the LPTMR is enabled, the CNR will increment every $2^2$ to $2^{16}$ prescaler clock cycles. After the LPTMR is enabled, the first increment of the CNR will take an additional one or two prescaler clock cycles due to synchronization logic. #### 33.4.3.2 Prescaler bypassed In Time Counter mode, when the prescaler is bypassed, the selected prescaler clock increments the CNR 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. #### 33.4.3.3 Glitch filter In Pulse Counter mode, when the glitch filter is enabled, the output of the glitch filter directly clocks the CNR. When the LPTMR is first enabled, the output of the glitch filter is asserted, that is, logic 1 for active-high and logic 0 for active-low. The following table shows the change in glitch filter output with the selected input source. | If | Then | |--------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------| | The selected input source remains deasserted for at least 2 <sup>1</sup> to 2 <sup>15</sup> consecutive prescaler clock rising edges | The glitch filter output will also deassert. | | The selected input source remains asserted for at least 2 <sup>1</sup> to 2 <sup>15</sup> consecutive prescaler clock rising-edges | The glitch filter output will also assert. | #### NOTE The input is only sampled on the rising clock edge. The CNR will increment each time the glitch filter output asserts. In Pulse Counter mode, the maximum rate at which the CNR can increment is once every $2^2$ to $2^{16}$ prescaler clock edges. When first enabled, the glitch filter will wait an additional one or two prescaler clock edges due to synchronization logic. #### 33.4.3.4 Glitch filter bypassed In Pulse Counter mode, when the glitch filter is bypassed, the selected input source increments the CNR every time it asserts. Before the LPTMR is first enabled, the selected input source is forced to be asserted. This prevents the CNR from incrementing if the selected input source is already asserted when the LPTMR is first enabled. ## 33.4.4 LPTMR compare When the CNR equals the value of the CMR and increments, the following events occur: - CSR[TCF] is set. - LPTMR interrupt is generated if CSR[TIE] is also set. - LPTMR hardware trigger is generated. - CNR is reset if CSR[TFC] is clear. When the LPTMR is enabled, the CMR can be altered only when CSR[TCF] is set. When updating the CMR, the CMR must be written and CSR[TCF] must be cleared before the LPTMR counter has incremented past the new LPTMR compare value. #### 33.4.5 LPTMR counter The CNR increments by one on every: - Prescaler clock in Time Counter mode with prescaler bypassed - Prescaler output in Time Counter mode with prescaler enabled - Input source assertion in Pulse Counter mode with glitch filter bypassed - Glitch filter output in Pulse Counter mode with glitch filter enabled The CNR is reset when the LPTMR is disabled or if the counter register overflows. If CSR[TFC] is cleared, then the CNR is also reset whenever CSR[TCF] is set. The CNR continues incrementing when the core is halted in Debug mode when configured for Pulse Counter mode, the CNR will stop incrementing when the core is halted in Debug mode when configured for Time Counter mode. The CNR cannot be initialized, but can be read at any time. On each read of the CNR, software must first write to the CNR with any value. This will synchronize and register the current value of the CNR into a temporary register. The contents of the temporary register are returned on each read of the CNR. When reading the CNR, 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. ## 33.4.6 LPTMR hardware trigger The LPTMR hardware trigger asserts at the same time the CSR[TCF] is set and can be used to trigger hardware events in other peripherals without software intervention. The hardware trigger is always enabled. | When | Then | |-----------------------------------------------------------|------------------------------------------------------------------------------------------------------------| | The CMR is set to 0 with CSR[TFC] clear | The LPTMR hardware trigger will assert on the first compare and does not deassert. | | The CMR is set to a nonzero value, or, if CSR[TFC] is set | The LPTMR hardware trigger will assert on each compare and deassert on the following increment of the CNR. | ## 33.4.7 LPTMR interrupt The LPTMR interrupt is generated whenever CSR[TIE] and CSR[TCF] are set. CSR[TCF] is cleared by disabling the LPTMR or by writing a logic 1 to it. CSR[TIE] can be altered and 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. # **Chapter 34 Periodic Interrupt Timer (PIT)** ### 34.1 Introduction #### **NOTE** For the chip-specific implementation details of this module's instances, see the chip configuration information. The PIT module is an array of timers that can be used to raise interrupts and trigger DMA channels. ## 34.1.1 Block diagram The following figure shows the block diagram of the PIT module. KM Family Reference Manual, Rev. 5, Oct 2013 625 #### orginal description Figure 34-1. Block diagram of the PIT #### NOTE See the chip configuration details for the number of PIT channels used in this MCU. ## 34.1.2 Features The main features of this block are: - Ability of timers to generate DMA trigger pulses - Ability of timers to generate interrupts - Maskable interrupts - Independent timeout periods for each timer ## 34.2 Signal description The PIT module has no external pins. ## 34.3 Memory map/register description This section provides a detailed description of all registers accessible in the PIT module. - Reserved registers will read as 0, writes will have no effect. - See the chip configuration details for the number of PIT channels used in this MCU. #### **PIT memory map** | Absolute<br>address<br>(hex) | Register name | Width<br>(in bits) | Access | Reset value | Section/<br>page | | |------------------------------|-------------------------------------------|--------------------|--------|-------------|------------------|--| | 4002_D000 | PIT Module Control Register (PIT0_MCR) | 32 | R/W | 0000_0000h | 34.3.1/627 | | | 4002_D100 | Timer Load Value Register (PIT0_LDVAL0) | 32 | R/W | 0000_0000h | 34.3.2/629 | | | 4002_D104 | Current Timer Value Register (PIT0_CVAL0) | 32 | R | 0000_0000h | 34.3.3/629 | | | 4002_D108 | Timer Control Register (PIT0_TCTRL0) | 32 | R/W | 0000_0000h | 34.3.4/630 | | | 4002_D10C | Timer Flag Register (PIT0_TFLG0) | 32 | R/W | 0000_0000h | 34.3.5/631 | | | 4002_D110 | Timer Load Value Register (PIT0_LDVAL1) | 32 | R/W | 0000_0000h | 34.3.2/629 | | | 4002_D114 | Current Timer Value Register (PIT0_CVAL1) | 32 | R | 0000_0000h | 34.3.3/629 | | | 4002_D118 | Timer Control Register (PIT0_TCTRL1) | 32 | R/W | 0000_0000h | 34.3.4/630 | | | 4002_D11C | Timer Flag Register (PIT0_TFLG1) | 32 | R/W | 0000_0000h | 34.3.5/631 | | | 4002_E000 | PIT Module Control Register (PIT1_MCR) | 32 | R/W | 0000_0000h | 34.3.1/627 | | | 4002_E100 | Timer Load Value Register (PIT1_LDVAL0) | 32 | R/W | 0000_0000h | 34.3.2/629 | | | 4002_E104 | Current Timer Value Register (PIT1_CVAL0) | 32 | R | 0000_0000h | 34.3.3/629 | | | 4002_E108 | Timer Control Register (PIT1_TCTRL0) | 32 | R/W | 0000_0000h | 34.3.4/630 | | | 4002_E10C | Timer Flag Register (PIT1_TFLG0) | 32 | R/W | 0000_0000h | 34.3.5/631 | | | 4002_E110 | Timer Load Value Register (PIT1_LDVAL1) | 32 | R/W | 0000_0000h | 34.3.2/629 | | | 4002_E114 | Current Timer Value Register (PIT1_CVAL1) | 32 | R | 0000_0000h | 34.3.3/629 | | | 4002_E118 | Timer Control Register (PIT1_TCTRL1) | 32 | R/W | 0000_0000h | 34.3.4/630 | | | 4002_E11C | Timer Flag Register (PIT1_TFLG1) | 32 | R/W | 0000_0000h | 34.3.5/631 | | ### 34.3.1 PIT Module Control Register (PITx\_MCR) This register enables or disables the PIT timer clocks and controls the timers when the PIT enters the Debug mode. #### wemory map/register description #### PITx\_MCR field descriptions | Field | Description | | | | | | | |------------------|------------------------------------------------------------------------------------------|--|--|--|--|--|--| | 31–3<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | | | | | | | 2<br>Reserved | This field is reserved. | | | | | | | | 1<br>MDIS | Module Disable - (PIT section) | | | | | | | | | Disables the standard timers. This field must be enabled before any other setup is done. | | | | | | | | | 0 Clock for standard PIT timers is enabled. | | | | | | | | | 1 Clock for standard PIT timers is disabled. | | | | | | | | 0<br>FRZ | Freeze | | | | | | | | | Allows the timers to be stopped when the device enters the Debug mode. | | | | | | | | | 0 Timers continue to run in Debug mode. | | | | | | | | | 1 Timers are stopped in Debug mode. | | | | | | | ## 34.3.2 Timer Load Value Register (PITx\_LDVALn) These registers select the timeout period for the timer interrupts. Address: Base address + 100h offset + (16d × i), where i=0d to 1d #### PITx\_LDVALn field descriptions | Field | Description | |-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | Timer Start Value Sets the timer start value. The timer will count down until it reaches 0, then it will generate an interrupt and load this register value again. Writing a new value to this register will not restart the timer; instead the value will be loaded after the timer expires. To abort the current cycle and start a timer period with the new value, the timer must be disabled and enabled again. | ## 34.3.3 Current Timer Value Register (PITx\_CVALn) These registers indicate the current timer position. Address: Base address + 104h offset + (16d × i), where i=0d to 1d #### PITx\_CVALn field descriptions | Field | Description | |-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | Current Timer Value Represents the current timer value, if the timer is enabled. NOTE: • If the timer is disabled, do not use this field as its value is unreliable. • The timer uses a downcounter. The timer values are frozen in Debug mode if MCR[FRZ] is set. | ## 34.3.4 Timer Control Register (PITx\_TCTRLn) These registers contain the control bits for each timer. Address: Base address + 108h offset + (16d $\times$ i), where i=0d to 1d #### PITx\_TCTRLn field descriptions | Field | Description | |------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31–3<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 2<br>CHN | Chain Mode When activated, Timer n-1 needs to expire before timer n can decrement by 1. Timer 0 cannot be chained. Timer is not chained. Timer is chained to previous timer. For example, for Channel 2, if this field is set, Timer 2 is chained to Timer 1. | | 1<br>TIE | Timer Interrupt Enable When an interrupt is pending, or, TFLGn[TIF] is set, enabling the interrupt will immediately cause an interrupt event. To avoid this, the associated TFLGn[TIF] must be cleared first. O Interrupt requests from Timer n are disabled. Interrupt will be requested whenever TIF is set. | | 0<br>TEN | Timer Enable Enables or disables the timer. 0 Timer n is disabled. 1 Timer n is enabled. | 631 ## 34.3.5 Timer Flag Register (PITx\_TFLGn) These registers hold the PIT interrupt flags. #### PITx\_TFLGn field descriptions | Field | Description | |------------------|----------------------------------------------------------------------------------------------------------------------------------------| | 31–1<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 0<br>TIF | Timer Interrupt Flag Sets to 1 at the end of the timer period. Writing 1 to this flag clears it. Writing 0 has no effect. If enabled, | | | or, when TCTRLn[TIE] = 1, TIF causes an interrupt request. 0 Timeout has not yet occurred. | | | 1 Timeout has occurred. | ## 34.4 Functional description This section provides the functional description of the module. ## 34.4.1 General operation This section gives detailed information on the internal operation of the module. Each timer can be used to generate trigger pulses and interrupts. Each interrupt is available on a separate interrupt line. runctional description #### 34.4.1.1 Timers The timers generate triggers at periodic intervals, when enabled. The timers load the start values as specified in their LDVAL registers, count down to 0 and then load the respective start value again. Each time a timer reaches 0, it will generate a trigger pulse and set the interrupt flag. All interrupts can be enabled or masked by setting TCTRLn[TIE]. A new interrupt can be generated only after the previous one is cleared. If desired, the current counter value of the timer can be read via the CVAL registers. The counter period can be restarted, by first disabling, and then enabling the timer with TCTRLn[TEN]. See the following figure. Figure 34-41. Stopping and starting a timer The counter period of a running timer can be modified, by first disabling the timer, setting a new load value, and then enabling the timer again. See the following figure. Figure 34-42. Modifying running timer period It is also possible to change the counter period without restarting the timer by writing LDVAL with the new load value. This value will then be loaded after the next trigger event. See the following figure. Figure 34-43. Dynamically setting a new load value #### 34.4.1.2 **Debug mode** In Debug mode, the timers will be frozen based on MCR[FRZ]. This is intended to aid software development, allowing the developer to halt the processor, investigate the current state of the system, for example, the timer values, and then continue the operation. ## 34.4.2 Interrupts All the timers support interrupt generation. See the MCU specification for related vector addresses and priorities. Timer interrupts can be enabled by setting TCTRLn[TIE]. TFLGn[TIF] are set to 1 when a timeout occurs on the associated timer, and are cleared to 0 by writing a 1 to the corresponding TFLGn[TIF]. ## 34.4.3 Chained timers When a timer has chain mode enabled, it will only count after the previous timer has expired. So if timer n-1 has counted down to 0, counter n will decrement the value by one. This allows to chain some of the timers together to form a longer timer. The first timer (timer 0) cannot be chained to any other timer. ## 34.5 Initialization and application information In the example configuration: • The PIT clock has a frequency of 50 MHz. #### **Example configuration for chained timers** - Timer 1 creates an interrupt every 5.12 ms. - Timer 3 creates a trigger event every 30 ms. The PIT module must be activated by writing a 0 to MCR[MDIS]. The 50 MHz clock frequency equates to a clock period of 20 ns. Timer 1 needs to trigger every 5.12 ms/20 ns = 256,000 cycles and Timer 3 every 30 ms/20 ns = 1,500,000 cycles. The value for the LDVAL register trigger is calculated as: LDVAL trigger = (period / clock period) -1 This means LDVAL1 and LDVAL3 must be written with 0x0003E7FF and 0x0016E35F respectively. The interrupt for Timer 1 is enabled by setting TCTRL1[TIE]. The timer is started by writing 1 to TCTRL1[TEN]. Timer 3 shall be used only for triggering. Therefore, Timer 3 is started by writing a 1 to TCTRL3[TEN]. TCTRL3[TIE] stays at 0. The following example code matches the described setup: ``` // turn on PIT PIT_MCR = 0x00; // Timer 1 PIT_LDVAL1 = 0x0003E7FF; // setup timer 1 for 256000 cycles PIT_TCTRL1 = TIE; // enable Timer 1 interrupts PIT_TCTRL1 |= TEN; // start Timer 1 // Timer 3 PIT_LDVAL3 = 0x0016E35F; // setup timer 3 for 1500000 cycles PIT_TCTRL3 |= TEN; // start Timer 3 ``` ## 34.6 Example configuration for chained timers In the example configuration: - The PIT clock has a frequency of 100 MHz. - Timers 1 and 2 are available. - An interrupt shall be raised every 1 hour. The PIT module needs to be activated by writing a 0 to MCR[MDIS]. The 100 MHz clock frequency equates to a clock period of 10 ns, so the PIT needs to count for 6000 million cycles, which is more than a single timer can do. So, Timer 1 is set up to trigger every 6 s (600 million cycles). Timer 2 is chained to Timer 1 and programmed to trigger 10 times. The value for the LDVAL register trigger is calculated as number of cycles-1, so LDVAL1 receives the value 0x23C345FF and LDVAL2 receives the value 0x00000009. The interrupt for Timer 2 is enabled by setting TCTRL2[TIE], the Chain mode is activated by setting TCTRL2[CHN], and the timer is started by writing a 1 to TCTRL2[TEN]. TCTRL1[TEN] needs to be set, and TCTRL1[CHN] and TCTRL1[TIE] are cleared. The following example code matches the described setup: ``` // turn on PIT PIT_MCR = 0x00; // Timer 2 PIT_LDVAL2 = 0x00000009; // setup Timer 2 for 10 counts PIT_TCTRL2 = TIE; // enable Timer 2 interrupt PIT_TCTRL2 |= CHN; // chain Timer 2 to Timer 1 PIT_TCTRL2 |= TEN; // start Timer 2 // Timer 1 PIT_LDVAL1 = 0x23C345FF; // setup Timer 1 for 600 000 000 cycles PIT_TCTRL1 = TEN; // start Timer 1 ``` Example configuration for chained timers ## **Chapter 35 Quad Timer (TMR)** #### 35.1 Overview Each timer module (TMR) contains four identical counter/timer groups. Each 16-bit counter/timer group contains a prescaler, a counter, a load register, a hold register, a capture register, two compare registers, two status and control registers, and one control register. All of the registers except the prescaler are read/writable. #### NOTE This document uses the terms "Timer" and "Counter" interchangeably because the counter/timers may perform either or both tasks. The load register provides the initialization value to the counter when the counter's terminal value has been reached. The hold register captures the counter's value when other counters are being read. This feature supports the reading of cascaded counters. The capture register enables an external signal to take a "snap shot" of the counter's current value. The COMP1 and COMP2 registers provide the values to which the counter is compared. If a match occurs, the OFLAG (TMR Output signal) can be set, cleared, or toggled. At match time, an interrupt is generated if enabled, and the new compare value is loaded into the COMP1 or COMP2 registers from CMPLD1 and CMPLD2 if enabled. The prescaler provides different time bases useful for clocking the counter/timer. The counter provides the ability to count internal or external events. Within a timer module (set of four timer/counters), the input pins are shareable. #### 35.2 Features The TMR module design includes these distinctive features: - Four 16-bit counters/timers - Count up/down - Counters are cascadable - Programmable count modulo - Max count rate equals peripheral clock/2 for external clocks - Max count rate equals peripheral clock for internal clocks - Count once or repeatedly - Counters are preloadable - Compare registers are preloadable (available with compare load feature) - Counters can share available input pins - Separate prescaler for each counter - Each counter has capture and compare capability - Programmable operation during debug mode - Inputs may act as fault inputs - Programmable input filter - Counting start can be synchronized across counters ## 35.3 Modes of Operation The TMR module design operates in only a single mode of operation: Functional Mode. The various counting modes are detailed in the Functional Description. ## 35.4 Block Diagram Each of the timer/counter groups within the quad-timer are shown in this figure. Figure 35-1. Quad Timer Block Diagram ## 35.5 Memory Map and Registers 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 and the address offset is defined at the module level. Make certain to check which quad timer is available on the chip being used, and which timer channels have external I/O. #### **NOTE** One TMR\_ENBL register per module (four channels). Hence, TMR0\_ENBL is applicable. Ignore TMR1\_ENBL, TMR2\_ENBL, and TMR3\_ENBL. #### TMR memory map | Absolute<br>address<br>(hex) | Register name | Width<br>(in bits) | Access | Reset value | Section/<br>page | | |------------------------------|-----------------------------------------------|--------------------|--------|-------------|------------------|--| | 4005_7000 | Timer Channel Compare Register 1 (TMR0_COMP1) | 16 | R/W | 0000h | 35.5.1/641 | | | 4005_7002 | Timer Channel Compare Register 2 (TMR0_COMP2) | 16 | R/W | 0000h | 35.5.2/642 | | | 4005_7004 | Timer Channel Capture Register (TMR0_CAPT) | 16 | R/W | 0000h | 35.5.3/642 | | | 4005_7006 | Timer Channel Load Register (TMR0_LOAD) | 16 | R/W | 0000h | 35.5.4/642 | | Table continues on the next page... #### wemory Map and Registers ## TMR memory map (continued) | Absolute<br>address<br>(hex) | Register name | Width<br>(in bits) | Access | Reset value | Section/<br>page | |------------------------------|--------------------------------------------------------------------|--------------------|--------|-------------|------------------| | 4005_7008 | Timer Channel Hold Register (TMR0_HOLD) | 16 | R/W | 0000h | 35.5.5/643 | | 4005_700A | Timer Channel Counter Register (TMR0_CNTR) | 16 | R/W | 0000h | 35.5.6/643 | | 4005_700C | Timer Channel Control Register (TMR0_CTRL) | 16 | R/W | 0000h | 35.5.7/643 | | 4005_700E | Timer Channel Status and Control Register (TMR0_SCTRL) | 16 | R/W | 0100h | 35.5.8/646 | | 4005_7010 | Timer Channel Comparator Load Register 1 (TMR0_CMPLD1) | 16 | R/W | 0000h | 35.5.9/647 | | 4005_7012 | Timer Channel Comparator Load Register 2 (TMR0_CMPLD2) | 16 | R/W | 0000h | 35.5.10/<br>648 | | 4005_7014 | Timer Channel Comparator Status and Control Register (TMR0_CSCTRL) | 16 | R/W | 0000h | 35.5.11/<br>648 | | 4005_7016 | Timer Channel Input Filter Register (TMR0_FILT) | 16 | R/W | 0000h | 35.5.12/<br>650 | | 4005_701E | Timer Channel Enable Register (TMR0_ENBL) | 16 | R/W | 000Fh | 35.5.13/<br>651 | | 4005_8000 | Timer Channel Compare Register 1 (TMR1_COMP1) | 16 | R/W | 0000h | 35.5.1/641 | | 4005_8002 | Timer Channel Compare Register 2 (TMR1_COMP2) | 16 | R/W | 0000h | 35.5.2/642 | | 4005_8004 | Timer Channel Capture Register (TMR1_CAPT) | 16 | R/W | 0000h | 35.5.3/642 | | 4005_8006 | Timer Channel Load Register (TMR1_LOAD) | 16 | R/W | 0000h | 35.5.4/642 | | 4005_8008 | Timer Channel Hold Register (TMR1_HOLD) | 16 | R/W | 0000h | 35.5.5/643 | | 4005_800A | Timer Channel Counter Register (TMR1_CNTR) | 16 | R/W | 0000h | 35.5.6/643 | | 4005_800C | Timer Channel Control Register (TMR1_CTRL) | 16 | R/W | 0000h | 35.5.7/643 | | 4005_800E | Timer Channel Status and Control Register (TMR1_SCTRL) | 16 | R/W | 0100h | 35.5.8/646 | | 4005_8010 | Timer Channel Comparator Load Register 1 (TMR1_CMPLD1) | 16 | R/W | 0000h | 35.5.9/647 | | 4005_8012 | Timer Channel Comparator Load Register 2 (TMR1_CMPLD2) | 16 | R/W | 0000h | 35.5.10/<br>648 | | 4005_8014 | Timer Channel Comparator Status and Control Register (TMR1_CSCTRL) | 16 | R/W | 0000h | 35.5.11/<br>648 | | 4005_8016 | Timer Channel Input Filter Register (TMR1_FILT) | 16 | R/W | 0000h | 35.5.12/<br>650 | | 4005_801E | Timer Channel Enable Register (TMR1_ENBL) | 16 | R/W | 000Fh | 35.5.13/<br>651 | | 4005_9000 | Timer Channel Compare Register 1 (TMR2_COMP1) | 16 | R/W | 0000h | 35.5.1/641 | | 4005_9002 | Timer Channel Compare Register 2 (TMR2_COMP2) | 16 | R/W | 0000h | 35.5.2/642 | | 4005_9004 | Timer Channel Capture Register (TMR2_CAPT) | 16 | R/W | 0000h | 35.5.3/642 | | 4005_9006 | Timer Channel Load Register (TMR2_LOAD) | 16 | R/W | 0000h | 35.5.4/642 | | 4005_9008 | Timer Channel Hold Register (TMR2_HOLD) | 16 | R/W | 0000h | 35.5.5/643 | | 4005_900A | Timer Channel Counter Register (TMR2_CNTR) | 16 | R/W | 0000h | 35.5.6/643 | | 4005_900C | Timer Channel Control Register (TMR2_CTRL) | 16 | R/W | 0000h | 35.5.7/643 | | 4005_900E | Timer Channel Status and Control Register (TMR2_SCTRL) | 16 | R/W | 0100h | 35.5.8/646 | Table continues on the next page... #### TMR memory map (continued) | Absolute<br>address<br>(hex) | Register name | Width<br>(in bits) | Access | Reset value | Section/<br>page | | |------------------------------|--------------------------------------------------------------------|--------------------|--------|-------------|------------------|--| | 4005_9010 | Timer Channel Comparator Load Register 1 (TMR2_CMPLD1) | 16 | R/W | 0000h | 35.5.9/647 | | | 4005_9012 | Timer Channel Comparator Load Register 2 (TMR2_CMPLD2) | 16 | R/W | 0000h | 35.5.10/<br>648 | | | 4005_9014 | Timer Channel Comparator Status and Control Register (TMR2_CSCTRL) | 16 | R/W | 0000h | 35.5.11/<br>648 | | | 4005_9016 | Timer Channel Input Filter Register (TMR2_FILT) | 16 | R/W | 0000h | 35.5.12/<br>650 | | | 4005_901E | Timer Channel Enable Register (TMR2_ENBL) | 16 | R/W | 000Fh | 35.5.13/<br>651 | | | 4005_A000 | Timer Channel Compare Register 1 (TMR3_COMP1) | 16 | R/W | 0000h | 35.5.1/641 | | | 4005_A002 | Timer Channel Compare Register 2 (TMR3_COMP2) | 16 | R/W | 0000h | 35.5.2/642 | | | 4005_A004 | Timer Channel Capture Register (TMR3_CAPT) | 16 | R/W | 0000h | 35.5.3/642 | | | 4005_A006 | Timer Channel Load Register (TMR3_LOAD) | 16 | R/W | 0000h | 35.5.4/642 | | | 4005_A008 | Timer Channel Hold Register (TMR3_HOLD) | 16 | R/W | 0000h | 35.5.5/643 | | | 4005_A00A | Timer Channel Counter Register (TMR3_CNTR) | 16 | R/W | 0000h | 35.5.6/643 | | | 4005_A00C | Timer Channel Control Register (TMR3_CTRL) | 16 | R/W | 0000h | 35.5.7/643 | | | 4005_A00E | Timer Channel Status and Control Register (TMR3_SCTRL) | 16 | R/W | 0100h | 35.5.8/646 | | | 4005_A010 | Timer Channel Comparator Load Register 1 (TMR3_CMPLD1) | 16 | R/W | 0000h | 35.5.9/647 | | | 4005_A012 | Timer Channel Comparator Load Register 2 (TMR3_CMPLD2) | 16 | R/W | 0000h | 35.5.10/<br>648 | | | 4005_A014 | Timer Channel Comparator Status and Control Register (TMR3_CSCTRL) | 16 | R/W | 0000h | 35.5.11/<br>648 | | | 4005_A016 | Timer Channel Input Filter Register (TMR3_FILT) | 16 | R/W | 0000h | 35.5.12/<br>650 | | | 4005_A01E | Timer Channel Enable Register (TMR3_ENBL) | 16 | R/W | 000Fh | 35.5.13/<br>651 | | ## 35.5.1 Timer Channel Compare Register 1 (TMRx\_COMP1) Address: Base address + 0h offset #### TMRx\_COMP1 field descriptions | Field | Description | |-----------------|--------------------------------------------------------------------------------------------------------| | | Comparison Value 1 | | OMPARISON_<br>1 | This read/write register stores the value used for comparison with the counter value in count up mode. | ## 35.5.2 Timer Channel Compare Register 2 (TMRx\_COMP2) Address: Base address + 2h offset | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|--------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| | Read<br>Write | COMPARISON_2 | | | | | | | | | | | | | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | #### TMRx\_COMP2 field descriptions | Field | Description | | |-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|--| | COMPARISON_ | Comparison Value 2 This read/write register stores the value used for comparison with the counter value in count down mode or alternating compare mode. | | ## 35.5.3 Timer Channel Capture Register (TMRx\_CAPT) Address: Base address + 4h offset | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|----|----|----|----|----|----|---|------|------|---|---|---|---|---|---|---| | Read [<br>Write | | | | | | | | CAPT | TURE | | | | | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | #### TMRx\_CAPT field descriptions | Field | Description | |---------|----------------------------------------------------------------------| | 15-0 | Capture Value | | CAPTURE | This read/write register stores the value captured from the counter. | ## 35.5.4 Timer Channel Load Register (TMRx\_LOAD) Address: Base address + 6h offset | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|----|----|----|----|----|----|---|----|----|---|---|---|---|---|---|---| | Read<br>Write | | | | | | | | LO | AD | | | | | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | #### TMRx\_LOAD field descriptions | Field | Description | |--------------|-------------------------------------------------------------------------------------------------------------| | 15–0<br>LOAD | Timer Load Register | | | This read/write register stores the value used to initialize the counter after counter compare or overflow. | ## 35.5.5 Timer Channel Hold Register (TMRx\_HOLD) Address: Base address + 8h offset | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------|----|----|----|----|----|----|---|----|----|---|---|---|---|---|---|---| | Read Write | | | | | | | | НО | LD | | | | | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | #### TMRx\_HOLD field descriptions | Field | Description | |--------------|--------------------------------------------------------------------------------------------------------------------------------------| | 15–0<br>HOLD | This read/write register stores the counter's values of specific channels whenever any of the four counters within a module is read. | ## 35.5.6 Timer Channel Counter Register (TMRx\_CNTR) Address: Base address + Ah offset | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|----|----|----|----|----|----|---|-----|------|---|---|---|---|---|---|---| | Read<br>Write | | | | | | • | | COU | NTER | | | | | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | #### TMRx\_CNTR field descriptions | Field | Description | |-----------------|------------------------------------------------------------------------------------------| | 15-0<br>COUNTER | This read/write register is the counter for the corresponding channel in a timer module. | ## 35.5.7 Timer Channel Control Register (TMRx\_CTRL) Address: Base address + Ch offset #### TMRx\_CTRL field descriptions | Field | Description | |-------|--------------------------------------------------------------------| | 15–13 | Count Mode | | CM | These bits control the basic counting and behavior of the counter. | Table continues on the next page... #### KM Family Reference Manual, Rev. 5, Oct 2013 Freescale Semiconductor, Inc. Preliminary 643 #### wemory Map and Registers ## TMRx\_CTRL field descriptions (continued) | Field | Description | |-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | 000 No operation | | | 001 Count rising edges of primary source <sup>1</sup> | | | 010 Count rising and falling edges of primary source <sup>2</sup> | | | 011 Count rising edges of primary source while secondary input high active | | | 100 Quadrature count mode, uses primary and secondary sources | | | 101 Count rising edges of primary source; secondary source specifies direction <sup>3</sup> | | | 110 Edge of secondary source triggers primary count until compare | | | 111 Cascaded counter mode (up/down) <sup>4</sup> | | 12–9 | Primary Count Source | | PCS | These bits select the primary count source. | | | NOTE: A timer selecting its own output for input is not a legal choice. The result is no counting. | | | 0000 Counter 0 input pin | | | 0001 Counter 1 input pin | | | 0010 Counter 2 input pin | | | 0011 Counter 3 input pin | | | 0100 Counter 0 output | | | 0101 Counter 1 output | | | 0110 Counter 2 output | | | 0111 Counter 3 output | | | 1000 IP bus clock divide by 1 prescaler | | | 1001 IP bus clock divide by 2 prescaler | | | 1010 IP bus clock divide by 4 prescaler | | | 1011 IP bus clock divide by 8 prescaler | | | 1100 IP bus clock divide by 16 prescaler | | | 1101 IP bus clock divide by 32 prescaler | | | 1110 IP bus clock divide by 64 prescaler | | | 1111 IP bus clock divide by 128 prescaler | | 8–7 | Secondary Count Source | | SCS | These bits identify the external input pin to be used as a count command or timer command. The selected input can trigger the timer to capture the current value of CNTR. The selected input can also be used to specify the count direction. The selected signal can also be used as a fault input when CSCTRL[FAULT] is set. The polarity of the signal can be inverted by SCTRL[IPS]. | | | 00 Counter 0 input pin | | | 01 Counter 1 input pin | | | 10 Counter 2 input pin | | | 11 Counter 3 input pin | | 6 | Count Once | | ONCE | This bit selects continuous or one shot counting mode. | | | 0 Count repeatedly. | | | 1 Count until compare and then stop. If counting up, a successful compare occurs when the counter reaches a COMP1 value. If counting down, a successful compare occurs when the counter reaches a COMP2 value. When output mode \$4 is used, the counter re-initializes after reaching the COMP1 value, continues to count to the COMP2 value, and then stops. | Table continues on the next page... #### TMRx\_CTRL field descriptions (continued) | Field | Description | |----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 5<br>LENGTH | <ul> <li>Count Length</li> <li>This bit determines whether the counter: <ul> <li>counts to the compare value and then re-initializes itself to the value specified in the LOAD (or CMPLD2) register, or</li> <li>continues counting past the compare value to the binary roll over.</li> </ul> </li> <li>Roll over.</li> <li>Count until compare, then re-initialize. If counting up, a successful compare occurs when the counter reaches a COMP1 value. If counting down, a successful compare occurs when the counter reaches a COMP2 value. When output mode \$4 is used, alternating values of COMP1 and COMP2 are used to generate successful comparisons. For example, the counter counts until a COMP1 value is reached, re-initializes, counts until COMP2 value is reached, re-initializes, counts until COMP1 value is reached, and so on.</li> </ul> | | 4<br>DIR | Count Direction This bit selects either the normal count direction up, or the reverse direction, down. Count up. Count down. | | 3<br>COINIT | Co-Channel Initialization This bit enables another counter/timer within the module to force the re-initialization of this counter/timer when it has an active compare event. O Co-channel counter/timers cannot force a re-initialization of this counter/timer Co-channel counter/timers may force a re-initialization of this counter/timer | | 2–0<br>OUTMODE | Output Mode These bits determine the mode of operation for the OFLAG output signal. OOO Asserted while counter is active OO1 Clear OFLAG output on successful compare O10 Set OFLAG output on successful compare O11 Toggle OFLAG output on successful compare 100 Toggle OFLAG output using alternating compare registers 101 Set on compare, cleared on secondary source input edge 110 Set on compare, cleared on counter rollover 111 Enable gated clock output while counter is active | - 1. Rising edges are counted only when SCTRL[IPS] = 0. Falling edges are counted when SCTRL[IPS] = 1. If the primary count source is IP bus clock divide by 1, only rising edges are counted regardless of the value of SCTRL[IPS]. - 2. IP bus clock divide by 1 cannot be used as a primary count source in edge count mode. - 3. Rising edges are counted only when SCTRL[IPS] = 0. Falling edges are counted when SCTRL[IPS] = 1. - 4. The primary count source must be set to one of the counter outputs. ## 35.5.8 Timer Channel Status and Control Register (TMRx\_SCTRL) Address: Base address + Eh offset | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |-------|-----------|--------|------|-------|--------|-------|------|-------| | Read | TCF TCFIE | | TQ. | TOFIE | I.E.E. | IEEIE | ID C | INPUT | | Write | | | TOF | TOFIE | IEF | IEFIE | IPS | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Read | OARTUR | E MODE | мотр | FFOF | \ | 0 | 0.00 | OFN | | Write | CAPTUR | E_MODE | MSTR | EEOF | VAL | FORCE | OPS | OEN | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | #### TMRx\_SCTRL field descriptions | Field | Description | |-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15 | Timer Compare Flag | | TCF | This bit is set when a successful compare occurs. This bit is cleared by writing a zero to this bit location. | | 14 | Timer Compare Flag Interrupt Enable | | TCFIE | This bit (when set) enables interrupts when TCF is set. | | 13 | Timer Overflow Flag | | TOF | This bit is set when the counter rolls over its maximum value \$FFFF or \$0000 (depending on count direction). This bit is cleared by writing a zero to this bit location. | | 12 | Timer Overflow Flag Interrupt Enable | | TOFIE | This bit (when set) enables interrupts when TOF is set. | | 11 | Input Edge Flag | | IEF | This bit is set when CAPTMODE is enabled and a proper input transition occurs (on an input selected as a secondary count source) while the count mode does not equal 000. This bit is cleared by writing a zero to this bit position. | | | NOTE: Setting the input polarity select bit (IPS) changes the edge to be detected. Also, the control register's secondary count source determines which external input pin is monitored by the detection circuitry. | | 10 | Input Edge Flag Interrupt Enable | | IEFIE | This bit (when set) enables interrupts when IEF is set. | | 9 | Input Polarity Select | | IPS | This bit (when set) inverts the input signal polarity. | | 8 | External Input Signal | | INPUT | This read only bit reflects the current state of the external input pin selected via the secondary count source after application of IPS and filtering. | | 7–6<br>CAPTURE_<br>MODE | Input Capture Mode | Table continues on the next page... ## TMRx\_SCTRL field descriptions (continued) | Field | Description | |------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | These bits specify the operation of the capture register as well as the operation of the input edge flag. The input source is the secondary count source. | | | 00 Capture function is disabled 01 Load capture register on rising edge (when IPS=0) or falling edge (when IPS=1) of input | | | <ul> <li>Load capture register on falling edge (when IPS=0) or rising edge (when IPS=1) of input</li> <li>Load capture register on both edges of input</li> </ul> | | 5<br>MSTR | Master Mode This bit (when set) enables the compare function's output to be broadcasted to the other counters/timers in the module. This signal then can be used to re-initialize the other counters and/or force their OFLAG signal outputs. | | 4<br>EEOF | Enable External OFLAG Force This bit (when set) enables the compare from another counter/timer within the same module to force the state of this counter's OFLAG output signal. | | 3<br>VAL | Forced OFLAG Value This bit determines the value of the OFLAG output signal when software triggers a FORCE command. | | 2<br>FORCE | Force OFLAG Output This write only bit forces the current value of VAL to be written to the OFLAG output. This bit always reads as a zero. VAL and FORCE can be written simultaneously in a single write operation. Write to FORCE only if the counter is disabled. Setting this bit while the counter is enabled may yield unpredictable results. | | 1<br>OPS | Output Polarity Select This bit determines the polarity of the OFLAG output signal. 0 True polarity. 1 Inverted polarity. | | 0<br>OEN | Output Enable This bit determines the direction of the external pin. | | | <ul> <li>The external pin is configured as an input.</li> <li>The OFLAG output signal is driven on the external pin. Other timer groups using this external pin as their input see the driven value. The polarity of the signal is determined by OPS.</li> </ul> | ## 35.5.9 Timer Channel Comparator Load Register 1 (TMRx\_CMPLD1) Address: Base address + 10h offset | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|----|----|----|----|----|----|-----|-------|-------|------|---|---|---|---|---|---| | Read<br>Write | | | | | | | COM | PARAT | OR_LO | AD_1 | | | | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | #### wemory Map and Registers #### TMRx\_CMPLD1 field descriptions | Field | Description | |-------------------------------|------------------------------------------------------------------------------------------------------------------------------------| | 15-0<br>COMPARATOR_<br>LOAD_1 | This read/write register is the comparator 1 preload value for the COMP1 register for the corresponding channel in a timer module. | ## 35.5.10 Timer Channel Comparator Load Register 2 (TMRx\_CMPLD2) Address: Base address + 12h offset | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|----|----|----|----|----|----|-----|-------|-------|------|---|---|---|---|---|---| | Read<br>Write | | | | | | | COM | PARAT | OR_LO | AD_2 | | | | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ## TMRx\_CMPLD2 field descriptions | Field | Description | |-------|------------------------------------------------------------------------------------------------------------------------------------| | | This read/write register is the comparator 2 preload value for the COMP2 register for the corresponding channel in a timer module. | ## 35.5.11 Timer Channel Comparator Status and Control Register (TMRx\_CSCTRL) Address: Base address + 14h offset #### TMRx\_CSCTRL field descriptions | Field | Description | |-----------------|---------------------------------------------------------------------------------------------------------| | 15–14<br>DBG EN | Debug Actions Enable | | 550_2.1 | These bits allow the TMR module to perform certain actions in response to the chip entering debug mode. | | | 00 Continue with normal operation during debug mode. (default) 01 Halt TMR counter during debug mode. | Table continues on the next page... #### KM Family Reference Manual, Rev. 5, Oct 2013 648 Preliminary Freescale Semiconductor, Inc. # TMRx\_CSCTRL field descriptions (continued) | Field | Description | | | | | |-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | | 10 Force TMR output to logic 0 (prior to consideration of SCTRL[OPS]). | | | | | | | 11 Both halt counter and force output to 0 during debug mode. | | | | | | 13<br>FAULT | Fault Enable | | | | | | 17.021 | The selected secondary input acts as a fault signal so that the timer OFLAG is cleared when the secondary input is set. When the secondary input is used in this mode, there is no resynchronization of the input so that there is a combinational path to clear the OFLAG. Fault inputs less than two clock periods wide will not be latched. Latched faults will be cleared the next time that the counter logic sets the OFLAG. | | | | | | | 0 Fault function disabled. | | | | | | | 1 Fault function enabled. | | | | | | 12 | Alternative Load Enable | | | | | | ALT_LOAD | This bit allows for an alternative method for loading the counter during modulo counting. Normally, the counter can be loaded only with the value from the LOAD register. When this bit is set, the counter is loaded from the LOAD register when counting up and a match with COMP1 occurs, or the counter is loaded from the CMPLD2 register when counting down and a match with COMP2 occurs. | | | | | | | 0 Counter can be re-initialized only with the LOAD register. | | | | | | | 1 Counter can be re-initialized with the LOAD or CMPLD2 registers depending on count direction. | | | | | | 11<br>ROC | Reload on Capture | | | | | | | This bit enables the capture function to cause the counter to be reloaded from the LOAD register. | | | | | | | 0 Do not reload the counter on a capture event. | | | | | | | 1 Reload the counter on a capture event. | | | | | | 10 | Triggered Count Initialization Control | | | | | | TCI | This bit is used during triggered count mode, CTRL[CM] = 110, to enable the counter to be re-initialized when a second trigger occurs while the counter is still counting. Normally, the second trigger causes the counting to stop/pause until a third trigger occurs. With this bit set, a second trigger event causes the counter to re-initialize and continue counting. | | | | | | | O Stop counter upon receiving a second trigger event while still counting from the first trigger event. | | | | | | | 1 Reload the counter upon receiving a second trigger event while still counting from the first trigger event. | | | | | | 9 | Counting Direction Indicator | | | | | | UP | This read-only bit is used during quadrature count mode, CTRL[CM] = 100, to read the direction of the last count. CTRL[DIR] reverses the sense of this bit. | | | | | | | 0 The last count was in the DOWN direction. | | | | | | | 1 The last count was in the UP direction. | | | | | | 8 | This field is reserved. | | | | | | Reserved | This read-only field is reserved and always has the value 0. | | | | | | 7<br>TCF2EN | Timer Compare 2 Interrupt Enable | | | | | | | An interrupt is issued when both this bit and TCF2 are set. | | | | | | 6<br>TCF1EN | Timer Compare 1 Interrupt Enable | | | | | | | An interrupt is issued when both this bit and TCF1 are set. | | | | | Table continues on the next page... #### wemory Map and Registers #### TMRx\_CSCTRL field descriptions (continued) | Field | Description | | | | | | |------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | 5<br>TCF2 | Timer Compare 2 Interrupt Flag When set, this bit indicates a successful comparison of the timer and the COMP2 register has occurred. This bit is sticky, and will remain set until explicitly cleared by writing a zero to this bit location. | | | | | | | 4<br>TCF1 | Timer Compare 1 Interrupt Flag When set, this bit indicates a successful comparison of the timer and the the COMP1 register has occurred. This bit is sticky, and will remain set until explicitly cleared by writing a zero to this bit location. | | | | | | | 3–2<br>CL2 | Compare Load Control 2 These bits control when COMP2 is preloaded with the value from CMPLD2. 00 Never preload 01 Load upon successful compare with the value in COMP1 10 Load upon successful compare with the value in COMP2 11 Reserved | | | | | | | 1–0<br>CL1 | Compare Load Control 1 These bits control when COMP1 is preloaded with the value from CMPLD1. ON Never preload Load upon successful compare with the value in COMP1 Load upon successful compare with the value in COMP2 Reserved | | | | | | # 35.5.12 Timer Channel Input Filter Register (TMRx\_FILT) Input filter considerations: - Set the FILT\_PER value such that the sampling period is larger than the period of the expected noise. In this way, a noise spike will corrupt only one sample. Choose the FILT\_CNT value to reduce the probability that noisy samples cause an incorrect transition to be recognized. The probability of an incorrect transistion is defined as the probability of an incorrect sample raised to the power of (FILT\_CNT + 3). - The values of FILT\_PER and FILT\_CNT must also be balanced against the desire for minimal latency in recognizing input transitions. Turning on the input filter (setting FILT\_PER to a non-zero value) introduces a latency of (((FILT\_CNT + 3) x FILT\_PER) + 2) IP bus clock periods. Address: Base address + 16h offset # TMRx\_FILT field descriptions | Field | Description | |-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15–11<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 10-8<br>FILT_CNT | Input Filter Sample Count These bits represent the number of consecutive samples that must agree prior to the input filter accepting an input transition. A value of 0x0 represents 3 samples. A value of 0x7 represents 10 samples. The value of FILT_CNT affects the input latency. | | 7–0<br>FILT_PER | Input Filter Sample Period These bits represent the sampling period (in IP bus clock cycles) of the TMR input signals. Each input is sampled multiple times at the rate specified by this field. If FILT_PER is 0x00 (default), then the input filter is bypassed. The value of FILT_PER affects the input latency. When changing values for FILT_PER from one non-zero value to another non-zero value, write a value of zero first to clear the filter. | # 35.5.13 Timer Channel Enable Register (TMRx\_ENBL) #### TMRx\_ENBL field descriptions | Field | Description | |------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15–4<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 3–0<br>ENBL | Timer Channel Enable These bits enable the prescaler (if it is being used) and counter in each channel. Multiple ENBL bits can be set at the same time to synchronize the start of separate counters. If an ENBL bit is set, then the corresponding channel starts its counter as soon as the CTRL[CM] field has a value other than 0. When an ENBL bit is clear, the corresponding counter maintains its current value. 0 Timer channel is disabled. 1 Timer channel is enabled. (default) | # 35.6 Functional Description #### 35.6.1 General The counter/timer has two basic modes of operation: it can count internal or external events, or it can count an internal clock source while an external input signal is asserted, thus timing the width of the external input signal. - The counter can count the rising, falling, or both edges of the selected input pin. - The counter can decode and count quadrature encoded input signals. - The counter can count up and down using dual inputs in a "count with direction" format. - The counter's terminal count value (modulo) is programmable. - The value that is loaded into the counter after reaching its terminal count is programmable. - The counter can count repeatedly, or it can stop after completing one count cycle. - The counter can be programmed to count to a programmed value and then immediately reinitialize, or it can count through the compare value until the count "rolls over" to zero. The external inputs to each counter/timer are shareable among each of the four counter/timers within the module. The external inputs can be used as: - Count commands - Timer commands - They can trigger the current counter value to be "captured" - They can be used to generate interrupt requests The polarity of the external inputs are selectable. The primary output of each timer/counter is the output signal OFLAG. The OFLAG output signal can be: • Set, cleared, or toggled when the counter reaches the programmed value. - The OFLAG output signal may be output to an external pin instead of having that pin serve as a timer input. - The OFLAG output signal enables each counter to generate square waves, PWM, or pulse stream outputs. - The polarity of the OFLAG output signal is selectable. Any counter/timer can be assigned as a master. A master's compare signal can be broadcast to the other counter/timers within the module. The other counters can be configured to reinitialize their counters and/or force their OFLAG output signals to predetermined values when a master's counter/timer compare event occurs. # 35.6.2 Usage of Compare Registers The dual compare registers (COMP1 and COMP2) provide a bidirectional modulo count capability. The COMP1 register is used when the counter is *counting up*, and the COMP2 register is used when the counter is *counting down*. Alternating compare mode is the only exception. The COMP1 register should be set to the desired maximum count value or FFFFh to indicate the maximum unsigned value prior to roll-over, and the COMP2 register should be set to the minimum count value or 0000h to indicate the minimum unsigned value prior to roll-under. If CTRL[OUTMODE] is set to 100, the OFLAG will toggle while using alternating compare registers. In this variable frequency PWM mode, the COMP2 value defines the desired pulse width of the on time, and the COMP1 register defines the off time. Use caution when changing COMP1 and COMP2 while the counter is active. If the counter has already passed the new value, it will count to FFFFh or 0000h, roll over, then begin counting toward the new value. The check is: Count=CMPx, *not* Count > COMP1 or Count < COMP2. The use of the CMPLD1 and CMPLD2 registers to compare values will help to minimize this problem. # 35.6.3 Usage of Compare Load Registers The CMPLD1, CMPLD2, and CSCTRL registers offer a high degree of flexibility for loading compare registers with user-defined values on different compare events. To ensure correct functionality while using these registers we strongly suggest using the following method described in this section. The purpose of the compare load feature is to allow quicker updating of the compare registers. In the past, a compare register could be updated using interrupts. However, because of the latency between an interrupt event occurring and the service of that interrupt, there was the possibility that the counter may have already counted past the new compare value by the time the compare register was updated by the interrupt service routine. The counter would then continue counting until it rolled over and reached the new compare value. To address this, the compare registers are now updated in hardware in the same way the counter register is re-initialized to the value stored in the load register. The compare load feature allows the user to calculate new compare values and store them in to the comparator load registers. When a compare event occurs, the new compare values in the comparator load registers are written to the compare registers eliminating the use of software to do this. The compare load feature is intended to be used in variable frequency PWM mode. The COMP1 register determines the pulse width for the logic low part of OFLAG and COMP2 determines the pulse width for the logic high part of OFLAG. The period of the waveform is determined by the COMP1 and COMP2 values and the frequency of the primary clock source. See the following figure. Figure 35-67. Variable PWM Waveform Should we desire to update the duty cycle or period of the above waveform, we would need to update the COMP1 and COMP2 values using the compare load feature. # 35.6.4 Usage of the Capture Register The capture register stores a copy of the counter's value when an input edge (positive, negative, or both) is detected. After a capture event occurs, no further updating of the capture register will occur until the SCTRL[IEF] (input edge flag) is cleared by writing a zero to the SCTRL[IEF]. #### 35.6.5 Functional Modes The selected external count signals are sampled at the TMR's base clock rate and then run through a transition detector. The maximum count rate is one-half of the TMR's base clock rate. Internal clock sources can be used to clock the counters at the TMR's base clock rate. If a counter is programmed to count to a specific value and then stop, the CTRL[CM] field is cleared when the count terminates. # 35.6.5.1 Stop Mode If CTRL[CM] is set to '000', the counter is inert. No counting will occur. Stop mode will also disable the interrupts caused by input transitions on a selected input pin. #### 35.6.5.2 Count Mode If CTRL[CM] is set to '001', the counter will count the rising edges of the selected clock source. This mode is useful for generating periodic interrupts for timing purposes, or counting external events such as "widgets" on a conveyor belt passing a sensor. If the selected input is inverted by setting SCTRL[IPS] (input polarity select), then the negative edge of the selected external input signal is counted. **Example: 35.6.5.2.1 Count Pulses from External Source** #### **runctional Description** ``` (See Processor Expert PulseAccumulator bean.) This example uses TMRA1 to count pulse (actually counts rising edges of the pulse) // from an external source (TA3). // void Pulse Init(void) /* TMRA1 CTRL: CM=0, PCS=3, SCS=0, ONCE=0, LENGTH=0, DIR=0, Co_INIT=0, OM=0 */ setReg(TMRA1 CTRL, 0x0600); /* Set up mode */ /* TMRA1 SCTRL: TCF=0,TCFIE=0,TOF=0,TOFIE=0,IEF=0,IEFIE=0,IPS=0,INPUT=0, Capture_Mode=0,MSTR=0,EEOF=0,VAL=0,FORCE=0,OPS=0,OEN=0 */ setReg(TMRA1_SCTRL,0x00); setReg(TMRA1 CNTR, 0x00); /* Reset counter register */ /* Reset load register */ setReg(TMRA1 LOAD, 0x00); setRegBitGroup(TMRA1_CTRL,CM,0x01); /* Run counter */ ``` # Example: 35.6.5.2.2 Generate Periodic Interrupt By Counting Internal Clocks ``` (See Processor Expert TimerInt bean.) This example generates an interrupt every 100ms, // assuming the chip is operating at 60 MHz. // // It does this by using the IP_bus_clk divided by 128 as the counter clock source. // The counter then counts to 46874 where it matches the COMP1 value. // At that time an interrupt is generated, the counter is reloaded and // the next COMP1 value is loaded from CMPLD1. void TimerInt_Init(void) /* TMRAO CTRL: CM=0,PCS=0,SCS=0,ONCE=0,LENGTH=1,DIR=0,Co INIT=0,OM=0 */ setReg(TMRA0_CTRL,0x20); /* Stop all functions of the timer */ /* TMRAO_SCTRL: TCF=0,TCFIE=0,TOF=0,TOFIE=0,IEF=0,IEFIE=0,IPS=0,INPUT=0, Capture Mode=0, MSTR=0, EEOF=0, VAL=0, FORCE=0, OPS=0, OEN=0 */ setReg(TMRA0_SCTRL,0x00); setReg(TMRA0_LOAD,0x00); /* Reset load register */ setReg(TMRA0_COMP1,46874); /* Set up compare 1 register */ setReg(TMRA0_CMPLD1,46874); /* Also set the compare preload /* Also set the compare preload register */ /* TMRAO CSCTRL: ??=0,??=0,??=0,??=0,??=0,??=0,??=0,TCF2EN=0,TCF1EN=1, TCF2=0, TCF1=0, CL2=0, CL1=1 */ /* Enable compare 1 interrupt and */ setReg(TMRA0 CSCTRL,0x41); /* compare 1 preload */ setRegBitGroup(TMRA0_CTRL,PCS,0xF); /* Primary Count Source to IP_bus_clk / 128 */ /* Reset counter register */ setReg(TMRA0_CNTR,0x00); setRegBitGroup(TMRA0_CTRL,CM,0x01); /* Run counter */ ``` # 35.6.5.3 Edge-Count Mode If CTRL[CM] is set to '010', the counter will count both edges of the selected external clock source. This mode is useful for counting the changes in the external environment, such as a simple encoder wheel. #### Example: 35.6.5.3.1 Count Both Edges of External Source Signal ``` (See Processor Expert PulseAccumulator bean.) This example uses TMRA1 to count pulse (actually counts rising edges of the pulse) // from an external source (TA3). // void Pulse Init (void) /* TMRA1_CTRL: CM=0,PCS=3,SCS=0,ONCE=0,LENGTH=0,DIR=0,Co_INIT=0,OM=0 */ setReg(TMRA1 CTRL, 0x0600); /* Set up mode */ /* TMRA1 SCTRL: TCF=0,TCFIE=0,TOF=0,TOFIE=0,IEF=0,IEFIE=0,IPS=0,INPUT=0, Capture Mode=0, MSTR=0, EEOF=0, VAL=0, FORCE=0, OPS=0, OEN=0 */ setReg(TMRA1_SCTRL,0x00); setReg(TMRA1_CNTR,0x00); /* Reset counter register */ /* Reset load register */ setReg(TMRA1 LOAD,0x00); setRegBitGroup(TMRA1_CTRL,CM,0x02); /* Run counter */ ``` #### 35.6.5.4 Gated-Count Mode If CTRL[CM] is set to '011', the counter will count while the selected secondary input signal is high. This mode is used to time the duration of external events. If the selected input is inverted by setting SCTRL[IPS] (input polarity select), then the counter will count while the selected secondary input is low. #### **Example: 35.6.5.4.1 Capture Duration of External Pulse** ``` (See Processor Expert PulseAccumulator bean.) This example uses TMRA1 to determine the duration of an external pulse. // // The IP bus clock is used as the primary counter. If the duration of the // external pulse is longer than 0.001 seconds one of the other IP bus clock // dividers can be used. If the pulse duration is longer than 0.128 seconds an external clock source will have to be used as the primary clock source. // void Pulsel Init(void) /* TMRA1_CTRL: CM=0,PCS=8,SCS=1,ONCE=0,LENGTH=0,DIR=0,Co_INIT=0,OM=0 */ setReg(TMRA1_CTRL,0x1080); /* Set up mode */ /* TMRA1 SCTRL: TCF=0, TCFIE=0, TOF=0, TOFIE=0, IEF=0, IEFIE=0, IPS=0, INPUT=0, Capture_Mode=0,MSTR=0,EEOF=0,VAL=0,FORCE=0,OPS=0,OEN=0 */ setReg(TMRA1_SCTRL,0x00); setReg(TMRA1 CNTR,0x00); /* Reset counter register */ /* Reset load register */ setReg(TMRA1_LOAD,0x00); setRegBitGroup(TMRA1_CTRL,CM,0x03); /* Run counter */ ``` #### 35.6.5.5 **Quadrature-Count Mode** If CTRL[CM] is set to '100', the counter will decode the primary and secondary external inputs as quadrature encoded signals. Quadrature signals are usually generated by rotary or linear sensors used to monitor movement of motor shafts or mechanical equipment. The quadrature signals are square waves that are 90 degrees out of phase. The decoding of quadrature signal provides both count and direction information. This figure shows a timing diagram illustrating the basic operation of a quadrature incremental position encoder. Figure 35-68. Quadrature Incremental Position Encoder #### **Example: 35.6.5.5.1 Quadrature Count Mode Example** ``` (See Processor Expert PulseAccumulator bean.) // This example uses TMRAO for counting states of a quadrature position encoder. // Timer input 0 is used as the primary count source (PHASEA). // Timer input 1 is used as the secondary count source (PHASEB). // void Pulse Init (void) /* TMRAO_CTRL: CM=0,PCS=0,SCS=1,ONCE=0,LENGTH=0,DIR=0,Co_INIT=0,OM=0 */ setReg(TMRC0 CTRL, 0x80); /* Set up mode */ /* TMRAO SCTRL: TCF=0,TCFIE=0,TOF=0,TOFIE=0,IEF=0,IEFIE=0,IPS=0,INPUT=0, Capture Mode=0, MSTR=0, EEOF=0, VAL=0, FORCE=0, OPS=0, OEN=0 */ setReg(TMRA0 SCTRL, 0 \times \overline{00}); setReg(TMRA0_CNTR,0x00); /* Reset counter register */ setReg(TMRA0_LOAD,0x00); /* Reset load register */ setReg(TMRA0_LOAD, 0xFFFFF); setReg(TMRA0_COMP1,0xFFFFF); /* Set up compare 1 register */ setReg(TMRA0_COMP2,0x00); /* Set up compare 2 register */ /* TMRAO CSCTRL: ??=0,??=0,??=0,??=0,??=0,??=0,??=0, TCF2EN=0, TCF1EN=0, TCF2=0, TCF1=0, CL2=0, CL1=0 */ setReg(TMRA0 CSCTRL,0x00); setRegBitGroup(TMRA0_CTRL,CM,0x04); /* Run counter */ ``` # 35.6.5.6 Quadrature-Count Mode with Index Input As an extension to the quadrature count mode discussed in the previous paragraph, some rotary shafts have a HOME or INDEX indicator. This would be a third input to the timer that is used to reset the timer's counter. In this example, channel 0 is used to decode the quadrature inputs, but it doesn't actually count. Because its upper and lower limits are both set to 0, its output is cascaded count up and count down signals each time the quadrature inputs indicate a change in count. Channel 1 works in cascaded count mode receiving its counting instructions from channel 0. When an input capture event occurs, channel 1 is programmed to reset its counter value. The channel 1 counter contains the position value for the shaft. #### **Example: 35.6.5.6.1 Quadrature Count Mode with Index Input Example** ``` (See Processor Expert PulseAccumulator bean.) // This example uses TMRA0 and TMRA1 for counting states of a quadrature position encoder. // Timer input 0 is used as the primary count source (PHASEA). // Timer input 1 is used as the secondary count source (PHASEB). // Timer input 2 is used as the index input source (INDEX). void Pulse Init(void) /* TMRA0_CTRL: CM=0,PCS=0,SCS=1,ONCE=0,LENGTH=1,DIR=0,Co_INIT=0,OM=0 */ setReg(TMRA0_CTRL,0xA0); /* Set up mode */ /* TMRAO SCTRL: TCF=0,TCFIE=0,TOF=0,TOFIE=0,IEF=0,IEFIE=0,IPS=0,INPUT=0, Capture_Mode=0,MSTR=0,EEOF=0,VAL=0,FORCE=0,OPS=0,OEN=0 */ setReg(TMRA0 SCTRL, 0 \times \overline{00}); /* Reset counter register */ setReg(TMRA0 CNTR,0x00); /* Reset load register */ setReg(TMRA0_LOAD,0x00); setReg(TMRA0_COMP1,0x00); /* Set up compare 1 register */ setReg(TMRA0_COMP2,0x00); /* Set up compare 2 register */ /* TMRAO CSCTRL: ??=0,??=0,??=0,??=0,??=0,??=0,??=0, TCF2EN=0, TCF1EN=0, TCF2=0, TCF1=0, CL2=0, CL1=0 */ setReg(TMRA0 CSCTRL,0x00); /* TMRA1 CTRL: CM=7,PCS=100,SCS=2,ONCE=0,LENGTH=0,DIR=0,Co INIT=0,OM=0 */ setReg(TMRA1_CTRL, 0xEA00); /* Set up capture edge */ /* TMRA1_SCTRL: Capture_Mode=10 */ setReg(TMRA1 SCTRL, 0x0080); /* TMRA1 CSTRL: ROC=1 */ setReg(TMRA1 CTRL, 0x0800); /* Set up reload on capture */ setRegBitGroup(TMRA0 CTRL, CM, 0x04); /* Run counter */ ``` # 35.6.5.7 Signed-Count Mode If CTRL[CM] is set to '101', the counter counts the primary clock source while the selected secondary source provides the selected count direction (up/down). #### **Example: 35.6.5.7.1 Signed Count Mode Example** ``` (See Processor Expert PulseAccumulator bean.) This example uses TMRAO for signed mode counting. // Timer input 2 is used as the primary count source. Timer input 1 is used to determine the count direction. // // void Pulse Init (void) /* TMRA0 CTRL: CM=0,PCS=2,SCS=1,ONCE=0,LENGTH=0,DIR=0,Co INIT=0,OM=0 */ setReg(TMRA0 CTRL, 0x0480); /* Set up mode */ /* TMRAO_SCTRL: TCF=0,TCFIE=0,TOF=0,TOFIE=1,IEF=0,IEFIE=0,IPS=0,INPUT=0, Capture_Mode=0,MSTR=0,EEOF=0,VAL=0,FORCE=0,OPS=0,OEN=0 */ setReg(TMRA0 SCTRL, 0x\overline{1000}); setReg(TMRA0 CNTR,0x00); /* Reset counter register */ setReg(TMRA0_LOAD,0x00); /* Reset load register */ setRegBitGroup(TMRA0 CTRL,CM,0x05); /* Run counter */ ``` # 35.6.5.8 Triggered-Count Mode 1 If CSCTRL[TCI] is clear and CTRL[CM] is set to '110', the counter will begin counting the primary clock source after a positive transition (negative edge if SCTRL[IPS]=1) of the secondary input occurs. The counting will continue until a compare event occurs or another positive input transition is detected. If a second input transition occurs before a terminal count is reached, counting will stop and SCTRL[TCF] (timer compare flag) will be set. Subsequent secondary input transitions will continue to restart and stop the counting until a compare event occurs. Figure 35-69. Triggered Count Mode 1 (CTRL[LENGTH]=0) **Example: 35.6.5.8.1 Triggered Count Mode 1 Example** ``` (See Processor Expert PulseAccumulator bean.) This example uses TMRA1 for triggered mode counting. // // Timer input 3 is used as the primary count source. Timer input 2 is used for the trigger input. // void Pulse_Init(void) /* TMRA1 CTRL: CM=0,PCS=3,SCS=2,ONCE=0,LENGTH=0,DIR=0,Co_INIT=0,OM=0 */ setReg(TMRA1_CTRL,0x0700); /* Set up mode */ /* TMRA1_SCTRL: TCF=0,TCFIE=0,TOF=0,TOFIE=1,IEF=0,IEFIE=0,IPS=0,INPUT=0, Capture Mode=0, MSTR=0, EEOF=0, VAL=0, FORCE=0, OPS=0, OEN=0 */ setReg(TMRA1 SCTRL, 0x1000); setReg(TMRA1 CNTR, 0x00); /* Reset counter register */ /* Reset load register */ setReg(TMRA1_LOAD, 0x00); setReg(TMRA1_COMP1,0x0012); /* Set up compare 1 register */ /* TMRA1 CSCTRL: ??=0,??=0,??=0,??=0,??=0,??=0,??=0, TCF2EN=0, TCF1EN=0, TCF2=0, TCF1=0, CL2=0, CL1=0 */ setReg(TMRA1 CSCTRL,0x00); setReqBitGroup(TMRA1 CTRL,CM,0x06); /* Run counter */ ``` #### 35.6.5.9 Triggered-Count Mode 2 If CSCTRL[TCI] is set and CTRL[CM] is set to '110', the counter will begin counting the primary clock source after a positive transition (negative edge if SCTRL[IPS]=1) of the secondary input occurs. The counting will continue until a compare event occurs or another positive input transition is detected. If a second input transition occurs before a terminal count was reached, the counter will reload and continue counting. When CSCTRL[TCI] is set, the OFLAG output mode, CTRL[OUTMODE], should probably be set to '101' (cleared on init, set on compare) to ensure the output will be in a known state after the second input transition and subsequent reload takes place. Figure 35-70. Triggered Count Mode 2 (CTRL[LENGTH]=0) **Example: 35.6.5.9.1 Triggered Count Mode 2Example** #### **runctional Description** ``` (See Processor Expert PulseAccumulator bean.) // This example uses TMRA1 for triggered mode counting. // // Timer input 3 is used as the primary count source. Timer input 2 is used for the trigger input. // void Pulse_Init(void) /* TMRA1 CTRL: CM=0,PCS=3,SCS=2,ONCE=0,LENGTH=0,DIR=0,Co INIT=0,OM=0 */ setReg(TMRA1 CTRL, 0x0700); /* Set up mode */ /* TMRA1 SCTRL: TCF=0,TCFIE=0,TOF=0,TOFIE=1,IEF=0,IEFIE=0,IPS=0,INPUT=0, Capture Mode=0, MSTR=0, EEOF=0, VAL=0, FORCE=0, OPS=0, OEN=0 */ setReg(TMRA1 SCTRL,0x1000); setReg(TMRA1 CNTR, 0x00); /* Reset counter register */ setReg(TMRA1_LOAD,0x00); /* Reset load register */ setReg(TMRA1_COMP1,0x0012); /* Set up compare 1 register */ \texttt{TCF2EN=0}, \texttt{TCF1EN=0}, \texttt{TCF2=0}, \texttt{TCF1=0}, \texttt{CL2=0}, \texttt{CL1=0} */ setReg(TMRA1 CSCTRL, 0x00); setRegBitGroup(TMRA1_CTRL,CM,0x06); /* Run counter */ ``` #### 35.6.5.10 One-Shot Mode If CTRL[CM] is set to '110', and the counter is set to reinitialize at a compare event (CTRL[LENGTH]=1),and CTRL[OUTMODE] is set to '101' (cleared on init, set on compare), the counter works in a one-shot mode. An external event causes the counter to count, and when the terminal count is reached, the output is asserted. This delayed output can be used to provide timing delays. Figure 35-71. One-Shot Mode (CTRL[LENGTH]=1) Example: 35.6.5.10.1 One-Shot Mode Example 663 ``` (See Processor Expert PulseAccumulator bean.) This example uses TMRA1 for one-shot mode counting. // Timer input 3 is used as the primary count source. Timer input 2 is used for the trigger input. // void Pulse_Init(void) /* TMRA1 CTRL: CM=0,PCS=3,SCS=2,ONCE=0,LENGTH=0,DIR=0,Co_INIT=0,OM=5 */ setReg(TMRA1_CTRL,0x0725); /* Set up mode */ /* TMRA1_SCTRL: TCF=0,TCFIE=0,TOF=0,TOFIE=1,IEF=0,IEFIE=0,IPS=0,INPUT=0, Capture Mode=0, MSTR=0, EEOF=0, VAL=0, FORCE=0, OPS=0, OEN=0 */ setReg(TMRA1 SCTRL,0x1000); setReg(TMRA1_CNTR,0x00); /* Reset counter register */ setReg(TMRA1_LOAD,0x00); /* Reset load register */ setReg(TMRA1_COMP1,0x0004); /* Set up compare 1 register */ /* TMRA1_CSCTRL: ??=0,??=0,??=0,??=0,??=0,??=0,??=0, TCF2EN=0, TCF1EN=0, TCF2=0, TCF1=0, CL2=0, CL1=0 */ setReg(TMRA1 CSCTRL,0x00); setRegBitGroup(TMRA1 CTRL, CM, 0x06); /* Run counter */ ``` #### 35.6.5.11 Cascade-Count Mode If CTRL[CM] is set to '111', the counter's input is connected to the output of another selected counter. The counter will count up and down as compare events occur in the selected source counter. This cascade or daisy-chained mode enables multiple counters to be cascaded to yield longer counter lengths. When operating in cascade mode, a special high-speed signal path is used between modules rather than the OFLAG output signal. If the selected source counter is counting up and it experiences a compare event, the counter will be incremented. If the selected source counter is counting down and it experiences a compare event, the counter will be decremented. Up to four counters may be cascaded to create a 64-bit wide synchronous counter. Check the data sheet to see if there are any frequency limits for cascaded counting mode. Whenever any counter is read within a counter module, all of the counters' values within the module are captured in their respective hold registers. This action supports the reading of a cascaded counter chain. First read any counter of a cascaded counter chain, then read the hold registers of the other counters in the chain. The cascaded counter mode is synchronous. #### **Note** It is possible to connect counters together by using the other (non-cascade) counter modes and selecting the outputs of other counters as a clock source. In this case, the counters are operating in a ripple mode, where higher order counters will transition a clock later than a purely synchronous design. #### **Example: 35.6.5.11.1 Generate Periodic Interrupt Cascading Two Counters** ``` (See Processor Expert TimerInt bean.) // This example generates an interrupt every 30 seconds, assuming the chip is operating at 60 MHz. // To do this, counter 2 is used to count 60,000 IP bus clocks, which means it will compare and reload every 0.001 seconds. // // Counter 3 is cascaded and used to count the 0.001 second ticks and generate the desired interrupt interval. // void TimerInt_Init(void) // Set counter 2 to count IP_bus clocks /* TMRA2 CTRL: CM=0,PCS=8,SCS=0,ONCE=0,LENGTH=1,DIR=0,Co_INIT=0,OM=0 */ setReg(TMRA2 CTRL, 0x1020); /* Stop all functions of the timer */ // Set counter 3 as cascaded and to count counter 2 outputs /* TMRA3_CTRL: CM=7,PCS=6,SCS=0,ONCE=0,LENGTH=1,DIR=0,Co_INIT=0,OM=0 */ setReg(TMRA3 CTRL, 0xEC20); /* Set up cascade counter mode */ /* TMRA3 SCTRL: TCF=0,TCFIE=0,TOF=0,TOFIE=0,IEF=0,IEFIE=0,IPS=0,INPUT=0, Capture Mode=0, MSTR=0, EEOF=0, VAL=0, FORCE=0, OPS=0, OEN=0 */ setReg(TMRA3 SCTRL, 0x00); /* TMRA2 SCTRL: TCF=0,TCFIE=0,TOF=0,TOFIE=0,IEF=0,IEFIE=0,IPS=0,INPUT=0, Capture Mode=0, MSTR=0, EEOF=0, VAL=0, FORCE=0, OPS=0, OEN=0 */ setReg(TMRA2 SCTRL,0x00); setReg(TMRA3_CNTR,0x00); /* Reset counter register */ setReg(TMRA2_CNTR,0x00); /* Reset load register */ setReg(TMRA3_LOAD,0x00); setReg(TMRA2_LOAD, 0x00); setReg(TMRA3_COMP1, 30000); /* milliseconds in 30 seconds */ setReg(TMRA3 CMPLD1,30000); setReg(TMRA2_COMP1, 60000); // Set to cycle every milisecond setReg(TMRA2_CMPLD1,60000); /* TMRA3 CSCTRL: ??=0,??=0,??=0,??=0,??=0,??=0,??=0, TCF2EN=0, TCF1EN=1, TCF2=0, TCF1=0, CL2=0, CL1=1 */ setReg(TMRA3_CSCTRL,0x41); /* Enable compare 1 interrupt and */ /* compare 1 preload /* TMRA2 CSCTRL: ??=0,??=0,??=0,??=0,??=0,??=0,??=0, TCF2EN=0, TCF1EN=0, TCF2=0, TCF1=0, CL2=0, CL1=1 */ setReg(TMRA2_CSCTRL,0x01); /* Enable Compare 1 preload */ setRegBitGroup(TMRA2 CTRL,CM,0x01); /* Run counter */ ``` #### 35.6.5.12 Pulse-Output Mode If CTRL[CM]=001, and CTRL[OUTMODE] is set to 111' (gated clock output), and CTRL[ONCE] is set, then the counter will output a pulse stream of pulses that has the same frequency of the selected clock source, and the number of output pulses is equal to the compare value minus the init value. This mode is useful for driving step motor systems. #### **Note** This does not work if CTRL[PCS] is set to 1000 (IP\_bus/1). 665 Figure 35-72. Pulse Output Mode #### **Example: 35.6.5.12.1 Pulse Outputs Using Two Counters** ``` (See Processor Expert PulseStream bean.) // This example generates six 10ms pulses, from TA1 output. // Assuming the chip is operating at 60 MHz. // To do this, timer 3 is used to generate a clock with a period of 10ms. // Timer 1 is used to gate these clocks and count the number of pulses that have // been generated. // void PulseStream Init(void) // Select IP bus clk/16 as the clock source for Timer A3 /* TMRA3 CTRL: CM=0,PCS=0x0C,SCS=0,ONCE=0,LENGTH=1,DIR=0,Co INIT=0,OM=3 */ setReg(TMRA3_CTRL, 0x1823); /* Set up mode */ /* TMRA3 SCTRI: TCF=0,TCFIE=0,TOF=0,TOFIE=0,IEF=0,IEFIE=0,IPS=0,INPUT=0, Capture Mode=0, MSTR=0, EEOF=0, VAL=0, FORCE=0, OPS=0, OEN=0 */ setReg(TMRA3 SCTRL,0x00); setReg(TMRA3 LOAD, 0x00); /* Reset load register */ setReg(TMRA3 COMP1,37500); /* (16 * 37500 ) / 60e6 = 0.01 sec */ /* TMRA3 CSCTRL: ??=0,??=0,??=0,??=0,??=0,??=0,??=0, TCF2EN=0, TCF1EN=0, TCF2=0, TCF1=0, CL2=0, CL1=0 */ setReg(TMRA3 CSCTRL,0x00); /* Set up comparator control register */ // Timer 3 output is the clock source for this timer. /* TMRA1 CTRL: CM=0, PCS=7, SCS=0, ONCE=1, LENGTH=1, DIR=0, CO INIT=0, OM=7 */ setReg(TMRA1 CTRL, 0x0E67); /* Set up mode */ /* TMRA1_SCTRL: TCF=0,TCFIE=0,TOF=0,TOFIE=0,IEF=0,IEFIE=0,IPS=0,INPUT=0, Capture Mode=0, MSTR=0, EEOF=0, VAL=0, FORCE=0, OPS=0, OEN=1 */ setReg(TMRA1 SCTRL,0x01); setReg(TMRA1_CNTR,0x00); /* Reset counter register */ setReg(TMRA1_LOAD,0x00); setReg(TMRA1_COMP1,0x04); /* Reset load register */ /* Set up compare 1 register */ // set to interrupt after the last pulse TCF2EN=0, TCF1EN=1, TCF2=0, TCF1=0, CL2=0, CL1=0 */ setReg(TMRA1_CSCTRL,0x40); /* Set up comparator control register */ // Finally, start the counters running setReg(TMRA3 CNTR,0); /* Reset counter */ setRegBitGroup (TMRA3 CTRL, CM, 0x01); /* Run source clock counter */ setRegBitGroup(TMRA1 CTRL,CM,0x01); /* Run counter */ ``` #### 35.6.5.13 Fixed-Frequency PWM Mode If CTRL[CM]=001, count through roll-over (CTRL[LENGTH]=0), continuous count (CTRL[ONCE]=0) and CTRL[OUTMODE] is '110' (set on compare, cleared on counter roll-over), then the counter output yields a pulse-width modulated (PWM) signal with a frequency equal to the count clock frequency divided by 65,536 and a pulse-width duty cycle equal to the compare value divided by 65,536. This mode of operation is often used to drive PWM amplifiers used to power motors and inverters. #### **Example: 35.6.5.13.1 Fixed-Frequency PWM Mode Example** # 35.6.5.14 Variable-Frequency PWM Mode If CTRL[CM]=001, count until compare (CTRL[LENGTH]=1), continuous count (CTRL[ONCE] = 0) and CTRL[OUTMODE] is '100' (toggle OFLAG and alternate compare registers), then the counter output yields a pulse-width modulated (PWM) signal whose frequency and pulse width is determined by the values programmed into the COMP1 and COMP2 registers, and the input clock frequency. This method of PWM generation has the advantage of allowing almost any desired PWM frequency and/or constant on or off periods. This mode of operation is often used to drive PWM amplifiers used to power motors and inverters. The CMPLD1 and CMPLD2 registers are especially useful for this mode, as they allow the programmer time to calculate values for the next PWM cycle while the PWM current cycle is underway. To set up the TMR to run in variable frequency PWM mode with compare preload please use the following setup for the specific counter you would like to use. When performing the setup, update the TMR\_CTRL register last because the counter will start counting if the count mode is changed to any value other than 3'b000 (assuming the primary count source is already active). #### **Timer Control Register (CTRL)** - CM=3'b001 (count rising edges of primary source) - PCS=4'b1000 (IP bus clock for best granularity for waveform timing) - SCS=Any (ignored in this mode) - ONCE=1'b0 (want to count repeatedly) - LENGTH=1'b1 (want to count until compare value is reached and re-initialize counter register) - DIR=Any (user's choice. The compare register values must be chosen carefully to account for things like roll-under, etc.) - COINIT=1'b0 (user can set this if they need this function) - OUTMODE=3'b100 (toggle OFLAG output using alternating compare registers) ## Timer Status and Control Register (SCTRL) - OEN = 1'b1 (output enable to allow OFLAG output to be put on an external pin. Set this bit as needed.) - OPS = Any (user's choice) - Make sure the rest of the bits are cleared for this register. We will enable interrupts in the comparator status and control register instead of in this register. # **Comparator Status and Control Register (CSCTRL)** - TCF2EN=1'b1 (allow interrupt to be issued when CSCTRL[TCF2] is set) - TCF1EN=1'b0 (do not allow interrupt to be issued when CSCTRL[TCF1] is set) - TCF1=1'b0 (clear timer compare 1 interrupt source flag. This is set when counter register equals compare register 1 value and OFLAG is low) - TCF2=1'b0 (clear timer compare 2 interrupt source flag. This is set when counter register equals compare register 2 value and OFLAG is high) #### **runctional Description** - CL1=2'b10 (load compare register when CSCTRL[TCF2] is asserted) - CL2=2'b01 (load compare register when CSCTRL[TCF1] is asserted) #### **Interrupt Service Routines** To service the CSCTRL[TCF2] interrupts generated by the timer, the interrupt controller must be configured to enable the interrupts for the particular timer being used. Additionally the user will need to write an interrupt service routine to do at a minimum the following: - Clear CSCTRL[TCF2] and CSCTRL[TCF1] flags. - Calculate and write new values for both CMPLD1 and CMPLD2. #### **Timing** This figure contains the timing for using the compare preload feature. The compare preload cycle begins with a compare event on COMP2 causing CSCTRL[TCF2] to be asserted. COMP1 is loaded with the value in the CMPLD1 (c3) one IP bus clock later. In addition an interrupt is asserted by the timer and the interrupt service routine is executed during which both comparator load registers are updated with new values (c4 and c5). When CSCTRL[TCF1] is asserted, COMP2 is loaded with the value in CMPLD2 (c4). And on the subsequent CSCTRL[TCF2] event, COMP1 is loaded with the value in CMPLD1 (c5). The cycle starts over again as an interrupt is asserted and the interrupt service routine clears CSCTRL[TCF1] and CSCTRL[TCF2] and calculates new values for CMPLD1 and CMPLD2. - Step 1-- CNTR matches COMP2 value. CSCTRL[TCF2] is asserted and an interrupt request is generated. - Step 2-- One clock later, OFLAG toggles, CMPLD1 is copied to COMP1, LOAD is copied to CNTR, the counter starts counting. - Step 3-- The interrupt service routine clears CSCTRL[TCF1] and CSCTRL[TCF2] and the ISR loads CMPLD1 and CMPLD2 with the values for the next cycle. The counter continues counting until CNTR matches COMP1. - Step 4-- CSCTRL[TCF1] is asserted. One clock later, OFLAG toggles, CMPLD2 is copied to COMP2, LOAD is copied to CNTR and the counter starts counting. - Step 5--The counter continues counting until CNTR matches COMP2. Figure 35-73. Compare Load Timing **Example: 35.6.5.14.1 Variable Frequency PWM Mode** #### nesets ``` (See Processor Expert PPG [Programmable Pulse Generator] bean.) // This example starts with an 11 msec with a 31 msec cycle. // Assuming the chip is operating at 60 MHz, the timer use IP_bus_clk/32 as its clock source. // Initial pulse period: 60e6/32 clocks/sec * 31 ms = 58125 total clocks in period // Initial pulse width: 60e6/32 clocks/sec * 11 ms = 20625 clocks in pulse // // // Once the initial values of COMP1/CMPLD1 and COMP2/CMPLD2 are set the pulse width can be varied by load new values of CMPLD1 and CMPLD2 on each compare interrupt. // (See Usage of Compare Load Registers.) // void PPG1 Init(void) setReg(TMRA0_LOAD,0); /* Clear load register */ setReg(TMRA0 CNTR,0); /* Clear counter */ /* TMRAO SCTRL: TCF=0,TCFIE=0,TOF=0,TOFIE=0,IEF=0,IEFIE=0,IPS=0,INPUT=0, Capture Mode=0, MSTR=0, EEOF=0, VAL=0, FORCE=1, OPS=0, OEN=1 */ setReg(TMRA0 SCTRL,5); /* Set Status and Control Register */ // Set compare preload operation and enable an interrupt on compare2 events. /* TMRAO_CSCTRL: TCF2EN=1,TCF1EN=0,TCF2=0,TCF1=0,CL21=0,CL20=1,CL11=1,CL10=0 */ setReg(TMRA0 CSCTRL, 0x86); /* Set Comparator Status and Control Register */ setReg(TMRA0_COMP1,20625); /* Set the pulse width of the off time */ /* Set the pulse width of the off time */ setReg(TMRA0 CMPLD1, 20625); setReg(TMRA0 COMP2,58125-20625); /* Set the pulse width of the on time */ setReg(TMRA0_CMPLD2,58125-20625); /* Set the pulse width of the on time */ /* TMRA0_CTRL: CM=1,PCS=0xD,SCS=0,ONCE=0,LENGTH=1,DIR=0,Co_INIT=0,OM=4 */ setRegBits(TMRA0 CTRL,0x3A24); /* Set variable PWM mode and run counter */ ``` #### 35.7 Resets #### **35.7.1 General** The TMR module can be reset only by the RST\_B signal. This forces all registers to their reset state and clears the OFLAG signal if it is asserted. The counter will be turned off until the settings in the control register are changed. Table 35-71. Reset Summary | Reset | Priority | Source | Characteristics | |-------|----------|----------------|-------------------| | RST_B | n/a | Hardware Reset | Full System Reset | # 35.8 Clocks #### **35.8.1** General The timer only receives the IP bus clock (system clock). # 35.9 Interrupts #### **35.9.1** General The TMR module can generate 20 interrupts, Five for each of the four counters/channels. | Core Interrupt | Interrupt | Description | | | |----------------|------------------|--------------------------------------------------|--|--| | | TMR0_COMP_IRQ_B | Compare Interrupt Request for Timer Channel 0 | | | | | TMR0_COMP1_IRQ_B | Compare 1 Interrupt Request for Timer Channel 0 | | | | TMR Channel 0 | TMR0_COMP2_IRQ_B | Compare 2 Interrupt Request for Timer Channel 0 | | | | | TMR0_OVF_IRQ_B | Overflow Interrupt Request for Timer Channel 0 | | | | | TMR0_EDGE_IRQ_B | Input Edge Interrupt Request for Timer Channel 0 | | | | | TMR1_COMP_IRQ_B | Compare Interrupt Request for Timer Channel 1 | | | | | TMR1_COMP1_IRQ_B | Compare 1 Interrupt Request for Timer Channel 1 | | | | TMR Channel 1 | TMR1_COMP2_IRQ_B | Compare 2 Interrupt Request for Timer Channel 1 | | | | | TMR1_OVF_IRQ_B | Overflow Interrupt Request for Timer Channel 1 | | | | | TMR1_EDGE_IRQ_B | Input Edge Interrupt Request for Timer Channel 1 | | | | | TMR2_COMP_IRQ_B | Compare Interrupt Request for Timer Channel 2 | | | | | TMR2_COMP1_IRQ_B | Compare 1 Interrupt Request for Timer Channel 2 | | | | TMR Channel 2 | TMR2_COMP2_IRQ_B | Compare 2 Interrupt Request for Timer Channel 2 | | | | | TMR2_OVF_IRQ_B | Overflow Interrupt Request for Timer Channel 2 | | | | | TMR2_EDGE_IRQ_B | Input Edge Interrupt Request for Timer Channel 2 | | | | | TMR3_COMP_IRQ_B | Compare Interrupt Request for Timer Channel 3 | | | | | TMR3_COMP1_IRQ_B | Compare 1 Interrupt Request for Timer Channel 3 | | | | TMR Channel 3 | TMR3_COMP2_IRQ_B | Compare 2 Interrupt Request for Timer Channel 3 | | | | | TMR3_OVF_IRQ_B | Overflow Interrupt Request for Timer Channel 3 | | | | | TMR3_EDGE_IRQ_B | Input Edge Interrupt Request for Timer Channel 3 | | | # 35.9.2 Description of Interrupt Operation #### 35.9.2.1 Timer Compare Interrupts These interrupts are generated when a successful compare occurs between a counter and it's compare registers while SCTRL[TCFIE] is set. These interrupts are cleared by writing a zero to the appropriate SCTRL[TCF]. When a timer compare interrupt is set in TMR\_SCTRL and the Compare Load registers are available, one of the following two interrupts will also be asserted. # 35.9.2.1.1 Timer Compare 1 Interrupts (Available with Compare Load Feature) These interrupts are generated when a successful compare occurs between a counter and its COMP1 register while CSCTRL[TCF1EN] is set. These interrupts are cleared by writing a zero to the appropriate CSCTRL[TCF1]. # 35.9.2.1.2 Timer Compare 2 Interrupts (Available with Compare Load Feature) These interrupts are generated when a successful compare occurs between a counter and its COMP2 register while CSCTRL[TCF2EN] is set. These interrupts are cleared by writing a zero to the appropriate CSCTRL[TCF2]. # 35.9.2.2 Timer Overflow Interrupts These interrupts are generated when a counter rolls over its maximum value while SCTRL[TOFIE] is set. These interrupts are cleared by writing zero to the appropriate SCTRL[TOF]. ## 35.9.2.3 Timer Input Edge Interrupts These interrupts are generated by a transition of the input signal (either positive or negative depending on IPS setting) while SCTRL[IEFIE] is set. These interrupts are cleared by writing a zero to the appropriate SCTRL[IEF]. # **Chapter 36 Inter-Integrated Circuit (I2C)** #### 36.1 Introduction #### **NOTE** For the chip-specific implementation details of this module's instances, see the chip configuration information. 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 I2C 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*. #### 36.1.1 Features The I2C module has the following 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 #### muroduction - 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 - Range slave address support - DMA support # 36.1.2 Modes of operation The I2C module's operation in various low power modes is as follows: - 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. # 36.1.3 Block diagram The following figure is a functional block diagram of the I2C module. Figure 36-1. I2C Functional block diagram # 36.2 I<sup>2</sup>C signal descriptions The signal properties of I<sup>2</sup>C are shown in the following table. Table 36-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 | # 36.3 Memory map/register definition This section describes in detail all I2C registers accessible to the end user. # wemory map/register definition # **I2C** memory map | Absolute<br>address<br>(hex) | Register name | Width<br>(in bits) | Access | Reset value | Section/<br>page | |------------------------------|----------------------------------------------------------|--------------------|--------|-------------|------------------| | 4006_7000 | I2C Address Register 1 (I2C0_A1) | 8 | R/W | 00h | 36.3.1/676 | | 4006_7001 | I2C Frequency Divider register (I2C0_F) | 8 | R/W | 00h | 36.3.2/677 | | 4006_7002 | I2C Control Register 1 (I2C0_C1) | 8 | R/W | 00h | 36.3.3/678 | | 4006_7003 | I2C Status register 1 (I2C0_S1) | 8 | R/W | 80h | 36.3.4/680 | | 4006_7004 | I2C Data I/O register (I2C0_D) | 8 | R/W | 00h | 36.3.5/681 | | 4006_7005 | I2C Control Register 2 (I2C0_C2) | 8 | R/W | 00h | 36.3.6/682 | | 4006_7006 | I2C Programmable Input Glitch Filter register (I2C0_FLT) | 8 | R/W | 00h | 36.3.7/683 | | 4006_7007 | I2C Range Address register (I2C0_RA) | 8 | R/W | 00h | 36.3.8/684 | | 4006_7008 | I2C SMBus Control and Status register (I2C0_SMB) | 8 | R/W | 00h | 36.3.9/685 | | 4006_7009 | I2C Address Register 2 (I2C0_A2) | 8 | R/W | C2h | 36.3.10/<br>687 | | 4006_700A | I2C SCL Low Timeout Register High (I2C0_SLTH) | 8 | R/W | 00h | 36.3.11/<br>687 | | 4006_700B | I2C SCL Low Timeout Register Low (I2C0_SLTL) | 8 | R/W | 00h | 36.3.12/<br>687 | | 4006_8000 | I2C Address Register 1 (I2C1_A1) | 8 | R/W | 00h | 36.3.1/676 | | 4006_8001 | I2C Frequency Divider register (I2C1_F) | 8 | R/W | 00h | 36.3.2/677 | | 4006_8002 | I2C Control Register 1 (I2C1_C1) | 8 | R/W | 00h | 36.3.3/678 | | 4006_8003 | I2C Status register 1 (I2C1_S1) | 8 | R/W | 80h | 36.3.4/680 | | 4006_8004 | I2C Data I/O register (I2C1_D) | 8 | R/W | 00h | 36.3.5/681 | | 4006_8005 | I2C Control Register 2 (I2C1_C2) | 8 | R/W | 00h | 36.3.6/682 | | 4006_8006 | I2C Programmable Input Glitch Filter register (I2C1_FLT) | 8 | R/W | 00h | 36.3.7/683 | | 4006_8007 | I2C Range Address register (I2C1_RA) | 8 | R/W | 00h | 36.3.8/684 | | 4006_8008 | I2C SMBus Control and Status register (I2C1_SMB) | 8 | R/W | 00h | 36.3.9/685 | | 4006_8009 | I2C Address Register 2 (I2C1_A2) | 8 | R/W | C2h | 36.3.10/<br>687 | | 4006_800A | I2C SCL Low Timeout Register High (I2C1_SLTH) | 8 | R/W | 00h | 36.3.11/<br>687 | | 4006_800B | I2C SCL Low Timeout Register Low (I2C1_SLTL) | 8 | R/W | 00h | 36.3.12/<br>687 | # 36.3.1 I2C Address Register 1 (I2Cx\_A1) This register contains the slave address to be used by the I2C module. Address: Base address + 0h offset # 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 field is reserved. This read-only field is reserved and always has the value 0. | # 36.3.2 I2C Frequency Divider register (I2Cx\_F) Address: Base address + 1h offset | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|----|-----|---|---|----|----|---|---| | Read<br>Write | MU | JLT | | | 1/ | CR | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | #### I2Cx\_F field descriptions | Field | Description | |-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7–6<br>MULT | Multiplier Factor Defines the multiplier factor (mul). This factor is used along with the SCL divider to generate the I2C baud rate. | | | 00 mul = 1<br>01 mul = 2<br>10 mul = 4<br>11 Reserved | | 5–0<br>ICR | ClockRate 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 \times SCL \ divider)$<br>The SDA hold time is the delay from the falling edge of SCL (I2C clock) to the changing of SDA (I2C data).<br>SDA hold time = bus period $(s) \times mul \times SDA \ hold \ value$<br>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) $\times$ mul $\times$ 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) $\times$ mul $\times$ SCL stop hold value For example, if the bus speed is 8 MHz, the following table shows the possible hold time values with different ICR and MULT selections to achieve an I <sup>2</sup> C baud rate of 100 kbit/s. | Table continues on the next page... #### wemory map/register definition # I2Cx\_F field descriptions (continued) | Field | | | Description | | | |-------|------|-----|-----------------|-----------|----------| | | MULT | ICR | Hold times (µs) | | | | | | | SDA | SCL Start | SCL Stop | | | 2h | 00h | 3.500 | 3.000 | 5.500 | | | 1h | 07h | 2.500 | 4.000 | 5.250 | | | 1h | 0Bh | 2.250 | 4.000 | 5.250 | | | 0h | 14h | 2.125 | 4.250 | 5.125 | | | 0h | 18h | 1.125 | 4.750 | 5.125 | # 36.3.3 I2C Control Register 1 (I2Cx\_C1) Address: Base address + 2h offset | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|-------|-------|-------|----|------|------|-------|----------| | Read | IICEN | IICIE | MST | TX | TXAK | 0 | WUEN | DMAEN | | Write | IIOEN | IIOIE | IVIOI | 17 | IAAN | RSTA | WOLIN | DIVIALIN | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | #### I2Cx\_C1 field descriptions | Field | Description | |------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7<br>IICEN | I2C Enable | | | Enables I2C module operation. | | | 0 Disabled | | | 1 Enabled | | 6<br>IICIE | I2C Interrupt Enable | | | Enables I2C interrupt requests. | | | 0 Disabled | | | 1 Enabled | | 5 | Master Mode Select | | MST | When MST is changed from 0 to 1, a START signal is generated on the bus and master mode is selected. When this bit changes from 1 to 0, a STOP signal is generated and the mode of operation changes from master to slave. | | | 0 Slave mode | | | 1 Master mode | | 4 | Transmit Mode Select | | TX | | Table continues on the next page... 679 # I2Cx\_C1 field descriptions (continued) | Field | Description | |------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | 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. | | | 0 Receive 1 Transmit | | 3 | Transmit Acknowledge Enable | | TXAK | Specifies the value driven onto the SDA during data acknowledge cycles for both master and slave receivers. The value of SMB[FACK] affects NACK/ACK generation. | | | NOTE: SCL is held low until TXAK is written. | | | O An acknowledge signal is sent to the bus on the following receiving byte (if FACK is cleared) or the current receiving byte (if FACK is set). | | | 1 No acknowledge signal is sent to the bus on the following receiving data byte (if FACK is cleared) or<br>the current receiving data byte (if FACK is set). | | 2<br>RSTA | Repeat START | | 110171 | Writing 1 to this bit generates a repeated START condition provided it is the current master. This bit will always be read as 0. Attempting a repeat at the wrong time results in loss of arbitration. | | 1<br>WUEN | Wakeup Enable | | WOLIN | The I2C module can wake the MCU from low power mode with no peripheral bus running when slave address matching occurs. | | | 0 Normal operation. No interrupt generated when address matching in low power mode. | | | 1 Enables the wakeup function in low power mode. | | 0<br>DMAEN | DMA Enable Enables or disables the DMA function. | | | All DMA signalling disabled. | | | 1 | | | <ul> <li>DMA transfer is enabled. While SMB[FACK] = 0, the following conditions trigger the DMA request:</li> <li>a data byte is received, and either address or data is transmitted. (ACK/NACK is automatic)</li> </ul> | | | <ul> <li>the first byte received matches the A1 register or is a general call address.</li> </ul> | | | If any address matching occurs, S[IAAS] and S[TCF] are set. If the direction of transfer is known from master to slave, then it is not required to check S[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. | # 36.3.4 I2C Status register 1 (I2Cx\_S1) Address: Base address + 3h offset #### I2Cx\_S1 field descriptions | Field | Description | |-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7<br>TCF | Transfer Complete Flag Acknowledges a byte transfer; TCF sets on the completion of a byte transfer. This bit is valid only during or immediately following a transfer to or from the I2C module. TCF is cleared by reading the I2C data register in receive mode or by writing to the I2C data register in transmit mode. | | | 0 Transfer in progress 1 Transfer complete | | 6<br>IAAS | <ul> <li>Addressed As A Slave</li> <li>This bit is set by one of the following conditions: <ul> <li>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).</li> <li>C2[GCAEN] is set and a general call is received.</li> <li>SMB[SIICAEN] is set and the calling address matches the second programmed slave address.</li> <li>ALERTEN is set and an SMBus alert response address is received</li> <li>RMEN is set and an address is received that is within the range between the values of the A1 and RA registers.</li> </ul> </li> <li>IAAS 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.</li> <li>Not addressed</li> <li>Addressed as a slave</li> </ul> | | 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 1 to it. O Standard bus operation. Loss of arbitration. | | 3<br>RAM | Range Address Match This bit is set to 1 by any of the following conditions: | Table continues on the next page... # I2Cx\_S1 field descriptions (continued) | Field | Description | | | | | | | |------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--| | | 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 to 0. | | | | | | | | | 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. | | | | | | | | | 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 by writing 1 to it, such as the interrupt routine. One of the following events can set this bit:</li> <li>One byte transfer, including ACK/NACK bit, completes if FACK is 0. 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>One byte transfer, excluding ACK/NACK bit, completes if FACK is 1.</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> <li>I2C bus stop or start detection if the SSIE bit in the Input Glitch Filter register is 1</li> </ul> | | | | | | | | | NOTE: To clear the I2C bus stop or start detection interrupt: In the interrupt service routine, first clear the STOPF or STARTF bit in the Input Glitch Filter register by writing 1 to it, and then clear the IICIF bit. If this sequence is reversed, the IICIF bit is asserted again. | | | | | | | | | 0 No interrupt pending | | | | | | | | | 1 Interrupt pending | | | | | | | | 0<br>RXAK | Receive Acknowledge | | | | | | | | | 0 Acknowledge signal was received after the completion of one byte of data transmission on the bus | | | | | | | | | 1 No acknowledge signal detected | | | | | | | # 36.3.5 I2C Data I/O register (I2Cx\_D) Address: Base address + 4h offset | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|---|---|---|----|----|---|---|---| | Read<br>Write | | | | DA | TA | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | #### wemory map/register definition # I2Cx\_D field descriptions | Field | Description | |-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7–0 | 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. | | | <b>NOTE:</b> 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. | | | 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). | # 36.3.6 I2C Control Register 2 (I2Cx\_C2) Address: Base address + 5h offset | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|-------|-------|------|------|------|---|----------|---| | Read<br>Write | GCAEN | ADEXT | HDRS | SBRC | RMEN | | AD[10:8] | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | #### I2Cx\_C2 field descriptions | Field | Description | | | | | | |-------|---------------------------------------------------------|--|--|--|--|--| | 7 | General Call Address Enable | | | | | | | GCAEN | Enables general call address. | | | | | | | | 0 Disabled | | | | | | | | 1 Enabled | | | | | | | 6 | Address Extension | | | | | | | ADEXT | Controls the number of bits used for the slave address. | | | | | | | | 0 7-bit address scheme | | | | | | | | 1 10-bit address scheme | | | | | | | 5 | High Drive Select | | | | | | | HDRS | Controls the drive capability of the I2C pads. | | | | | | Table continues on the next page... 682 **Preliminary** Freescale Semiconductor, Inc. # I2Cx\_C2 field descriptions (continued) | Field | Description | |-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | 0 Normal drive mode | | | 1 High drive mode | | 4<br>SBRC | Slave Baud Rate Control | | | Enables independent slave mode baud rate at maximum frequency, which forces clock stretching on SCL in very fast I2C modes. To a slave, an example of a "very fast" mode is when the master transfers at 40 kbit/s but the slave can capture the master's data at only 10 kbit/s. | | | 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 | | TAIVILIN | 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. | | | 0 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 | | Λυ[10.0] | Contains the upper three bits of the slave address in the 10-bit address scheme. This field is valid only while the ADEXT bit is set. | # 36.3.7 I2C Programmable Input Glitch Filter register (I2Cx\_FLT) Address: Base address + 6h offset #### I2Cx\_FLT field descriptions | Field | Description | |-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | Stop Hold Enable | | SHEN | Set this bit to hold off entry to stop mode when any data transmission or reception is occurring. The following scenario explains the holdoff functionality: 1. The I2C module is configured for a basic transfer, and the SHEN bit is set to 1. 2. A transfer begins. 3. The MCU signals the I2C module to enter stop mode. 4. The byte currently being transferred, including both address and data, completes its transfer. 5. The I2C slave or master acknowledges that the in-transfer byte completed its transfer and | | | acknowledges the request to enter stop mode. | | | <ol><li>After receiving the I2C module's acknowledgment of the request to enter stop mode, the MCU<br/>determines whether to shut off the I2C module's clock.</li></ol> | Table continues on the next page... #### wemory map/register definition # I2Cx\_FLT field descriptions (continued) | Field | Description | |-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | If the SHEN bit is set to 1 and the I2C module is in an idle or disabled state when the MCU signals to enter stop mode, the module immediately acknowledges the request to enter stop mode. | | | If SHEN is cleared to 0 and the overall data transmission or reception that was suspended by stop mode entry was incomplete: To resume the overall transmission or reception after the MCU exits stop mode, software must reinitialize the transfer by resending the address of the slave. | | | If the I2C Control Register 1's IICIE bit was set to 1 before the MCU entered stop mode, system software will receive the interrupt triggered by the I2C Status Register's TCF bit after the MCU wakes from the stop mode. | | | <ul><li>Stop holdoff is disabled. The MCU's entry to stop mode is not gated.</li><li>Stop holdoff is enabled.</li></ul> | | 6<br>STOPF | I2C Bus Stop Detect Flag | | | Hardware sets this bit when the I2C bus's stop status is detected. The STOPF bit must be cleared by writing 1 to it. | | | <ul><li>0 No stop happens on I2C bus</li><li>1 Stop detected on I2C bus</li></ul> | | 5<br>SSIE | I2C Bus Stop or Start Interrupt Enable | | | This bit enables the interrupt for I2C bus stop or start detection. | | | <b>NOTE:</b> To clear the I2C bus stop or start detection interrupt: In the interrupt service routine, first clear the STOPF or STARTF bit by writing 1 to it, and then clear the IICIF bit in the status register. If this sequence is reversed, the IICIF bit is asserted again. | | | 0 Stop or start detection interrupt is disabled | | | 1 Stop or start detection interrupt is enabled | | 4<br>STARTF | I2C Bus Start Detect Flag | | | Hardware sets this bit when the I2C bus's start status is detected. The STARTF bit must be cleared by writing 1 to it. | | | 0 No start happens on I2C bus | | | 1 Start detected on I2C bus | | 3–0<br>FLT | I2C Programmable Filter Factor | | | Controls the width of the glitch, in terms of bus clock cycles, that the filter must absorb. For any glitch whose size is less than or equal to this width setting, the filter does not allow the glitch to pass. | | | Oh No filter/bypass | | | 1-Fh Filter glitches up to width of <i>n</i> bus clock cycles, where <i>n</i> =1-15d | # 36.3.8 I2C Range Address register (I2Cx\_RA) Address: Base address + 7h offset KM Family Reference Manual, Rev. 5, Oct 2013 684 Preliminary Freescale Semiconductor, Inc. #### 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 write 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 field is reserved. This read-only field is reserved and always has the value 0. | # 36.3.9 I2C SMBus Control and Status register (I2Cx\_SMB) #### **NOTE** When the SCL and SDA signals are held high for a length of time greater than the high timeout period, the SHTF1 flag sets. Before reaching this threshold, while the system is detecting how long these signals are being held high, a master assumes that the bus is free. However, the SHTF1 bit is set to 1 in the bus transmission process with the idle bus state. #### NOTE When the TCKSEL bit is set, there is no need to monitor the SHTF1 bit because the bus speed is too high to match the protocol of SMBus. Address: Base address + 8h offset #### I2Cx\_SMB field descriptions | Field | Description | |--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | Fast NACK/ACK Enable | | FACK | For SMBus packet error checking, the CPU must be able to issue an ACK or NACK according to the result of receiving data byte. | | | <ul> <li>An ACK or NACK is sent on the following receiving data byte</li> <li>Writing 0 to TXAK after receiving a data byte generates an ACK. Writing 1 to TXAK after receiving a data byte generates a NACK.</li> </ul> | | 6<br>ALERTEN | SMBus Alert Response Address Enable Enables or disables SMBus alert response address matching. | Table continues on the next page... #### wemory map/register definition # I2Cx\_SMB field descriptions (continued) | Field | Description | |--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | <b>NOTE:</b> After the host responds to a device that used the alert response address, you must use software to put the device's address on the bus. The alert protocol is described in the SMBus specification. | | | SMBus alert response address matching is disabled | | | 1 SMBus alert response address matching is enabled | | 5<br>SIICAEN | Second I2C Address Enable Enables or disables SMBus device default address. | | | Enables of disables similar device default address. | | | 0 I2C address register 2 matching is disabled | | | 1 I2C address register 2 matching is enabled | | 4<br>TCKSEL | Timeout Counter Clock Select | | | Selects the clock source of the timeout counter. | | | 0 Timeout counter counts at the frequency of the bus clock / 64 | | | 1 Timeout counter counts at the frequency of the bus clock | | 3<br>SLTF | SCL Low Timeout Flag | | | 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 0. | | | 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 × LoValue / 512, which indicates the bus is free. This bit is cleared automatically. | | | 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 1 to it. | | | 0. No SCI, high and SDA law timeout accure | | | <ul><li>No SCL high and SDA low timeout occurs</li><li>SCL high and SDA low timeout occurs</li></ul> | | | | | 0<br>SHTF2IE | SHTF2 Interrupt Enable Enables SCL high and SDA low timeout interrupt. | | | | | | 0 SHTF2 interrupt is disabled | | | 1 SHTF2 interrupt is enabled | # 36.3.10 I2C Address Register 2 (I2Cx\_A2) Address: Base address + 9h offset ## 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 field is reserved. This read-only field is reserved and always has the value 0. | ## 36.3.11 I2C SCL Low Timeout Register High (I2Cx\_SLTH) Address: Base address + Ah offset | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|---|---|---|------|--------|---|---|---| | Read<br>Write | | | | SSLT | [15:8] | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ## 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. | ## 36.3.12 I2C SCL Low Timeout Register Low (I2Cx\_SLTL) Address: Base address + Bh offset ## 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. | # 36.4 Functional description This section provides a comprehensive functional description of the I2C module. # **36.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 36-38. I2C bus transmission signals 689 ## **36.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. #### 36.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 can 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. ## 36.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. #### runctional 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. ## **36.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. ## 36.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. ## 36.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. ## 36.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 36-39. I2C clock synchronization # 36.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. **runctional description** ## 36.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. In other words, the SCL bus signal's low period is increased to be the same length as the slave's SCL low period. ## 36.4.1.10 I2C divider and hold values #### **NOTE** For some cases on some devices, the SCL divider value may vary by +/-2 or +/-4 when ICR's value ranges from 00h to 0Fh. These potentially varying SCL divider values are highlighted in the following table. For the actual SCL divider values for your device, see the chip-specific details about the I2C module. Table 36-41. I2C divider and hold values | ICR<br>(hex) | SCL<br>divider | SDA hold value | SCL hold<br>(start)<br>value | SCL hold<br>(stop)<br>value | ICR<br>(hex) | SCL<br>divider<br>(clocks) | SDA hold<br>(clocks) | SCL hold<br>(start)<br>value | SCL 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 | Table continues on the next page... Table 36-41. I2C divider and hold values (continued) | ICR | SCL | SDA hold | SCL hold | SCL hold | ICR | SCL | SDA hold | SCL hold | SCL hold | | |-------|---------|----------|------------------|-----------------|-------|---------------------|----------|------------------|-----------------|--| | (hex) | divider | value | (start)<br>value | (stop)<br>value | (hex) | divider<br>(clocks) | (clocks) | (start)<br>value | (stop)<br>value | | | 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 | | | 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 | | #### 36.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. ## 36.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 7 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 8 bits of the second byte of the slave address with its own address, but only one slave finds a match and generates 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. **runctional description** Table 36-42. Master-transmitter addresses slave-receiver with a 10-bit address | S | Slave | R/W | A1 | Slave | A2 | Data | Α | <br>Data | A/A | Р | |---|--------------|-----|----|---------|----|------|---|----------|-----|---| | | address | 0 | | address | | | | | | | | | first 7 bits | | | second | | | | | | | | | 11110 + | | | byte | | | | | | | | | AD10 + | | | AD[8:1] | | | | | | | | | AD9 | | | | | | | | | | 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. #### 36.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 36-43. Master-receiver addresses a slave-transmitter with a 10-bit address | S | Slave | R/W | A1 | Slave | A2 | Sr | Slave | R/W | А3 | Data | Α | <br>Data | Α | Р | |---|---------|-----|----|---------|----|----|---------|-----|----|------|---|----------|---|---| | | address | 0 | | address | | | address | 1 | | | | | | | | | first 7 | | | second | | | first 7 | | | | | | | | | | bits | | | byte | | | bits | | | | | | | | | | 11110 + | | | AD[8:1] | | | 11110 + | | | | | | | | | | AD10 + | | | | | | AD10 + | | | | | | | | | | AD9 | | | | | | 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. ## 36.4.3 Address matching All received addresses can be requested in 7-bit or 10-bit address format. - AD[7:1] in Address Register 1, which contains the I2C primary slave address, always participates in the address matching process. It provides a 7-bit address. - If the ADEXT bit is set, AD[10:8] in Control Register 2 participates in the address matching process. It extends the I2C primary slave address to a 10-bit address. Additional conditions that affect address matching include: - 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, 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 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 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. # 36.4.4 System management bus specification SMBus provides a control bus for system and power management related tasks. A system can 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 the 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. runctional description #### 36.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. The slave device must 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. #### 36.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 the I2C module is an active master, if it detects that SMBCLK low has exceeded the value of T<sub>TIMEOUT,MIN</sub>, 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<sub>TIMEOUT,MIN</sub> condition, it resets its communication and is then able to receive a new START condition. ## 36.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 occurs after a START condition appears on the bus but before a STOP condition appears on the bus. Any master detecting this scenario can assume the bus is free when either of the following occurs: - SHTF1 rises. - 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, another 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 triggers IICIF. ## 36.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 36-40. 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. ## 36.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. To calculate the CRC-8 by software, this module can hold the SCL line low after #### runctional description 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 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. #### 36.4.5 Resets The I2C module is disabled after a reset. The I2C module cannot cause a core reset. # 36.4.6 Interrupts The I2C module generates an interrupt when any of the events in the table found here 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. #### Table 36-44. Interrupt summary | 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 | | I <sup>2</sup> C bus stop detection | STOPF | IICIF | IICIE & SSIE | | I <sup>2</sup> C bus start detection | STARTF | IICIF | IICIE & SSIE | | SMBus SCL low timeout | SLTF | IICIF | IICIE | | SMBus SCL high SDA low timeout | SHTF2 | IICIF | IICIE & SHTF2IE | | Wakeup from stop or wait mode | IAAS | IICIF | IICIE & WUEN | ## 36.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 eighth clock to indicate the completion of byte. ## 36.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. ## 36.4.6.3 Stop Detect Interrupt When the stop status is detected on the $I^2C$ bus, the STOPF bit is set to 1. The CPU is interrupted, provided the IICIE and STOPIE bits are both set to 1. # 36.4.6.4 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. runctional description ## 36.4.6.5 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. ## 36.4.6.6 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. ## 36.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 specify the size of the glitch (in terms of bus clock cycles) for the filter to absorb and not pass. Figure 36-41. Programmable input glitch filter diagram ## 36.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 a low power mode where no peripheral bus is running. Data sent on the bus that is the same as a target device address might also wake the target MCU. 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 it is needed to transfer packets. The SCL line is not held low until the I2C module resets after address matching. The main purpose of this feature is to wake the MCU from a low power mode where no peripheral bus is running. When the MCU is in such a mode: addressing as a slave, slave read/write, and sending an acknowledge bit are not fully supported. To avoid I2C transfer problems resulting from this situation, firmware should prevent the MCU execution of a STOP #### unualization/application information instruction when the I2C module is in the middle of a transfer unless the Stop mode holdoff feature is used during this period (set FLT[SHEN] to 1). ## 36.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. # 36.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) - 1. Write: Frequency Divider register to set the I2C baud rate (see example in description of ICR) - 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 encompasses 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. An example of an I2C driver which implements many of the steps described here is available in AN4342: Using the Inter-Integrated Circuit on ColdFire+ and Kinetis. #### unualization/application information #### Notes: - 1. If general call is enabled, check to determine if the received address is a general call address (0x00). If the received address is 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 36-42. Typical I2C interrupt routine #### 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 be needed before the first and second data reading, to wait for the possible longest time period (in worst case) of the 9th SCL cycle. - 3. This read is a dummy read in order to reset the SMBus receiver state machine. ## Figure 36-43. Typical I2C SMBus interrupt routine mualization/application information # **Chapter 37 Serial Peripheral Interface (SPI)** ## 37.1 Introduction #### **NOTE** For the chip-specific implementation details of this module's instances, see the chip configuration information. 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. ## 37.1.1 Features The SPI includes these distinctive features: • Master mode or slave mode operation #### muroduction - Full-duplex or single-wire bidirectional mode - Programmable transmit bit rate - Double-buffered transmit and receive data register - 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 # 37.1.2 Modes of operation The SPI functions in the following three modes. • 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 C2[SPISWAI] is clear, the SPI operates like in Run mode. If C2[SPISWAI] 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. ## 37.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. ## 37.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 (SS pin). In this system, the master device has configured its SS pin as an optional slave select output. #### muroduction Figure 37-1. SPI system connections ## 37.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 37 Serial Peripheral Interface (SPI)** Figure 37-2. SPI module block diagram without FIFO #### External signal description Figure 37-3. SPI Module Block Diagram with FIFO # 37.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). ## 37.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. ## 37.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). ## 37.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). ## 37.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). # 37.3 Memory map/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. ## **SPI** memory map | Address offset (hex) | Absolute<br>address<br>(hex) | Register name | Width<br>(in bits) | Access | Reset value | Section/<br>page | |----------------------|--------------------------------------------|----------------------------------------|--------------------|--------|-------------|------------------| | 0 | 4007_5000 | SPI Status Register (SPI0_S) | 8 | R | 20h | 37.3.1/714 | | 1 | 4007_5001 | SPI Baud Rate Register (SPI0_BR) | 8 | R/W | 00h | 37.3.2/718 | | 2 | 4007_5002 | SPI Control Register 2 (SPI0_C2) | 8 | R/W | 00h | 37.3.3/719 | | 3 | 4007_5003 | SPI Control Register 1 (SPI0_C1) | 8 | R/W | 04h | 37.3.4/720 | | 4 | 4007_5004 | SPI Match Register low (SPI0_ML) | 8 | R/W | 00h | 37.3.5/722 | | 5 | 4007_5005 | SPI match register high (SPI0_MH) | 8 | R/W | 00h | 37.3.6/723 | | 6 | 4007_5006 | SPI Data Register low (SPI0_DL) | 8 | R/W | 00h | 37.3.7/723 | | 7 | 4007_5007 | SPI data register high (SPI0_DH) | 8 | R/W | 00h | 37.3.8/724 | | Α | 4007_500A | SPI clear interrupt register (SPI0_CI) | 8 | R/W | 00h | 37.3.9/724 | | В | 4007_500B | SPI control register 3 (SPI0_C3) | 8 | R/W | 00h | 37.3.10/<br>726 | | 0 | 4007_6000 | SPI Status Register (SPI1_S) | 8 | R | 20h | 37.3.1/714 | | 1 | 4007_6001 | SPI Baud Rate Register (SPI1_BR) | 8 | R/W | 00h | 37.3.2/718 | | 2 | 4007_6002 | SPI Control Register 2 (SPI1_C2) | 8 | R/W | 00h | 37.3.3/719 | | 3 | 4007_6003 | SPI Control Register 1 (SPI1_C1) | 8 | R/W | 04h | 37.3.4/720 | | 4 | 4007_6004 | SPI Match Register low (SPI1_ML) | 8 | R/W | 00h | 37.3.5/722 | | 5 | 4007_6005 | SPI match register high (SPI1_MH) | 8 | R/W | 00h | 37.3.6/723 | | 6 | 4007_6006 | SPI Data Register low (SPI1_DL) | 8 | R/W | 00h | 37.3.7/723 | | 7 | 4007_6007 | SPI data register high (SPI1_DH) | 8 | R/W | 00h | 37.3.8/724 | | Α | 4007_600A | SPI clear interrupt register (SPI1_CI) | 8 | R/W | 00h | 37.3.9/724 | | В | 4007_600B SPI control register 3 (SPI1_C3) | | 8 | R/W | 00h | 37.3.10/<br>726 | # 37.3.1 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. - 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. Address: 4007\_5000h base + 0h offset = 4007\_5000h #### SPI0\_S field descriptions | Field | Description | |-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | 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): 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 | Table continues on the next page... #### wemory map/register definition # SPI0\_S field descriptions (continued) | Field | Description | | | | | | | |------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--| | | 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 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) | | | | | | | | | 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. | | | | | | | | | <ul> <li>Value in the receive data buffer does not match the value in the MH:ML registers</li> <li>Value in the receive data buffer matches the value in the MH:ML registers</li> </ul> | | | | | | | | 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. | | | | | | | Table continues on the next page... # SPI0\_S field descriptions (continued) | Field | Description | |---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | 0 SPI transmit buffer not empty (when FIFOMODE is not present or is 0) or SPI FIFO not empty (when FIFOMODE is 1) | | | SPI transmit buffer empty (when FIFOMODE is not present or is 0) or SPI FIFO empty (when FIFOMODE is 1) | | 4 | Master Mode Fault Flag | | MODF | 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 C1[MSTR] is 1, C2[MODFEN] is 1, and C1[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). | | | 0 No mode fault error | | | 1 Mode fault error detected | | 3 | Receive FIFO nearly full flag | | RNFULLF | 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. | | | 0 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 | | | 1 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 | | 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. | | | 0 Transmit FIFO has less than 8 bytes | | | 1 Transmit FIFO has 8 bytes of data | | 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. | Table continues on the next page... #### wemory map/register definition ## SPI0\_S field descriptions (continued) | Field | Description | |-------|----------------------------------------------------------------------------------------------------------------------------| | | 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. | | | 1 Read FIFO is empty. | # 37.3.2 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. Address: 4007\_5000h base + 1h offset = 4007\_5001h ## SPI0\_BR field descriptions | Field | Description | | | | | |-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | 7 | This field is reserved. | | | | | | Reserved | This read-only field is reserved and always has the value 0. | | | | | | 6–4 | SPI Baud Rate Prescale Divisor | | | | | | SPPR[2:0] | 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 | SPI Baud Rate Divisor | | | | | | SPR[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. | | | | | Table continues on the next page... #### KM Family Reference Manual, Rev. 5, Oct 2013 718 **Preliminary** Freescale Semiconductor, Inc. ## SPI0\_BR field descriptions (continued) | Field | Description | | | | | |-------|-------------|---------------------------|--|--|--| | | 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 | | | | # 37.3.3 SPI Control Register 2 (SPIx\_C2) This read/write register is used to control optional features of the SPI system. Address: 4007\_5000h base + 2h offset = 4007\_5002h | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|-------|---------|--------|--------|---------|--------|---------|------| | Read<br>Write | SPMIE | SPIMODE | TXDMAE | MODFEN | BIDIROE | RXDMAE | SPISWAI | SPC0 | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ## SPI0\_C2 field descriptions | Field | Description | |---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | SPI Match Interrupt Enable | | SPMIE | 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 | 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 bit enables 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. | Table continues on the next page... #### wemory map/register definition ## SPI0\_C2 field descriptions (continued) | Field | Description | | | | | | | |--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--| | | 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<br>BIDIROE | Bidirectional Mode Output Enable | | | | | | | | BIDINGE | When bidirectional mode is enabled because SPI pin control 0 (SPC0) is set to 1, BIDIROE 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. | | | | | | | | | O Output driver disabled so SPI data I/O pin acts as an input | | | | | | | | | 1 SPI I/O pin enabled as an output | | | | | | | | 2 | Receive DMA enable | | | | | | | | RXDMAE | 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. | | | | | | | | | 0 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 | Enables bidirectional pin configurations. | | | | | | | | | 0 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. | | | | | | | # 37.3.4 SPI Control Register 1 (SPIx\_C1) This read/write register includes the SPI enable control, interrupt enables, and configuration options. Address: 4007\_5000h base + 3h offset = 4007\_5003h #### KM Family Reference Manual, Rev. 5, Oct 2013 720 **Preliminary** Freescale Semiconductor, Inc. # 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): 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 or Read FIFO Full Interrupts are disabled (when FIFOMODE is 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 | SPI System Enable | | | | | | | | | SPE | 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. | | | | | | | | | | SPI system inactive SPI system enabled | | | | | | | | | 5 | SPI Transmit Interrupt Enable | | | | | | | | | SPTIE | 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). | | | | | | | | | | Interrupts from SPTEF inhibited (use polling) When SPTEF is 1, hardware interrupt requested | | | | | | | | | 4 | Master/Slave Mode Select | | | | | | | | | MSTR | Selects master or slave mode operation. | | | | | | | | | | 0 SPI module configured as a slave SPI device | | | | | | | | | | 1 SPI module configured as a master SPI device | | | | | | | | | 3 | Clock Polarity | | | | | | | | | CPOL | 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. | | | | | | | | | | 0 Active-high SPI clock (idles low) 1 Active-low SPI clock (idles high) | | | | | | | | | 2 | Clock Phase | | | | | | | | | СРНА | Selects one of two clock formats for different kinds of synchronous serial peripheral devices. Refer to the description of "SPI Clock Formats" for details. | | | | | | | | | | <ul> <li>First edge on SPSCK occurs at the middle of the first cycle of a data transfer.</li> <li>First edge on SPSCK occurs at the start of the first cycle of a data transfer.</li> </ul> | | | | | | | | #### wemory map/register definition ## SPI0\_C1 field descriptions (continued) | Field | Description | | | | | | |-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | 1 | Slave Select Output Enable | | | | | | | SSOE | This bit is used in combination with the Mode Fault Enable (MODFEN) field in the C2 register and the Master/Slave (MSTR) control bit to determine the function of the $\overline{SS}$ pin. | | | | | | | | When C2[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 C2[MODFEN] is 1: In master mode, $\overline{SS}$ pin function is $\overline{SS}$ input for mode fault. In slave mode, $\overline{SS}$ pin function is slave select input. | | | | | | | | 1 When C2[MODFEN] is 0: In master mode, $\overline{SS}$ pin function is general-purpose I/O (not SPI). In slave mode, $\overline{SS}$ pin function is slave select input. | | | | | | | | When C2[MODFEN] is 1: In master mode, $\overline{SS}$ pin function is automatic $\overline{SS}$ output. In slave mode: $\overline{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). | | | | | | | | <ul><li>SPI serial data transfers start with the most significant bit.</li><li>SPI serial data transfers start with the least significant bit.</li></ul> | | | | | | # 37.3.5 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 in the S register (S[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. 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. Address: 4007\_5000h base + 4h offset = 4007\_5004h #### SPI0\_ML field descriptions | Field | Description | |------------------|-----------------------------------| | 7–0<br>Bits[7:0] | Hardware compare value (low byte) | # 37.3.6 SPI match register high (SPIx\_MH) Refer to the description of the ML register. Address: 4007\_5000h base + 5h offset = 4007\_5005h #### SPI0\_MH field descriptions | Field | Description | |-------------------|------------------------------------| | 7–0<br>Bits[15:8] | Hardware compare value (high byte) | # 37.3.7 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 S[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 S[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 S[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. #### wemory map/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) | # 37.3.8 SPI data register high (SPIx\_DH) Refer to the description of the DL register. Address: 4007\_5000h base + 7h offset = 4007\_5007h ## SPI0\_DH field descriptions | Field | Description | |-------------------|------------------| | 7–0<br>Bits[15:8] | Data (high byte) | # 37.3.9 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 total more than 64 bits of data. 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. Address: 4007\_5000h base + Ah offset = 4007\_500Ah #### SPI0\_CI field descriptions | Field | Description | | | | | | |----------------|----------------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | 7 | Transmit FIFO error flag | | | | | | | TXFERR | This flag indicates that a transmit FIFO error occurred because entries in the FIFO total more than 64 bits of data. | | | | | | | | 0 No transmit FIFO error occurred | | | | | | | | 1 A transmit FIFO error occurred | | | | | | | 6 | Receive FIFO error flag | | | | | | | RXFERR | This flag indicates that a receive FIFO error occurred because entries in the FIFO total more than 64 bits of data. | | | | | | | | 0 No receive FIFO error occurred | | | | | | | | 1 A receive FIFO error occurred | | | | | | | 5 | Transmit FIFO overflow flag | | | | | | | TXFOF | This flag indicates that a transmit FIFO overflow condition has occurred. | | | | | | | | 0 Transmit FIFO overflow condition has not occurred | | | | | | | | 1 Transmit FIFO overflow condition occurred | | | | | | | 4 | Receive FIFO overflow flag | | | | | | | RXFOF | This flag indicates that a receive FIFO overflow condition has occurred. | | | | | | | | 0 Receive FIFO overflow condition has not occurred | | | | | | | | 1 Receive FIFO overflow condition occurred | | | | | | | 3 | Transmit FIFO nearly empty flag clear interrupt | | | | | | | TNEAREFCI | 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 | | | | | | Table continues on the next page... #### wemory map/register definition ### SPI0\_CI field descriptions (continued) | Field | Description | | | | | | |--------------|--------------------------------------------------------------------------------|--|--|--|--|--| | | Writing 1 to this bit clears the RNFULLF interrupt provided that C3[3] is set. | | | | | | | 1<br>SPTEFCI | Transmit FIFO empty flag clear interrupt | | | | | | | OI TEI OI | Writing 1 to this bit clears the SPTEF interrupt provided that C3[3] is set. | | | | | | | 0<br>SPRFCI | Receive FIFO full flag clear interrupt | | | | | | | SENEO | Writing 1 to this bit clears the SPRF interrupt provided that C3[3] is set. | | | | | | # 37.3.10 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. 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. Address: 4007\_5000h base + Bh offset = 4007\_500Bh ## SPI0\_C3 field descriptions | Field | Description | |------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7–6<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 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<br>RNFULLF | Receive FIFO nearly full watermark | | 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. | | | 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 RNFULLF flag is set. This bit is ignored and has no function if the FIFOMODE bit is 0. | | | 0 No interrupt upon RNFULLF being set | | | 1 Enable interrupts upon RNFULLF being set | | 0 | FIFO mode enable | | FIFOMODE | 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 | # 37.4 Functional description This section provides the functional description of the module. runctional description ## **37.4.1** General The SPI system is enabled by setting the SPI enable (SPE) bit in SPI Control Register 1. While C1[SPE] is set, the four associated SPI port pins are dedicated to the SPI function as: - Slave select (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 S[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 (CPHA) and Clock Polarity Control (CPOL) bits 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. C1[CPHA] 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 C1[MSTR] is clear, slave mode is selected. ## 37.4.2 Master mode The SPI operates in master mode when C1[MSTR] is set. Only a master SPI module can initiate transmissions. A transmission begins by reading the SPIx\_S register while S[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 - If C2[MODFEN] and C1[SSOE] are set, the SS pin is configured as slave select output. The SS output becomes low during each transmission and is high when the SPI is in idle state. If C2[MODFEN] is set and C1[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 C1[MSTR] 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 S[ MODF] 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 C1[CPOL], C1[CPHA], C1[SSOE], C1[LSBFE], C2[MODFEN], C2[SPC0], C2[BIDIROE] with C2[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. ## 37.4.3 Slave mode The SPI operates in slave mode when the MSTR bit in SPI Control Register 1 is clear. #### runctional description 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. • SS pin The SS pin is the slave select input. Before a data transmission occurs, the SS pin of the slave SPI must be low. SS must remain low until the transmission is complete. If SS goes high, the SPI is forced into an idle state. The SS input also controls the serial data output pin. If SS is high (not selected), the serial data output pin is high impedance. If 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 (SS is high), then the SPSCK input is ignored and no internal shifting of the SPI shift register occurs. 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 C1[CPHA] 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 C1[LSBFE]. 731 When C1[CPHA] is set, the first edge is used to get the first data bit onto the serial data output pin. When C1[CPHA] is clear and the 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 register. To indicate transfer is complete, the SPRF flag in the SPI Status Register is set. #### **Note** A change of the bits FIFOMODE, SPIMODE, C2[BIDIROE] with C2[SPC0] set, C1[CPOL], C1[CPHA], C1[SSOE], C1[LSBFE], C2[MODFEN], and C2[SPC0] in slave mode will corrupt a transmission in progress and must be avoided. ## 37.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 37-34. SPIH:L read side structural overview in FIFO mode Figure 37-35. SPIH:L write side structural overview in FIFO mode # 37.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 37-36. Basic Flow of SPI Transmission by DMA ## 37.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 37-37. Recommended startup of SPI transmit by DMA # **37.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 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. # 37.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. runctional description ## 37.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 in the Control Register 1 to select one of four clock formats for data transfers. C1[CPOL] selectively inserts an inverter in series with the clock. C1[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 C1[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 C2[MODFEN] and C1[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 37-38. SPI clock formats (CPHA = 1) When C1[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 C1[CPHA] = 1, the slave's $\overline{SS}$ input is not required to go to its inactive high level between transfers. In this clock format, a back-to-back transmission can occur, as follows: - 1. A transmission is in progress. - 2. A new data byte is written to the transmit buffer before the in-progress transmission is complete. - 3. When the in-progress transmission is complete, the new, ready data byte is transmitted immediately. #### runctional description Between these two successive transmissions, no pause is inserted; the $\overline{SS}$ pin remains low. The following figure shows the clock formats when SPIMODE = 0 and C1[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 (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 SS OUT waveform applies to the slave select output from a master (provided C2[MODFEN] and C1[SSOE] = 1). The master 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 SS IN waveform applies to the slave select input of a slave. Figure 37-39. SPI clock formats (CPHA = 0) When C1[CPHA] = 0, the slave begins to drive its MISO output with the first data bit value (MSB or LSB depending on LSBFE) when 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 C1[CPHA] = 0, the slave's SS input must go to its inactive high level between transfers. # 37.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 37-40. SPI baud rate generation # 37.4.9 Special features The following section describes the special features of SPI module. runctional description # 37.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 C1[SSOE] and C2[MODFEN] as shown in the description of C1[SSOE]. 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. # 37.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. C1[MSTR] 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 37-34. Normal Mode and Bidirectional Mode The direction of each serial I/O pin depends on C2[BIDIROE]. 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. 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 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. ## 37.4.10 Error conditions The SPI module has one error condition: the mode fault error. ### 37.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 C2[MODFEN] is set. In the special case where the SPI is in master mode and C2[MODFEN] 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. #### runctional description 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. # 37.4.11 Low-power mode options This section describes the low-power mode options. #### 37.4.11.1 SPI in Run mode In Run mode, with the SPI system enable (SPE) bit in the SPI Control Register 1 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. ## 37.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 C2[SPISWAI] is clear, the SPI operates normally when the CPU is in Wait mode. - If C2[SPISWAI] is set, SPI clock generation ceases and the SPI module enters a power conservation state when the CPU is in wait mode. - If C2[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 C2[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). 743 #### **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 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. ## 37.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 C2[SPISWAI]. 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 reinitialized. # 37.4.12 Reset The reset values of registers and signals are described in the Memory Map and Register Descriptions content, 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. # 37.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). ## 37.4.13.1 MODF MODF occurs when the master detects an error on the $\overline{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. ## 37.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. After SPRF is set, it does not clear until it is serviced. SPRF has an automatic clearing process that is described in the SPI Status Register details. If the SPRF is not serviced before the end of the next transfer (that is, SPRF remains active throughout another transfer), the subsequent transfers are ignored and no new data is copied into the Data register. ### 37.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. After SPTEF is set, it does not clear until it is serviced. SPTEF has an automatic clearing process that is described in the SPI Status Register details. ## 37.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. ### 37.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. #### 37.4.13.6 RNFULLF The RNFULLF bit applies when the FIFO feature is supported. #### unualization/application information 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. # 37.5 Initialization/application information This section discusses an example of how to initialize and use the SPI. # 37.5.1 Initialization sequence Before the SPI module can be used for communication, an initialization procedure must be carried out, as follows: - 1. Update the 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 the 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 as well as to control 8- or 16-bit mode selection and other optional features. - 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 S[SPTEF] = 1, and then write to the transmit data register (SPIx\_DH:SPIx\_DL) to begin transfer. ## 37.5.2 Pseudo-Code Example In this example, the SPI module is set up for master mode with only hardware match interrupts enabled. The SPI runs in 16-bit mode at a maximum baud rate of bus clock divided by 2. Clock phase and polarity are 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(%01010 | )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 | | SPIx_C2 = 0xC0(%11000000) | | | | | | | | |---------------------------|---------|---|---|----------------------------------------------|--|--|--| | 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 | = | 0000 | Sets baud rate divisor to 2 | | SPIx_S = 0 | )x00(%0000000) | | | | | |------------|----------------|------------------------------------------------|---|---|------------------------------------------------------------------------------------| | | Bit 7 | SPRF | = | 0 | Flag is set when receive data buffer is full | | | Bit 6 | SPMF | = | 0 | Flag is set when SPIx_MH/ML = 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 = | 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. | | | | | | #### unualization/application information #### $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 37-41. Initialization Flowchart Example for SPI Master Device in 16-bit Mode for FIFOMODE = 0 #### unualization/application information Figure 37-42. Initialization Flowchart Example for SPI Master Device in 16-bit Mode for FIFOMODE = 1 750 **Preliminary** Freescale Semiconductor, Inc. # Chapter 38 Universal Asynchronous Receiver/Transmitter (UART) ## 38.1 Introduction #### NOTE For the chip-specific implementation details of this module's instances, see the chip configuration information. The UART allows asynchronous serial communication with peripheral devices and CPUs. ## **38.1.1 Features** The UART includes the following features: - Full-duplex operation - Standard mark/space non-return-to-zero (NRZ) format - 13-bit baud rate selection with /32 fractional divide, based on the module clock frequency - Programmable 8-bit or 9-bit data format - Separately enabled transmitter and receiver - Programmable transmitter output polarity - Programmable receive input polarity - Up to 14-bit break character transmission. - 11-bit break character detection option KM Family Reference Manual, Rev. 5, Oct 2013 751 #### muroduction - Independent FIFO structure for transmit and receive - Two receiver wakeup methods: - Idle line wakeup - Address mark wakeup - Address match feature in the 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 to interface with SIM cards and smart cards - Support for 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 - Receiver framing error detection - Hardware parity generation and checking - 1/16 bit-time noise detection - DMA interface # 38.1.2 Modes of operation The UART functions in the same way in all the normal modes. It has the following low power mode: • Stop mode ## 38.1.2.1 Run mode This is the normal mode of operation. ## 38.1.2.2 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 is disabled. The UART operation resumes after an external interrupt brings the CPU out of Stop mode. Bringing the CPU out of Stop mode by reset aborts any ongoing transmission or reception and resets the UART. Entering or leaving Stop mode does not initiate any power down or power up procedures for the ISO-7816 smartcard interface. # 38.2 UART signal descriptions The UART signals are shown in the following table. Table 38-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 | # 38.2.1 Detailed signal descriptions The detailed signal descriptions of the UART are shown in the following table. Table 38-2. UART—Detailed signal descriptions | Signal | I/O | Description | | | | |-----------------------------------------|-----|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | CTS | I | Clear to send. Ir | Clear to send. Indicates whether the UART can start transmitting data when flow control is enabled. | | | | | | State meaning | Asserted—Data transmission can start. | | | | | | | Negated—Data transmission cannot start. | | | | | | Timing | Assertion—When transmitting device's RTS asserts. | | | | | | | Negation—When transmitting device's RTS deasserts. | | | | · · · · · · · · · · · · · · · · · · · | | | ond. When driven by the receiver, indicates whether the UART is ready to When driven by the transmitter, can enable an external transceiver during transmission. | | | | | | State<br>meaning | Asserted—When driven by the receiver, ready to receive data. When driven by the transmitter, enable the external transmitter. | | | | | | 3 | 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. | | | Chapter 38 Universal Asynchronous Receiver/Transmitter (UART) ## Table 38-2. UART—Detailed signal descriptions (continued) | Signal | I/O | Description | | | | |--------|-----|-----------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | 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. | | | # 38.3 Memory map and registers This section provides a detailed description of all memory and registers. Only byte accesses are supported. ## **UART** memory map | Absolute<br>address<br>(hex) | Register name | | Access | Reset value | Section/<br>page | |------------------------------|--------------------------------------------|---|--------|-------------|------------------| | 4006_A000 | UART Baud Rate Registers: High (UART0_BDH) | 8 | R/W | 00h | 38.3.1/760 | | 4006_A001 | UART Baud Rate Registers: Low (UART0_BDL) | 8 | R/W | 04h | 38.3.2/761 | | 4006_A002 | UART Control Register 1 (UART0_C1) | 8 | R/W | 00h | 38.3.3/761 | | 4006_A003 | UART Control Register 2 (UART0_C2) | 8 | R/W | 00h | 38.3.4/763 | | 4006_A004 | UART Status Register 1 (UART0_S1) | 8 | R | C0h | 38.3.5/765 | | 4006_A005 | UART Status Register 2 (UART0_S2) | 8 | R/W | 00h | 38.3.6/768 | | 4006_A006 | UART Control Register 3 (UART0_C3) | 8 | R/W | 00h | 38.3.7/769 | | 4006_A007 | UART Data Register (UART0_D) | 8 | R/W | 00h | 38.3.8/771 | | 4006_A008 | UART Match Address Registers 1 (UART0_MA1) | 8 | R/W | 00h | 38.3.9/772 | | 4006_A009 | UART Match Address Registers 2 (UART0_MA2) | 8 | R/W | 00h | 38.3.10/<br>772 | | 4006_A00A | UART Control Register 4 (UART0_C4) | 8 | R/W | 00h | 38.3.11/<br>773 | | 4006_A00B | UART Control Register 5 (UART0_C5) | 8 | R/W | 00h | 38.3.12/<br>773 | | 4006_A00C | UART Extended Data Register (UART0_ED) | 8 | R | 00h | 38.3.13/<br>774 | | 4006_A00D | UART Modem Register (UART0_MODEM) | 8 | R/W | 00h | 38.3.14/<br>775 | | 4006_A010 | UART FIFO Parameters (UART0_PFIFO) | 8 | R/W | See section | 38.3.15/<br>777 | | 4006_A011 | UART FIFO Control Register (UART0_CFIFO) | 8 | R/W | 00h | 38.3.16/<br>778 | #### wemory map and registers # **UART** memory map (continued) | Absolute<br>address<br>(hex) | Register name | Width<br>(in bits) | Access | Reset value | Section/<br>page | |------------------------------|----------------------------------------------------|--------------------|--------|-------------|------------------| | 4006_A012 | UART FIFO Status Register (UART0_SFIFO) | 8 | R/W | C0h | 38.3.17/<br>779 | | 4006_A013 | UART FIFO Transmit Watermark (UART0_TWFIFO) | | R/W | 00h | 38.3.18/<br>780 | | 4006_A014 | UART FIFO Transmit Count (UART0_TCFIFO) | 8 | R | 00h | 38.3.19/<br>781 | | 4006_A015 | UART FIFO Receive Watermark (UART0_RWFIFO) | 8 | R/W | 01h | 38.3.20/<br>781 | | 4006_A016 | UART FIFO Receive Count (UART0_RCFIFO) | 8 | R | 00h | 38.3.21/<br>782 | | 4006_A018 | UART 7816 Control Register (UART0_C7816) | 8 | R/W | 00h | 38.3.22/<br>782 | | 4006_A019 | UART 7816 Interrupt Enable Register (UART0_IE7816) | 8 | R/W | 00h | 38.3.23/<br>784 | | 4006_A01A | UART 7816 Interrupt Status Register (UART0_IS7816) | 8 | R/W | 00h | 38.3.24/<br>785 | | 4006_A01B | UART 7816 Wait Parameter Register (UART0_WP7816T0) | 8 | R/W | 0Ah | 38.3.25/<br>786 | | 4006_A01B | UART 7816 Wait Parameter Register (UART0_WP7816T1) | 8 | R/W | 0Ah | 38.3.26/<br>787 | | 4006_A01C | UART 7816 Wait N Register (UART0_WN7816) | 8 | R/W | 00h | 38.3.27/<br>787 | | 4006_A01D | UART 7816 Wait FD Register (UART0_WF7816) | 8 | R/W | 01h | 38.3.28/<br>788 | | 4006_A01E | UART 7816 Error Threshold Register (UART0_ET7816) | | R/W | 00h | 38.3.29/<br>788 | | 4006_A01F | UART 7816 Transmit Length Register (UART0_TL7816) | 8 | R/W | 00h | 38.3.30/<br>789 | | 4006_B000 | UART Baud Rate Registers: High (UART1_BDH) | 8 | R/W | 00h | 38.3.1/760 | | 4006_B001 | UART Baud Rate Registers: Low (UART1_BDL) | 8 | R/W | 04h | 38.3.2/761 | | 4006_B002 | UART Control Register 1 (UART1_C1) | 8 | R/W | 00h | 38.3.3/761 | | 4006_B003 | UART Control Register 2 (UART1_C2) | 8 | R/W | 00h | 38.3.4/763 | | 4006_B004 | UART Status Register 1 (UART1_S1) | 8 | R | C0h | 38.3.5/765 | | 4006_B005 | UART Status Register 2 (UART1_S2) | 8 | R/W | 00h | 38.3.6/768 | | 4006_B006 | UART Control Register 3 (UART1_C3) | 8 | R/W | 00h | 38.3.7/769 | | 4006_B007 | UART Data Register (UART1_D) | 8 | R/W | 00h | 38.3.8/771 | | 4006_B008 | UART Match Address Registers 1 (UART1_MA1) | 8 | R/W | 00h | 38.3.9/772 | | 4006_B009 | UART Match Address Registers 2 (UART1_MA2) | 8 | R/W | 00h | 38.3.10/<br>772 | | 4006_B00A | UART Control Register 4 (UART1_C4) | 8 | R/W | 00h | 38.3.11/<br>773 | | 4006_B00B | UART Control Register 5 (UART1_C5) | 8 | R/W | 00h | 38.3.12/<br>773 | ## **UART** memory map (continued) | Absolute<br>address<br>(hex) | Register name | Width<br>(in bits) | Access | Reset value | Section/<br>page | |------------------------------|-------------------------------------------------------------|--------------------|--------|-----------------|------------------| | 4006_B00C | UART Extended Data Register (UART1_ED) | 8 | R | 00h | 38.3.13/<br>774 | | 4006_B00D | UART Modem Register (UART1_MODEM) | 8 | R/W | 00h | 38.3.14/<br>775 | | 4006_B010 | UART FIFO Parameters (UART1_PFIFO) | 8 | R/W | See section | 38.3.15/<br>777 | | 4006_B011 | UART FIFO Control Register (UART1_CFIFO) | 8 | R/W | 00h | 38.3.16/<br>778 | | 4006_B012 | UART FIFO Status Register (UART1_SFIFO) | 8 | R/W | C0h | 38.3.17/<br>779 | | 4006_B013 | UART FIFO Transmit Watermark (UART1_TWFIFO) | 8 | R/W | 00h | 38.3.18/<br>780 | | 4006_B014 | UART FIFO Transmit Count (UART1_TCFIFO) | 8 | R | 00h | 38.3.19/<br>781 | | 4006_B015 | UART FIFO Receive Watermark (UART1_RWFIFO) | 8 | R/W | 01h | 38.3.20/<br>781 | | 4006_B016 | UART FIFO Receive Count (UART1_RCFIFO) 8 R | | | 00h | 38.3.21/<br>782 | | 4006_B018 | UART 7816 Control Register (UART1_C7816) | 8 | R/W | 00h | 38.3.22/<br>782 | | 4006_B019 | UART 7816 Interrupt Enable Register (UART1_IE7816) | 8 | R/W | 00h | 38.3.23/<br>784 | | 4006_B01A | UART 7816 Interrupt Status Register (UART1_IS7816) 8 R/\ | | R/W | 00h | 38.3.24/<br>785 | | 4006_B01B | UART 7816 Wait Parameter Register (UART1_WP7816T0) 8 R/W 0/ | | 0Ah | 38.3.25/<br>786 | | | 4006_B01B | UART 7816 Wait Parameter Register (UART1_WP7816T1) | 8 | R/W | 0Ah | 38.3.26/<br>787 | | 4006_B01C | UART 7816 Wait N Register (UART1_WN7816) | 8 | R/W | 00h | 38.3.27/<br>787 | | 4006_B01D | UART 7816 Wait FD Register (UART1_WF7816) | 8 | R/W | 01h | 38.3.28/<br>788 | | 4006_B01E | UART 7816 Error Threshold Register (UART1_ET7816) | 8 | R/W | 00h | 38.3.29/<br>788 | | 4006_B01F | UART 7816 Transmit Length Register (UART1_TL7816) 8 R/W | | R/W | 00h | 38.3.30/<br>789 | | 4006_C000 | UART Baud Rate Registers: High (UART2_BDH) | 8 | R/W | 00h | 38.3.1/760 | | 4006_C001 | UART Baud Rate Registers: Low (UART2_BDL) | 8 | R/W | 04h | 38.3.2/761 | | 4006_C002 | UART Control Register 1 (UART2_C1) | 8 | R/W | 00h | 38.3.3/761 | | 4006_C003 | UART Control Register 2 (UART2_C2) | 8 | R/W | 00h | 38.3.4/763 | | 4006_C004 | UART Status Register 1 (UART2_S1) | 8 | R | C0h | 38.3.5/765 | | 4006_C005 | UART Status Register 2 (UART2_S2) | 8 | R/W | 00h | 38.3.6/768 | | 4006_C006 | UART Control Register 3 (UART2_C3) | 8 | R/W | 00h | 38.3.7/769 | Table continues on the next page... # **UART** memory map (continued) | Absolute address (hex) | Register name | Width<br>(in bits) | Access | Reset value | Section/<br>page | |------------------------|----------------------------------------------------|----------------------------------------------|--------|-----------------|------------------| | 4006_C007 | UART Data Register (UART2_D) | 8 | R/W | 00h | 38.3.8/771 | | 4006_C008 | UART Match Address Registers 1 (UART2_MA1) | 8 | R/W | 00h | 38.3.9/772 | | 4006_C009 | UART Match Address Registers 2 (UART2_MA2) | 8 | R/W | 00h | 38.3.10/<br>772 | | 4006_C00A | UART Control Register 4 (UART2_C4) | 8 | R/W | 00h | 38.3.11/<br>773 | | 4006_C00B | UART Control Register 5 (UART2_C5) | 8 | R/W | 00h | 38.3.12/<br>773 | | 4006_C00C | UART Extended Data Register (UART2_ED) | 8 | R | 00h | 38.3.13/<br>774 | | 4006_C00D | UART Modem Register (UART2_MODEM) | 8 | R/W | 00h | 38.3.14/<br>775 | | 4006_C010 | UART FIFO Parameters (UART2_PFIFO) | 8 | R/W | See section | 38.3.15/<br>777 | | 4006_C011 | UART FIFO Control Register (UART2_CFIFO) | RT FIFO Control Register (UART2_CFIFO) 8 R/W | | 00h | 38.3.16/<br>778 | | 4006_C012 | UART FIFO Status Register (UART2_SFIFO) | ter (UART2_SFIFO) 8 R/W | | C0h | 38.3.17/<br>779 | | 4006_C013 | UART FIFO Transmit Watermark (UART2_TWFIFO) | 8 | R/W | 00h | 38.3.18/<br>780 | | 4006_C014 | UART FIFO Transmit Count (UART2_TCFIFO) | 8 | R | 00h | 38.3.19/<br>781 | | 4006_C015 | UART FIFO Receive Watermark (UART2_RWFIFO) | 8 | R/W | 01h | 38.3.20/<br>781 | | 4006_C016 | UART FIFO Receive Count (UART2_RCFIFO) | 8 | R | 00h | 38.3.21/<br>782 | | 4006_C018 | UART 7816 Control Register (UART2_C7816) | 8 | R/W | 00h | 38.3.22/<br>782 | | 4006_C019 | UART 7816 Interrupt Enable Register (UART2_IE7816) | 8 | R/W | 00h | 38.3.23/<br>784 | | 4006_C01A | UART 7816 Interrupt Status Register (UART2_IS7816) | 8 | R/W | 00h | 38.3.24/<br>785 | | 4006_C01B | UART 7816 Wait Parameter Register (UART2_WP7816T0) | 8 | R/W | 0Ah | 38.3.25/<br>786 | | 4006_C01B | UART 7816 Wait Parameter Register (UART2_WP7816T1) | '816T1) 8 R/W | | 0Ah | 38.3.26/<br>787 | | 4006_C01C | UART 7816 Wait N Register (UART2_WN7816) 8 R/W | | 00h | 38.3.27/<br>787 | | | 4006_C01D | UART 7816 Wait FD Register (UART2_WF7816) | Wait FD Register (UART2_WF7816) 8 R/W 01h | | 38.3.28/<br>788 | | | 4006_C01E | UART 7816 Error Threshold Register (UART2_ET7816) | 8 R/W 00h | | 38.3.29/<br>788 | | | 4006_C01F | UART 7816 Transmit Length Register (UART2_TL7816) | 8 | R/W | 00h | 38.3.30/<br>789 | ## **UART** memory map (continued) | Absolute<br>address<br>(hex) | Register name | Width<br>(in bits) | Access | Reset value | Section/<br>page | |------------------------------|----------------------------------------------------|--------------------|--------|-------------|------------------| | 4006_D000 | UART Baud Rate Registers: High (UART3_BDH) | 8 | R/W | 00h | 38.3.1/760 | | 4006_D001 | UART Baud Rate Registers: Low (UART3_BDL) | 8 | R/W | 04h | 38.3.2/761 | | 4006_D002 | UART Control Register 1 (UART3_C1) | 8 | R/W | 00h | 38.3.3/761 | | 4006_D003 | UART Control Register 2 (UART3_C2) | 8 | R/W | 00h | 38.3.4/763 | | 4006_D004 | UART Status Register 1 (UART3_S1) | 8 | R | C0h | 38.3.5/765 | | 4006_D005 | UART Status Register 2 (UART3_S2) | 8 | R/W | 00h | 38.3.6/768 | | 4006_D006 | UART Control Register 3 (UART3_C3) | 8 | R/W | 00h | 38.3.7/769 | | 4006_D007 | UART Data Register (UART3_D) | 8 | R/W | 00h | 38.3.8/771 | | 4006_D008 | UART Match Address Registers 1 (UART3_MA1) | 8 | R/W | 00h | 38.3.9/772 | | 4006_D009 | UART Match Address Registers 2 (UART3_MA2) | 8 | R/W | 00h | 38.3.10/<br>772 | | 4006_D00A | UART Control Register 4 (UART3_C4) | 8 | R/W | 00h | 38.3.11/<br>773 | | 4006_D00B | UART Control Register 5 (UART3_C5) | 8 | R/W | 00h | 38.3.12/<br>773 | | 4006_D00C | UART Extended Data Register (UART3_ED) | 8 | R | 00h | 38.3.13/<br>774 | | 4006_D00D | UART Modem Register (UART3_MODEM) | 8 | R/W | 00h | 38.3.14/<br>775 | | 4006_D010 | UART FIFO Parameters (UART3_PFIFO) | 8 | R/W | See section | 38.3.15/<br>777 | | 4006_D011 | UART FIFO Control Register (UART3_CFIFO) | 8 | R/W | 00h | 38.3.16/<br>778 | | 4006_D012 | UART FIFO Status Register (UART3_SFIFO) | 8 | R/W | C0h | 38.3.17/<br>779 | | 4006_D013 | UART FIFO Transmit Watermark (UART3_TWFIFO) | 8 | R/W | 00h | 38.3.18/<br>780 | | 4006_D014 | UART FIFO Transmit Count (UART3_TCFIFO) | 8 | R | 00h | 38.3.19/<br>781 | | 4006_D015 | UART FIFO Receive Watermark (UART3_RWFIFO) | 8 | R/W | 01h | 38.3.20/<br>781 | | 4006_D016 | UART FIFO Receive Count (UART3_RCFIFO) | 8 | R | 00h | 38.3.21/<br>782 | | 4006_D018 | UART 7816 Control Register (UART3_C7816) | 8 | R/W | 00h | 38.3.22/<br>782 | | 4006_D019 | UART 7816 Interrupt Enable Register (UART3_IE7816) | 8 | R/W | 00h | 38.3.23/<br>784 | | 4006_D01A | UART 7816 Interrupt Status Register (UART3_IS7816) | 8 | R/W | 00h | 38.3.24/<br>785 | | 4006_D01B | UART 7816 Wait Parameter Register (UART3_WP7816T0) | 8 | R/W | 0Ah | 38.3.25/<br>786 | | 4006_D01B | UART 7816 Wait Parameter Register (UART3_WP7816T1) | 8 | R/W | 0Ah | 38.3.26/<br>787 | Table continues on the next page... ## **UART** memory map (continued) | Absolute address (hex) | Register name | Width<br>(in bits) | Access | Reset value | Section/<br>page | |------------------------|---------------------------------------------------|--------------------|--------|-------------|------------------| | 4006_D01C | UART 7816 Wait N Register (UART3_WN7816) | 8 | R/W | 00h | 38.3.27/<br>787 | | 4006_D01D | UART 7816 Wait FD Register (UART3_WF7816) | 8 | R/W | 01h | 38.3.28/<br>788 | | 4006_D01E | UART 7816 Error Threshold Register (UART3_ET7816) | 8 | R/W | 00h | 38.3.29/<br>788 | | 4006_D01F | UART 7816 Transmit Length Register (UART3_TL7816) | 8 | R/W | 00h | 38.3.30/<br>789 | ## 38.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 nonzero value, but after reset, the baud rate generator remains disabled until the first time the receiver or transmitter is enabled, that is, when C2[RE] or C2[TE] is set. Address: Base address + 0h offset ### **UARTx\_BDH** field descriptions | Field | Description | | | | | | | |---------------|------------------------------------------------------------------------------------------------------|--|--|--|--|--|--| | 7<br>Reserved | Reserved. | | | | | | | | | This field is reserved. | | | | | | | | 6<br>RXEDGIE | RxD Input Active Edge Interrupt Enable | | | | | | | | | Enables the receive input active edge, RXEDGIF, to generate interrupt requests. | | | | | | | | | 0 Hardware interrupts from RXEDGIF disabled using polling. | | | | | | | | | 1 RXEDGIF interrupt request enabled. | | | | | | | | 5<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | | | | | | | 4–0<br>SBR | UART Baud Rate Bits | | | | | | | | John | The baud rate for the UART is determined by the 13 SBR fields. See Baud rate generation for details. | | | | | | | Table continues on the next page... ### **UARTx\_BDH** field descriptions (continued) | Field | | Description | |-------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | NOTE: | <ul> <li>The baud rate generator is disabled until C2[TE] or C2[RE] is set for the first time after reset. The baud rate generator is disabled when SBR = 0.</li> <li>Writing to BDH has no effect without writing to BDL, because writing to BDH puts the data in a temporary location until BDL is written.</li> </ul> | ## 38.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 nonzero value, but after reset, the baud rate generator remains disabled until the first time the receiver or transmitter is enabled, that is, when C2[RE] or C2[TE] is set. Address: Base address + 1h offset | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|---|---|---|----|----|---|---|---| | Read<br>Write | | | | SE | 3R | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | ### **UARTx\_BDL** field descriptions | Field | Description | | | | | | | |------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--| | 7–0<br>SBR | UART Baud Rate Bits The baud rate for the UART is determined by the 13 SBR fields. See Baud rate generation for details. NOTE: • The baud rate generator is disabled until C2[TE] or C2[RE] is set for the first time after | | | | | | | | | <ul> <li>reset.The baud rate generator is disabled when SBR = 0.</li> <li>Writing to BDH has no effect without writing to BDL, because writing to BDH puts the data in a temporary location until BDL is written.</li> </ul> | | | | | | | # 38.3.3 UART Control Register 1 (UARTx\_C1) This read/write register controls various optional features of the UART system. Address: Base address + 2h offset # **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. O Normal operation. | | | 1 Loop mode where transmitter output is internally connected to receiver input. The receiver input is determined by RSRC. | | 6<br>Reserved | Reserved. | | _ | This field is reserved. | | 5<br>RSRC | Receiver Source Select | | Hono | This field has no meaning or effect unless the LOOPS field is set. When LOOPS is set, the RSRC field determines the source for the receiver shift register input. | | | <ul> <li>Selects internal loop back mode. The 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 field must be set when C7816[ISO_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 | | | 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 | | | Determines when the receiver starts counting logic 1s as idle character bits. The count 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. | | | <ul> <li>NOTE:</li> <li>In case the UART is programmed with ILT = 1, a logic of 1'b0 is automatically shifted after a received stop bit, therefore resetting the idle count.</li> <li>In case the 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] fields.</li> </ul> | | | 0 Idle character bit count starts after start bit. | | | 1 Idle character bit count starts after stop bit. | | 1 | Parity Enable | | PE | Enables the parity function. When parity is enabled, parity function inserts a parity bit in the bit position immediately preceding the stop bit. This field must be set when C7816[ISO_7816E] is set/enabled. | Table continues on the next page... ## **UARTx\_C1** field descriptions (continued) | Field | Description | |---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | 0 Parity function disabled. | | | 1 Parity function enabled. | | 0<br>PT | Parity Type | | | 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 field must be cleared when C7816[ISO_7816E] is set/enabled. 0 Even parity. 1 Odd parity. | # 38.3.4 UART Control Register 2 (UARTx\_C2) This register can be read or written at any time. Address: Base address + 3h offset | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|-----|------|-----|------|----|----|-----|-----| | Read<br>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<br>TIE | Transmitter Interrupt or DMA Transfer Enable. | | | | | | | | | | Enables S1[TDRE] 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 unless servicing a DMA request. | | | | | | | | | | 0 TDRE interrupt and DMA transfer requests disabled. | | | | | | | | | | 1 TDRE interrupt or DMA transfer requests enabled. | | | | | | | | | 6<br>TCIE | Transmission Complete Interrupt Enable | | | | | | | | | 1012 | Enables the transmission complete flag, S1[TC], to generate interrupt requests . | | | | | | | | | | 0 TC interrupt requests disabled. | | | | | | | | | | 1 TC interrupt requests enabled. | | | | | | | | | 5<br>RIE | Receiver Full Interrupt or DMA Transfer Enable | | | | | | | | | THE | Enables S1[RDRF] to generate interrupt requests or DMA transfer requests, based on the state of C5[RDMAS]. | | | | | | | | | | 0 RDRF interrupt and DMA transfer requests disabled. | | | | | | | | | | 1 RDRF interrupt or DMA transfer requests enabled. | | | | | | | | Table continues on the next page... # **UARTx\_C2** field descriptions (continued) | Field | Description | |----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 4 | Idle Line Interrupt Enable | | ILIE | Enables the idle line flag, S1[IDLE], to generate interrupt requests | | | 0 IDLE interrupt requests disabled. | | | IDLE interrupt requests disabled. I IDLE interrupt requests enabled. | | 3 | Transmitter Enable | | TE | Enables the UART transmitter. TE can be used to queue an idle preamble by clearing and then setting TE. When C7816[ISO_7816E] is set/enabled and C7816[TTYPE] = 1, this field is automatically cleared after the requested block has been transmitted. This condition is detected when TL7816[TLEN] = 0 and four additional characters are transmitted. | | | 0 Transmitter off. | | | 1 Transmitter on. | | 2<br>RE | Receiver Enable | | 1112 | Enables the UART receiver. | | | 0 Receiver off. | | | 1 Receiver on. | | 1<br>RWU | Receiver Wakeup Control This field can be set to place the UART receiver in a standby state. RWU automatically clears when an RWU event occurs, that is, an IDLE event when C1[WAKE] is clear or an address match when C1[WAKE] | | | is set. This field must be cleared when C7816[ISO_7816E] is set. NOTE: RWU must be set only with C1[WAKE] = 0 (wakeup on idle) if the channel is currently not idle. This can be determined by S2[RAF]. If the flag is set to wake up an IDLE event and the channel is already idle, it is possible that the UART will discard data. This is because the data must be received 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 wakes the receiver by automatically clearing RWU.</li> </ul> | | 0 | Send Break | | SBK | Toggling SBK sends one break character from the following: See Transmitting break characters for the number of logic 0s for the different configurations. Toggling implies clearing the SBK field 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). Ensure that C2[TE] is asserted atleast 1 clock before assertion of this bit. • 10, 11, or 12 logic 0s if S2[BRK13] is cleared • 13 or 14 logic 0s if S2[BRK13] is set. | | | This field must be cleared when C7816[ISO_7816E] is set. | | | 0 Normal transmitter operation. | | | 1 Queue break characters to be sent. | ## 38.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 its fields. To clear a flag, the status register should be read followed by a read or write to D register, depending on the interrupt flag type. Other instructions can be executed between the two steps as long the handling of I/O is not compromised, 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, reasserts. For example, if the DMA or interrupt service routine fails to write sufficient data to the transmit buffer to raise it above the watermark level, the flag reasserts and generates another interrupt or DMA request. - Reading an empty data register to clear one of the flags of the S1 register causes the FIFO pointers to become misaligned. A receive FIFO flush reinitializes the pointers. A better way to prevent this situation is to always leave one byte in FIFO and this byte will be read eventually in clearing the flag bit. ### **UARTx\_S1** field descriptions | | Field | Description | |---|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Ī | 7<br>TDRE | Transmit Data Register Empty Flag | | | | 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 must be 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 because the TDRE reasserts until the watermark has been exceeded. So, attempting to clear the TDRE with every write will be ineffective until sufficient data has been written. | Table continues on the next page... # **UARTx\_S1** field descriptions (continued) | Field | Description | |-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | <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<br>TC | Transmit Complete Flag 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). TC is cleared by reading S1 with TC set and then doing one of the following: When C7816[ISO_7816E] is set/enabled, this field is set of the control base becomes ided, but prior to any experienced in a set of the control base becomes ided. | | | <ul> <li>field is set after any NACK signal has been received, but prior to any corresponding guard times expiring.</li> <li>Writing to D to transmit new data.</li> <li>Queuing a preamble by clearing and then setting C2[TE].</li> <li>Queuing a break character by writing 1 to SBK in C2.</li> </ul> | | | <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 | | | RDRF is set when the number of datawords in the receive buffer is equal to or more than the number indicated by RWFIFO[RXWATER]. A dataword that is in the process of being received is not included in the count. To clear RDRF, read S1 when RDRF is set and then read D. For more efficient interrupt and DMA operation, read all data except the final value from the buffer, using D/C3[T8]/ED. Then read S1 and the final data value, resulting in the clearing of the RDRF flag. Even if RDRF 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 some point in time since this flag was last cleared.</li> </ul> | | 4<br>IDLE | Idle Line Flag 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). To clear IDLE, read UART status S1 with IDLE set and then read D. IDLE is set when either of the following appear on the receiver input: • 10 consecutive logic 1s if C1[M] = 0 • 11 consecutive logic 1s if C1[M] = 1 and C4[M10] = 0 • 12 consecutive logic 1s if C1[M] = 1, C4[M10] = 1, and C1[PE] = 1 | | | Idle detection is not supported when 7816E is set/enabled and hence this flag is ignored. | | | <b>NOTE:</b> When 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 become set. | | | <ul> <li>Receiver input is either active now or has never become active since the IDLE flag was last cleared.</li> <li>Receiver input has become idle or the flag has not been cleared since it last asserted.</li> </ul> | | 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 is stored in the data buffer even if sufficient room exists. Additionally, while the OR flag is set, the RDRF and IDLE flags are blocked from asserting, that is, transition from an inactive to an active state. To clear OR, read S1 when OR is set and then read D. See functional description 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 C7816[ONACK]. | Table continues on the next page... 766 Preliminary Freescale Semiconductor, Inc. ## **UARTx\_S1** field descriptions (continued) | Field | Description | |---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | 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 | Noise Flag | | | NF is set when the UART detects noise on the receiver input. NF does not become set in the case of an overrun. When NF is set, it indicates only 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 D. | | | 0 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<br>FE | Framing Error Flag | | | FE is set when a logic 0 is accepted as the stop bit. FE does not set in the case of an overrun. FE inhibits further data reception until it is cleared. To clear FE, read S1 with FE set and then read D. The last data in the receive buffer represents the data that was received with the frame error enabled. Framing errors are not supported when 7816E is set/enabled. However, if this flag is set, data is still not received in 7816 mode. | | | 0 No framing error detected. | | | 1 Framing error. | | 0<br>PF | Parity Error Flag | | FI | PF is set when PE is set 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 PF is set, it indicates only 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 has a depth of one. To clear PF, read S1 and then read D.Within the receive buffer structure the received dataword is tagged if it is received with a parity error. This information is available by reading the ED register prior to reading the D register. | | | <ul> <li>No parity error 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.</li> <li>At least one dataword was received with a parity error since the last time this flag was cleared.</li> </ul> | ## 38.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 be changed by the user only between transmit and receive packets. Address: Base address + 5h offset | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|---|---------|--------|--------|--------|---------|-----------|-----| | Read | 0 | RXEDGIF | MSBF | RXINV | RWUID | BRK13 | Reserved | RAF | | Write | | w1c | IVIODI | TIXIIV | TIWOID | DITICIO | rieserveu | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ### **UARTx\_S2** field descriptions | Field | Description | |---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 6<br>RXEDGIF | RxD Pin Active Edge Interrupt Flag RXEDGIF is set when an active edge occurs on the RxD pin. The active edge is falling if RXINV = 0, and | | | rising if RXINV=1. RXEDGIF is cleared by writing a 1 to it. See for additional details. RXEDGIF description | | | NOTE: The active edge is detected only in two wire mode and on receiving 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 field reverses the order of the bits that are transmitted and received on the wire. This field does not affect the polarity of the bits, the location of the parity bit, or the location of the start or stop bits. This field is automatically set when C7816[INIT] and C7816[ISO7816E] are enabled and an initial character is detected in T = 0 protocol mode. | | | 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 | | | Setting this field 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. In IrDA format, a zero is represented by short high pulse in the middle of a bit time remaining idle low for a one for normal polarity. A zero is represented by a short low pulse in the middle of a bit time remaining idle high for a one for inverted polarity. This field is automatically set when C7816[INIT] and C7816[ISO7816E] are enabled and an initial character is detected in T = 0 protocol mode. | Table continues on the next page... ### **UARTx\_S2** field descriptions (continued) | Field | Description | |---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | NOTE: Setting RXINV inverts the RxD input for data bits, start and stop bits, break, and idle. When C7816[ISO7816E] is set/enabled, 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 field controls whether the idle character that wakes the receiver sets S1[IDLE]. This field must be cleared when C7816[ISO7816E] is set/enabled. | | | 0 S1[IDLE] is not set upon detection of an idle character. | | | 1 S1[IDLE] is set upon detection of an idle character. | | 2<br>BRK13 | Break Transmit Character Length | | | Determines whether the transmit break character is 10, 11, or 12 bits long, or 13 or 14 bits long. See for the length of the break character for the different configurations. The detection of a framing error is not affected by this field. Transmitting break characters | | | 0 Break character is 10, 11, or 12 bits long. | | | 1 Break character is 13 or 14 bits long. | | 1<br>Reserved | Reserved. | | | This field is reserved. | | 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. | | | NOTE: In case C7816[ISO7816E] is set and C7816[TTYPE] = 0, it is possible to configure the guard to 12. However, if a NACK is required to be transmitted, the data transfer actually takes 13 ETU with the 13th ETU slot being a inactive buffer. Therefore, in this situation, the RAF may deasse one ETU prior to actually being inactive. | | | 0 UART receiver idle/inactive waiting for a start bit. | | | 1 UART receiver active, RxD input not idle. | # 38.3.7 UART Control Register 3 (UARTx\_C3) Writing R8 does not have any effect. TXDIR and TXINV can be changed only between transmit and receive packets. Address: Base address + 6h offset # **UARTx\_C3** field descriptions | Field | Description | |------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | Received Bit 8 | | R8 | R8 is the ninth data bit received when the UART is configured for 9-bit data format, that is, if C1[M] = 1 or C4[M10] = 1. The R8 value corresponds to the current data value in the UARTx_D register. To read the 9th bit, read the value of UARTx_C3[R8], then read the UARTx_D register. | | 6<br>T8 | Transmit Bit 8 T8 is the ninth data bit transmitted when the UART is configured for 9-bit data format, that is, if 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. To correctly transmit the 9th bit, write UARTx_C3[T8] to the desired value, then write the UARTx_D register with the remaining data. | | 5 | Transmitter Pin Data Direction in Single-Wire mode | | TXDIR | Determines whether the TXD pin is used as an input or output in the single-wire mode of operation. This field is relevant only to the single wire mode. When C7816[ISO7816E] is set/enabled and C7816[TTYPE] = 1, this field is automatically cleared after the requested block is transmitted. This condition is detected when TL7816[TLEN] = 0 and 4 additional characters are transmitted. Additionally, if C7816[ISO7816E] is set/enabled and C7816[TTYPE] = 0 and a NACK is being transmitted, the hardware automatically overrides this field as needed. In this situation, TXDIR does 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. | | | Setting this field 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 field is automatically set when C7816[INIT] and C7816[ISO7816E] are enabled and an initial character is detected in T = 0 protocol mode. | | | 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. | | | <ul><li>0 Transmit data is not inverted.</li><li>1 Transmit data is inverted.</li></ul> | | 3<br>ORIE | Overrun Error Interrupt Enable | | | 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 | | | 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 | Table continues on the next page... ### **UARTx\_C3** field descriptions (continued) | Field | Description | |-----------|------------------------------------------------------------------------------------------------------| | | Enables the framing error flag, S1[FE], to generate interrupt requests. | | | <ul><li>0 FE interrupt requests are disabled.</li><li>1 FE interrupt requests are enabled.</li></ul> | | 0<br>PEIE | Parity Error Interrupt Enable Enables the parity error flag, S1[PF], to generate interrupt requests. | | | <ul><li>0 PF interrupt requests are disabled.</li><li>1 PF interrupt requests are enabled.</li></ul> | ## 38.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 to clear the S1[RDRF] bit (assuming receiver buffer level is less than RWFIFO[RXWATER]). The C3 register needs to be read, prior to the D register, only if the ninth bit of data needs to be captured. Similarly, the ED register needs to be read, prior to the D register, only if the additional flag data for the dataword needs to be captured. - 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 is loaded into the D register. So, for the data bits, mask off the parity bit from the value you read out of this register. - 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, and then the new data on data bus is stored in D, the temporary value written by the last write to C3[T8] gets stored in the C3[T8] register. Address: Base address + 7h offset | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|----|---|---|---|---|---|---|---| | Read [<br>Write | RT | | | | | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 771 ### **UARTx\_D** field descriptions | Field | Description | |-------|-----------------------------------------------------------------------------------------------------------| | 7–0 | Reads return the contents of the read-only receive data register and writes go to the write-only transmit | | RT | data register. | ## 38.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] field 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. | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|----|---|---|---|---|---|---|---| | Read<br>Write | MA | | | | | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ### **UARTx\_MA1** field descriptions | Field | Description | |-----------|---------------| | 7–0<br>MA | Match Address | ## 38.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] field is set. If a match occurs, the following data is transferred to the data register. If a match fails, the following data is discarded. #### Address: Base address + 9h offset #### **UARTx\_MA2** field descriptions | Field | Description | |-----------|---------------| | 7–0<br>MA | Match Address | # 38.3.11 UART Control Register 4 (UARTx\_C4) Address: Base address + Ah offset ## **UARTx\_C4** field descriptions | Field | Description | |-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7<br>MAEN1 | Match Address Mode Enable 1 See Match address operation for more information. | | | <ul> <li>All data received is transferred to the data buffer if MAEN2 is cleared.</li> <li>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 field must be cleared when C7816[ISO7816E] is set/enabled.</li> </ul> | | 6<br>MAEN2 | Match Address Mode Enable 2 See Match address operation for more information. O All data received is transferred to the data buffer if MAEN1 is cleared. 1 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 a match occurs, data is transferred to the data buffer. This field must be cleared when C7816[ISO7816E] is set/enabled. | | 5<br>M10 | 10-bit Mode select 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. If M10 is set, then both C1[M] and C1[PE] must also be set. This field must be cleared when C7816[ISO7816E] is set/enabled. See Data format (non ISO-7816) for more information. | | | <ul> <li>The parity bit is the ninth bit in the serial transmission.</li> <li>The parity bit is the tenth bit in the serial transmission.</li> </ul> | | 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. See Baud rate generation for more information. | # 38.3.12 UART Control Register 5 (UARTx\_C5) Address: Base address + Bh offset | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|-------|---|-------|---|---|---|---|---| | Read | TDMAS | 0 | RDMAS | 0 | | C | ) | | | Write | | | | | | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ### **UARTx\_C5** field descriptions | Field | Description | | | |-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | 7<br>TDMAS | Transmitter DMA Select | | | | IDIVIAS | Configures the transmit data register empty flag, S1[TDRE], to generate interrupt or DMA requests if C2[TIE] is set. | | | | | <ul> <li>NOTE:</li> <li>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.</li> <li>If C2[TIE] and TDMAS are both set, then C2[TCIE] must be cleared, and D must not be written unless a DMA request is being serviced.</li> </ul> | | | | | 0 If C2[TIE] is set and the S1[TDRE] flag is set, the TDRE interrupt request signal is asserted to request interrupt service. | | | | | 1 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 field is reserved. This read-only field is reserved and always has the value 0. | | | | 5<br>RDMAS | Receiver Full DMA Select | | | | | 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, and S1[RDRF] is set, the RDRF DMA and RDFR interrupt request signals are not asserted, regardless of the state of RDMAS. | | | | | 0 If C2[RIE] and S1[RDRF] are set, the RDFR interrupt request signal is asserted to request an interrupt service. | | | | | 1 If C2[RIE] and S1[RDRF] are set, the RDRF DMA request signal is asserted to request a DMA transfer. | | | | 4<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | | | 3–0<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | | ## 38.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 contains valid data only 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 the application, and in some cases maybe completely optional. These fields automatically update to reflect the conditions of the next dataword whenever D is read. • If S1[NF] and S1[PF] have not been set since the last time the receive buffer was empty, the NOISY and PARITYE fields will be zero. #### Address: Base address + Ch offset ### **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 field is reserved. This read-only field is reserved and always has the value 0. | ## 38.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 use the RTS and CTS signals. #### Address: Base address + Dh offset # **UARTx\_MODEM** field descriptions | Field | Description | | | | |-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | 7–4 | This field is reserved. | | | | | Reserved | This read-only field is reserved and always has the value 0. | | | | | 3<br>RXRTSE | Receiver request-to-send enable | | | | | TIXITIOL | 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 greater than RWFIFO[RXWATER]. RTS is asserted when the number of characters in the receiver 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. | | | | | | 0 Transmitter RTS is active low. | | | | | | 1 Transmitter RTS is active high. | | | | | 1<br>TXRTSE | Transmitter request-to-send enable | | | | | IXHISE | 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, RTS asserts one bit time before the start bit is transmitted. RTS deasserts one bit time after all characters in the transmitter data buffer and shift register are completely sent, including the last stop bit. (FIFO)(FIFO) | | | | | 0<br>TXCTSE | Transmitter clear-to-send enable | | | | | INCISE | TXCTSE controls the operation of the transmitter. TXCTSE can be set independently from the state of TXRTSE and RXRTSE. | | | | | | 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. | | | | # 38.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 size of the FIFO that has been implemented. This register may be read at any time. This register must be written only when C2[RE] and C2[TE] are cleared/not set and when the data buffer/FIFO is empty. <sup>\*</sup> Notes: - TXFIFOSIZE field: The reset value depends on whether the specific UART instance supports the FIFO and on the size of that FIFO. See the Chip Configuration details for more information on the FIFO size supported for each UART instance. - RXFIFOSIZE field: The reset value depends on whether the specific UART instance supports the FIFO and on the size of that FIFO. See the Chip Configuration details for more information on the FIFO size supported for each UART instance. #### **UARTx\_PFIFO** field descriptions | Field | Description | | | | |-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | 7<br>TXFE | Transmit FIFO Enable | | | | | TALE | When this field is set, the built in FIFO structure for the transmit buffer is enabled. The size of the FIFO structure is indicated by TXFIFOSIZE. If this field is not set, 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 field. Additionally, TXFLUSH and RXFLUSH commands must be issued immediately after changing this field. | | | | | | 0 Transmit FIFO is not enabled. Buffer is depth 1. (Legacy support). | | | | | | 1 Transmit FIFO is enabled. Buffer is depth indicated by TXFIFOSIZE. | | | | | 6–4<br>TXFIFOSIZE | Transmit FIFO. Buffer Depth 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. | | | | | | 101 Transmit FIFO/Buffer depth = 64 datawords. | | | | | | 110 Transmit FIFO/Buffer depth = 128 datawords. | | | | | | 111 Reserved. | | | | | 3<br>RXFE | Receive FIFO Enable | | | | Table continues on the next page... ### **UARTx\_PFIFO** field descriptions (continued) | Field | Description | | | | |-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | | When this field 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 field is not set, 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 field. Additionally, TXFLUSH and RXFLUSH commands must be issued immediately after changing this field. | | | | | | 0 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. | | | | ## 38.3.16 UART FIFO Control Register (UARTx\_CFIFO) This register provides the ability to program various control fields for FIFO operation. This register may be read or written at any time. Note that writing to TXFLUSH and RXFLUSH may result in data loss and requires careful action to prevent unintended/ unpredictable behavior. Therefore, 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 | | | Writing to this field 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. | Table continues on the next page... #### KM Family Reference Manual, Rev. 5, Oct 2013 778 Preliminary Freescale Semiconductor, Inc. ### **UARTx\_CFIFO** field descriptions (continued) | Field | Description | | | |-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | 6<br>RXFLUSH | Receive FIFO/Buffer Flush | | | | TIXI EGGIT | Writing to this field 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. | | | | | 1 All data in the receive FIFO/buffer is cleared out. | | | | 5–3<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | | | 2 | Receive FIFO Overflow Interrupt Enable | | | | RXOFE | When this field is set, the RXOF flag generates an interrupt to the host. | | | | | 0 RXOF flag does not generate an interrupt to the host. | | | | | 1 RXOF flag generates an interrupt to the host. | | | | 1 | Transmit FIFO Overflow Interrupt Enable | | | | TXOFE | When this field is set, the TXOF flag generates 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 | | | | | When this field is set, the RXUF flag generates 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. | | | ## 38.3.17 UART FIFO Status Register (UARTx\_SFIFO) This register provides status information regarding the transmit and receiver buffers/FIFOs, including interrupt information. This register may be written to or read at any time. Address: Base address + 12h offset ### **UARTx\_SFIFO** field descriptions | Field | Description | |-------------|-----------------------------------------------------------------------------------------------------------------------------------------------| | 7<br>TXEMPT | Transmit Buffer/FIFO Empty | | | Asserts when there is no data in the Transmit FIFO/buffer. This field does not take into account data that is in the transmit shift register. | Table continues on the next page... ## **UARTx\_SFIFO** field descriptions (continued) | Field | Description | |-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | 0 Transmit buffer is not empty. | | | 1 Transmit buffer is empty. | | 6<br>RXEMPT | Receive Buffer/FIFO Empty | | | Asserts when there is no data in the receive FIFO/Buffer. This field 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–3 | This field is reserved. | | Reserved | This read-only field is reserved and always has the value 0. | | 2<br>RXOF | Receiver Buffer Overflow Flag | | | Indicates that more data has been written to the receive buffer than it can hold. This field will assert regardless of the value of CFIFO[RXOFE]. However, an interrupt will be issued to the host only if CFIFO[RXOFE] is set. This flag is cleared by writing a 1. | | | 0 No receive buffer overflow has occurred since the last time the flag was cleared. | | | 1 At least one receive buffer overflow has occurred since the last time the flag was cleared. | | 1<br>TXOF | Transmitter Buffer Overflow Flag | | | Indicates that more data has been written to the transmit buffer than it can hold. This field will assert regardless of the value of CFIFO[TXOFE]. However, an interrupt will be issued to the host only if CFIFO[TXOFE] is set. This flag is cleared by writing a 1. | | | 0 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 | | | Indicates that more data has been read from the receive buffer than was present. This field will assert regardless of the value of CFIFO[RXUFE]. However, an interrupt will be issued to the host only if CFIFO[RXUFE] 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. | # 38.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 must be written only when C2[TE] is not set. Changing the value of the watermark will not clear the S1[TDRE] flag. Address: Base address + 13h offset #### **UARTx\_TWFIFO** field descriptions | Field | Description | |---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7–0 | Transmit Watermark | | TXWATER | | | | When the number of datawords in the transmit FIFO/buffer is equal to or less than the value in this register | | | field, an interrupt via S1[TDRE] or a DMA request via C5[TDMAS] is generated as determined by | | | C5[TDMAS] and C2[TIE]. For proper operation, the value in TXWATER must be set to be less than the size of the transmit buffer/FIFO size as indicated by PFIFO[TXFIFOSIZE] and PFIFO[TXFE]. | # 38.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 any time. ### **UARTx\_TCFIFO** field descriptions | Field | Description | |-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | Transmit Counter The value in this register indicates the number of datawords that are in the transmit FIFO/buffer. If a dataword is being transmitted, that is, in the transmit shift register, it is not included in the count. This value may be used in conjunction with PFIFO[TXFIFOSIZE] to calculate how much room is left in the transmit FIFO/buffer. | # 38.3.20 UART FIFO Receive Watermark (UARTx\_RWFIFO) This register provides the ability to set a programmable threshold for notification of the need to remove data from the receiver FIFO/buffer. This register may be read at any time but must be written only when C2[RE] is not asserted. Changing the value in this register will not clear S1[RDRF]. Address: Base address + 15h offset | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|---|---|---|-----|------|---|---|---| | Read<br>Write | | | | RXW | ATER | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | ### **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, an interrupt via S1[RDRF] or a DMA request via C5[RDMAS] is generated as determined by C5[RDMAS] and C2[RIE]. For proper operation, the value in RXWATER must be set to be less than the receive FIFO/buffer size as indicated by PFIFO[RXFIFOSIZE] and PFIFO[RXFE] and must be greater than 0. | ## 38.3.21 UART FIFO Receive Count (UARTx\_RCFIFO) This is a read only register that indicates how many datawords are currently in the receive FIFO/buffer. It may be read at any time. ### **UARTx\_RCFIFO** field descriptions | Field | Description | |----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7–0<br>RXCOUNT | Receive Counter The value in this register indicates the number of datawords that are in the receive FIFO/buffer. If a dataword is being received, that is, in the receive shift register, it is not included in the count. This value may be used in conjunction with PFIFO[RXFIFOSIZE] to calculate how much room is left in the receive FIFO/buffer. | ## 38.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 any time but values must be changed only when ISO\_7816E is not set. 782 Preliminary Freescale Semiconductor, Inc. ## **UARTx\_C7816** field descriptions | Field | Description | |------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7–5<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 4<br>ONACK | Generate NACK on Overflow | | | When this field is set, the receiver automatically generates a NACK response if a receive buffer overrun occurs, as indicated by S1[OR]. In many systems, this results in the transmitter resending the packet that overflowed until the retransmit threshold for that transmitter is reached. A NACK is generated only if TTYPE=0. This field operates independently of ANACK. See . Overrun NACK considerations | | | The received data does not generate a NACK when the receipt of the data results in an overflow event. | | | 1 If the receiver buffer overflows, a NACK is automatically sent on a received character. | | 3<br>ANACK | Generate NACK on Error | | | When this field is set, the receiver automatically generates a NACK response if a parity error occurs or if INIT is set and an invalid initial character is detected. A NACK is generated only if TTYPE = 0. If ANACK is set, the UART attempts to retransmit the data indefinitely. To stop retransmission attempts, clear C2[TE] or ISO_7816E and do not set until S1[TC] sets C2[TE] again. | | | 0 No NACK is automatically generated. | | | A NACK is automatically generated if a parity error is detected or if an invalid initial character is detected. | | | Detect Initial Character | | | When this field is set, all received characters are searched for a valid initial character. If an invalid initial character is identified, and ANACK is set, a NACK is sent. 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 detecting 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, IS7816[INITD] is set and an interrupt issued as programmed by IE7816[INITDE]. When a valid initial character is detected, INIT is automatically cleared. This Initial Character Detect feature is supported only in T = 0 protocol mode. | | | <ul> <li>Normal operating mode. Receiver does not seek to identify initial character.</li> <li>Receiver searches for initial character.</li> </ul> | | | Transfer Type | | TTYPE | Indicates the transfer protocol being used. | | | See 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 7816F | ISO-7816 Functionality Enabled | | | Indicates that the UART is operating according to the ISO-7816 protocol. | | | NOTE: This field must be modified only when no transmit or receive is occurring. If this field is changed during a data transfer, the data being transmitted or received may be transferred incorrectly. | | | ISO-7816 functionality is turned off/not enabled. ISO-7816 functionality is turned on/enabled. | | 1<br>TTYPE<br>0<br>ISO_7816E | <ul> <li>1 Receiver searches for initial character.</li> <li>Transfer Type</li> <li>Indicates the transfer protocol being used.</li> <li>See ISO-7816 / smartcard support for more details.</li> <li>0 T = 0 per the ISO-7816 specification.</li> <li>1 T = 1 per the ISO-7816 specification.</li> <li>ISO-7816 Functionality Enabled</li> <li>Indicates that the UART is operating according to the ISO-7816 protocol.</li> <li>NOTE: This field must be modified only when no transmit or receive is occurring. If this field is changed during a data transfer, the data being transmitted or received may be transferred incorrectly.</li> <li>0 ISO-7816 functionality is turned off/not enabled.</li> </ul> | 783 ## 38.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 are not asserted when 7816E is not set/enabled. However, these flags may remain set if they are asserted while 7816E was set and not subsequently cleared. This register may be read or written to at any time. | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|-----|------|------|--------|---|------|------|------| | Read<br>Write | WTE | CWTE | BWTE | INITDE | 0 | GTVE | TXTE | RXTE | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ### **UARTx\_IE7816** field descriptions | Field | Description | |-------------|-------------------------------------------------------------------------------------| | 7 | Wait Timer Interrupt Enable | | WTE | 0 The assertion of IS7816[WT] does not result in the generation of an interrupt. | | | 1 The assertion of IS7816[WT] results in the generation of an interrupt. | | 6<br>CWTE | Character Wait Timer Interrupt Enable | | · · · · · · | 0 The assertion of IS7816[CWT] does not result in the generation of an interrupt. | | | 1 The assertion of IS7816[CWT] results in the generation of an interrupt. | | 5<br>BWTE | Block Wait Timer Interrupt Enable | | | 0 The assertion of IS7816[BWT] does not result in the generation of an interrupt. | | | 1 The assertion of IS7816[BWT] results in the generation of an interrupt. | | 4<br>INITDE | Initial Character Detected Interrupt Enable | | | 0 The assertion of IS7816[INITD] does not result in the generation of an interrupt. | | | 1 The assertion of IS7816[INITD] results in the generation of an interrupt. | | 3 | This field is reserved. | | Reserved | This read-only field is reserved and always has the value 0. | | 2<br>GTVE | Guard Timer Violated Interrupt Enable | | GIVE | The assertion of IS7816[GTV] does not result in the generation of an interrupt. | | | 1 The assertion of IS7816[GTV] results in the generation of an interrupt. | | 1<br>TXTE | Transmit Threshold Exceeded Interrupt Enable | | ., | 0 The assertion of IS7816[TXT] does not result in the generation of an interrupt. | | | 1 The assertion of IS7816[TXT] results in the generation of an interrupt. | | 0<br>RXTE | Receive Threshold Exceeded Interrupt Enable | | | 0 The assertion of IS7816[RXT] does not result in the generation of an interrupt. | | | 1 The assertion of IS7816[RXT] results in the generation of an interrupt. | ## 38.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 field location. Writing a 0 has no effect. All bits are "sticky", meaning they indicate that only the flag condition that occurred since the last time the bit was cleared, not that the condition currently exists. The status flags are set regardless of whether the corresponding field in the IE7816 is set or cleared. The IE7816 controls only if an 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. | A 1 1 | _ | | _ | 4 4 1 | | |----------|------|---------|-----|-------|--------| | Address: | Base | address | + - | ı An | offset | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|-----|-----|-----|-------|---|-----|-----|-----| | Read | WT | CWT | BWT | INITD | 0 | GTV | TXT | RXT | | Write | w1c | w1c | w1c | w1c | | w1c | w1c | w1c | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ### **UARTx\_IS7816** field descriptions | Field | Description | |------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7<br>WT | Wait Timer Interrupt | | | 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 programmed value. This flag asserts only 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<br>CWT | Character Wait Timer Interrupt | | | Indicates that the character wait time, the time between the leading edges of two consecutive characters in a block, has exceeded the programmed value. This flag asserts only 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. | | 5<br>BWT | Block Wait Timer Interrupt | | | 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, has exceeded the programmed value. This flag asserts only when C7816[TTYPE] = 1.This interrupt is cleared by writing 1. | | | 0 Block wait time (BWT) has not been violated. | | | 1 Block wait time (BWT) has been violated. | | 4<br>INITD | Initial Character Detected Interrupt | | | Indicates that a valid initial character is received. This interrupt is cleared by writing 1. | Table continues on the next page... ### **UARTx\_IS7816** field descriptions (continued) | Field | Description | | | | | | |----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | | A valid initial character has not been received. | | | | | | | | 1 A valid initial character has been received. | | | | | | | 3 | This field is reserved. | | | | | | | Reserved | This read-only field is reserved and always has the value 0. | | | | | | | 2<br>GTV | Guard Timer Violated Interrupt | | | | | | | | Indicates that one or more of the character guard time, block guard time, or guard time are violated. This interrupt is cleared by writing 1. | | | | | | | | 0 A guard time (GT, CGT, or BGT) has not been violated. | | | | | | | | 1 A guard time (GT, CGT, or BGT) has been violated. | | | | | | | 1<br>TXT | Transmit Threshold Exceeded Interrupt | | | | | | | | Indicates that the transmit NACK threshold has been exceeded as indicated by ET7816[TXTHRESHOLD]. Regardless of whether this flag is set, the UART continues to retransmit indefinitely. This flag asserts only 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 ET7816[TXTHRESHOLD]. | | | | | | | | 1 The number of retries and corresponding NACKS exceeds the value in ET7816[TXTHRESHOLD] | | | | | | | 0<br>RXT | Receive Threshold Exceeded Interrupt | | | | | | | | Indicates that there are 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 asserts only when C7816[TTYPE] = 0. Clearing this field also resets the counter keeping track of consecutive NACKS. The UART will continue to attempt to receive data regardless of whether 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. | | | | | | | | O 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]. | | | | | | # 38.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 any time. This register must be written to only when C7816[ISO\_7816E] is not set. Address: Base address + 1Bh offset #### **UARTx\_WP7816T0** field descriptions | Field | Description | |-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7–0<br>WI | Wait Time Integer (C7816[TTYPE] = 0) | | | 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 used only when C7816[TTYPE] = 0. See Wait time and guard time parameters. | ## 38.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 may be read at any time. This register must be written to only when C7816[ISO\_7816E] is not set. | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|-----|---|---|---|----|----|---|---| | Read<br>Write | CWI | | | | BV | VI | | | | Reset | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 0 | #### **UARTx\_WP7816T1** field descriptions | Field | Description | |------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7–4<br>CWI | Character Wait Time Integer (C7816[TTYPE] = 1) | | | Used to calculate the value used for the CWT counter. It represents a value between 0 and 15. This value is used only when C7816[TTYPE] = 1. See Wait time and guard time parameters. | | 3–0<br>BWI | Block Wait Time Integer(C7816[TTYPE] = 1) | | | Used to calculate the value used for the BWT counter. It represent a value between 0 and 15. This value is used only when C7816[TTYPE] = 1. See Wait time and guard time parameters . | ## 38.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 any time. This register must be written to only when C7816[ISO\_7816E] is not set. Address: Base address + 1Ch offset #### **UARTx\_WN7816** field descriptions | Field | Description | |-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | GTN | Guard Band N Defines a parameter used in the calculation of GT, CGT, and BGT counters. The value represents an integer number between 0 and 255. See Wait time and guard time parameters. | ## 38.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 at any time. This register must be written to only when C7816[ISO\_7816E] is not set. Address: Base address + 1Dh offset | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|------|---|---|---|---|---|---|---| | Read<br>Write | GTFD | | | | | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | #### **UARTx** WF7816 field descriptions | Field | Description | |-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | GTFD | FD Multiplier Used as another multiplier in the calculation of WT and BWT. This value 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. | # 38.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 be written to only when C7816[ISO\_7816E] is not set. Address: Base address + 1Eh offset #### **UARTx\_ET7816** field descriptions | Field | Description | |-------------|-------------------------------------------------------------------------------------------------------| | 7–4 | Transmit NACK Threshold | | TXTHRESHOLD | | | | 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. This field is meaningful only when | Table continues on the next page... ### **UARTx\_ET7816** field descriptions (continued) | Field | Description | | | | | | |--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | | 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 continues to retransmit indefinitely. This flag only asserts when C7816[TTYPE] = 0. For additional information see the IS7816[TXT] field description. | | | | | | | | 0 TXT asserts on the first NACK that is received. | | | | | | | | 1 TXT asserts on the second NACK that is received. | | | | | | | 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. After the counter exceeds that value in the field, the IS7816[RXT] is asserted. This field is meaningful only 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 continues to receive valid packets indefinitely. For additional information, see IS7816[RXT] field description. | | | | | | # 38.3.30 UART 7816 Transmit Length Register (UARTx\_TL7816) The TL7816 register is used to indicate the number of characters contained in the block being transmitted. This register is used only when C7816[TTYPE] = 1. This register may be read at anytime. This register must be written only when C2[TE] is not enabled. ## UARTx\_TL7816 field descriptions | Field | Description | |-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7–0 | Transmit Length | | TLEN | | | | This value plus four 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. Therefore, this register must be programmed with the number of bytes in the data packet if an 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, that is, the first three characters transmitted in a block, or the LRC or last CRC character in the Epilogue field, that is, the last character transmitted. This field must be programed or adjusted only when C2[TE] is cleared. | # 38.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. ### 38.4.1 Transmitter Figure 38-151. Transmitter Block Diagram ## 38.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). #### 38.4.1.2 Transmission bit order When S2[MSBF] is set, the UART automatically transmits the MSB of the data word as the first bit after the start bit. Similarly, 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. Therefore, the format of the data written to D for transmission is completely independent of the S2[MSBF] setting. ### 38.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] and D. Data in the transmit buffer is then 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 an 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 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 C2[TE] automatically loads the transmit shift register with the following preamble: - 11 logic 1s if C1[M] = 1 and C4[M10] = 0 - 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 D 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 C2[TE] 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 in BGT is used, because C2[TE] will remain asserted until the end of the block transfer. C2[TE] is automatically cleared when C7816[TTYPE] = 1 and the block being transmitted has completed. When C7816[TTYPE] = 0, the transmitter listens for a NACK indication. If no NACK is received, it is assumed that the character was correctly received. If a NACK is received, the transmitter resends the data, assuming that the number of retries for that character, that is, the number of NACKs received, is less than or equal to the value in ET7816[TXTHRESHOLD]. 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 C2[TE], the transmitter enable signal goes low and the transmit signal goes idle. If the software clears C2[TE] while a transmission is in progress, the character in the transmit shift register continues to shift out, provided S1[TC] was cleared during the data write sequence. To clear S1[TC], the S1 register must be read followed by a write to D register. If S1[TC] is cleared during character transmission and C2[TE] is cleared, the transmission enable signal is deasserted at the completion of the current frame. Following this, the transmit data out signal enters the idle state even if there is data pending in the 791 #### **runctional** description 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 S1[TC] to set. Alternatively, the same can be achieved by setting TWFIFO[TXWATER] to 0x0 and waiting for S1[TDRE] to set. ## 38.4.1.4 Transmitting break characters Setting 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 C1[M], C1[PE], S2[BRK13] and C4[M10]. See the following table. | S2[BRK13] | C1[M] | C4[M10] | C1[PE] | Bits transmitted | |-----------|-------|---------|--------|------------------| | 0 | 0 | _ | _ | 10 | | 0 | 1 | 1 | 0 | 11 | | 0 | 1 | 1 | 1 | 12 | | 1 | 0 | _ | _ | 13 | | 1 | 1 | _ | _ | 14 | Table 38-158. Transmit break character length As long as C2[SBK] is set, the transmitter logic continuously loads break characters into the transmit shift register. After the software clears C2[SBK], 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 preempts that queued data. The queued data is then transmitted after the break character is complete. ### 38.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 C1[M], C1[PE] and C4[M10]. The preamble is a synchronizing idle character that begins the first transmission initiated after setting C2[TE]. 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 C2[TE] is cleared during a transmission, the transmit data output signal becomes idle after completion of the transmission in progress. Clearing and then setting C2[TE] 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 preempts that queued data. The queued data is then transmitted after the idle character is complete. If C2[TE] is cleared and the transmission is completed, the UART is not the master of the TXD pin. ### 38.4.1.6 Hardware flow control The transmitter supports hardware flow control by gating the transmission with the value of CTS. If the clear-to-send operation is enabled, the character is transmitted when CTS is asserted. If 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 CTS is reasserted. If the clear-to-send operation is disabled, the transmitter ignores the state of 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 CTS regardless of whether the clear-to-send operation is enabled. The transmitter's CTS signal can also be enabled even if the same UART receiver's RTS signal is disabled. ### 38.4.1.7 Transceiver driver enable The transmitter can use RTS as an enable signal for the driver of an external transceiver. See Transceiver driver enable using RTS for details. If the request-to-send operation is enabled, when a character is placed into an empty transmitter data buffer, RTS asserts one bit time before the start bit is transmitted. RTS remains asserted for the whole time that the transmitter data buffer has any characters. 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 RTS, with the same assertion and deassertion timing as having a character in the transmitter data buffer. The transmitter's RTS signal asserts only when the transmitter is enabled. However, the transmitter's RTS signal is unaffected by its CTS signal. 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 38-152. Transmitter RTS and CTS timing diagram ### 38.4.2 Receiver Figure 38-153. UART receiver block diagram # 38.4.2.1 Receiver character length The UART receiver can accommodate 8-, 9-, or 10-bit data characters. The states of C1[M], C1[PE] and C4[M10] determine the length of data characters. When receiving 9 or 10-bit data, C3[R8] is the ninth bit (bit 8). ## 38.4.2.2 Receiver bit ordering When S2[MSBF] is set, the receiver operates such that the first bit received after the start bit is the MSB of the dataword. Similarly, the bit received immediately preceding the parity bit, or the stop bit if parity is not enabled, is treated as the LSB for the dataword. All necessary bit ordering is handled automatically by the module. Therefore, the format of the data read from receive data buffer is completely independent of S2[MSBF]. ## 38.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. S1[RDRF] 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, RDRF generates an RDRF interrupt request. Alternatively, by programming C5[RDMAS], a DMA request can be generated. When C7816[ISO\_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 IS7816[RXT] is set and an interrupt generated if IE7816[RXTE] is set. If an error is detected due to parity or an 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, C7816[ONACK] is set/enabled, and the received character results in the receive buffer overflowing, a NACK is issued by the receiver. Additionally, S1[OR] is set and an interrupt is issued if required, and the data in the shift register is discarded. ## 38.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: - 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 38-154. 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 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 38-159. 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 38-160. 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 38-161. 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 | 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 38-155. 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 38-156. 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 38-157. 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 38-158. 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 38-159. 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 38-160. Start bit search example 6 ## 38.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]. A break character also sets the S1[FE] because a break character has no stop bit. 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 S1[FE] is set, data will not be received when C7816[ISO7816E] is set. KM Family Reference Manual, Rev. 5, Oct 2013 801 # 38.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 UART break character detection threshold depends on C1[M], C1[PE] and C4[M10]. See the following table. M M10 PE Threshold (bits) 0 — — 10 1 0 — 11 1 1 1 12 Table 38-162. Receive break character detection threshold Break characters are not detected or supported when C7816[ISO\_7816E] is set/enabled. ### 38.4.2.7 Hardware flow control To support hardware flow control, the receiver can be programmed to automatically deassert and assert RTS. - RTS remains asserted until the transfer is complete, even if the transmitter is disabled midway 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 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 RTS when the number of characters in the receiver data register is less than the watermark. It is not affected if 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 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 can also indicated, with a dashed line, if necessary. The watermark is set to 2. Figure 38-161. Receiver hardware flow control timing diagram ### 38.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 0. As the receiver samples an incoming frame, it resynchronizes the RT clock on any valid falling edge within the frame. Resynchronization within frames corrects a misalignment between transmitter bit times and receiver bit times. ### 38.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 38-162. 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 Figure 38-162, 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 $\times$ 16 RT cycles + 10 RT cycles). With the misaligned character shown in the Figure 38-162, 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\%$$ ### 38.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 38-163. 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 Figure 38-163, 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 Figure 38-163, 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\%$$ ## 38.4.2.9 Receiver wakeup C1[WAKE] determines how the UART is brought out of the standby state to process an incoming message. C1[WAKE] enables either idle line wakeup or address mark wakeup. Receiver wakeup is not supported when C7816[ISO\_7816E] is set/enabled because multi-receiver systems are not allowed. ## 38.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 C2[RWU] 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] and return to the standby state. C2[RWU] 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. 805 When C2[RWU] is 1 and S2[RWUID] is 0, the idle character that wakes the receiver does not set S1[IDLE] or the receive data register full flag, S1[RDRF]. The receiver wakes and waits for the first data character of the next message which is stored in the receive data buffer. When S2[RWUID] and C2[RWU] are set and C1[WAKE] is cleared, any idle condition sets S1[IDLE] and generates an interrupt if enabled. Idle input line wakeup is not supported when C7816[ISO\_7816E] is set/enabled. ## **38.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 C2[RWU] 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] and return to the standby state. C2[RWU] 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] after the stop bit is received and places the received data into the receiver data buffer. Note that if Match Address operation is enabled i.e. C4[MAEN1] or C4[MAEN2] is set, then received frame is transferred to receive buffer only if the comparison matches. 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. ## 38.4.2.9.3 Match address operation Match address operation is enabled when C4[MAEN1] or C4[MAEN2] is set. In this function, a frame received by the RX pin with a logic 1 in the bit position of the address mark is considered an address and is compared with the associated MA1 or MA2 register. The frame is transferred to the receive buffer, and S1[RDRF] is set, only if the comparison matches. All subsequent frames received with a logic 0 in the bit position of the address mark 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 0 in the bit position of the address mark are also discarded. If both C4[MAEN1] and C4[MAEN2] 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. Note that the position of the address mark is the same as the Parity Bit when parity is enabled for 8 bit and 9 bit data formats. - 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. # 38.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 SBR[12:0] 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 transmitter is driven by the baud rate clock divided by 16. 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 with the fine-adjust counter. - Synchronization with the module clock can cause phase shift. The Table 38-163 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 38-163. 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 | Table continues on the next page... Table 38-163. Baud rates (example: module clock = 10.2 MHz) (continued) | Bits<br>SBR<br>(decimal) | Bits<br>BRFA | BRFD value | Receiver<br>clock (Hz) | Transmitter<br>clock (Hz) | Target Baud<br>rate | Error<br>(%) | |--------------------------|--------------|---------------|------------------------|---------------------------|---------------------|--------------| | 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 38-164. 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 | | | | 00101 | 5/32 = 0.15625 | | | | 00110 | 6/32 = 0.1875 | | | | 00111 | 7/32 = 0.21875 | | | | 01000 | 8/32 = 0.25 | | | | 01001 | 9/32 = 0.28125 | | | | 01010 | 10/32 = 0.3125 | | | | 01011 | 11/32 = 0.34375 | | | | 01100 | 12/32 = 0.375 | | | | 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 | | | | 10011 | 19/32 = 0.59375 | | | | 10100 | 20/32 = 0.625 | | | | 10101 | 21/32 = 0.65625 | | | Table continues on the next page... Chapter 38 Universal Asynchronous Receiver/Transmitter (UART) Table 38-164. Baud rate fine adjust (continued) | BRFA | Baud Rate Fractional Divisor (BRFD) | | | |-----------|-------------------------------------|--|--| | 10110 | 22/32 = 0.6875 | | | | 10111 | 23/32 = 0.71875 | | | | 11000 | 24/32 = 0.75 | | | | 1 1 0 0 1 | 25/32 = 0.78125 | | | | 11010 | 26/32 = 0.8125 | | | | 11011 | 27/32 = 0.84375 | | | | 11100 | 28/32 = 0.875 | | | | 11101 | 29/32 = 0.90625 | | | | 11110 | 30/32 = 0.9375 | | | | 11111 | 31/32 = 0.96875 | | | # 38.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 C1[M], C1[PE], S2[MSBF] and C4[M10]. ## 38.4.4.1 Eight-bit configuration Clearing C1[M] configures the UART for 8-bit data characters, that is, eight bits are memory mapped in 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 the most significant bit is used in this way, then it serves as an address or data indication, leaving the remaining seven bits as actual data. When C1[PE] is set, the eighth data bit is automatically calculated as the parity bit. See the following table. Table 38-165. Configuration of 8-bit data format | LIADT CAIDEL | 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 | 1. The address bit identifies the frame as an address character. See Receiver wakeup. # 38.4.4.2 Nine-bit configuration When C1[M] is set and C4[M10] is cleared, the UART is configured for 9-bit data characters. If C1[PE] is enabled, the ninth bit is either C3[T8/R8] or the internally generated parity bit. This results in a frame consisting of a total of 11 bits. In the event that the ninth data bit is selected to be 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 ninth data bit is being used as an address mark. When C1[M] and C4[M10] are 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 tenth internal data bit. Note that if C4[M10] is set, C1[PE] must also be set. In this case, the tenth bit is the internally generated parity bit. The ninth bit can either be used as an address mark or a ninth data bit. See the following table. | C1[DE] | C1[PE] UC1[M] | UC1[M] C1[M10] | Start | Data | Address | Parity | Stop | |-----------------|---------------|----------------|-----------------------------|-------|-------------------|--------|------| | CI[FE] UCI[M] | CILIMITO | bit | bits | bits | bits | bit | | | 0 | 0 | 0 | | See I | 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 | Invalid Configuration | | | | | | 1 | 0 | 0 | See Eight-bit configuration | | | | | | 1 | 0 | 1 | | Inv | valid Configurati | on | | | 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 | Table 38-166. Configuration of 9-bit data formats #### **Note** Unless in 9-bit mode with M10 set, do not use address mark wakeup with parity enabled. <sup>1.</sup> The address bit identifies the frame as an address character. <sup>2.</sup> The address bit identifies the frame as an address character. ## 38.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. ### 38.4.4.3.1 Eight-bit format with parity disabled The most significant bit can be used for address mark wakeup. Figure 38-164. Eight bits of data with LSB first Figure 38-165. Eight bits of data with MSB first ### 38.4.4.3.2 Eight-bit format with parity enabled Figure 38-166. Seven bits of data with LSB first and parity Figure 38-167. Seven bits of data with MSB first and parity # 38.4.4.3.3 Nine-bit format with parity disabled The most significant bit can be used for address mark wakeup. Figure 38-168. Nine bits of data with LSB first Figure 38-169. Nine bits of data with MSB first KM Family Reference Manual, Rev. 5, Oct 2013 811 ### 38.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 38-170. Eight bits of data with LSB first and parity Figure 38-171. Eight bits of data with MSB first and parity ### 38.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 38-172. Nine bits of data with LSB first and parity ``` ADDRESS MARK START BIT 8 BIT 7 BIT 6 BIT 5 BIT 4 BIT 3 BIT 2 BIT 1 BIT 0 PARITY STOP START BIT BIT 6 BIT 6 BIT 5 BIT 6 BIT 5 BIT 6 ``` Figure 38-173. Nine bits of data with MSB first and parity # 38.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 38-174. Single-wire operation (C1[LOOPS] = 1, C1[RSRC] = 1) Enable single wire operation by setting C1[LOOPS] and the receiver source field, C1[RSRC]. Setting C1[LOOPS] disables the path from the unsynchronized receiver input signal to the receiver. Setting C1[RSRC] 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 required that both C2[TE] and C2[RE] are set. ## 38.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 38-175. Loop operation (C1[LOOPS] = 1, C1[RSRC] = 0) Enable loop operation by setting C1[LOOPS] and clearing C1[RSRC]. Setting C1[LOOPS] disables the path from the unsynchronized receiver input signal to the receiver. Clearing C1[RSRC] 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 required that both C2[TE] and C2[RE] are set. # 38.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 because 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 programmed 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. To maintain maximum flexibility to support future 7816 enhancements or devices that 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. ### 38.4.7.1 Initial characters In ISO-7816 with T = 0 mode, the UART can be configured to use C7816[INIT] 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 alter S2[MSBF], C3[TXINV], and S2[RXINV] 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 38-167. Initial character automated settings S2[MSBF], C3[TXINV], and S2[RXINV] must be reset to their default values before C7816[INIT] is set. Once C7816[INIT] is set, the receiver searches all received data for the first valid initial character. Detecting a Direct Convention Initial Character will cause no change to S2[MSBF], C3[TXINV], and S2[RXINV], while detecting an Inverse Convention Initial Character will cause these fields to set automatically. All data received, which is not a valid initial character, is ignored and all flags resulting from the invalid data are blocked from asserting. If C7816[ANACK] is set, a NACK is returned for invalid received initial characters and an RXT interrupt is generated as programmed. ### 38.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 Peripheral Pin Select (PPS) formats. Figure 38-176. 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 two 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 C2[TE] and C2[RE]. Initial Character Detect feature is also supported in this mode. ### 38.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, that is, for each group of characters. 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 38-177. 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 C2[TE], C3[TXDIR] and enter receive mode. Therefore, the software must program the transmit buffer with the next data to be transmitted and then enable C2[TE] and set C3[TXDIR], once the 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. ## 38.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 formulae used to calculate the number ETUs for each wait time and guard time value are shown in Table 38-168. Wait time (WT) is defined as the maximum allowable time between the leading edge of a character transmitted by the smartcard device and the leading edge of the previous character that was transmitted by the UART or the device. Similarly, character wait time (CWT) is defined as the maximum allowable time between the leading edge of two characters within the same block. Block wait time (BWT) is defined as the maximum time between the leading edge character of the last block received by the smartcard device and the leading edge of the first character transmitted by the smartcard device. 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, that is, transmission or reception. Block guard time (BGT) is the minimum allowable time between the leading edges of two consecutive characters in opposite directions, that is, 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 is 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 is 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 before the corresponding guard time expiring. | Downwater | Reset value | C7816[TTYPE] = 0 | C7816[TTYPE] = 1 | |----------------------------|-------------|-----------------------------------|------------------------------------------| | Parameter | [ETU] | [ETU] | [ETU] | | Wait time (WT) | 9600 | ((WI + 1) × 960 × (GTFD + 1)) - 1 | Not used | | Character wait time (CWT) | Not used | Not used | 11 + 2 <sup>(CWI - 1)</sup> | | Block wait time (BWT) | Not used | Not used | 10 + 2 <sup>BWI</sup> × 960 × (GTFD + 1) | | Guard time (GT) | 12 | GTN not equal to 255 | Not used | | | | 12 + GTN | | | | | GTN equal 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 38-168. Wait and guard time calculations # 38.4.7.5 Baud rate generation The value in WF7816[GTFD] does not impact the clock frequency. 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 smartcard device. 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. 817 # 38.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 field definitions. ### 38.5 Reset All registers reset to a particular value are indicated in Memory map and registers. # 38.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 Memory map and registers. 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 38-169. 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 | RXEDGIF | RXEDGIE | - | | Receiver | OR | ORIE | - | | Receiver | NF | NEIE | - | | Receiver | FE | FEIE | - | | Receiver | PF | PEIE | - | | Receiver | RXUF | RXUFE | - | | Transmitter | TXOF | TXOFE | - | | Receiver | WT | WTWE | - | | Receiver | CWT | CWTE | - | | Receiver | BWT | BWTE | - | | Receiver | INITD | INITDE | - | | Receiver | TXT | TXTE | - | | Receiver | RXT | RXTE | - | | Receiver | GTV | GTVE | - | # 38.6.1 RXEDGIF description S2[RXEDGIF] is set when an active edge is detected on the RxD pin. Therefore, the active edge can be detected only when in two wire mode. A RXEDGIF interrupt is generated only when S2[RXEDGIF] is set. If RXEDGIE is not enabled before S2[RXEDGIF] is set, an interrupt is not generated until S2[RXEDGIF] is set. ## 38.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 S2[RXINV]. To detect the falling edge, S2[RXINV] is programmed to 0. To detect the rising edge, S2[RXINV] is programmed to 1. Synchronizing logic is used prior to detect edges. Prior to detecting an edge, the receive data on RxD input must be at the deasserted 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. # 38.6.1.2 Clearing RXEDGIF interrupt request Writing a logic 1 to S2[RXEDGIF] immediately clears the RXEDGIF interrupt request even if the RxD input remains asserted. S2[RXEDGIF] remains set if another active edge is detected on RxD while attempting to clear S2[RXEDGIF] by writing a 1 to it. ## 38.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). # 38.7 DMA operation In the transmitter, S1[TDRE] can be configured to assert a DMA transfer request. In the receiver, S1[RDRF], can be configured to assert a DMA transfer request. The following table shows the configuration field 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 38-170. DMA configuration When a flag is configured for a DMA request, its associated DMA request is asserted when the flag is set. When S1[RDRF] is configured as a DMA request, the clearing mechanism of reading S1, followed by reading D, 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 is cleared. If the DMA operation failed to remove the situation that caused the DMA request, another request is issued. # 38.8 Application information This section describes the UART application information. # 38.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 PFIFO[TXFIFOSIZE] and PFIFO[RXFIFOSIZE]. Additionally, legacy support is provided that allows for the FIFO structure to 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, which is a set of characters, has completed transmission. These methods include: - 1. Set TXFIFO[TXWATER] to 0. TDRE asserts 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 TCFIFO[TXCOUNT]. 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. S1[TC] 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. # 38.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 set up 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 provided to the smartcard device must be 1/372th of the clock and must not exceed 5 MHz. - 2. Write to C1 to configure word length, parity, and other configuration fields (LOOPS, RSRC) and set C1[M] = 1, C1[PE] = 1, and C1[PT] = 0. - 3. Write to set S2[RWUID] = 0 - 4. Write to set MODEM[RXRTSE] = 0, MODEM[TXRTSPOL] = 0, MODEM[TXRTSE] = 0, and MODEM[TXCTSE] = 0. - 5. Write to set up interrupt enable fields desired (C3[ORIE], C3[NEIE], C3[PEIE], and C3[FEIE]) - 6. Write to set C4[MAEN1] = 0 and C4[MAEN2] = 0. - 7. Write to C5 register and configure DMA control register fields as desired for application. - 8. Write to set C7816[INIT] = 1,C7816[ TTYPE] = 0, and C7816[ISO\_7816E] = 1. Program C7816[ONACK] and C7816[ANACK] as desired. ### **Application information** - 9. Write to IE7816 to set interrupt enable parameters as desired. - 10. Write to ET7816 and set as desired. - 11. Write to set C2[ILIE] = 0, C2[RE] = 1, C2[TE] = 1, C2[RWU] = 0, and C2[SBK] = 0. Set up interrupt enables C2[TIE], C2[TCIE], and C2[RIE] as desired. At this time, the UART will start listening for an initial character. After being identified, it will automatically adjust S2[MSBF], C3[TXINV], and S2[RXINV]. The software must then receive and process an answer to reset. Upon processing the answer to reset, the software must write to set C2[RE] = 0 and C2[TE] = 0. The software should then adjust 7816 specific and UART generic parameters to match and configure data that was received during the answer on reset period. After the new settings have been programmed, including the new baud rate and C7816[TTYPE], C2[RE] and C2[TE] can be reenabled as required. # 38.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. Therefore, no mechanism is provided for automated transmission/receipt control. The software must monitor S1[TDRE], 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 be transmitted until the next receiver/transmit switchover is loaded into the transmit FIFO/buffer. # 38.8.2.2 Transmission procedure for (C7816[TTYPE] = 1) When the protocol selected is C7816[TTYPE] = 1, data is transferred in blocks. Before starting a transmission, the software must write the size, in number of bytes, for the Information Field portion of the block into TLEN. If a CRC is being transmitted for the block, the value in TLEN must be one more than the size of the information field. The software must then set C2[TE] = 1 and C2[RE] = 1. The software must then monitor S1[TDRE]/interrupt and write the prologue, information, and epilogue field to the transmit buffer. TLEN automatically decrements, except for prologue bytes and the final epilogue byte. When the final epilogue byte has been transmitted, the UART automatically clears C2[TE] and C3[TXDIR] to 0, and the UART automatically starts capturing the response to the block that was transmitted. After the software has detected the receipt of the response, the transmission process must be repeated as needed with sufficient urgency to ensure that the block wait time and character wait times are not violated. # 38.8.3 Initialization sequence (non ISO-7816) To initiate a 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 has no effect without also writing to BDL. - b. Write to C1 to configure word length, parity, and other configuration bits (LOOPS, RSRC, M, WAKE, ILT, PE, and PT). Write to C4, MA1, and MA2 to configure. - c. Enable the transmitter, interrupts, receiver, and wakeup as required, by writing to C2 (TIE, TCIE, RIE, ILIE, TE, RE, RWU, and SBK), S2 (MSBF and BRK13), and C3 (ORIE, NEIE, PEIE, and FEIE). A preamble or idle character is then shifted out of the transmitter shift register. - 2. Transmit procedure for each byte. - a. Monitor S1[TDRE] by reading S1 or responding to the TDRE interrupt. The amount of free space in the transmit buffer directly using TCFIFO[TXCOUNT] can also be monitored. - 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, S1[TDRE] 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]. This occurs 9/16ths of a bit time after the start of the stop bit of the previous frame. 823 ### **Application information** 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 S1[TDRE] 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 C2[TE]. - 4. Write the first and subsequent datawords of the second message to C3[T8]/D. # 38.8.4 Overrun (OR) flag implications To be flexible, the overrun flag (OR) operates slight differently depending on the mode of operation. There may be implications that need to be carefully considered. This section clarifies the behavior and the resulting implications. Regardless of mode, if a dataword is received while S1[OR] is set, S1[RDRF] and S1[IDLE] are blocked from asserting. If S1[RDRF] or S1[IDLE] were previously asserted, they will remain asserted until cleared. ## 38.8.4.1 Overrun operation The assertion of S1[OR] indicates that a significant event has occurred. The assertion indicates that received data has been lost because there was a lack of room to store it in the data buffer. Therefore, while S1[OR] is set, no further data is stored in the data buffer until S1[OR] is cleared. This ensures that the application will be able to handle the overrun condition. In most applications, because the total amount of lost data is known, the application will attempt to return the system to a known state. Before S1[OR] is cleared, all received data will be dropped. For this, the software does the following. - 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 the overrun event occurred, or using CFIFO[RXFLUSH] to clear the buffer. - 2. Clear S1[OR]. Note that if data was cleared using CFIFO[RXFLUSH], then clearing S1[OR] will result in SFIFO[RXUF] asserting. This is because the only way to clear 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 SFIFO[RXUF] 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 whether the lost data will be resent by the device. In this scenario, flushing the receiver data buffer may not be required. Rather, if S1[OR] is cleared, the lost data may be resent and therefore may be recoverable. ### 38.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 smartcard device has implemented retransmission, the lost data will be retransmitted. While useful, there is a programming implication that 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 after 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, S1[OR] will be blocked and kept from asserting. # 38.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. ## 38.8.7 Modem feature This section describes the modem features. **Application information** # 38.8.7.1 Ready-to-receive using RTS To help to stop overrun of the receiver data buffer, the 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 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 RTS and CTS signals. Figure 38-178. Ready-to-receive The transmitter's CTS signal can be used for hardware flow control whether its RTS signal is used for hardware flow control, transceiver driver enable, or not at all. ## 38.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 the UART is driving. The RTS signal can be used by the transmitter to enable the driver of a transceiver. The polarity of RTS can be matched to the polarity of the transceiver's driver enable signal. See the following figure. Figure 38-179. Transceiver driver enable using RTS In the figure, the receiver enable signal is asserted. Another option for this 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. # 38.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. In most cases, if the condition that caused the interrupt to trigger still exists when the interrupt is cleared, then 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 be 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. # 38.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 code from previous versions is used, it must 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 are used, such as, 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. S1[OR] will be set only 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 S1[RDRF] was set even if there was room in the data buffer. While the clearing mechanism has remained the same for S1[RDRF], 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. #### **Application information** 5. Previously, when 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 C2[RWU]. This behavior has been modified. Now, when C2[RWU] is set (and WAKE = 0), at least one non-idle bit must be detected before an idle can be detected. # **Chapter 39 Cyclic Redundancy Check (CRC)** ## 39.1 Introduction #### **NOTE** For the chip-specific implementation details of this module's instances, see the chip configuration information. The cyclic redundancy check (CRC) module generates 16/32-bit CRC code for error detection. The CRC module provides a programmable polynomial, WAS, 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. ## **39.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 # 39.1.2 Block diagram The following is a block diagram of the CRC. KM Family Reference Manual, Rev. 5, Oct 2013 829 #### wemory map and register descriptions Figure 39-1. Programmable cyclic redundancy check (CRC) block diagram # 39.1.3 Modes of operation Various MCU modes affect the CRC module's functionality. ## 39.1.3.1 Run mode This is the basic mode of operation. # 39.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 dependent on the MCU. # 39.2 Memory map and register descriptions ## CRC memory map | Absolute<br>address<br>(hex) | Register name | Width<br>(in bits) | Access | Reset value | Section/<br>page | |------------------------------|-------------------------------------|--------------------|--------|-------------|------------------| | 4003_4000 | CRC Data register (CRC_DATA) | 32 | R/W | FFFF_FFFFh | 39.2.1/831 | | 4003_4004 | CRC Polynomial register (CRC_GPOLY) | 32 | R/W | 0000_1021h | 39.2.2/832 | | 4003_4008 | CRC Control register (CRC_CTRL) | 32 | R/W | 0000_0000h | 39.2.3/832 | # 39.2.1 CRC Data register (CRC\_DATA) The CRC Data register contains the value of the seed, data, and checksum. When CTRL[WAS] is set, any write to the data register is regarded as the seed value. When CTRL[WAS] 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; with MSB of data value written first. 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: 4003\_4000h base + 0h offset = 4003\_4000h #### **CRC\_DATA** field descriptions | Field | Description | |-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31–24<br>HU | CRC High Upper Byte | | | In 16-bit CRC mode (CTRL[TCRC] is 0), this field is not used for programming a seed value. In 32-bit CRC mode (CTRL[TCRC] is 1), values written to this field are part of the seed value when CTRL[WAS] is 1. When CTRL[WAS] 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 | | 112 | In 16-bit CRC mode (CTRL[TCRC] is 0), this field is not used for programming a seed value. In 32-bit CRC mode (CTRL[TCRC] is 1), values written to this field are part of the seed value when CTRL[WAS] is 1. When CTRL[WAS] 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 | | LO | When CTRL[WAS] is 1, values written to this field are part of the seed value. When CTRL[WAS] is 0, data written to this field is used for CRC checksum generation. | | 7–0 | CRC Low Lower Byte | | LL | When CTRL[WAS] is 1, values written to this field are part of the seed value. When CTRL[WAS] is 0, data written to this field is used for CRC checksum generation. | # 39.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: 4003\_4000h base + 4h offset = 4003\_4004h | Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|----|----|----|----|----|----|----|-------|------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|-----|-------|---|---|---|---|---|---|---| | R | | | | | | | | HIG | 2 LL | | | | | | | | | | | | | | | 1.0 | W | | | | | | | | | W | | | | | | | | 1 111 | ai i | | | | | | | | | | | | | | | LC | , v v | | | | | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 1 | ## **CRC\_GPOLY** field descriptions | Field | Description | |---------------|------------------------------------------------------------------------------------------------------------------------------| | 31–16<br>HIGH | High Polynominal Half-word | | | Writable and readable in 32-bit CRC mode (CTRL[TCRC] is 1). This field is not writable in 16-bit CRC mode (CTRL[TCRC] is 0). | | 15–0<br>LOW | Low Polynominal Half-word | | | Writable and readable in both 32-bit and 16-bit CRC modes. | # 39.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 CTRL[WAS] and then writing the seed into the CRC data register. Address: 4003\_4000h base + 8h offset = 4003\_4008h KM Family Reference Manual, Rev. 5, Oct 2013 # **CRC\_CTRL** field descriptions | Field | Description | |---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31–30<br>TOT | Type Of Transpose For Writes | | | Defines the transpose configuration of the data written to the CRC data register. See 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. | | 29–28<br>TOTR | Type Of Transpose For Read | | | Identifies the transpose configuration of the value read from the CRC Data register. See 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. | | 27 | This field is reserved. | | Reserved | This read-only field is reserved and always has the value 0. | | 26<br>FXOR | Complement Read Of CRC Data Register | | | Some CRC protocols require the final checksum to be XORed with 0xFFFFFFFF 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. | | 25<br>WAS | Write CRC Data Register As Seed | | | When asserted, a value written to the CRC data register is considered a seed value. When deasserted, a value written to the CRC data register is taken as data for CRC computation. | | | Writes to the CRC data register are data values. | | | Writes to the CRC data register are seed values. | | 24 | Width of CRC protocol. | | TCRC | 0 16-bit CRC protocol. | | | 1 32-bit CRC protocol. | | 23–0 | This field is reserved. | | Reserved | This read-only field is reserved and always has the value 0. | | | , | # 39.3 Functional description **runctional description** ## 39.3.1 CRC initialization/reinitialization To enable the CRC calculation, the user must program CRC\_CTRL[WAS], CRC\_GPOLY, necessary parameters for transposition and CRC result inversion in the applicable registers. Asserting CRC\_CTRL[WAS] enables the programming of the seed value into the CRC\_DATA register. After a completed CRC calculation, reasserting CRC\_CTRL[WAS] and programming a seed, whether the value is new or a previously used seed value, reinitialize the CRC module for a new CRC computation. All other parameters must be set before programming the seed value and subsequent data values. ## 39.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. Noncontiguous bytes can lead to an incorrect CRC computation. ### 39.3.2.1 16-bit CRC To compute a 16-bit CRC: - 1. Clear CRC\_CTRL[TCRC] 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 CRC\_GPOLY[LOW] field. The CRC\_GPOLY[HIGH] field is not usable in 16-bit CRC mode. - 4. Set CRC\_CTRL[WAS] to program the seed value. - 5. Write a 16-bit seed to CRC[LU:LL]. CRC\_DATA[HU:HL] are not used. - 6. Clear CRC\_CTRL[WAS] to start writing data values. - 7. Write data values into CRC[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. ## 39.3.2.2 32-bit CRC To compute a 32-bit CRC: 835 - 1. Set CRC\_CTRL[TCRC] 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 CRC\_GPOLY[HIGH:LOW]. - 4. Set CRC\_CTRL[WAS] to program the seed value. - 5. Write a 32-bit seed to CRC[LU:LL]. - 6. Clear CRC\_CTRL[WAS] to start writing data values. - 7. Write data values into CRC[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[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. # 39.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. 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. ## 39.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: - 1. 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. #### runctional description reg[31:0] becomes {reg[24:31], reg[16:23], reg[8:15], reg[0:7]} Figure 39-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 39-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 39-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. # 39.3.4 CRC result complement When CTRL[FXOR] 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 CTRL[FXOR] is cleared, reading the CRC data register accesses the raw checksum value. runctional description # **Chapter 40 Random Number Generator Accelerator (RNGA)** ## 40.1 Introduction #### **NOTE** For the chip-specific implementation details of this module's instances, see the chip configuration information. This chapter describes the random number generator accelerator RNGA, including a programming model, functional description, and application information. Throughout this chapter, the terms "RNG" and "RNGA" are meant to be synonymous. ## 40.1.1 Overview RNGA is a digital integrated circuit capable of generating 32-bit random numbers. The random bits are generated by clocking shift registers with clocks derived from ring oscillators. The configuration of the shift registers ensures statistically good data, that is, data that looks random. The oscillators with their unknown frequencies provide the required entropy needed to create random data. It is important to note that there is no known cryptographic proof showing that this is a secure method of generating random data. In fact, there may be an attack against the random number generator described in this document if its output is used directly in a cryptographic application. The attack is based on the linearity of the internal shift registers. In light of this, it is highly recommended that the random data produced by this module be used as an input seed to a NIST approved, based on DES or SHA-1, Pseudo Random Number Generator as defined in *NIST FIPS PUB 186-2 Appendix 3* and *NIST FIPS PUB SP 800-90*. Other sources of entropy can be used along with RNGA to generate the seed to the pseudorandom algorithm. The more random sources combined to create the seed, the better. The following is a list of sources that can be easily combined with the output of this module: #### woues of operation - Current time using highest precision possible. - Real-time system inputs that can be characterized as "random." - Other entropy supplied directly by the user. # 40.2 Modes of operation RNGA supports the following modes of operation. Table 40-1. Modes of operation supported by RNGA | Mode | Description | | | | | | | | |------|------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--| | | The ring-oscillator clocks are active; RNGA generates entropy (randomness) from the clocks and stores it in shift registers. | | | | | | | | | · · | The ring-oscillator clocks are inactive; RNGA does not generate entropy. | | | | | | | | Although RNGA has several modes, only one is intended for use during normal operation. Sleep mode is entered by setting the appropriate field in the RNGA Control register. • Normal mode, CR[SLP]=0 In this mode, RNGA generates random data. Because this is the default mode of operation, the user is not required to change the mode before requesting random data. • Sleep mode, CR[SLP]=1 In this mode, RNGA's oscillator clocks are shut off. The mode is entered by writing 1 to CR[SLP]. In this mode, the RNGA Output Register is not loaded. # 40.3 Entering modes supported by RNGA Table 40-2. How to enter modes supported by RNGA | Mode | Procedure | |-------------|--------------------| | Sleep mode | Write 1 to CR[SLP] | | Normal mode | Write 0 to CR[SLP] | # 40.4 Memory map and register definition This section describes the RNGA registers. ## **RNG** memory map | Absolute<br>address<br>(hex) | Register name | Width<br>(in bits) | Access | Reset value | Section/<br>page | |------------------------------|--------------------------------|--------------------|--------------------------|-------------|------------------| | 4002_9000 | RNGA Control Register (RNG_CR) | 32 | R/W | 0000_0010h | 40.4.1/841 | | 4002_9004 | RNGA Status Register (RNG_SR) | 32 | R | 0001_0000h | 40.4.2/843 | | 4002_9008 | RNGA Entropy Register (RNG_ER) | 32 | W<br>(always<br>reads 0) | 0000_0000h | 40.4.3/845 | | 4002_900C | RNGA Output Register (RNG_OR) | 32 | R | 0000_0000h | 40.4.4/845 | # 40.4.1 RNGA Control Register (RNG\_CR) This register controls the operation of RNGA. Address: 4002 9000h base + 0h offset = 4002 9000h ## **RNG\_CR** field descriptions | Field | Description | |------------------|-----------------------------------------------------------------------------------------------------------------------------| | 31–5<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 4<br>SLP | Sleep Specifies whether RNGA is in Sleep or Normal mode. NOTE: You can also enter Sleep mode by asserting the DOZE signal. | Table continues on the next page... ## memory map and register definition # **RNG\_CR** field descriptions (continued) | Field | Description | |---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | 0 Normal mode | | | 1 Sleep (low-power) mode (the RNGA oscillators are disabled, and RNGA doesn't load the OR with data) | | 3 | Clear Interrupt | | CLRI | Clears the interrupt by resetting the error-interrupt indicator (SR[ERRI]) | | | NOTE: Reading SR[ERRI] immediately after writing to CR[CLRI] is not recommended. | | | 0 Do not clear the interrupt. | | | 1 Clear the interrupt (RNGA also writes 0 to SR[ERRI] and returns the value of this field to 0). When you write 1 to this field, RNGA then resets the error-interrupt indicator (SR[ERRI]) and returns the value of this field to 0. | | 2 | Interrupt Mask | | INTM | Masks triggering an error interrupt to the interrupt controller when an OR underflow condition occurs. An OR underflow condition occurs when you read OR[RANDOUT] while it is 0. | | | 0 Not masked | | | 1 Masked | | 1<br>HA | High Assurance | | | Enables notification of security violations (via SR[SECV]). A security violation occurs when you read OR[RANDOUT] while it is 0. | | | NOTE: This field is sticky. After enabling notification of security violations, you must reset RNGA to disable them again. | | | 0 Disabled | | | 1 Enabled. | | 0 | | | GO | Specifies whether random-data generation and loading (into OR[RANDOUT]) is enabled. | | | <b>NOTE:</b> This field is sticky. You must reset RNGA to stop RNGA from loading OR[RANDOUT] with data Setting this field does not bring RNGA out of Sleep mode. Furthermore, this field does not need to be reset after exiting Sleep mode. | | | 0 Disabled | | | 1 Enabled | # 40.4.2 RNGA Status Register (RNG\_SR) Indicates the status of RNGA. Address: 4002\_9000h base + 4h offset = 4002\_9004h ## **RNG\_SR field descriptions** | Field | Description | |--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31–24 | This field is reserved. | | Reserved | This read-only field is reserved and always has the value 0. | | 23–16<br>OREG_SIZE | Output Register Size | | | Indicates the size of the Output (OR) register in terms of the number of 32-bit random-data words it can hold. 1 = One word (this value is fixed) | | 15–8<br>OREG_LVL | Output Register Level | | | Indicates the number of random-data words that are in OR[RANDOUT], which indicates whether OR[RANDOUT] is valid. 0 = No words (empty). 1 = One word (valid). | | | NOTE: If you read OR[RANDOUT] when it is not 0, RNGA then writes 0 to this field and to OR[RANDOUT]. | | 7–5 | This field is reserved. | | Reserved | This read-only field is reserved and always has the value 0. | | 4 | Sleep | | SLP | Specifies whether RNGA is in Sleep or Normal mode. | Table continues on the next page... ## memory map and register definition # **RNG\_SR field descriptions (continued)** | Field | Description | |----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | NOTE: You can also enter Sleep mode by asserting the DOZE signal. | | | 0 Normal mode | | | 1 Sleep (low-power) mode (the RNGA oscillators are disabled, and RNGA doesn't load the OR with | | | data) | | 3 | Error Interrupt | | ERRI | Indicates whether an OR underflow condition has occurred since you last cleared the error interrupt (CR[CLRI]) or RNGA was reset, regardless of whether the error interrupt is masked (CR[INTM]). An OR underflow condition occurs when you read OR[RANDOUT] while it is 0. | | | NOTE: After you reset the error-interrupt indicator (via CR[CLRI]), RNGA writes 0 to this field. | | | 0 No underflow | | | 1 Underflow | | 2 | Output Register Underflow | | ORU | Indicates whether an OR underflow condition has occurred since you last read this register (SR) or RNGA was reset, regardless of whether the error interrupt is masked (CR[INTM]). An OR underflow condition occurs when you read OR[RANDOUT] while it is 0. | | | NOTE: After you read this register, RNGA writes 0 to this field. | | | 0 No underflow | | | 1 Underflow | | 1<br>LRS | Last Read Status | | LNO | Indicates whether the most recent read of OR[RANDOUT] caused an OR underflow condition, regardless of whether the error interrupt is masked (CR[INTM]). An OR underflow condition occurs when you read OR[RANDOUT] while it is 0. | | | NOTE: After you read this register, RNGA writes 0 to this field. | | | 0 No underflow | | | 1 Underflow | | 0 | Security Violation | | SECV | When high assurance is enabled (CR[HA]), indicates that a security violation has occurred. A security violation occurs when you read OR[RANDOUT] while it is 0. | | | NOTE: This field is sticky. To reset a security violation, you must reset RNGA. | | | 0 No security violation or CR[HA] is not set. | | | 1 Security violation | # 40.4.3 RNGA Entropy Register (RNG\_ER) Specifies an entropy value that the RNGA uses in addition to its ring oscillators to seed its pseudorandom algorithm. Address: 4002\_9000h base + 8h offset = 4002\_9008h ## **RNG\_ER field descriptions** | Field | Description | | |-----------------|-----------------------------------------------------------------------------------------------------------------------------------------|--| | 31–0<br>EXT_ENT | External Entropy Specifies an entropy value that the RNGA uses in addition to its ring oscillators to seed its pseudorandom algorithm. | | | | <b>NOTE:</b> Specifying a value for this field is optional but recommended. You can write to this field at any time during operation. | | # 40.4.4 RNGA Output Register (RNG\_OR) Stores a random-data word generated by RNGA. Address: 4002\_9000h base + Ch offset = 4002\_900Ch ## RNG\_OR field descriptions | Field | Description | |-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31–0<br>RANDOUT | Random Output | | | Stores a random-data word generated by RNGA. 0 = Invalid data (if you read this field when it is 0, RNGA then writes 1 to SR[ERRI], SR[ORU], and SR[LRS]; when the error interrupt is not masked (CR[INTM]), RNGA also asserts an error interrupt request to the interrupt controller). Any other value = Valid data (if you read this field when it is not 0, RNGA then writes 0 to this field and SR[OREG_LVL]). NOTE: Before reading RANDOUT, be sure it is valid (SR[OREG_LVL]). | **runctional description** ## RNG\_OR field descriptions (continued) | Field | |-------| |-------| # 40.5 Functional description This is a block diagram of RNGA. The following sections describe these blocks in more detail. Figure 40-5. RNGA block diagram # 40.5.1 RNGA Output Register (RNG\_OR) The RNGA Output Register provides temporary storage for random data generated by the RNGA Core/Control Logic block. The RNGA Status Register allows the user to monitor the presence of valid random data in the RNGA Output Register through the SR[OREG\_LVL] field. If the user reads from the RNGA Output Register when it is empty, RNGA returns all zeros data and if the interrupt is enabled, the RNGA drives a request to the interrupt controller. Polling SR[OREG\_LVL] is very important to make sure random values are present before reading from the RNGA Output Register. # 40.5.2 RNGA Core/Control Logic Block This block contains the RNGA's Control Logic as well as its Core Engine used to generate random data. ## 40.5.2.1 RNGA Control Block The Control Block contains the address decoder, all addressable registers, and control state machines for RNGA. This block is responsible for communication with both the peripheral interface and the RNGA Output register interface. The block also controls the Core Engine to generate random data. The general functionality of the block is as follows: After reset, RNGA operates in Normal mode as follows: - 1. The core engine generates entropy and stores it in the shift registers. - 2. After you enable random-data generation and loading (CR[GO]), every 256 clock cycles the core engine generates a new random-data word. The control block immediately loads the word into OR[RANDOUT] if OR[RANDOUT] is 0 (as indicated by SR[OREG\_LVL]); otherwise, the control block discards the word. ## **40.5.2.2** Core Engine The Core Engine block contains the logic used to generate random data. The logic within the Core Engine contains the internal shift registers as well as the logic used to generate the two oscillator-based clocks. The Control Block determines how the shift registers are configured as well as when the oscillator clocks are turned on. # 40.6 Initialization/application information The intended general operation of RNGA is as follows: - 1. Reset/initialize - 2. Write 1 to CR[INTM], CR[HA], and CR[GO]. - 3. Poll the RNGA Status register for SR[OREG\_LVL]!=0 - 4. When SR[OREG\_LVL]!=0, then read the available random data from the RNGA Output register - 5. Repeat steps 3 and 4 as needed When using this RNGA as a pure entropy source, rather than as a random number generator, the requirement is to maximize entropy. When data is extracted from RNGA as quickly as the hardware allows, there is about one or two bits of added entropy per 32-bit word. Any single bit of that word contains that entropy. Therefore, when used as an entropy source, a random number should be generated for each bit of entropy required, 847 #### unualization/application information and the least significant bit (any bit would be equivalent) of each word retained. The remainder of each random number should then be discarded. Used this way, even with full knowledge of the internal state of RNGA and all prior random numbers, an attacker is not be able to predict the values of the extracted bits. # Chapter 41 LCD Controller (SLCD) ## 41.1 Introduction #### **NOTE** For the chip-specific implementation details of this module's instances, see the chip configuration information. The SLCD module is a CMOS charge pump voltage inverter that is designed for low-voltage and low-power operation. SLCD is designed to generate the appropriate waveforms to drive multiplexed numeric, alphanumeric, or custom segment LCD panels. SLCD also has several timing and control settings that can be software configured depending on the application's requirements. Timing and control consists of registers and control logic for: - LCD frame frequency - Duty cycle selection - Front plane/back plane selection and enabling - Blink modes and frequency - Operation in low-power modes # 41.1.1 Features SLCD includes these features: - LCD waveforms functional in all low-power modes - 64 LCD pins with selectable front plane/back plane configuration to: KM Family Reference Manual, Rev. 5, Oct 2013 849 #### muroduction - Generate up to 63 front plane signals - Generate up to 8 back plane signals - Programmable LCD frame frequency - Programmable blink modes and frequency - All segments blank during blink period - Alternate display for each LCD segment in x4 or less mode - Blink operation in low-power modes - Programmable LCD duty cycle from static to 1/8 - Programmable LCD power supply switch, making it an ideal solution for batterypowered and board-level applications - Charge pump that requires only four external capacitors - Internal LCD power using V<sub>DD</sub> - Internal V<sub>IREG</sub> regulated power supply option - External V<sub>LL3</sub> power supply option - Internal regulated voltage source with a 4-bit trim register to apply contrast control - Integrated charge pump for generating LCD bias voltages - On-chip generation of bias voltages - Waveform storage registers (WF) - Low power consumption in standby modes - Back plane reassignment to assist in vertical scrolling on dot-matrix displays - Software configurable LCD frame frequency interrupt - Support for segment fault detection # 41.1.2 Modes of operation SLCD supports the following operating modes: 851 ## Table 41-1. SLCD operation modes | Mode | LCD behavior | | |-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | Run | SLCD can operate an LCD panel. SLCD continues displaying the current LCD panel contents based on the WF registers. | | | Wait | Depending on the configuration, SLCD can operate an LCD panel in Wait mode. If LCDDOZE = 1, SLCD clock generation is turned off and the SLCD enters a power-conservation state and is disabled. If LCDDOZE = 0, the LCD controller can operate an LCD panel in Wait mode, and SLCD continues displaying the current LCD panel contents based on the WF registers. | | | | In Wait mode, the LCD frame interrupt can cause the MCU to exit Wait. | | | Stop | Depending on the state of the LCDSTP bit, SLCD can operate an LCD panel in Stop mode. If LCDSTP = 1, SLCD clock generation is turned off and the LCD controller enters a power conservation state and is disabled. If LCDSTP = 0, the LCD controller can operate an LCD panel in Stop mode, and SLCD continues to display the current LCD panel contents based on the LCD operation prior to the Stop event. | | | | If the LCD is enabled in Stop mode, the selected LCD clock source must be enabled to operate in Stop mode. | | | | The LCD frame interrupt does not cause the MCU to exit Stop mode. | | | VLPR | SLCD behavior is the same as in Run mode. | | | VLPW | SLCD behavior is the same as in Wait mode. | | | VLPS | SLCD behavior is the same as in Stop mode. | | | LLS | SLCD behavior is the same as in Stop mode. | | | VLLS3 | SLCD behavior is the same as in Stop mode. | | | VLLS2 | SLCD behavior is the same as in Stop mode. | | | VLLS1 | SLCD behavior is the same as in Stop mode. | | ## **NOTE** LCD End of Frame wakeup is not supported in LLS and VLLSx modes. ## **NOTE** The clock source and power modes are chip-specific. For the clock source and power-mode assignments, see the chapter that describes how modules are configured. # 41.1.3 Block diagram Figure 41-1 shows the SLCD block diagram. #### signal descriptions עט Figure 41-1. SLCD block diagram # 41.2 LCD signal descriptions SLCD has several external pins dedicated to power supply and LCD front plane/back plane signaling. SLCD can be configured to support up to eight back plane signals. This table lists and describes the LCD external signals or pins. Table 41-2. LCD signal descriptions | Signal | Description | 1/0 | |----------------------------------------------------------------------------|----------------------------------------------------------------------------------|-----| | LCD_P[63:0] . 64 LCD front plane/back plane | Configurable front plane/back plane driver that connects directly to the display | 0 | | | LCD_P[63:0] can operate as GPIO pins | | | V <sub>LL1</sub> , V <sub>LL2</sub> , V <sub>LL3</sub> . LCD bias voltages | LCD bias voltages (requires external capacitors when charge pump is used) | I/O | | V <sub>cap1</sub> , V <sub>cap2</sub> . LCD<br>charge pump<br>capacitance | Charge pump capacitor pins | 0 | # 41.2.1 LCD\_P[63:0] When LCD functionality is enabled by the PEN[63:0] bits in the PEN registers, the corresponding LCD\_P[63:0] pin generates a front plane or back plane waveform depending on the configuration of the back plane enable field (BPEN[63:0]). # 41.2.2 $V_{LL1}$ , $V_{LL2}$ , $V_{LL3}$ $V_{LL1}$ , $V_{LL2}$ , and $V_{LL3}$ are bias voltages for the LCD controller driver waveforms that can be internally generated using the internal charge pump, when enabled. When using the LCD charge pump, CPSEL = 1, a 0.1 $\mu$ F capacitor ( $C_{BYLCD}$ ) must be placed from $V_{LLx}$ to ground. The charge pump can also be configured to accept $V_{LL3}$ as an input and generate $V_{LL1}$ and $V_{LL2}$ . $V_{LL3}$ must never be connected to a voltage other than $V_{DD}$ . Refer to VSUPPLY explanation. # 41.2.3 $V_{cap1}$ , $V_{cap2}$ The charge pump capacitor ( $C_{LCD}$ ) is used to transfer charge from the input supply to the regulated output. Use a ceramic capacitor. A 0.1 $\mu F$ capacitor must be placed between these two pins. # 41.3 Memory map and register definition The total address for each register is the sum of the base address for SLCD and the address offset for each register. This section consists of register descriptions. Each description includes a standard register diagram. Details of register bit and field function follow the register diagrams, in bit order. ## **LCD** memory map | Absolute address (hex) | Register name | Width<br>(in bits) | Access | Reset value | Section/<br>page | |------------------------|----------------------------------------------|--------------------|--------|-------------|------------------| | 4004_3000 | LCD General Control Register (LCD_GCR) | 32 | R/W | See section | 41.3.1/854 | | 4004_3004 | LCD Auxiliary Register (LCD_AR) | 32 | R/W | 0000_0000h | 41.3.2/859 | | 4004_3008 | LCD Fault Detect Control Register (LCD_FDCR) | 32 | R/W | 0000_0000h | 41.3.3/861 | #### • ## LCD memory map (continued) | Absolute address (hex) | Register name | Width<br>(in bits) | Access | Reset value | Section/<br>page | |------------------------|---------------------------------------------|--------------------|--------|-------------|------------------| | 4004_300C | LCD Fault Detect Status Register (LCD_FDSR) | 32 | R/W | 0000_0000h | 41.3.4/863 | | 4004_3010 | LCD Pin Enable register (LCD_PENL) | 32 | R/W | 0000_0000h | 41.3.5/864 | | 4004_3014 | LCD Pin Enable register (LCD_PENH) | 32 | R/W | 0000_0000h | 41.3.5/864 | | 4004_3018 | LCD Back Plane Enable register (LCD_BPENL) | 32 | R/W | 0000_0000h | 41.3.6/865 | | 4004_301C | LCD Back Plane Enable register (LCD_BPENH) | 32 | R/W | 0000_0000h | 41.3.6/865 | | 4004_3020 | LCD Waveform register (LCD_WF3TO0) | 32 | R/W | 0000_0000h | 41.3.7/865 | | 4004_3024 | LCD Waveform register (LCD_WF7TO4) | 32 | R/W | 0000_0000h | 41.3.8/866 | | 4004_3028 | LCD Waveform register (LCD_WF11TO8) | 32 | R/W | 0000_0000h | 41.3.9/867 | | 4004_302C | LCD Waveform register (LCD_WF15TO12) | 32 | R/W | 0000_0000h | 41.3.10/<br>868 | | 4004_3030 | LCD Waveform register (LCD_WF19TO16) | 32 | R/W | 0000_0000h | 41.3.11/<br>868 | | 4004_3034 | LCD Waveform register (LCD_WF23TO20) | 32 | R/W | 0000_0000h | 41.3.12/<br>869 | | 4004_3038 | LCD Waveform register (LCD_WF27TO24) | 32 | R/W | 0000_0000h | 41.3.13/<br>869 | | 4004_303C | LCD Waveform register (LCD_WF31TO28) | 32 | R/W | 0000_0000h | 41.3.14/<br>870 | | 4004_3040 | LCD Waveform register (LCD_WF35TO32) | 32 | R/W | 0000_0000h | 41.3.15/<br>871 | | 4004_3044 | LCD Waveform register (LCD_WF39TO36) | 32 | R/W | 0000_0000h | 41.3.16/<br>871 | | 4004_3048 | LCD Waveform register (LCD_WF43TO40) | 32 | R/W | 0000_0000h | 41.3.17/<br>872 | | 4004_304C | LCD Waveform register (LCD_WF47TO44) | 32 | R/W | 0000_0000h | 41.3.18/<br>872 | | 4004_3050 | LCD Waveform register (LCD_WF51TO48) | 32 | R/W | 0000_0000h | 41.3.19/<br>873 | | 4004_3054 | LCD Waveform register (LCD_WF55TO52) | 32 | R/W | 0000_0000h | 41.3.20/<br>874 | | 4004_3058 | LCD Waveform register (LCD_WF59TO56) | 32 | R/W | 0000_0000h | 41.3.21/<br>874 | | 4004_305C | LCD Waveform register (LCD_WF63TO60) | 32 | R/W | 0000_0000h | 41.3.22/<br>875 | # 41.3.1 LCD General Control Register (LCD\_GCR) Write: LCDEN anytime. Do not change SOURCE, LCLK, or DUTY while LCDEN = 1. For proper operation, do not modify VSUPPLY while the LCDEN bit is asserted. VSUPPLY must also be configured according to the external hardware power supply configuration. ## **NOTE** The reset value of this register depends on the reset type: • POR -- 0x0831\_0003 Address: 4004\_3000h base + 0h offset = 4004\_3000h ## LCD\_GCR field descriptions | Field | Description | |-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31<br>RVEN | Regulated Voltage Enable | | | Enables internal voltage regulator. It must have the charge pump enabled. | | | 0 Regulated voltage disabled. | | | 1 Regulated voltage enabled. | | 30–28<br>Reserved | Reserved | | | This field is reserved. | | | This read-only field is reserved and always has the value 0. | | 27–24<br>RVTRIM | Regulated Voltage Trim | | | This 4-bit trim register is used to adjust the regulated input. Each bit in the register has equal weight. The regulated input is changed by 1.5% for each count. | | 23<br>CPSEL | Charge Pump or Resistor Bias Select | | | Selects the LCD controller charge pump or a resistor network to supply the LCD voltages V $_{\rm LL1}$ , V $_{\rm LL2}$ , and V $_{\rm LL3}$ . | | | 0 LCD charge pump is disabled. Resistor network selected. (The internal 1/3-bias is forced.) | | | 1 LCD charge pump is selected. Resistor network disabled. (The internal 1/3-bias is forced.) | | 22 | Reserved | | Reserved | This field is reserved. | | | NOTE: This bit should always be zero and nothing should be written to it | | 21–20 | Load Adjust | | LADJ | | ## memory map and register definition # LCD\_GCR field descriptions (continued) | Field | Description | | | | |----------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------|--|--| | | Configures SLCD to handle different LCD glass capacitance. | | | | | | For CPSEL = 0 | Adjust the resistor bias network for different LCD glass capacitance. 00 — Low Load (LCD glass capacitance 2000 pF or | | | | | | lower). | | | | | | 01 — Low Load (LCD glass capacitance 2000 pF or lower). | | | | | | 10 — High Load (LCD glass capacitance 8000 pF or lower) . | | | | | | 11 — High Load (LCD glass capacitance 8000 pF or lower). | | | | | For CPSEL = 1 | <ul> <li>Adjust the clock source for the charge pump.</li> <li>Higher loads require higher charge pump clock rates.</li> </ul> | | | | | | 00 — Fastest clock source for charge pump (LCD glass capacitance 8000 pF or ). | | | | | | 01 — Intermediate clock source for charge pump (LCD glass capacitance 4000 pF or ). | | | | | | 10 — Intermediate clock source for charge pump (LCD glass capacitance 2000 pF or ). | | | | | | 11 — Slowest clock source for charge pump (LCD glass capacitance 1000 pF or ). | | | | | | | | | | 19<br>Reserved | Reserved This field is reserved. This road only field is recented and always letters. | ages the value O | | | | 18 | This read-only field is reserved and always has the value 0. Reserved | | | | | Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | | | | 17<br>VSUPPLY | Voltage Supply Control Configures whether the LCD controller power supply is external or internal. Avoid modifying this field while the LCD controller is enabled, for example, if LCDEN = 1. | | | | | | 0 Drive V <sub>LL3</sub> internally from V <sub>DD</sub> 1 Drive V <sub>LL3</sub> externally from V <sub>DD</sub> or drive V | / <sub>LL</sub> internally from v <sub>IREG</sub> | | | | 16<br>Reserved | This field is reserved. | | | | | 15<br>LCDIEN | LCD Frame Frequency Interrupt Enable Enables an LCD interrupt event that coincid. | es with the LCD controller frame frequency. | | | | O No interrupt request is generated by this event. | | · | | | | | 1 When LCDIF bit is set, this event cause | | | | # LCD\_GCR field descriptions (continued) | Field | Description | |-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 14<br>FDCIEN | LCD Fault Detection Complete Interrupt Enable | | I BOILIN | Enables an LCD interrupt event when fault detection is completed. | | | 0 No interrupt request is generated by this event. | | | 1 When a fault is detected and FDCF bit is set, this event causes an interrupt request. | | 13–12<br>ALTDIV | LCD AlternateClock Divider | | | Functions as a clock divider to divide the alternate clock before it is selected as LCD clock source. | | | O Divide factor = 1 (No divide) | | | 1 Divide factor = 8 | | | 2 Divide factor = 64 | | | 3 Divide factor = 512 | | 11<br>Reserved | Reserved | | | This field is reserved. | | | This read-only field is reserved and always has the value 0. | | 10 | Reserved | | Reserved | This field is reserved. | | | NOTE: This bit should always be zero and nothing should be written to it | | 9 | LCD Doze enable | | LCDDOZE | LCD driver, charge pump, resistor bias network, and voltage regulator stop while in Doze mode. | | | O Allows the LCD driver, charge pump, resistor bias network, and voltage regulator to continue running during Doze mode. | | | 1 Disables the LCD driver, charge pump, resistor bias network, and voltage regulator when MCU enters | | | Doze mode. | | 8<br>LCDSTP | LCD Stop | | LODOTI | LCD driver, charge pump, resistor bias network, and voltage regulator stop while in Stop mode. | | | O Allows the LCD driver, charge pump, resistor bias network, and voltage regulator to continue running during Stop mode. | | | Disables the LCD driver, charge pump, resistor bias network, and voltage regulator when MCU enters Stop mode. | | 7 | LCD Driver Enable | | LCDEN | Starts LCD controller waveform generator. | | | O All front plane and back plane pins are disabled. The LCD controller system is also disabled, and all LCD waveform generation clocks are stopped. V <sub>LL3</sub> is connected to V <sub>DD</sub> internally. | | | LCD controller driver system is enabled, and front plane and back plane waveforms are generated. All | | | LCD pins, LCD_Pn, enabled using the LCD Pin Enable register, output an LCD driver waveform. The back plane pins output an LCD driver back plane waveform based on the settings of DUTY[2:0]. Charge pump or resistor bias is enabled. | | 6 | LCD Clock Source Select | | SOURCE | | ## memory map and register definition # LCD\_GCR field descriptions (continued) | Field | Description | |-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | The LCD controller has two possible clock sources. This bit is used to select which clock source is the basis for LCD clock. | | | NOTE: The clock sources are chip-specific. For the clock source assignments, see the chapter that describes how modules are configured. Alternate clock can be only MCGIRCLK, and therefore when SOURCE=1, SIM_SOPT1[OSC32KSEL] bit plays no role. Default clock can be either MCGIRCLK, ERCLK32K, OSC32KCLK, according to the selection in SIM_SOPT1[OSC32KSEL] | | | 0 Selects the default clock as the LCD clock source. | | | Selects the alternate clock as the LCD clock source. | | 5–3 | LCD Clock Prescaler | | LCLK | Used as a clock divider to generate the SLCD frame frequency. LCD controller duty cycle configuration is used to determine the LCD controller frame frequency. LCD controller frame frequency calculations are provided in SLCD base clock and frame frequency. | | | LCD controller frame frequency = LCD clock/((DUTY + 1) × 8 × (4 + LCLK[2:0]) × Y) | | | where: | | | • 30 < LCD clock < 39.063 kHz | | | • Y = 2, 2, 3, 3, 4, 5, 8, 16 chosen by module duty cycle configuration | | 2–0<br>DUTY | LCD duty select | | | Selects the duty cycle of the LCD controller driver. | | | 000 Use 1 BP (1/1 duty cycle). | | | 001 Use 2 BP (1/2 duty cycle). | | | 010 Use 3 BP (1/3 duty cycle). | | | 011 Use 4 BP (1/4 duty cycle). (Default) | | | 100 Use 5 BP (1/5 duty cycle). | | | 101 Use 6 BP (1/6 duty cycle). | | | 110 Use 7 BP (1/7 duty cycle). | | | 111 Use 8 BP (1/8 duty cycle). | # 41.3.2 LCD Auxiliary Register (LCD\_AR) ## **NOTE** The reset value of this register depends on the reset type: • POR — 0x0000\_0000 ## LCD\_AR field descriptions | Field | Description | | | |----------|---------------------------------------------------------------------------------------------------------|--|--| | 31–16 | Reserved | | | | Reserved | This field is weaponed | | | | | This field is reserved. | | | | | This read-only field is reserved and always has the value 0. | | | | 15 | LCD Frame Frequency Interrupt flag | | | | LCDIF | Indicates a frame frequency interrupt condition has occurred. To clear the interrupt, write 1 to LCDIF. | | | | | 0 Frame frequency interrupt condition has not occurred. | | | | | 1 Start of SLCD frame has occurred. | | | | 14–8 | Reserved | | | | Reserved | This field is reserved. | | | Table continues on the next page... ## memory map and register definition # LCD\_AR field descriptions (continued) | Field | Description | |---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | This read-only field is reserved and always has the value 0. | | 7<br>BLINK | Blink command | | | Starts or stops SLCD blinking. | | | 0 Disables blinking. | | | 1 Starts blinking at blinking frequency specified by LCD blink rate calculation. | | 6<br>ALT | Alternate display mode | | | For four back planes or less, the LCD back plane sequencer changes to output an alternate display. ALT bit is ignored if DUTY[2:0] is 100 or greater. | | | 0 Normal display mode. | | | 1 Alternate display mode. | | 5<br>BLANK | Blank display mode | | 22 | Asserting this bit clears all segments in the LCD. | | | 0 Normal or alternate display mode. | | | 1 Blank display mode. | | 4<br>Reserved | Reserved | | neserved | This field is reserved. | | | This read-only field is reserved and always has the value 0. | | 3<br>BMODE | Blink mode | | _ | Selects the blink mode displayed during the blink period. | | | 0 Display blank during the blink period. | | | 1 Display alternate display during blink period (Ignored if duty is 5 or greater). | | 2–0<br>BRATE | Blink-rate configuration | | | Selects frequency at which the LCD blinks when the BLINK bit is asserted. The following equation provides an expression for the LCD controller blink rate and shows how BRATE field is used in the LCD blink-rate calculation. LCD controller blink rate = LCD clock /2 <sup>(12 + BRATE)</sup> | # 41.3.3 LCD Fault Detect Control Register (LCD\_FDCR) ## **NOTE** The reset value of this register depends on the reset type: • POR — 0x0000\_0000 ## LCD\_FDCR field descriptions | Field | Description | |-------------------|--------------------------------------------------------------------------------------| | 31–16<br>Reserved | Reserved This field is reserved. | | | This read-only field is reserved and always has the value 0. | | 15<br>Reserved | Reserved This field is recorded | | | This field is reserved. This read-only field is reserved and always has the value 0. | | 14–12<br>FDPRS | Fault Detect Clock Prescaler | | | Fault detect sample clock frequency is: | | | 0 1/1 bus clock. | | | 1 1/2 bus clock. | | | 2 1/4 bus clock. | | | 3 1/8 bus clock. | | | 4 1/16 bus clock. | | | 5 1/32 bus clock. | | | 6 1/64 bus clock. | | | 7 1/128 bus clock. | ## memory map and register definition # LCD\_FDCR field descriptions (continued) | Field | Description | |---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 11–9<br>FDSWW | Fault Detect Sample Window Width | | | Specifies the sample window width of fault detection, in number of cycles in the range from 4–512 (Sample window = $4*2^N$ ). | | | 0 Sample window width is 4 sample clock cycles. | | | 1 Sample window width is 8 sample clock cycles. | | | 2 Sample window width is 16 sample clock cycles. | | | 3 Sample window width is 32 sample clock cycles. | | | 4 Sample window width is 64 sample clock cycles. | | | 5 Sample window width is 128 sample clock cycles. | | | 6 Sample window width is 256 sample clock cycles. | | | 7 Sample window width is 512 sample clock cycles. | | 8<br>Reserved | Reserved | | | This field is reserved. | | | This read-only field is reserved and always has the value 0. | | 7 | Fault Detect Enable | | FDEN | If LCDEN is 1, asserting FDEN inserts a test frame after normal LCD refresh frame is completed. After the test frame is done, Fault detection complete flag (FDCF) is set. When the test frame is done, a normal LCD refresh frame starts. FDEN is one-shot register, it clears after FDCF is set. | | | To initiate another fault detection, FDEN must be set again. | | | 0 Disable fault detection. | | | 1 Enable fault detection. | | 6 | Fault Detect Back Plane Enable | | FDBPEN | Tauk Botost Basik Flatio Eriabio | | | Enables "back plane" timing for the fault detect circuit. FDBPEN = 0 generates front plane timing. This bit specifies the type of pin selected under fault detect test. | | | 0 Type of the selected pin under fault detect test is front plane. | | | 1 Type of the selected pin under fault detect test is back plane. | | 5–0 | Fault Detect Pin ID | | FDPINID | T duit Detect 1 III ID | | | Specifies the LCD pin to be checked by pullup fault detection. | | | 0 Fault detection for LCD_P0 pin. | | | 1 Fault detection for LCD_P1 pin. | | | | | | 63 Fault detection for LCD_P63 pin. | # 41.3.4 LCD Fault Detect Status Register (LCD\_FDSR) ## **NOTE** The reset value of this register depends on the reset type: • POR — 0x0000\_0000 ## LCD\_FDSR field descriptions | Field | Description | |----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31–16 | Reserved | | Reserved | This Colding are a great | | | This field is reserved. | | | This read-only field is reserved and always has the value 0. | | 15 | Fault Detection Complete Flag | | FDCF | | | | FDCF indicates that the fault detection is completed. Writing 1 to this bit clears it to zero. This bit also acts as an interrupt flag when FDCIEN is set. Software can use either interrupt or polling to check whether one pin fault detection is completed. | | | 0 Fault detection is not completed. | | | 1 Fault detection is completed. | | | ' | | 14–8 | Reserved | | Reserved | | | | This field is reserved. | | | This read-only field is reserved and always has the value 0. | #### wemory map and register definition ## LCD\_FDSR field descriptions (continued) | Field | Description | |--------------|-----------------------------------------------------------------------------------------------------------------------------| | 7–0<br>FDCNT | Fault Detect Counter | | | Contains how many "one/high" are sampled inside the fault detect sample window. | | | 0 No "one" samples. | | | 1 1 "one" samples. | | | 2 2 "one" samples. | | | | | | 254 254 "one" samples. | | | 255 255 or more "one" samples. The FDCNT can overflow. Therefore, FDSWW and FDPRS must be reconfigured for proper sampling. | # 41.3.5 LCD Pin Enable register (LCD\_PENn) When LCDEN = 1, each PEN bit enables the corresponding LCD pin (LCD\_Pn) for LCD waveform generation. Initialize these registers before enabling the LCD controller. ## **NOTE** The reset value of this register depends on the reset type: • POR — 0x0000\_0000 Address: $4004_{3000h}$ base + 10h offset + $(4d \times i)$ , where i=0d to 1d ## LCD\_PENn field descriptions | Field | Description | |-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31–0 | LCD Pin Enable | | PEN | The PEN[63:0] bits enable the LCD_P[63:0] pins for LCD operation. PENL contains PEN[31:0], and PENH contains PEN[63:32]. | | | Each LCD_P[63:0] pin can be configured as a back plane or a front plane based on the corresponding BPEN[ $n$ ] bit in the Back Plane Enable register (BPEN). If LCDEN = 0, these bits have no effect on the state of the I/O pins. Set PEN[63:0] bits before LCDEN is set. | | | LCD operation disabled on LCD_Pn. LCD operation enabled on LCD_Pn. | ## 41.3.6 LCD Back Plane Enable register (LCD\_BPENn) When PEN[n] = 1, the BPEN[63:0] bits configure the corresponding LCD pin to operate as an LCD back plane or an LCD front plane. Most applications set a maximum of eight of these bits. Initialize these registers before enabling the LCD controller. ### **NOTE** The reset value of this register depends on the reset type: • POR — 0x0000\_0000 ### LCD\_BPENn field descriptions | Field | Description | | | | | | | | | |-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--| | 31–0 | Back Plane Enable | | | | | | | | | | BPEN | The BPEN[63:0] bits configure the LCD_P[63:0] pins to operate as an LCD back plane or LCD front plate BPENL contains BPEN[31:0], and BPENH contains BPEN[63:32]. | | | | | | | | | | | If LCDEN = 0, these bits have no effect on the state of the I/O pins. It is recommended to set BPEN[6: bits before LCDEN is set. | | | | | | | | | | | <ul><li>Front plane operation enabled on LCD_Pn.</li><li>Back plane operation enabled on LCD_Pn.</li></ul> | | | | | | | | | # 41.3.7 LCD Waveform register (LCD\_WF3TO0) Each of the WFyTOx registers contains four waveform control (WFn) fields, where x is the n index value of the WFn field in the least significant byte (bits 7-0) and y is the n index value of the WFn field in the most significant byte (bits 31-24). The bits in each WFn field control the front plane segments or back plane phases connected to the LCD\_Pn signal. In an LCD controller, each element consists of a front plane segment and a back plane phase. These segments and phases are labeled A through H (x8 multiplexing, 1/8 duty cycle). Each LCD\_Pn signal can be connected to one or more segments (in front plane operation) or one or more phases (in back plane operation). An LCD element is turned on when the associated back plane phase is activated and the front plane segment is on. #### memory map and register definition If LCD\_Pn is configured for front plane operation, the bits in WFn turn on or off each of the front plane segments connected to LCD\_Pn: bit 0 controls segment A, bit 1 controls segment B, and so on. If LCD\_Pn is configured for back plane operation, the bits in WFn activate or deactivate each of the back plane phases connected to LCD\_Pn: bit 0 controls phase A, bit 1 controls phase B, and so on. Software can write to this register with 8-bit, 16-bit, or 32-bit writes. After reset, the WFyTOx register is cleared to 0. #### **NOTE** The reset value of this register depends on the reset type: • POR — 0x0000\_0000 Address: 4004\_3000h base + 20h offset = 4004\_3020h #### LCD\_WF3TO0 field descriptions | Field | Description | |--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31–24<br>WF3 | Segment-on front plane operation — Each bit turns on or off the segments associated with LCD_P3 in the following pattern: HGFEDCBA (most significant bit controls segment H and least significant bit controls segment A). | | | Segment-on back plane operation — Each bit activates or deactivates the phases associated with LCD_P3 in the following pattern: HGFEDCBA (most significant bit controls phase H and least significant bit controls phase A). | | | For each bit: | | | 0 Segment off or phase deactivated | | | 1 Segment on or phase activated | | 23–16<br>WF2 | Controls segments or phases connected to LCD_P2 as described above for WF3. | | 15–8<br>WF1 | Controls segments or phases connected to LCD_P1 as described above for WF3. | | 7–0<br>WF0 | Controls segments or phases connected to LCD_P0 as described above for WF3. | # 41.3.8 LCD Waveform register (LCD\_WF7TO4) See the LCD Waveform register (WFC3TO0) for register and field descriptions. #### NOTE The reset value of this register depends on the reset type: • POR — 0x0000\_0000 Address: 4004\_3000h base + 24h offset = 4004\_3024h ### LCD\_WF7TO4 field descriptions | Field | Description | |--------------|-------------------------------------------------------------------------------------| | 31–24<br>WF7 | Controls segments or phases connected to LCD_P7 as described above for WF3TO0[WF3]. | | 23–16<br>WF6 | Controls segments or phases connected to LCD_P6 as described above for WF3TO0[WF3]. | | 15–8<br>WF5 | Controls segments or phases connected to LCD_P5 as described above for WF3TO0[WF3]. | | 7–0<br>WF4 | Controls segments or phases connected to LCD_P4 as described above for WF3TO0[WF3]. | ## 41.3.9 LCD Waveform register (LCD\_WF11TO8) See the LCD Waveform register (WFC3TO0) for register and field descriptions. #### **NOTE** The reset value of this register depends on the reset type: • POR — 0x0000\_0000 Address: 4004\_3000h base + 28h offset = 4004\_3028h #### LCD\_WF11TO8 field descriptions | Field | Description | |---------------|--------------------------------------------------------------------------------------| | 31–24<br>WF11 | Controls segments or phases connected to LCD_P11 as described above for WF3TO0[WF3]. | | 23–16<br>WF10 | Controls segments or phases connected to LCD_P10 as described above for WF3TO0[WF3]. | | 15–8<br>WF9 | Controls segments or phases connected to LCD_P9 as described above for WF3TO0[WF3]. | Table continues on the next page... memory map and register definition ### LCD\_WF11TO8 field descriptions (continued) | Fi | ield | Description | |----|-----------|-------------------------------------------------------------------------------------| | 1 | –0<br>/F8 | Controls segments or phases connected to LCD_P8 as described above for WF3TO0[WF3]. | ## 41.3.10 LCD Waveform register (LCD\_WF15TO12) See the LCD Waveform register (WFC3TO0) for register and field descriptions. #### **NOTE** The reset value of this register depends on the reset type: • POR — 0x0000\_0000 Address: 4004\_3000h base + 2Ch offset = 4004\_302Ch ### LCD\_WF15TO12 field descriptions | Field | Description | |---------------|--------------------------------------------------------------------------------------| | 31–24<br>WF15 | Controls segments or phases connected to LCD_P15 as described above for WF3TO0[WF3]. | | 23–16<br>WF14 | Controls segments or phases connected to LCD_P14 as described above for WF3TO0[WF3]. | | 15–8<br>WF13 | Controls segments or phases connected to LCD_P13 as described above for WF3TO0[WF3]. | | 7–0<br>WF12 | Controls segments or phases connected to LCD_P12 as described above for WF3TO0[WF3]. | # 41.3.11 LCD Waveform register (LCD\_WF19TO16) See the LCD Waveform register (WFC3TO0) for register and field descriptions. #### NOTE The reset value of this register depends on the reset type: • POR — 0x0000\_0000 Address: 4004\_3000h base + 30h offset = 4004\_3030h ## LCD\_WF19TO16 field descriptions | Field | Description | |---------------|--------------------------------------------------------------------------------------| | 31–24<br>WF19 | Controls segments or phases connected to LCD_P19 as described above for WF3TO0[WF3]. | | 23–16<br>WF18 | Controls segments or phases connected to LCD_P18 as described above for WF3TO0[WF3]. | | 15–8<br>WF17 | Controls segments or phases connected to LCD_P17 as described above for WF3TO0[WF3]. | | 7–0<br>WF16 | Controls segments or phases connected to LCD_P16 as described above for WF3TO0[WF3]. | # 41.3.12 LCD Waveform register (LCD\_WF23TO20) See the LCD Waveform register (WFC3TO0) for register and field descriptions. #### **NOTE** The reset value of this register depends on the reset type: • POR — 0x0000\_0000 Address: 4004\_3000h base + 34h offset = 4004\_3034h | Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|------|----|----|------|----|--------|----|----|----|----|----|----|----|---------|----|----|----|----|----|----|----|--------|---|---|---|---|---|----|----|---|---|---| | R | | | | \//E | 23 | | | | | | | WF | 22 | | | | | | | WF | 21 | | | | | | | WF | 20 | | | | | w | WF23 | | | | | VVI 22 | | | | | | | | VVI Z I | | | | | | | | VVI 20 | | | | | | | | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ## LCD\_WF23TO20 field descriptions | Field | Description | |---------------|--------------------------------------------------------------------------------------| | 31–24<br>WF23 | Controls segments or phases connected to LCD_P23 as described above for WF3TO0[WF3]. | | 23–16<br>WF22 | Controls segments or phases connected to LCD_P22 as described above for WF3TO0[WF3]. | | 15–8<br>WF21 | Controls segments or phases connected to LCD_P21 as described above for WF3TO0[WF3]. | | 7–0<br>WF20 | Controls segments or phases connected to LCD_P20 as described above for WF3TO0[WF3]. | # 41.3.13 LCD Waveform register (LCD\_WF27TO24) See the LCD Waveform register (WFC3TO0) for register and field descriptions. ### **NOTE** The reset value of this register depends on the reset type: #### wemory map and register definition • POR — 0x0000 0000 Address: 4004\_3000h base + 38h offset = 4004\_3038h | Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|----|----|----|-----|-----|----|----|----|----|----|----|-------|----|----|----|----|----|----|----|-------|----|----|---|---|---|---|---|-------|----------------|---|---|---| | R | | | | WF | -27 | | | | | | | WF | 26 | | | | | | | WF | 25 | | | | | | | WF | 2/ | | | | | W | | | - | VVI | | | | | | | | V V I | 20 | | | | | | | V V I | 25 | | | | | | | V V I | Z <del>+</del> | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ### LCD\_WF27TO24 field descriptions | Field | Description | |---------------|--------------------------------------------------------------------------------------| | 31–24<br>WF27 | Controls segments or phases connected to LCD_P27 as described above for WF3TO0[WF3]. | | 23–16<br>WF26 | Controls segments or phases connected to LCD_P26 as described above for WF3TO0[WF3]. | | 15–8<br>WF25 | Controls segments or phases connected to LCD_P25 as described above for WF3TO0[WF3]. | | 7–0<br>WF24 | Controls segments or phases connected to LCD_P24 as described above for WF3TO0[WF3]. | # 41.3.14 LCD Waveform register (LCD\_WF31TO28) See the LCD Waveform register (WFC3TO0) for register and field descriptions. ### **NOTE** The reset value of this register depends on the reset type: • POR — 0x0000\_0000 Address: 4004\_3000h base + 3Ch offset = 4004\_303Ch ### LCD\_WF31TO28 field descriptions | Field | Description | |---------------|--------------------------------------------------------------------------------------| | 31–24<br>WF31 | Controls segments or phases connected to LCD_P31 as described above for WF3TO0[WF3]. | | 23–16<br>WF30 | Controls segments or phases connected to LCD_P30 as described above for WF3TO0[WF3]. | | 15–8<br>WF29 | Controls segments or phases connected to LCD_P29 as described above for WF3TO0[WF3]. | | 7–0<br>WF28 | Controls segments or phases connected to LCD_P28 as described above for WF3TO0[WF3]. | 871 ## 41.3.15 LCD Waveform register (LCD\_WF35TO32) See the LCD Waveform register (WFC3TO0) for register and field descriptions. #### NOTE The reset value of this register depends on the reset type: • POR — 0x0000\_0000 Address: 4004\_3000h base + 40h offset = 4004\_3040h ### LCD\_WF35TO32 field descriptions | Field | Description | |---------------|--------------------------------------------------------------------------------------| | 31–24<br>WF35 | Controls segments or phases connected to LCD_P35 as described above for WF3TO0[WF3]. | | 23–16<br>WF34 | Controls segments or phases connected to LCD_P34 as described above for WF3TO0[WF3]. | | 15–8<br>WF33 | Controls segments or phases connected to LCD_P33 as described above for WF3TO0[WF3]. | | 7–0<br>WF32 | Controls segments or phases connected to LCD_P32 as described above for WF3TO0[WF3]. | ## 41.3.16 LCD Waveform register (LCD\_WF39TO36) See the LCD Waveform register (WFC3TO0) for register and field descriptions. ### **NOTE** The reset value of this register depends on the reset type: • POR — 0x0000\_0000 Address: 4004\_3000h base + 44h offset = 4004\_3044h #### wemory map and register definition ### LCD\_WF39TO36 field descriptions | Field | Description | |---------------|--------------------------------------------------------------------------------------| | 31–24<br>WF39 | Controls segments or phases connected to LCD_P39 as described above for WF3TO0[WF3]. | | 23–16<br>WF38 | Controls segments or phases connected to LCD_P38 as described above for WF3TO0[WF3]. | | 15–8<br>WF37 | Controls segments or phases connected to LCD_P37 as described above for WF3TO0[WF3]. | | 7–0<br>WF36 | Controls segments or phases connected to LCD_P36 as described above for WF3TO0[WF3]. | # 41.3.17 LCD Waveform register (LCD\_WF43TO40) See the LCD Waveform register (WFC3TO0) for register and field descriptions. #### NOTE The reset value of this register depends on the reset type: • POR — 0x0000\_0000 Address: 4004\_3000h base + 48h offset = 4004\_3048h ## LCD\_WF43TO40 field descriptions | Field | Description | |---------------|--------------------------------------------------------------------------------------| | 31–24<br>WF43 | Controls segments or phases connected to LCD_P43 as described above for WF3TO0[WF3]. | | 23–16<br>WF42 | Controls segments or phases connected to LCD_P42 as described above for WF3TO0[WF3]. | | 15–8<br>WF41 | Controls segments or phases connected to LCD_P41 as described above for WF3TO0[WF3]. | | 7–0<br>WF40 | Controls segments or phases connected to LCD_P40 as described above for WF3TO0[WF3]. | # 41.3.18 LCD Waveform register (LCD\_WF47TO44) See the LCD Waveform register (WFC3TO0) for register and field descriptions. ### **NOTE** The reset value of this register depends on the reset type: ## • POR — 0x0000\_0000 Address: 4004\_3000h base + 4Ch offset = 4004\_304Ch | Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|----|----|----|-----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|-------|----|----|---|---|---|---|---|-------|----|---|---|---| | R | | | | WF | 17 | | | | | | | WF | 16 | | | | | | | WF | 15 | | | | | | | WF | 11 | | | | | W | | | - | VVI | 47 | | _ | | | | | VVI | +0 | | | | | | | V V I | 45 | | | | | | | V V I | | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ## LCD\_WF47TO44 field descriptions | Field | Description | |---------------|--------------------------------------------------------------------------------------| | 31–24<br>WF47 | Controls segments or phases connected to LCD_P47 as described above for WF3TO0[WF3]. | | 23–16<br>WF46 | Controls segments or phases connected to LCD_P46 as described above for WF3TO0[WF3]. | | 15–8<br>WF45 | Controls segments or phases connected to LCD_P45 as described above for WF3TO0[WF3]. | | 7–0<br>WF44 | Controls segments or phases connected to LCD_P44 as described above for WF3TO0[WF3]. | # 41.3.19 LCD Waveform register (LCD\_WF51TO48) See the LCD Waveform register (WFC3TO0) for register and field descriptions. ### **NOTE** The reset value of this register depends on the reset type: • POR — 0x0000\_0000 Address: 4004\_3000h base + 50h offset = 4004\_3050h ### LCD\_WF51TO48 field descriptions | Field | Description | |---------------|--------------------------------------------------------------------------------------| | 31–24<br>WF51 | Controls segments or phases connected to LCD_P51 as described above for WF3TO0[WF3]. | | 23–16<br>WF50 | Controls segments or phases connected to LCD_P50 as described above for WF3TO0[WF3]. | | 15–8<br>WF49 | Controls segments or phases connected to LCD_P49 as described above for WF3TO0[WF3]. | | 7–0<br>WF48 | Controls segments or phases connected to LCD_P48 as described above for WF3TO0[WF3]. | ## 41.3.20 LCD Waveform register (LCD\_WF55TO52) See the LCD Waveform register (WFC3TO0) for register and field descriptions. #### NOTE The reset value of this register depends on the reset type: • POR — 0x0000 0000 Address: 4004\_3000h base + 54h offset = 4004\_3054h ### LCD\_WF55TO52 field descriptions | Field | Description | |---------------|--------------------------------------------------------------------------------------| | 31–24<br>WF55 | Controls segments or phases connected to LCD_P55 as described above for WF3TO0[WF3]. | | 23–16<br>WF54 | Controls segments or phases connected to LCD_P54 as described above for WF3TO0[WF3]. | | 15–8<br>WF53 | Controls segments or phases connected to LCD_P53 as described above for WF3TO0[WF3]. | | 7–0<br>WF52 | Controls segments or phases connected to LCD_P52 as described above for WF3TO0[WF3]. | ## 41.3.21 LCD Waveform register (LCD\_WF59TO56) See the LCD Waveform register (WFC3TO0) for register and field descriptions. ### **NOTE** The reset value of this register depends on the reset type: • POR — 0x0000\_0000 Address: 4004\_3000h base + 58h offset = 4004\_3058h ## LCD\_WF59TO56 field descriptions | Field | Description | |---------------|--------------------------------------------------------------------------------------| | 31–24<br>WF59 | Controls segments or phases connected to LCD_P59 as described above for WF3TO0[WF3]. | | 23–16<br>WF58 | Controls segments or phases connected to LCD_P58 as described above for WF3TO0[WF3]. | | 15–8<br>WF57 | Controls segments or phases connected to LCD_P57 as described above for WF3TO0[WF3]. | | 7–0<br>WF56 | Controls segments or phases connected to LCD_P56 as described above for WF3TO0[WF3]. | # 41.3.22 LCD Waveform register (LCD\_WF63TO60) See the LCD Waveform register (WFC3TO0) for register and field descriptions. #### **NOTE** The reset value of this register depends on the reset type: • POR — 0x0000\_0000 Address: 4004\_3000h base + 5Ch offset = 4004\_305Ch ## LCD\_WF63TO60 field descriptions | Field | Description | |---------------|--------------------------------------------------------------------------------------| | 31–24<br>WF63 | Controls segments or phases connected to LCD_P63 as described above for WF3TO0[WF3]. | | 23–16<br>WF62 | Controls segments or phases connected to LCD_P62 as described above for WF3TO0[WF3]. | | 15–8<br>WF61 | Controls segments or phases connected to LCD_P61 as described above for WF3TO0[WF3]. | | 7–0<br>WF60 | Controls segments or phases connected to LCD_P60 as described above for WF3TO0[WF3]. | # 41.4 Functional description This section provides a complete functional description of SLCD. Before enabling SLCD by asserting [GCR]LCDEN, configure SLCD based on the end application requirements. Out of reset, SLCD is configured with default settings, but these settings are not optimal for every application. SLCD provides several versatile configuration settings and options to support varied implementation requirements, including: - Frame frequency - Duty cycle (number of back planes) - Back plane assignment (which LCD\_P[63:0] pins operate as back planes) - Frame frequency interrupt enable - Blinking frequency and options - Power-supply configurations - Fault detection configuration SLCD also provides an LCD pin enable control. Setting the LCD pin enable bit in the PENn register for a particular LCD\_Pn pin enables SLCD front plane or back plane waveform functionality of that pin after GCR[LCDEN] is set. When GCR[LCDEN] is clear and the LCD pin enable bit is set, the LCD\_Pn pin will be driven disabled. When the back plane enable bit in the BPENn is set, the associated pin operates as a back plane. The WFyTOx registers can then activate (display) the corresponding LCD segments on an LCD panel. The WFyTOx registers control the on/off state for the segments controlled by the LCD pins defined as front planes and the active phase for the back planes. Blank display modes do not use the data from the WFyTOx registers. When using the WFyTOx register for front plane operation, writing a 0 turns the segment off. For pins enabled as back plane, the bits in WFn fields assign the phases of the back plane (A-H) for the corresponding back plane pin. For a detailed description of SLCD operation for a basic seven-segment LCD display, see LCD seven segment example description. # 41.4.1 LCD controller driver description The LCD controller driver has eight modes of operation: - 1/1 duty (one back plane) (Phase A), static mode - 1/2 duty (two back planes) (Phase A, B), 1/3 bias (four voltage levels) 877 - 1/3 duty (three back planes) (Phase A, B, C), 1/3 bias (four voltage levels) - 1/4 duty (four back planes) (Phase A, B, C, D), 1/3 bias (four voltage levels) - 1/5 duty (five back planes) (Phase A, B, C, D, E), 1/3 bias (four voltage levels) - 1/6 duty (six back planes) (Phase A, B, C, D, E, F), 1/3 bias (four voltage levels) - 1/7 duty (seven back planes) (Phase A, B, C, D, E, F, G), 1/3 bias (four voltage levels) - 1/8 duty (eight back planes) (Phase A, B, C, D, E, F, G, H), 1/3 bias (four voltage levels) All modes are 1/3 bias. These modes of operation are described in more detail in the next sections. ## 41.4.1.1 LCD duty cycle The denominator of the duty cycle indicates the number of LCD panel segments capable of being driven by each individual front plane output driver. Depending on the duty cycle, the LCD waveform drive can be categorized as static or multiplexed. In static-driving method, the LCD is driven with two square waveforms. The static-driving method is the most basic method to drive an LCD panel, but because each front plane driver can drive only one LCD segment, static driving limits the LCD segments that can be driven with a given number of front plane pins. In static mode, only one back plane is required. In multiplexed mode, the LCD waveforms are multi-level and depend on the bias mode. Multiplex mode, depending on the number of back planes, can drive multiple LCD segments with a single front plane driver. This reduces the number of driver circuits and connections to LCD segments. For multiplex mode operation, at least two back plane drivers are needed. The LCD controller is optimized for multiplex mode. The numerator of the duty cycle indicates the amount of time the LCD panel segment is energized during each LCD controller frame cycle. The denominator of the duty cycle indicates the number of back planes that are being used to drive an LCD panel and the number of phase sequences, 1 to 8. The duty cycle is used by the back plane phase generator to set the phase outputs. The phase outputs A-H are driven according to the sequence shown below. The sequence is repeated at the LCD frame frequency. The duty cycle is configured using GCR[DUTY[2:0]], as shown in Table 41-30. Table 41-30. LCD controller duty cycle modes | Duty | | GCR | | Number of book planes | Phase seguence | | | |------|-------|-------|-------|-----------------------|----------------|--|--| | Duty | DUTY2 | DUTY1 | DUTY0 | Number of back planes | Phase sequence | | | | 1/1 | 0 | 0 | 0 | 1 | A | | | | 1/2 | 0 | 0 | 1 | 2 | AB | | | | 1/3 | 0 | 1 | 0 | 3 | ABC | | | | 1/4 | 0 | 1 | 1 | 4 | ABCD | | | | 1/5 | 1 | 0 | 0 | 5 | ABCDE | | | | 1/6 | 1 | 0 | 1 | 6 | ABCDEF | | | | 1/7 | 1 | 1 | 0 | 7 | ABCDEFG | | | | 1/8 | 1 | 1 | 1 | 8 | ABCDEFGH | | | ### 41.4.1.2 LCD bias Because a single front plane driver is configured to drive more and more individual LCD segments, three voltage levels are required to generate the appropriate waveforms to drive the segment. SLCD is designed to operate using the 1/3 bias mode. #### 41.4.1.3 SLCD base clock and frame frequency SLCD is optimized to operate using a 32.768 kHz clock input. Two clock sources are available to the SLCD, which are selectable by configuring the GCR[SOURCE]. The two clock sources include: - Default clock (GCR[SOURCE] = 0) - Alternate clock (GCR[SOURCE] = 1) #### NOTE The clock source is chip-specific. For the clock source assignments, see the chapter that describes how modules are configured. Figure 41-28 shows the LCD clock tree. The clock tree shows the two possible clock sources, and the LCD frame frequency and blink frequency clock source. The LCD blink frequency is discussed in Blink frequency. Figure 41-28. LCD clock tree An external 32.768 kHz clock input is required to achieve lowest power consumption. The value of GCR[LCLK] is important because it is used to generate the SLCD frame frequency. The following two tables show SLCD frame frequency calculations that consider several possible SLCD configurations of GCR[LCLK[2:0]], and GCR[DUTY[2:0]]. SLCD frame frequency is defined as the number of times the LCD segments are energized per second. The SLCD frame frequency must be selected to achieve the right balance between flickering (SLCD frame frequency too close to the frequency of an interfering light source or too low), contrast (SLCD frame frequency too low for the display chosen), and power (SLCD frame frequency too high).. Selecting lower values for the LCD base and frame frequency results in lower current consumption for the SLCD. The SLCD base clock frequency is the SLCD frame frequency multiplied by the number of back plane phases that are being generated. The number of back plane phases is selected using the GCR[DUTY[2:0]] bits. The SLCD base clock is used by the back plane sequencer to generate the LCD waveform data for the enabled phases (A-H). Table 41-31. SLCD frame frequency calculations for clock input ~ 32.768 kHz | Duty cycle | 1/1 | 1/2 | 1/3 | 1/4 | 1/5 | 1/6 | 1/7 | 1/8 | |----------------|------|------|------|------|------|------|------|------| | Y | 16 | 8 | 5 | 4 | 3 | 3 | 2 | 2 | | GCR[LCLK[2:0]] | | | | | | | | | | 0 | 64 | 64 | 68.3 | 64 | 68.3 | 56.9 | 73.1 | 64 | | 1 | 51.2 | 51.2 | 54.6 | 51.2 | 54.6 | 45.5 | 58.5 | 51.2 | | 2 | 42.7 | 42.7 | 45.5 | 42.7 | 45.5 | 37.9 | 48.8 | 42.7 | Table continues on the next page... Table 41-31. SLCD frame frequency calculations for clock input ~ 32.768 kHz (continued) | Duty cycle | 1/1 | 1/2 | 1/3 | 1/4 | 1/5 | 1/6 | 1/7 | 1/8 | |----------------|------|------|------|------|------|------|------|------| | Υ | 16 | 8 | 5 | 4 | 3 | 3 | 2 | 2 | | GCR[LCLK[2:0]] | | | | | | | | | | 3 | 36.6 | 36.6 | 39 | 36.6 | 39 | 32.5 | 41.8 | 36.6 | | 4 | 32 | 32 | 34.1 | 32 | 34.1 | 28.4 | 36.6 | 32 | | 5 | 28.4 | 28.4 | 30.3 | 28.4 | 30.3 | 25.3 | 32.5 | 28.4 | | 6 | 25.6 | 25.6 | 27.3 | 25.6 | 27.3 | 22.8 | 29.3 | 25.6 | | 7 | 23.3 | 23.3 | 24.8 | 23.3 | 24.8 | 20.7 | 26.6 | 23.3 | Table 41-32. SLCD frame frequency calculations for clock input ~ 39.063 kHz | Duty cycle | 1/1 | 1/2 | 1/3 | 1/4 | 1/5 | 1/6 | 1/7 | 1/8 | |----------------|------|------|------|------|------|------|------|------| | Υ | 16 | 8 | 5 | 4 | 3 | 3 | 2 | 2 | | GCR[LCLK[2:0]] | | , | | | - | | , | | | 0 | 76.3 | 76.3 | 81.4 | 76.3 | 81.4 | 67.8 | 87.2 | 76.3 | | 1 | 61 | 61 | 65.1 | 61 | 65.1 | 54.3 | 69.8 | 61 | | 2 | 50.9 | 50.9 | 54.3 | 50.9 | 54.3 | 45.2 | 58.1 | 50.9 | | 3 | 43.6 | 43.6 | 46.5 | 43.6 | 46.5 | 38.8 | 49.8 | 43.6 | | 4 | 38.1 | 38.1 | 40.7 | 38.1 | 40.7 | 33.9 | 43.6 | 38.1 | | 5 | 33.9 | 33.9 | 36.2 | 33.9 | 36.2 | 30.1 | 38.8 | 33.9 | | 6 | 30.5 | 30.5 | 32.6 | 30.5 | 32.6 | 27.1 | 34.9 | 30.5 | | 7 | 27.7 | 27.7 | 29.6 | 27.7 | 29.6 | 24.7 | 31.7 | 27.7 | # 41.4.1.4 LCD waveform examples This section shows the timing examples of the LCD output waveforms for the several modes of operation. As shown in Table 41-33, all examples use 1/3 bias mode. Table 41-33. Configurations for example LCD waveforms | Examples | Bias mode | GCR[DUTY[2:0]] | Duty cycle | |-----------|-----------|----------------|------------| | Example 1 | | 001 | 1/2 | | Example 2 | 1/3 | 011 | 1/4 | | Example 3 | | 111 | 1/8 | ## 41.4.1.4.1 1/2 duty multiplexed with 1/3 bias mode (low-power waveform) Duty=1/2: DUTY[2:0] = 001 LCD\_P[1:0] enabled as back planes: BPEN0 = 1 and BPEN1 = 1 in the BPEN0 LCD\_P0 assigned to Phase A: WF0 = 0x01 LCD\_P1 assigned to Phase B: WF1 = 0x02, WF1TO0 = 0x00000201 Figure 41-29. 1/2 duty and 1/3 bias (low-power waveform) # 41.4.1.4.2 1/4 duty multiplexed with 1/3 bias mode (low-power waveform) Duty = 1/4: DUTY[2:0] = 011 LCD\_P[3:0] enabled as back planes: BPEN0 = 0x0F LCD\_P0 assigned to Phase A: WF0 = 0x01 LCD\_P1 assigned to Phase B: WF1 = 0x02 LCD\_P2 assigned to Phase C: WF2 = 0x04 LCD\_P3 assigned to Phase D: WF3 = 0x08, WF3TO0 = 0x08040201 Figure 41-30. 1/4 duty and 1/3 bias (low-power waveform) # 41.4.1.4.3 1/8 Duty multiplexed with 1/3 bias mode (low-power waveform) Duty = 1/8:DUTY[2:0] = 111 $LCD_P[7:0]$ enabled as backplanes: BPEN0 = 0xFF LCD\_P0 assigned to Phase A: WF0 = 0x01 LCD\_P1 assigned to Phase B: WF1 = 0x02 LCD\_P2 assigned to Phase C: WF2 = 0x04 LCD\_P3 assigned to Phase D: WF3 = 0x08 LCD\_P4 assigned to Phase E: WF4 = 0x10 LCD\_P5 assigned to Phase F: WF5 = 0x20 LCD\_P6 assigned to Phase G: WF6 = 0x40 LCD\_P7 assigned to Phase H: WF7 = 0x80, WF7TO4 = 0x80402010, WF3TO0 = 0x08040201 Figure 41-31. 1/8 Duty and 1/3 bias (low-power waveform) # 41.4.2 WFyTOx registers For a segment on the LCD panel to be displayed, data must be written to the WFyTOx registers. For LCD pins enabled as front planes, each bit in the WFyTOx registers corresponds to a segment on an LCD panel. The different phases (A-H) represent the different back planes of the LCD panel. The selected LCD duty cycle controls the number of implemented phases. Refer to Table 41-30 for normal LCD operation the phases follow the sequence shown. For LCD pins enabled as a back plane, the WFyTOx register assigns the phase in which the back plane pin is active. This is how back plane assignment is done. An example of normal operation follows. To enable LCD\_P0 to operate as back plane 0: - 1. Enable the LCD\_P0 by setting PEN0 bit in the PENL register, PENL = 0x00000001. - 2. Configure LCD\_P0 as a back plane pin by setting the BPEN0 bit in the BPEN0 register. - 3. The WF0 bit in the WF3TO0 register is set to associate LCD\_P0 with back plane phase A, WF3tO0 =0x00000001. This configures LCD\_P0 to operate as a back plane that is active in phase A. For LCD pins enabled as a front plane: - Writing 1 to a given WF location results in the corresponding display segment being driven with the differential root mean square (RMS) voltage necessary to turn the segment on during the phase selected. - Writing 0 to a given location results in the corresponding display segment being driven with the differential RMS voltage necessary to turn the segment off during the phase selected. # 41.4.3 LCD display modes SLCD can be configured to implement several different display modes. In the LCD auxiliary register (AR), the bits ALT and BLANK configure the different display modes: #### Normal display mode (default) The LCD segments are controlled by the data placed in the WFyTOx registers, as described in WFyTOx registers. #### Blank display mode The WF data is bypassed and the front plane and back plane pins are configured to clear all segments. Alternate display mode The backplane sequence is modified for duty cycles of 1/4, 1/3, 1/2, and 1/1. For four back planes or less, the back plane sequence is modified as shown below. The altered sequence allows two complete displays to be placed in the WFyTOx registers. The first display is placed in phases A-D and the second in phases E-H in the case of four back planes. If the LCD duty cycle is five back planes or greater, the ALT bit is ignored and creates a blank display. Refer to Table 41-35 for additional information. #### NOTE For alternate display modes, both the segment data and the back plane configuration must be configured for both the upper and lower nibble. For example, if LCD\_P0 is configured as back plane 0 (phase A) then for proper operation in Alternate Display mode, the WF3TO0 must be set to 0x00000011 to set both BPEWF0 and BPAWF0. Using the alternate display function, an inverse display can be accomplished for x4 mode and less by placing inverse data in the alternate phases of the WFyTOx registers. | Duty | Back plane sequence | Alternate back plane sequence | |------|---------------------|-------------------------------| | 1/1 | Α | Е | | 1/2 | АВ | EF | | 1/3 | ABC | EFG | | 1/4 | ABCD | EFGH | Table 41-34. Alternate display back plane sequence ### 41.4.3.1 LCD blink modes Blink mode is used as a means of alternating among different LCD display modes at a defined frequency. The LCD controller can be configured to implement two blink modes. The AR[BMODE] bit in the LCD auxiliary register configures the different blink modes. Blink modes are activated by setting AR[BLINK]. If AR[BLINK] = 0, SLCD operates normally as described in LCD display modes. If AR[BLINK] = 1, AR[BMODE] configures the blinking operation. During a blink, the display data driven by SLCD changes to the mode selected by AR[BMODE]. The AR[BMODE] bit selects two different blink modes, blank and alternate modes. They operate in the same way, as defined in LCD display modes. Table 41-35 shows the interaction between display modes and blink modes. If the LCD duty cycle is five back planes or greater, AR[BMODE] = 1 is ignored and reverts to create a blank display during the blink period. | BLANK | ALT | BMODE | LCD duty cycle | BLINK = 1 | | | |-------|-----|-------|----------------|--------------------------------|--------------------------------|--| | | • | | | Normal period | Blink period | | | 0 | 0 | 0 | 1-4 | Normal display | Blank display | | | 0 | 0 | 1 | 1-4 | Normal display | Alternate display <sup>1</sup> | | | 0 | 1 | 0 | 1-4 | Alternate display <sup>1</sup> | Blank display | | | 0 | 1 | 1 | 1-4 | Alternate display <sup>1</sup> | Alternate display <sup>1</sup> | | | 1 | х | 0 | 1-4 | Blank display | Blank display | | | 1 | х | 1 | 1-4 | Blank display | Alternate display <sup>1</sup> | | | 0 | х | х | 8 | Normal display | Blank display | | | 1 | х | х | 8 | Blank display | Blank display | | Table 41-35. Display mode interaction ## 41.4.3.2 Blink frequency The LCD clock is the basis for the calculation of the LCD controller blink frequency. The LCD controller blink frequency is equal to the LCD clock (GCR[LCLK]) divided by the factor selected by the AR[BRATE[2:0]] bits. The following table shows LCD controller blink frequency calculations for all values of AR[BRATE[2:0]] at a few common GCR[LCLK] selections. Table 41-36. Blink frequency calculations (Blink rate = LCD clock (Hz) ÷ Blink divider) | AR[BRATE[2:0]] | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | |--------------------------|----------------------|------|-------|-------|------|------|------|-------| | LCD clock<br>(GCR[LCLK]) | Blink frequency (Hz) | | | | | | | | | 30 kHz | 7.32 | 3.66 | 1.831 | 0.916 | 0.46 | 0.23 | 0.11 | 0.06 | | 32.768 kHz | 8 | 4 | 2 | 1 | 0.5 | 0.25 | 0.13 | 0.06 | | 39.063 kHz | 9.54 | 4.77 | 2.38 | 1.19 | 0.6 | 0.30 | 0.15 | 0.075 | # 41.4.4 LCD charge pump and power supply operation This section describes the LCD charge pump and LCD power supply configuration options. <sup>1.</sup> For alternate display modes, both the segment data and the back plane configuration must be configured for both the upper and lower nibble. For example, if LCD\_P0 is configured as back plane 0 (phase A) then for proper operation in Alternate Display mode, the WF3TO0 should be set to 0x00000011 to set both BPEWF0 and BPAWF0. The LCD bias voltages ( $V_{LL1}$ , $V_{LL2}$ and $V_{LL3}$ ) can be generated by the LCD charge pump or a resistor divider network that is connected using the GCR[CPSEL] bit. The input source to the LCD charge pump is controlled by GCR[VSUPPLY]. GCR[VSUPPLY] indicates the state of internal signals used to configure power switches as shown in the table in the following figure. The block diagram in the following figure illustrates several potential operational modes for SLCD including configuration of the SLCD power supply source using $V_{DD}$ , internal regulated voltage $V_{IREG}$ , or an external supply on $V_{LL3}$ . $V_{LL3}$ must never be externally driven to any level other than $V_{DD}$ . Upon reset GCR[VSUPPLY] is configured to connect $V_{LL3}$ to $V_{DD}$ . This configuration must be changed to match the application requirements before SLCD is enabled. Figure 41-32. LCD charge pump block diagram Table 41-37. LCD power supply configuration options | GCR[VSUPPLY] | Configuration | powersw1 | powersw2 | |--------------|----------------------------------------------------------|----------|----------| | 0 | Drive V <sub>LL3</sub> internally from V <sub>DD</sub> | 0 | 1 | | 1 | Drive V <sub>LL3</sub> externally from V <sub>DD</sub> | 0 | 0 | | | or | | | | | Drive V <sub>LL1</sub> internally from V <sub>IREG</sub> | | | #### **Note** The charge pump is optimized for 1/3 bias mode operation only. The charge pump requires external capacitance for its operation. Place 0.1 $\mu F$ ceramic capacitors across $V_{cap1}$ and $V_{cap2}$ , and from each $V_{LLx}$ pin to ground. ## 41.4.4.1 LCD power supply configuration The LCD bias voltages can be internally derived from: - V<sub>DD</sub> - A voltage source connected to VLL3. This voltage source must not be externally driven to any level other than VDD. - Internally derived from a regulated voltage source that can be configured to supply $1.0~V~(V_{IREG})$ Table 41-38 provides a more detailed description of the power state of SLCD that depends on the configuration of the GCR[VSUPPLY], GCR[CPSEL] and GCR[RVEN] bits. The table shows all possible configurations of the LCD power supply. All other combinations of the configuration bits above are not permissible LCD power supply modes and must be avoided. Table 41-38. LCD power supply options | LCD operational state | LCD power supply configuration | VSUPPLY | CPSEL | RVEN | |----------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|-------|------| | V <sub>LL3</sub> connected to V <sub>DD</sub> internally | For 3 V glass operation, V <sub>DD</sub> must be in valid range for contrast desired for display. Charge pump is used to generate V <sub>LL1</sub> and V <sub>LL2</sub> . | 0 | 1 | 0 | | V <sub>LL3</sub> is driven externally | For 3 V glass operation, V <sub>LL3</sub> must be in valid range for contrast desired on the display. Charge pump is used to generate V <sub>LL1</sub> and V <sub>LL2</sub> . | 1 | 1 | 0 | | V <sub>LL3</sub> is driven externally<br>Resistor bias network<br>enabled. | For 3 V glass operation V <sub>LL3</sub> must be in valid range for contrast desired on the display. Charge pump is disabled. Resistor bias network is used to create V <sub>LL1</sub> and V <sub>LL2</sub> . | 1 | 0 | 0 | Table continues on the next page... Table 41-38. LCD power supply options (continued) | LCD operational state | LCD power supply configuration | VSUPPLY | CPSEL | RVEN | |--------------------------------------|------------------------------------------------------------------------------------------------------------------|---------|-------|------| | $V_{IREG}$ is connected to $V_{LL1}$ | For 3 V glass operation,, V <sub>IREG</sub> = 1 V. V <sub>IREG</sub> may be adjusted to achieve desired contrast | | | | | | $V_{IREG}$ is connected to $V_{LL1}$ internally. | 1 | 1 | 1 1 | | | Charge pump is used to generate $V_{LL2}$ and $V_{LL3}$ . | | | | ## 41.4.4.1.1 LCD external power supply, VSUPPLY = 1 When VSUPPLY = 1, powersw2is deasserted. $V_{DD}$ is not available to power SLCD internally, so an alternate (internal RBIAS or external) power source is required for $V_{LL1}$ , $V_{LL2}$ , and $V_{LL3}$ when the charge pump is disabled. If the charge pump is enabled, external power must be applied to $V_{LL3}$ , $V_{LL2}$ , or $V_{LL1}$ ; or internal power applied to $V_{LL1}$ through the $V_{IREG}$ . If $V_{LL3}$ is applied externally, it MUST be equal to $V_{DD}$ .. With this configuration, the charge pump generates the other LCD bias voltages not provided internally or externally. ## Internal VIREG If the charge pump is enabled, the internal regulated voltage, $V_{IREG}$ , can be used as an input to generate the LCD bias voltages. In this state, the external voltage source must not be connected to $V_{LL1}$ , $V_{LL2}$ , or $V_{LL3}$ . $V_{IREG}$ is controlled by the LCD general control register (GCR). Figure 41-32 shows that $V_{IREG}$ is connected to $V_{LL1}$ when the RVEN bit is set. $V_{LL1}$ is connected to the internal charge pump. Using the charge pump, the value of $V_{LL1}$ is tripled and output as $V_{LL3}$ . $V_{IREG}$ should be adjusted so that $V_{LL3}$ is in an acceptable range for the desired contrast on the glass. .GCR contains trim bits that can be used to make changes to the regulated voltage so that contrast can be adjusted as desired. The trim can be used to increase or decrease the regulated voltage by 1.5% for each count. A total of $\pm 12\%$ of change can be done to the regulated voltage. The following table shows the selected LCD bias voltages $V_{LL1}$ , $V_{LL2}$ , and $V_{LL3}$ values based on the value of $V_{IRFG}$ . ## 41.4.4.1.2 LCD internal power supply, VSUPPLY = 0 $V_{DD}$ is used as the SLCD power supply when VSUPPLY = 0. When powering SLCD using $V_{DD}$ , the charge pump must be enabled (GCR[CPSEL] = 1). When VSUPPLY = 0, $V_{DD}=V_{LL3}$ and $V_{DD}$ should be kept in a range that supports the desired contrast on the glass. ## **41.4.5** Resets During a reset, SLCD is configured in Default mode. Default mode includes the following settings: - GCR[LCDEN] is cleared, thereby forcing all front plane and back plane driver outputs to the high impedance state. - 1/4 duty - 1/3 bias - LCLK[2:0], VSUPPLY , CPSEL, RVEN, and BRATE[2:0] revert to their reset values; $V_{LL3}$ is internally connected to $V_{DD}$ # 41.4.6 Interrupts When an SLCD frame-frequency interrupt event occurs, the AR[LCDIF] bit is asserted. It remains asserted until software clears the SLCD frame frequency interrupt. The interrupt can be cleared by software writing a 1 to the LCDIF bit. The SLCD frame frequency interrupt is not available in all low-power modes. If both the AR[LCDIF] bit and the GCR[LCDIEN] bit are set, an LCD interrupt signal asserts. When a fault detection complete event occurs, FDSR[FDCF] bit is set. The FDSR[FDCF] bit remains asserted until software writes 1 to clear. If both FDSR[FDCF] and GCR[FDCIEN] bits are set, an LCD interrupt signal is asserted. # 41.4.7 LCD display fault detect circuit (LFD) Most failures, where an LCD segment is either unexpectedly on or off, result in erroneous information that can mislead a user and cause a dangerous situation. The LCD display fault detect circuit's (LFD) function finds faults in the LCD display, display connector, and board connections between the MCU and the display. The LCD panel can be regarded as a matrix of segments, as shown in Figure 41-33, Figure 41-34, and Figure 41-35. Any open/short connection changes the capacitive characteristics of the segment matrix. The pullup fault detection checks the capacitive characteristic of an LCD\_Pn pin by applying a weak pullup voltage to the display capacitor matrix. The rise time response is sampled and summed within a user-defined time frame and stored for postprocessing in FDSR[FDCNT]. The summing of the digitized values uses the principle that the response of a capacitor for each charge/ discharge is constant for the same loading conditions. Figure 41-33. Pullup fault detect in connection/segment normal case If there's any open case in connection or panel, the $C_{\mbox{segments will be}}$ come smaller, which makes the pullup time shorter. Figure 41-34. Pullup fault detect in connection/segment open case If there's any short case between BP and FP, V<sub>pad wi</sub>ll be shortened to V<sub>SS and</sub> never be pulled up. Figure 41-35. Pullup fault detect in connection/segment short case This circuit works by measuring the capacitance of the LCD front plane or back plane connection and comparing it to a reference number. This reference number is usually measured at the user's production facility (by this circuit) and stored in flash memory for later comparison. The comparison must account for fluctuations due to temperature, voltage, and other environmental effects. Intelligent software may be able to account for these effects more accurately by using time-dependent algorithms; but the basic comparison to a factory-measured number should be sufficient for most applications. This circuit can measure the following: • Front plane or back plane rise time response changes, including pad, pin, board, and all pixels connected to the measured front plane or back plane. 895 - Short-circuits in the front plane or back plane connection (all silicon or board locations), see Figure 41-35. - Excessive leakage in the front plane or back plane connection (silicon or board). - Supply connectivity through the driver for the V<sub>SS</sub> level. - Opens in the front plane or back plane connection (bondwire, package, silicon, or board), see Figure 41-35. The purpose of this circuit is not to: - Measure independent pixel capacitances. - Measure voltage levels or contrast. - Measure the open connections between the front plane/back plane and the $V_{LL1}$ , $V_{LL2}$ , and $V_{LL3}$ drivers. If there is any open case in connection or panel, $C_{\text{segments}}$ becomes smaller, which changes the rise time response. Pullup fault detection can be performed while LCDEN is asserted. - 1. Set the target pin number by writing FDCR[FDPINID[5:0]]. - 2. Set FDCR[FDBPEN] if the target pin is working as back plane, or set FDCR[FDBPEN] as 0 if the target pin is working as front plane. - 3. Select the sample clock frequency by setting FDCR[FDPRS[2:0]]. - 4. Set the sample window by writing to FDCR[FDSWW[2:0]]. - 5. Enable detection by writing 1 to FDCR[FDEN]. - 6. Wait until the FDSR[FDCF] bit is asserted (by polling or by interrupt). - 7. Read FDSR[FDCNT]. - 8. Write 1 to clear FSCR[FDCF]. Figure 41-36. Pullup fault detection timing diagram, while FDBPEN is 0 Figure 41-37. Pullup fault detection timing diagram, while FDBPEN is 1 #### **Note** The voltage waveforms applied to the LCD electrodes must have no DC component. Therefore, a reversed pullup voltage waveform must be applied before the pullup detect waveform. Fault detection occupies one frame and the pullup time is half-frame duration. You must ensure that the fault detection window set by the sample window width is less than half-frame duration. ## 41.5 Initialization section This section provides a recommended initialization sequence for the LCD controller and also includes initialization examples for several LCD application scenarios. # 41.5.1 Initialization sequence The list below provides a recommended initialization sequence for the LCD controller. You must write to all PEN, BPEN, and WFyTOx registers to initialize their values after a reset. #### 1. GCR - a. Configure LCD clock source (SOURCE bit). - b. Enable regulated voltage (RVEN). - c. Trim the regulated voltage (RVTRIM). - d. Enable charge pump (CPSEL bit). - e. Configure charge pump clock (LADJ[1:0]). - f. Configure LCD power supply (VSUPPLY). - g. Configure LCD frame frequency interrupt (LCDIEN bit). - h. Configure LCD behavior in low-power mode (LCDDOZE and LCDSTP bits). - i. Configure LCD duty cycle (DUTY[2:0]). - j. Select and configure LCD frame frequency (LCLK[2:0]). #### 2. AR - a. Configure display mode (ALT and BLANK bits). - b. Configure blink mode (BMODE). - c. Configure blink frequency (BRATE[2:0]). #### 3. PENn a. Enable LCD controller pins (PEN[63:0] bits). #### 4. BPENn a. Enable LCD pins to operate as an LCD back plane (BPEN[63:0]). ## 5. WFyTOx a. Initialize WFyTOx registers with back plane configuration and an initial display screen. #### 6. GCR a. Enable LCD controller (LCDEN bit). # 41.5.2 Initialization examples This section provides initialization information for LCD configuration. Each example details the register and field values required to achieve the appropriate LCD configuration for a given LCD application scenario. Table 41-39 lists each example and the setup requirements. | | Example | Operating voltage, | LCD clock<br>source | LCD<br>glass<br>operating<br>voltage | Required<br>LCD<br>segments | LCD<br>frame<br>rate | Blinking mode/<br>rate | Behavior in<br>Wait/Stop<br>modes | LCD power input | |---|---------|--------------------|---------------------|--------------------------------------|-----------------------------|----------------------|------------------------|-----------------------------------|--------------------------------------| | Ī | 1 | 2.7 V | External | 3 V | 128 | 30 Hz | None | Wait: on | Power via | | | | | 32.768 kHz | | | | | Stop: on | external<br>resistor bias<br>network | Table 41-39. LCD application scenario These examples illustrate the flexibility of SLCD to be configured to meet a wide range of application requirements, including: - Clock inputs/sources - LCD power supply #### mualization section - LCD glass operating voltage - LCD segment count - Varied blink modes/frequencies - LCD frame rate # 41.5.2.1 Initialization example 1 Table 41-40. LCD setup requirements for example 1 | Example | Operating voltage, | LCD<br>clock<br>source | LCD<br>glass<br>operating<br>voltage | Required<br>LCD<br>segments | LCD<br>frame<br>rate | Blinking mode/rate | Behavior<br>in Stop<br>and Wait<br>modes | LCD<br>power<br>input | |---------|--------------------|------------------------|--------------------------------------|-----------------------------|----------------------|--------------------|------------------------------------------|-----------------------------------------| | 1 | 2.7 V | External | 3 V | 128 | 30 Hz | None | Wait: on | Power via | | | | 32.768 kHz | | | | | Stop: on | External<br>resistor<br>bias<br>network | Table 41-41 lists the setup values required to initialize the LCD as specified by example 1: ## Table 41-41. Initialization register values for example 1 | Register | Field | Binary<br>value | Comment | | |-----------|-------------|-----------------|----------------------------------------------------------------------------------------------------------------------------|--| | GCR | CPSEL | 0 | Disable charge pump. | | | | LADJ[1:0] | XX | Adjust the resistor bias network for different LCD glass capacitance. | | | | | | or | | | | | | Configure LCD charge pump clock source. | | | | VSUPPLY | 1 | When VSUPPLY = 1 and CPSEL = 0, the LCD must be externally powered via V <sub>LL3</sub> (see Table 41-38). | | | | LCDIEN | 0 | LCD frame interrupts disabled. | | | | LCDDOZE | 1 | LCD is "on" in Wait mode. | | | | LCDSTP | 1 | LCD is "on" in Stop mode. | | | | LCDEN | 0 | Initialization is done before initializing the LCD controller. | | | | SOURCE | 0 | Selects the external clock reference as the LCD clock input. | | | | LCLK[2:0] | 101 | For 1/8 duty cycle, select closest value to the desired 30 Hz LCD frame frequency (see Table 41-31). | | | | DUTY[2:0] | 111 | For 128 segments (8x16), select 1/8 duty cycle. | | | | RVEN | 0 | V <sub>IREG</sub> is not used for this configuration. | | | | RVTRIM[3:0] | XXXX | Trim value may be adjusted to achieve desired contrast. For a given voltage, trim value is determined by characterization. | | | AR | BLINK | 0 | No blinking. | | | | ALT | X | Alternate bit is configured during LCD operation. | | | | BLANK | Х | Blank bit is configured during LCD operation. | | | | BMODE | X | N/A; Blink Blank = 0; Blink Alternate = 1 | | | | BRATE[2:0] | XXX | N/A | | | PEN[3:0] | PEN0 | 11111111 | Only 29 LCD pins need to be enabled. | | | | PEN1 | 11111111 | Note: Any of the 63 LCD pins can be used, this allows flexibility in | | | | PEN2 | 11111111 | hardware design. | | | | PEN3 | 00000000 | | | | BPEN[3:0] | BPEN0 | 11111111 | Eight back plane pins needed. | | | | BPEN1 | 00000000 | Note: Any LCD pin can be enabled to operate as a back plane. | | | | BPEN2 | 00000000 | | | | | BPEN3 | 00000000 | | | | WFyTOx | WF0 | 00000001 | Configure which phase the eight back plane pins are active in. This | | | | WF1 | 00000010 | configuration sets LCD_P0 to be active in Phase A, LCD_P1 to be active in Phase B, and so on. | | | | WF2 | 00000100 | · | | | | WF3 | 00001000 | This configuration sets LCD pins 0–7 to represent back plane 1–8. | | | | WF4 | 00010000 | Note: Any back plane pin can be active in any phase. | | | | WF5 | 00100000 | | | | | WF6 | 01000000 | | | | | WF7 | 10000000 | | | ## 41.6 Application information Figure 41-38 is a programmer's model of SLCD. The programmer's model groups the SLCD register fields into functional groups. The model is a high-level illustration of SLCD showing the module's functional hierarchy including initialization and runtime control. Figure 41-38. LCD programmer's model diagram ## 41.6.1 LCD seven segment example description A description of the connection between SLCD and a seven segment LCD character is illustrated in Figure 41-39 to provide a basic example for a 1/3 duty cycle LCD implementation. The example uses three back plane pins (LCD\_P3, LCD\_P4, and LCD\_P5) and three front plane pins (LCD\_P0, LCD\_P1, and LCD\_P2). The contents of the WFyTOx registers and output waveforms are also shown. Output waveforms are illustrated in the following two figures. #### **Application information** Front plane connection Back plane connection a BP0 (a, b COMMONED) BP1 (c, f, g COMMONED) FP2 (b, c COMMONED) FP1 (a, d, g COMMONED) FP0 (e, f COMMONED) The above segment assignments are provided by the specification for the LCD glass for this example. For this LCD controller any of the LCD pins can be configured to be front plane 0-2 or back plane 0-2. For this example, set LCD\_P0 as FP0, LCD\_P1 as FP1, and LCD\_P2 as FP2. For this example, set LCD\_P3 as BP0, LCD\_P4 as BP1 and LCD\_P5 as BP2. Back plane assignment is done in the LCD waveform registers as shown below: | WF3 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | |-----|---|---|---|---|---|---|---|---| | WF4 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | | WF5 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | With the above conditions the segment assignment is shown below: To display the character "4": WF0 = XXXXX01X, WF1 = XXXXX010, WF2 = XXXXXX11 X = don't care Figure 41-39. Waveform output from WFyTOx registers #### 41.6.1.1 LCD controller waveforms Figure 41-40. LCD waveforms ## 41.6.1.2 Segment on driving waveform The voltage waveform across the "f" segment of the LCD (between LCD\_P4/BP1 and LCD\_P0/FP0) is illustrated in Figure 41-41. As shown in the waveform, the voltage level reaches the value $V_3$ — therefore, the segment will be on. **Application information** Figure 41-41. "f" segment voltage waveform ## 41.6.1.3 Segment off driving waveform The voltage waveform across the "e" segment of the LCD (between LCD\_P5/BP2 and LCD\_P0/FP0) is illustrated in Figure 41-42. As shown in the waveform, the voltage does not reach the voltage V<sub>3</sub> threshold — therefore the segment will be off. Figure 41-42. "e" segment voltage waveform ## 41.6.2 LCD contrast control Contrast control for SLCD is achieved when the LCD power supply is adjusted to a value greater than or less than the LCD threshold voltage. The LCD threshold voltage is the nominal voltage required to energize the LCD segments. For 3 V LCD glass, the LCD threshold voltage is usually about 3 V. Increasing the value of the LCD voltage makes the energized segments on the LCD glass become more opaque. Decreasing the value of the LCD voltage makes the energized segments on the LCD glass become more transparent. The LCD power supply can be adjusted to facilitate contrast control by using the internal regulator $V_{IREG}$ and adjusting its trim (RVTRIM), or for more extreme contrast control, by using external components like a variable resistor. #### Chapter 41 LCD Controller (SLCD) #### LCD GLASS PANEL NOTE: LCD\_P[28:8] Contrast control configuration when LCD is powered using internal $V_{DD}$ LCD\_P[7:0] $\rm V_{\rm DD~iS}$ specified between 2.7 and 5.5V Power supply IC LCD power pins $V_{LL3}$ $V_{LL2}$ $V_{\underline{L}\underline{L}\underline{1}}$ $V_{\text{DD}}$ $C_{BYLCD} = 0.1 \mu F$ $\overline{V}_{cap2}$ $V_{cap1}$ —||— 0.1 μF $\mathsf{C}_\mathsf{LCD}$ Figure 41-43. Power connections for contrast control Application information # **Chapter 42 General-Purpose Input/Output (GPIO)** ### 42.1 Introduction #### **NOTE** For the chip-specific implementation details of this module's instances, see the chip configuration information. The general-purpose input and output (GPIO) module communicates to the processor core via a zero wait state interface (IOPORT) for maximum pin performance. The GPIO registers support 8-bit, 16-bit or 32-bit accesses. The GPIO data direction and output data registers control the direction and output data of each pin when the pin is configured for the GPIO function. The GPIO input data register displays the logic value on each pin when the pin is configured for any digital function, provided the corresponding Port Control and Interrupt module for that pin is enabled. ## 42.1.1 Features - Features of the GPIO module include: - Port Data Input register visible in all digital pin-multiplexing modes - Port Data Direction register - Zero wait state access to GPIO registers through IOPORT #### NOTE The GPIO module is clocked by system clock. ## 42.1.2 Modes of operation The following table depicts different modes of operation and the behavior of the GPIO module in these modes. KM Family Reference Manual, Rev. 5, Oct 2013 909 Table 42-1. Modes of operation | Modes of operation | Description | |--------------------|------------------------------------| | Run | The GPIO module operates normally. | | Wait | The GPIO module operates normally. | | Stop | The GPIO module is disabled. | | Debug | The GPIO module operates normally. | ## 42.1.3 GPIO signal descriptions Table 42-2. GPIO signal descriptions | GPIO signal descriptions | Description | I/O | |--------------------------|------------------------------|-----| | PORTA7-PORTA0 | General-purpose input/output | I/O | | PORTB7-PORTB0 | General-purpose input/output | I/O | | PORTC7-PORTC0 | General-purpose input/output | I/O | | PORTD7-PORTD0 | General-purpose input/output | I/O | | PORTE7-PORTE0 | General-purpose input/output | I/O | | PORTF7-PORTF0 | General-purpose input/output | I/O | | PORTG7-PORTG0 | General-purpose input/output | I/O | | PORTH7-PORTH0 | General-purpose input/output | I/O | | PORTI7-PORTI0 | General-purpose input/output | I/O | #### NOTE Not all pins within each port are implemented on each device. See the chapter on signal multiplexing for the number of GPIO ports available in the device. #### **NOTE** PORT H6 and H7 are open drain. PORTI1 is open drain ## 42.1.3.1 Detailed signal description #### Table 42-3. GPIO interface-detailed signal descriptions | Signal | I/O | Description | | | | |---------------|-------------------------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | PORTA7-PORTA0 | PORTA7-PORTA0 I/O Gener | | urpose input/output | | | | PORTB7-PORTB0 | | State meaning | Asserted: The pin is logic 1. | | | | PORTC7-PORTC0 | | | Deasserted: The pin is logic 0. | | | | PORTD7-PORTD0 | | Timing | Assertion: When output, this | | | | PORTE7-PORTE0 | | | signal occurs on the rising-<br>edge of the system clock. For | | | | PORTF7-PORTF0 | | | input, it may occur at any time | | | | PORTG7-PORTG0 | | | and input may be asserted asynchronously to the system | | | | PORTH7-PORTH0 | | | clock. | | | | PORTI7-PORTI0 | | | Deassertion: When output, this signal occurs on the rising-edge of the system clock. For input, it may occur at any time and input may be asserted asynchronously to the system clock. | | | ## 42.2 Memory map and register definition Any read or write access to the GPIO memory space that is outside the valid memory map results in a bus error. #### **GPIO** memory map | Absolute<br>address<br>(hex) | Register name | Width<br>(in bits) | Access | Reset value | Section/<br>page | |------------------------------|----------------------------------------------|--------------------|--------|-------------|------------------| | 400F_F000 | Port Data Output Register (GPIOA_PDOR) | 8 | R/W | 00h | 42.2.1/912 | | 400F_F010 | Port Data Input Register (GPIOA_PDIR) | 8 | R | 00h | 42.2.2/913 | | 400F_F014 | Port Data Direction Register (GPIOA_PDDR) | 8 | R/W | 00h | 42.2.3/913 | | 400F_F01C | GPIO Attribute Checker Register (GPIOA_GACR) | 8 | R/W | 00h | 42.2.4/914 | | 400F_F001 | Port Data Output Register (GPIOB_PDOR) | 8 | R/W | 00h | 42.2.1/912 | | 400F_F011 | Port Data Input Register (GPIOB_PDIR) | 8 | R | 00h | 42.2.2/913 | | 400F_F015 | Port Data Direction Register (GPIOB_PDDR) | 8 | R/W | 00h | 42.2.3/913 | | 400F_F01D | GPIO Attribute Checker Register (GPIOB_GACR) | 8 | R/W | 00h | 42.2.4/914 | | 400F_F002 | Port Data Output Register (GPIOC_PDOR) | 8 | R/W | 00h | 42.2.1/912 | | 400F_F012 | Port Data Input Register (GPIOC_PDIR) | 8 | R | 00h | 42.2.2/913 | | 400F_F016 | Port Data Direction Register (GPIOC_PDDR) | 8 | R/W | 00h | 42.2.3/913 | | 400F_F01E | GPIO Attribute Checker Register (GPIOC_GACR) | 8 | R/W | 00h | 42.2.4/914 | | 400F_F003 | Port Data Output Register (GPIOD_PDOR) | 8 | R/W | 00h | 42.2.1/912 | Table continues on the next page... #### **GPIO** memory map (continued) | Absolute address (hex) | Register name | Width<br>(in bits) | Access | Reset value | Section/<br>page | |------------------------|----------------------------------------------|--------------------|--------|-------------|------------------| | 400F_F013 | Port Data Input Register (GPIOD_PDIR) | 8 | R | 00h | 42.2.2/913 | | 400F_F017 | Port Data Direction Register (GPIOD_PDDR) | 8 | R/W | 00h | 42.2.3/913 | | 400F_F01F | GPIO Attribute Checker Register (GPIOD_GACR) | 8 | R/W | 00h | 42.2.4/914 | | 400F_F040 | Port Data Output Register (GPIOE_PDOR) | 8 | R/W | 00h | 42.2.1/912 | | 400F_F050 | Port Data Input Register (GPIOE_PDIR) | 8 | R | 00h | 42.2.2/913 | | 400F_F054 | Port Data Direction Register (GPIOE_PDDR) | 8 | R/W | 00h | 42.2.3/913 | | 400F_F05C | GPIO Attribute Checker Register (GPIOE_GACR) | 8 | R/W | 00h | 42.2.4/914 | | 400F_F041 | Port Data Output Register (GPIOF_PDOR) | 8 | R/W | 00h | 42.2.1/912 | | 400F_F051 | Port Data Input Register (GPIOF_PDIR) | 8 | R | 00h | 42.2.2/913 | | 400F_F055 | Port Data Direction Register (GPIOF_PDDR) | 8 | R/W | 00h | 42.2.3/913 | | 400F_F05D | GPIO Attribute Checker Register (GPIOF_GACR) | 8 | R/W | 00h | 42.2.4/914 | | 400F_F042 | Port Data Output Register (GPIOG_PDOR) | 8 | R/W | 00h | 42.2.1/912 | | 400F_F052 | Port Data Input Register (GPIOG_PDIR) | 8 | R | 00h | 42.2.2/913 | | 400F_F056 | Port Data Direction Register (GPIOG_PDDR) | 8 | R/W | 00h | 42.2.3/913 | | 400F_F05E | GPIO Attribute Checker Register (GPIOG_GACR) | 8 | R/W | 00h | 42.2.4/914 | | 400F_F043 | Port Data Output Register (GPIOH_PDOR) | 8 | R/W | 00h | 42.2.1/912 | | 400F_F053 | Port Data Input Register (GPIOH_PDIR) | 8 | R | 00h | 42.2.2/913 | | 400F_F057 | Port Data Direction Register (GPIOH_PDDR) | 8 | R/W | 00h | 42.2.3/913 | | 400F_F05F | GPIO Attribute Checker Register (GPIOH_GACR) | 8 | R/W | 00h | 42.2.4/914 | | 400F_F080 | Port Data Output Register (GPIOI_PDOR) | 8 | R/W | 00h | 42.2.1/912 | | 400F_F090 | Port Data Input Register (GPIOI_PDIR) | 8 | R | 00h | 42.2.2/913 | | 400F_F094 | Port Data Direction Register (GPIOI_PDDR) | 8 | R/W | 00h | 42.2.3/913 | | 400F_F09C | GPIO Attribute Checker Register (GPIOI_GACR) | 8 | R/W | 00h | 42.2.4/914 | ## 42.2.1 Port Data Output Register (GPIOx\_PDOR) This register configures the logic levels that are driven on each general-purpose output pins. #### **NOTE** Do not modify pin configuration registers associated with pins not available in your selected package. All un-bonded pins not available in your package will default to DISABLE state for lowest power consumption. Address: Base address + 0h offset #### GPIOx\_PDOR field descriptions | Field | Description | |------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7–0<br>PDO | Port Data Output Unimplemented pins for a particular device read as zero. | | | <ul> <li>Logic level 0 is driven on pin, provided pin is configured for general-purpose output.</li> <li>Logic level 1 is driven on pin, provided pin is configured for general-purpose output.</li> </ul> | ## 42.2.2 Port Data Input Register (GPIOx\_PDIR) #### **NOTE** Do not modify pin configuration registers associated with pins not available in your selected package. All un-bonded pins not available in your package will default to DISABLE state for lowest power consumption. #### **GPIOx\_PDIR** field descriptions | Field | Description | |------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7–0<br>PDI | Port Data Input | | | Reads 0 at the unimplemented pins for a particular device. Pins that are not configured for a digital function read 0. If the Port Control and Interrupt module is disabled, then the corresponding bit in PDIR does not update. | | | <ul><li>0 Pin logic level is logic 0, or is not configured for use by digital function.</li><li>1 Pin logic level is logic 1.</li></ul> | ## 42.2.3 Port Data Direction Register (GPIOx\_PDDR) The PDDR configures the individual port pins for input or output. #### Address: Base address + 14h offset #### memory map and register definition #### **GPIOx\_PDDR** field descriptions | Field | Description | |-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | PDD | Port Data Direction Configures individual port pins for input or output. 0 Pin is configured as general-purpose input, for the GPIO function. 1 Pin is configured as general-purpose output, for the GPIO function. | ## 42.2.4 GPIO Attribute Checker Register (GPIOx\_GACR) The GPIO module supports a device-specific number of data ports #### NOTE GPIO supports single-cycle accesses from the processor core IOPORT bus as well as references from the PBRIDGE-mapped address space. Since the core's IOPORT does not support any type of bus stalls or error terminations, if an IOPORT access fails the attribute checks, it is treated as a RAZ/WI access, that is, reads-as-zero and writes ignored. GPIO GACRn register is checked for PBRDIGE accesses only if the corresponding PACRn register allowed the reference. The appropriate PACRn controls access rights to the entire GPIO address space, while the GACRn registers define the access rights down to the byte level for the actual data ports. #### **GPIOx\_GACR** field descriptions | Field | Description | |-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7<br>ROB | Read-Only Byte | | | This register bit provides a mechanism to "lock" the configuration state defined by ACB. Once asserted, this bit remains set and attempted writes to the ACB are ignored until the next system reset clears the flag. | | | 0 Writes to the ACB are allowed. | | | 1 Writes to the ACB are ignored. | | 6–3<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | Table continues on the next page... #### **GPIOx\_GACR** field descriptions (continued) | Field | Description | | | | |-------|-------------------------------------------------------------------------------------------------------------|--|--|--| | 2–0 | Attribute Check Byte | | | | | ACB | This 3 bit field defines the attributes required to access the corresponding GPIO port's programming model. | | | | | | 000 User nonsecure: Read + Write; User Secure: Read + Write; Privileged Secure: Read + Write | | | | | | 001 User nonsecure: Read; User Secure: Read + Write; Privileged Secure: Read + Write | | | | | | 010 User nonsecure: None; User Secure: Read + Write; Privileged Secure: Read + Write | | | | | | 011 User nonsecure: Read; User Secure: Read; Privileged Secure: Read + Write | | | | | | 100 User nonsecure: None; User Secure: Read; Privileged Secure: Read + Write | | | | | | 101 User nonsecure: None; User Secure: None; Privileged Secure: Read + Write | | | | | | 110 User nonsecure: None; User Secure: None; Privileged Secure: Read | | | | | | 111 User nonsecure: None; User Secure: None; Privileged Secure: None | | | | ## 42.3 Functional description ## 42.3.1 General-purpose input The logic state of each pin is available via the Port Data Input registers, provided the pin is configured for a digital function and the corresponding Port Control and Interrupt module is enabled. The Port Data Input registers return the synchronized pin state after any enabled digital filter in the Port Control and Interrupt module. The input pin synchronizers are shared with the Port Control and Interrupt module, so that if the corresponding Port Control and Interrupt module is disabled, then synchronizers are also disabled. This reduces power consumption when a port is not required for general-purpose input functionality. ## 42.3.2 General-purpose output The logic state of each pin can be controlled via the port data output registers and port data direction registers, provided the pin is configured for the GPIO function. The following table depicts the conditions for a pin to be configured as input/output. | If | Then | |------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------| | A pin is configured for the GPIO function and the corresponding port data direction register bit is clear. | The pin is configured as an input. | | A pin is configured for the GPIO function and the corresponding port data direction register bit is set. | The pin is configured as an output and and the logic state of the pin is equal to the corresponding port data output register. | #### runctional description The corresponding Port Control and Interrupt module does not need to be enabled to update the state of the port data direction registers and port data output registers. ## **Chapter 43 Bit Manipulation Engine (BME)** #### 43.1 Introduction The Bit Manipulation Engine (BME) provides hardware support for atomic read-modify-write memory operations to the peripheral address space in Cortex-M0+ based microcontrollers. This architectural capability is also known as "decorated storage" as it defines a mechanism for providing additional semantics for load and store operations to memory-mapped peripherals beyond just the reading and writing of data values to the addressed memory locations. In the BME definition, the "decoration", that is, the additional semantic information, is encoded into the peripheral address used to reference the memory. By combining the basic load and store instructions of the ARM Cortex-M instruction set architecture (v6M, v7M) with the concept of decorated storage provided by the BME, the resulting implementation provides a robust and efficient read-modify-write capability to this class of ultra low-end microcontrollers. The resulting architectural capability defined by this core platform function is targeted at the manipulation of n-bit fields in peripheral registers and is consistent with I/O hardware addressing in the Embedded C standard. For most BME commands, a single core read or write bus cycle is converted into an atomic read-modify-write, that is, an indivisible "read followed by a write" bus sequence. BME decorated references are only available on system bus transactions generated by the processor core and targeted at the standard 512 KB peripheral address space based at $0x4000\_0000^1$ . The decoration semantic is embedded into address bits[28:19], creating a 448 MB space at addresses $0x4400\_0000\_0x5FFF\_FFFF$ for AIPS; these bits are stripped out of the actual address sent to the peripheral bus controller and used by the BME to define and control its operation. To be perfectly accurate, the peripheral address space occupies a 516 KB region: 512 KB based at 0x4000\_0000 plus a 4 KB space based at 0x400F\_F000 for GPIO accesses. This organization provides compatibility with the Kinetis K Family. Attempted accesses to the memory space located between 0x4008\_0000 - 0x400F\_EFFF are error terminated due to an illegal address. #### 43.1.1 Overview The following figure is a generic block diagram of the processor core and platform for this class of ultra low-end microcontrollers. Figure 43-1. Cortex-M0+ core platform block diagram As shown in the block diagram, the BME module interfaces to a switch AHB slave port as its primary input and sources an AHB bus output to the Peripheral Bridge (PBRIDGE) controller. The BME hardware microarchitecture is a 2-stage pipeline design matching the protocol of the AMBA-AHB system bus interfaces. The PBRIDGE module converts the AHB system bus protocol into the IPS/APB protocol used by the attached slave peripherals. #### 43.1.2 Features The key features of the BME include: - Lightweight implementation of decorated storage for selected address spaces - Additional access semantics encoded into the reference address - Resides between a switch slave port and a peripheral bridge bus controller - Two-stage pipeline design matching the AHB system bus protocol - Combinationally passes non-decorated accesses to peripheral bridge bus controller - Conversion of decorated loads and stores from processor core into atomic readmodify-writes - Decorated loads support unsigned bit field extracts, load-and-{set,clear} 1-bit operations - Decorated stores support bit field inserts, logical AND, OR, and XOR operations - Support for byte, halfword and word-sized decorated operations - Supports minimum signal toggling on AHB output bus to reduce power dissipation ## 43.1.3 Modes of operation The BME module does not support any special modes of operation. As a memory-mapped device located on a crossbar slave AHB system bus port, BME responds strictly on the basis of memory addresses for accesses to the peripheral bridge bus controller. All functionality associated with the BME module resides in the core platform's clock domain; this includes its connections with the crossbar slave port and the PBRIDGE bus controller. ## 43.2 Memory map and register definition The BME module provides a memory-mapped capability and does not include any programming model registers. The exact set of functions supported by the BME are detailed in the Functional description. The peripheral address space occupies a 516 KB region: 512 KB based at 0x4000\_0000 plus a 4 KB space based at 0x400F\_F000 for GPIO accesses; the decorated address space is mapped to the 448 MB region located at 0x4400\_0000-0x5FFF\_FFFF. ## 43.3 Functional description Information found here details the specific functions supported by the BME. Recall the combination of the basic load and store instructions of the Cortex-M instruction set architecture (v6M, v7M) plus the concept of decorated storage provided by the BME, the resulting implementation provides a robust and efficient read-modify-write capability to this class of ultra low-end microcontrollers. The resulting architectural capability defined by this core platform function is targeted at the manipulation of n-bit fields in peripheral registers and is consistent with I/O hardware addressing in the Embedded C standard. For most BME commands, a single core read or write bus cycle is converted into an atomic read-modify-write, that is, an indivisible "read followed by a write" bus sequence. Consider decorated store operations first, then decorated loads. #### 43.3.1 BME decorated stores The functions supported by the BME's decorated stores include three logical operators (AND, OR, XOR) plus a bit field insert. For all these operations, BME converts a single decorated AHB store transaction into a 2-cycle atomic read-modify-write sequence, where the combined read-modify operation is performed in the first AHB data phase, and then the write is performed in the second AHB data phase. A generic timing diagram of a decorated store showing a peripheral bit field insert operation is shown as follows: #### **Chapter 43 Bit Manipulation Engine (BME)** Figure 43-2. Decorated store: bit field insert timing diagram All the decorated store operations follow the same execution template shown in Figure 43-2, a two-cycle read-modify-write operation: - 1. Cycle x, 1st AHB address phase: Write from input bus is translated into a read operation on the output bus using the actual memory address (with the decoration removed) and then captured in a register. - 2. Cycle x+1, 2nd AHB address phase: Write access with the registered (but actual) memory address is output - 3. Cycle x+1, 1st AHB data phase: Memory read data is modified using the input bus write data and the function defined by the decoration and captured in a data register; the input bus cycle is stalled. - 4. Cycle x+2, 2nd AHB data phase: Registered write data is sourced onto the output write data bus. #### NOTE Any wait states inserted by the slave device are simply passed through the BME back to the master input bus, stalling the AHB transaction cycle for cycle. ## 43.3.1.1 Decorated store logical AND (AND) This command performs an atomic read-modify-write of the referenced memory location. - 1. First, the location is read; - 2. It is then modified by performing a logical AND operation using the write data operand sourced for the system bus cycle - 3. Finally, the result of the AND operation is written back into the referenced memory location. The data size is specified by the write operation and can be byte (8-bit), halfword (16-bit) or word (32-bit). The core performs the required write data lane replication on byte and halfword transfers. | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|----|----|----|----|----|----|----|----|----|----|----|----|------------|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| | ioandb | 0 | * | * | 0 | 0 | 1 | | | - | - | - | - | mem_addr | | | | | | | | | | | | | | | | | | | | | ioandh | 0 | * | * | 0 | 0 | 1 | | | - | - | - | - | mem_addr 0 | | | | | | 0 | | | | | | | | | | | | | | | ioandw | 0 | * | * | 0 | 0 | 1 | - | - | - | - | - | - | mem_addr 0 | | | | | 0 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Figure 43-3. Decorated store address: logical AND See Figure 43-3 where addr[30:29] = 10 for peripheral, addr[28:26] = 001 specifies the AND operation, and mem\_addr[19:0] specifies the address offset into the space based at $0x4000\_0000$ for peripherals. The "-" indicates an address bit "don't care". The decorated AND write operation is defined in the following pseudo-code as: where the operand size <sz> is defined as b(yte, 8-bit), h(alfword, 16-bit) and w(ord, 32-bit). This notation is used throughout the document. In the cycle definition tables, the notations AHB\_ap and AHB\_dp refer to the address and data phases of the BME AHB transaction. The cycle-by-cycle BME operations are detailed in the following table. | <b>Table 43-1.</b> | Cycle definitions of c | decorated store: logical AND | |--------------------|------------------------|------------------------------| |--------------------|------------------------|------------------------------| | Pipeline stage | | Cycle | | |----------------|-------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------|-------------------------------------------------| | | х | x+1 | x+2 | | BME AHB_ap | Forward addr to memory; Decode decoration; Convert master_wt to slave_rd; Capture address, attributes | Recirculate captured addr + attr to memory as slave_wt | <next></next> | | BME AHB_dp | <pre><previous></previous></pre> | Perform memory read; Form (rdata & wdata) and capture destination data in register | Perform write sending registered data to memory | ## 43.3.1.2 Decorated store logical OR (OR) This command performs an atomic read-modify-write of the referenced memory location. - 1. First, the location is read. - 2. It is then modified by performing a logical OR operation using the write data operand sourced for the system bus cycle. - 3. Finally, the result of the OR operation is written back into the referenced memory location. The data size is specified by the write operation and can be byte (8-bit), halfword (16-bit) or word (32-bit). The core performs the required write data lane replication on byte and halfword transfers. | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|----|----|----|----|----|----|----|----|----|----|----|------------|----------|----|----|----|----|----|----|----|----|------|----|----|---|---|---|---|---|---|---|---| | ioorb | 0 | * | * | 0 | 1 | 0 | 1 | - | - | - | 1 | - mem_addr | | | | | | | | | | | | | | | | | | | | | | ioorh | 0 | * | * | 0 | 1 | 0 | - | - | - | - | 1 | 1 | mem_addr | | | | | | 0 | | | | | | | | | | | | | | | ioorw | 0 | * | * | 0 | 1 | 0 | - | - | - | - | | - | | | | | | | | | m | nem_ | ad | dr | | | | | | | 0 | 0 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Figure 43-4. Decorated address store: logical OR See Figure 43-4, where addr[30:29] = 10 for peripheral, addr[28:26] = 010 specifies the OR operation, and mem\_addr[19:0] specifies the address offset into the space based at $0x4000\_0000$ for peripherals. The "-" indicates an address bit "don't care". The decorated OR write operation is defined in the following pseudo-code as: The cycle-by-cycle BME operations are detailed in the following table. runctional description Table 43-2. Cycle definitions of decorated store: logical OR | Pipeline stage | | Cycle | | |----------------|-------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------|-------------------------------------------------| | | х | x+1 | x+2 | | BME AHB_ap | Forward addr to memory; Decode decoration; Convert master_wt to slave_rd; Capture address, attributes | Recirculate captured addr + attr to memory as slave_wt | <next></next> | | BME AHB_dp | <pre><previous></previous></pre> | Perform memory read; Form (rdata I wdata) and capture destination data in register | Perform write sending registered data to memory | ## 43.3.1.3 Decorated store logical XOR (XOR) This command performs an atomic read-modify-write of the referenced memory location. - 1. First, the location is read. - 2. It is then modified by performing a logical XOR (exclusive-OR) operation using the write data operand sourced for the system bus cycle. - 3. Finally, the result of the XOR operation is written back into the referenced memory location. The data size is specified by the write operation and can be byte (8-bit), halfword (16-bit) or word (32-bit). The core performs the required write data lane replication on byte and halfword transfers. Figure 43-5. Decorated address store: logical XOR See Figure 43-5, where addr[30:29] = 10 for peripheral, addr[28:26] = 011 specifies the XOR operation, and mem\_addr[19:0] specifies the address offset into the peripheral space based at $0x4000\_0000$ for peripherals. The "-" indicates an address bit "don't care". The decorated XOR write operation is defined in the following pseudo-code as: The cycle-by-cycle BME operations are detailed in the following table. | Table 43-3. | Cycle definitions of decorated store: logical XOR | |-------------|---------------------------------------------------| |-------------|---------------------------------------------------| | Pipeline Stage | | Cycle | | |----------------|-------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------|-------------------------------------------------| | | х | x+1 | x+2 | | BME AHB_ap | Forward addr to memory; Decode decoration; Convert master_wt to slave_rd; Capture address, attributes | Recirculate captured addr + attr to memory as slave_wt | <next></next> | | BME AHB_dp | <pre><previous></previous></pre> | Perform memory read; Form (rdata ^ wdata) and capture destination data in register | Perform write sending registered data to memory | ## 43.3.1.4 Decorated store bit field insert (BFI) This command inserts a bit field contained in the write data operand, defined by LSB position (b) and the bit field width (w+1), into the memory "container" defined by the access size associated with the store instruction using an atomic read-modify-write sequence. The data size is specified by the write operation and can be byte (8-bit), halfword (16-bit) or word (32-bit). #### **NOTE** For the word sized operation, the maximum bit field width is 16 bits. The core performs the required write data lane replication on byte and halfword transfers. The BFI operation can be used to insert a single bit into a peripheral. For this case, the w field is simply set to 0, indicating a bit field width of 1. Figure 43-6. Decorated address store: bit field insert where addr[30:29] =10 for peripheral,addr[28] = 1 signals a BFI operation, addr[27:23] is "b", the LSB identifier, addr[22:19] is "w", the bit field width minus 1 identifier, and addr[18:0] specifies the address offset into the peripheral space based at 0x4000\_0000 for peripherals. The "-" indicates an address bit "don't care". Note, unlike the other decorated store operations, BFI uses addr[19] as the least significant bit in the "w" specifier and not as an address bit. #### runctional description The decorated BFI write operation is defined in the following pseudo-code as: The write data operand (wdata) associated with the store instruction contains the bit field to be inserted. It must be properly aligned within a right-aligned container, that is, within the lower 8 bits for a byte operation, the lower 16 bits for a halfword, or the entire 32 bits for a word operation. To illustrate, consider the following example of the insertion of the 3-bit field "xyz" into an 8-bit memory container, initially set to "abcd\_efgh". For all cases, w is 2, signaling a bit field width of 3. ``` if b = 0 and the decorated store (strb) Rt register[7:0] = ---- -xyz, then destination is "abcd exyz" if b = 1 and the decorated store (strb) Rt register[7:0] = ---- xyz-, then destination is "abcd xyzh" if b = 2 and the decorated store (strb) Rt register[7:0] = ---x yz--, then destination is "abcx yzgh" if b = 3 and the decorated store (strb) Rt register[7:0] = --xy z---, then destination is "abxy_zfgh" if b = 4 and the decorated store (strb) Rt register[7:0] = -xyz ----, then destination is "axyz_efgh" if b = 5 and the decorated store (strb) Rt register[7:0] = xyz-_---, then destination is "xyzd_efgh" if b = 6 and the decorated store (strb) Rt register[7:0] = yz-- ----, then destination is "yzcd efgh" if b = 7 and the decorated store (strb) Rt register[7:0] = z--- ---, then destination is "zbcd efgh" ``` Note from the example, when the starting bit position plus the field width exceeds the container size, only part of the source bit field is inserted into the destination memory location. Stated differently, if $(b + w+1) > \text{container\_width}$ , only the low-order "container\\_width - b" bits are actually inserted. The cycle-by-cycle BME operations are detailed in the following table. | Pipeline stage | | Cycle | | | | | | | | | | | |----------------|-------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------|--|--|--|--|--|--|--|--|--| | | х | x+1 | x+2 | | | | | | | | | | | ВМЕ АНВ_ар | Forward addr to memory; Decode decoration; Convert master_wt to slave_rd; Capture address, attributes | Recirculate captured addr + attr to memory as slave_wt | <next></next> | | | | | | | | | | | BME AHB_dp | <pre><previous></previous></pre> | Perform memory read; Form<br>bit mask; Form bitwise<br>((mask) ? wdata : rdata)) and<br>capture destination data in<br>register | Perform write sending registered data to memory | | | | | | | | | | Table 43-4. Cycle definitions of decorated store: bit field insert #### 43.3.2 BME decorated loads The functions supported by the BME's decorated loads include two single-bit load-and-{set, clear} operators plus unsigned bit field extracts. For the two load-and-{set, clear} operations, BME converts a single decorated AHB load transaction into a two-cycle atomic read-modify-write sequence, where the combined read-modify operations are performed in the first AHB data phase, and then the write is performed in the second AHB data phase as the original read data is returned to the processor core. For an unsigned bit field extract, the decorated load transaction is stalled for one cycle in the BME as the data field is extracted, then aligned and returned to the processor in the second AHB data phase. This is the only decorated transaction that is not an atomic read-modify-write, as it is a simple data read. A generic timing diagram of a decorated load showing a peripheral load-and-set 1-bit operation is shown as follows. Figure 43-7. Decorated load: load-and-set 1-bit field insert timing diagram #### runctional description Decorated load-and-{set, clear} 1-bit operations follow the execution template shown in the above figure: a 2-cycle read-modify-write operation: - 1. Cycle x, first AHB address phase: Read from input bus is translated into a read operation on the output bus with the actual memory address (with the decoration removed) and then captured in a register - 2. Cycle x+1, second AHB address phase: Write access with the registered (but actual) memory address is output - 3. Cycle x+1, first AHB data phase: The "original" 1-bit memory read data is captured in a register, while the 1-bit field is set or clear based on the function defined by the decoration with the modified data captured in a register; the input bus cycle is stalled - 4. Cycle x+2, second AHB data phase: The selected original 1-bit is right-justified, zero-filled and then driven onto the input read data bus, while the registered write data is sourced onto the output write data bus #### NOTE Any wait states inserted by the slave device are simply passed through the BME back to the master input bus, stalling the AHB transaction cycle for cycle. A generic timing diagram of a decorated load showing an unsigned peripheral bit field operation is shown in the following figure. Figure 43-8. Decorated load: unsigned bit field insert timing diagram The decorated unsigned bit field extract follows the same execution template shown in the above figure, a 2-cycle read operation: - Cycle x, 1st AHB address phase: Read from input bus is translated into a read operation on the output bus with the actual memory address (with the decoration removed) and then captured in a register - Cycle x+1, 2nd AHB address phase: Idle cycle - Cycle x+1, 1st AHB data phase: A bit mask is generated based on the starting bit position and the field width; the mask is AND'ed with the memory read data to isolate the bit field; the resulting data is captured in a data register; the input bus cycle is stalled - Cycle x+2, 2nd AHB data phase: Registered data is logically right-aligned for proper alignment and driven onto the input read data bus #### NOTE Any wait states inserted by the slave device are simply passed through the BME back to the master input bus, stalling the AHB transaction cycle for cycle. #### Decorated load: load-and-clear 1 bit (LAC1) 43.3.2.1 This command loads a 1-bit field defined by the LSB position (b) into the core's general purpose destination register (Rt) and zeroes the bit in the memory space after performing an atomic read-modify-write sequence. The extracted 1-bit data field from the memory address is right-justified and zero-filled in the operand returned to the core. The data size is specified by the read operation and can be byte (8-bit), halfword (16-bit) or word (32-bit). Figure 43-9. Decorated load address: load-and-clear 1 bit See Figure 43-9 where addr[30:29] = 10 for peripheral, addr[28:26] = 010 specifies the load-and-clear 1 bit operation, addr[25:21] is "b", the bit identifier, and mem\_addr[19:0] specifies the address offset into the space based at 0x4000\_0000 for peripheral. The "-" indicates an address bit "don't care". The decorated load-and-clear 1-bit read operation is defined in the following pseudo-code as: ``` rdata = iolac1<sz>(accessAddress) // decorated load-and-clear 1 = mem[accessAddress & 0xE00FFFFF, size] // memory read mask = 1 << b // generate bit mask rdata = (tmp & mask) >> b // read data returned to core = tmp & ~mask // modify mem[accessAddress & 0xE00FFFFF, size] = tmp // memory write ``` The cycle-by-cycle BME operations are detailed in the following table. Table 43-5. Cycle definitions of decorated load: load-and-clear 1 bit | Pipeline Stage | | Cycle | | |----------------|------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------| | | х | x+1 | x+2 | | BME AHB_ap | Forward addr to memory;<br>Decode decoration; Capture<br>address, attributes | Recirculate captured addr + attr to memory as slave_wt | <next></next> | | BME AHB_dp | <pre><previous></previous></pre> | Perform memory read; Form<br>bit mask; Extract bit from<br>rdata; Form (rdata & ~mask)<br>and capture destination data<br>in register | Return extracted bit to master;<br>Perform write sending<br>registered data to memory | 931 ## 43.3.2.2 Decorated Load: Load-and-Set 1 Bit (LAS1) This command loads a 1-bit field defined by the LSB position (b) into the core's general purpose destination register (Rt) and sets the bit in the memory space after performing an atomic read-modify-write sequence. The extracted one bit data field from the memory address is right justified and zero filled in the operand returned to the core. The data size is specified by the read operation and can be byte (8-bit), halfword (16-bit) or word (32-bit). Figure 43-10. Decorated load address: load-and-set 1 bit where addr[30:29] = 10 for peripheral, addr[28:26] = 011 specifies the load-and-set 1 bit operation, addr[25:21] is "b", the bit identifier, and mem\_addr[19:0] specifies the address offset into the space based at $0x4000\_0000$ for peripheral. The "-" indicates an address bit "don't care". The decorated Load-and-Set 1 Bit read operation is defined in the following pseudo-code as: The cycle-by-cycle BME operations are detailed in the following table. Table 43-6. Cycle definitions of decorated load: load-and-set 1-bit | Pipeline Stage | | Cycle | | | | | | | | | | | | |----------------|---|--------------------------------------------------------|---------------|--|--|--|--|--|--|--|--|--|--| | | х | x+1 | x+2 | | | | | | | | | | | | BME AHB_ap | | Recirculate captured addr + attr to memory as slave_wt | <next></next> | | | | | | | | | | | Table continues on the next page... **runctional description** Table 43-6. Cycle definitions of decorated load: load-and-set 1-bit (continued) | Pipeline Stage | | Cycle | | |----------------|----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------| | | х | x+1 | x+2 | | BME AHB_dp | <pre><previous></previous></pre> | Perform memory read; Form<br>bit mask; Extract bit from<br>rdata; Form (rdata I mask)<br>and capture destination data<br>in register | Return extracted bit to master;<br>Perform write sending<br>registered data to memory | ## 43.3.2.3 Decorated load unsigned bit field extract (UBFX) This command extracts a bit field defined by LSB position (b) and the bit field width (w +1) from the memory "container" defined by the access size associated with the load instruction using a two-cycle read sequence. The extracted bit field from the memory address is right-justified and zero-filled in the operand returned to the core. Recall this is the only decorated operation that does not perform a memory write, that is, UBFX only performs a read. The data size is specified by the write operation and can be byte (8-bit), halfword (16-bit) or word (32-bit). Note for the word sized operation, the maximum bit field width is 16 bits. The use of a UBFX operation is recommended to extract a single bit. For this case, the w field is simply set to 0, indicating a bit field width of 1. | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|----|----|----|----|----|----|----|----|----|----|----|----|----|------------|----|----|----|----|----|----|----|----|-----|------|---|---|---|---|---|---|---|---| | ioubfxb | 0 | * | * | 1 | - | - | b | b | b | - | w | W | W | | | | | | | | | me | m_a | addr | | | | | | | | | | ioubfxh | 0 | * | * | 1 | - | b | b | b | b | W | w | W | W | mem_addr | | | | | | | | 0 | | | | | | | | | | | | ioubfxw | 0 | * | * | 1 | b | b | b | b | b | W | W | W | W | mem_addr ( | | | | | | | 0 | 0 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Figure 43-11. Decorated load address: unsigned bit field extract See Figure 43-11, where addr[30:29] = 10 for peripheral, addr[28] = 1 specifies the unsigned bit field extract operation, addr[27:23] is "b", the LSB identifier, addr[22:19] is "w", the bit field width minus 1 identifier, and mem\_addr[18:0] specifies the address offset into the space based at 0x4000\_0000 for peripheral. The "-" indicates an address bit "don't care". Note, unlike the other decorated load operations, UBFX uses addr[19] as the least significant bit in the "w" specifier and not as an address bit. The decorated unsigned bit field extract read operation is defined in the following pseudo-code as: Like the BFI operation, when the starting bit position plus the field width exceeds the container size, only part of the source bit field is extracted from the destination memory location. Stated differently, if $(b + w+1) > \text{container\_width}$ , only the low-order "container\\_width - b" bits are actually extracted. The cycle-by-cycle BME operations are detailed in the following table. | Pipeline Stage | Cycle | | | | | | | | | | | |----------------|------------------------------------------------------------------------------|--------------------------------------------------------------------------------------|-------------------------------------------------------------------------|--|--|--|--|--|--|--|--| | | х | x+1 | x+2 | | | | | | | | | | ВМЕ АНВ_ар | Forward addr to memory;<br>Decode decoration; Capture<br>address, attributes | Idle AHB address phase | <next></next> | | | | | | | | | | BME AHB_dp | <previous></previous> | Perform memory read; Form bit mask; Form (rdata & mask) and capture destination data | Logically right shift registered data; Return justified rdata to master | | | | | | | | | in register Table 43-7. Cycle definitions of decorated load: unsigned bit field extract ## 43.3.3 Additional details on decorated addresses and GPIO accesses As previously noted, the peripheral address space occupies a 516 KB region: 512 KB based at 0x4000\_0000 plus a 4 KB space based at 0x400F\_F000 for GPIO accesses. This memory layout provides compatibility with the Kinetis K Family and provides 129 address "slots", each 4 KB in size. The GPIO address space is multiply-mapped by the hardware: it appears at the "standard" system address $0x400F_F000$ and is physically located in the address slot corresponding to address $0x4000_F000$ . Decorated loads and stores create a slight complication involving accesses to the GPIO. Recall the use of address[19] varies by decorated operation; for AND, OR, XOR, LAC1 and LAS1, this bit functions as a true address bit, while for BFI and UBFX, this bit defines the least significant bit of the "w" bit field specifier. As a result, undecorated GPIO references and decorated AND, OR, XOR, LAC1 and LAS1 operations can use the standard 0x400F\_F000 base address, while decorated BFI and UBFX operations must use the alternate 0x4000\_F000 base address. Another #### Application information implementation can simply use 0x400F\_F000 as the base address for all undecorated GPIO accesses and 0x4000\_F000 as the base address for all decorated accesses. Both implementations are supported by the hardware. Table 43-8. Decorated peripheral and GPIO address details | Peripheral address space | Description | | | | | | | | | |--------------------------|------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--| | 0x4000_0000-0x4007_FFFF | Undecorated (normal) peripheral accesses | | | | | | | | | | 0x4008_0000-0x400F_EFFF | Illegal addresses; attempted references are aborted and error terminated | | | | | | | | | | 0x400F_F000-0x400F_FFFF | Undecorated (normal) GPIO accesses using standard address | | | | | | | | | | 0x4010_0000-0x43FF_FFFF | Illegal addresses; attempted references are aborted and error terminated | | | | | | | | | | 0x4400_0000-0x4FFF_FFFF | Decorated AND, OR, XOR, LAC1, LAS1 references to peripherals and GPIO based at either 0x4000_F000 or 0x400F_F000 | | | | | | | | | | 0x5000_0000-0x5FFF_FFF | Decorated BFI, UBFX references to peripherals and GPIO only based at 0x4000_F000 | | | | | | | | | ## 43.4 Application information In this section, GNU assembler macros with C expression operands are presented as examples of the required instructions to perform decorated operations. This section specifically presents a partial bme.h file defining the assembly language expressions for decorated logical stores: AND, OR, and XOR. Comparable functions for BFI and the decorated loads are more complex and available in the complete BME header file. These macros use the same function names presented in Functional description. ``` #define IOANDW(ADDR,WDATA) __asm("ldr r3, =(1<<26);" "orr r3, %[addr];" "mov r2, %[wdata];" "str r2, [r3];" :: [addr] "r" (ADDR), [wdata] "r" (WDATA) : "r2", "r3"); #define IOANDH(ADDR, WDATA) _{asm("ldr} r3, = (1 << 26);" "orr r3, %[addr];" "mov r2, %[wdata];" "strh r2, [r3];" :: [addr] "r" (ADDR), [wdata] "r" (WDATA) : "r2", "r3"); #define IOANDB(ADDR, WDATA) _asm("ldr r3, =(1<<26);" "orr r3, %[addr];" "mov r2, %[wdata];" "strb r2, [r3];" :: [addr] "r" (ADDR), [wdata] "r" (WDATA) : "r2", "r3"); #define IOORW(ADDR,WDATA) _{asm("ldr} r3, = (1 << 27);" "orr r3, %[addr];" "mov r2, %[wdata];" ``` KM Family Reference Manual, Rev. 5, Oct 2013 935 ``` r2, [r3];" "str :: [addr] "r" (ADDR), [wdata] "r" (WDATA) : "r2", "r3"); #define IOORH(ADDR, WDATA) __asm("ldr r3, = (1 << 27);" "orr r3, %[addr];" "mov r2, %[wdata];" r2, [r3];" "strh :: [addr] "r" (ADDR), [wdata] "r" (WDATA) : "r2", "r3"); #define IOORB(ADDR, WDATA) r3, =(1<<27);" __asm("ldr r3, %[addr];" "orr "mov r2, %[wdata];" "strb r2, [r3];" :: [addr] "r" (ADDR), [wdata] "r" (WDATA) : "r2", "r3"); #define IOXORW(ADDR,WDATA) __asm("ldr r3, = (3 << 26);" r3, %[addr];" "orr r2, %[wdata];" r2, [r3];" "mov "str :: [addr] "r" (ADDR), [wdata] "r" (WDATA) : "r2", "r3"); #define IOXORH(ADDR, WDATA) __asm("ldr r3, =(3<<26);" r3, %[addr];" "mov r2, %[wdata];" "strh r2, [r3];" :: [addr] "r" (ADDR), [wdata] "r" (WDATA) : "r2", "r3"); #define IOXORB(ADDR, WDATA) __asm("ldr r3, =(3<<26);" r3, %[addr];" r2, %[wdata];" "orr "mov "strb r2, [r3];" :: [addr] "r" (ADDR), [wdata] "r" (WDATA) : "r2", "r3"); ``` Application information # **Chapter 44 Micro Trace Buffer (MTB)** ### 44.1 Introduction Microcontrollers using the Cortex-M0+ processor core include support for a CoreSight Micro Trace Buffer to provide program trace capabilities. The proper name for this function is the CoreSight Micro Trace Buffer for the Cortex-M0+ Processor; in this document, it is simply abbreviated as the MTB. The simple program trace function creates instruction address change-of-flow data packets in a user-defined region of the system RAM. Accordingly, the system RAM controller manages requests from two sources: - AMBA-AHB reads and writes from the system bus - program trace packet writes from the processor As part of the MTB functionality, there is a DWT (Data Watchpoint and Trace) module that allows the user to define watchpoint addresses, or optionally, an address and data value, that when triggered, can be used to start or stop the program trace recording. This document details the functionality of both the MTB\_RAM and MTB\_DWT capabilities. ## 44.1.1 Overview A generic block diagram of the processor core and platform for this class of ultra low-end microcontrollers is shown as follows: muroduction Figure 44-1. Core platform block diagram As shown in the block diagram, the platform RAM (PRAM) controller connects to two input buses: - the crossbar slave port for system bus accesses - a "private execution MTB port" from the core The logical paths from the crossbar master input ports to the PRAM controller are highlighted along with the private execution trace port from the processor core. The private MTB port signals the instruction address information needed for the 64-bit program trace packets written into the system RAM. The PRAM controller output interfaces to the attached RAM array. In this document, the PRAM controller is the MTB\_RAM controller. The following information is taken from the ARM CoreSight Micro Trace Buffer documentation. "The execution trace packet consists of a pair of 32-bit words that the MTB generates when it detects the processor PC value changes non-sequentially. A non-sequential PC change can occur during branch instructions or during exception entry. The processor can cause a trace packet to be generated for any instruction. The following figure shows how the execution trace information is stored in memory as a sequence of packets. Figure 44-2. MTB execution trace storage format The first, lower addressed, word contains the source of the branch, the address it branched from. The value stored only records bits[31:1] of the source address, because Thumb instructions are at least halfword aligned. The least significant bit of the value is the A-bit. The A-bit indicates the atomic state of the processor at the time of the branch, and can differentiate whether the branch originated from an instruction in a program, an exception, or a PC update in Debug state. When it is zero the branch originated from an instruction, when it is one the branch originated from an exception or PC update in Debug state. This word is always stored at an even word location. The second, higher addressed word contains the destination of the branch, the address it branched to. The value stored only records bits[31:1] of the branch address. The least significant bit of the value is the S-bit. The S-bit indicates where the trace started. An S-bit value of 1 indicates where the first packet after the trace started and a value of 0 is used for other packets. Because it is possible to start and stop tracing multiple times in a trace session, the memory might contain several packets with the S-bit set to 1. This word is always stored in the next higher word in memory, an odd word address. When the A-bit is set to 1, the source address field contains the architecturally-preferred return address for the exception. For example, if an exception was caused by an SVC instruction, then the source address field contains the address of the following instruction. This is different from the case where the A-bit is set to 0. In this case, the source address contains the address of the branch instruction. #### muroduction For an exception return operation, two packets are generated: - The first packet has the: - Source address field set to the address of the instruction that causes the exception return, BX or POP. - Destination address field set to bits[31:1] of the EXC\_RETURN value. See the ARM v6-M Architecture Reference Manual. - The A-bit set to 0. - The second packet has the: - Source address field set to bits[31:1] of the EXC\_RETURN value. - Destination address field set to the address of the instruction where execution commences. - A-bit set to 1." Given the recorded change-of-flow trace packets in system RAM and the memory image of the application, a debugger can read out the data and create an instruction-by-instruction program trace. In keeping with the low area and power implementation cost design targets, the MTB trace format is less efficient than other CoreSight trace modules, for example, the ETM (Embedded Trace Macrocell). Since each branch packet is 8 bytes in size, a 1 KB block of system RAM can contain 128 branches. Using the Dhrystone 2.1 benchmark's dynamic runtime as an example, this corresponds to about 875 instructions per KB of trace RAM, or with a zero wait state memory, this corresponds to approximately 1600 processor cycles per KB. This metric is obviously very sensitive to the runtime characteristics of the user code. The MTB\_DWT function (not shown in the core platform block diagram) monitors the processor address and data buses so that configurable watchpoints can be detected to trigger the appropriate response in the MTB recording. ## 44.1.2 Features The key features of the MTB\_RAM and MTB\_DWT include: - Memory controller for system RAM and Micro Trace Buffer for program trace packets - Read/write capabilities for system RAM accesses, write-only for program trace packets - Supports zero wait state response to system bus accesses when no trace data is being written - Can buffer two AHB address phases and one data write for system RAM accesses - Supports 64-bit program trace packets including source and destination instruction addresses - Program trace information in RAM available to MCU's application code or external debugger - Program trace watchpoint configuration accessible by MCU's application code or debugger - Location and size of RAM trace buffer is configured by software - Two DWT comparators (addresses or address + data) provide programmable start/ stop recording - CoreSight compliant debug functionality # 44.1.3 Modes of operation The MTB\_RAM and MTB\_DWT functions do not support any special modes of operation. The MTB\_RAM controller, as a memory-mapped device located on the platform's slave AHB system bus, responds strictly on the basis of memory addresses for accesses to its attached RAM array. The MTB private execution bus provides program trace packet write information to the RAM controller. Both the MTB\_RAM and MTB\_DWT modules are memory-mapped, so their programming models can be accessed. All functionality associated with the MTB\_RAM and MTB\_DWT modules resides in the core platform's clock domain; this includes its connections with the RAM array. # 44.2 External signal description The MTB\_RAM and MTB\_DWT modules do not directly support any external interfaces. The internal interface includes a standard AHB bus with a 32-bit datapath width from the appropriate crossbar slave port plus the private execution trace bus from the processor core. The signals in the private execution trace bus are detailed in the following table taken from the ARM CoreSight Micro Trace Buffer documentation. The signal direction is defined as viewed by the MTB\_RAM controller. Table 44-1. Private execution trace port from the core to MTB\_RAM | Signal | Direction | Description | |--------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | LOCKUP | Input | Indicates the processor is in the Lockup state. This signal is driven LOW for cycles when the processor is executing normally and driven HIGH for every cycle the processor is waiting in the Lockup state. This signal is valid on every cycle. | | IAESEQ | Input | Indicates the next instruction address in execute, IAEX, is sequential, that is non-branching. | Table continues on the next page... wemory map and register definition Table 44-1. Private execution trace port from the core to MTB\_RAM (continued) | Signal | Direction | Description | |------------|-----------|-----------------------------------------------------------------------------------------------------------| | IAEXEN | Input | IAEX register enable. | | IAEX[30:0] | Input | Registered address of the instruction in the execution stage, shifted right by one bit, that is, PC >> 1. | | ATOMIC | Input | Indicates the processor is performing non-instruction related activities. | | EDBGRQ | Output | Request for the processor to enter the Debug state, if enabled, and halt. | In addition, there are two signals formed by the MTB\_DWT module and driven to the MTB\_RAM controller: TSTART (trace start) and TSTOP (trace stop). These signals can be configured using the trace watchpoints to define programmable addresses and data values to affect the program trace recording state. # 44.3 Memory map and register definition The MTB\_RAM and MTB\_DWT modules each support a sparsely-populated 4 KB address space for their programming models. For each address space, there are a variety of control and configurable registers near the base address, followed by a large unused address space and finally a set of CoreSight registers to support dynamic determination of the debug configuration for the device. Accesses to the programming model follow standard ARM conventions. Taken from the ARM CoreSight Micro Trace Buffer documentation, these are: - Do not attempt to access reserved or unused address locations. Attempting to access these locations can result in UNPREDICTABLE behavior. - The behavior of the MTB is UNPREDICTABLE if the registers with UNKNOWN reset values are not programmed prior to enabling trace. - Unless otherwise stated in the accompanying text: - Do not modify reserved register bits - Ignore reserved register bits on reads - All register bits are reset to a logic 0 by a system or power-on reset - Use only word size, 32-bit, transactions to access all registers # 44.3.1 MTB\_RAM Memory Map ## MTB memory map | Absolute<br>address<br>(hex) | Register name | Width<br>(in bits) | Access | Reset value | Section/<br>page | |------------------------------|---------------------------------------------------|--------------------|--------|-------------|------------------| | F000_0000 | MTB Position Register (MTB_POSITION) | 32 | R/W | Undefined | 44.31.1/<br>944 | | F000_0004 | MTB Master Register (MTB_MASTER) | 32 | R/W | See section | 44.31.2/<br>946 | | F000_0008 | MTB Flow Register (MTB_FLOW) | 32 | R/W | Undefined | 44.31.3/<br>947 | | F000_000C | MTB Base Register (MTB_BASE) | 32 | R | Undefined | 44.31.4/<br>949 | | F000_0F00 | Integration Mode Control Register (MTB_MODECTRL) | 32 | R | 0000_0000h | 44.31.5/<br>950 | | F000_0FA0 | Claim TAG Set Register (MTB_TAGSET) | 32 | R | 0000_0000h | 44.31.6/<br>950 | | F000_0FA4 | Claim TAG Clear Register (MTB_TAGCLEAR) | 32 | R | 0000_0000h | 44.31.7/<br>951 | | F000_0FB0 | Lock Access Register (MTB_LOCKACCESS) | 32 | R | 0000_0000h | 44.31.8/<br>951 | | F000_0FB4 | Lock Status Register (MTB_LOCKSTAT) | 32 | R | 0000_0000h | 44.31.9/<br>952 | | F000_0FB8 | Authentication Status Register (MTB_AUTHSTAT) | 32 | R | 0000_0000h | 44.31.10/<br>952 | | F000_0FBC | Device Architecture Register (MTB_DEVICEARCH) | 32 | R | 4770_0A31h | 44.31.11/<br>953 | | F000_0FC8 | Device Configuration Register (MTB_DEVICECFG) | 32 | R | 0000_0000h | 44.31.12/<br>953 | | F000_0FCC | Device Type Identifier Register (MTB_DEVICETYPID) | 32 | R | 0000_0031h | 44.31.13/<br>954 | | F000_0FD0 | Peripheral ID Register (MTB_PERIPHID4) | 32 | R | See section | 44.31.14/<br>954 | | F000_0FD4 | Peripheral ID Register (MTB_PERIPHID5) | 32 | R | See section | 44.31.14/<br>954 | | F000_0FD8 | Peripheral ID Register (MTB_PERIPHID6) | 32 | R | See section | 44.31.14/<br>954 | | F000_0FDC | Peripheral ID Register (MTB_PERIPHID7) | 32 | R | See section | 44.31.14/<br>954 | | F000_0FE0 | Peripheral ID Register (MTB_PERIPHID0) | 32 | R | See section | 44.31.14/<br>954 | | F000_0FE4 | Peripheral ID Register (MTB_PERIPHID1) | 32 | R | See section | 44.31.14/<br>954 | | F000_0FE8 | Peripheral ID Register (MTB_PERIPHID2) | 32 | R | See section | 44.31.14/<br>954 | | F000_0FEC | Peripheral ID Register (MTB_PERIPHID3) | 32 | R | See section | 44.31.14/<br>954 | Table continues on the next page... #### wemory map and register definition #### MTB memory map (continued) | Absolute<br>address<br>(hex) | Register name | Width<br>(in bits) | Access | Reset value | Section/<br>page | |------------------------------|-------------------------------------|--------------------|--------|-------------|------------------| | F000_0FF0 | Component ID Register (MTB_COMPID0) | 32 | R | See section | 44.31.15/<br>955 | | F000_0FF4 | Component ID Register (MTB_COMPID1) | 32 | R | See section | 44.31.15/<br>955 | | F000_0FF8 | Component ID Register (MTB_COMPID2) | 32 | R | See section | 44.31.15/<br>955 | | F000_0FFC | Component ID Register (MTB_COMPID3) | 32 | R | See section | 44.31.15/<br>955 | # 44.31.1 MTB Position Register (MTB\_POSITION) The MTB\_POSITION register contains the Trace Write Address Pointer and Wrap fields. This register can be modified by the explicit programming model writes. It is also automatically updated by the MTB hardware when trace packets are being recorded. The base address of the system RAM in the memory map dictates special consideration for the placement of the MTB. Consider the following guidelines: For the standard configuration where the size of the MTB is $\leq 25\%$ of the total RAM capacity, it is recommended the MTB be based at the address defined by the MTB\_BASE register. The read-only MTB\_BASE register is defined by the expression (0x2000\_0000 - (RAM\_Size/4)). For this configuration, the MTB\_POSITION register is initialized to MTB\_BASE & 0x0000\_7FF8. If the size of the MTB is more than 25% but less than or equal to 50% of the total RAM capacity, it is recommended the MTB be based at address $0x2000\_0000$ . In this configuration, the MTB\_POSITION register is initialized to $(0x2000\_0000 \& 0x0000 7FF8) = 0x0000 00000$ . Following these two suggested placements provides a full-featured circular memory buffer containing program trace packets. In the unlikely event an even larger trace buffer is required, a write-once capacity of 75% of the total RAM capacity can be based at address 0x2000\_0000. The MTB\_POSITION register is initialized to (0x2000\_0000 & 0x0000\_7FF8) = 0x0000\_0000. However, this configuration cannot support operation as a circular queue and instead requires the use of the MTB\_FLOW[WATERMARK] capability to automatically disable tracing or halting the processor as the number of packet writes approach the buffer capacity. See the MTB\_FLOW register description for more details. **x**\* 0 Address: F000\_0000h base + 0h offset = F000\_0000h 31 Bit 30 27 24 23 19 18 16 R **POINTER** W **x**\* **x**\* **x**\* Reset $\mathbf{x}^{\star}$ х\* х\* х\* **x**\* Bit 15 14 13 12 11 10 6 5 3 0 0 R WRAP **POINTER** W ## MTB\_POSITION field descriptions $\mathbf{X}^{\star}$ | Field | Description | |-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31–3<br>POINTER | Trace Packet Address Pointer[28:0] | | TOMTEN | Because a packet consists of two words, the POINTER field is the address of the first word of a packet. This field contains bits[31:3] of the RAM address where the next trace packet is written. Therefore, it points to an unused location and is automatically incremented. | | | A debug agent can calculate the system memory map address for the current location in the MTB using the following "generic" equation: | | | Given mtb_size = 1 << (MTB_MASTER[MASK] + 4), | | | systemAddress = MTB_BASE + (((MTB_POSITION & 0xFFFF_FFF8) + (mtb_size - (MTB_BASE & (mtb_size-1)))) & 0x0000_7FF8); | | | For this device, a simpler expression also applies. See the following pseudo-code: | | | if $((MTB\_POSITION >> 13) == 0x3)$ systemAddress = $(0x1FFF << 16) + (0x1 << 15) + (MTB\_POSITION & 0x7FF8)$ ; else systemAddress = $(0x2000 << 16) + (0x0 << 15) + (MTB\_POSITION & 0x7FF8)$ ; | | | <b>NOTE:</b> The size of the RAM is parameterized and the most significant bits of the POINTER field are RAZ/WI. | | | For these devices, POSITION[31:15] == POSITION[POINTER[28:12]] are RAZ/WI. Therefore, the active bits in this field are POSITION[14:3] == POSITION[POINTER[11:0]]. | | 2<br>WRAP | This field is set to 1 automatically when the POINTER value wraps as determined by the MTB_MASTER[MASK] field in the MASTER Trace Control Register. A debug agent might use the WRAP field to determine whether the trace information above and below the pointer address is valid. | | 1–0<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | Reset \* Notes: <sup>•</sup> x = Undefined at reset. # 44.31.2 MTB Master Register (MTB\_MASTER) The MTB\_MASTER register contains the main program trace enable plus other trace controls. This register can be modified by the explicit programming model writes. MTB\_MASTER[EN] and MTB\_MASTER[HALTREQ] fields are also automatically updated by the MTB hardware. Before MTB\_MASTER[EN] or MTB\_MASTER[TSTARTEN] are set to 1, the software must initialize the MTB\_POSITION and MTB\_FLOW registers. If MTB\_FLOW[WATERMARK] is used to stop tracing or to halt the processor, MTB\_MASTER[MASK] must still be set to a value that prevents MTB\_POSITION[POINTER] from wrapping before it reaches the MTB\_FLOW[WATERMARK] value. #### NOTE The format of this mask field is different than MTBDWT\_MASKn[MASK]. Address: F000\_0000h base + 4h offset = F000\_0004h ## MTB\_MASTER field descriptions | Field | Description | | |-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | EN | Main Trace Enable When this field is 1, trace data is written into the RAM memory location addressed by MTB_POSITION[POINTER]. The MTB_POSITION[POINTER] value auto increments after the trace data packet is written. | | | | EN can be automatically set to 0 using the MTB_FLOW[WATERMARK] field and the MTB_FLOW[AUTOSTOP] bit. | | Table continues on the next page... <sup>\*</sup> Notes: <sup>•</sup> x = Undefined at reset. # MTB\_MASTER field descriptions (continued) | Field | Description | |-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | EN is automatically set to 1 if TSTARTEN is 1 and the TSTART signal is HIGH. | | | EN is automatically set to 0 if TSTOPEN is 1 and the TSTOP signal is HIGH. | | | NOTE: If EN is set to 0 because MTB_FLOW[WATERMARK] is set, then it is not automatically set to 1 if TSTARTEN is 1 and the TSTART input is HIGH. In this case, tracing can only be restarted if MTB_FLOW[WATERMARK] or MTB_POSITION[POINTER] value is changed by software. | | 30–10<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 9<br>HALTREQ | Halt Request | | | This field is connected to the halt request signal of the trace logic, EDBGRQ. When HALTREQ is set to 1, the EDBFGRQ is asserted if DBGEN (invasive debug enable, one of the debug authentication interface signals) is also HIGH. HALTREQ can be automatically set to 1 using MTB_FLOW[WATERMARK]. | | 8<br>RAMPRIV | RAM Privilege | | TIAWII TUV | If this field is 0, then user or privileged AHB read and write accesses to the RAM are permitted. If this field is 1, then only privileged AHB read and write accesses to the RAM are permitted and user accesses are RAZ/WI. The HPROT[1] signal determines if an access is a user or privileged mode reference. | | 7<br>SFRWPRIV | Special Function Register Write Privilege | | STIWITH | If this field is 0, then user or privileged AHB read and write accesses to the MTB_RAM Special Function Registers (programming model) are permitted. If this field is 1, then only privileged write accesses are permitted; user write accesses are ignored. The HPROT[1] signal determines if an access is user or privileged. Note MTB_RAM SFR read access are not controlled by this bit and are always permitted. | | 6 | Trace Stop Input Enable | | TSTOPEN | If this field is 1 and the TSTOP signal is HIGH, then EN is set to 0. If a trace packet is being written to memory, the write is completed before tracing is stopped. | | 5<br>TSTARTEN | Trace Start Input Enable | | ISTANTEN | If this field is 1 and the TSTART signal is HIGH, then EN is set to 1. Tracing continues until a stop condition occurs. | | 4–0 | Mask | | MASK | This value determines the maximum size of the trace buffer in RAM. It specifies the most-significant bit of the MTB_POSITION[POINTER] field that can be updated by automatic increment. If the trace tries to advance past this power of 2, the MTB_POSITION[WRAP] bit is set to 1, the MTB_POSITION[MASK+3:3] == MTB_POSITION[POINTER[MASK:0]] bits are set to 0, and the MTB_POSITION[14:MASK+3] == MTB_POSITION[POINTER[11:MASK+1]] bits remain unchanged. | | | This field causes the trace packet information to be stored in a circular buffer of size 2^[MASK+4] bytes, that can be positioned in memory at multiples of this size. As detailed in the MTB_POSITION description, typical "upper limits" for the MTB size are RAM_Size/4 or RAM_Size/2. Values greater than the maximum have the same effect as the maximum. | # 44.31.3 MTB Flow Register (MTB\_FLOW) The MTB\_FLOW register contains the watermark address and the autostop/autohalt control bits. #### wemory map and register definition If tracing is stopped using the watermark autostop feature, it cannot be restarted until software clears the watermark autostop. This can be achieved in one of the following ways: - Changing the MTB\_POSITION[POINTER] field value to point to the beginning of the trace buffer, or - Setting MTB\_FLOW[AUTOSTOP] = 0. A debug agent can use MTB\_FLOW[AUTOSTOP] to fill the trace buffer once only without halting the processor. A debug agent can use MTB\_FLOW[AUTOHALT] to fill the trace buffer once before causing the Cortex-M0+ processor to enter the Debug state. To enter Debug state, the Cortex-M0+ processor might have to perform additional branch type operations. Therefore, the MTB\_FLOW[WATERMARK] field must be set below the final entry in the trace buffer region. <sup>\*</sup> Notes: ## MTB\_FLOW field descriptions | Field | Description | |-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31–3<br>WATERMARK | WATERMARK[28:0] | | | This field contains an address in the same format as the MTB_POSITION[POINTER] field. When MTB_POSITION[POINTER] matches the WATERMARK field value, actions defined by the AUTOHALT and AUTOSTOP bits are performed. | | 2<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | Table continues on the next page... <sup>•</sup> x = Undefined at reset. #### MTB\_FLOW field descriptions (continued) | Field Description | | |-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | AUTOHALT | If this field is 1 and WATERMARK is equal to MTB_POSITION[POINTER], then MTB_MASTER[HALTREQ] is automatically set to 1. If the DBGEN signal is HIGH, the MTB asserts this halt request to the Cortex-M0+ processor by asserting the EDBGRQ signal. | | | If this field is 1 and WATERMARK is equal to MTB_POSITION[POINTER], then MTB_MASTER[EN] is automatically set to 0. This stops tracing. | # 44.31.4 MTB Base Register (MTB\_BASE) The read-only MTB\_BASE Register indicates where the RAM is located in the system memory map. This register is provided to enable auto discovery of the MTB RAM location, by a debug agent and is defined by a hardware design parameter. For this device, the base address is defined by the expression: MTB\_BASE[BASEADDR] = 0x2000\_0000 - (RAM\_Size/4) Address: F000\_0000h base + Ch offset = F000\_000Ch <sup>\*</sup> Notes: x = Undefined at reset. ### MTB\_BASE field descriptions | Field | Description | | |----------|---------------------------------------------------------------------------------------------------|--| | 31–0 | This value is defined with a hardwired signal and the expression: 0x2000_0000 - (RAM_Size/4). For | | | BASEADDR | example, if the total RAM capacity is 16 KB, this field is 0x1FFF_F000. | | # 44.31.5 Integration Mode Control Register (MTB\_MODECTRL) This register enables the device to switch from a functional mode, or default behavior, into integration mode. It is hardwired to specific values used during the auto-discovery process by an external debug agent. #### MTB\_MODECTRL field descriptions | Field | Description | |------------------|--------------------------| | 31-0<br>MODECTRL | Hardwired to 0x0000_0000 | # 44.31.6 Claim TAG Set Register (MTB\_TAGSET) The Claim Tag Set Register returns the number of bits that can be set on a read, and enables individual bits to be set on a write. It is hardwired to specific values used during the auto-discovery process by an external debug agent. #### Address: F000\_0000h base + FA0h offset = F000\_0FA0h ## MTB\_TAGSET field descriptions | Field | Description | | |----------------|--------------------------|--| | 31–0<br>TAGSET | Hardwired to 0x0000_0000 | | # 44.31.7 Claim TAG Clear Register (MTB\_TAGCLEAR) The read/write Claim Tag Clear Register is used to read the claim status on debug resources. A read indicates the claim tag status. Writing 1 to a specific bit clears the corresponding claim tag to 0. It is hardwired to specific values used during the auto-discovery process by an external debug agent. Address: F000\_0000h base + FA4h offset = F000\_0FA4h #### MTB\_TAGCLEAR field descriptions | Field | Description | |------------------|--------------------------| | 31–0<br>TAGCLEAR | Hardwired to 0x0000_0000 | # 44.31.8 Lock Access Register (MTB\_LOCKACCESS) The Lock Access Register enables a write access to component registers. It is hardwired to specific values used during the auto-discovery process by an external debug agent. Address: F000\_0000h base + FB0h offset = F000\_0FB0h ## MTB\_LOCKACCESS field descriptions | Field | Description | |--------------------|--------------------------| | 31–0<br>LOCKACCESS | Hardwired to 0x0000_0000 | # 44.31.9 Lock Status Register (MTB\_LOCKSTAT) The Lock Status Register indicates the status of the lock control mechanism. This register is used in conjunction with the Lock Access Register. It is hardwired to specific values used during the auto-discovery process by an external debug agent. #### MTB\_LOCKSTAT field descriptions | Field | Description | |------------------|--------------------------| | 31–0<br>LOCKSTAT | Hardwired to 0x0000_0000 | # 44.31.10 Authentication Status Register (MTB\_AUTHSTAT) The Authentication Status Register reports the required security level and current status of the security enable bit pairs. Where functionality changes on a given security level, this change must be reported in this register. It is connected to specific signals used during the auto-discovery process by an external debug agent. MTB\_AUTHSTAT[3:2] indicates if nonsecure, noninvasive debug is enabled or disabled, while MTB\_AUTHSTAT[1:0] indicates the enabled/disabled state of nonsecure, invasive debug. For both 2-bit fields, 0b10 indicates the functionality is disabled and 0b11 indicates it is enabled. #### MTB\_AUTHSTAT field descriptions | Field | Description | |------------------|--------------------------------------------------------------------------------------| | 31–4<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 3<br>Reserved | This read-only field is reserved and always has the value 1. | | 2<br>BIT2 | Connected to NIDEN or DBGEN signal. | | 1<br>Reserved | This read-only field is reserved and always has the value 1. | | 0<br>BIT0 | Connected to DBGEN. | # 44.31.11 Device Architecture Register (MTB\_DEVICEARCH) This register indicates the device architecture. It is hardwired to specific values used during the auto-discovery process by an external debug agent. Address: F000\_0000h base + FBCh offset = F000\_0FBCh ### MTB\_DEVICEARCH field descriptions | Field | Description | |--------------------|---------------------------| | 31–0<br>DEVICEARCH | Hardwired to 0x4770_0A31. | # 44.31.12 Device Configuration Register (MTB\_DEVICECFG) This register indicates the device configuration. It is hardwired to specific values used during the auto-discovery process by an external debug agent. Address: F000 0000h base + FC8h offset = F000 0FC8h #### memory map and register definition ### MTB\_DEVICECFG field descriptions | Field | Description | |-------------------|---------------------------| | 31–0<br>DEVICECFG | Hardwired to 0x0000_0000. | # 44.31.13 Device Type Identifier Register (MTB\_DEVICETYPID) This register indicates the device type ID. It is hardwired to specific values used during the auto-discovery process by an external debug agent. Address: F000\_0000h base + FCCh offset = F000\_0FCCh #### MTB\_DEVICETYPID field descriptions | Field | Description | |---------------------|---------------------------| | 31–0<br>DEVICETYPID | Hardwired to 0x0000_0031. | # 44.31.14 Peripheral ID Register (MTB\_PERIPHIDn) These registers indicate the peripheral IDs. They are hardwired to specific values used during the auto-discovery process by an external debug agent. Address: F000\_0000h base + FD0h offset + (4d $\times$ i), where i=0d to 7d - \* Notes: - See field descriptions for the reset values.x = Undefined at reset. #### MTB\_PERIPHIDn field descriptions | Field | Description | | |-------|--------------------------------------------------------------------------------------------------------------------------------------------|--| | | Peripheral ID4 is hardwired to 0x0000_0004; ID0 to 0x0000_0032; ID1 to 0x0000_00B9; ID2 to 0x0000_000B; and all the others to 0x0000_0000. | | # 44.31.15 Component ID Register (MTB\_COMPIDn) These registers indicate the component IDs. They are hardwired to specific values used during the auto-discovery process by an external debug agent. #### MTB COMPIDn field descriptions | Field | Description | |-------|----------------------------------------------------------------------------------------------------------------------| | | Component ID Component ID0 is hardwired to 0x0000_000D; ID1 to 0x0000_0090; ID2 to 0x0000_0005; ID3 to 0x0000_00B1. | # 44.3.2 MTB\_DWT Memory Map The MTB\_DWT programming model supports a very simplified subset of the v7M debug architecture and follows the standard ARM DWT definition. #### MTBDWT memory map | Absolute<br>address<br>(hex) | Register name | Width<br>(in bits) | Access | Reset value | Section/<br>page | |------------------------------|------------------------------------------------------|--------------------|--------|-------------|------------------| | F000_1000 | MTB DWT Control Register (MTBDWT_CTRL) | 32 | R | 2F00_0000h | 44.32.1/<br>957 | | F000_1020 | MTB_DWT Comparator Register (MTBDWT_COMP0) | 32 | R/W | 0000_0000h | 44.32.2/<br>958 | | F000_1024 | MTB_DWT Comparator Mask Register (MTBDWT_MASK0) | 32 | R/W | 0000_0000h | 44.32.3/<br>958 | | F000_1028 | MTB_DWT Comparator Function Register 0 (MTBDWT_FCT0) | 32 | R/W | 0000_0000h | 44.32.4/<br>959 | | F000_1030 | MTB_DWT Comparator Register (MTBDWT_COMP1) | 32 | R/W | 0000_0000h | 44.32.2/<br>958 | | F000_1034 | MTB_DWT Comparator Mask Register (MTBDWT_MASK1) | 32 | R/W | 0000_0000h | 44.32.3/<br>958 | Table continues on the next page... <sup>\*</sup> Notes: <sup>•</sup> See field descriptions for the reset values.x = Undefined at reset. #### wemory map and register definition # MTBDWT memory map (continued) | Absolute address (hex) | Register name | Width<br>(in bits) | Access | Reset value | Section/<br>page | |------------------------|-------------------------------------------------------|--------------------|--------|-------------|------------------| | F000_1038 | MTB_DWT Comparator Function Register 1 (MTBDWT_FCT1) | 32 | R/W | 0000_0000h | 44.32.5/<br>961 | | F000_1200 | MTB_DWT Trace Buffer Control Register (MTBDWT_TBCTRL) | 32 | R/W | 2000_0000h | 44.32.6/<br>962 | | F000_1FC8 | Device Configuration Register (MTBDWT_DEVICECFG) | 32 | R | 0000_0000h | 44.32.7/<br>964 | | F000_1FCC | Device Type Identifier Register (MTBDWT_DEVICETYPID) | 32 | R | 0000_0004h | 44.32.8/<br>964 | | F000_1FD0 | Peripheral ID Register (MTBDWT_PERIPHID4) | 32 | R | See section | 44.32.9/<br>965 | | F000_1FD4 | Peripheral ID Register (MTBDWT_PERIPHID5) | 32 | R | See section | 44.32.9/<br>965 | | F000_1FD8 | Peripheral ID Register (MTBDWT_PERIPHID6) | 32 | R | See section | 44.32.9/<br>965 | | F000_1FDC | Peripheral ID Register (MTBDWT_PERIPHID7) | 32 | R | See section | 44.32.9/<br>965 | | F000_1FE0 | Peripheral ID Register (MTBDWT_PERIPHID0) | 32 | R | See section | 44.32.9/<br>965 | | F000_1FE4 | Peripheral ID Register (MTBDWT_PERIPHID1) | 32 | R | See section | 44.32.9/<br>965 | | F000_1FE8 | Peripheral ID Register (MTBDWT_PERIPHID2) | 32 | R | See section | 44.32.9/<br>965 | | F000_1FEC | Peripheral ID Register (MTBDWT_PERIPHID3) | 32 | R | See section | 44.32.9/<br>965 | | F000_1FF0 | Component ID Register (MTBDWT_COMPID0) | 32 | R | See section | 44.32.10/<br>965 | | F000_1FF4 | Component ID Register (MTBDWT_COMPID1) | 32 | R | See section | 44.32.10/<br>965 | | F000_1FF8 | Component ID Register (MTBDWT_COMPID2) | 32 | R | See section | 44.32.10/<br>965 | | F000_1FFC | Component ID Register (MTBDWT_COMPID3) | 32 | R | See section | 44.32.10/<br>965 | # 44.32.1 MTB DWT Control Register (MTBDWT\_CTRL) The MTBDWT\_CTRL register provides read-only information on the watchpoint configuration for the MTB\_DWT. Address: F000\_1000h base + 0h offset = F000\_1000h ### MTBDWT\_CTRL field descriptions | Field | Description | |-----------------|--------------------------------------------------------------------------------------------------------------------------------| | 31–28<br>NUMCMP | Number of comparators | | | The MTB_DWT implements two comparators. | | 27-0 | DWT configuration controls | | DWTCFGCTRL | This field is hardwired to 0xF00_0000, disabling all the remaining DWT functionality. The specific fields and their state are: | | | MTBDWT_CTRL[27] = NOTRCPKT = 1, trace sample and exception trace is not supported | | | MTBDWT_CTRL[26] = NOEXTTRIG = 1, external match signals are not supported | | | MTBDWT_CTRL[25] = NOCYCCNT = 1, cycle counter is not supported | | | MTBDWT_CTRL[24] = NOPRFCNT = 1, profiling counters are not supported | | | MTBDWT_CTRL[22] = CYCEBTENA = 0, no POSTCNT underflow packets generated | | | MTBDWT_CTRL[21] = FOLDEVTENA = 0, no folded instruction counter overflow events | | | MTBDWT_CTRL[20] = LSUEVTENA = 0, no LSU counter overflow events | | | MTBDWT_CTRL[19] = SLEEPEVTENA = 0, no sleep counter overflow events | | | MTBDWT_CTRL[18] = EXCEVTENA = 0, no exception overhead counter events | | | MTBDWT_CTRL[17] = CPIEVTENA = 0, no CPI counter overflow events | | | MTBDWT_CTRL[16] = EXCTRCENA = 0, generation of exception trace disabled | | | MTBDWT_CTRL[12] = PCSAMPLENA = 0, no periodic PC sample packets generated | | | MTBDWT_CTRL[11:10] = SYNCTAP = 0, no synchronization packets | | | MTBDWT_CTRL[9] = CYCTAP = 0, cycle counter is not supported | | | MTBDWT_CTRL[8:5] = POSTINIT = 0, cycle counter is not supported | | | MTBDWT_CTRL[4:1] = POSTPRESET = 0, cycle counter is not supported | | | MTBDWT_CTRL[0] = CYCCNTENA = 0, cycle counter is not supported | # 44.32.2 MTB\_DWT Comparator Register (MTBDWT\_COMPn) The MTBDWT\_COMPn registers provide the reference value for comparator n. Address: F000\_1000h base + 20h offset + (16d $\times$ i), where i=0d to 1d #### MTBDWT\_COMPn field descriptions | Field | Description | | | | |-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | | Reference value for comparison If MTBDWT_COMP0 is used for a data value comparator and the access size is byte or halfword, the data value must be replicated across all appropriate byte lanes of this register. For example, if the data is a byte-sized "x" value, then COMP[31:24] = COMP[23:16] = COMP[15:8] = COMP[7:0] = "x". Likewise, if the data is a halfword-size "y" value, then COMP[31:16] = COMP[15:0] = "y". | | | | # 44.32.3 MTB\_DWT Comparator Mask Register (MTBDWT\_MASKn) The MTBDWT\_MASKn registers define the size of the ignore mask applied to the reference address for address range matching by comparator n. Note the format of this mask field is different than the MTB\_MASTER[MASK]. Address: F000\_1000h base + 24h offset + (16d $\times$ i), where i=0d to 1d #### MTBDWT MASKn field descriptions | Field | Description | | | | |------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | 31–5<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | | | | 4–0<br>MASK | MASK The value of the ignore mask, 0-31 bits, is applied to address range matching. MASK = 0 is used to include all bits of the address in the comparison, except if MASK = 0 and the comparator is configured to watch instruction fetch addresses, address bit [0] is ignored by the hardware since all fetches must be at least halfword aligned. For MASK != 0 and regardless of watch type, address bits [x-1:0] are ignored in the address comparison. | | | | Table continues on the next page... ## MTBDWT\_MASKn field descriptions (continued) | Field | Description | | | | | |-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | | Using a mask means the comparator matches on a range of addresses, defined by the unmasked most significant bits of the address, bits [31:x]. The maximum MASK value is 24, producing a 16 Mbyte mask. An attempted write of a MASK value > 24 is limited by the MTBDWT hardware to 24. | | | | | | | If MTBDWT_COMP0 is used as a data value comparator, then MTBDWT_MASK0 should be programmed to zero. | | | | | # 44.32.4 MTB\_DWT Comparator Function Register 0 (MTBDWT\_FCT0) The MTBDWT\_FCTn registers control the operation of comparator n. #### memory map and register definition # MTBDWT\_FCT0 field descriptions | Field | Description | | | | | | | |-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--| | 31–25 | This field is reserved. | | | | | | | | Reserved | This read-only field is reserved and always has the value 0. | | | | | | | | 24 | Comparator match | | | | | | | | MATCHED | If this read-only flag is asserted, it indicates the operation defined by the FUNCTION field occurred since the last read of the register. Reading the register clears this bit. | | | | | | | | | No match. Match occurred. | | | | | | | | 23–20<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | | | | | | | 19–16<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | | | | | | | 15–12 | Data Value Address 0 | | | | | | | | DATAVADDR0 | Since the MTB_DWT implements two comparators, the DATAVADDR0 field is restricted to values {0,1}. When the DATAVMATCH bit is asserted, this field defines the comparator number to use for linked address comparison. | | | | | | | | | If MTBDWT_COMP0 is used as a data watchpoint and MTBDWT_COMP1 as an address watchpoint, DATAVADDR0 must be set. | | | | | | | | 11–10 | Data Value Size | | | | | | | | DATAVSIZE | For data value matching, this field defines the size of the required data comparison. | | | | | | | | | 00 Byte. | | | | | | | | | 01 Halfword. | | | | | | | | | 10 Word. | | | | | | | | | 11 Reserved. Any attempts to use this value results in UNPREDICTABLE behavior. | | | | | | | | 9<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | | | | | | | 8 | Data Value Match | | | | | | | | DATAVMATCH | When this field is 1, it enables data value comparison. For this implementation, MTBDWT_COMP0 supports address or data value comparisons; MTBDWT_COMP1 only supports address comparisons. | | | | | | | | | 0 Perform address comparison. | | | | | | | | | 1 Perform data value comparison. | | | | | | | | 7–4<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | | | | | | | 3–0 | Function | | | | | | | | FUNCTION | Selects the action taken on a comparator match. If MTBDWT_COMP0 is used for a data value and MTBDWT_COMP1 for an address value, then MTBDWT_FCT1[FUNCTION] must be set to zero. For this configuration, MTBDWT_MASK1 can be set to a non-zero value, so the combined comparators match on a range of addresses. | | | | | | | | | 0000 Disabled. | | | | | | | | | 0100 Instruction fetch. | | | | | | | | | 0101 Data operand read. | | | | | | | | | 0110 Data operand write. | | | | | | | | | 0111 Data operand (read + write). | | | | | | | | | others Reserved. Any attempts to use this value results in UNPREDICTABLE behavior. | | | | | | | ### MTBDWT\_FCT0 field descriptions (continued) | Field | Description | |-------|-------------| |-------|-------------| # 44.32.5 MTB\_DWT Comparator Function Register 1 (MTBDWT\_FCT1) The MTBDWT\_FCTn registers control the operation of comparator n. Since the MTB\_DWT only supports data value comparisons on comparator 0, there are several fields in the MTBDWT\_FCT1 register that are RAZ/WI (bits 12, 11:10, 8). #### wemory map and register definition #### MTBDWT\_FCT1 field descriptions | Field | Description | | | | | | | |---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--| | 31–25 | This field is reserved. | | | | | | | | Reserved | his read-only field is reserved and always has the value 0. | | | | | | | | 24<br>MATCHED | Comparator match | | | | | | | | | If this read-only flag is asserted, it indicates the operation defined by the FUNCTION field occurred since the last read of the register. Reading the register clears this bit. | | | | | | | | | 0 No match. | | | | | | | | | 1 Match occurred. | | | | | | | | 23–4 | This field is reserved. | | | | | | | | Reserved | This read-only field is reserved and always has the value 0. | | | | | | | | 3–0 | Function | | | | | | | | FUNCTION | Selects the action taken on a comparator match. If MTBDWT_COMP0 is used for a data value and MTBDWT_COMP1 for an address value, then MTBDWT_FCT1[FUNCTION] must be set to zero. For this configuration, MTBDWT_MASK1 can be set to a non-zero value, so the combined comparators match on a range of addresses. | | | | | | | | | 0000 Disabled. | | | | | | | | | 0100 Instruction fetch. | | | | | | | | | 0101 Data operand read. | | | | | | | | | 0110 Data operand write. | | | | | | | | | 0111 Data operand (read + write). | | | | | | | | | others Reserved. Any attempts to use this value results in UNPREDICTABLE behavior. | | | | | | | # 44.32.6 MTB\_DWT Trace Buffer Control Register (MTBDWT\_TBCTRL) The MTBDWT\_TBCTRL register defines how the watchpoint comparisons control the actual trace buffer operation. Recall the MTB supports starting and stopping the program trace based on the watchpoint comparisons signaled via TSTART and TSTOP. The watchpoint comparison signals are enabled in the MTB's control logic by setting the appropriate enable bits, MTB\_MASTER[TSTARTEN, TSTOPEN]. In the event of simultaneous assertion of both TSTART and TSTOP, TSTART takes priority. ## MTBDWT\_TBCTRL field descriptions | Field | Description | | | | | |------------------|-------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | 31–28<br>NUMCOMP | Number of Comparators | | | | | | | This read-only field specifies the number of comparators in the MTB_DWT. This implementation includes two registers. | | | | | | 27–2 | This field is reserved. | | | | | | Reserved | This read-only field is reserved and always has the value 0. | | | | | | 1<br>ACOMP1 | Action based on Comparator 1 match | | | | | | | When the MTBDWT_FCT1[MATCHED] is set, it indicates MTBDWT_COMP1 address compare has | | | | | | | triggered and the trace buffer's recording state is changed. | | | | | | | 0 Trigger TSTOP based on the assertion of MTBDWT_FCT1[MATCHED]. | | | | | | | Trigger TSTART based on the assertion of MTBDWT_FCT1[MATCHED]. | | | | | | 0 | Action based on Comparator 0 match | | | | | | ACOMP0 | When the MTBDWT_FCT0[MATCHED] is set, it indicates MTBDWT_COMP0 address compare has | | | | | | | triggered and the trace buffer's recording state is changed. The assertion of MTBDWT_FCT0[MATCHED] is caused by the following conditions: | | | | | | | <ul> <li>Address match in MTBDWT_COMP0 when MTBDWT_FCT0[DATAVMATCH] = 0</li> </ul> | | | | | | | <ul> <li>Data match in MTBDWT_COMP0 when MTBDWT_FCT0[DATAVMATCH, DATAVADDR0] = {1,0}</li> </ul> | | | | | | | <ul> <li>Data match in MTBDWT_COMP0 and address match in MTBDWT_COMP1 when<br/>MTBDWT_FCT0[DATAVMATCH, DATAVADDR0] = {1,1}</li> </ul> | | | | | | | 0 Trigger TSTOP based on the assertion of MTBDWT_FCT0[MATCHED]. | | | | | | | 1 Trigger TSTART based on the assertion of MTBDWT_FCT0[MATCHED]. | | | | | # 44.32.7 Device Configuration Register (MTBDWT\_DEVICECFG) This register indicates the device configuration. It is hardwired to specific values used during the auto-discovery process by an external debug agent. Address: F000\_1000h base + FC8h offset = F000\_1FC8h #### MTBDWT\_DEVICECFG field descriptions | Field | Description | | | | | |-------------------|---------------------------|--|--|--|--| | 31–0<br>DEVICECFG | Hardwired to 0x0000_0000. | | | | | # 44.32.8 Device Type Identifier Register (MTBDWT\_DEVICETYPID) This register indicates the device type ID. It is hardwired to specific values used during the auto-discovery process by an external debug agent. Address: F000\_1000h base + FCCh offset = F000\_1FCCh #### MTBDWT\_DEVICETYPID field descriptions | Field | Description | |---------------------|---------------------------| | 31–0<br>DEVICETYPID | Hardwired to 0x0000_0004. | 965 # 44.32.9 Peripheral ID Register (MTBDWT\_PERIPHIDn) These registers indicate the peripheral IDs. They are hardwired to specific values used during the auto-discovery process by an external debug agent. • See field descriptions for the reset values. x = Undefined at reset. #### MTBDWT PERIPHIDn field descriptions | Field Description | | | | | | | |-------------------|----------------------------------------------------------------------------------------------------|--|--|--|--|--| | 31–0<br>PERIPHID | Peripheral ID1 is hardwired to 0x0000_00E0; ID2 to 0x0000_0008; and all the others to 0x0000_0000. | | | | | | # 44.32.10 Component ID Register (MTBDWT\_COMPIDn) These registers indicate the component IDs. They are hardwired to specific values used during the auto-discovery process by an external debug agent. - \* Notes: - See field descriptions for the reset values.x = Undefined at reset. #### MTBDWT COMPIDn field descriptions | Field | Description | | | | |----------------|----------------------------------------------------------------------------------------------------------------------|--|--|--| | 31–0<br>COMPID | Component ID Component ID0 is hardwired to 0x0000_000D; ID1 to 0x0000_0090; ID2 to 0x0000_0005; ID3 to 0x0000_00B1. | | | | <sup>\*</sup> Notes: # 44.3.3 System ROM Memory Map The System ROM Table registers are also mapped into a sparsely-populated 4 KB address space. For core configurations like that supported by Cortex-M0+, ARM recommends that a debugger identifies and connects to the debug components using the CoreSight debug infrastructure. ARM recommends that a debugger follows the flow as shown in the following figure to discover the components in the CoreSight debug infrastructure. In this case, a debugger reads the peripheral and component ID registers for each CoreSight component in the CoreSight system. Figure 44-56. CoreSight discovery process ### **ROM** memory map | Absolute<br>address<br>(hex) | Register name | Width<br>(in bits) | Access | Reset value | Section/<br>page | |------------------------------|----------------------------------------------|--------------------|--------|-------------|------------------| | F000_2000 | Entry (ROM_ENTRY0) | 32 | R | See section | 44.33.1/<br>967 | | F000_2004 | Entry (ROM_ENTRY1) | 32 | R | See section | 44.33.1/<br>967 | | F000_2008 | Entry (ROM_ENTRY2) | 32 | R | See section | 44.33.1/<br>967 | | F000_200C | End of Table Marker Register (ROM_TABLEMARK) | 32 | R | 0000_0000h | 44.33.2/<br>968 | | F000_2FCC | System Access Register (ROM_SYSACCESS) | 32 | R | 0000_0001h | 44.33.3/<br>968 | Table continues on the next page... #### **ROM memory map (continued)** | Absolute<br>address<br>(hex) | Register name | Width<br>(in bits) | Access | Reset value | Section/<br>page | |------------------------------|----------------------------------------|--------------------|--------|-------------|------------------| | F000_2FD0 | Peripheral ID Register (ROM_PERIPHID4) | 32 | R | See section | 44.33.4/<br>969 | | F000_2FD4 | Peripheral ID Register (ROM_PERIPHID5) | 32 | R | See section | 44.33.4/<br>969 | | F000_2FD8 | Peripheral ID Register (ROM_PERIPHID6) | 32 | R | See section | 44.33.4/<br>969 | | F000_2FDC | Peripheral ID Register (ROM_PERIPHID7) | 32 | R | See section | 44.33.4/<br>969 | | F000_2FE0 | Peripheral ID Register (ROM_PERIPHID0) | 32 | R | See section | 44.33.4/<br>969 | | F000_2FE4 | Peripheral ID Register (ROM_PERIPHID1) | 32 | R | See section | 44.33.4/<br>969 | | F000_2FE8 | Peripheral ID Register (ROM_PERIPHID2) | 32 | R | See section | 44.33.4/<br>969 | | F000_2FEC | Peripheral ID Register (ROM_PERIPHID3) | 32 | R | See section | 44.33.4/<br>969 | | F000_2FF0 | Component ID Register (ROM_COMPID0) | 32 | R | See section | 44.33.5/<br>969 | | F000_2FF4 | Component ID Register (ROM_COMPID1) | 32 | R | See section | 44.33.5/<br>969 | | F000_2FF8 | Component ID Register (ROM_COMPID2) | 32 | R | See section | 44.33.5/<br>969 | | F000_2FFC | Component ID Register (ROM_COMPID3) | 32 | R | See section | 44.33.5/<br>969 | # 44.33.1 Entry (ROM\_ENTRY*n*) The System ROM Table begins with "n" relative 32-bit addresses, one for each debug component present in the device and terminating with an all-zero value signaling the end of the table at the "n+1"-th value. It is hardwired to specific values used during the auto-discovery process by an external debug agent. Address: F000\_2000h base + 0h offset + (4d $\times$ i), where i=0d to 2d <sup>\*</sup> Notes: <sup>•</sup> See field descriptions for reset values.x = Undefined at reset. #### memory map and register definition #### ROM\_ENTRYn field descriptions | Field | Description | |---------------|------------------------------------------------------------------------------------------------------| | 31–0<br>ENTRY | ENTRY Entry 0 (MTB) is hardwired to 0xFFFF_E003; Entry 1 (MTBDWT) to 0xFFFF_F003; Entry 2 (CM0+ ROM | | | Table) to 0xF00F_D003. | # 44.33.2 End of Table Marker Register (ROM\_TABLEMARK) This register indicates end of table marker. It is hardwired to specific values used during the auto-discovery process by an external debug agent. Address: F000\_2000h base + Ch offset = F000\_200Ch ### ROM\_TABLEMARK field descriptions | Field | Description | |--------------|--------------------------| | 31–0<br>MARK | Hardwired to 0x0000_0000 | # 44.33.3 System Access Register (ROM\_SYSACCESS) This register indicates system access. It is hardwired to specific values used during the auto-discovery process by an external debug agent. Address: F000\_2000h base + FCCh offset = F000\_2FCCh #### ROM\_SYSACCESS field descriptions | Field | Description | |-------------------|--------------------------| | 31–0<br>SYSACCESS | Hardwired to 0x0000_0001 | 969 # 44.33.4 Peripheral ID Register (ROM\_PERIPHIDn) These registers indicate the peripheral IDs. They are hardwired to specific values used during the auto-discovery process by an external debug agent. • See field descriptions for reset values.x = Undefined at reset. #### ROM PERIPHIDn field descriptions | Field | Description | |------------------|----------------------------------------------------------------------------------------------------| | 31–0<br>PERIPHID | Peripheral ID1 is hardwired to 0x0000_00E0; ID2 to 0x0000_0008; and all the others to 0x0000_0000. | # 44.33.5 Component ID Register (ROM\_COMPIDn) These registers indicate the component IDs. They are hardwired to specific values used during the auto-discovery process by an external debug agent. - \* Notes: - See field descriptions for reset values.x = Undefined at reset. #### ROM\_COMPIDn field descriptions | Field | Description | | |----------------|----------------------------------------------------------------------------------------------------------------------|--| | 31–0<br>COMPID | Component ID Component ID0 is hardwired to 0x0000_000D; ID1 to 0x0000_0010; ID2 to 0x0000_0005; ID3 to 0x0000_00B1. | | <sup>\*</sup> Notes wemory map and register definition # **Chapter 45 Flash Memory Module (FTFA)** ## 45.1 Introduction #### **NOTE** For the chip-specific implementation details of this module's instances, see the chip configuration information. The flash memory module includes the following accessible memory regions: Program flash memory for vector space and code store 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 flash memory 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-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. 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. KM Family Reference Manual, Rev. 5, Oct 2013 971 ### **45.1.1 Features** The flash memory module includes the following features. #### **NOTE** See the device's Chip Configuration details for the exact amount of flash memory available on your device. ## 45.1.1.1 Program Flash Memory Features - Sector size of 1 KB - Program flash protection scheme prevents accidental program or erase of stored data - Automated, built-in, program and erase algorithms with verify ## 45.1.1.2 Other Flash Memory 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 ## 45.1.2 Block Diagram The block diagram of the flash memory module is shown in the following figure. Figure 45-1. Flash Block Diagram ## 45.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 flash memory module. **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 flash memory module. **Flash block** — A macro within the flash memory module which provides the nonvolatile memory storage. **Flash Memory Module** — All flash blocks plus a flash management unit providing high-level control and an interface to MCU buses. **IFR** — Nonvolatile information register found in each flash block, separate from the main memory array. **Longword** — 32 bits of data with an aligned longword having byte-address[1:0] = 00. **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 flash memory module resources. The CPU or other bus masters initiate flash program and erase operations (or other flash commands) using writes to the FCCOB register group in the flash memory module. #### **External Signal Description** **NVM Special Mode** — An NVM mode enabling external, off-chip access to the memory resources in the flash memory module. A reduced flash command set is available when the MCU is secured. See the Chip Configuration details for information on when this mode is used. **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. **Secure** — An MCU state conveyed to the flash memory module as described in the Chip Configuration details for this device. In the secure state, reading and changing NVM contents is restricted. **Word** — 16 bits of data with an aligned word having byte-address[0] = 0. # 45.2 External Signal Description The flash memory module contains no signals that connect off-chip. ## 45.3 Memory Map and Registers This section describes the memory map and registers for the flash memory module. Data read from unimplemented memory space in the flash memory module is undefined. Writes to unimplemented or reserved memory space (registers) in the flash memory module are ignored. ## 45.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 flash memory 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 Chip 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_040F | 1 | Reserved | | 0x0_040E | 1 | Reserved | | 0x0_040D | 1 | Flash nonvolatile option byte. Refer to the description of the Flash Option Register (FOPT). | | 0x0_040C | 1 | Flash security byte. Refer to the description of the Flash Security Register (FSEC). | # 45.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 table found here and further described in the subsequent paragraphs. The program flash IFR is located within the program flash 0 memory block. | Address Range Size (Bytes) Field Description | |----------------------------------------------| |----------------------------------------------| ### 45.3.2.1 Program Once Field The Program Once Field in the program flash IFR provides 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 #### wemory Map and Registers 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). ### 45.3.3 Register Descriptions The flash memory 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). #### FTFA memory map | Absolute<br>address<br>(hex) | Register name | Width<br>(in bits) | Access | Reset value | Section/<br>page | |------------------------------|-----------------------------------------------------|--------------------|--------|-------------|------------------| | 4002_0000 | Flash Status Register (FTFA_FSTAT) | 8 | R/W | 00h | 45.33.1/<br>977 | | 4002_0001 | Flash Configuration Register (FTFA_FCNFG) | 8 | R/W | 00h | 45.33.2/<br>979 | | 4002_0002 | Flash Security Register (FTFA_FSEC) | 8 | R | Undefined | 45.33.3/<br>980 | | 4002_0003 | Flash Option Register (FTFA_FOPT) | 8 | R | Undefined | 45.33.4/<br>981 | | 4002_0004 | Flash Common Command Object Registers (FTFA_FCCOB3) | 8 | R/W | 00h | 45.33.5/<br>982 | | 4002_0005 | Flash Common Command Object Registers (FTFA_FCCOB2) | 8 | R/W | 00h | 45.33.5/<br>982 | | 4002_0006 | Flash Common Command Object Registers (FTFA_FCCOB1) | 8 | R/W | 00h | 45.33.5/<br>982 | | 4002_0007 | Flash Common Command Object Registers (FTFA_FCCOB0) | 8 | R/W | 00h | 45.33.5/<br>982 | | 4002_0008 | Flash Common Command Object Registers (FTFA_FCCOB7) | 8 | R/W | 00h | 45.33.5/<br>982 | | 4002_0009 | Flash Common Command Object Registers (FTFA_FCCOB6) | 8 | R/W | 00h | 45.33.5/<br>982 | | 4002_000A | Flash Common Command Object Registers (FTFA_FCCOB5) | 8 | R/W | 00h | 45.33.5/<br>982 | Table continues on the next page... 977 #### FTFA memory map (continued) | Absolute address (hex) | Register name | Width<br>(in bits) | Access | Reset value | Section/<br>page | |------------------------|---------------------------------------------------------------|--------------------|--------|-----------------|------------------| | 4002_000B | Flash Common Command Object Registers (FTFA_FCCOB4) | 8 | R/W | 00h | 45.33.5/<br>982 | | 4002_000C | Flash Common Command Object Registers (FTFA_FCCOBB) 8 R/W 00h | | 00h | 45.33.5/<br>982 | | | 4002_000D | Flash Common Command Object Registers (FTFA_FCCOBA) | 8 | R/W | 00h | 45.33.5/<br>982 | | 4002_000E | Flash Common Command Object Registers (FTFA_FCCOB9) | 8 | R/W | 00h | 45.33.5/<br>982 | | 4002_000F | Flash Common Command Object Registers (FTFA_FCCOB8) | 8 | R/W | 00h | 45.33.5/<br>982 | | 4002_0010 | Program Flash Protection Registers (FTFA_FPROT3) | 8 | R/W | Undefined | 45.33.6/<br>983 | | 4002_0011 | Program Flash Protection Registers (FTFA_FPROT2) | 8 | R/W | Undefined | 45.33.6/<br>983 | | 4002_0012 | Program Flash Protection Registers (FTFA_FPROT1) | 8 | R/W | Undefined | 45.33.6/<br>983 | | 4002_0013 | Program Flash Protection Registers (FTFA_FPROT0) | 8 | R/W | Undefined | 45.33.6/<br>983 | ## 45.33.1 Flash Status Register (FTFA\_FSTAT) The FSTAT register reports the operational status of the flash memory module. 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: 4002\_0000h base + 0h offset = 4002\_0000h | 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 | KM Family Reference Manual, Rev. 5, Oct 2013 #### wemory Map and Registers # FTFA\_FSTAT field descriptions | Field | Description | |-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | Command Complete Interrupt Flag | | CCIF | Indicates that a flash 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. | | | CCIF 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. | | | <ul><li>0 Flash command in progress</li><li>1 Flash command has completed</li></ul> | | 6 | Flash Read Collision Error Flag | | RDCOLERR | Indicates that the MCU attempted a read from a flash memory resource that was being manipulated by a flash 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 | Indicates an illegal access has occurred to a flash memory resource caused by a violation of the command write sequence or issuing an illegal flash 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. | | | No access error detected | | | 1 Access error detected | | 4 | Flash Protection Violation Flag | | FPVIOL | Indicates an attempt was made to program or erase an address in a protected area of program flash memory during a command write sequence. While FPVIOL is set, the CCIF flag cannot be cleared to launch a command. The FPVIOL bit is cleared by writing a 1 to it. Writing a 0 to the FPVIOL bit has no effect. | | | 0 No protection violation detected | | | 1 Protection violation detected | | 3–1<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0. | | 0 | Memory Controller Command Completion Status Flag | | MGSTAT0 | The MGSTAT0 status flag is set if an error is detected during execution of a flash command or during the flash reset sequence. As a status flag, this field 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. | # 45.33.2 Flash Configuration Register (FTFA\_FCNFG) This register provides information on the current functional state of the flash memory module. The erase control bits (ERSAREQ and ERSSUSP) have write restrictions. The unassigned bits read as noted and are not writable. Address: 4002\_0000h base + 1h offset = 4002\_0001h #### FTFA\_FCNFG field descriptions | Field | Description | |----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | Command Complete Interrupt Enable | | CCIE | Controls interrupt generation when a flash command completes. | | | 0 Command complete interrupt disabled | | | 1 Command complete interrupt enabled. An interrupt request is generated whenever the FSTAT[CCIF] flag is set. | | 6 | Read Collision Error Interrupt Enable | | RDCOLLIE | Controls interrupt generation when a flash memory read collision error occurs. | | | 0 Read collision error interrupt disabled | | | 1 Read collision error interrupt enabled. An interrupt request is generated whenever a flash memory read collision error is detected (see the description of FSTAT[RDCOLERR]). | | 5 | Erase All Request | | ERSAREQ | 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. | | | ERSAREQ sets when an erase all request is triggered external to the flash memory module and CCIF is set (no command is currently being executed). ERSAREQ is cleared by the flash memory module when the operation completes. | | | 0 No request or request complete | | | <ul><li>1 Request to:</li><li>1. run the Erase All Blocks command,</li></ul> | | | 2. verify the erased state, | | | <ol> <li>program the security byte in the Flash Configuration Field to the unsecure state, and</li> <li>release MCU security by setting the FSEC[SEC] field to the unsecure state.</li> </ol> | | 4 | Erase Suspend | | ERSSUSP | Allows the user to suspend (interrupt) the Erase Flash Sector command while it is executing. | Table continues on the next page... #### wemory Map and Registers ### FTFA\_FCNFG field descriptions (continued) | Field | Description | |----------|--------------------------------------------------------------| | | 0 No suspend requested | | | 1 Suspend the current Erase Flash Sector command execution. | | 3 | This field is reserved. | | Reserved | This read-only field is reserved and always has the value 0. | | 2 | This field is reserved. | | Reserved | This read-only field is reserved and always has the value 0. | | 1 | This field is reserved. | | Reserved | This read-only field is reserved and always has the value 0. | | 0 | This field is reserved. | | Reserved | This read-only field is reserved and always has the value 0. | # 45.33.3 Flash Security Register (FTFA\_FSEC) This read-only register holds all bits associated with the security of the MCU and flash memory module. 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: 4002\_0000h base + 2h offset = 4002\_0002h <sup>\*</sup> Notes: #### FTFA\_FSEC field descriptions | Field | Description | |--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7–6<br>KEYEN | Backdoor Key Security Enable Enables or disables backdoor key access to the flash memory 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 | Table continues on the next page... <sup>•</sup> x = Undefined at reset. ### FTFA\_FSEC field descriptions (continued) | Field | Description | |---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | Enables and disables mass erase capability of the flash memory module. The state of this field is relevant only when SEC is set to secure outside of NVM Normal Mode. When SEC 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<br>FSLACC | Freescale Failure Analysis Access Code | | 1 02/100 | Enables or disables 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 SEC is set to secure. When SEC 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 | | | Defines the security state of the MCU. In the secure state, the MCU limits access to flash memory module resources. The limitations are defined per device and are detailed in the Chip Configuration details. If the flash memory module is unsecured using backdoor key access, SEC is forced to 10b. | | | 00 MCU security status is secure. | | | 01 MCU security status is secure. | | | 10 MCU security status is unsecure. (The standard shipping condition of the flash memory module is unsecure.) | | | 11 MCU security status is secure. | # 45.33.4 Flash Option Register (FTFA\_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. #### wemory Map and Registers Address: 4002\_0000h base + 3h offset = 4002\_0003h <sup>\*</sup> Notes: #### FTFA\_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. | # 45.33.5 Flash Common Command Object Registers (FTFA\_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. Address: $4002\_0000h$ base + 4h offset + $(1d \times i)$ , where i=0d to 11d #### FTFA\_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. | | | The following table shows a generic flash 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 flash command, typically an address and/or data values. | KM Family Reference Manual, Rev. 5, Oct 2013 <sup>•</sup> x = Undefined at reset. 983 #### FTFA\_FCCOBn field descriptions (continued) | Field | Description | | | | | | | |-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | | <b>NOTE:</b> 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 | Typical Command Parameter Contents [7:0] | | | | | | | | 0 | FCMD (a code that defines the flash 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 | | | | | | | | A | Data Byte 6 | | | | | | | | В | Data Byte 7 | | | | | | | | FCCOB Endianness an | nd Multi-Byte Access : | | | | | | | | The FCCOB register gro | oup uses a big endian addressing convention. For all command parameter fields lost significant data resides in the lowest FCCOB register number. The FCCOB and and written as individual bytes, aligned words (2 bytes) or aligned longwords | | | | | | # 45.33.6 Program Flash Protection Registers (FTFA\_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 flash command. Unprotected regions can be changed by program and erase operations. The four FPROT registers allow up to 32 protectable regions. Each bit protects a 1/32 region of the program flash memory except for memory configurations with less than 32 KB of program flash where each assigned bit protects 1 KB. For configurations with 24 KB of program flash memory or less, FPROT0 is not used. For configurations with 16 KB of program flash memory or less, FPROT1 is not used. For configurations with 8 KB of program flash memory, FPROT2 is not used. The bitfields are defined in each register as follows: #### wemory Map and Registers | Program flash protection register | Program flash protection bits | |-----------------------------------|-------------------------------| | FPROT0 | PROT[31:24] | | FPROT1 | PROT[23:16] | | FPROT2 | PROT[15:8] | | FPROT3 | PROT[7:0] | 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 | 0x000B | | FPROT1 | 0x000A | | FPROT2 | 0x0009 | | FPROT3 | 0x0008 | 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. Address: $4002\_0000h$ base + 10h offset + (1d × i), where i=0d to 3d | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|------------|------------|----|------------|------------|------------|------------|----| | Read<br>Write | | | | PR | ОТ | | | | | Reset | <b>x</b> * | <b>x</b> * | x* | <b>x</b> * | <b>x</b> * | <b>x</b> * | <b>x</b> * | x* | <sup>\*</sup> Notes: #### FTFA\_FPROTn field descriptions | Field | Description | 1 | |-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---| | 7–0<br>PROT | Program Flash Region Protect | 1 | | 11101 | 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. | | | | Restriction: 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. | | KM Family Reference Manual, Rev. 5, Oct 2013 <sup>•</sup> x = Undefined at reset. #### FTFA\_FPROTn field descriptions (continued) | Field | Description | | | | |-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | | Each bit in the 32-bit protection register represents 1/32 of the total program flash except for configurations where program flash memory is less than 32 KB. For configurations with less than 32 KB program flash memory, each assigned bit represents 1 KB. | | | | | | <ul><li>0 Program flash region is protected.</li><li>1 Program flash region is not protected</li></ul> | | | | # 45.4 Functional Description The information found here describes functional details of the flash memory module. #### 45.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: - FPROTn - For 2<sup>n</sup> program flash sizes, four registers typically protect 32 regions of the program flash memory as shown in the following figure Figure 45-24. Program flash protection KM Family Reference Manual, Rev. 5, Oct 2013 #### NOTE Flash protection features are discussed further in AN4507: Using the Kinetis Security and Flash Protection Features. Not all features described in the application note are available on this device. ### 45.4.2 Interrupts Flash Read Collision Error The flash memory module can generate interrupt requests to the MCU upon the occurrence of various flash events. These interrupt events and their associated status and control bits are shown in the following table. Flash Event Readable Interrupt Status Bit Enable Bit Flash Command Complete FSTAT[CCIF] FCNFG[CCIE] FSTAT[RDCOLERR] FCNFG[RDCOLLIE] Table 45-24. Flash Interrupt Sources #### **Note** Vector addresses and their relative interrupt priority are determined at the MCU level. Some devices also generate a bus error response as a result of a Read Collision Error event. See the chip configuration information to determine if a bus error response is also supported. ### 45.4.3 Flash Operation in Low-Power Modes #### 45.4.3.1 Wait Mode When the MCU enters wait mode, the flash memory module is not affected. The flash memory module can recover the MCU from wait via the command complete interrupt (see Interrupts). 987 ### 45.4.3.2 Stop Mode When the MCU requests stop mode, if a flash 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 flash command is running (CCIF = 0). #### NOTE While the MCU is in very-low-power modes (VLPR, VLPW, VLPS), the flash memory module does not accept flash commands. ## 45.4.4 Functional Modes of Operation The flash memory module has two operating modes: NVM Normal and NVM Special. The operating mode affects the command set availability (see Table 45-25). Refer to the Chip Configuration details of this device for how to activate each mode. ### 45.4.5 Flash Reads and Ignored Writes The flash memory module requires only the flash address to execute a flash memory read. 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). # 45.4.6 Read While Write (RWW) The following simultaneous accesses are not allowed: • Reading from program flash memory space while a flash command is active (CCIF=0). # 45.4.7 Flash Program and Erase All flash functions except read require the user to setup and launch a flash command through a series of peripheral bus writes. The user cannot initiate any further flash commands until notified that the current command has completed. The flash command structure and operation are detailed in Flash Command Operations. ### 45.4.8 Flash Command Operations Flash command operations are typically used to modify flash memory contents. The next sections describe: - The command write sequence used to set flash command parameters and launch execution - A description of all flash commands available ### 45.4.8.1 Command Write Sequence Flash commands are specified using a command write sequence illustrated in Figure 45-25. The flash memory 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. Attempts to launch a flash command in VLP mode will be ignored. ### 45.4.8.1.1 Load the FCCOB Registers The user must load the FCCOB registers with all parameters required by the desired flash command. The individual registers that make up the FCCOB data set can be written in any order. ### 45.4.8.1.2 Launch the Command by Clearing CCIF Once all relevant command parameters have been loaded, the user launches the command by clearing FSTAT[CCIF] by writing a '1' to it. FSTAT[CCIF] remains 0 until the flash command completes. The FSTAT register contains a blocking mechanism that prevents a new command from launching (can't clear FSTAT[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. ### 45.4.8.1.3 Command Execution and Error Reporting The command processing has several steps: 1. The flash memory module reads the command code and performs a series of parameter checks and protection checks, if applicable, which are unique to each command. If the parameter check fails, the FSTAT[ACCERR] (access error) flag is set. FSTAT[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. Program and erase commands also check the address to determine if the operation is requested to execute on protected areas. If the protection check fails, FSTAT[FPVIOL] (protection error) flag is set. Command processing never proceeds to execution when the parameter or protection step fails. Instead, command processing is terminated after setting FSTAT[CCIF]. - 2. If the parameter and protection checks pass, the command proceeds to execution. Run-time errors, such as failure to erase verify, may occur during the execution phase. Run-time errors are reported in FSTAT[MGSTAT0]. A command may have access errors, protection errors, and run-time errors, but the run-time errors are not seen until all access and protection errors have been corrected. - 3. Command execution results, if applicable, are reported back to the user via the FCCOB and FSTAT registers. - 4. The flash memory module sets FSTAT[CCIF] signifying that the command has completed. The flow for a generic command write sequence is illustrated in the following figure. Figure 45-25. Generic flash command write sequence flowchart ### 45.4.8.2 Flash Commands The following table summarizes the function of all flash commands. | FCMD | Command | Program flash | Function | |------|------------------|---------------|-------------------------------------------------------------------------------------------| | 0x01 | Read 1s Section | × | Verify that a given number of program flash locations from a starting address are erased. | | 0x02 | Program Check | × | Tests previously-programmed locations at margin read levels. | | 0x03 | Read Resource | IFR, ID | Read 4 bytes from program flash IFR or version ID. | | 0x06 | Program Longword | × | Program 4 bytes in a program flash block. | Table continues on the next page... #### **Chapter 45 Flash Memory Module (FTFA)** | FCMD | Command | Program flash | Function | | |------|----------------------------|--------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|--| | 0x09 | Erase Flash Sector | × | Erase all bytes in a program flash sector. | | | 0x40 | Read 1s All Blocks | × | Verify that the program flash block is erased then release MCU security. | | | 0x41 | Read Once | IFR Read 4 bytes of a de 64 byte field in the p flash 0 IFR. | | | | 0x43 | Program Once | IFR | One-time program of 4 bytes of a dedicated 64-byte field in the program flash 0 IFR. | | | 0x44 | Erase All Blocks | se All Blocks × Era bloc rele | | | | | | | NOTE: An erase is only possible when all memory locations are unprotected. | | | 0x45 | Verify Backdoor Access Key | × | Release MCU security after comparing a set of user-supplied security keys to those stored in the program flash. | | # 45.4.8.3 Flash Commands by Mode The following table shows the flash commands that can be executed in each flash operating mode. Table 45-25. Flash Commands by Mode | FCMD | Command | NVM Normal | | | NVM Special | | | |-------|-------------------------------|------------|--------|---------|-------------|--------|---------| | FCNID | | Unsecure | Secure | MEEN=10 | Unsecure | Secure | MEEN=10 | | 0x01 | Read 1s Section | × | × | × | × | _ | _ | | 0x02 | Program Check | × | × | × | × | _ | _ | | 0x03 | Read Resource | × | × | × | × | _ | _ | | 0x06 | Program Longword | × | × | × | × | _ | _ | | 0x09 | Erase Flash Sector | × | × | × | × | _ | _ | | 0x40 | Read 1s All Blocks | × | × | × | × | × | _ | | 0x41 | Read Once | × | × | × | × | _ | _ | | 0x43 | Program Once | × | × | × | × | _ | _ | | 0x44 | Erase All Blocks | × | × | × | × | × | _ | | 0x45 | Verify Backdoor Access<br>Key | × | × | × | × | _ | _ | KM Family Reference Manual, Rev. 5, Oct 2013 ### 45.4.9 Margin Read Commands The Read-1s commands (Read 1s All Blocks 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 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, un-margined, 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. 993 ### 45.4.10 Flash Command Description This section describes all flash commands that can be launched by a command write sequence. The flash memory module 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 FSTAT[ACCERR] and FSTAT[FPVIOL] 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 flash memory module is running a command (FSTAT[CCIF] = 0) on that same block. The flash memory module may return invalid data to the MCU with the collision error flag (FSTAT[RDCOLERR]) set. #### **CAUTION** Flash data must be in the erased state before being programmed. Cumulative programming of bits (adding more zeros) is not allowed. ### 45.4.10.1 Read 1s Section Command The Read 1s Section command checks if a section of program 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 45-26. 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 | | | | | 1. Must be longword aligned (Flash address [1:0] = 00). Upon clearing CCIF to launch the Read 1s Section command, the flash memory module sets the read margin for 1s according to Table 45-27 and then reads all locations within the specified section of flash memory. If the flash memory module fails to read all 1s (that is, the flash section is not erased), FSTAT[MGSTAT0] is set. FSTAT[CCIF] sets after the Read 1s Section operation completes. Table 45-27. 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 45-28. 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 0. | FSTAT[ACCERR] | | Read-1s fails. | FSTAT[MGSTAT0] | # 45.4.10.2 Program Check Command The Program Check command tests a previously programmed program flash longword to see if it reads correctly at the specified margin level. Table 45-29. 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 | | A | Byte 2 expected data | | В | Byte 3 expected data | 995 1. Must be longword aligned (Flash address [1:0] = 00). Upon clearing CCIF to launch the Program Check command, the flash memory module sets the read margin for 1s according to Table 45-30, 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, FSTAT[MGSTAT0] is set. The flash memory module then sets the read margin for 0s, re-reads, and compares again. If the comparison at margin-0 fails, FSTAT[MGSTAT0] is set. FSTAT[CCIF] is set after the Program Check operation completes. The supplied address must be longword aligned (the lowest two bits of the byte address must be 00): - Byte 3 data is written to the supplied byte address ('start'), - Byte 2 data is programmed to byte address start+0b01, - Byte 1 data is programmed to byte address start+0b10, - Byte 0 data is programmed to byte address start+0b11. #### NOTE See the description of margin reads, Margin Read Commands Table 45-30. 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 45-31. Program Check Command Error Handling | Error Condition | Error Bit | |-------------------------------------------------------------|----------------| | Command not available in current mode/security | FSTAT[ACCERR] | | An invalid flash address is supplied FSTAT[ACC | | | 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] | ### 45.4.10.3 Read Resource Command The Read Resource command allows the user to read data from special-purpose memory resources located within the flash memory module. The special-purpose memory resources available include program flash IFR space and the Version ID field. Each resource is assigned a select code as shown in Table 45-33. **Table 45-32. 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 45-33) | <sup>1.</sup> Must be longword aligned (Flash address [1:0] = 00). **Table 45-33. Read Resource Select Codes** | Resource<br>Select Code | Description | Resource Size | Local Address Range | |-------------------------|---------------------|---------------|---------------------| | 0x00 | Program Flash 0 IFR | 256 Bytes | 0x00_0000-0x00_00FF | | 0x01 <sup>1</sup> | Version ID | 8 Bytes | 0x00_0000-0x00_0007 | 1. Located in program flash 0 reserved space. 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 45-34. 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[AC | | | Flash address is not longword aligned | FSTAT[ACCERR] | # 45.4.10.4 Program Longword Command The Program Longword command programs four previously-erased bytes in the program 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-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 Contents [7:0] **FCCOB Number** 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 Byte 3 program value Table 45-35. Program Longword Command FCCOB Requirements 1. Must be longword aligned (Flash address [1:0] = 00). 7 Upon clearing CCIF to launch the Program Longword command, the flash memory module programs the data bytes into the flash using the supplied address. 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 FSTAT[MGSTAT0]. The CCIF flag is set after the Program Longword operation completes. The supplied address must be longword aligned (flash address [1:0] = 00): - Byte 3 data is written to the supplied byte address ('start'), - Byte 2 data is programmed to byte address start+0b01, - Byte 1 data is programmed to byte address start+0b10, and - Byte 0 data is programmed to byte address start+0b11. Table 45-36. 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] | Table continues on the next page... Table 45-36. Program Longword Command Error Handling (continued) | Error Condition | Error Bit | |--------------------------------------------------------------|----------------| | Any errors have been encountered during the verify operation | FSTAT[MGSTAT0] | #### 45.4.10.5 Erase Flash Sector Command The Erase Flash Sector operation erases all addresses in a flash sector. Table 45-37. 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 | | 1. Must be longword aligned (flash address [1:0] = 00). After clearing CCIF to launch the Erase Flash Sector command, the flash memory module erases the selected program 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). 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 45-26). Table 45-38. 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[ACCERR] | | Flash address is not longword aligned | FSTAT[ACCERR] | | The selected program flash sector is protected | FSTAT[FPVIOL] | | Any errors have been encountered during the verify operation <sup>1</sup> | FSTAT[MGSTAT0] | 1. User margin read may be run using the Read 1s Section command to verify all bits are erased. ### 45.4.10.5.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 flash memory module samples the state of the ERSSUSP bit at convenient points. If the flash memory module detects that the ERSSUSP bit is set, the Erase Flash Sector operation is suspended and the flash memory module sets CCIF. While ERSSUSP is set, all writes to flash registers are ignored except for writes to the FSTAT and FCNFG registers. If an Erase Flash Sector operation effectively completes before the flash memory module detects that a suspend request has been made, the flash memory module clears the ERSSUSP bit prior to setting CCIF. When an Erase Flash Sector operation has been successfully suspended, the flash memory module 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 flash memory module has acknowledged it. #### 45.4.10.5.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 flash memory module 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. ### 45.4.10.5.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 flash memory module starts the new command using the new FCCOB contents. #### **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 45-26. Suspend and Resume of Erase Flash Sector Operation KM Family Reference Manual, Rev. 5, Oct 2013 1001 ### 45.4.10.6 Read 1s All Blocks Command The Read 1s All Blocks command checks if the program flash blocks 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 45-39. 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 flash memory module: - sets the read margin for 1s according to Table 45-40, - checks the contents of the program flash are in the erased state. If the flash memory module 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 CCIF flag sets after the Read 1s All Blocks operation has completed. Table 45-40. 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 45-41. Read 1s All Blocks Command Error Handling | Error Condition | Error Bit | |---------------------------------------|----------------| | An invalid margin choice is specified | FSTAT[ACCERR] | | Read-1s fails | FSTAT[MGSTAT0] | #### 45.4.10.7 Read Once Command The Read Once command provides read access to a reserved -byte field located in the program flash 0 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 is programmed using the Program Once command described in Program Once Command. **FCCOB Number** FCCOB Contents [7:0] 0 0x41 (RDONCE) 1 Program Once record index (0x00 - ) 2 Not used 3 Not used Returned Values 4 Program Once byte 0 value 5 Program Once byte 1 value 6 Program Once byte 2 value 7 Program Once byte 3 value Table 45-42. Read Once Command FCCOB Requirements After clearing CCIF to launch the Read Once command, a 4-byte Program 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 . During execution of the Read Once command, any attempt to read addresses within the program flash block containing this -byte field returns invalid data. The Read Once command can be executed any number of times. Table 45-43. 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] | ### 45.4.10.8 Program Once Command The Program Once command enables programming to a reserved -byte field in the program flash 0 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 0 IFR cannot be erased. **Table 45-44. Program Once Command FCCOB Requirements** | FCCOB Number | FCCOB Contents [7:0] | | |--------------|-------------------------------------|--| | 0 | 0x43 (PGMONCE) | | | 1 | Program Once record index (0x00 - ) | | | 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 flash memory module 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 0 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 . During execution of the Program Once command, any attempt to read addresses within the program flash block containing this -byte field returns invalid data. **Table 45-45. 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. #### 45.4.10.9 Erase All Blocks Command The Erase All Blocks operation erases all flash memory, verifies all memory contents, and releases MCU security. Table 45-46. 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 flash memory module erases all program flash memory, then verifies that all are erased. If the flash memory module verifies that all flash memories were properly erased, security is released by setting the FSEC[SEC] field to the unsecure state. The Erase All Blocks command aborts if any flash region is protected. The security byte and all other contents of the flash configuration field (see Flash Configuration Field Description) are 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 45-47. 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 is protected | FSTAT[FPVIOL] | | Any errors have been encountered during the verify operation <sup>1</sup> | FSTAT[MGSTAT0] | 1. User margin read may be run using the Read 1s All Blocks command to verify all bits are erased. ### 45.4.10.9.1 Triggering an Erase All External to the Flash Memory Module The functionality of the Erase All BlocksErase All Blocks Unsecure 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 regardless of the protection settings. If the post-erase verify passes, the routine then releases security by setting the FSEC[SEC] field register to the unsecure state. 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. #### **Verify Backdoor Access Key Command** 45.4.10.10 The Verify Backdoor Access Key command only executes if the mode and security conditions are satisfied (see Flash 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 45-48. 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 flash memory module checks the FSEC[KEYEN] bits to verify that this command is enabled. If not enabled, the flash memory module sets the FSTAT[ACCERR] bit and terminates. If the command is enabled, the flash memory module 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 flash memory module 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 45-49. 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] | Table continues on the next page... Table 45-49. Verify Backdoor Access Key Command Error Handling (continued) | Error Condition | Error Bit | |----------------------------------------------------------------------------------------------|---------------| | 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] | ## 45.4.11 Security The flash memory module provides security information to the MCU based on contents of the FSEC security register. The MCU then limits access to flash memory resources as defined in the device's Chip Configuration details. During reset, the flash memory 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. The settings are described in the Flash Security Register (FTFA\_FSEC) details. Flash security features are discussed further in AN4507: Using the Kinetis Security and Flash Protection Features. Note that not all features described in the application note are available on this device. Table 45-50. FSEC register fields | FSEC field | Description | |------------|--------------------------| | KEYEN | Backdoor Key Access | | MEEN | Mass Erase Capability | | FSLACC | Freescale Factory Access | | SEC | MCU security | # 45.4.11.1 Flash Memory Access by Mode and Security The following table summarizes how access to the flash memory module is affected by security and operating mode. #### Table 45-51. Flash Memory Access Summary | Operating Mode | Chip Security State | | |----------------|---------------------|-------------------------------------------------------------------------------------| | Operating Mode | Unsecure | Secure | | NVM Normal | Full command set | | | NVM Special | Full command set | Only the Erase All BlocksErase All Blocks Unsecure and Read 1s All Blocks commands. | ### 45.4.11.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 chip reset. ### 45.4.11.2.1 Unsecuring the Chip Using Backdoor Key Access 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 chip can be unsecured by the following backdoor key access sequence: 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 chip is unsecured and the FSEC[SEC] bits are forced to the unsecure state An illegal key provided to the Verify Backdoor Access Key command prohibits further use of the Verify Backdoor Access Key command. A reset of the chip 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 chip 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 chip, the security state of the flash memory 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 chip has full control of the contents of the Flash Configuration Field. The chip 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. ### 45.4.12 Reset Sequence On each system reset the flash memory module executes a sequence which establishes initial values for the flash block configuration parameters, FPROT, FOPT, and FSEC registers. FSTAT[CCIF] is cleared throughout the reset sequence. The flash memory module holds off CPU access during 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 flash 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 46 Flash Memory Controller (FMC)** ### 46.1 Introduction The Flash Memory Controller (FMC) is a memory acceleration unit. A list of features provided by the FMC can be found here. - an interface between bus masters and the 32-bit program flash memory. - a buffer and a cache that can accelerate program flash memory data transfers. ### 46.1.1 Overview The Flash Memory Controller manages the interface between bus masters and the 32-bit program flash memory. The FMC receives status information detailing the configuration of the flash memory 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. A write operation to program flash memory results in a bus error. In addition, the FMC provides two separate mechanisms for accelerating the interface between bus masters and program flash memory. 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. ## 46.1.2 Features The features of FMC module include: - Interface between bus masters and the 32-bit program flash memory: - 8-bit, 16-bit, and 32-bit read operations to nonvolatile flash memory. - Acceleration of data transfer from the program flash memory to the device: #### woues of operation - 32-bit prefetch speculation buffer for program flash accesses 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 ## 46.2 Modes of operation The FMC operates only when a bus master accesses the program flash memory. 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 cannot be accessed, the FMC is disabled. ## 46.3 External signal description The FMC has no external (off-chip) signals. ## 46.4 Memory map and register descriptions The MCM's programming model provides control and configuration of the FMC's features. For details, see the description of the MCM's Platform Control Register (PLACR). ## 46.5 Functional description The FMC is a flash acceleration unit with flexible buffers for user configuration. Besides managing the interface between bus masters and the program flash memory, 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. Upon system reset, the FMC is configured as follows: - Flash cache is enabled. - Instruction speculation and caching are enabled. - Data speculation is disabled. - Data caching is enabled. 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 user may adjust the controls to enable buffering per access type (data or instruction). #### **NOTE** When reconfiguring the FMC, do not program the control and configuration inputs to the FMC while the program flash memory is being accessed. Instead, change them with a routine executing from RAM in supervisor mode. runctional description # **Appendix A Missing Neutral Scenario Recommendations** Assuming that on power up, the meter could be tampered with and neutral is disconnected, the SoC must boot in lowest power consumption mode and enable only the required modules. The process after reset could be as follows: - 1. There needs to be a mechanism on board to signal missing neutral. The indication can be connected to GPIO or TAMPERx pin for CPU to monitor. - 2. CPU should not enable any peripheral (only iRTC is functional or GPIO port which has the GPIO for missing neutral indication) and first check the status of this TAMPERx pin or GPIO pin - 3. CPU can configure and enable minimal peripherals required for missing neutral operation. If in VLPR mode, CPU should enable peripherals in a staggered fashion to control the current increase (since PMC is in loose regulation mode). - 4. Based on the state of this pin, the next steps are decided. If the pin indicates no tamper, CPU can start enabling other peripherals and the AFEs and continue normal operation in RUN mode. CPU can also enable FLL and PLL to give clocks to core and peripherals. - 5. If the pin indicates missing neutral tamper, CPU will enter into VLPR mode (or continue in VLPR if boot happens in VLPR mode) to conserve power in ICS and Flash. - 6. While in VLPR, the time stamp is recorded in iRTC (if TAMPERx pin is used) and CPU will work with one AFE (for phase current measurement with PGA disabled to save power), VREF, one CMP (for frequency measurement). Other system modules that will be needed are AXBS, AIPS. Communication peripherals can be enabled based on application needs. This can vary depending on customer application requirements. AFE works in low power mode with modulator clock on less than 1 MHz (768 kHz nominal). AFE will be running at reduced accuracy since PGA is disabled. VREF is also configured to work in "low power buffer mode". - 7. CPU will continue to operate in VLPR (or go into VLPW) until the missing neutral situation is resolved. When operating in VLPR, the software code must written in an optimized way so that current due to code execution is not high. The table below summarizes the key points of the boot sequence (broken down into major steps) in both RUN and VLPR modes assuming a missing neutral condition exists. **Table A-1. Boot Modes Summary** | | Power Up | Reset<br>Sequence | Flash<br>Calibration | Flash<br>Initialization -<br>NVOPT fetch | Flash<br>Initialization -<br>Remainder<br>operation | Boot Up | Phase<br>Measurement | |------|-----------------------------------------------------------------|------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------| | RUN | Flash along<br>with other<br>analog<br>components<br>charges up | Mode for boot<br>selected.<br>Default clock<br>source<br>selected is 4<br>MHz IRC. | Flash<br>calibrates itself<br>using internal<br>clock source<br>(25 MHz) | Flash initializes and fetches NVOPT information. Based on NVOPT bit, flash clock source is changed to externally supplied clock (ipg_clk) | Flash initializes using externally supplied clock. | core_hold<br>signal de-<br>asserted and<br>CPU starts to<br>boot up. CPU<br>checks for<br>missing neutral<br>condition and<br>enables<br>minimal set of<br>peripherals. | AFE enabled in<br>low power<br>mode with PGA<br>disabled. The<br>clock to AFE is<br>less than 1<br>MHz. | | VLPR | Flash along<br>with other<br>analog<br>components<br>charges up | Mode for boot<br>selected.<br>Default clock<br>source<br>selected is 4<br>MHz IRC | Flash calibrates itself using externally supplied clock (ipg_clk). Flash clock should be ensured to be =< 1 MHz | Flash initializes using externally supplied clock. NVOPT bit is not checked. | Flash initializes<br>using externally<br>supplied clock. | core_hold signal de- asserted and CPU starts to boot up. CPU checks for missing neutral condition and enables minimal set of peripherals in a staggered fashion | AFE enabled in<br>low power<br>mode with PGA<br>disabled. The<br>clock to AFE is<br>less than 1<br>MHz. | #### **NOTE** To handle current spikes during Flash charging and Flash NVOPT fetching (when booting in RUN), a capacitor on VDD supply will be required. A capacitor on VDD supply can sustain more than 1.6 mA current if the high current consumption is of short duration (3-5 µs). 1014 Preliminary Freescale Semiconductor, Inc. # **Appendix B Revision history** The following table provides a revision history for this document. Table B-1. Changes between Rev 5 and Rev 4 | Chapter | Description | |---------------------------------|---------------------------------------------------------------------------------------------------------------------------------| | System Memory Map | Table: System memory map. • Flash Memory (Includes exception vectors in first 1024 bytes). "1024 bytes" updated to "192 bytes" | | System Integration Module (SIM) | SIM register definition updated: • SIM_FCFG1 [PFSIZE] field description updated. | | Clock Distribution | Added new topic: Enable PLL in VLPR or VLPR and PSTOP1 | Table B-2. Changes between Rev 4 and Rev 3 | Chapter | Description | |----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Global changes | Editorial changes throughout the document | | Chip configuration chapter | Updated Section 3.10.2.1 "instantiation Information". Added NOTE: KM family devices have a 1/3 bias controller that works with a 1/3 bias LCD glass. To avoid ghosting, the LCD OFF threshold should be greater than VLL1 level. If the LCD glass has an OFF threshold less than VLL1 level, use the internal VREG mode and generate VLL1 internally using RVTRIM option. This can reduce VLL1 level to allow for a lower OFF threshold LCD glass. | | Clock distribution | Table 5-1: Clock summary updated. • Row: External reference 32kHz (ERCLK32K) updated • Row: Internal reference (MCGIRCLK) | | Power Management | Table 7-2 updated: • Added a footnote to MCG row • Added a footnote to XBAR row | | Pinouts and Packaging | Updated section: Package Types. • NOTE: All pin muxing configurations reset to default value on any reset assertion (reset asserts on VLLSx mode exit). When RESET pin is used as GPIO and pulled low; an internal reset (e.g. VLLSx mode exit or WDOG reset, etc) will make this pin function as RESET (default function) and since it is pulled low, it will appear as if pin reset is asserted and will cause full chip reset. | Table continues on the next page... ## Table B-2. Changes between Rev 4 and Rev 3 (continued) | Chapter | Description | |------------------------------|----------------------------------------------------------------------------------------------------------| | Miscellaneous Control Module | Updated register MCM_MATCR. Fields [8-15] and [24-31] are marked Reserved. | | System Mode Controller | Updated register SMC_PMCTRL. Field 7, bit description updated. | | Analog Front End | Updated figures: | | Multipurpose Clock Generator | Updated register MCG_C6 | | Independent Real Time Clock | <ul> <li>Added section: VBAT mode</li> <li>Added register: RTC Control 2 Register (RTC_CTRL2)</li> </ul> | ### **Table B-3. Revision History** | Rev. No. | Date | Substantial Changes | |----------|--------|---------------------| | Rev1 | 8/2012 | Initial release | Table continues on the next page... ## Table B-3. Revision History (continued) | Rev. No. | Date | Substantial Changes | |----------|---------|--------------------------------------------------------------------------------------| | Rev2 | 10/2012 | — Minor changes in block diagram | | | | —Table KM Feature Set footnote removed | | | | —Added section "ARM Cortex M0+<br>Core" | | | | —Minor editorial changes in section "Debug facilities" | | | | —In Table "Interrupt vector assignments" AFE channel names and descriptions updated. | | | | Chip configuration chapter | | | | —Table "System memory map" updated | | | | —Under Clock distribution chapter, Introduction section updated. | | | | —Section "High Level clocking diagram", Clocking Diagram figure updated | | | | —Section "Clock definitions" updated | | | | —Under "Device clock summary" section, clock summary table updated | | | | —Section "Internal clocking requirements" updated | | | | —Section "Clock divider values after reset" updated | | | | —Table Module clocks updated | | | | —Section "Reset pin filter" updated | | | | —Table Flash Option Register (FTFL_FOPT) Bit Definitions updated | | | | —Section "Boot Up Process" updated | | | | —TMR memory map updated | | | | —GPIO memory map updated | Table continues on the next page... ## Table B-3. Revision History (continued) | Rev. No. | Date | Substantial Changes | |----------|---------|-----------------------------------------------------------------------------------------------------------------------| | Rev3 | 04/2013 | —Block diagram updated. PXBR renamed to XBAR. | | | | —Minor editorial changes in section<br>"Performance targets" | | | | —Table AWIC Stop and VLPS Wakeup Sources updated | | | | —Instantiation information section of<br>"Segment LCD controller" updated | | | | —Minor update in Table "DMA request sources". Under column "DMA Channel 0 Assignment", AFE_CH1 replaced with AFE_CH0. | | | | —Chip Configuration chapter: Footnote updated for row "DMA Done Signal" | | | | —Chip configuration chapter: Table "RTC General Purpose Data Register Table" updated. | | | | —Section "PIT/DMA Periodic Trigger Assignments" added under PIT configuration | | | | —Section "Clock definitions" updated | | | | —Table "Module clocks" updated | | | | —Updated Section "Boot Up Process" | | | | —Table "Module operation in low power modes" updated | | | | —Section "Tamper Detection Flow", RTC_TTSR_SCR[8] updated to RTC_TTSR_SCR[11] | | | | —NOTE added to "KM Signal Multiplexing and Pin Assignments" | | | | —System Integration module chapter updated | | | | —DMA Status Register / Byte Count Register updated | | | | —Section "Always enabled DMA sources" updated | | | | —MPU memory map updated | | | | —Watchdog Time out Value Register<br>High and Watchdog Time out Value<br>Register Low reset values updated | Table continues on the next page... # Table B-3. Revision History (continued) | Rev. No. | Date | Substantial Changes | |----------|------|---------------------------------------------------------------------------| | | | —AFE and UART chapters updated | | | | —Minor editorial changes in section "SLCD base clock and frame frequency" | | | | —Fig "LCD clock tree" updated | | | | —Table "Initialization register values for example 1" updated | | | | —Figure "LCD programmer's model diagram" updated | | | | —Appendix "Missing Neutral Scenario Recommendations" updated | How to Reach Us: **Home Page:** freescale.com Web Support: freescale.com/support Information in this document is provided solely to enable system and software implementers to use Freescale products. There are no express or implied copyright licenses granted hereunder to design or fabricate any integrated circuits based on the information in this document. Freescale reserves the right to make changes without further notice to any products herein. Freescale makes no warranty, representation, or guarantee regarding the suitability of its products for any particular purpose, nor does Freescale assume any liability arising out of the application or use of any product or circuit, and specifically disclaims any and all liability, including without limitation consequential or incidental damages. "Typical" parameters that may be provided in Freescale 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 does not convey any license under its patent rights nor the rights of others. Freescale sells products pursuant to standard terms and conditions of sale, which can be found at the following address: freescale.com/SalesTermsandConditions. Freescale, the Freescale logo, and Kinetis are trademarks of Freescale Semiconductor, Inc., Reg. U.S. Pat. & Tm. Off. All other product or service names are the property of their respective owners. ARM and Cortex are the registered trademarks of ARM Limited. © 2011-2013 Freescale Semiconductor, Inc. Document Number: MKMxxZxxCxx5RM Rev. 5 10/2013