# MSPM0 L-Series 32-MHz Microcontrollers Technical Reference Manual Literature Number: SLAU847C OCTOBER 2022 – REVISED MAY 2023 # **Table of Contents** | Read This First | 9 | |----------------------------------------|-----| | About This Manual | | | Notational Conventions | | | Glossary | 9 | | Related Documentation | 9 | | Support Resources | 9 | | 1 Architecture | | | 1.1 Architecture Overview | 12 | | 1.2 Bus Organization | 12 | | 1.3 Platform Memory Map | 14 | | 1.3.1 Code Region | 14 | | 1.3.2 SRAM Region | 14 | | 1.3.3 Peripheral Region | 16 | | 1.3.4 Subsystem Region | | | 1.3.5 System PPB Region | 16 | | 1.4 Boot Configuration | | | 1.4.1 Configuration Memory (NONMAIN) | 16 | | 1.4.2 Boot Configuration Routine (BCR) | 18 | | 1.4.3 Bootstrap Loader (BSL) | | | 1.4.4 NONMAİN | 26 | | 1.5 Factory Constants | 38 | | 1.5.1 FACTORYREGION Registers | 40 | | 2 PMCU | 75 | | 2.1 PMCU Overview | 76 | | 2.1.1 Power Domains | 77 | | 2.1.2 Operating Modes | 77 | | 2.2 Power Management (PMU) | 81 | | 2.2.1 Power Supply | 81 | | 2.2.2 Core Regulator | 81 | | 2.2.3 Supply Supervisors | 82 | | 2.2.4 Bandgap Reference | 83 | | 2.2.5 Temperature Sensor | 83 | | 2.2.6 VBOOST for Analog Muxes | 84 | | 2.2.7 Peripheral Power Enable Control | 86 | | 2.3 Clock Module (CKM) | 87 | | 2.3.1 Oscillators | 87 | | 2.3.2 Clocks | 92 | | 2.3.3 Clock Tree | 98 | | 2.3.4 Clock Monitors | 100 | | 2.3.5 Frequency Clock Counter (FCC) | 101 | | 2.4 System Controller (SYSCTL) | | | 2.4.1 Resets and Device Initialization | 102 | | 2.4.2 Operating Mode Selection | 109 | | 2.4.3 Asynchronous Fast Clock Requests | | | 2.4.4 SRAM Write Protection | | | 2.4.5 Flash Wait States | | | 2.4.6 Flash Bank Address Swap | 113 | | 2.4.7 Shutdown Mode Handling | | | 2.4.8 Configuration Lockout | | | 2.4.9 System Status | | Table of Contents www.ti.com | 2.4.10 Error Handling | | |------------------------------------------------------------|------| | 2.4.11 SYSCTL Events | | | 2.5 Quick Start Reference | 117 | | 2.5.1 Default Device Configuration | 117 | | 2.5.2 Leveraging MFCLK | 117 | | 2.5.3 Optimizing Power Consumption in STOP Mode | | | 2.5.4 Optimizing Power Consumption in STANDBY Mode | | | 2.5.5 Optimizing for Lowest Wakeup Latency | .118 | | 2.5.6 Optimizing for Lowest Peak Current in RUN/SLEEP Mode | | | 2.6 PMCU Registers | | | 2.6.1 SYSCTL Registers | | | 3 CPU | | | 3.1 Overview | | | 3.2 Arm Cortex-M0+ CPU | | | 3.2.1 CPU Register File | | | 3.2.2 Stack Behavior | | | 3.2.3 Execution Modes and Privilege Levels | | | 3.2.4 Address Space and Supported Data Sizes | | | 3.3 Interrupts and Exceptions | | | 3.3.1 Peripheral Interrupts (IRQs) | | | 3.3.2 Interrupt and Exception Table | | | 3.3.3 Processor Lockup Scenario | | | 3.4 CPU Peripherals | | | 3.4.1 System Control Block (SCB) | 1// | | 3.4.2 System Tick Timer (SysTick) | | | 3.5 NVM Access Acceleration | | | 3.5.1 Prefetch | | | 3.5.2 Cache | | | 3.6 Read-only Memory (ROM) | | | 3.7 CPUSS Registers | | | 3.8 WUC Registers | | | 4 DMA | | | 4.1 DMA Overview | | | 4.2 DMA Operation | | | 4.2.1 Addressing Modes | | | 4.2.2 Channel Types | | | 4.2.4 Extended Modes | | | 4.2.5 Initiating DMA Transfers | | | 4.2.6 Stopping DMA Transfers | | | 4.2.7 Channel Priorities. | | | 4.2.8 Burst Block Mode | | | 4.2.9 Using DMA with System Interrupts | | | 4.2.10 DMA Controller Interrupts | | | 4.2.11 DMA Trigger Event Status | | | 4.2.12 DMA Operating Mode Support | | | 4.2.13 DMA Address and Data Errors. | | | 4.2.14 Interrupt and Event Support. | | | 4.3 DMA Registers | | | 5 NVM (Flash) | | | 5.1 NVM Overview | | | 5.1.1 Key Features | | | 5.1.2 System Components. | | | 5.1.3 Terminology | | | 5.2 Flash Memory Bank Organization | | | 5.2.1 Banks | | | 5.2.2 Flash Memory Regions | | | 5.2.3 Addressing | | | 5.2.4 Memory Organization Examples | | | 5.3 Flash Controller | | | 5.3.1 Overview of Flash Controller Commands | | www.ti.com Table of Contents | 5.3.2 NOOP Command | | |---------------------------------------------------------------------------------|-----| | 5.3.3 PROGRAM Command | 282 | | 5.3.4 ERASE Command | | | 5.3.5 READVERIFY Command | 287 | | 5.3.6 BLANKVERIFY Command | 288 | | 5.3.7 Command Diagnostics | | | 5.3.8 Overriding the System Address With a Bank ID, Region ID, and Bank Address | 289 | | 5.3.9 FLASHCTL Events | 290 | | 5.4 Write Protection | | | 5.4.1 Write Protection Resolution | 290 | | 5.4.2 Static Write Protection | | | 5.4.3 Dynamic Write Protection | | | 5.5 Read Interface | | | 5.5.1 Bank Address Swapping | | | 5.6 FLASHCTL Registers | | | 6 Events | | | 6.1 Events Overview | | | 6.1.1 Event Publisher | | | 6.1.2 Event Subscriber | | | 6.1.3 Event Fabric Routing | | | 6.1.4 Event Routing Map | | | 6.1.5 Event Propagation Latency | | | 6.2 Events Operation | | | 6.2.1 CPU Interrupt | | | 6.2.2 DMA Trigger | | | 6.2.3 Peripheral to Peripheral Event | | | 6.2.4 Extended Module Description Register | | | 6.2.5 Using Event Registers | | | 7 IOMUX | | | 7.1 IOMUX Overview | | | 7.1.1 IO Types and Analog Sharing | | | 7.2 IOMUX Operation | | | 7.2.2 Logic High to Hi-Z Conversion | | | 7.2.2 Logic Ingrito III-2 Conversion | | | 7.2.4 SHUTDOWN Mode Wakeup Logic | | | 7.2.5 Pullup/Pulldown Resistors | | | 7.2.6 Drive Strength Control | | | 7.2.7 Hysteresis and Logic Level Control | | | 7.3 IOMUX (PINCMx) Register Format | | | 7.4 IOMUX Registers | | | 8 GPIO | | | 8.1 GPIO Overview | | | 8.2 GPIO Operation | | | 8.2.1 GPIO Ports | | | 8.2.2 GPIO Read/Write Interface | | | 8.2.3 GPIO Input Glitch Filtering and Synchronization | | | 8.2.4 GPIO Fast Wake | | | 8.2.5 GPIO DMA Interface | | | 8.2.6 Event Publishers and Subscribers | 387 | | 8.3 GPIO Registers | 389 | | 9 ADC | 497 | | 9.1 ADC Overview | 498 | | 9.2 ADC Operation | 499 | | 9.2.1 ADC Core | | | 9.2.2 Voltage Reference Options | 500 | | 9.2.3 Generic Resolution Modes | 500 | | 9.2.4 Hardware Averaging | | | 9.2.5 ADC Clocking | | | 9.2.6 Common ADC Use Cases | 502 | | 9.2.7 Power Down Behavior | 503 | Table of Contents www.ti.com | 9.2.8 Sampling Trigger Sources and Sampling Modes | | |---------------------------------------------------|-----| | 9.2.9 Sampling Period | | | 9.2.10 Conversion Modes | | | 9.2.11 Data Format | | | 9.2.12 Advanced Features | | | 9.2.13 Status Register | | | 9.2.14 ADC Events | | | 9.3 ADC12 Registers | | | 10.1 Comparator Overview. | | | 10.1 Comparator Overview | | | 10.2.1 Comparator Configuration | | | 10.2.2 Comparator Comiguration | | | 10.2.3 Comparator Output. | | | 10.2.4 Output Filter | | | 10.2.5 Sampled Output Mode | | | 10.2.6 Blanking Mode | | | 10.2.7 Reference Voltage Generator | | | 10.2.8 Comparator Hysteresis | | | 10.2.9 Input SHORT Switch | 603 | | 10.2.10 Interrupt and Events Support | 603 | | 10.3 COMP Registers | 606 | | 11 OPA | 635 | | 11.1 OPA Overview | | | 11.2 OPA Operation | | | 11.2.1 Analog Core | | | 11.2.2 Power Up Behavior | | | 11.2.3 Inputs | | | 11.2.4 Output | | | 11.2.5 Clock Requirements | | | 11.2.6 Chopping | | | 11.2.7 OPA Amplifier Modes | | | 11.2.8 OPA Configuration Selection | | | 11.2.9 Burnout Current Source | | | 12 GPAMP | | | 12.1 GPAMP Overview | | | 12.2 GPAMP Operation | | | 12.2.1 Analog Core | | | 12.2.2 Power Up Behavior | | | 12.2.3 Inputs. | | | 12.2.4 Output | | | 12.2.5 GPAMP Amplifier Modes | | | 12.2.6 Chopping | | | 12.3 GPAMP Registers | | | 13 VREF | | | 13.1 VREF Overview | 664 | | 13.2 VREF Operation | 664 | | 13.2.1 Internal Reference Generation | 664 | | 13.2.2 External Reference Input | | | 13.2.3 Analog Peripheral Interface | | | 13.3 VREF Registers | | | 14 UART | | | 14.1 UART Overview | | | 14.1.1 Purpose of the Peripheral | | | 14.1.2 Features | | | 14.1.3 Functional Block Diagram | | | 14.2 UART Operation | | | 14.2.1 Clock Control | | | 14.2.2 Signal Descriptions | | | 14.2.0 General Atoniceolate and Fiolocol | 0/8 | www.ti.com Table of Contents | 14.2.4 Low Power Operation | | |-----------------------------------------------------|--| | 14.2.5 Reset Considerations | | | 14.2.6 Initialization | | | 14.2.7 Interrupt and Events Support | | | 14.2.8 Emulation Modes. | | | 14.3 UART Registers | | | 15 SPI | | | 15.1 SPI Overview | | | 15.1.1 Purpose of the Peripheral | | | 15.1.2 Features | | | 15.1.3 Functional Block Diagram | | | 15.1.4 External Connections and Signal Descriptions | | | 15.2 SPI Operation | | | 15.2.1 Clock Control | | | 15.2.2 General Architecture | | | 15.2.3 Protocol Descriptions | | | 15.2.4 Reset Considerations | | | 15.2.5 Initialization | | | 15.2.6 Interrupt and Events Support | | | 15.2.7 Emulation Modes | | | 15.3 SPI Registers | | | 16 I <sup>2</sup> C | | | 16.1 I <sup>2</sup> C Overview | | | 16.1.1 Purpose of the Peripheral | | | 16.1.2 Features | | | 16.1.3 Functional Block Diagram | | | 16.1.4 Environment and External Connections | | | 16.2 I <sup>2</sup> C Operation | | | 16.2.1 Clock Control | | | 16.2.2 Signal Descriptions | | | 16.2.3 General Architecture | | | 16.2.4 Protocol Descriptions | | | 16.2.5 Reset Considerations | | | 16.2.6 Initialization | | | 16.2.7 Interrupt and Events Support | | | 16.2.8 Emulation Modes | | | 16.3 I2C Registers | | | 17 CRC | | | 17.1 CRC Overview | | | 17.1.1 CRC16-CC111 | | | 17.1.2 CRC Operation | | | 17.2 CRC Operation | | | 17.2.1 CRC Generator implementation | | | · | | | 17.3 CRC Registers | | | 18.1 TIMx Overview | | | 18.1.1 TIMG Overview | | | 18.1.2 TIMA Overview | | | 18.1.3 TIMx Instance Configuration. | | | 18.2 TIMx Operation | | | 18.2.1 Timer Counter. | | | 18.2.2 Counting Mode Control. | | | 18.2.3 Capture/Compare Module | | | 18.2.4 Shadow Load and Shadow Compare | | | 18.2.5 Output Generator | | | 18.2.6 Fault Handler (TIMA only) | | | 18.2.7 Synchronization With Cross Trigger | | | 18.2.8 Low Power Operation | | | 18.2.9 Interrupt and Event Support. | | | 18.2.10 Debug Handler (TIMA only) | | | 10.2. 10 Dobug Handler (Thirk Only) | | Table of Contents www.ti.com | 18.3 Timers (TIMx) Registers | 975 | |----------------------------------|------| | 19 WWDT | | | 19.1 WWDT Overview | 1070 | | 19.1.1 Watchdog Mode | 1070 | | 19.1.2 Interval Timer Mode | 1071 | | 19.2 WWDT Operation | 1071 | | 19.2.1 Mode Selection | 1071 | | 19.2.2 Clock Configuration | 1072 | | 19.2.3 Low-Power Mode Behavior | 1073 | | 19.2.4 Debug Behavior | 1073 | | 19.2.5 WWDT Events | 1073 | | 19.3 WWDT Registers | 1075 | | 20 Debug | 1093 | | 20.1 Overview | 1094 | | 20.1.1 Debug Interconnect | 1094 | | 20.1.2 Physical Interface | 1095 | | 20.1.3 Debug Access Ports | 1096 | | 20.2 Debug Features | | | 20.2.1 Processor Debug | 1096 | | 20.2.2 Peripheral Debug | 1097 | | 20.2.3 EnergyTrace | | | 20.3 Behavior in Low Power Modes | 1097 | | 20.4 Restricting Debug Access | 1098 | | 20.5 Mailbox (DSSM) | 1098 | | 20.5.1 DSSM Events | 1099 | | 20.5.2 DEBUGSS Registers | 1101 | | 21 Revision History | | #### **About This Manual** This manual describes the modules and peripherals of the MSPM0L family of devices. Each description presents the module or peripheral in a general sense. Not all features and functions of all modules or peripherals are present on all devices. In addition, modules or peripherals can differ in their exact implementation on different devices. Pin functions, internal signal connections, and operational parameters differ from device to device. See the device-specific data sheet for these details. #### **Notational Conventions** This document uses the following conventions. - Hexadecimal numbers can be shown with the suffix h or the prefix 0x. For example, the following number is 40 hexadecimal (decimal 64): 40h or 0x40. - · Registers in this document are shown in figures and described in tables. - Each register figure shows a rectangle divided into fields that represent the fields of the register. Each field is labeled with its bit name, its beginning and ending bit numbers above, and its read/write properties with default reset value below. A legend explains the notation used for the properties. - Reserved bits in a register figure can have one of multiple meanings: - Not implemented on the device - Reserved for future device expansion - Reserved for TI testing - Reserved configurations of the device that are not supported - Writing nondefault values to the Reserved bits could cause unexpected behavior and should be avoided. # **Glossary** TI Glossary This glossary lists and explains terms, acronyms, and definitions. # **Related Documentation** # **Support Resources** TI E2E<sup>™</sup> support forums are an engineer's go-to source for fast, verified answers and design help — straight from the experts. Search existing answers or ask your own question to get the quick design help you need. Linked content is provided "AS IS" by the respective contributors. They do not constitute TI specifications and do not necessarily reflect TI's views; see TI's Terms of Use. #### **Trademarks** TI E2E<sup>™</sup> and EnergyTrace<sup>™</sup> are trademarks of Texas Instruments. Arm<sup>®</sup> and Cortex<sup>®</sup> are registered trademarks of Arm Limited. All trademarks are the property of their respective owners. Read This First www.ti.com This page intentionally left blank. # Chapter 1 **Architecture** The device architecture includes the bus organization, the platform memory map, and the boot configuration. | 1.1 Architecture Overview | 12 | |---------------------------|----| | 1.2 Bus Organization | | | 1.3 Platform Memory Map | | | 1.4 Boot Configuration | 16 | | 1.5 Factory Constants | 38 | #### 1.1 Architecture Overview MSPM0 L-series MCUs (MSPM0Lxx) combine 32-bit compute performance together with precision analog to enable a wide variety of sensing, interface, control, and housekeeping applications. The device architecture supports both general-purpose and low-power applications through a flexible, easy-to-configure power management and clocking system with fast wake-up from low-power modes. MSPM0 L-series devices also offer support for 125°C ambient temperature and AEC-Q100 Grade 1 qualification. This chapter introduces the device architecture, including an overview of the power domains and bus organization, the platform memory map, and the device boot configuration. # 1.2 Bus Organization There are three main power domains on MSPM0Lxx devices: - PD1 (power domain 1) which contains the CPU subsystem, memory interfaces, and high-speed peripherals - PD0 (power domain 0) which contains the low-speed low-power peripherals - The supply voltage (VDD) which powers IOs, analog modules, and limited logic directly from the supply The PD1 domain is disabled in certain operating modes to minimize power consumption. The PD0 domain supports ultra-low-power performance and is always enabled in operating modes in which the core regulator is operating. There are four main data buses on MSPM0Lxx devices: - The AHB bus matrix, which interfaces the CPU to the device memory systems (ROM, SRAM, and flash memory) and the peripheral buses - The PD1 (power domain 1) CPU-only peripheral bus, clocked from MCLK - The PD1 (power domain 1) peripheral bus, clocked from MCLK - The PD0 (power domain 0) peripheral bus, clocked from ULPCLK The CPU and the DMA controller are the only two bus controllers in the device. Arbitration between the CPU and the DMA for shared peripherals happens between the CPU-only PD1 peripheral bus and the CPU/DMA PD1 peripheral bus. The DMA does not have access to peripherals on the CPU-only PD1 peripheral bus or the CPU bus matrix (the green components in the bus diagram). As such, the CPU can access peripherals on the CPU-only PD1 peripheral bus at the same time that the DMA is processing a transaction on the PD1 or PD0 bus. Likewise, the CPU can access SRAM or flash memory through the AHB bus matrix at the same time that the DMA is processing a transaction, so long as the DMA is not accessing the same memory that the CPU is attempting to access. Arbitration between the CPU and the DMA for memory systems (SRAM or flash memory) happens at the memory interface itself. All arbitration between the CPU and DMA is done on a round-robin basis. Figure 1-1. MSPM0Lxx Bus Organization #### Note This is a generic diagram of the typical peripherals on an MSPM0Lxx device and their respective bus locations. Not all devices have all peripheral options shown here. To determine the peripherals which are available on a given device, see the device-specific data sheet. The GPIO and ADC peripherals (the orange components in the bus diagram) have special capabilities to enable both fast register access from the CPU and operation in low power operating modes. - GPIO peripherals interface to the system through two mechanisms: the PD1 peripheral bus, and the Arm® Cortex®-M0+ single-cycle high-speed IO bus. - Accesses from the CPU to any GPIO registers are transacted through the single-cycle IO bus for best performance, enabling fast toggling of IO under software control. - The GPIO DOUT registers (data out) are also available on the PD1 peripheral bus, primarily so that the DMA can be used to load values to the GPIO DOUT registers. - While the bus interfaces to the GPIO peripherals are in the PD1 power domain (for best read/write performance), the GPIO logic itself is in the PD0 power domain so that it is available in all operating modes in which the core regulator is active. - ADC peripherals interface to the system through the PD1 peripheral bus but contain functional logic in the PD0 power domain. - ADC peripheral register accesses are processed through the PD1 peripheral bus (for best read/write performance) - The the ADC conversion logic is in the PD0 power domain to enable running timer-triggered ADC conversions without CPU interaction in certain low-power modes when PD1 is disabled. # 1.3 Platform Memory Map All MSPM0Lxx devices share a common platform memory map. Peripherals are assigned a fixed address space and have the same address space on all devices within the family. The memory map is compliant with the standard Arm Cortex-M memory regions. Table 1-1. Top Level Memory Map | Memory Region | Start Address | End Address | Description | |---------------|---------------|-------------|---------------------------------------------------------------------------------| | Code | 0x0000.0000 | 0x1FFF.FFFF | Flash memory and ROM | | SRAM | 0x2000.0000 | 0x3FFF.FFFF | SRAM | | Peripheral | 0x4000.0000 | 0x5FFF.FFFF | Global peripheral memory-mapped registers and global non-executable data memory | | Subsystem | 0x6000.0000 | 0x7FFF.FFFF | Local CPU subsystem memory-mapped registers | | System PPB | 0xE000.0000 | 0xE00F.FFFF | Arm private peripheral bus | # 1.3.1 Code Region The code region contains the flash memory used to store executable code and data. Accesses to the flash memory from the CPU through the code region are processed through the AHB bus matrix to the flash read interface directly. The flash memory is aliased to two address spaces in the code region: one returning ECC-corrected data, the other providing uncorrected (raw) data. See Section 5.2.3.1 for the detailed flash memory map. Note that not all MSPM0Lxx devices have ECC-protected flash memory. See the device-specific data sheet to determine if ECC is present. The code region also contains the read-only memory (ROM) used for the TI device boot code and the bootstrap loader. The ROM is only available during the initial device boot process. #### 1.3.2 SRAM Region The SRAM region contains the system memory (SRAM). The SRAM supports zero wait state access at the maximum MCLK frequency (32 MHz). Accesses to the SRAM from the CPU are processed through the AHB bus matrix to the SRAM interface directly. The SRAM region supports devices with up to 1MB of SRAM. See the device-specific data sheet for the amount of SRAM present on a given device. Certain devices optionally support parity or parity and ECC checking of the SRAM. Refer to the device-specific data sheet to determine if a device supports ECC or parity checked SRAM. # **Parity Checking** In the case of parity checking (if available), 1 parity bit is provided per 8 data bits. Parity checking is capable of detecting a single bit error in the corresponding 8 bits of data (SED). Writing data to a parity checked address updates the corresponding parity bits based on the new data. Reading data from a parity checked address checks the read data against the corresponding parity bits. Upon a read, if the data does not match the corresponding parity bits, a parity error is generated. For information on how parity errors are handled by the device, see Section 2.4.10 #### **Aliased Subregions** The physical SRAM on a device is aliased into multiple address subregions in the overall SRAM region, as shown in Table 1-2. The default, parity checked, and unchecked address subregions all map to the same physical SRAM memory. The difference between each aliased subregion is in the type of integrity checks which are applied to the access. For example, writing data to address 0x2000.0000 (the default subregion) will cause the same data to appear at address 0x2020.0000 (the unchecked subregion). The default subregion (0x2000.0000) is available on all MSPM0 devices, and when used, provides the highest level of integrity checking available on the device. The parity checked subregion (0x2010.0000) is available on devices which support ECC and/or parity checking, and accesses are always processed with parity checking. The unchecked subregion (0x2020.0000) is available on all devices, and when using this subregion, no integrity checks are performed. The parity/ECC code subregion (0x2030.0000) is available on devices with ECC or parity checking, and it returns the parity or ECC code which corresponds to the address being read. #### **Note** To improve robustness, there is no mechanism provided to disable parity checking of the parity-checked SRAM address space. To operate without parity checking, link the application against the unchecked SRAM address space. Table 1-2. SRAM Region Memory Map | Subregion | Start | End | Description | |-----------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Default | 0x2000.0000 | 0x200F.FFFF | <ul> <li>The highest available integrity check on the device is always applied to accesses in this subregion:</li> <li>If the device supports ECC, this subregion is ECC checked.</li> <li>If the device only supports parity (no ECC), this subregion is parity checked and accesses are equivalent to accesses to the parity checked subregion.</li> <li>If the device does not support ECC or parity, no checks are applied to accesses in this subregion and the region is equivalent to the unchecked subregion.</li> </ul> | | Parity checked | 0x2010.0000 | 0x201F.FFFF | If the device supports parity, accesses to this subregion are parity checked. | | Unchecked | 0x2020.0000 | 0x202F.FFFF | No ECC or parity checks are applied to accesses in this subregion. | | Parity/ECC code | 0x2030.0000 | Ox202F.FFFF No ECC or parity checks are applied to accesses in this substrated in the device supports parity or ECC, the parity or ECC or directly accessed through this subregion: If the device supports ECC, access to any address we boundary returns the 8 bits corresponding to the ECC the application is linked against the default region) or bits (one per byte) if the application is linked against checked region. If the device supports parity only, access to any address a 32-bit boundary returns the 4 parity bits (one per byte) application is linked against the default region or parity region. If the device does not support ECC or parity, access region always returns zeros. | | #### Note When ECC checking is used on devices which support ECC, writes to the SRAM require two cycles to complete. Read accesses only require a single cycle and do not incur any additional performance penalty. On devices supporting parity or ECC, it is possible for application software to partition the usage of the physical SRAM into arbitrary zones which are intended to be ECC checked, parity checked, or unchecked. For example, if a device has 32KB of total SRAM memory, and it supports ECC and parity checking, it is possible to configure the application software to link against two subregions, one being ECC checked and the other being parity checked. #### Note It is not recommended to mix and match ECC checked, parity checked, and unchecked accesses to the same memory locations, as this can result in unintended parity/ECC errors. For example, if an SRAM memory location is written to through the parity checked subregion on a device which supports ECC, and then later that location is read through the default (ECC checked) subregion, an ECC error may be generated because the data was written with parity stored to the ECC/parity code memory, as opposed to the correct ECC code being stored. #### Note The SRAM contents may be random at power-up or when existing SHUTDOWN mode. A read of an SRAM location through an ECC/parity checked region which has not yet been written to may result in a ECC/parity error being detected, causing a hard fault in the processor. Ensure that all SRAM locations are initialized first before being read. #### 1.3.3 Peripheral Region The peripheral region contains the memory-mapped peripherals on the three peripheral buses. The flash memory is also aliased in the peripheral region. Table 1-3. Peripheral Region Memory Map | Туре | Start | End | Description | |----------------------|-------------|-------------|----------------------------------------------------------------| | Peripherals | 0x4000.0000 | 0x40FF.FFFF | Memory-mapped registers of peripherals on the peripheral buses | | Aliased flash memory | 0x4100.0000 | 0x41FF.FFFF | See Section 5.2.3.1 | # 1.3.4 Subsystem Region The subsystem region contains memory-mapped registers which are specific to the CPU subsystem and do not need to be accessed globally. See the CPU subsystem chapter for the memory-mapped registers in the subsystem region. #### 1.3.5 System PPB Region The system PPB region contains memory-mapped registers on the Arm private peripheral bus. These registers are tightly coupled to the CPU and are the interface for peripherals such as the memory protection unit (MPU), SysTick timer, and CPU power management and reset functions. # 1.4 Boot Configuration After a BOOTRST, the device always executes the start-up boot routines to configure the device for operation before starting the main application. Boot routines are executed from read-only memory (ROM) before the main application is started. There are two boot routines: the boot configuration routine (BCR), and the bootstrap loader (BSL). The boot configuration routine sets up the device security policies, configures the device for operation, and optionally starts the BSL. The BSL, if started by the BCR, can be used to program and/or verify the device memory (flash and SRAM) through the use of a standard serial interface (UART or I2C). After the start-up routines have successfully completed execution, the CPU is reset and the application is always started by unconditionally fetching the stack pointer (SP) and reset vector from 0x0000.0000 and 0x0000.0004 of the flash memory. To enable secure boot, this single point of entry into the application code is enforced by the boot sequence. It is not possible to boot into a different memory location. #### 1.4.1 Configuration Memory (NONMAIN) The NONMAIN is a dedicated region of flash memory which stores the configuration data used by the BCR and BSL to boot the device. The region is not used for any other purpose. The BCR and BSL both have configuration policies which can be left at their default values (as is typical during development and evaluation), or modified for specific purposes (as is typical during production programming) by altering the values programmed into the NONMAIN flash region. The BCR and BSL configuration data structures are both contained within a single flash sector in the NONMAIN flash memory region. To change any parameter in the boot configuration, it is necessary to erase the entire NONMAIN sector and re-program both the BCR and BSL configuration structures with the desired settings. The configuration data in the NONMAIN flash region is not affected by a mass erase command, but it is erased and re-programmed to factory defaults by a factory reset command sent to the BCR via the debug sub system mailbox (DSSM) over SWD. The NONMAIN flash is also erased by a factory reset command sent to the BSL using the UART or I2C BSL interface. However, unlike the DSSM factory reset, the BSL factory reset does not program TI factory defaults to the NONMAIN memory following the erase. As such, it is the responsibility of the host which is connected to the MSPM0 target (via the BSL interface) to re-program the NONMAIN memory with a valid configuration before terminating the BSL session. #### Note If a factory reset command is executed through the BSL, and a valid NONMAIN configuration is not programmed back into the device before the BSL session is terminated, the device will assume a maximally restrictive state upon the next reset cycle, and it will not be possible to access the device via SWD or the BSL. Always ensure that a valid NONMAIN configuration is programmed back when using the BSL factory reset command. The address ranges for the NONMAIN data structures are given in Table 1-4. A detailed breakdown of the NONMAIN region is provided at the end of this section. | NONMAIN Section | Start Address | End Address | | | | | | |-----------------------|---------------|-------------|--|--|--|--|--| | BCR Configuration | 41C0.0000h | 41C0.005Bh | | | | | | | BCR Configuration CRC | 41C0.005Ch | 41C0.005Fh | | | | | | | BSL Configuration | 41C0.0100h | 41C0.0153h | | | | | | | BSL Configuration CRC | 41C0.0154h | 41C0.0157h | | | | | | # 1.4.1.1 CRC-Backed Configuration Data The BCR configuration data and BSL configuration data structures in the NONMAIN memory each include a CRC32 value corresponding to the CRC32 digest of the respective structure. During the device boot process, the BCR will compute the CRC digest of the data structures and compare it with the stored CRC values before the data contained within the structures is trusted for use. #### **BCR Configuration CRC Fail Handling** In the event that the BCR configuration data (which contains the SWD policies, BSL enable/disable policy, and flash memory protection and integrity check policies) fails its CRC check during boot, a catastrophic boot error results and the following limitations are imposed: - The error cause will be logged in the CFG-AP as a boot diagnostic - The BSL will not be invoked, even if it was configured to be enabled - · The user application is not started - · No application debug access is enabled - A pending SWD factory reset command, if enabled or enabled with password, is honored - · A pending TI failure analysis flow entry, if enabled, is honored - The boot process will re-attempt up to 3 times - If the 2nd or 3rd attempt pass, the device boots normally - If the 3rd attempt does not pass, no further boot attempts are made until the next BOR or POR The benefit of the this CRC check is that any bit flips in configuration data, such as the static write protection configuration (which is a pillar of secure boot), may be detected with high confidence during the boot process. The fail handling procedure explicitly prevents the BSL and user application from running, and the only supported options (SWD factory reset and TI FA) are protected by 16-bit pattern-match fields. #### **BSL Configuration CRC Fail Handling** If the BSL configuration data (which contains the BSL password and BSL policies) fails the CRC check during BSL invocation, a catastrophic boot error results and the following limitations are imposed: - · The error cause is logged in the CFG-AP as a boot diagnostic - The BSL is not invoked, even if it was configured to be enabled - · The user application is not started - · No application debug access is enabled - The boot process re-attempts up to 3 times - If the 2nd or 3rd attempt pass, the device boots normally - If the 3rd attempt does not pass, no further boot attempts are made until the next BOR or POR The benefit of this CRC check s that any bit flips in the BSL configuration data may be detected with high confidence during the invoke process. The failure handling procedure prevents the BSL from starting with invalid data which could lead to a loss of security. #### TI Factory Trim Data CRC Fail Handling In addition to the user-specified configuration data, if the TI factory trim fails its CRC check during boot, a catastrophic boot error will also result with the following limitations: - The error cause will be logged in the CFG-AP as a boot diagnostic - · The BSL will not be invoked, even if it was configured to be enabled - · The user application is not started - · No application debug access is enabled - · A pending TI failure analysis flow entry, if enabled, is honored - The boot process will re-attempt up to 3 times - If the 2nd or 3rd attempt pass, the device boots normally - If the 3rd attempt does not pass, no further boot attempts are made until the next BOR or POR #### 1.4.1.2 16-bit Pattern Match for Critical Fields Critical policies in the BCR configuration memory, such as the SWD security policies, are implemented as 16-bit pattern-match fields in the NONMAIN memory, with the following characteristics: - An exact pattern match is required to enable lower security states - Any value in the 16-bit field not matching the exact defined patterns results in a maximally secure state for the respective parameter This behavior prevents single bit flips from causing the device to enter a lower security state than that which was originally specified. #### 1.4.2 Boot Configuration Routine (BCR) The boot configuration routine is the first firmware to run on the device after a BOOTRST. The BCR manages the following at boot time: - · Configuring the debug interface security policy - · Optionally executing a mass erase - Optionally executing a factory reset - Configuring the flash memory static write protection policy - Optionally verifying the integrity of some or all of the application firmware (with a 32-bit CRC) - Optionally starting the bootstrap loader (BSL) #### 1.4.2.1 Serial Wire Debug Related Policies The serial wire debug related policies configure the functionality which is available through the device's physical debug interface (SWD). By default, MSPM0 devices come from TI in an unrestricted state. This state allows for easy production programming, evaluation, and development. However, this unrestricted state is not recommended for mass production, as it leaves a large attack surface present. To accommodate a variety of needs while keeping the configuration process simple, MSPM0 devices support three generic security levels: no restrictions (Level 0), custom restrictions (Level 1), and fully restricted (Level 2). Table 1-5 shows the three generic security levels, from least restrictive to most restrictive. There are 4 main uses of the SWD interface for which protection needs to be considered: - Application debug access, which includes: - Full access to the processor, memory map, and peripherals through the AHB-AP - Access to the device EnergyTrace+ state information through the ET-AP - Access to the device power state controls for debug through the PWR-AP - · Mass erase access, which includes: - Ability to send a command through SWD to erase the MAIN memory region while leaving the NONMAIN device configuration memory intact - · Factory reset access, which includes: - Ability to send a command through SWD to erase the MAIN memory region and reset the NONMAIN device configuration memory to TI factory defaults (Level 0) - TI failure analysis access, which includes: - Ability for TI to initiate a failure analysis return flow through SWD (note that the TI FA flow always forces a factory reset before FA access is given to TI; this ensures that TI does not have any mechanism to read proprietary customer information stored in the device flash memory when a failure analysis flow is initiated) | Table | 1-5. | Generic | Security | Levels | |-------|------|---------|----------|--------| | Iabic | 1-0. | COLICIE | Occurry | EC4613 | | Level | Scenario | SW-DP Policy | App Debug<br>Policy | Mass Erase<br>Policy | Factory Reset<br>Policy | TI FA Policy | | | | | | |-------|---------------------|--------------|------------------------|----------------------------------------------------------|-----------------------------|--------------|--|--|--|--|--| | 0 | No restrictions | EN | EN | EN | EN | EN | | | | | | | 1 | Custom restrictions | EN | EN, EN with<br>PW, DIS | EN, EN with<br>PW, DIS | EN, EN with PW, DIS EN, DIS | | | | | | | | 2 | Fully restricted | DIS | Don't care | Don't care (access not possible with SW-DP disabled) (1) | | | | | | | | <sup>(1)</sup> When the SW-DP policy is **SW-DP disabled**, the mass erase and factory reset policies are a don't care from the point of view of the SWD interface. However, if the bootstrap loader (BSL) is enabled, the mass erase and factory reset policies do impact what functionality is available through the BSL. See the BSL security section for details on securing the BSL. #### 1.4.2.1.1 SWD Security Level 0 SWD security level 0 is the least restrictive SWD security state. This is the default state of a new device from TI, and it is also the state of a device following a successful factory reset. There are no restrictions on application debug access, mass erase, factory reset, for failure analysis in this state. #### When to Use This State Level 0 is well suited for prototyping and development, as it allows programming of the device memory and debug of the processor and peripherals. # When to Not Use this State Level 0 should not be used in mass production. An attacker would have full freedom to read the contents of the device memory, manipulate the execution of the device, and possibly change the flash memory contents (depending on the flash memory write protection scheme). #### 1.4.2.1.2 SWD Security Level 1 SWD security level 1 allows for a customized security configuration. The physical debug port (SW-DP) is left enabled, and each function (application debug, mass erase command, factory reset command, and TI failure analysis) may be individually enabled, disabled, or (in some cases) enabled through password authentication, providing considerable flexibility to tailor the device behavior to specific use-cases. #### When to Use This State Level 1 is well suited for restricted prototyping/development scenarios and for mass production scenarios where the desire is to retain certain SWD functions (such as factory reset and TI failure analysis) while disabling other functions (such as application debug). Common examples of Level 1 customized configurations are given in Table 1-6. # **Table 1-6. Examples of Level 1 Configurations** | | Configuration | | | | | | | | |------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|------------|------------------|-------|--|--|--|--| | Level 1 Scenario | App Debug | Mass Erase | Factory<br>Reset | TI FA | | | | | | This scenario restricts debug access with a user-specified password, but it leaves the factory reset and TI failure analysis available. This configuration allows field debug (with password), and it also allows the device to be brought back to the default "Level 0" state through factory reset. | EN with PW | DIS | EN | EN | | | | | | This scenario does not allow debug. It does allow factory reset, but only with a user-specified password. This provides a way to open up a device in the field by clearing the MAIN memory contents and bringing the device back to a "Level 0" state if the password is known. Importantly, even if the factory reset password were compromised, it would not be possible for an attacker to read proprietary information in the MAIN flash memory. | DIS | DIS | EN with PW | EN | | | | | | This scenario does not allow debug and it does not allow TI failure analysis. This prevents TI from performing a factory reset and further FA activities on the device, unless the user executes a factory reset with their user-specified password before returning the devices to TI for FA. | DIS | DIS | EN with PW | DIS | | | | | #### Note Level 1 is the recommended configuration for most standard production use-cases. For applications which do not require secure boot, TI recommends using Level 1 in production with factory reset left enabled (with password) and TI failure analysis left enabled. In such a configuration, the device may be recovered to a less restrictive state after provisioning either by the user (with password) or by TI (through the failure analysis return flow). In use-cases requiring maximum secure boot assurance, a more restrictive Level 1 or Level 2 may be used for production, with the trade-off that devices may not be recoverable to a less restrictive state once provisioned. #### When to Not Use this State Level 1 should not be used during prototyping if complete access to the device is desired; in such a case, Level 0 should be used instead. Level 1 should also not be used in a mass production scenario where a maximally restrictive state is desired and no SWD functions are to be enabled; in such a case, Level 2 should be used instead as it directly disables the complete SWD physical interface and minimizes the possibility of misconfiguration. #### Note If a device is configured with application debug and factory reset disabled, the only way for a user to restore debug access to the device is if the user application code provides a mechanism to change the NONMAIN configuration to a less restrictive state. If the NONMAIN is locked through static write protection then the state is not reversible and there is no way for a user to re-gain debug access. #### 1.4.2.1.3 SWD Security Level 2 SWD security level 2 configures the device in a maximally restrictive state. The physical debug port (SW-DP) is completely disabled, and all of the SWD-accessible functions (application debug, mass erase, factory reset, and TI failure analysis) are not accessible through SWD, regardless of their individual configuration. When level 2 is selected (SW-DP disabled), the application debug configuration and TI failure analysis configuration fields are don't care fields which do not impact the device configuration. If the BSL is disabled, then the mass erase and factory reset configuration fields are also don't care fields. However, if the BSL is enabled, then the mass erase and factory reset configuration fields are still used by the BSL to authorize mass erase or factory reset commands originating from the BSL interface. #### When to Use This State Level 2 should only be used for mass production when no further access to any SWD functions is required and a maximally secure state is desired for the device. #### When to Not Use this State Level 2 should not be used in the following cases: - · Future application debug and/or re-programming through SWD may be required - The user would like TI to be able to perform failure analysis on the device - The user would like to be able to remove proprietary information from the flash memory by sending a mass erase or factory reset command through SWD #### Note Once a device is configured for level 2 (SW-DP disabled), further access to the device through SWD **is not possible**. The only way to bring a device back to a level 0 or level 1 state with SWD access restored is if the BSL and factory reset are both enabled (allowing a BSL factory reset command to be sent), or a mechanism in the user application code is included which can change the NONMAIN configuration to a less restrictive state. In either scenario, if the NONMAIN is locked through static write protection then the level 2 state is not reversible and there is no way to re-gain SWD access. #### 1.4.2.2 SWD Mass Erase and Factory Reset Commands The BCR provides mass erase and factory reset functionality through commands sent to the device over SWD from a debug probe using the debug subsystem mailbox (DSSM). These commands are not available in SWD security level 2, but they are optionally available in security level 0 and 1. When the device is not configured for SWD security level 2, the mass erase and factory reset commands can be individually configured to be enabled, enabled with a unique 128-bit password, or disabled. By default, both commands are enabled. The SWD mass erase and factory reset DSSM commands superseded any static write protection policies. For example, if SWD factory reset is configured to be enabled or enabled with password, the BCR configuration data can be reset even if it is statically write protected. #### **SWD Mass Erase** A SWD mass erase is an erase of the MAIN flash regions only, which typically includes the user application. The BCR and BSL policies stored in the NONMAIN flash region are not affected by a mass erase. A mass erase is useful for erasing all application code and data while leaving the device configuration itself intact. To set the mass erase command mode and password, configure the BOOTCFG3.MASSERASECMDACCESS field and the PWDMASSERASE password fields in the NONMAIN memory. #### **SWD Factory Reset** A SWD factory reset is an erase of the MAIN flash regions followed by a reset of the NONMAIN flash region to default values. Such an erase is useful for completely resetting the BCR and BSL device boot policies while also erasing the application code and data. To set the factory reset command mode and password, configure the BOOTCFG3.FACTORYRESETCMDACCESS field and the PWDFACTORYRESET password fields in the NONMAIN memory. #### 1.4.2.3 Flash Memory Protection and Integrity Related Policies The flash memory protection and integrity policies specify which sectors of flash memory are locked from modification, as well as which sectors are to be checked for integrity during the boot process before the user application is started. #### 1.4.2.3.1 Locking the Application (MAIN) Flash Memory MSPM0 MCUs implement a static write protection scheme to lock out user defined sectors in the MAIN flash region from any program/erase operations at runtime. The desired static write protection scheme is configured as a part of the boot security policies in the NONMAIN flash region. #### **Purpose** Static write protection enables placement of a fixed, user-defined, application in the flash memory which has the following characteristics: - Once programmed and locked, it is not modifiable by the application code or ROM bootloader - If placed at the beginning of the flash memory, it is guaranteed to always be the first code which executes when the ROM boot configuration routine transfers execution to the user application MSPM0 static write protection supports both characteristics, which must be satisfied to implement a secure boot image manager. #### Capabilities Any sector which is configured in the NONMAIN to be write-locked will be functionally immutable when the boot configuration routine transfers execution to either the bootstrap loader or the user application code in MAIN flash. Any attempt to program or erase a statically protected sector by the application code or the bootstrap loader will result in a hardware flash operation error, and the sector will not be modified. While static write protection prevents any modification by application code or the boot loader, a mass erase or factory reset command sent through the SWD interface would be honored. If this behavior is not desired, the mass erase and/or factory reset SWD commands may be protected with unique passwords or disabled altogether (see the SWD policies). To completely remove any means of modifying statically write protected MAIN flash sectors, the mass erase and factory reset commands (or the SW-DP) must be disabled, and the NONMAIN boot configuration memory must also be statically write protected to prevent application code from changing the underling write protection scheme by modifying the contents NONMAIN region. This is discussed in the following section. #### 1.4.2.3.2 Locking the Configuration (NONMAIN) Flash Memory MSPM0 MCUs implement a static write protection scheme to lock out the NONMAIN flash region from any program/erase operations at runtime. The write protection scheme is configured as a part of the boot security policies in the NONMAIN flash region. ## **Purpose** By default from TI, the NONMAIN configuration memory (which contains the user-specified boot security policies and bootstrap loader policies) is not write protected. This enables the NONMAIN to be erased by the user during provisioning and re-programmed with the user-specified policies which will be used in mass production. In many cases, it is desirable for the configuration memory to be locked once it has been provisioned. Locking the configuration memory has the benefit of preventing any unauthorized modification of the security policies, bootstrap loader policies, and static write protection policies by either the bootstrap loader or the application code itself. In most applications, devices in mass production do not require modification of the configuration memory, even when the device firmware is updated. #### **Capabilities** When configured to be protected, the entire NONMAIN region will be write-locked and will be functionally immutable when the boot configuration routine transfers execution to either the bootstrap loader or the user application code in MAIN flash. Any attempt to program or erase the NONMAIN by the application code or the bootstrap loader will result in a hardware flash operation error, and the sector will not be modified. While static write protection prevents any modification by application code or the boot loader, a factory reset command sent through the SWD interface would still be honored. If this behavior is not desired, the factory reset SWD command may be protected with a unique password or disabled altogether (see the SWD policies). To completely remove any means of modifying the NONMAIN configuration memory, the factory reset command and TI FA (or the SW-DP) must be disabled. #### **Note** When the NONMAIN is statically write protected, and the factory reset command and TI FA (or the SW-DP) are disabled, the NONMAIN is equivalent to immutable read-only memory, and it is no longer possible to change the device configuration by any means. Further, if any MAIN memory region sectors are configured with static protection, these sectors also can not be modified by any means and may be considered as immutable. #### 1.4.2.3.3 Static Write Protection NONMAIN Fields Write protection may be enabled on a per-sector basis for the first 32 sectors of the MAIN flash memory. For the remaining sectors of flash memory, write protection may be enabled per 8 sectors. To set a static write protection policy, configure the FLASHSWP0 and FLASHSWP1 fields in the NONMAIN memory. #### Note Mass erase and factory reset commands sent to the BCR via the debug sub system mailbox (DSSM) will override the specified static write protection policy. If this behavior is not desired, configure the mass erase and factory reset commands to be enabled with password or disabled. Note that mass erase and factory reset commands sent to the BSL will respect the specified static write protection policy (the BSL has the same permissions as application code). # 1.4.2.4 Application CRC Verification The BCR supports executing a complete CRC32 integrity check of the application code and data contained in the MAIN flash regions during the boot process before starting the user application. This is useful to ensure the integrity of some or all of the application code and data before executing it. To enable the CRC32 integrity check at boot, the following information must be programmed into the BCR configuration in NONMAIN flash memory: - 32-bit starting address of the CRC check (APPCRCSTART.ADDRESS field) - The length of the application (specified in bytes) for which the CRC check is applied (APPCRCLEN.LENGTH field) - The precalculated 32-bit CRC value to test against (APPCRC.DIGEST field) - The enabled key value for the CRC check (BOOTCFG3.APPCRCMODE field) In the event that an application CRC check fails at boot, the application in MAIN flash is not started. If the boot strap loader is enabled, it is entered. If the BSL is not enabled, then the boot fails. #### 1.4.2.5 Fast Boot The execution time of the BCR can be reduced by enabling fast boot mode. Fast boot mode, when enabled, speeds up the boot process using the following methods: - Limiting the BSL entry methods. When fast boot mode is enabled, only the SYSCTL register invoke method and the DSSM invoke method can be used to enter the bootloader. The other BSL invoke conditions are not tested (for example, pin based invoke). - Bypassing the application CRC check (even if the application CRC check is enabled). To enable fast boot mode, set the fast boot mode to enabled in the BOOTCFG2.FASTBOOTMODE field in the NONMAIN flash memory. # 1.4.2.6 Bootstrap Loader (BSL) Enable/Disable Policy The bootstrap loader (BSL) provides a means to program and verify the device memory through a standard serial interface (UART or I2C), as opposed to the serial wire debug interface. The BSL has its own configuration policy, but the BCR determines if the BSL is enabled to be invoked, or if it is to be disabled (non-invokable). Since the BSL presents an additional attack surface, if it is not used in an application it may be disabled in the user-specified boot security policies. If the BSL is used in an application, then the BSL security settings (including the BSL access password) are managed in the BSL configuration policy. #### 1.4.2.6.1 BSL Enable The bootstrap loader (BSL) can be enabled or disabled by setting the bootloader mode to enabled or disabled in the BOOTCFG2.BSLMODE field in the NONMAIN flash memory. When the BSL is disabled, it is not possible to enter the bootloader through any invocation mechanism. #### 1.4.3 Bootstrap Loader (BSL) The bootstrap loader (BSL) provides a method to program and/or verify the device memory through a standard UART or I2C serial interface. Key features of the BSL which are accessible through the serial interface include: - Programming and erase of flash memory - · Ability to return a firmware version number through a pointer to the main flash - · Ability to specify a hardware invoke GPIO - Ability to enable code/data read-out (disabled by default) - · Ability to return a 32-bit CRC of a code/data region (1KB minimum region size) to verify programming - Access is always protected with a 256-bit password - Configurable security alert handling for resisting brute force attacks - Support for MAIN flash plug-ins to enable additional interfaces beyond UART and I2C For a complete description of the BSL features, see the BSL user's guide. The BSL can be completely disabled if desired by properly configuring the BSL mode in the BCR configuration in the NONMAIN flash. See the BSL Enable section for details on enabling or disabling the BSL. #### 1.4.3.1 GPIO Invoke The bootloader supports hardware invoking after a BOOTRST through the use of a GPIO. The BSL configuration in the NONMAIN flash memory contains the pad, pin, and polarity definition for the GPIO invocation. Devices come configured from TI for a specific GPIO and polarity, but software can change this default by modifying the GPIO pin configuration in the BSL configuration in NONMAIN flash memory. To specify the polarity of the BSL\_invoke pin, configure the BSLCONFIG0.BSLIVK\_LVL field in the NONMAIN memory. To specify the device pin to be used for BSL\_invoke, configure the following fields in the NONMAIN memory: - Store the IOMUX PINCMx index into the BSLCONFIG0.BSLIVK PAD NUM field - Store the GPIO port (A or B) into the BSLCONFIG0.BSLIVK GPIOPORT field - Store the GPIO pin (0-31) into the BSLCONFIG0.BSLIVK GPIOPIN field See the device specific data sheet to determine the default BSL invoke GPIO. #### 1.4.3.2 Bootstrap Loader (BSL) Security Policies The BSL security policies are interpreted by the boot loader when it is invoked, and include the following parameters: - BSL access password, described in Section 1.4.3.2.1 - BSL read-out policy, described in Section 1.4.3.2.2 - BSL security alert policy (tamper detection), described in Section 1.4.3.2.3 #### 1.4.3.2.1 BSL Access Password Access to the BSL is always protected by a 256-bit user-specified password. There is no option to disable the password. The password must be provided to the BSL after invocation for access to most BSL functions to be granted. When the password is not provided, the only BSL commands allowed are *Get Identity* and *Start Application*. If a wrong password is provided to the BSL, the BSL halts for 2 seconds, after which an additional attempt can be made to send the correct password. After three failed password attempts, the security alert function is activated (see Section 1.4.3.2.3). #### 1.4.3.2.2 BSL Read-out Policy The BSL optionally supports read-out of the device memory for debug and/or diagnostic purposes (after access to the BSL has been granted with a correct password match). By default, this capability is disabled for security to prevent extraction of sensitive code and/or data from the device. When the BSL read-out policy is disabled, the only information which may be provided to a host through the BSL interface is a CRC32 digest of a memory segment with a minimum segment length of 1 kilobyte. If direct read-out of the device memory is desired, it may be enabled in the BSL configuration. # 1.4.3.2.3 BSL Security Alert Policy The BSL provides an alert mechanism for taking action when tampering is suspected. Specifically, if an incorrect password is passed to the BSL 3 times during one BSL session, the security alert is activated and the BSL may respond in one of three different ways based on the specified security alert policy: - 1. Issue a factory reset (erasing the MAIN flash and resetting the NONMAIN flash regions) - 2. Disable the BSL (leaves the MAIN flash intact but re-configures the NONMAIN to block BSL access) - 3. Ignore (do not modify the configuration and allow password attempts to continue) #### Note Options 1 and 2 require that the NONMAIN flash region not be statically write protected (see Section 1.4.2.3.2). When option 1 is selected, any MAIN memory region which is configured to be statically write protected (see Section 1.4.2.3.1) will not be erased during the factory reset. # 1.4.3.3 Application Version The BSL supports returning an application version number through the BSL serial interface. This allows the BSL host to interrogate the firmware version without being able to read the firmware. The version field is 32 bits in length. To link the application version command to a version number programmed in the main flash, program the address of the version number in the BSLAPPVER.ADDRESS field in NONMAIN flash memory. The version data is only returned if the address specified in BSLAPPVER.ADDRESS corresponds to a valid flash memory address. #### 1.4.3.4 BSL Triggered Mass Erase and Factory Reset It is possible to send a mass erase or factory reset command to the BSL. The commands work in a similar way as the SWD mass erase and factory reset commands, with several key exceptions. #### **BSL Mass Erase** A mass erase command sent to the BSL will erase the MAIN flash memory. Any MAIN flash memory sectors which are configured to be statically write protected (via the FLASHSWP0 and FLASHSWP1 fields in the NONMAIN configuration memory) will not be erased. The NONMAIN device configuration memory is never erased by a mass erase. #### **BSL Factory Reset** A factory reset command sent to the BSL will first perform a BSL mass erase to erase the main flash memory (excluding any sectors which are statically write protected). Then, it will additionally erase the NONMAIN device configuration memory. A BSL factory reset command is only accepted if the following are true: - 1. The NONMAIN memory itself is not currently configured to be statically write protected (BOOTCFG4.NONMAINSWP field in the NONMAIN is set to not protected) - 2. The factory reset command is not configured to be disabled (BOOTCFG3.FACTORYRESETCMDACCESS field in the NONMAIN is not set to disabled) The BSL host must program valid configuration data back into the NONMAIN (via BSL commands) before terminating the BSL session, or the device may enter an unrecoverable state. #### Note If the NONMAIN is left unprogrammed after a BSL factory reset, the device will assume a maximally restrictive state on the next reset cycle, any application code in MAIN flash will not be started, and it will not be possible to access the device via any means. To prevent lockout, always ensure that valid configuration data is programmed into NONMAIN following a BSL factory reset. # **1.4.4 NONMAIN** # Table 1-7. NONMAIN | Offset | Acronym | Register Name | Section | |---------------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------| | 41C00000h | BCRCONFIGID | Configuration ID of BCR Structure | BCRCONFIGID (Offset = 41C00000h) [Default = 00000001h] | | 41C00004h | BOOTCFG0 | Serial wire debug (SWD) lock policy. | BOOTCFG0 (Offset =<br>41C00004h) [Default =<br>AABBAABBh] | | 41C00008h | BOOTCFG1 | BSL invoke pin policy. | BOOTCFG1 (Offset =<br>41C00008h) [Default =<br>AABBAABBh] | | 41C0000Ch + formula | PWDDEBUGLOCK[y] | SWD command and password authentication request. | PWDDEBUGLOCK[y]<br>(Offset = 41C0000Ch<br>+ formula) [Default =<br>FFFFFFFFh] | | 41C0001Ch | BOOTCFG2 | Fast boot mode policy and BSL mode policy. | BOOTCFG2 (Offset =<br>41C0001Ch) [Default =<br>AABBFFFFh] | | 41C00020h | BOOTCFG3 | Mass erase and factory reset mode policies. These policies affect SWD initiated and BSL initiated mass erase and factory reset commands. If the SW-DP is disabled (SWDP_MODE is disabled), SWD initiated commands are not allowed as the SW-DP is fully disabled. If the BSL is disabled (BSLMODE is disabled), these settings are a don't care for BSL initiated commands as the BSL is not enabled to be invoked. | BOOTCFG3 (Offset =<br>41C00020h) [Default =<br>AABBAABBh] | | 41C00024h + formula | PWDMASSERASE[y] | SWD mass erase command password (must be provided via DSSM to authenticate a mass erase command). | PWDMASSERASE[y]<br>(Offset = 41C00024h<br>+ formula) [Default =<br>FFFFFFFFh] | | 41C00034h + formula | PWDFACTORYRESET[y] | SWD factory reset command password (must be provided via DSSM to authenticate a factory reset command). | PWDFACTORYRESET[y]<br>(Offset = 41C00034h<br>+ formula) [Default =<br>FFFFFFFFh] | | 41C00044h | FLASHSWP0 | Static write protection policy for the first 32kB of flash memory. When protected, sectors will not be available for program or erase by either the bootloader or application code. | FLASHSWP0 (Offset = 41C00044h) [Default = FFFFFFFh] | | 41C00048h | FLASHSWP1 | Static write protection policy for additional sectors of flash memory. When protected, sectors will not be available for program or erase by either the bootloader or application code. | FLASHSWP1 (Offset = 41C00048h) [Default = FFFFFFFh] | | 41C0004Ch | BOOTCFG4 | | BOOTCFG4 (Offset =<br>41C0004Ch) [Default =<br>FFFFFFFh] | | 41C00050h | APPCRCSTART | Start address of the application CRC check (must be an address in a MAIN flash region). | APPCRCSTART (Offset = 41C00050h) [Default = FFFFFFFh] | Table 1-7. NONMAIN (continued) | Offers | Acronim | Pagieter Nema | Seetien. | |---------------------|------------------|---------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------| | Offset | Acronym | Register Name | Section | | 41C00054h | APPCRCLENGTH | Length of the application area to include in the application CRC check (in bytes), starting from APPCRCSTART. | APPCRCLENGTH (Offset<br>= 41C00054h) [Default =<br>FFFFFFFh] | | 41C00058h | APPCRC | Expected application CRC check digest (CRC-32) to test against during boot. | APPCRC (Offset = 41C00058h) [Default = FFFFFFFh] | | 41C0005Ch | BOOTCRC | CRC digest (CRC-32) of the BCR (boot configuration) portion of the NONMAIN memory. | BOOTCRC (Offset =<br>41C0005Ch) [Default =<br>1879DAC3h] | | 41C00100h | BSLCONFIGID | BSL configuration ID. | BSLCONFIGID (Offset = 41C00100h) [Default = 00000001h] | | 41C00104h | BSLPINCFG0 | BSL UART pin configuration. | BSLPINCFG0 (Offset = 41C00104h) [Default = 02180217h] | | 41C00108h | BSLPINCFG1 | BSL I2C pin configuration. | BSLPINCFG1 (Offset = 41C00108h) [Default = 03020301h] | | 41C0010Ch | BSLCONFIG0 | BSL invoke pin configuration and memory read-out policy. | BSLCONFIG0 (Offset =<br>41C0010Ch) [Default =<br>FFFF1293h] | | 41C00110h + formula | BSLPW[y] | 256-bit BSL access password. | BSLPW[y] (Offset = 41C00110h + formula) [Default = FFFFFFFFh] | | 41C00130h | BSLPLUGINCFG | Defines the presence and type of a BSL plug-in in MAIN flash memory. | BSLPLUGINCFG (Offset<br>= 41C00130h) [Default =<br>FFFFFFFh] | | 41C00134h + formula | BSLPLUGINHOOK[y] | Function pointers for plug-in init, receive, transmit, and de-init functions. | BSLPLUGINHOOK[y]<br>(Offset = 41C00134h<br>+ formula) [Default =<br>FFFFFFFFh] | | 41C00144h | PATCHHOOKID | Alternate BSL configuration. | PATCHHOOKID (Offset = 41C00144h) [Default = FFFFFFFh] | | 41C00148h | SBLADDRESS | Address of an alternate BSL. | SBLADDRESS (Offset = 41C00148h) [Default = FFFFFFFh] | | 41C0014Ch | BSLAPPVER | Address of the application version word. | BSLAPPVER (Offset = 41C0014Ch) [Default = FFFFFFFh] | | 41C00150h | BSLCONFIG1 | BSL security configuration. | BSLCONFIG1 (Offset = 41C00150h) [Default = 0048FFFFh] | | 41C00154h | BSLCRC | CRC digest (CRC-32) of the BSL_CONFIG portion of the NONMAIN memory. | BSLCRC (Offset =<br>41C00154h) [Default =<br>8C76DE95h] | Complex bit access types are encoded to fit into small table cells. Table 1-8 shows the codes that are used for access types in this section. **Table 1-8. NONMAIN Access Type Codes** | Table 1-6: NOTHINAIN Access Type Godes | | | | | | | | | | | |----------------------------------------|------|-------------|--|--|--|--|--|--|--|--| | Access Type | Code | Description | | | | | | | | | | Read Type | | | | | | | | | | | | R | R | Read | | | | | | | | | | Write Type | | | | | | | | | | | | W | W | Write | | | | | | | | | Table 1-8. NONMAIN Access Type Codes (continued) | Access Tyme | Codo | Description | |-------------------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Access Type | Code | Description | | Reset or Default Value | | | | -n | | Value after reset or the default value | | Register Array Variable | s | | | i,j,k,l,m,n | | When these variables are used in a register name, an offset, or an address, they refer to the value of a register array where the register is part of a group of repeating registers. The register groups form a hierarchical structure and the array is represented with a formula. | | У | | When this variable is used in a register name, an offset, or an address it refers to the value of a register array. | # 1.4.4.1 BCRCONFIGID (Offset = 41C00000h) [Default = 00000001h] Return to the Summary Table. Configuration ID of BCR Structure # Figure 1-2. BCRCONFIGID # Table 1-9. BCRCONFIGID Field Descriptions | Bit | Field | 71. | | Description | | | | | | | |------|--------|-----|-----------|---------------------------------|--|--|--|--|--|--| | 31-0 | CONFIG | R/W | 00000001h | Configuration ID of the BOOTCFG | | | | | | | # 1.4.4.2 BOOTCFG0 (Offset = 41C00004h) [Default = AABBAABBh] Return to the Summary Table. Serial wire debug (SWD) lock policy. # Figure 1-3. BOOTCFG0 # Table 1-10. BOOTCFG0 Field Descriptions | Bit | Field | Туре | Default | Description | |-------|-----------|------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-16 | SWDP_MODE | R/W | AABBh | The serial wire debug port (SW-DP) access policy. This policy sets whether any communication is allowed with the device via the SWD pins (to any DAP). When disabled, no SWD communication is possible regardless of the configuration of the DEBUGACCESS field. 5566h = The SW-DP is fully disabled and no device access is possible via the SW-DP (0x5566 and all other values NOT 0xAABB). AABBh = The SW-DP is enabled and device access is set by the additional policies in NONMAIN. | # Table 1-10. BOOTCFG0 Field Descriptions (continued) | Bit | Field | Туре | Default | Description | |------|-------------|------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-0 | DEBUGACCESS | W | AABBh | The debug access policy for accessing the AHB-AP, ET-AP, and PWR-AP debug access ports. Note that if SWDP_MODE is set to DISABLED, the value of this field is ignored and the debug port will remain fully locked. 5566h = Access to AHB-AP, ET-AP, and PWR-AP via SWD is disabled (0x5566 and all other values NOT 0xCCDD or 0xAABB). AABBh = Access to AHB-AP, ET-AP, and PWR-AP via SWD is enabled. CCDDh = Access to AHB-AP, ET-AP, and PWR-AP via SWD is only enabled when the correct password is provided via the DSSM before BCR execution. | # 1.4.4.3 BOOTCFG1 (Offset = 41C00008h) [Default = AABBAABBh] Return to the Summary Table. BSL invoke pin policy. # Figure 1-4. BOOTCFG1 | 3 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|----------------|----|----|----|----|----|----|----|----|------------|----|----|----|----|----|------|-----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| | | BSL_PIN_INVOKE | | | | | | | | | TI_FA_MODE | | | | | | | | | | | | | | | | | | | | | | | | | R/W-AABBh | | | | | | | | | | | | | | R | /W-A | ABE | 3h | | | | | | | | | | | | | | | # Table 1-11. BOOTCFG1 Field Descriptions | Bit | Field | Туре | Default | Description | | | | | | | | | | | |-------|----------------|------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--| | 31-16 | BSL_PIN_INVOKE | R/W | AABBh | Boot strap loader (BSL) pin invoke method enable/disable policy. 5566h = The BSL_INVOKE pin is not checked during boot (0x5566 and all other values NOT 0xAABB). AABBh = The BSL_INVOKE pin is checked during boot. | | | | | | | | | | | | 15-0 | TI_FA_MODE | R/W | AABBh | Sets the TI failure analysis enable/disable policy. If enabled, a re-test request through DSSM is allowed, else it is not allowed. Note that if SWDP_MODE is set to disabled, this field is ignored and failure analysis is not possible. 5566h = TI failure analysis is not allowed (0x5566 and all other values NOT 0xAABB). AABBh = TI failure analysis is allowed. | | | | | | | | | | | # 1.4.4.4 PWDDEBUGLOCK[y] (Offset = 41C0000Ch + formula) [Default = FFFFFFFh] Return to the Summary Table. SWD command and password authentication request. Offset = 41C0000Ch + (y \* 4h); where y = 0h to 3h # Figure 1-5. PWDDEBUGLOCK[y] # Table 1-12. PWDDEBUGLOCK[y] Field Descriptions | Bit | Field | Туре | Default | Description | |------|-------|------|----------|-------------| | 31-0 | PW | R/W | FFFFFFFh | Password | # 1.4.4.5 BOOTCFG2 (Offset = 41C0001Ch) [Default = AABBFFFFh] Return to the Summary Table. Fast boot mode policy and BSL mode policy. # Figure 1-6. BOOTCFG2 # Table 1-13. BOOTCFG2 Field Descriptions | Bit | Field | Туре | Default | Description | |-------|--------------|------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-16 | BSLMODE | | AABBh | BSLMODE configures the boot strap loader enable/disable policy. 5566h = The BSL is disabled (0x5566 and all other values NOT 0xAABB). AABBh = The BSL is enabled. | | 15-0 | FASTBOOTMODE | | FFFFh | FASTBOOTMODE configures the fast boot mode enable/disable policy. 5566h = Fast boot mode is disabled. All enabled BSL invoke conditions are evaluated (0x5566 and all other values NOT 0xAABB). AABBh = Fast boot mode is enabled. Only the software BSL invoke condition is evaluated. | # 1.4.4.6 BOOTCFG3 (Offset = 41C00020h) [Default = AABBAABBh] Return to the Summary Table. Mass erase and factory reset mode policies. These policies affect SWD initiated and BSL initiated mass erase and factory reset commands. If the SW-DP is disabled (SWDP\_MODE is disabled), SWD initiated commands are not allowed as the SW-DP is fully disabled. If the BSL is disabled (BSLMODE is disabled), these settings are a don't care for BSL initiated commands as the BSL is not enabled to be invoked. # Figure 1-7. BOOTCFG3 # Table 1-14. BOOTCFG3 Field Descriptions | Bit | Field | Туре | Default | Description | | | | | | | | | | | |-------|---------------------------|------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--| | 31-16 | FACTORYRESETCMDAC<br>CESS | R/W | AABBh | The factory reset command policy. 5566h = The factory reset command is not allowed (0x5566 and all other values NOT 0xAABB or 0xCCDD). AABBh = The factory reset command is allowed. CCDDh = The factory reset command is allowed only when the matching password is provided via the DSSM. | | | | | | | | | | | | 15-0 | MASSERASECMDACCE<br>SS | R/W | AABBh | The mass erase command policy. 5566h = The mass erase command is not allowed (0x5566 and all other values NOT 0xAABB or 0xCCDD). AABBh = The mass erase command is allowed. CCDDh = The mass erase command is allowed only when the matching password is provided via the DSSM. | | | | | | | | | | | # 1.4.4.7 PWDMASSERASE[y] (Offset = 41C00024h + formula) [Default = FFFFFFFh] Return to the Summary Table. SWD mass erase command password (must be provided via DSSM to authenticate a mass erase command). Offset = 41C00024h + (y \* 4h); where y = 0h to 3h #### Figure 1-8. PWDMASSERASE[y] Table 1-15. PWDMASSERASE[y] Field Descriptions | Bit | Field | Туре | Default | Description | |------|-------|------|----------|-------------| | 31-0 | PW | R/W | FFFFFFFh | Password | # 1.4.4.8 PWDFACTORYRESET[y] (Offset = 41C00034h + formula) [Default = FFFFFFFh] Return to the Summary Table. SWD factory reset command password (must be provided via DSSM to authenticate a factory reset command). Offset = 41C00034h + (y \* 4h); where y = 0h to 3h # Figure 1-9. PWDFACTORYRESET[y] #### Table 1-16. PWDFACTORYRESET[y] Field Descriptions | Bit | Field | Туре | Default | Description | |------|-------|------|----------|-------------| | 31-0 | PW | R/W | FFFFFFFh | Password | # 1.4.4.9 FLASHSWP0 (Offset = 41C00044h) [Default = FFFFFFFh] Return to the Summary Table. Static write protection policy for the first 32kB of flash memory. When protected, sectors will not be available for program or erase by either the bootloader or application code. # Figure 1-10. FLASHSWP0 #### Table 1-17. FLASHSWP0 Field Descriptions | Bit | Field | Туре | Default | Description | |------|---------|------|----------|------------------------------------------------------------------------| | 31-0 | MAINLOW | R/W | FFFFFFFh | 1 bit per sector (Setting a bit to 0 disables write, 1 enables write). | #### 1.4.4.10 FLASHSWP1 (Offset = 41C00048h) [Default = FFFFFFFh] Return to the Summary Table. Static write protection policy for additional sectors of flash memory. When protected, sectors will not be available for program or erase by either the bootloader or application code. # Figure 1-11. FLASHSWP1 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----------|----|----|----|----|----|----|----|----|----|----|----|----|-----|------|-----|-----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| | | MAINHIGH | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | R/W | -FFF | FFF | FFh | | | | | | | | | | | | | | | # Table 1-18. FLASHSWP1 Field Descriptions | Bit | Field | Туре | Default | Description | |------|----------|------|----------|-------------------------------------------------------------------------------------------------------------------------| | 31-0 | MAINHIGH | R/W | FFFFFFFh | 1 bit per 8 sectors. Bits 3:0, not used as covered with FLASHSWP0. (Setting a bit to 0 disables write, 1 enables write) | # 1.4.4.11 BOOTCFG4 (Offset = 41C0004Ch) [Default = FFFFFFFh] Return to the Summary Table. #### Figure 1-12. BOOTCFG4 | | Figure 1-12. BOOTCFG4 | | | | | | | | | | | | | | | |----------------------|------------------------------------|----|----------|-------|----|----|------------|--|--|--|--|--|--|--|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | | | | | | | APPCRCMODE | | | | | | | | | | | | | | | | | R/W-FFFFh 23 22 21 20 19 18 17 16 | | | | | | | | | | | | | | | | 23 22 21 20 19 18 17 | | | | | | | | | | | | | | | | | | | | APPCR | CMODE | | | | | | | | | | | | | R/W-FFFFh | | | | | | | | | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | | | | | | | | RESE | RVED | | | | | | | | | | | | | | | | R/ | W- | | | | | | | | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | | | | | RESERVED | | | | NONMAINSWP | | | | | | | | | | | | | R/W- | | | | R/W-FFFFh | | | | | | | | | # Table 1-19. BOOTCFG4 Field Descriptions | | | 14.5.5 1 10 | | OT I Icia Descriptions | | | | | | | | |-------|------------|-------------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--| | Bit | Field | Туре | Default | Description | | | | | | | | | 31-16 | APPCRCMODE | R/W | FFFFh | APPCRCMODE enables or disables the boot time CRC check of a segment of MAIN flash memory. 5566h = The boot time MAIN flash CRC check is disabled. The application code in MAIN flash is always started unless the reset vector or stack pointer are blank/unprogrammed (0x5566 and all other values NOT 0xAABB). AABBh = The boot time MAIN flash CRC check is enabled. If the boot time CRC check passes, the application code in MAIN flash is started unless the reset vector or stack pointer are blank (unprogrammed). In the event of a failing CRC check, the application code in MAIN flash will not be started and the boot process fails. | | | | | | | | | 15-1 | RESERVED | R/W | 0h | | | | | | | | | | 0 | NONMAINSWP | R/W | FFFFh | Static write protection policy for entire NONMAIN device configuration memory. Setting bit to 0 disables program/erase of the NONMAIN by all means other than a SWD-initiated factory reset, the enables program/erase of the NONMAIN by normal means. | | | | | | | | # 1.4.4.12 APPCRCSTART (Offset = 41C00050h) [Default = FFFFFFFh] Return to the Summary Table. Start address of the application CRC check (must be an address in a MAIN flash region). # Figure 1-13. APPCRCSTART | | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|----|---------|----|----|----|----|----|----|----|----|----|----|----|----|-----|------|-----|-----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| | | | ADDRESS | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | ı | | | | | | | | | | | | | | | R/W | -FFF | FFF | FFh | | | | | | | | | | | | | | | # Table 1-20. APPCRCSTART Field Descriptions | Bit | Field | Туре | Default | Description | |------|---------|------|----------|-------------------------------------| | 31-0 | ADDRESS | R/W | FFFFFFFh | Application CRC check start address | # 1.4.4.13 APPCRCLENGTH (Offset = 41C00054h) [Default = FFFFFFFh] Return to the Summary Table. Length of the application area to include in the application CRC check (in bytes), starting from APPCRCSTART. # Figure 1-14. APPCRCLENGTH | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|-------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| | | LENGTH | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | R/W-FFFFFFh | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | # **Table 1-21. APPCRCLENGTH Field Descriptions** | Bit | Field | Туре | Default | Description | |------|--------|------|----------|------------------------------------------| | 31-0 | LENGTH | R/W | FFFFFFFh | Application CRC check source data length | # 1.4.4.14 APPCRC (Offset = 41C00058h) [Default = FFFFFFFh] Return to the Summary Table. Expected application CRC check digest (CRC-32) to test against during boot. #### Figure 1-15. APPCRC | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|-------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| | | DIGEST | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | R/W-FFFFFFh | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | # Table 1-22. APPCRC Field Descriptions | Bit | Field | Туре | Default | Description | |------|--------|------|----------|----------------------------------------| | 31-0 | DIGEST | R/W | FFFFFFFh | Application CRC check expected digest. | # 1.4.4.15 BOOTCRC (Offset = 41C0005Ch) [Default = 1879DAC3h] Return to the Summary Table. CRC digest (CRC-32) of the BCR (boot configuration) portion of the NONMAIN memory. # Figure 1-16. BOOTCRC # Table 1-23. BOOTCRC Field Descriptions | Bit | Field | Туре | Default | Description | |------|--------|------|-----------|-----------------------------------------| | 31-0 | DIGEST | R/W | 1879DAC3h | BCR boot configuration data CRC digest. | # 1.4.4.16 BSLCONFIGID (Offset = 41C00100h) [Default = 00000001h] Return to the Summary Table. BSL configuration ID. # Figure 1-17. BSLCONFIGID # Table 1-24. BSLCONFIGID Field Descriptions | Bit | Field | Туре | Default | Description | |------|--------|------|-----------|-------------------------------------| | 31-0 | CONFIG | R/W | 00000001h | Configuration ID of the BSL_CONFIG. | # 1.4.4.17 BSLPINCFG0 (Offset = 41C00104h) [Default = 02180217h] Return to the Summary Table. BSL UART pin configuration. # Figure 1-18. BSLPINCFG0 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | |----|----|----|--------|--------|----|----|-----|----------------|----|----|--------|--------|----|----|----|--|--|--| | | | U | ARTTX_ | MUX_SE | L | | | | | U | ARTTX_ | PAD_NU | М | | | | | | | | | | R/W | -02h | | | | R/W-18h | | | | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | U. | ARTRX_ | MUX_SE | L | | | UARTRX_PAD_NUM | | | | | | | | | | | | | | | | | | | R/W | -17h | | | | | | | | | | | # Table 1-25. BSLPINCFG0 Field Descriptions | Bit | Field | Туре | Default | Description | |-------|----------------|------|---------|------------------------------------| | 31-24 | UARTTX_MUX_SEL | R/W | 02h | UART TX IOMUX PINCM mux selection. | | 23-16 | UARTTX_PAD_NUM | R/W | 18h | UART TX IOMUX PINCM register. | | 15-8 | UARTRX_MUX_SEL | R/W | 02h | UART RX IOMUX PINCM mux selection. | | 7-0 | UARTRX_PAD_NUM | R/W | 17h | UART RX IOMUX PINCM register. | # 1.4.4.18 BSLPINCFG1 (Offset = 41C00108h) [Default = 03020301h] Return to the Summary Table. BSL I2C pin configuration. # Figure 1-19. BSLPINCFG1 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | |----|----|----|---------|--------|----|----|----|-----------------|----|----|---------|---------|----|----|----|--|--| | | | L | 2CSCL_N | MUX_SE | L | | | | | L | 2CSCL_F | PAD_NUI | И | | | | | | | | | R/W | '-03h | | | | R/W-2h | | | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 6 5 4 3 2 1 0 | | | | | | | | | | | | | 12 | 2CSDA_I | MUX_SE | L | | | | | I2 | 2CSDA_F | PAD_NUI | М | | | | | # Figure 1-19. BSLPINCFG1 (continued) R/W-03h R/W-1h # Table 1-26. BSLPINCFG1 Field Descriptions | Bit | Field | Туре | Default | Description | |-------|----------------|------|---------|------------------------------------| | 31-24 | I2CSCL_MUX_SEL | R/W | 03h | I2C SCL IOMUX PINCM mux selection. | | 23-16 | I2CSCL_PAD_NUM | R/W | 2h | I2C SCL IOMUX PINCM register. | | 15-8 | I2CSDA_MUX_SEL | R/W | 03h | I2C SDA IOMUX PINCM mux selection. | | 7-0 | I2CSDA_PAD_NUM | R/W | 1h | I2C SDA IOMUX PINCM register. | # 1.4.4.19 BSLCONFIG0 (Offset = 41C0010Ch) [Default = FFFF1293h] Return to the Summary Table. BSL invoke pin configuration and memory read-out policy. # Figure 1-20. BSLCONFIG0 | | | | 9 | 50200 | | | | | | | | | |------------|-----------|---------------------|-------|----------|----------------|----|----|--|--|--|--|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | | | | | | READ | OUTEN | | | | | | | | | | | | | R/W-F | FFFFh | | | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | | | | | | READO | OUTEN | | | | | | | | | | | R/W-FFFFh | | | | | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | | RESE | RVED | BSLIVK_GPIOP<br>ORT | | E | BSLIVK_GPIOPIN | | | | | | | | | R- | 0h | R/W- | | | R/W-12h | | | | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | BSLIVK_LVL | RESERVED | | | BSLIVK_F | PAD_NUM | | | | | | | | | R/W-1h | R-0h | | | R/W | -13h | | | | | | | | # Table 1-27. BSLCONFIG0 Field Descriptions | Bit Field Type I | | | | Description | |------------------|-----------------|-----|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-16 | READOUTEN | R/W | <b>Default</b><br>FFFFh | Sets the memory read-out policy for the BSL interface. | | | IND BOOTEN | | | 5566h = Memory read-out is not possible via the BSL interface (0x5566 and all other values NOT 0xAABB). AABBh = Memory contents may be read via the BSL interface. | | 15-14 | RESERVED | R | 0h | | | 13 | BSLIVK_GPIOPORT | R/W | Oh | The BSL_invoke GPIO port index corresponding to the pad used for BSL_invoke. Oh = The BSL_invoke pin is on GPIO port A. 1h = The BSL_invoke pin is on GPIO port B. | | 12-8 | BSLIVK_GPIOPIN | R/W | 12h | The BSL_invoke GPIO pin index corresponding to the pad used for BSL_invoke. | | 7 | BSLIVK_LVL | R/W | 1h | The BSL_invoke input logic level which shall invoke the BSL. 0h = LOW 1h = HIGH | | 6 | RESERVED | R | 0h | | | 5-0 | BSLIVK_PAD_NUM | R/W | 13h | The IOMUX PINCM register corresponding to the pad to be used for BSL_invoke. | # 1.4.4.20 BSLPW[y] (Offset = 41C00110h + formula) [Default = FFFFFFFh] Return to the Summary Table. 256-bit BSL access password. Offset = 41C00110h + (y \* 4h); where y = 0h to 7h #### Figure 1-21. BSLPW[y] Table 1-28. BSLPW[y] Field Descriptions | Bit | Field | Туре | Default | Description | |------|----------|------|----------|-------------| | 31-0 | PASSWORD | R/W | FFFFFFFh | Password | # 1.4.4.21 BSLPLUGINCFG (Offset = 41C00130h) [Default = FFFFFFFh] Return to the Summary Table. Defines the presence and type of a BSL plug-in in MAIN flash memory. #### Figure 1-22. BSLPLUGINCFG | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |------------|------------|----|----|----|----|----|-------------|----|----|----|-----|------|----|----|----| | SRAMEXISTS | | | | | | | FLASHEXISTS | | | | | | | | | | R/W-FFh | | | | | | | | | | | R/W | -FFh | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | PLUGINTYPE | | | | | | | | | | | | | | | | R/W-FFFFh | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | # Table 1-29. BSLPLUGINCFG Field Descriptions | Bit | Field | Туре | Default | Description | |-------|-------------|------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-24 | SRAMEXISTS | R/W | FFh | SRAM consumed by Flash plugin, from 0x00 to 0xFF. | | 23-16 | FLASHEXISTS | R/W | FFh | The field tells if Flash Plugin exists are not. 0xBB - Flash Plugin exists; 0xFF (all other values) - Only ROM plugins will be used. | | 15-0 | PLUGINTYPE | R/W | FFFFh | The type code for the BSL plug-in. 1000h = Plug-in is for UART. 2000h = Plug-in is for I2C. FFFFh = For all other values. Any other interfaces with valid hooks will be added to Plugin list. | # 1.4.4.22 BSLPLUGINHOOK[y] (Offset = 41C00134h + formula) [Default = FFFFFFFh] Return to the Summary Table. Function pointers for plug-in init, receive, transmit, and de-init functions. Offset = 41C00134h + (y \* 4h); where y = 0h to 3h # Figure 1-23. BSLPLUGINHOOK[y] #### Table 1-30. BSLPLUGINHOOK[y] Field Descriptions | Bit | Field | Туре | Default | Description | |------|-----------|------|---------|-----------------------------------------------------------------------------------------------------------------| | 31-0 | BSLPLUGIN | R/W | | Address of the BSL plug-in hook. Byte [3-0]: Init; Byte [7-4]: Receive; Byte [11-8]: Send; Byte [15-12]: Deinit | #### 1.4.4.23 PATCHHOOKID (Offset = 41C00144h) [Default = FFFFFFFh] Return to the Summary Table. Alternate BSL configuration. #### Figure 1-24. PATCHHOOKID #### Table 1-31. PATCHHOOKID Field Descriptions | Bit | Field | Туре | Default | Description | |-------|----------|------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------| | 31-16 | RESERVED | R/W | 0h | | | 15-0 | ID | R/W | | ID field to invoke an alternate BSL. 5566h = Do not use an alternate BSL (0x5566 and all other values NOT 0xAABB). AABBh = Use the alternate BSL. | ### 1.4.4.24 SBLADDRESS (Offset = 41C00148h) [Default = FFFFFFFh] Return to the Summary Table. Address of an alternate BSL. #### Figure 1-25. SBLADDRESS | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|-------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| | | ADDRESS | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | R/W-FFFFFFh | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | ### Table 1-32. SBLADDRESS Field Descriptions | Bit | Field | Туре | Default | Description | |------|---------|------|----------|-------------------------------------------| | 31-0 | ADDRESS | R/W | FFFFFFFh | Address of the alternate BSL, if present. | ### 1.4.4.25 BSLAPPVER (Offset = 41C0014Ch) [Default = FFFFFFFh] Return to the Summary Table. Address of the application version word. #### Figure 1-26. BSLAPPVER Table 1-33. BSLAPPVER Field Descriptions | Bit | Field | Туре | Default | Description | |------|---------|------|---------|-----------------------------------------------------------------------------------------| | 31-0 | ADDRESS | R/W | | Address of the application version word (must be a valid flash address to be returned). | #### 1.4.4.26 BSLCONFIG1 (Offset = 41C00150h) [Default = 0048FFFFh] Return to the Summary Table. BSL security configuration. #### Figure 1-27. BSLCONFIG1 | 3 | 1 3 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|------------|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|------|------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| | | TARGETADDR | | | | | | | | | | | | | | ALE | ERT/ | ACTI | ON | | | | | | | | | | | | | | | | | R/W-0048h | | | | | | | | | | | | | | R | /W-F | FFF | h | | | | | | | | | | | | | | | #### Table 1-34. BSLCONFIG1 Field Descriptions | Bit | Field | Туре | Default | Description | |-------|-------------|------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-16 | TARGETADDR | R/W | 0048h | I2C target address to be used for the BSL I2C communication. | | 15-0 | ALERTACTION | R/W | FFFFh | Action to take upon a security alert condition. 5566h = Ignore the security alert condition (0x5566 and all other values NOT 0xAABB or 0xCCDD). AABBh = Trigger a factory reset. Note that if sectors in MAIN or NONMAIN flash are write protected they will not be affected by the BSL factory reset. CCDDh = Re-configure the NONMAIN region to disable the BSL. This is not supported if the NONMAIN region is configured to be write protected. | #### 1.4.4.27 BSLCRC (Offset = 41C00154h) [Default = 8C76DE95h] Return to the Summary Table. CRC digest (CRC-32) of the BSL\_CONFIG portion of the NONMAIN memory. #### Figure 1-28. BSLCRC | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|---------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| | | DIGEST | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | R/W-8C76DE95h | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | #### **Table 1-35. BSLCRC Field Descriptions** | Bit | Field | Туре | Default | Description | |------|--------|------|-----------|-----------------------------------| | 31-0 | DIGEST | R/W | 8C76DE95h | BSL configuration data CRC digest | ### 1.5 Factory Constants All devices include a memory-mapped FACTORY region which provides read-only data describing the capabilities of a device as well as any factory-provided trim information for use by application software. Key data provided in the FACTORY memory region includes: - The device unique 96-bit identity - The default BSL pins - The total MAIN region flash memory size (in KB) - The total DATA region flash memory size (in KB), if present - · The flash bank count - The total SRAM memory size (in KB) - The temperature sensor calibration value - The SYSPLL startup parameters (if SYSPLL is present, else reserved); MSPM0Lxx devices do not have a SYSPLL present ### 1.5.1 FACTORYREGION Registers Table 1-36 lists the memory-mapped registers for the FACTORYREGION registers. All register offset addresses not listed in Table 1-36 should be considered as reserved locations and the register contents should not be modified. **Table 1-36. FACTORYREGION Registers** | Offset | Acronym | Register Name Group | Section | |---------------|---------------|----------------------------------------------------------------------------------------------------------------------------|------------------| | 41C4000<br>0h | TRACEID | Trace identifier | Section 1.5.1.1 | | 41C4000<br>4h | DEVICEID | Device identifier | Section 1.5.1.2 | | 41C4000<br>8h | USERID | Device variant identifier | Section 1.5.1.3 | | 41C4000<br>Ch | BSLPIN_UART | BSL UART Pin Configuration | Section 1.5.1.4 | | 41C4001<br>0h | BSLPIN_I2C | BSL I2C Pin Configuration | Section 1.5.1.5 | | 41C4001<br>4h | BSLPIN_INVOKE | BSL Pin Invocation IO Configuration | Section 1.5.1.6 | | 41C4001<br>8h | SRAMFLASH | The encoding of memory size and flash bank number | Section 1.5.1.7 | | 41C4001<br>Ch | RESERVED0 | | Section 1.5.1.8 | | 41C4002<br>0h | RESERVED1 | | Section 1.5.1.9 | | 41C4002<br>4h | RESERVED2 | | Section 1.5.1.10 | | 41C4002<br>8h | RESERVED3 | | Section 1.5.1.11 | | 41C4002<br>Ch | RESERVED4 | | Section 1.5.1.12 | | 41C4003<br>0h | RESERVED5 | | Section 1.5.1.13 | | 41C4003<br>4h | RESERVED6 | | Section 1.5.1.14 | | 41C4003<br>8h | RESERVED7 | | Section 1.5.1.15 | | 41C4003<br>Ch | TEMP_SENSE0 | Temperature sensor room temperature calibration code. This is ADC conversion results of temperature sensor output voltage. | Section 1.5.1.16 | | 41C4004<br>0h | RESERVED9 | | Section 1.5.1.17 | | 41C4004<br>4h | RESERVED10 | | Section 1.5.1.18 | | 41C4004<br>8h | RESERVED11 | | Section 1.5.1.19 | | 41C4004<br>Ch | RESERVED12 | | Section 1.5.1.20 | | 41C4005<br>0h | RESERVED13 | | Section 1.5.1.21 | | 41C4005<br>4h | RESERVED14 | | Section 1.5.1.22 | | 41C4005<br>8h | RESERVED15 | | Section 1.5.1.23 | **Table 1-36. FACTORYREGION Registers (continued)** | Offset | Acronym | Register Name | Group | Section | |---------------|------------|---------------------------------------------------------------------|-------|------------------| | 41C4005<br>Ch | RESERVED16 | | | Section 1.5.1.24 | | 41C4006<br>0h | RESERVED17 | | | Section 1.5.1.25 | | 41C4006<br>4h | RESERVED18 | | | Section 1.5.1.26 | | 41C4006<br>8h | RESERVED19 | | | Section 1.5.1.27 | | 41C4006<br>Ch | RESERVED20 | | | Section 1.5.1.28 | | 41C4007<br>0h | RESERVED21 | | | Section 1.5.1.29 | | 41C4007<br>4h | RESERVED22 | | | Section 1.5.1.30 | | 41C4007<br>8h | RESERVED23 | | | Section 1.5.1.31 | | 41C4007<br>Ch | BOOTCRC | BOOTCRC records the 32-b all locations in OPEN including locations. | | Section 1.5.1.32 | Complex bit access types are encoded to fit into small table cells. Table 1-37 shows the codes that are used for access types in this section. **Table 1-37. FACTORYREGION Access Type Codes** | Access Type | Code | Description | | | | | | | | |------------------------|------|----------------------------------------|--|--|--|--|--|--|--| | Read Type | | | | | | | | | | | R | R | Read | | | | | | | | | Reset or Default Value | | | | | | | | | | | -n | | Value after reset or the default value | | | | | | | | ### 1.5.1.1 TRACEID Register (Offset = 41C40000h) [Reset = 00000000h] TRACEID is shown in Figure 1-29 and described in Table 1-38. Return to the Summary Table. Unique value per device shipped ### Figure 1-29. TRACEID Register Table 1-38. TRACEID Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|-------|------|-------|-------------| | 31-0 | DATA | R | 0h | | # 1.5.1.2 DEVICEID Register (Offset = 41C40004h) [Reset = 0BB8802Fh] DEVICEID is shown in Figure 1-30 and described in Table 1-39. Return to the Summary Table. Device identifier (die revision specific) ### Figure 1-30. DEVICEID Register ### Table 1-39. DEVICEID Register Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|--------------|------|-------|----------------------------------| | 31-28 | VERSION | R | 0h | Revision of the device | | 27-12 | PARTNUM | R | BB88h | Part number of the device | | 11-1 | MANUFACTURER | R | 17h | TI's JEDEC bank and company code | | 0 | ALWAYS_1 | R | 1h | This is always 1 | # 1.5.1.3 USERID Register (Offset = 41C40008h) [Reset = 80000000h] USERID is shown in Figure 1-31 and described in Table 1-40. Return to the Summary Table. The variant feature set # Figure 1-31. USERID Register # Table 1-40. USERID Register Field Descriptions | | 14 | D.O . 40. O | O=: \:. D : \: \ | Jiotor i ioia Boodriptiono | |-------|----------|-------------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Field | Туре | Reset | Description | | 31 | START | R | 1h | | | 30-28 | MAJORREV | R | Oh | Monotonic increasing value indicating a new revision significant enough that users of the device may have to revise PCB or or software design | | 27-24 | MINORREV | R | 0h | Monotonic increasing value indicating a new revision that preserves compatibility with lesser minorrev values. New capability may be introduced such that lesser minorrev numbers may not be compatible with greater if the new capability is used. | | 23-16 | VARIANT | R | 0h | Bit pattern uniquely identifying the variant of a part | | 15-0 | PART | R | 0h | Bit pattern that uniquely identifying a part | # 1.5.1.4 BSLPIN\_UART Register (Offset = 41C4000Ch) [Reset = 02180219h] BSLPIN\_UART is shown in Figure 1-32 and described in Table 1-41. Return to the Summary Table. **BSL UART Pin Configuration** ### Figure 1-32. BSLPIN\_UART Register Table 1-41. BSLPIN\_UART Register Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|--------------|------|-------|-------------------------------------------| | 31-24 | UART_TXT_PF | R | 2h | BSL UART TXD Pin Function selection value | | 23-16 | UART_TXD_PAD | R | 18h | UART TXD PIN used by BSL | | 15-8 | UART_RXD_PF | R | 2h | BSL UART RXD Pin Function selection value | | 7-0 | UART_RXD_PAD | R | 19h | UART RXD PIN used by BSL | # 1.5.1.5 BSLPIN\_I2C Register (Offset = 41C40010h) [Reset = 03020301h] BSLPIN\_I2C is shown in Figure 1-33 and described in Table 1-42. Return to the Summary Table. **BSL I2C Pin Configuration** ### Figure 1-33. BSLPIN\_I2C Register ### Table 1-42. BSLPIN\_I2C Register Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|-------------|------|-------|------------------------------------------| | 31-24 | I2C_SCL_PF | R | 3h | BSL I2C SCL Pin Function selection value | | 23-16 | I2C_SCL_PAD | R | 2h | I2C SCL PIN used by BSL | | 15-8 | I2C_SDA_PF | R | 3h | BSL I2C SDA Pin Function selection value | | 7-0 | I2C_SDA_PAD | R | 1h | I2C SDA PIN used by BSL | # 1.5.1.6 BSLPIN\_INVOKE Register (Offset = 41C40014h) [Reset = 000001ABh] BSLPIN\_INVOKE is shown in Figure 1-34 and described in Table 1-43. Return to the Summary Table. **BSL Pin Invocation IO Configuration** ### Figure 1-34. BSLPIN\_INVOKE Register ### Table 1-43. BSLPIN\_INVOKE Register Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|--------------|------|-------|----------------------------------------| | 31-15 | RESERVED | R | 0h | | | 14-13 | GPIO_REG_SEL | R | 0h | GPIO Module Selection | | 12-8 | GPIO_PIN_SEL | R | 1h | GPIO Pin Selection in GPIO Module | | 7 | GPIO_LEVEL | R | 1h | GPIO Level used for BSL Pin Invocation | | 6-0 | BSL_PAD | R | 2Bh | BSL Invocation Pin Number | # 1.5.1.7 SRAMFLASH Register (Offset = 41C40018h) [Reset = 00040040h] SRAMFLASH is shown in Figure 1-35 and described in Table 1-44. Return to the Summary Table. The encoding of memory size and flash bank number ### Figure 1-35. SRAMFLASH Register ### Table 1-44. SRAMFLASH Register Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|--------------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-26 | DATAFLASH_SZ | R | 0h | The encoding of the field is that the value of the field is an integer to be interpreted as number of KBs. For eg: if the value of the field id 4, then it is 4KB, if the value is 32, then 32KB, and so on. | | 25-16 | SRAM_SZ | R | 4h | The encoding of the field is that the value of the field is an integer to be interpreted as number of KBs. For eg: if the value of the field id 4, then it is 4KB, if the value is 32, then 32KB, and so on. | | 15-14 | RESERVED | R | 0h | | | 13-12 | MAINNUMBANKS | R | Oh | The encoding of the field is that the value of the field is an integer to be interpreted as number of banks. 0 is one bank, 1 is two banks, 2 is three banks and 3 is 4 banks. 0h = 0 1h = 1 2h = 2 3h = 3 | | 11-0 | MAINFLASH_SZ | R | 40h | The encoding of the field is that the value of the field is an integer to be interpreted as number of KBs. For eg: if the value of the field id 4, then it is 4KB, if the value is 32, then 32KB, and so on. | ### 1.5.1.8 RESERVED0 Register (Offset = 41C4001Ch) [Reset = 00000000h] RESERVED0 is shown in Figure 1-36 and described in Table 1-45. Return to the Summary Table. ### Figure 1-36. RESERVED0 Register ### Table 1-45. RESERVED0 Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|-------------| | 31-0 | RESERVED | R | 0h | Reserved | ### 1.5.1.9 RESERVED1 Register (Offset = 41C40020h) [Reset = 00000000h] RESERVED1 is shown in Figure 1-37 and described in Table 1-46. Return to the Summary Table. ### Figure 1-37. RESERVED1 Register ### Table 1-46. RESERVED1 Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|-------------| | 31-0 | RESERVED | R | 0h | Reserved | ### 1.5.1.10 RESERVED2 Register (Offset = 41C40024h) [Reset = 00000000h] RESERVED2 is shown in Figure 1-38 and described in Table 1-47. Return to the Summary Table. ### Figure 1-38. RESERVED2 Register ### Table 1-47. RESERVED2 Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|-------------| | 31-0 | RESERVED | R | 0h | Reserved | ### 1.5.1.11 RESERVED3 Register (Offset = 41C40028h) [Reset = 00000000h] RESERVED3 is shown in Figure 1-39 and described in Table 1-48. Return to the Summary Table. ### Figure 1-39. RESERVED3 Register # Table 1-48. RESERVED3 Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|-------------| | 31-0 | RESERVED | R | 0h | Reserved | ### 1.5.1.12 RESERVED4 Register (Offset = 41C4002Ch) [Reset = 00000000h] RESERVED4 is shown in Figure 1-40 and described in Table 1-49. Return to the Summary Table. ### Figure 1-40. RESERVED4 Register ### Table 1-49. RESERVED4 Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|-------------| | 31-0 | RESERVED | R | 0h | Reserved | ### 1.5.1.13 RESERVED5 Register (Offset = 41C40030h) [Reset = 00000000h] RESERVED5 is shown in Figure 1-41 and described in Table 1-50. Return to the Summary Table. ### Figure 1-41. RESERVED5 Register ### Table 1-50. RESERVED5 Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|-------------| | 31-0 | RESERVED | R | 0h | Reserved | ### 1.5.1.14 RESERVED6 Register (Offset = 41C40034h) [Reset = 00000000h] RESERVED6 is shown in Figure 1-42 and described in Table 1-51. Return to the Summary Table. ### Figure 1-42. RESERVED6 Register ### Table 1-51. RESERVED6 Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|-------------| | 31-0 | RESERVED | R | 0h | Reserved | ### 1.5.1.15 RESERVED7 Register (Offset = 41C40038h) [Reset = 00000000h] RESERVED7 is shown in Figure 1-43 and described in Table 1-52. Return to the Summary Table. ### Figure 1-43. RESERVED7 Register ### Table 1-52. RESERVED7 Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|-------------| | 31-0 | RESERVED | R | 0h | Reserved | ### 1.5.1.16 TEMP\_SENSE0 Register (Offset = 41C4003Ch) [Reset = 00000000h] TEMP\_SENSE0 is shown in Figure 1-44 and described in Table 1-53. Return to the Summary Table. Temperature sensor room temperature calibration code. This is ADC conversion results of temperature sensor output voltage. ### Figure 1-44. TEMP\_SENSE0 Register ### Table 1-53. TEMP\_SENSE0 Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|-------|------|-------|-------------| | 31-0 | DATA | R | 0h | | ### 1.5.1.17 RESERVED9 Register (Offset = 41C40040h) [Reset = 00000000h] RESERVED9 is shown in Figure 1-45 and described in Table 1-54. Return to the Summary Table. ### Figure 1-45. RESERVED9 Register ### Table 1-54. RESERVED9 Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|-------------| | 31-0 | RESERVED | R | 0h | Reserved | ### 1.5.1.18 RESERVED10 Register (Offset = 41C40044h) [Reset = 00000000h] RESERVED10 is shown in Figure 1-46 and described in Table 1-55. Return to the Summary Table. # Figure 1-46. RESERVED10 Register ### Table 1-55. RESERVED10 Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|-------------| | 31-0 | RESERVED | R | 0h | Reserved | ### 1.5.1.19 RESERVED11 Register (Offset = 41C40048h) [Reset = 00000000h] RESERVED11 is shown in Figure 1-47 and described in Table 1-56. Return to the Summary Table. ### Figure 1-47. RESERVED11 Register # Table 1-56. RESERVED11 Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|-------------| | 31-0 | RESERVED | R | 0h | Reserved | ### 1.5.1.20 RESERVED12 Register (Offset = 41C4004Ch) [Reset = 00000000h] RESERVED12 is shown in Figure 1-48 and described in Table 1-57. Return to the Summary Table. ### Figure 1-48. RESERVED12 Register ### Table 1-57. RESERVED12 Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|-------------| | 31-0 | RESERVED | R | 0h | Reserved | ### 1.5.1.21 RESERVED13 Register (Offset = 41C40050h) [Reset = 00000000h] RESERVED13 is shown in Figure 1-49 and described in Table 1-58. Return to the Summary Table. ### Figure 1-49. RESERVED13 Register # Table 1-58. RESERVED13 Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|-------------| | 31-0 | RESERVED | R | 0h | Reserved | ### 1.5.1.22 RESERVED14 Register (Offset = 41C40054h) [Reset = 00000000h] RESERVED14 is shown in Figure 1-50 and described in Table 1-59. Return to the Summary Table. ### Figure 1-50. RESERVED14 Register ### Table 1-59. RESERVED14 Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|-------------| | 31-0 | RESERVED | R | 0h | Reserved | ### 1.5.1.23 RESERVED15 Register (Offset = 41C40058h) [Reset = 00000000h] RESERVED15 is shown in Figure 1-51 and described in Table 1-60. Return to the Summary Table. ### Figure 1-51. RESERVED15 Register # Table 1-60. RESERVED15 Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|-------------| | 31-0 | RESERVED | R | 0h | Reserved | ### 1.5.1.24 RESERVED16 Register (Offset = 41C4005Ch) [Reset = 00000000h] RESERVED16 is shown in Figure 1-52 and described in Table 1-61. Return to the Summary Table. ### Figure 1-52. RESERVED16 Register # Table 1-61. RESERVED16 Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|-------------| | 31-0 | RESERVED | R | 0h | Reserved | ### 1.5.1.25 RESERVED17 Register (Offset = 41C40060h) [Reset = 00000000h] RESERVED17 is shown in Figure 1-53 and described in Table 1-62. Return to the Summary Table. ### Figure 1-53. RESERVED17 Register # Table 1-62. RESERVED17 Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|-------------| | 31-0 | RESERVED | R | 0h | Reserved | ### 1.5.1.26 RESERVED18 Register (Offset = 41C40064h) [Reset = 00000000h] RESERVED18 is shown in Figure 1-54 and described in Table 1-63. Return to the Summary Table. ### Figure 1-54. RESERVED18 Register ### Table 1-63. RESERVED18 Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|-------------| | 31-0 | RESERVED | R | 0h | Reserved | ### 1.5.1.27 RESERVED19 Register (Offset = 41C40068h) [Reset = 00000000h] RESERVED19 is shown in Figure 1-55 and described in Table 1-64. Return to the Summary Table. ### Figure 1-55. RESERVED19 Register # Table 1-64. RESERVED19 Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|-------------| | 31-0 | RESERVED | R | 0h | Reserved | ### 1.5.1.28 RESERVED20 Register (Offset = 41C4006Ch) [Reset = 00000000h] RESERVED20 is shown in Figure 1-56 and described in Table 1-65. Return to the Summary Table. ### Figure 1-56. RESERVED20 Register ### Table 1-65. RESERVED20 Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|-------------| | 31-0 | RESERVED | R | 0h | Reserved | ### 1.5.1.29 RESERVED21 Register (Offset = 41C40070h) [Reset = 00000000h] RESERVED21 is shown in Figure 1-57 and described in Table 1-66. Return to the Summary Table. ### Figure 1-57. RESERVED21 Register # Table 1-66. RESERVED21 Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|-------------| | 31-0 | RESERVED | R | 0h | Reserved | ### 1.5.1.30 RESERVED22 Register (Offset = 41C40074h) [Reset = 00000000h] RESERVED22 is shown in Figure 1-58 and described in Table 1-67. Return to the Summary Table. ### Figure 1-58. RESERVED22 Register ### Table 1-67. RESERVED22 Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|-------------| | 31-0 | RESERVED | R | 0h | Reserved | ### 1.5.1.31 RESERVED23 Register (Offset = 41C40078h) [Reset = 00000000h] RESERVED23 is shown in Figure 1-59 and described in Table 1-68. Return to the Summary Table. ### Figure 1-59. RESERVED23 Register # Table 1-68. RESERVED23 Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|-------------| | 31-0 | RESERVED | R | 0h | Reserved | www.ti.com Architecture # 1.5.1.32 BOOTCRC Register (Offset = 41C4007Ch) [Reset = 00000000h] BOOTCRC is shown in Figure 1-60 and described in Table 1-69. Return to the Summary Table. BOOTCRC records the 32-bit CRC of all locations in OPEN including reserved locations. # Figure 1-60. BOOTCRC Register # Table 1-69. BOOTCRC Register Field Descriptions | | | | | <u> </u> | |------|-------|------|-------|-------------| | Bit | Field | Туре | Reset | Description | | 31-0 | DATA | R | 0h | | Architecture www.ti.com This page intentionally left blank. # Chapter 2 **PMCU** The power management and clock unit (PMCU) is a unified system module which provides all power management, clock configuration, and reset control functionality for the device. All power management unit (PMU) and clock module (CKM) policies for device operation are configured through memory-mapped registers in the system controller (SYSCTL). | 2.1 PMCU Overview | | |--------------------------------|--| | 2.2 Power Management (PMU) | | | 2.3 Clock Module (CKM) | | | 2.4 System Controller (SYSCTL) | | | 2.5 Quick Start Reference | | | 2.6 PMCU Registers | | | 2.0 1 m 00 1 togic to 1 | | ## 2.1 PMCU Overview The power management and clock unit (PMCU) provides all power, clocking, reset, and system control services for the device. The PMCU contains three submodules to provide this functionality: the power management unit (PMU), the clock module (CKM), and the system controller (SYSCTL). The PMU is an analog submodule that generates the internal regulated supplies for the device and supervises the condition of the external supply. The PMU also contains voltage and current reference circuits used by the on-chip regulators and analog peripherals. The CKM is an analog submodule that provides clock sources (internal oscillators) and presents these clock sources to SYSCTL. SYSCTL distributes these clock sources to the CPU, buses, and peripherals on the device. The SYSCTL is a digital submodule that provides the control logic for all functions in the PMCU. In addition, SYSCTL contains the memory-mapped registers used by software to configure power management and clocks, assess the status of the device, and control resets. SYSCTL also provides 4 bytes of general-purpose memory that is retained in SHUTDOWN mode and can be used to store status information in SHUTDOWN mode when SRAM and register contents are lost. Figure 2-1 shows the interfaces between the PMCU and the device supplies, clocks, and signals. Configuration of the PMCU by software is always done through memory-mapped registers in the SYSCTL submodule. Figure 2-1. MSPM0Lxx PMCU Top Level # Note Not all devices have all of the PMCU features shown in Figure 2-1. See the device-specific data sheet to understand the features present on a given device. ## **Using this Guide** The PMU, CKM, and SYSCTL sections of this chapter describe the functionality provided by each submodule in detail. The quick start section describes overall system level operation of the PMCU and how to configure the PMCU for different application scenarios. ## 2.1.1 Power Domains Two core power domains are provided on the device: PD1 and PD0. PD1 is always powered in RUN and SLEEP modes, but is disabled in all other modes. PD0 is always powered in RUN, SLEEP, STOP and STANDBY modes. PD1 and PD0 are both disabled in SHUTDOWN mode. - The PD1 domain includes the CPU subsystem, the SRAM memory, PD1 peripherals, and the PD1 peripheral bus, which runs from MCLK (including the DMA) with a maximum frequency of 32 MHz. While PD1 is disabled in STOP and STANDBY mode, the CPU registers, SRAM, and peripheral MMR configuration registers are maintained in retention such that they are available to resume operation immediately when STOP or STANDBY modes are exited. - The PD0 domain includes the PD0 peripherals and PD0 bus segment which runs from ULPCLK with a max frequency of 32 MHz in RUN and SLEEP mode, 4 MHz in STOP mode, and 32 kHz in STANDBY mode. The PD0 domain is powered in all modes except SHUTDOWN and can be thought of as an "always-on" domain. The device-specific data sheet describes which peripherals on a device are in PD1 and which are in PD0. The device also has a single external supply (VDD) domain that provides power to the IO and analog peripherals. # 2.1.2 Operating Modes Five operating modes (power modes) are provided to allow for optimization of the device power consumption based on application requirements. In order of decreasing power, the modes are: RUN, SLEEP, STOP, STANDBY, and SHUTDOWN. Figure 2-2 shows the interaction between the modes. Figure 2-2. MSPM0Lxx Operating Modes Section 2.1.2.6 indicates what functions are available in each operating mode of the device. See the operating mode selection section for information on how to configure the device for a particular operating mode. ## **Operating Mode Concept** MSPM0 MCUs implement a policy-based power and clock management scheme. Policies can be configured through application software for how the clocking is to managed in each operating mode to obtain the best balance of power and performance for a given application. After the operating policy for each mode is configured, application software can enter and exit the various operating modes through simple register commands, and SYSCTL automatically manages all the necessary PMU states, oscillator and clock enable and disables, and the SYSOSC frequency according to the software-defined policies and software-selected mode. A variety of hardware-triggered low-power mode suspension mechanisms also exist to enable on-demand access to a fast clock when requested by supported peripherals, as well as functions such as DMA and ADC triggering from low-power modes. The policy-driven operating mode scheme together with the asynchronous low-power mode suspension mechanisms enable application software to select the operating mode and corresponding policy that provide the lowest possible power consumption for background activities, with transient foreground activities either bringing up the DMA, bringing up a fast clock, or bringing the device to RUN (in the case of an IRQ) for burst handling. ## 2.1.2.1 RUN Mode In RUN mode, the CPU is active executing code and any peripheral can be enabled. There are three RUN mode policy options: RUN0, RUN1, and RUN2. - RUNO: The MCLK and the CPUCLK run from a fast clock source (SYSOSC). - **RUN1**: The MCLK and the CPUCLK run from LFCLK (at 32 kHz) to reduce active power, but SYSOSC is left enabled to service analog modules such as an ADC, OPA, or COMP (in HS mode). - **RUN2**: The MCLK and the CPUCLK run from LFCLK (at 32 kHz), and SYSOSC is completely disabled to save power. This is the lowest power state with the CPU running. #### 2.1.2.2 SLEEP Mode In SLEEP mode, the CPU is disabled (clock gated) but otherwise the device configuration is the same as RUN. There are three SLEEP mode policy options: SLEEP0, SLEEP1, and SLEEP2. The SLEEPx policy is determined by the current RUNx policy when SLEEP mode is entered. - **SLEEP0**: Identical to RUN0, with the CPU disabled. - **SLEEP1**: Identical to RUN1, with the CPU disabled. - SLEEP2: Identical to RUN2, with the CPU disabled. # 2.1.2.3 STOP Mode In STOP mode, the CPU, SRAM, and PD1 peripherals are disabled and in retention (if applicable). PD0 peripherals are available with a max ULPCLK frequency of 4 MHz. SYSOSC can run at higher frequencies to support ADC, OPA, or HS COMP operation, but ULPCLK will be automatically limited to the 4 MHz SYSOSC output by SYSCTL. DMA is available to be triggered. A DMA trigger wakes the PD1 power domain to make the SRAM and DMA available for processing the DMA transfer, and the DMA transfer is processed at the current MCLK and ULPCLK rate. After the transfer completes, the SRAM is returned to retention and PD1 is disabled automatically. STOP mode is the lowest power mode that supports ADC, OPA, and high-speed COMP operation. There are three policy options for STOP mode: STOP0, STOP1, and STOP2. - **STOP0**: The SYSOSC is left running at the current frequency when entering STOP mode (either 32 MHz, 24 MHz, 16 MHz, or 4 MHz). ULPCLK is always limited to 4 MHz automatically by hardware, but SYSOSC is not disturbed to support consistent operation of analog peripherals such as the ADC, OPA, or COMP. - NOTE: If STOP0 is entered from RUN1 (SYSOSC enabled but MCLK sourced from LFCLK), SYSOSC remains enabled as in RUN1, and ULPCLK remains at 32 kHz as in RUN1. - NOTE: If STOP0 is entered from RUN2 (SYSOSC was disabled and MCLK was sourced from LFCLK), SYSOSC remains disabled as in RUN2, and ULPCLK remains at 32 kHz as in RUN2. - **STOP1**: The SYSOSC is gear shifted from its current frequency to 4 MHz for the lowest power consumption in STOP mode with SYSOSC running. SYSOSC and ULPCLK both run at 4 MHz. - **STOP2**: The SYSOSC is disabled and the ULPCLK is sourced from LFCLK at 32 kHz. This is the lowest power state in STOP mode. # 2.1.2.4 STANDBY Mode In STANDBY mode, the CPU, SRAM, and PD1 peripherals are disabled and in retention. PD0 peripherals, with the exception of the ADC and OPA, are available with a maximum ULPCLK frequency of 32 kHz. SYSOSC is disabled. DMA is available to be triggered. A DMA trigger wakes the PD1 power domain to make the SRAM and DMA available for processing the DMA transfer, and the DMA transfer is processed at the current MCLK and ULPCLK rate (32 kHz). After the transfer completes, the SRAM is returned to retention and PD1 is disabled automatically. ADC, OPA, and high-speed COMP operation is not supported in STANDBY mode. There are 2 policy options for STANDBY mode: STANDBY0 and STANDBY1. - STANDBY0: All PD0 peripherals receive the ULPCLK and LFCLK. - STANDBY1: Only TIMG0 and TIMG1 receive ULPCLK or LFCLK. A TIMG0 or TIMG1 interrupt or ADC trigger in STANDBY1 always triggers an asynchronous fast clock request to wake the system. Other PD0 peripherals (such as UART, I2C, GPIO, and COMP) can also wake the system upon an external event through an asynchronous fast clock request, but they are not actively clocked in STANDBY1. #### 2.1.2.5 SHUTDOWN Mode In SHUTDOWN mode, no clocks are available. The core regulator is completely disabled and all SRAM and register contents are lost, with the exception of the 4 bytes of general-purpose memory in SYSCTL that can be used to store state information. The BOR and bandgap circuit are disabled. The device can wake through a wake-up capable IO, a debug connection, or NRST. SHUTDOWN mode has the lowest current consumption of any operating mode. Exiting SHUTDOWN mode triggers a BOR. # 2.1.2.6 Supported Functionality by Operating Mode Supported functionality in each operating mode is given in Table 2-1. Functional key: - **EN**: The function is enabled in the specified mode. - **DIS**: The function is disabled (either clock or power gated) in the specified mode, but the function's configuration is retained. - OPT: The function is optional in the specified mode, and remains enabled if configured to be enabled. - NS: The function is not automatically disabled in the specified mode, but its use is not supported. - OFF: The function is fully powered off in the specified mode, and no configuration information is retained. ## Note For a complete listing of the behavior for each peripheral instance on a given device, see the Supported Functionality by Operating Mode table in the detailed description section of the devicespecific data sheet. Table 2-1. MSPM0Lxx Supported Functionality by Operating Mode | | | | RUN | | | SLEEP | | | STOP | | STANDBY | | z | |----------------|-------------------|------------|--------|------|------------|--------|--------|--------------------------|-------|-------|----------|----------|----------| | Operating Mode | | RUNO | RUN1 | RUN2 | SLEEPO | SLEEP1 | SLEEP2 | STOP0 | STOP1 | STOP2 | STANDBY0 | STANDBY1 | SHUTDOWN | | Oscillators | SYSOSC | EN | EN | DIS | EN | EN | DIS | OPT <sup>(1)</sup> | EN | DIS | DIS | DIS | OFF | | Oscillators | LFOSC | | | | | | EN | | | | | | OFF | | | CPUCLK | 32M<br>max | 32k | 32k | | | | DIS | | | | | OFF | | | MCLK to PD1 | 32M<br>max | 32k | 32k | 32M<br>max | 32k | 32k | DIS | | | | OFF | | | | ULPCLK to PD0 | 32M<br>max | 32k | 32k | 32M<br>max | 32k | 32k | 4M<br>max <sup>(1)</sup> | 4M | 32 | 2k | DIS | OFF | | Clocks | ULPCLK to TIMG0/1 | 32M<br>max | 32k | 32k | 32M<br>max | 32k | 32k | 4M<br>max <sup>(1)</sup> | 4M | | 32k | | OFF | | | MFCLK | OPT | D | IS | OPT | D | IS | OF | PT | | DIS | | OFF | | Clocks | LFCLK | | | | | 3: | 2k | | | | | DIS | OFF | | | LFCLK to TIMG0/1 | | | | | | 32k | | | | | | OFF | | | MCLK Monitor | | OPT DI | | | | | | | | DIS | OFF | | Table 2-1. MSPM0Lxx Supported Functionality by Operating Mode (continued) | | 145.02 11 11.01 | | RUN | | | SLEEP | | | STOP | | STANDBY | | z | |---------------------|-----------------|---------------------|------|--------------|--------|--------|--------------|-----------------------------------|--------------------|----------|-----------------|----------|----------| | Ol | perating Mode | RUNO | RUN1 | RUN2 | SLEEPO | SLEEP1 | SLEEP2 | STOP0 | STOP1 | STOP2 | STANDBY0 | STANDBY1 | SHUTDOWN | | | POR monitor | | | | | | Е | N | | | | | | | PMU | BOR monitor | | | | | | EN | | | | | | OFF | | | Core regulator | | | FULL | DRIVE | | | RED | UCED D | RIVE | LOW | DRIVE | OFF | | | CPU | | EN | | | | | D | IS | | • | | OFF | | Core | DMA | | | 0 | PT | | | | DIS (tri | ggers su | pported) | | OFF | | Functions | Flash | | | Е | N | | | | | DIS | | | OFF | | | SRAM | | | E | :N | | | | | OFF | | | | | Darinharala | PD1 Peripherals | | | 0 | PT | | | DIS or OFF (peripheral dependent) | | | | | OFF | | Peripherals | PD0 Peripherals | | | | | 0 | PT | OP | | | | | OFF | | | ADC | | | | OI | PT | | | | NS (trig | gers supported) | | OFF | | | OPA | OPT | N | IS | OPT | N | IS | OPT | | | NS | | OFF | | | GPAMP | | | | OI | PT | | • | | | NS | | OFF | | Analog | COMP, 8-bit DAC | OPT | | (ULP<br>ily) | OPT | | (ULP<br>ily) | 0 | PT | OP' | T (ULP o | only) | OFF | | | VREF | | OPT | | | | | OPT (sample mode) | | | | | OFF | | IOMUX and IO Wakeup | | EN | | | | | | | DIS w/<br>WAKE | | | | | | Wake Source | | N/A ANY IRQ PD0 IRQ | | | | | | | IOMU<br>X,<br>NRST | | | | | <sup>(1)</sup> If STOP0 is entered from RUN1 (SYSOSC enabled but MCLK sourced from LFCLK), SYSOSC will remain enabled as it was in RUN1 and ULPCLK will remain at 32 kHz as it was in RUN1. If STOP0 is entered from RUN2 (SYSOSC was disabled and MCLK was sourced from LFCLK), SYSOSC will remain disabled as it was in RUN2 and ULPCLK will remain at 32 kHz as it was in RUN2. # 2.1.2.7 Suspended Low Power Mode Operation Some peripherals can be configured to temporarily suspend STOP or STANDBY mode operation to handle a temporary activity or process an event. There are two ways in which STOP or STANDBY mode can be suspended: - An asynchronous fast clock request - A DMA trigger # Suspended STOP or STANDBY for an Asynchronous Fast Clock Request An asynchronous fast clock request temporarily suspends any active low-power mode and runs the MCLK and ULPCLK tree at 32 MHz, sourced from SYSOSC. Asynchronous fast clock requests are also functional in RUN and SLEEP mode if MCLK is sourced from either LFCLK at 32 kHz or SYSOSC at a frequency lower than 32 MHz. While asynchronous fast clock requests suspend the low-power mode and change clock tree configuration to support 32 MHz operation, these requests do not enable the PD1 power domain if the device was in STOP or STANDBY mode. This functionality enables use cases such as: - TIMG0 or TIMG1 wakeup from STANDBY1 - On-demand UART, I<sup>2</sup>C, or SPI communication. - Timer-triggered ADC sampling from STANDBY mode # Suspended STOP or STANDBY for a DMA Trigger <sup>(2)</sup> When using the STANDBY1 policy for STANDBY, only TIMG0/1 are clocked. Other PD0 peripherals can generate an asynchronous fast clock request upon external activity, but they will not be actively clocked. If a DMA trigger is asserted in STOP or STANDBY mode, the low-power mode is temporarily suspended and the PD1 power domain (including the SRAM and flash memory) is enabled to process the DMA request. Unlike the asynchronous fast clock request, DMA transfers do not change the clock tree configuration. A DMA request in STOP or STANDBY mode is processed at the current ULPCLK rate. # 2.2 Power Management (PMU) The power management unit (PMU) generates the regulated core supplies for the device and provides supervision of the external supply. It also contains a bandgap voltage reference used by the PMU and other analog peripherals. ## Key PMU features include: - Support for device operation across a wide supply range (1.62 V to 3.6 V) - Low-dropout linear voltage regulator to generate the internal core logic supply, with multiple operating modes for reducing device current in low-power modes (managed automatically by SYSCTL) - Power-on reset (POR) supply monitor - · Brownout reset (BOR) supply monitor with four configurable threshold voltages - · Bandgap voltage reference supporting the BOR, core regulator, and analog peripherals - · Analog mux VBOOST unit for increasing analog mux performance - · Temperature sensor with connection to the ADC Figure 2-3. MSPM0Lxx PMU Block Diagram ## 2.2.1 Power Supply Power is supplied to the device through the VDD and VSS connections. The device supports operation with a supply voltage of 1.62 V to 3.6 V and will start with a 1.62 V supply. A decoupling capacitor ( $C_{VDD}$ ) must be placed across all VDD and VSS supply pairs. See the device-specific data sheet for the correct value and tolerance of $C_{VDD}$ . Products with 64 pins or less typically have a single VDD/VSS power pair. VDD is used directly to provide the IO supply (VDDIO) and the analog supply (VDDA). VDDIO and VDDA are internally connected to VDD so that additional power supply pins are not required. # 2.2.2 Core Regulator The PMU uses an on-chip, configurable, low-dropout linear voltage regulator to generate a 1.35V supply rail to power the device core. In general, the core regulator output ( $V_{CORE}$ ) supplies power to the core logic, which includes the CPU, digital peripherals and the device memory. The core regulator requires an external capacitor $(C_{VCORE})$ which is connected between the device VCORE pin and VSS (ground). See the device specific data sheet for the correct value and tolerance of $C_{VCORE}$ . The core regulator is active in all power modes except for SHUTDOWN. In all other power modes (RUN, SLEEP, STOP, and STANDBY) the drive strength of the regulator is configured automatically to support the max load current of each mode. This reduces the quiescent current of the regulator when using low-power modes, improving low power performance. SYSCTL automatically configures the regulator for best power consumption based on the power mode which is currently active. # 2.2.3 Supply Supervisors The PMU provides two supply supervisor circuits: - A power-on reset (POR) circuit to indicate that the external supply has reached sufficient voltage to start the on-chip bandgap reference and BOR circuit - A user-programmable brownout reset (BOR) circuit which ensures that the external supply is maintained at a sufficient voltage to support correct operation of the device # 2.2.3.1 Power-on Reset (POR) Supervisor The power-on reset (POR) supervisor monitors the external supply (VDD) and asserts or de-asserts a POR violation to SYSCTL. During cold power-up, the device is held in a POR state until VDD passes the POR+ threshold. Once VDD has passed POR+, the POR state is released and the bandgap reference and BOR monitor circuit are started. If VDD drops below the POR- level, then a POR- violation is asserted and the device is again held in a POR reset state. The POR supervisor does not indicate that VDD has reached a level high enough to support correct operation of the device. Rather, it is the first step in the boot process and is used to determine if the supply voltage is sufficient to power up the bandgap reference and BOR circuit, which are then used to determine if the supply has reached a level sufficient to for the device to run correctly. The POR supervisor is active in all power modes including SHUTDOWN, and cannot be disabled. ## 2.2.3.2 Brownout Reset (BOR) Supervisor The brownout reset (BOR) supervisor monitors the external supply (VDD) and asserts or de-asserts a BOR violation to SYSCTL. The primary responsibility of the BOR circuit is to ensure that the external supply is maintained high enough to enable correct operation of internal circuits, including the core regulator. The BOR threshold reference is derived from the internal bandgap circuit. The threshold itself is programmable and is always higher than the POR threshold. During cold start, after VDD passes the POR+ threshold the bandgap reference and BOR circuit are started. The device is then held in a BOR state until VDD passes the BOR0+ threshold. Once VDD passes BOR0+, the BOR supervisor releases the device to continue the boot process, and the PMU is started. There are four selectable BOR threshold levels (BOR0-BOR3). During startup, the BOR threshold is always BOR0 (the lowest value) to ensure that the device always starts at the specified VDD minimum (1.62 V). After boot, software can optionally re-configure the BOR circuit to use a different (higher) threshold level (BOR1-BOR3). When the BOR threshold is BOR0, a BOR0- violation always generates a BOR- violation signal to SYSCTL, generating a BOR level reset. When the BOR threshold is re-configured to BOR1, BOR2, or BOR3, the BOR circuit generates a SYSCTL interrupt rather than asserting the BOR- violation. This can be used to give the application an indication that the supply has dropped below a certain level without causing a reset. To change the BOR level from the default (BOR0), first select the desired value in the LEVEL field of the BORTHRESHOLD register in SYSCTL. Then, activate the threshold set in the LEVEL field by setting the GO bit in the BORCLRCMD register. The change can be validated by testing the BORCURTHRESOLD field in the SYSSTATUS register, which returns a value corresponding to the currently active BOR threshold. The BOR threshold change takes approximately 15µs to complete, during which time the BOR circuit is blind to changes in the supply. If the BOR is in interrupt mode (a threshold level of BOR1-3), and the supply drops below the corresponding BORx- level, an interrupt is generated and the BOR circuit automatically switches the BOR threshold level to BOR0 to ensure that a BOR- violation is asserted if VDD drops below BOR0-. Application software can set the BOR level back to the level specified in the LEVEL field of the BORTHRESHOLD register by setting the GO bit again in the BORCLRCMD register. The BOR supervisor is active in RUN, SLEEP, STOP, and STANDBY modes but is disabled automatically in SHUTDOWN mode. # 2.2.3.3 POR and BOR Behavior During Supply Changes When the supply voltage (VDD) drops below POR-, the entire device state is cleared. Small variations in VDD that do not pass below the BOR0- threshold do not cause a BOR- violation, and the device continues to run. Behavior for BORx thresholds other than BOR0 (for example, BOR1-BOR3) is the same as is shown for BOR0, except that the BOR circuit is configured to generate an interrupt rather than immediately triggering a BOR reset. Figure 2-4. POR/BOR vs. Supply Voltage (VDD) # 2.2.4 Bandgap Reference The PMU provides a temperature and supply voltage stable bandgap voltage reference which is used by the device for internal functions, including: - · Deriving the brownout reset circuit thresholds - Setting the output voltage for the core regulator - Deriving the on-chip VREF levels for on-chip analog peripherals The bandgap reference is enabled in RUN, SLEEP, STOP modes. It operates in a sampled mode in STANDBY to reduce power consumption. It is disabled in SHUTDOWN mode. SYSCTL manages the bandgap state automatically; no user configuration is required. # 2.2.5 Temperature Sensor The PMU provides a basic temperature sensor which can be used to approximate the temperature of the device. The temperature sensor is connected internally to the ADC, and the ADC must be used to perform a temperature measurement. See the device-specific data sheet to determine the correct internal ADC channel to use when measuring the temperature sensor. The temperature sensor outputs a voltage which has a linear relationship with temperature. The temperature coefficient (TS<sub>c</sub>) is the slope of the temperature-voltage relationship (given in mV/C), and is given in the specifications section of the device-specific data sheet. A unit-specific single-point trim value (TEMP\_SENSE0.DATA) is provided in the factory constants memory of each device. This value indicates the temperature sensor output voltage at the factory trim temperature ( $TS_{TRIM}$ ), in ADC result code format. The ADC result code in TEMP\_SENSE0.DATA is based upon 12-bit sampling mode together with the 1.4V internal voltage reference. The TS<sub>TRIM</sub> temperature is also given in the specifications section of the device-specific data sheet. The approximate temperature of the device can be computed through the use of the following parameters: - TS<sub>c</sub>, taken from the device data sheet - TEMP\_SENSE0.DATA, taken from the unit-specific factory constants memory - TS<sub>TRIM</sub>, taken from the device data sheet - V<sub>SAMPLE</sub> (voltage sample of the temperature sensor at time of interest, taken with the ADC) The temperature is computed through the linear relationship given in Equation 1, where $V_{SAMPLE}$ is the current temperature sensor voltage, and $V_{TRIM}$ is the factory calibrated temperature sensor voltage at the $TS_{TRIM}$ temperature (derived from TEMP\_SENSE0.DATA): $$T_{SAMPLE} = (1 / TS_c) * (V_{SAMPLE} - V_{TRIM}) + TS_{TRIM}$$ (1) The ADC<sub>CODE</sub> raw result can be converted to a voltage equivalent ( $V_{SAMPLE}$ ) as shown in the relationship in Equation 2, where RES is the ADC resolution in bits, and VREF is the ADC reference voltage. $$V_{SAMPLE} = (VREF / 2^{RES}) * (ADC_{CODE} - 0.5)$$ (2) ## **Example** To illustrate the process of converting an ADC sample of the temperature sensor into an approximate device temperature, an example is given below. Example parameters: - TS<sub>c</sub> = -2.04 mV/C - TEMP\_SENSE0.DATA = 1857 (ADC result code based on 12-bit mode and a 1.4-V reference) - TS<sub>TRIM</sub> = 30C - ADC<sub>CODE</sub> = 1677 (ADC result code based on 12-bit mode and a 1.4-V reference) First, the current temperature sensor sample voltage is calculated using Equation 2: $$V_{SAMPLE} = (1.4 \text{ V} / 4096) * (1677 - 0.5) = 0.5730 \text{ V}$$ (3) Then, the single-point calibration voltage is calculated using the same means: $$V_{TRIM} = (1.4 \text{ V} / 4096) * (1857 - 0.5) = 0.6345 \text{ V}$$ (4) Then, the temperature is approximated using Equation 1: $$T_{SAMPLE} = (1 / -0.002044) * (0.5730 V - 0.6345) + 30^{\circ}C = 60^{\circ}C$$ (5) ## **Note** The temperature sensor is not available in STANDBY and SHUTDOWN operating modes. # 2.2.6 VBOOST for Analog Muxes The VBOOST circuit in the PMU generates an internal VBOOST supply that is used by the analog muxes in COMPs, GPAMPs, and OPAs, if present on a device. The VBOOST circuit enables consistent analog mux performance across the external supply voltage (VDD) range. # **Enabling and Disabling VBOOST** SYSCTL automatically manages the enable request for the VBOOST circuit based on the following parameters: - The COMP, OPA, and GPAMP peripheral PWREN settings - The MODE setting of any COMP which is enabled (FAST vs. ULP mode) - The ANACPUMPCFG control bits in the GENCLKCFG register in SYSCTL VBOOST is disabled by default following a SYSRST. Application software is not required to enable the VBOOST circuit prior to using the COMP, OPA, or GPAMP. When a COMP, OPA, or the GPAMP is enabled by application software, SYSCTL also enables the VBOOST circuit to support the analog peripheral. The VBOOST circuit has a startup time requirement (12 µs typical) to transition from a disabled state to an enabled state. If a COMP, OPA, or the GPAMP is enabled when VBOOST is disabled, then the corresponding analog peripheral ready status is not asserted until both the peripheral and the VBOOST circuit are ready. If the startup time of the COMP, OPA, or GPAMP is less than the VBOOST startup time, the peripheral startup time is extended to account for the VBOOST startup time. Alternatively, application software can force the VBOOST circuit to be enabled at all times (with ANACPUMPCFG=0x2) or while in RUN or SLEEP mode (with ANACPUMPCFG=0x1) so that there is no additional startup delay when enabling a COMP, OPA, or the GPAMP. Table 2-2 gives the behavior of the ANACPUMPCFG control and corresponding application use cases. | | | ble 2-2. I ofcling VDOOST Enable V | THE ANALOG SHIP OF S | | | | | |-----|---------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | | SOOST Control IACPUMPCFG) | | Behavior | | | | | | VAL | MODE | VBOOST Enable | Application Use Case | | | | | | 0x0 | ONDEMAND | VBOOST is automatically enabled by SYSCTL only when a COMP, OPA, or the GPAMP is enabled. | This setting provides the lowest power consumption in all modes when fast startup of the COMP, OPA, or GPAMP is not critical. | | | | | | 0x1 | ONACTIVE | VBOOST is forced to be enabled when the device is in RUN or SLEEP mode. VBOOST is also kept enabled in STOP or STANDBY mode if a COMP, OPA, or the GPAMP is enabled. | This setting provides low power consumption by disabling the VBOOST automatically in STOP and STANDBY modes when no peripherals requiring VBOOST are enabled. VBOOST is automatically reenabled upon exit to RUN mode to provide fast startup of the COMP, OPA, or GPAMP in the event that application software enables a COMP, OPA, or GPAMP in RUN mode. | | | | | | 0x2 | ONALWAYS | VBOOST is forced to be enabled in all operating modes except SHUTDOWN. | This setting makes sure that the COMP, OPA, and GPAMP never incur additional startup latency due to VBOOST startup in applications where fast COMP, OPA, or GPAMP startup is critical. | | | | | Table 2-2. Forcing VBOOST Enable With ANACPUMPCFG The VBOOST enable, VBOOST clock selection, and VBOOST clock error logic is shown in Figure 2-5. Figure 2-5. VBOOST Request Logic # **VBOOST Clock** The VBOOST circuit requires a functional clock to operate. VBOOST is clocked by either the SYSOSC (4-MHz output) or the LFCLK (32 kHz) based on the currently active MCLK and ULPCLK tree source. The VBOOST clock is selected by automatically by SYSCTL according to the logic shown in Figure 2-5 and described here: - When the MCLK and ULPCLK are sourced from LFCLK (32 kHz), the VBOOST is also sourced from LFCLK at 32 kHz. - When the MCLK and ULPCLK are sourced from any other source (for example, not sourced from LFCLK), VBOOST is sourced from the SYSOSC 4-MHz output. By definition, SYSOSC is always enabled when MCLK and ULPCLK are not sourced from LFCLK. Certain VBOOST operating conditions require that the VBOOST clock be 4 MHz (sourced from SYSOSC) and not 32 kHz (sourced from LFCLK). Such conditions include: - OPA operation or fast mode COMP operation - VBOOST is starting up (transitioning from disabled to enabled) The application software must make sure that MCLK and ULPCLK are not sourced from LFCLK when either of these conditions are present. SYSCTL does not change the current system clock configuration for a VBOOST request. If the MCLK and ULPCLK tree is sourced from LFCLK in one of these scenarios, SYSCTL asserts an ANACLKERR status in the SYSSTATUS register in SYSCTL to indicate to application software that there is a mismatch between the VBOOST clock requirement and the current MCLK and ULPCLK configuration. The complete clock requirements for VBOOST are given in Table 2-3. **Table 2-3. VBOOST Clock Requirements** | | VBOOST Request | VBOOST Circuit Clock<br>Requirement | MCLK and ULPCLK Source Requirement <sup>(1)</sup> | Supported Operating<br>Modes or Policies | |-------------------------------------------------------------------------------------------|----------------------------|-------------------------------------|---------------------------------------------------|----------------------------------------------------------------------------------| | No active request (VBOOST is disabled) | | N/A | Don't care | Don't care | | VBOOST is starting up from a disabled state | | 4 MHz | Not LFCLK | RUN0, SLEEP0, STOP0,<br>STOP1 | | OPA enabled | | 4 MHz | Not LFCLK | RUN0, SLEEP0, STOP0,<br>STOP1 | | | Fast mode (FAST) | 4 MHz | Not LFCLK | RUN0, SLEEP0, STOP0,<br>STOP1 | | COMP<br>enabled | Ultra-low-power mode (ULP) | 4 MHz or 32 kHz | Don't care | RUN0, RUN1, RUN2,<br>SLEEP0, SLEEP1, SLEEP2,<br>STOP0, STOP1, STOP2,<br>STANDBY0 | | GPAMP enabled <sup>(2)</sup> | | 4 MHz or 32 kHz | Don't care | RUN0, RUN1, RUN2,<br>SLEEP0, SLEEP1, SLEEP2,<br>STOP0, STOP1, STOP2,<br>STANDBY0 | | VBOOST running with no peripheral request active (due to ANACPUMPCFG!=0x0) <sup>(2)</sup> | | 4 MHz or 32 kHz | Don't care | RUN0, RUN1, RUN2,<br>SLEEP0, SLEEP1, SLEEP2,<br>STOP0, STOP1, STOP2,<br>STANDBY0 | <sup>(1)</sup> Application software must make sure that the clock system is configured as stated in the previous table to support proper VBOOST operation for each scenario. SYSCTL does not change the system clock configuration when VBOOST is requested. If a VBOOST request requires the VBOOST clock to be 4 MHz and MCLK is sourced from LFCLK, SYSCTL will assert an ANACLKERR to indicate to the application that the current system clock configuration is not valid to support the current VBOOST request. ## 2.2.7 Peripheral Power Enable Control All peripherals on a device, with the exception of infrastructure peripherals such as SYSCTL itself and the IOMUX, contain a power enable control register (PWREN) with a KEY and ENABLE field. Before any other <sup>(2)</sup> If no OPA is enabled and no COMP is enabled and configured in FAST mode, the VBOOST does not require a 4-MHz clock and VBOOST can run from LFCLK to reduce power consumption. However, if the VBOOST was previously disabled (no request present) and it is requested by a peripheral becoming enabled or by application software (ANACPUMPCFG!=0x0), a 4-MHz VBOOST clock is required for VBOOST startup. After VBOOST startup is complete, the VBOOST clock can be 32 kHz sourced from LFCLK if no OPA is enabled and no COMP is enabled in FAST mode. Changing the MCLK source to LFCLK during VBOOST startup can lead to incorrect operation of the VBOOST and inconsistent analog peripheral performance. When the VBOOST circuit has started and is ready, the ANACPUMPGOOD bit is set in the SYSSTATUS register in SYSCTL. peripheral registers are configured by software, the peripheral itself must be enabled by writing the ENABLE bit together with the appropriate KEY value to the peripheral's PWREN register. When a peripheral ENABLE bit is cleared, the peripheral can be considered to be inactive and the remaining peripheral-specific registers are isolated from the peripheral bus and thus are not be accessible for read/write operations. ## **Note** After setting the ENABLE | KEY bits in the PWREN register to enable a peripheral, wait at least 4 ULPCLK clock cycles before accessing the rest of the peripheral's memory-mapped registers. The 4 cycles allow for the bus isolation signals at the peripheral's bus interface to update. ## 2.2.7.1 Automatic Peripheral Disable in Low Power Modes Peripherals in power domain 1 (PD1) will be forced to a disabled state by SYSCTL upon entry into a STOP or STANDBY low-power mode. As such, these peripherals will not be available for use in STOP or STANDBY. Most PD1 peripherals will retain their configuration settings after being automatically disabled, such that reconfiguration is not required upon exit from STOP or STANDBY mode. See the peripheral-specific chapter in this guide for details on which peripheral registers are retained through STOP and STANDBY mode for PD1 peripherals. If a PD1 peripheral was multiplexed to an IO pin (through the IOMUX) in an output configuration, the last valid output state (logic 0 or logic 1) from the peripheral to the IO is latched upon entry to STOP or STANDBY mode. This prevents external circuits from being disturbed by SYSCTL disabling a peripheral during low-power operation. Upon exit from STOP or STANDBY mode, the IO is again connected to the peripheral as the peripheral becomes re-enabled. # 2.3 Clock Module (CKM) The clock module contains the oscillators, the clock monitors, and the clock selection and control logic. A frequency clock counter is also provided for checking and/or calibrating the frequency of high-speed clocks against a reference period/pulse provided on an IO pin. #### 2.3.1 Oscillators Several oscillators are provided for generating low to high frequency clocks for use by the system. The CKM contains all the oscillators in the device and uses them to generate the system clocks. ## **Internal Oscillators** - LFOSC: low frequency oscillator (32 kHz typical frequency) - SYSOSC: system oscillator (4 or 32 MHz factory-trimmed frequencies, 16 or 24 MHz user-trimmed frequencies) ## 2.3.1.1 Internal Low Frequency Oscillator (LFOSC) The low frequency oscillator (LFOSC) is an on-chip low power oscillator which is factory trimmed to a frequency of 32.768 kHz. LFOSC can provide higher accuracy when used over a reduced temperature range. See the device-specific data sheet for details. The LFOSC is active by default after a BOOTRST, sourcing the LFCLK. The LFOSC startup monitor sets the LFOSCGOOD bit in the CLKSTATUS register when LFOSC is ready. # 2.3.1.2 Internal System Oscillator (SYSOSC) The system oscillator (SYSOSC) is an on-chip, accurate, and configurable oscillator with factory-trimmed frequencies of 32 MHz (base frequency) and 4 MHz (low frequency) and support for user-trimmed operation at either 24 MHz or 16 MHz. Key features of the SYSOSC include: - High accuracy with optional frequency correction loop (FCL) - Fast start-up time from a disabled state - Capable of switching from base frequency to low frequency, or low frequency to base frequency, in one clock cycle with no functional interruption (gear shift) - Phase-aligned transition to minimize disturbance to peripherals - Fast settling to specified accuracy - SYSCTL can initiate seamless gear shift frequency switch in STOP mode to reduce SYSOSC current - A secondary output with a constant 4-MHz frequency for use by MFCLK and MFPCLK - When f<sub>SYSOSC</sub> = 32 MHz, the 4-MHz output is derived from SYSOSC divided digitally by 8. When f<sub>SYSOSC</sub> = 4 MHz, the 4-MHz output is derived from SYSOSC directly. User frequencies of 24 MHz and 16 MHz are supported with digital dividers of /6 and /4, respectively. SYSCTL manages the digital divider on this output to ensure a constant 4-MHz output regardless of the selected SYSOSC frequency. - Peripherals using this output through the MFCLK or MFPCLK see a continuous 4-MHz functional clock in RUN, SLEEP, and STOP modes, with reduced current in STOP mode when gear shift is enabled due to SYSOSC running natively at 4 MHz instead of at 32 MHz with a divide-by-8. The SYSOSC is active at base frequency (32 MHz) by default after a brownout reset, sourcing MCLK. ## 2.3.1.2.1 SYSOSC Gear Shift The SYSOSC can shift from base frequency (32 MHz) to low frequency (4 MHz), or low frequency back to base frequency, in a single SYSOSC clock cycle with the frequency change being phase aligned to minimize jitter. This feature is particularly well suited for low power, low cost microcontroller applications because it allows a single oscillator to be used to generate two frequencies: - A high-speed 32-MHz clock (for running the CPU during compute), which is only enabled when needed - A lower-speed 4-MHz clock (for running peripherals such as timers, UART interfaces, and I<sup>2</sup>C interfaces) which is continuously running When a high-speed clock is needed (for example, in RUN and SLEEP modes), SYSOSC can run at its base frequency to provide high performance. In such a case, SYSOSC can be used directly to source MCLK so that MCLK can be used by the CPU, DMA, and peripherals clocked by the bus. For peripherals that run continuously but do not require the high clock frequency, the middle frequency system clock (MFCLK) is provided at 4 MHz by taking the 32-MHz SYSOSC and dividing down by 8. When the fast 32-MHz clock is not needed (for example, if the CPU has completed processing data), then in STOP mode SYSOSC can be gear shifted down to 4 MHz in one cycle, and MFCLK switches to being clocked directly by SYSOSC- keeping a continuously running 4-MHz clock, but with a reduction in SYSOSC current and no need for a separate oscillator to provide the 4-MHz clock. When the CPU is again needed, SYSOSC can be switched back from 4 MHz to 32 MHz. This transition also occurs in one SYSOSC clock cycle. During the gear shift up, MFCLK switches back to SYSOSC/8 to keep the 4-MHz constant frequency. The timing transition between base frequency (32 MHz) and low frequency (4 MHz) during a gearshift down request is shown in Figure 2-6. Figure 2-6. SYSOSC Gearshift Down Timing The SYSOSC gearshift mode is tightly integrated with the power management scheme and is controlled by SYSCTL. Gearshift mode can be used when switching between RUN mode and STOP mode (gear down) and STOP mode and RUN mode (gear up). To use gearshift in STOP mode to reduce SYSOSC current, set the USE4MHZSTOP bit in the SYSOSCCFG register. Note that if SYSOSC is configured for 4-MHz operation in RUN and SLEEP mode as well as STOP mode (no gear shift), then the USE4MHZSTOP bit does not need to be set to keep the SYSOSC at 4 MHz when entering STOP mode. ## 2.3.1.2.2 SYSOSC Frequency and User Trims SYSOSC comes factory trimmed for operation at either 32 MHz or 4 MHz. The default frequency of operation is the base frequency (32 MHz). It is possible to run SYSOSC continuously at 4 MHz for reduced current operation if 4 MHz provides suitable performance for the application. To change the SYSOSC frequency to 4 MHz, set the FREQ field in the SYSOSCCFG register to 4M. ## Note The FREQ field in the SYSOSCCFG register must only be changed when SYSOSC is the MCLK source. Do not change the SYSOSC FREQ configuration when MCLK is sourced from LFCLK. SYSOSC also supports user-trimmed operation at either 24 MHz or 16 MHz. No other frequencies are allowed. To run SYSOSC at a user trimmed frequency, first ensure that SYSOSC is running at the base frequency (32 MHz). Then, configure the SYSOSCTRIMUSER register for the target frequency. Finally, select USER in the FREQ field of the SYSOSCCFG register. For trimming, see the trim procedure. ## Note When running at a user frequency (16 MHz or 24 MHz), changing the SYSOSC frequency selection to low frequency (4 MHz) requires a transition through the base frequency (32 MHz) before SYSOSC switches to low frequency. The same is true when switching from low frequency to a user frequency. This change is managed entirely in hardware. Software can directly select the low frequency when running at a user frequency (and the reverse) but the hardware transitions through the base frequency when making the frequency change. If MFCLK (4 MHz) is enabled, it will be maintained at 4 MHz during the transition. # 2.3.1.2.3 SYSOSC Frequency Correction Loop The SYSOSC frequency accuracy can be improved through the use of the SYSOSC frequency correction loop (FCL) feature. The FCL circuit utilizes an external resistor, populated between the ROSC pin and VSS, to stabilize the SYSOSC frequency by providing a precision reference current for the SYSOSC. The accuracy overall frequency accuracy which is achievable depends on the operating temperature range together with the tolerance and temperature drift of the selected external resistor. The device-specific data sheet includes specifications for overall SYSOSC frequency accuracy when the TI-recommended ±0.1% tolerance, ±25-ppm/°C, TCR resistor is used. The TI-recommended resistor enables a variety of applications, including UART communication. If the overall accuracy values in the device-specific data sheet with the TI-recommended resistor specifications meets the application and cost requirements, then there is no need to compute the accuracy for an alternate resistor or alternate temperature ranges. However, if a higher accuracy or reduced cost resistor is needed, t is possible to use a more precise or less precise resistor for ROSC in order to balance cost with frequency accuracy for a given application scenario. # Computing SYSOSC Overall Frequency Accuracy with FCL (External Resistor Mode) Assuming an ideal (zero error, zero temperature drift) reference resistor, the FCL mode improves the SYSOSC circuit accuracy to the level specified in the f<sub>SYSOSC</sub>: "SYSOSC frequency accuracy when frequency correction loop (FCL) is enabled and an ideal ROSC resistor is assumed" section of the SYSOSC specifications table in the device-specific data sheet. The overall SYSOSC frequency accuracy in FCL mode which is achievable for a given external resistor and temperature range is determined by combining the following error sources to determine the total frequency error: - 1. The ROSC resistor tolerance (at 25°C); this comes from the resistor specifications - 2. The ROSC resistor temperature coefficient of resistance (TCR); this comes from the resistor specifications - 3. The minimum and maximum expected operating temperatures for the system being designed - 4. The SYSOSC frequency accuracy with an ideal resistor for the desired temperature range (taken from the MSPM0 device-specific data sheet) The table below provides an example of how to compute the accuracy for different conditions, given the following typical application scenario: - A target operating temperature range of -40 to 85°C. - ROSC resistor with a ±0.1% tolerance and ±25 ppm/°C TCR selected Table 2-4. Computing Overall SYSOSC FCL Frequency Accuracy based on ROSC | Step | Description | MIN | TYP | MAX | UNIT | | | |------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|----------------|----------------|--------|--|--| | 1 | Define the operating temp range of the application. | -40 | 25 | 85 | °C | | | | 2 | Select the target f <sub>SYSOSC</sub> frequency (4 or 32 MHz) | | 32.00 | | MHz | | | | 3 | Look up the corresponding f <sub>SYSOSC</sub> ideal resistor accuracy from the device-specific data sheet based on the temperature range in Step 1. | -0.80 | | 0.93 | % | | | | 4 | Compute the min and max f <sub>SYSOSC</sub> with an ideal resistor based on the selected frequency in Step 2 and the accuracy range in Step 3. | 31.744 | | 32.298 | MHz | | | | 5 | Select an ROSC resistor with acceptable tolerance (the TI-recommended ±0.1% tolerance used in this example) | 99.9 | 100 | 100.1 | kΩ | | | | 6 | Note the temperature coefficient of resistance (TCR) of the ROSC resistor. | | ±25 | | ppm/°C | | | | 7 | Compute the max temperature variation from 25°C (nominal) based on the temperature range defined in Step 1. | 1: | 25 - (-40) = | - (-40) = 65 | | | | | 8 | Compute the max ROSC drift over the max temperature variation (from Step 7) and the TCR (from Step 6). | -0.16 | | 0.16 | % | | | | 9 | Compute the min and max ROSC resistance including tolerance (from Step 5) and temperature drift (from Step 8). | 99.74 | | 100.26 | kΩ | | | | 10 | Compute the overall ROSC resistor accuracy (in percent), using the overall ROSC resistance range from Step 9 vs. the nominal resistor value. | -0.26 | | 0.26 | % | | | | 11 | Compute the variation in the min and max f <sub>SYSOSC</sub> by degrading the min/max f <sub>SYSOSC</sub> computed in Step 4 by the ROSC accuracy computed in Step 10. | 31.66 | | 32.38 | MHz | | | | 12 | If desired, convert the raw min/max f <sub>SYSOSC</sub> computed in Step 11 into a %-based accuracy format relative to the target f <sub>SYSOSC</sub> from Step 2. | -1.06 | | 1.20 | % | | | To increase the SYSOC accuracy with FCL, first disable all digital functions on the ROSC pin in IOMUX (this is the default state after power up). An ROSC reference resistor that meets the application accuracy requirements must be placed between the ROSC pin and the device ground (VSS). Enable FCL mode by setting the SETUSEFCL bit in the SYSOSCFCLCTL register. When the FCL mode is enabled, software cannot disable the mode. A BOOTRST is required before a change to the FCL mode. ## Note The power consumption of SYSOSC is marginally higher with the FCL enabled due to the reference current that flows through ROSC. Settling time from startup to target accuracy can also be longer. See the device-specific data sheet for startup times. ## 2.3.1.2.4 SYSOSC User Trim Procedure The SYSOSC can be trimmed to a user-trimmed value of 16 MHz or 24 MHz, if desired. Trimming is accomplished by manipulating the fields in the SYSOSCTRIMUSER to achieve a target frequency of 16 or 24 MHz. To trim the SYSOSC, the SYSOC can be brought out externally to a pin using the CLK\_OUT unit so that it can be measured. Follow the procedure below to derive the user trim values. Once trimmed values are obtained, they can be programmed in to the flash memory of the device to be recalled later. Each device must be trimmed individually for accuracy. SYSOSC can also be trimmed internally by using the frequency clock counter (FCC). # Trim procedure using CLK\_OUT with frequency correction loop (FCL) disabled (No ROSC resistor) - 1. Enable the CLK\_OUT unit and select SYSOSC as the clock source, following the instructions in the CLK\_OUT section - 2. Set the SYSOSC frequency to BASE to start (ensure that the FREQ field in the SYSOSCCFG register is set to 0h for BASE), and leave the FCL mode disabled - 3. Program an initial tuning for the target frequency in the SYSOSCTRIMUSER register: - a. Set the RCOARSE trim field in the SYSOSCTRIMUSER register to mid-range - b. Set the RFINE trim field in the SYSOSCTRIMUSER register to mid-range - 4. Switch SYSOSC to the user-trimmed frequency by selecting USER in the FREQ field of the SYSOSCCFG register - 5. Measure the SYSOSC frequency at the CLK\_OUT pin - 6. Switch SYSOSC back to BASE frequency by selecting BASE in the FREQ field of the SYSOSCCFG register - 7. Adjust the SYSOSCTRIMUSER parameters to close on the target frequency: - a. Set the target frequency (16 or 24 MHz) in the FREQ field of the SYSOSCTRIMUSER register - b. Adjust trim parameters to achieve 16 or 24 MHZ based on the selection made in step 7a - Increasing the CAP trim field in the SYSOSCTRIMUSER register will reduce the SYSOSC range. For 24 MHz, select CAP=0, and for 16 MHz select CAP=1 - ii. Increasing the RCOARSE trim field in SYSOSCTRIMUSER will reduce the frequency in large steps of approximately 1 MHz - iii. Increasing the RFINE trim field in SYSOSCTRIMUSER will decrease the frequency in small steps of approximately 100 kHz - 8. Repeat steps 4 through 7 until the desired accuracy has been achieved - 9. Save the resulting SYSOSCTRIMUSER value for recall # Trim procedure using CLK OUT with frequency correction loop (FCL) enabled (ROSC resistor present) - 1. First, complete the FCL disabled trim procedure (defined above) to obtain starting values for the CAP, RCOARSE, and RFINE trim fields in the SYSOSCTRIMUSER register - 2. Increase the RCOARSE value by 02h from the value obtained in Step 1 - 3. With CLK\_OUT still enabled (SYSOSC as the source for CLK\_OUT), ensure that the FREQ field in the SYSOSCCFG register is set to 0h for BASE, and enable the FCL mode by setting the SETUSEFCL bit in the SYSOSCFCLCTL register - 4. Set the RDIV trim field in the SYSOSCUSERTRIM register to mid-range - 5. Switch SYSOSC to the user-trimmed frequency by selecting USER in the FREQ field of the SYSOSCCFG register - 6. Measure the SYSOSC frequency at the CLK OUT pin - 7. Switch SYSOSC back to BASE frequency by selecting BASE in the FREQ field of the SYSOSCCFG register - 8. Adjust trim parameters to close on the target frequency: - a. Increasing the RDIV trim field in the SYSOSCTRIMUSER register will increase the frequency in small steps of approximately 50 kHz - b. Continue increasing or decreasing RDIV if the frequency is in saturation (not appearing to adjust) - 9. Repeat steps 5-8 until the desired accuracy has been achieved - 10. Save the resulting SYSOSCTRIMUSER value for recall ## Note SYSOSCTRIMUSER parameters only take effect when switching to the USER frequency. Once USER frequency is selected, changes to SYSOSCTRIMUSER have no effect. To refresh the USER values, first switch to BASE frequency, then update SYSOSCTRIMUSER, and then switch SYSOSC back to BASE frequency. # 2.3.1.2.5 Disabling SYSOSC SYSOSC can be disabled in STOP mode by setting the DISABLESTOP bit in the SYSOSCCFG register. Doing so forces the MCLK to use LFCLK in STOP mode (this is the STOP2 policy). This provides the lowest possible power consumption in STOP mode, as the system runs at 32 kHz and SYSOSC consumes no current. When exiting STOP mode to RUN mode, SYSCTL will automatically re-enable SYSOSC and switch MCLK back to SYSOSC. SYSOSC can be disabled manually by setting the DISABLE bit in the SYSOSCCFG register. When SYSOSCCFG.DISABLE is set, the system will run from LFCLK in all power modes. #### Note The DISABLE and DISABLESTOP bits in SYSOSCCFG are mutually exclusive, and must not be set at the same time. SYSOSC is always disabled automatically in STANDBY and SHUTDOWN modes. ## 2.3.2 Clocks The CKM takes oscillator outputs and generates a variety of functional clocks for use by the device. ## **Clocks** - System Clocks - MCLK: Main system clock for PD1 peripherals and PD1 bus - CPUCLK: CPU clock, derived from MCLK - ULPCLK: Main system clock for PD0 peripherals and PD0 bus, derived from MCLK - MFCLK: Fixed 4 MHz clock, synchronized to MCLK/ULPCLK - MFPCLK: Fixed 4 MHz clock - LFCLK: Fixed 32 kHz clock, synchronized to MCLK/ULPCLK - · Peripheral Specific Clocks - ADCCLK: ADC sampling period clock - External Clocks - CLK OUT: External clock output with divider for pushing out a clock to external circuits All clocks are disabled in SHUTDOWN mode. In addition to the configurable clocks listed above, several direct clock connections are made to analog peripherals (see the Section 2.3.2.9 section). # 2.3.2.1 MCLK (Main Clock) Tree The MCLK is the main system clock and the root point of synchronization for all synchronized clocks (MCLK, CPUCLK, ULPCLK, MFCLK, and LFCLK). It is typically the highest speed clock in the system and supports operation up to 32 MHz across the full temperature range of the device. The MCLK tree is the root source for the CPUCLK (in RUN mode), the PD1 high speed peripheral bus clock (in RUN and SLEEP modes), and the ULPCLK low power bus clock (in RUN, SLEEP, STOP, and STANDBY modes). In addition, the 4-MHz MFCLK and 32-kHz LFCLK outputs are synchronized to MCLK. The MCLK output to PD1 peripherals is enabled in RUN and SLEEP modes, and disabled in all other power modes. While the MCLK output to PD1 is disabled in STOP and STANDBY modes, the MCLK tree is still running to source ULPCLK and to provide synchronization for MFCLK and LFCLK. The MCLK source is selected with a glitch free clock mux and can be changed dynamically at runtime by user software. It can also be changed automatically by hardware when entering STOP and STANDBY modes or during an asynchronous fast clock request. The available sources for MCLK include: - SYSOSC at 4, 16, 24, or 32 MHz (the default clock source after reset) - **SYSOSC** at 4 MHz with **MDIV** divider (for applications where the peripheral bus and CPU run between 250 kHz and 4 MHz) - LFCLK at 32 kHz for applications where the entire system, including the CPU, runs at 32 kHz with low peak operating current # Using MCLK in RUN and SLEEP Mode After boot, MCLK is sourced from SYSOSC by default. The decision of which oscillator to use to source MCLK is important because MCLK sets both the CPUCLK frequency and the bus clock frequency for PD1 peripherals. As a result, the accuracy and the clock speed of the oscillator selected for MCLK must be appropriate not only for the operation of the CPU but also for the operation of the PD1 peripherals that use the bus clock as their functional clock. The clock source and frequency selection decisions made for MCLK also affect ULPCLK in RUN and SLEEP modes. See the ULPCLK section for more information on how MCLK and ULPCLK are related in RUN and SLEEP mode. # Using MCLK in STOP and STANDBY Mode In STOP and STANDBY modes, the MCLK output to PD1 peripherals is disabled, but the ULPCLK, which is the bus clock for PD0 peripherals, is still active in STOP and optionally active in STANDBY. See the ULPCLK section for more information on how the MCLK source and ULPCLK are related in STOP and STANDBY mode. ## **MCLK Source Selection** Application software can change the MCLK source from SYSOSC to LFCLK in all modes by setting MCLKCFG.USELFCLK, giving the low peak current consumption with the CPU and PD1 peripherals operational. Table 2-5 gives the proper register bit configurations for selecting different clocks for MCLK in RUN and SLEEP modes. Table 2-5. MSPM0Lxx MCLK Source Selection in RUN and SLEEP Mode | Desired Source | MCLKCFG.USELFCLK | |----------------|------------------| | SYSOSC | 0 | | LFCLK | 1 | To switch MCLK from SYSOSC to LFCLK in RUN mode: - 1. Verify that MCLK is sourced from SYSOSC (CLKSTATUS.CURMCLKSEL is cleared) - 2. If SYSOSC is not running at base frequency, and SYSOSC is to be left enabled when switching MCLK to LFCLK, set SYSOSC to base frequency before proceeding - 3. Set MCLKCFG.USELFCLK to switch MCLK to LFCLK and leave SYSOSC enabled, or set SYSOSCCFG.DISABLE to switch MCLK to LFCLK and disable SYSOSC To switch MCLK from LFCLK to SYSOSC in RUN mode: 1. Verify that MCLK is sourced from LFCLK (CLKSTATUS.CURMCLKSEL is set) 2. Clear MCLKCFG.USELFCLK or SYSOSCCFG.DISABLE, whichever was set to switch MCLK to LFCLK # MCLK Divider (MDIV) An MCLK source divider (MDIV) is provided to enable MCLK operation in between the lowest SYSOSC frequency (4 MHz) and the LFCLK frequency (32 kHz). MDIV is for applications with a limited peak current but that still require a higher clock speed than 32 kHz. MDIV supports dividing the 4-MHz SYSOSC frequency by up to 16, enabling the additional MCLK frequency options given in Table 2-6. For example, a 500-kHz MCLK frequency can be obtained by setting SYSOSC to 4 MHz and setting MDIV to 7 (divide-by-8). Table 2-6 shows the MCLK frequency which is realized with /2, /4, /8, and /16 MDIV configurations, but MDIV can be set to any integer divider between /2 and /16 (MDIV register values of 0x1 through 0xF, respectively, with 0x0 disabling the MDIV). Table 2-6. Typical MCLK Configurations for Operation Between 4 MHz and 32 kHz | MCLK Source | MDIV | MCLK Frequency | |----------------|--------------|----------------| | | 0 (Disabled) | 4 MHz | | | 1 (/2) | 2 MHz | | SYSOSC (4 MHz) | 3 (/4) | 1 MHz | | | 7 (/8) | 500 kHz | | | 15 (/16) | 250 kHz | To use MDIV to operate MCLK at an intermediate frequency below 4 MHz, follow the steps below: - Disable asynchronous fast clock requests (make sure that the BLOCKASYNCALL bit is set in the in SYSOSCCFG register) - 2. Make sure that SYSOSC is selected as the MCLK source - 3. Set the SYSOSC frequency to 4 MHz (set the FREQ field in the SYSOSCCFG register to 0x01) - 4. Delay for 10 MCLK cycles - 5. Set the desired divider value in the MDIV field in the MCLKCFG register (from 1 to 15, corresponding to /2 to /16, respectively) Several rules apply when using MDIV to reduce the MCLK frequency: - · The SYSOSC frequency must be kept at 4 MHz when MDIV is enabled - Asynchronous requests to change the SYSOSC frequency must remain blocked To disable MDIV: - 1. Disable MDIV (set the MDIV field in the MCLKCFG register to 0x0) - 2. Wait for 16 MCLK cycles before changing the SYSOSC frequency from 4 MHz to another frequency ## Note MDIV does not apply to LFCLK, as MDIV is not in the LFCLK path when LFCLK is selected as the MCLK source. If LFCLK is selected for MCLK, MDIV must be disabled. ## 2.3.2.2 CPUCLK (Processor Clock) The processor clock (CPU clock) is always derived directly from MCLK and is active in RUN mode at the MCLK frequency. In all other power modes, CPUCLK is disabled. ## 2.3.2.3 ULPCLK (Low-Power Clock) The ULPCLK is the bus clock for peripherals in the PD0 power domain. It supports operation up to 32 MHz and is derived directly from the MCLK tree . The ULPCLK frequency is dependent on the MCLK configuration, the selected power mode, and the selected UDIV divider. ## **ULPCLK Behavior in RUN and SLEEP Modes** The PD0 power domain has a frequency limit of 32 MHz in RUN and SLEEP modes. ## **ULPCLK Behavior in STOP and STANDBY Modes** In STOP mode, the MCLK tree (and by extension, the ULPCLK) can run from SYSOSC with a 4 MHz rate (if SYSOSCCFG.DISABLESTOP=0x0) or from LFCLK at 32 kHz (if SYSOSCCFG.DISABLESTOP=0x1). When SYSOSC is used (SYSOSCCFG.DISABLESTOP=0x0), SYSCTL ensures that ULPCLK is always 4 MHz even if SYSOSC is running at a higher frequency (due to user configuration or due to an asynchronous request from a peripheral). In STANDBY mode, the MCLK tree (and by extension, the ULPCLK) either run from LFCLK (STANDBY0) or are disabled (STANDBY1) to conserve power. In STANDBY1, only the TIMG0 and TIMG1 timer peripherals receive ULPCLK. | Selected Review Mode Configuration Register Settings ULBCLK Francesco | | | | | | | | | | | |--------------------------------------------------------------------------|---------------------------------------------------|-----------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--| | Selected Power Mode | Configuration | Register Settings | ULPCLK Frequency | | | | | | | | | RUN or SLEEP (32 MHz | MCLK source is SYSOSC (RUN0, SLEEP0) | MCLKCFG.USELFCLK=0x0 | ULPCLK is sourced from MCLK according to the MCLK configuration with $f_{ULPCLK} = f_{MCLK}$ | | | | | | | | | maximum) | MCLK source is LFCLK<br>(RUN1/2, SLEEP1/2) | MCLKCFG.USELFCLK=0x1<br>or<br>SYSOSCCFG.DISABLE=0x1 | ULPCLK is sourced from LFCLK with f <sub>ULPCLK</sub> = f <sub>LFCLK</sub> = 32 kHz | | | | | | | | | STOP (4 MHz maximum) | STOP with SYSOSC enabled (STOP0/1) | SYSOSCCFG.DISABLESTO<br>P = 0x0 | ULPCLK is sourced from SYSOSC with f <sub>ULPCLK</sub> = 4 MHz | | | | | | | | | STOP (4 MINZ MAXIMUM) | STOP with SYSOSC disabled (STOP2) | SYSOSCCFG.DISABLESTO<br>P = 0x1 | ULPCLK is sourced from LFCLK with f <sub>ULPCLK</sub> = f <sub>LFCLK</sub> = 32 kHz | | | | | | | | | STANDBY (32 kHz | STANDBY with ULPCLK and LFCLK enabled (STANDBY0) | MCLKCFG.STOPCLKSTBY= 0x0 | ULPCLK is sourced from LFCLK with f <sub>ULPCLK</sub> = f <sub>LFCLK</sub> = 32 kHz | | | | | | | | | maximum) | STANDBY with ULPCLK and LFCLK disabled (STANDBY1) | MCLKCFG.STOPCLKSTBY=<br>0x1 | ULPCLK is disabled to all peripherals except TIMG0 and TIMG1, which receive f <sub>ULPCLK</sub> =f <sub>LFCLK</sub> = 32 kHz | | | | | | | | | SHUTDOWN (Off) | - | - | ULPCLK is off | | | | | | | | Table 2-7. MSPM0Lxx ULPCLK by Operating Mode ## 2.3.2.4 MFCLK (Middle Frequency Clock) The MFCLK provides a continuous 4-MHz clock to a variety of peripherals on the device. The MFCLK 4-MHz rate is always derived from the SYSOSC. As the SYSOSC frequency is not fixed (it can be configured for 32, 24, 16, or 4 MHz), SYSCTL automatically applies a divider to SYSOSC to keep MFCLK at a constant 4-MHz rate regardless of the current SYSOSC frequency. MFCLK can be used by peripherals such as timers and serial interfaces that require a constant clock source in RUN, SLEEP, and STOP power modes. After a SYSRST, MFCLK is initially disabled. MFCLK can be enabled in software by setting USEMFTICK in the MCLKCFG register in SYSCTL. MFCLK is active in RUN, SLEEP, and STOP power modes only, and SYSOSC must be enabled for MFCLK to operate. All MFCLK edges are synchronized to the main system clocks (MCLK and ULPCLK), meaning that the registers of peripherals clocked by MFCLK can be read or written to at any time without any special handling. Peripherals can select MFCLK as their functional clock source through their respective CLKSEL mux. Not all peripherals support running from MFCLK. ## **Using MFCLK in STOP Mode** When using MFCLK in STOP mode, SYSOSC can be configured to automatically switch to 4 MHz (low frequency) when entering STOP mode and automatically switch back to the previously selected frequency when exiting STOP mode to RUN mode (gear shift mode). As MFCLK is a 4 MHz clock source, running SYSOSC at 4 MHz in STOP mode reduces power consumption when in STOP mode. To configure SYSOSC for gear shift mode, see Section 2.3.1.2.1. # **Requirements for Using MFCLK** 1. When using MFCLK, the MDIV (MCLK divider) must be disabled (set to /1). Disable MDIV by setting MDIV in the MCLKCFG register to 0x0. SYSCTL hardware does not allow MFCLK to run when MCLKCFG.MDIV != 0 - When using MFCLK, do not enable MFCLK when MCLK is sourced from the low-frequency clock (LFCLK). Application software must enable MFCLK by setting the USEMFTICK bit before switching the MCLK source from SYSOSC to LFCLK. Software can switch MCLK to LFCLK after USEMFTICK is set. In this case, MFCLK halts when MCLK is sourced from LFCLK, and it resumes when MCLK is switched back to SYSOSC. - 3. When MFCLK is enabled by setting USEMFTICK in the MCLKCFG register, it is considered by the hardware as a static policy. Do not clear USEMFTICK. When MFCLK is configured to be enabled, it is only active when SYSOSC is active and MCLK is not sourced from LFCLK. When MCLK is sourced from LFCLK, MFCLK is stopped by hardware automatically. Note that if the device is in STANDBY, MCLK is always sourced from LFCLK and MFCLK is always disabled by hardware. Asynchronous fast clock requests, if configured, temporarily enable SYSOSC to handle specific peripheral events and activity. If MFCLK is configured to be enabled (USEMFTICK is set), then MFTICK runs when a peripheral asserts an asynchronous fast clock request. # 2.3.2.5 MFPCLK (Middle Frequency Precision Clock) MFPCLK provides a continuous 4-MHz clock to the external clock output (CLK\_OUT) mux in RUN, SLEEP, or STOP mode. To enable the MFPCLK, set the MFPCLKEN bit in the GENCLKEN register in SYSCTL. # 2.3.2.6 LFCLK (Low-Frequency Clock) LFCLK provides a continuous 32-kHz clock to a variety of peripherals on the device. After a BOOTRST, LFCLK is sourced by the internal 32-kHz oscillator (LFOSC). LFCLK is active in RUN, SLEEP, STOP, and STANDBY power modes. It is possible to disable both ULPCLK and LFCLK together to most peripherals in STANDBY mode to achieve the lowest possible STANDBY mode power consumption (STANDBY1). To do so, set the STOPCLKSTBY bit in the MCLKCFG register in SYSCTL before entering STANDBY. In this state, TIMG0 and TIMG1 are the only clocked peripherals. LFCLK is a synchronized clock. All LFCLK edges are synchronized to the main system clocks (MCLK and ULPCLK), meaning that the registers of peripherals clocked by LFCLK can be read or written to at any time without any special handling. #### Note When MCLK/ULPCLK are not sourced by LFCLK (for example, when they are sourced by SYSOSC) there is a 5 ULPCLK cycle synchronization delay between the low frequency clock source's clock edge and the corresponding LFCLK edge as seen by peripherals running from LFCLK. When the MCLK/ULPCLK frequency is constant, this delay is constant and it does not add jitter to LFCLK. If the MCLK/ULPCLK frequency changes, the synchronization delay changes proportionally and this results in a small single-cycle LFCLK jitter at the MCLK/ULPCLK frequency transition point. This jitter changes the duty cycle of one LFCLK period, but there is no accumulation of error (there is never a change in the number of LFCLK periods, ensuring an accurate LFCLK time base for peripherals). A common case would be MCLK/ULPCLK sourced from SYSOSC at 32MHz, with SYSOSC occasionally switching to 4MHz to reduce power consumption. When SYSOSC (and, by definition, MCLK/ULPCLK) switch from 32MHz to 4MHz, the synchronization delay increases from 0.16µs to 1.25µs (an increase of 1.1µs). Thus, during the SYSOSC frequency transition, one LFCLK period will appear 1.1µs (3.6%) longer than normal. When SYSOSC switches back from 4MHz to 32MHz, one LFCLK period will appear 1.1µs shorter than normal, and the phase shift is recovered and error is not accumulated in the long term. Peripherals can select LFCLK as their functional clock source through their respective CLKSEL mux. Not all peripherals support running from LFCLK. It is possible to run the main clock (MCLK) from LFCK, in which case the entire device runs at the LFCLK rate (32 kHz). # 2.3.2.7 ADCCLK (ADC Sample Period Clock) The ADCCLK is used by the ADC modules to set the ADC sampling period. The ADCCLK is provided from the CKM to the ADCs, but the clock selection is done within the ADC peripheral configuration registers. See the ADC chapter for information on configuring the ADCCLK can be selected as SYSOSC. # 2.3.2.8 External Clock Output (CLK OUT) A clock output unit is provided for sending digital clock signals from the device to external circuits or to the frequency clock counter. This feature is useful for clocking external circuitry such as an external ADC that does not have a clock source. The clock output unit has a flexible set of sources to select and includes a programmable divider. Available clock sources for CLK\_OUT: - SYSOSC - ULPCLK - MFPCLK - LFCLK The selected clock source can be divided by 1 (no divide), 2, 4, 6, 8, 10, 12, 14, or 16 before being output to the pin or to the frequency clock counter. To use the clock output unit: - 1. Configure IOMUX to select the CLK OUT function on the device pin with CLK OUT. - 2. Select the desired clock source in the EXCLKSRC field of the GENCLKCFG register. - 3. Set the desired clock divider, if necessary, in the EXCLKDIVVAL field of the GENCLKCFG register, and enable the divider by setting the EXCLKDIVEN bit. - 4. Enable the external clock output by setting the EXCLKEN bit in the GENCLKEN register. #### Note When the CLK\_OUT source is selected as ULPCLK or MFPCLK, the clock divider must be enabled (EXCLKDIVEN must be set). #### Note When clearing the EXCLKEN bit to disable CLK\_OUT, allow the clock source to run for 10 clock cycles to stabilize the EXCLKSRC mux. #### 2.3.2.9 Direct Clock Connections for Infrastructure Several direct clock connections are made in the device to support specific analog functionality: - SYSOSC to ADCs - SYSOSC to OPAs, if OPAs are present on a device - SYSOSC and LFCLK to PMU analog mux VBOOST circuit #### **Direct Connections to ADCs** In addition to receiving ADCCLK to set the sampling window, the ADC modules also receive the direct output of SYSOSC. The SYSOSC direct output to the ADCs is used by the charge pump logic in the ADC modules. SYSOSC can be configured at any frequency to support this function. The ADC supports requesting SYSOSC automatically before a conversion, so there is not a requirement for application software to ensure that SYSOSC is running before triggering an ADC conversion. ## **Direct Connections to OPAs** The SYSOSC direct clock connection to the OPAs, if present, enable all OPA operating modes to be used even when the peripheral bus clock (ULPCLK) is running at a lower frequency than what is required by the OPA. Certain OPA modes require that SYSOSC be running at 32 MHz. See the OPA section for clocking details. Configuration of SYSOSC to a frequency which supports the selected OPA mode is the responsibility of the application software. If the OPA is enabled and configured for a mode which requires SYSOSC to be running at a certain frequency, and software has not configured SYSOSC to run at this frequency, an OPAMPCLKERR will be asserted in the CLKSTATUS register in SYSCTL and the OPA can not function properly. # **Direct Connections to the PMU Analog Mux VBOOST Circuit** Both the SYSOSC and the LFCLK are connected directly to the analog mux VBOOST circuit in the PMU, which is used to boost the performance of the analog muxes used by the COMPs, OPAs, and GPAMP. The VBOOST circuit is enabled automatically when a peripheral requires it for correct operation. It is the responsibility of the application software to ensure that the SYSOSC or LFCLK are enabled to support correct operation of the VBOOST circuit. If the VBOOST circuit requires SYSOSC or LFCLK, and the clock is not available, an ANACLKERR is asserted in the CLKSTATUS register in SYSCTL. SYSCTL can also be configured to raise a SYSCTL interrupt when ANACLKERR is asserted, to alert the application that a COMP, OPA, or the GPAMP can not be functioning properly as expected. #### 2.3.3 Clock Tree Figure 2-7 shows the top level clocking tree for MSPM0Lxx family devices. This diagram shows the mapping between oscillators (sources) and clocks (destinations), as well as the SYSCTL register bit fields for the selection muxes. Note that not all devices have all clock system features shown in Figure 2-7. Figure 2-7. MSPM0Lxx Top Level Clock Tree - 1. MDIV is a clock divider that supports specific use-cases. Review the MCLK section for specific design considerations regarding MDIV. - 2. LFCLK and MFCLK are fixed-frequency 32-kHz and 4-MHz clocks, respectively, that can be selected by certain peripherals for ensuring a constant clock rate even when MCLK or ULPCLK changes source or rate. LFCK and MFCLK are always synchronized to each other and to MCLK and ULPCLK. - 3. TIMG0 and TIMG1 (general purpose timers) receive an ungated LFCLK and ULPCLK, enabling them to continue operating even in STANDBY1 when STOPCLKSTBY is asserted to gate the LFCLK and ULPCLK to all other peripherals to save additional power in STANDY mode. - 4. SYSOSC is provided to the OPAs for use directly. The OPAs do not request SYSOSC automatically. It is the responsibility of application software to ensure that SYSOSC is enable and running at the necessary frequency to support correct OPA operation before enabling the OPA. # 2.3.3.1 Peripheral Clock Source Selection Most peripherals on the device contain an input clock selection mux which is used to select, and optionally divide down, the functional clock for the peripheral. Figure 2-8 shows the superset peripheral clock selection mux and optional clock divider. Note that not every peripheral has every clock source shown in Figure 2-8. For example, accelerators such as CRC, and DMA run off of the bus clock. There is no option to select MFCLK or LFCLK for these peripherals. To determine the available clock sources for a peripheral, see the chapter for the specific peripheral and review the clock input selections. Figure 2-8. Peripheral Clock Selection Mux and Divider # **Exceptions** There are also several peripherals that have a unique clock selection scheme and do not use the standard peripheral clock mux shown above. Typically this is due to a requirement for a peripheral to have a clock source that is asynchronous to the rest of the system. Cases where this occurs include: An analog-to-digital converter (ADC), where ADCCLK has a special selection mux to take asynchronous clock sources directly (the ADC sampling clock is selected with a special selection in the ADC control registers) ## 2.3.4 Clock Monitors Several hardware clock monitors are provided to ensure that the CKM is functioning properly. Clock faults are processed through SYSCTL and result in either a brownout reset (in the event of a fatal fault) or a SYSCTL interrupt. # 2.3.4.1 MCLK Monitor A digital clock monitor can be used with MCLK. The MCLK monitor asserts an MCLK fault if there is no MCLK activity for a period of 1-12 LFCLK cycles. An MCLK fault is always considered fatal to the system and generates a BOOTRST. The MCLK monitor can be enabled after the LFCLK is configured and running. To enable the MCLK monitor, set the MCLKDEADCHK bit in the MCLKCFG register in SYSCTL. When enabled, the MCLK monitor runs in all operating modes except for STANDBY1 and SHUTDOWN. # 2.3.4.2 Startup Monitors Clock startup monitors are provided for application software to check that the LFOSC is alive before it is selected by software to be used to source a clock in the system. When a clock source has started successfully and is ready, a GOOD indication is given in the CLKSTATUS register in SYSCTL and an interrupt is generated. The startup monitors only provide a status indication when a related clock system configuration change is made. When an initial GOOD indication is given, the clock is not continuously monitored by the startup monitor. Continuous monitoring is provided for MCLK. # 2.3.4.2.1 LFOSC Startup Monitor The LFOSC is started automatically after a BOOTRST. The LFOSC takes some time to start. A startup monitor is provided to indicate to the application software when LFOSC startup has completed, at which time the LFCLK is available for use by peripherals. When LFSOSC startup has completed, the LFOSC startup monitor asserts the LFOSCGOOD bit in the CLKSTATUS register in SYSCTL and the LFOSCGOOD interrupt is asserted to alert the application. See the device-specific data sheet for the LFOSC startup time. # 2.3.5 Frequency Clock Counter (FCC) The frequency clock counter (FCC) enables flexible in-system testing and calibration of a variety of oscillators and clocks on the device. The FCC counts the number of clock periods seen on the selected source clock within a known fixed trigger period (derived from a secondary reference source) to provide an estimation of the frequency of the source clock. Application software can use the FCC to measure the frequency of the following source oscillators and clocks (selected through the FCCSELCLK field in the GENCLKCFG register): - MCLK - SYSOSC - CLK OUT - The external FCC input (FCC\_IN) The reference clock used to set the trigger time over which pulses of the source clock are counted is configurable (through the FCCTRIGSRC field in the GENCLKCFG register), and can be driven by: - The external FCC input (FCC IN) - LFCLK The trigger time period can be set in one of two ways (through the FCCLVLTRIG field in the GENCLKCFG register): - Level triggered (one rising edge to one falling edge of the reference clock input). Please note that LFCLK\_IN cannot be used as a trigger clock source if using level triggering. - Rising-edge to rising-edge triggered, for a defined number of clock periods of the reference clock (selectable from 1 to 32 through the FCCTRIGCNT field in the GENCLKCFG register) When the trigger source is selected as the external FCC input in level-triggered mode, a user-specified counting period can be set by applying a logic high pulse on the FCC\_IN pin of the desired trigger length. The FCC counter is 22 bits and supports counting from 0 up to $2^{22} - 1$ or 4 194 303. While the external FCC input (FCC\_IN function) can be used as either the FCC clock source or the FCC trigger input, it cannot be used for both functions during the same FCC capture. It must be configured as either the FCC clock source or the FCC trigger. ## 2.3.5.1 Using the FCC # Rising-Edge to Rising-Edge Triggered Mode with FCC\_IN Trigger The following steps describe how to use the FCC to count the number of source clock pulses within the trigger period set by the reference clock, with the FCC\_IN pin being selected as the reference clock and the SYSOSC being selected as the source clock. This example would be useful for calibrating the SYSOSC frequency with respect to an accurate clock source provided to the FCC\_IN pin externally. - Set the source clock to SYSOSC by configuring the FCCSELCLK field in the GENCLKCFG register. - 2. Set the reference clock to FCC\_IN by clearing the FCCTRIGSRC bit in the GENCLKCFG register. - 3. Select rising-edge to rising-edge triggering by clearing the FCCLVLTRIG bit in the GENCLKCFG register. - 4. Select the desired number of reference clock periods to count the source clock over in the FCCTRIGCNT field in the GENCLKCFG register. - 5. Ensure that SYSOSC is enabled at the desired frequency, and that the external clock source connected to FCC IN is running correctly before continuing. - 6. Write the GO bit and KEY field to the FCCCMD register to start the FCC capture on the next trigger clock period. - Poll the FCCDONE status bit in the CLKSTATUS register. When the capture completes, FCCDONE will be set by hardware. FCCDONE is read-only and is automatically cleared by hardware when a new capture is started. - 8. Extract the resulting count from the 22-bit DATA field in the FCC register. # 2.3.5.2 FCC Frequency Computation and Accuracy The frequency of the source clock can be computed after capture if the trigger time is known. The frequency is computed by dividing the number of source clock cycles captured by the trigger time. For example, if the trigger source was a 32.768kHz clock, the trigger mode was rising-edge to rising-edge, and the period count was 1, then the trigger time is one 32.768-kHz clock period ( $30.5~\mu$ s). If the captured source count were to come back as 122, the frequency of the source clock is computed as 122 divided by $30.5~\mu$ s, giving a source clock frequency of approximately 3.99MHz. $$f_{source} = FCC.DATA / ((GENCLKCFG.FCCTRIGCNT+1) / f_{ref})$$ (6) The FCC is accuracy is dependent on the trigger clock accuracy as well as the total number of clock cycles captured. The FCC intrinsic error is ≤2 source clock cycles per capture due to synchronization of the trigger to the source clock. Therefore, the impact of these two clock cycles is reduced as more cycles are counted (as the trigger time is increased and/or the source clock frequency is increased). Approximate intrinsic error of the FCC for various source clock frequencies captured against one 32.678kHz period (FCCTRIGCNT=0) and 32 clock periods (FCCTRIGCNT=31) are given in Table 2-8. **FCC Count FCC Count Approximate FCC Intrinsic** Use Case (Source Clock Frequency) FCC Trigger Time Result Uncertainty **Uncertainty Error** 30.5µs 122 1.6% 4-MHz source clock 976.6µs 3906 0.05% 30.5µs 488 0.4% 16-MHz source clock 976.6µs 15625 0.01% 30.5µs 732 0.27% 24-MHz source clock 2 cycles 976.6µs 23437 0.01% 30.5µs 976 0.20% 32-MHz source clock 976.6µs 31250 0.01% 30.5µs 2441 0.08% 80-MHz source clock 976.6us 78125 0.003% Table 2-8. FCC Error # 2.4 System Controller (SYSCTL) The system controller (SYSCTL) contains all control logic for managing the configuration and state of the PMU and CKM analog circuitry. SYSCTL also provides reset management, control over NRST and SWD pin muxing, flash bank swap control, and flash ECC error handling. All power, clock, and reset configuration is done through the SYSCTL memory-mapped register interface. ## 2.4.1 Resets and Device Initialization The SYSCTL manages device reset levels and device initialization. ## 2.4.1.1 Reset Levels The device has five reset levels: - 1. Power-on reset (POR) - 2. Brownout reset (BOR) - Boot reset (BOOTRST) - 4. System reset (SYSRST) - 5. CPU reset (CPURST) The relationships between reset levels are given in Figure 2-9. Figure 2-9. MSPM0 Reset Levels - (1) An NRST (low <1 s), software boot reset, or WWDT0 violation triggered BOOTRST runs the boot configuration routine. - <sup>(2)</sup> A software-triggered bootstrap loader (BSL) entry command first triggers a SYSRST, after which it runs the boot configuration routine (BCR) to authenticate the BSL entry before starting the BSL. After the BSL execution concludes, a SYSRST is generated and the BCR executes again. When the BCR completes, a final SYSRST is issued and the application is started. This entire process does not reset the SYSOSC FCL enable configurations, as only a SYSRST reset level is asserted throughout the process. - (3) If a boot fail occurs during execution of the boot configuration routine, a BOOTRST can be generated by SYSCTL to attempt the boot process again from the BOOTRST level. See Section 2.4.1.8. ## **Note** SLEEP, STOP, and STANDBY operating modes are not shown in this diagram. These modes originate from and return to RUN mode unless an exception occurs which causes a reset level to be asserted or a mode to be suspended. ## 2.4.1.1.1 Power-on Reset (POR) Reset Level A power-on reset (POR) is a complete device reset. The following conditions generate a POR: - The device powers up (cold start) - A POR- supply monitor violation(VDD drops below the POR supply monitor negative-going threshold) - A parity fault on PMU trim data or the shutdown memory - Software triggers a POR through SYSCTL (RESETLEVEL 0x03) - · The NRST pin is held low for more than one second when in NRST mode A POR always resets the shutdown memory, reenable the NRST/SWD pin functions (if disabled), and trigger a BOR. ## 2.4.1.1.2 Brownout Reset (BOR) Reset Level A brownout reset (BOR) resets the device power management unit (PMU). All regulated core logic powered from VCORE is power cycled. The following conditions generate a BOR: - A POR - A BOR0- supply monitor violation (VDD drops below the BOR0- supply monitor negative-going threshold) - An exit from shutdown mode (through a wakeup-capable IO, NRST, or SWD) The following are not reset by a BOR: - The shutdown memory (SHUTDNSTOREx) - · The NRST state, if disabled by software - The SWD state, if disabled by software - The latched IO pin state, if the cause of the BOR is an exit from SHUTDOWN mode (see SHUTDOWN mode handling) A BOR always triggers a BOOTRST when VDD > BOR0+. # 2.4.1.1.3 Boot Reset (BOOTRST) Reset Level A boot reset (BOOTRST) triggers execution of the device boot configuration routine and resets the majority of the core logic, including the SYSOSC FCL mode (if enabled). The system memory (SRAM) is also power cycled and SRAM contents are lost. The following conditions generate a BOOTRST: - A BOR - A parity fault on non-PMU trim data - A fatal clock failure (see MCLK Monitor) - A WWDT0 violation - Software triggers a BOOTRST through SYSCTL (RESETLEVEL 0x01) - The NRST pin is held low for longer than the minimum reset pulse time but less than one second when in NRST mode - A BOOTRST followed by a boot failure (re-attempt of a failed boot sequence) The following are not reset by a BOOTRST: - The shutdown memory (SHUTDNSTOREx) - The NRST disable state, if disabled by software - The SWD disable state, if disabled by software Following a BOOTRST, a SYSRST is always triggered if the boot configuration routine completes successfully. If the boot configuration routine fails to complete successfully, a BOOTRST is again generated and the boot process is attempted again from the BOOTRST point. The boot process attempts to complete successfully up to 3 times, after which the device state locks until a BOR or POR reset occurs (see Section 2.4.1.8). ## 2.4.1.1.4 System Reset (SYSRST) Reset Level A system reset clears the state of the CPU and all the peripherals, with the exceptions listed below. The following conditions generate a SYSRST: - A BOOTRST followed by a boot pass - A bootstrap loader (BSL) exit, which is always followed by execution of the boot configuration routine (BCR) - A flash ECC uncorrectable (DED) error - A WWDT1 violation (if present) - A CPU lockup violation - Software triggers a SYSRST through SYSCTL (RESETLEVEL 0x00) - Software triggers a SYSRST with BSL entry through SYSCTL (RESETLEVEL 0x02) - The debug subsystem triggers a system reset The following are not reset by a SYSRST: - The shutdown memory (SHUTDNSTOREx) - The NRST state, if disabled by software - The SWD state, if disabled by software - The SYSOSC frequency correction loop (FCL), if enabled by software In most cases, the device is in RUN mode after a SYSRST, and the CPU executes the reset vector and begins execution of the application software. There are two exceptions to this: - If the SYSRST was triggered with a BSL entry request, the BCR runs followed by the BSL. - If the SYSRST was triggered due to a BSL exit request, the BCR runs, followed by an additional SYSRST, after which the application software starts. ## 2.4.1.1.5 CPU-only Reset (CPURST) Reset Level A CPU-only reset clears the state of the CPU logic only. Peripheral states are not affected by a CPU reset. A CPU reset is only generated by software through the CPU AIRCR local register or by the debug subsystem. ## 2.4.1.2 Initial Conditions After POR After a POR, when the boot process completes and the CPU starts the application, the initial device conditions are as follows: - The NRST pin is configured in NRST mode - Serial wire debug (SWD) IO are in SWD mode - All other configurable I/O pins are high impedance (Hi-Z) - · Peripheral modules are reset as described in their respective chapters of this manual - The device is in RUN mode - MCLK is sourced from the internal SYSOSC at base frequency (32 MHz) - LFCLK is sourced from the internal LFOSC (note that LFOSC requires time to start up before LFCLK can be used) - · MFCLK is disabled - · Peripherals are disabled - Any flash sectors configured to be write protected at boot are write protected # 2.4.1.3 NRST Pin After a cold start, the NRST pin is configured in NRST mode. The NRST pin must be high for the device to boot successfully. There is no internal pullup resistor on NRST. External circuitry (either a pullup resistor to VDD or a reset control circuit) must actively pull NRST high for the device to start. After the device is started, a low pulse on NRST <1 second in duration triggers a BOOTRST. If a low pulse on NRST is held for >1 second, a POR is triggered. Some low pin count devices support reconfiguring the NRST pin to be a GPIO pin. See the pin configuration of the device-specific data sheet to see if GPIO functionality is shared with NRST. Application software can disable the NRST functionality of the NRST pin, allowing GPIO functionality to be enabled. To disable NRST, set the DISABLE bit in the EXRSTPIN register along with the KEY. Then configure IOMUX for the desired functionality. After the NRST pin function is disabled, it can only be re-enabled by a POR. ## **Note** When the NRST pin is shared with the I2C open-drain pin, it is important for the user's system to ensure that the device is powered up and in I2C mode before any transactions occur on the I2C bus. If the device is inadvertently reset due to a low signal on the shared reset or I2C SDA line before this point, it may cause the device reset. To prevent this, pullups on the NRST pin that is shared with the I2C open-drain IO should be selected to meet the I2C pullup requirements for minimum and maximum values. ## 2.4.1.4 SWD Pins There are two serial wire debug (SWD) pins present on all devices: - SWCLK (serial wire clock) - SWDIO (serial wire data input/output) After a cold start, the SWD pins are configured in SWD mode to allow a debug connection to be established. It is possible to re-configure the SWD pins as general purpose IO (GPIO) in software to enable use of these pins in an application when debug support is no longer required. To disable SWD functionality, set the DISABLE bit in the SWDCFG register in SYSCTL along with the KEY. Then configure IOMUX for the desired functionality. Once the SWD pin functions are disabled, they can only be re-enabled by triggering a POR. ## 2.4.1.5 Generating Resets in Software Software can generate a software POR, a software BOOTRST, a software SYSRST with bootstrap loader (BSL) entry, or a software SYSRST by issuing the appropriate command to SYSCTL. To issue a reset, first select the desired reset level in the RESETLEVEL register in SYSCTL. Then set the GO bit in the RESETCMD register along with the KEY value. | LEVEL | Action | |-------|--------------------------------| | 0x0 | Software SYSRST | | 0x1 | Software BOOTRST | | 0x2 | Software SYSRST with BSL entry | | 0x3 | Software POR | Table 2-9. Software Generated SYSCTL Reset Commands A CPU-only reset (CPURST) which does not reset the peripherals can also be triggered in software within the Cortex-M0+ CPU by setting the SYSRESETREQ bit in the AIRCR local CPU register. See the CPU Sub System chapter for more information. ## Starting the BSL from Software The software-triggered BSL entry (RESETLEVEL 0x02) is a special case of the SYSRST which provides a mechanism for the application software to start the ROM bootstrap loader (BSL). It is not possible to jump to the bootloader code directly during normal software execution in RUN mode. When application software commands a software-triggered BSL entry (RESETLEVEL 0x02), a SYSRST is generated first, followed by execution of the boot configuration routine (for authentication), after which the BSL is started (if the device security policy has the BSL configured to be enabled). Once the BSL has completed execution, a second SYSRST is issued and the BCR will execute. When the BCR completes, a final SYSTRST is asserted to return control of the system back to the application software. Any system configuration which is not reset by a SYSRST will be maintained through this entire process. ## 2.4.1.6 Reset Cause After a device reset occurs, the lowest level reset cause which occurred during reset processing is captured in hardware so that application software can interrogate the reason for the reset and take any appropriate action when starting the application. The lowest level reset cause is encoded into a 5-bit field in the reset cause register in SYSCTL. The contents of the reset cause register are always cleared upon a read, and return zero after being read if no reset has occurred after the read. The reset cause encodings are given in Table 2-10. Table 2-10. Reset Cause Encoding | Reset Reset | | | | | Device Modules Reset | | | | | | | | | | | | | |-------------|----------|------|-------------------------------|-------------------|----------------------|-----------------------|-----------------|-------------|------|---------------|------------------|----------------------|-------------|-----|---|---|---| | Reset Level | Cause ID | | Reset Cause | NRST/SWD Disables | SHUTDN STOREX | Core Regulator | Debug Subsystem | LFCLK State | SRAM | BCR Execution | ІОМИХ | EVENT, DMA, FLASHCTL | Peripherals | СРО | | | | | | 0x00 | 0 | No | eset s | ince I | ast re | ad | | | | | | | | | | | | | | | VDD < POR- violation | | | | | | | | | | | | | | | | 505 | 0x01 | 0x01 | 0x01 | 0x01 | 1 | PMU trim parity fault | R | R | R | R | R | R | R | R | R | R | R | | POR | | | SHUTDNSTOREx parity fault | | | | | | | | | | | | | | | | | 0x02 | 2 | NRST pin reset (>1s) | R | R | R | R | R | R | R | R | R | R | R | | | | | | 0x03 | 3 | Software-triggered POR | R | R | R | R | R | R | R | R | R | R | R | | | | | | 0x04 | 4 | VDD < BOR- violation | | | R | R | R | R | R | R | R | R | R | | | | | BOR | 0x05 | 5 | Wake from SHUTDOWN | | | R | R | R | R | R | R <sup>(1)</sup> | R | R | R | | | | | BOK | 0x06 | 6 | | Reserved | | | | | | | | | | | | | | | | 0x07 | 7 | | Reserved | | | | | | | | | | | | | | | | 0x08 | 8 | Non-PMU trim parity fault | | | | | R | R | R | R | R | R | R | | | | | | 0x09 | 9 | Fatal clock fault | | | | | R | R | R | R | R | R | R | | | | | | 0x0A | 10 | | Reserved | | | | | | | | | | | | | | | BOOTRST | 0x0B | 11 | | Reserved | | | | | | | | | | | | | | | BOOTKST | 0x0C | 12 | NRST pin reset (<1 s) | | | | | | R | R | R | R | R | R | | | | | | 0x0D | 13 | Software-triggered BOOTRST | | | | | | R | R | R | R | R | R | | | | | | 0x0E | 14 | WWDT0 violation | | | | | | R | R | R | R | R | R | | | | | | 0x0F | 15 | | Reserved | | | | | | | | | | | | | | | | 0x10 | 16 | BSL exit | | | | | | | R | R | R | R | R | | | | | | 0x11 | 17 | BSL entry | | | | | | | R | R | R | R | R | | | | | | 0x12 | 18 | | Re | serve | d | | | | | | | • | | | | | | | 0x13 | 19 | Reserved | | | | | | | | | | | | | | | | | 0x14 | 20 | Uncorrectable flash ECC error | | | | | | | | R | R | R | R | | | | | evenet | 0x15 | 21 | CPULOCK violation | | | | | | | | R | R | R | R | | | | | SYSRST | 0x16 | 22 | | Re | serve | d | | | | | | | | | | | | | | 0x17 | 23 | | Re | serve | d | | | | | | | | | | | | | | 0x18 | 24 | | Reserved | | | | | | | | | | | | | | | | 0x19 | 25 | | Re | serve | d | | | | | | | | | | | | | | 0x1A | 26 | Debug-triggered SYSRST | | | | | | | | R | R | R | R | | | | | | 0x1B | 27 | Software-triggered SYSRST | | | | | | | | R | R | R | R | | | | | Reset | | | | | | Device Modules Reset | | | | | | | | | | | |-------------|----------|----|---------------------------|-------------------|---------------|----------------------|-----------------|-------------|------|---------------|-------|----------------------|-------------|-----|--|--| | Reset Level | Cause ID | | Reset Cause | NRST/SWD Disables | SHUTDN STOREX | Core Regulator | Debug Subsystem | LFCLK State | SRAM | BCR Execution | IOMUX | EVENT, DMA, FLASHCTL | Peripherals | CPU | | | | CPURST | 0x1C | 28 | Debug-triggered CPURST | | | | | | | | | | | R | | | | | 0x1D | 29 | Software-triggered CPURST | | | | | | | | | | | R | | | | | 0x1E | 30 | Reserved | | | | | | | | | | | | | | | | 0x1F | 31 | | Reserved | | | | | | | | | | | | | Table 2-10. Reset Cause Encoding (continued) (1) In the case of a SHUTDOWN mode exit, the IOMUX registers are always reset but the IOs themselves retain their last state from the point of entry into SHUTDOWN until the user clears the RELEASE bit in the SHDNIOREL register in SYSCTL. This enables application software to be able to reconfigure IOMUX and any corresponding peripherals before releasing the IO after a SHUTDOWN exit. See shutdown mode handling and IOMUX wake. If two reset causes occur simultaneously, the lowest cause reset ID value is prioritized and reported. For example, if a WWDT0 violation (cause 0x12) occurs at the same time that a VDD < BOR- violation (cause 0x04) occurs, the reported reset cause is a BOR- violation (cause 0x04), as this is a lower level reset which clears additional aspects of the device state. The reset cause encoding enables simple software handling during application startup. The reset cause value can be read by application software and tested to be within a certain value range to determine if the following occurred: - RESETCAUSE==0x00: No reset since last read - RESETCAUSE<0x04: The NRST/SWD disable state was reset and can need to be reconfigured</li> - RESETCAUSE<0x04: The SHUTDNSTOREx memory was reset and can need to be reconfigured - RESETCAUSE<0x08: The regulated VCORE domain, including the SRAM, was power cycled - RESETCAUSE<0x1C: The peripherals were reset and can need to be reconfigured The following example shows how the reset cause can be tested to take specific actions when starting an application after a reset: ## 2.4.1.7 Peripheral Reset Control Each peripheral on a device contains a reset control register (RSTCTL) and a status register (STAT). The STAT register is a read-only register which contains a RESETSTKY bit, indicating if the peripheral was reset. This bit can be read by application software to determine if a peripheral was reset and needs to be re-configured. The RESETSTKY bit is cleared by writing the RESETSTKYCLR bit together with the KEY value to the RSTCTL register. Application software can also force a reset of the peripheral by writing the RESETASSERT bit together with the KEY value to the RSTCTL register. This action will reset the peripheral to its default state, and will set the RESETSTKY bit in the STAT register. #### 2.4.1.8 Boot Fail Handling If a boot fails during execution of the boot configuration routine (BCR), SYSCTL asserts a BOOTRST to attempt another boot. A boot fail can be caused by the following: - · Boot configuration data integrity error - Device trim integrity error - BCR timeout (BCR takes significantly longer than expected to complete for any other reason) Up to three attempts to successfully boot the device are made by hardware. If the first, second, or third boot attempt is successful, the application starts normally. If the third attempt fails, then the boot process fails, no further boot attempts are made, and the application software is not started. The purpose of the additional boot attempts is to allow the device to boot correctly if a transient (temporary) error was the cause of the boot fail. If three boot attempts are not successful, a steady-state error condition is likely present and the application is not started to prevent unexpected operation. #### Note If a device is locked due to three failed attempts to boot, and a BOR- violation occurs, a BOR and BOOTRST are still generated (by definition) and a single boot attempt is made. Under the same conditions, if power is completely removed from the device (triggering a POR- violation), then the device again attempts to boot up to three times. #### 2.4.2 Operating Mode Selection The device operating mode is configured through the use of the following: - Policy bits in the SYSOSCCFG and MCLKCFG registers in SYSCTL (to control the behavior of SYSOSC in RUN, SLEEP, and STOP modes) - 2. Policy bits in the PMODECFG register in SYSCTL (to set the deep sleep level of STOP, STANDBY or SHUTDOWN) - 3. SLEEPDEEP policy bit in the SCR local CPU register (to select whether a WFI instruction triggers SLEEP mode or STOP/STANDBY/SHUTDOWN mode) - 4. Use of the Arm WFI (wait for interrupt) CPU instruction (to enter the configured SLEEP/STOP/STANDBY/SHUTDOWN state) Before entering an operating mode where the CPU is disabled, make sure that the appropriate peripheral that can wake the CPU from sleep has been configured to generate a CPU interrupt on the desired event. For a detailed description of the behavior of each operating mode, see the operating modes section. # **Policy Bit Configuration** Table 2-11 defines how to configure the relevant policy bits for each operating mode. All values are indicated in binary format. A dash (-) indicates that the particular policy bit is a don't care for the specified operating mode. SLEEP(2) STOP **STANDBY Operating Mode Policy Control** RUN SHUTDOWN **STANDBY0** STANDBY STOP2<sup>(3)</sup> SLEEP2 RUN2 SLEEP( RUNO SLEEP RUN1 Register Bit DISABLE(1) 0 0 1 0 0 (1) 1 USE4MHZSTOP SYSOSCCFG 0 1 0 DISABLESTOP 0 0 1 USELFCLK(1) 0 1 0 1 0 0 **MCLKCFG** STOPCLKSTBY 0 \_ 1 **PMODECFG** DSLEEP 00 00 00 01 01 10 SCR SLEEPDEEP n 0 n n 1 1 1 1 1 **Table 2-11. Operating Mode Policy Bit Configuration** - (1) The SYSOSCCFG.DISABLE and MCLKCFG.USELFCLK policy bits take effect immediately after being configured, as these bits affect the RUN mode behavior. Other policy bits only take effect when the CPU is put into deep sleep. - (2) SLEEP mode behavior is always identical to RUN mode, except with the CPUCLK disabled. As such, the SLEEP behavior is determined by the configuration of RUN mode. - (3) The STOP2 policy for STOP mode can be configured by setting the DISABLESTOP bit or DISABLE bit in the SYSOSCCFG register before entering DEEPSLEEP. When DISABLESTOP is set and DISABLE is cleared, SYSOSC is only disabled when DEEPSLEEP is requested. SYSOSC continues to run in RUN and SLEEP modes. When DISABLE is set, DISABLESTOP becomes a don't care, and SYSOSC is disabled immediately and is kept disabled in STOP mode. #### **Entering SLEEP Mode** Entering **SLEEP** mode disables the CPU, but otherwise maintains the same configuration as **RUN**. To enter **SLEEP** mode: - 1. Configure the Cortex-M0+ CPU for SLEEP by clearing the SLEEPDEEP bit in the Cortex-M0+ SCR local register - 2. Enter sleep mode by executing a WFI (wait for interrupt) CPU instruction #### **Entering STOP or STANDBY Modes** To enter STOP or STANDBY mode: - 1. Configure the PMODECFG register in SYSCTL to 0b00 (STOP) or 0b01 (STANDBY) - 2. Configure the Cortex-M0+ CPU for DEEP SLEEP by setting the SLEEPDEEP bit in the Cortex-M0+ SCR local register - 3. Enter sleep mode by executing a WFI (wait for interrupt) CPU instruction #### **Entering SHUTDOWN Mode** To enter **SHUTDOWN** mode: - 1. Configure the PMODECFG register in SYSCTL to 0b10 (SHUTDOWN) - 2. Configure the Cortex-M0+ CPU for DEEP SLEEP by setting the SLEEPDEEP bit in the Cortex-M0+ SCR local register - 3. Enter sleep mode by executing a WFI (wait for interrupt) CPU instruction #### 2.4.3 Asynchronous Fast Clock Requests Peripherals are configured to asynchronously assert a hardware request to the SYSCTL for a fast clock source, even if the device is operating in STOP or STANDBY mode. This mechanism is ideal for applications where the MCLK/ULPCLK tree is normally sourced from either LFCLK (at 32 kHz) or SYSOSC (at 4 MHz), but a faster clock is temporarily needed to quickly handle a peripheral event (for example, a timer IRQ or GPIO IRQ) or peripheral activity (such as serial communication or an ADC conversion). Asynchronous fast clock requests are also useful for scenarios where the device is running in STANDBY1 mode. In STANDBY1 (when STOPCLKSTBY is set), the ULPCLK and LFCLK are disabled to all peripherals except for TIMG0 and TIMG1, leaving TIMG0 and TIMG1 as the only clocked peripherals. To wake up the device from this state where the bus clock (ULPCLK) is disabled, a TIMG0 and TIMG1 interrupt request forces an asynchronous fast clock request to wake the device to RUN mode. Other peripherals can also wake the device from this state if they support detecting an asynchronous event (for example GPIO, comparator, and serial interfaces). Asynchronous fast clock requests temporarily provide peripherals with a 32 MHz bus clock ( MCLK/ULPCLK), sourced from the SYSOSC, for the duration of the request. MFCLK, if enabled for use, is also enabled during the asynchronous request. #### **Asynchronous Fast Clock Behavior** When configured, SYSCTL will respond to a peripheral fast clock request in the following way: - 1. If the device is currently in a STOP or STANDBY mode, the low power state is temporarily suspended to support running the bus clock (ULPCLK) at the SYSOSC base frequency (32 MHz) - 2. If SYSOSC is disabled, it is forced to be enabled; if SYSOSC is already running but at a different frequency than base frequency, it is forced to base frequency (32 MHz) - 3. The MCLK/ULPCLK tree is forced to be sourced from SYSOSC at the 32 MHz rate; if the device is in RUN mode then the CPUCLK is also switches to the SYSOSC rate (the CPUCLK is always derived from MCLK) - 4. If the MFCLK is configured to be used, it will be activated After the configuration above is applied, it will be held for the duration of time that the asynchronous request remains asserted plus an additional 32 SYSOSC cycles (approximately 1µs). 32 SYSOSC cycles after the request is removed, the system will return to the configuration which existed before the fast clock request, provided the CPU did not change the configuration during the request. Asynchronous fast clock requests are ignored and will have no effect on the device configuration if any of the following are true: - MCLK is already sourced from SYSOSC at base frequency (32 MHz) - Asynchronous fast clock requests are globally blocked by setting the BLOCKASYNCALL bit in the SYSOSCCFG register in SYSCTL #### **Peripheral Support** The TIMG0, TIMG1, GPIO, comparator, SPI, I2C, UART, and ADC peripherals all provide support for generating an asynchronous fast clock request. The purpose, request source, and configuration requirements for these peripherals are given in Table 2-12. Table 2-12. Peripheral Support for Asynchronous Fast Clock Requests | Table 2 12.1 diplicial support of Asynchical Fact Glock Requests | | | | | |------------------------------------------------------------------|--------------------------------------|------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | Peripheral | Purpose | Request Source | Configuration | | | TIMG0 and<br>TIMG1 | Fast CPU wake from TIMG0/TIMG1 event | TIMG0 or TIMG1<br>IRQ to CPU | An IRQ event from TIMG0 or TIMG1 generates an asynchronous fast clock request when the device is in STANDBY1 mode and the corresponding IMASK interrupt is set in the TIMG registers. This is needed to wake the device as the ULPCLK is disabled to reduce power consumption. | | | GPIO | Fast CPU wake from GPIO activity | | The GPIO generates an asynchronous fast clock request through the GPIO configuration registers. This is ideal for applications where GPIO wake from STANDBY mode is desired, as the fast clock request will cause the GPIO digital glitch filters to run at the 32 MHz rate. In addition to configuring the GPIO registers to request the fast clock, the BLOCKASYNCALL bit must be cleared in the SYSOSCCFG register to allow the request to propagate. | | | Comparator | Fast wake from a comparator event | Comparator event | A comparator event generates an asynchronous fast clock request to provide the lowest latency comparator event response. The BLOCKASYNC bit in the CLKCFG register of the respective comparator must be disabled. | | | Table 2-12. Peripheral | Support for Asynchrono | us Fast Clock Red | quests (continued) | |-------------------------|------------------------|-------------------|--------------------| | 145.5 = 1211 0116110141 | | 40 . 40. 0.00 | quooto (oontinaou) | | Peripheral | Purpose | Request Source | Configuration | |------------|--------------------------------------------------------------------------------------------------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | SPI | Temporarily use fast clock for bit clock generation | SPI activity | SPI activity generates an asynchronous fast clock request when the BLOCKASYNC bit is cleared in the CLKCFG register of the respective SPI peripheral. | | 12C | Temporarily use fast clock for bit clock generation | I2C activity | I2C activity generates an asynchronous fast clock request when the BLOCKASYNC bit is cleared in the CLKCFG register of the respective I2C peripheral. | | UART | Temporarily use a fast clock for baud rate generation | UART activity | UART activity generates an asynchronous fast clock request when the BLOCKASYNC bit is cleared in the CLKCFG register of the respective UART peripheral. | | ADC | Temporarily run the<br>SYSOSC to support<br>timer-triggered ADC<br>operation from a low-<br>power mode | ADC | If an ADC conversion is triggered when SYSOSC is disabled, an asynchronous fast clock request is generated to enable the SYSOSC (SYSOSC is required for correct ADC operation). | #### **Fast CPU Event Handling** In addition to the peripheral event and activity fast clock request triggers, the SYSCTL can be configured to generate an asynchronous fast clock request upon any IRQ request to the CPU. This provides the lowest latency interrupt handling when the system is running at the LFCLK rate (32 kHz), as the IRQ request will propagate through the wake-up logic at the SYSOSC rate (32 MHz) vs. the LFCLK rate (32 kHz). When the FASTCPUEVENT bit is set in the SYSOSCCFG register in SYSCTL, any interrupt request to the CPU will also generate a fast clock request. #### **Asynchronous Fast Clock Request Logic** The logic for asserting a fast clock request is given in Figure 2-10. Figure 2-10. MSPM0Lxx Asynchronous Fast Clock Request Logic #### 2.4.4 SRAM Write Protection Certain applications need to place read-only data into SRAM. This can occur if code is placed into SRAM (for zero wait state execution) or if critical lookup tables are placed in SRAM (for zero wait state reads). In these cases, especially when code is to be executed from the SRAM, it is desirable to prevent unintentional writes to SRAM addresses that can corrupt executable code in the event of a buffer overrun or a stack overflow. Likewise, it is desirable to prevent execution from non-write-protected SRAM addresses. To improve robustness of data in stored in SRAM, SYSCTL provides a write-exclusive-execute boundary mechanism. To use this feature, first load the read-only data into the desired SRAM address, then configure the SRAM address range to be write protected. SRAM contents which are to be read-execute (no writes) should be placed into the upper portion of SRAM. SRAM contents which are to be read-write (no execute) should be placed into the lower portion of the SRAM. Then, the SRAMBOUNDRY register may be written with the desired boundary to partition the SRAM into two regions, with the lower region being RW and the upper region being RX. #### 2.4.5 Flash Wait States Flash wait states are managed automatically by SYSCTL when MCLK is running from SYSOSC or LFCLK. Application software is not required to configure any wait states for proper operation of the device. Refer to the *Recommended Operation Conditions* section of the device specific data sheet to determine the max clock frequency supported with 0 or 1 wait state. #### 2.4.6 Flash Bank Address Swap Devices with multiple flash banks provide a mechanism for swapping the address space of the upper banks with the address space of the lower banks to enable firmware updates where the firmware image itself does not need to have knowledge of the bank it resides in to be able to execute properly on the hardware. To swap the addresses of the upper flash banks with the addresses of the lower flash banks, set the USEUPPER bit in the FLBANKSWAP register while also writing the KEY value. Special considerations apply when swapping the flash bank address space. See the non-volatile memory system chapter of this guide for considerations when using flash bank address swapping. #### 2.4.7 Shutdown Mode Handling When the device is configured to enter SHUTDOWN mode, the core regulator is powered down and the device register contents and SRAM contents are lost. An exit from SHUTDOWN mode generates a BOR level reset. Two mechanisms are provided to preserve the device state when entering SHUTDOWN mode: IO latching and a small shutdown memory. #### **Shutdown IO State** The digital IO pin states (output low/high, pullup/pulldown, Hi-Z, drive configuration) are latched and retained upon entry to SHUTDOWN. After exiting SHUTDOWN mode, the IOs are held in the previous state until released by application software setting the RELEASE bit in the SHDNIOREL register along with the matching KEY value. When exiting SHUTDOWN mode, application software must first re-configure the IO to their proper state, then release the IO. To determine at startup if the cause of a reset was an exit from SHUTDOWN mode, application software must read the RSTCAUSE register in SYSCTL. #### Note When exiting SHUTDOWN, the serial wire debug (SWD) pins will also remain locked until application software sets the RELEASE bit. As a result, it is not possible to establish a debug connection when waking up from SHUTDOWN mode until the IO a re released by application software. #### Note When exiting SHUTDOWN, the boot strap loader (BSL) invoke pin must be held at a logic low level to prevent unintended entry into the BSL during exit from SHUTDOWN. An entry to the BSL during SHUTDOWN exit would prevent the application code from starting, the BSL interfaces would not be available, and a SWD connection would not be possible as the IO states remain latched through SHUTDOWN exit until application software releases the IOs. #### **Shutdown Memory** To enable saving of application state information before entering SHUTDOWN mode, 4 bytes of shutdown memory are provided in SYSCTL. These memory locations are retained in SHUTDOWN mode and are readable by the application after exiting SHUTDOWN. To save data to the SHUTDOWN memory, write to the SHUTDNSTORE0-3 registers in SYSCTL. #### 2.4.8 Configuration Lockout Configuration registers in SYSCTL can be locked out from writes to add a layer of robustness against unintended changes to the PMCU at runtime. To lock out the configuration registers from writes, set the ACTIVE bit in the WRITELOCK register in SYSCTL. All SYSCTL registers are protected by the WRITELOCK functionality except for those listed below: - WRITELOCK - PMODECFG - · FCC, FCCCMD - FLBANKSWAP - RSTCAUSE (read-to-clear), RESETLEVEL, RESETCMD - BORTHRESHOLD, BORCLRCMD - SHDNIOREL - PMUOPAMP - SHUTDNSTOREx In addition to the overall SYSCTL configuration write lock feature, many SYSCTL registers also require a KEY value to be written in conjunction with the desire configuration data for the write to take effect. #### 2.4.9 System Status The status of various aspects of the PMCU can be polled by software by reading the CLKSTATUS and SYSSTATUS registers in SYSCTL. #### Checking Clock Status (CLKSTATUS) The CLKSTATUS register in SYSCTL is a read-only register which indicates the current configuration and status of the clock module. Key status information provided in CLKSTATUS includes: - The current SYSOSC frequency - The current MCLK selection - The LFOSC status - Error indications if a peripheral requested a clock and the clock cannot be generated This status information is useful to validate that a requested clock change has completed successfully, or to check the true SYSOSC frequency in applications where SYSOSC can have asynchronous activation or frequency requests issued by peripherals. #### **Checking System Status (SYSSTATUS)** The SYSSTATUS register in SYSCTL is a read-only register which indicates the peripheral-specific status information. # 2.4.10 Error Handling MSPM0 devices include several diagnostic mechanism to detect errors at runtime. Table 2-13 lists error sources and their corresponding handling mechanism. #### **Note** Not all MSPM0 devices support all diagnostic features. For example, some devices do not have ECC/parity on memories and some devices do not have dual watchdog timers. Always refer to the device-specific data sheet to understand which diagnostic features are available for a given device. In the PMCU registers section, register maps are also provided for each MCU sub-family detailing the specific registers available for a given device. Table 2-13. Error Sources and Handling Mechanisms | Error Course | | Handling Mechanisms | |------------------------------|-----------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Error Source | Error | Handling Mechanism | | Flash (if device<br>has ECC) | Non-correctable ECC error (if device has ECC) | <ul> <li>For a CPU or DMA request, a FLASHDED non-maskable interrupt is generated to the processor is generated or a SYSRST is generated depending on configuration of the FLASHECCRSTDIS bit</li> <li>The FLASHDED sticky bit is set in the SYSSTATUS register in SYSCTL</li> </ul> | | | Correctable ECC error (if device has ECC) | A FLASHSEC interrupt is also generated in SYSCTL The FLASHSEC sticky bit is set in the SYSSTATUS register in SYSCTL | | SRAM | Non-correctable ECC error (if device has ECC) | An SRAMDED non-maskable interrupt is generated to the processor | | | Correctable ECC error (if device has ECC) | A SYSCTL SRAMSED interrupt is generated to the processor | | | Parity error (if device has parity) | Non-maskable interrupt is generated to the processor if the request was from the CPU DMA data error interrupt is generated if the request was from the DMA | | | Address error on CPU access | A hard fault is generated in the CPU | | | Address error on DMA access | A DMA address error interrupt is generated in the DMA controller | | | ECC error on CAN SRAM (if device has CAN-FD) | An interrupt is generated in the CAN-FD peripheral | | SHUTDNSTOREx<br>Memory | Parity error | A POR is generated | | CKM | MCLK failure | A BOOTRST is generated | | | LFCLK failure (if present) | <ul> <li>A BOOTRST is generated if LFCLK is sourcing MCLK</li> <li>An LFCLKFAIL non-maskable interrupt is generated in the SYSCTL NMI registers.</li> </ul> | | CPUSS (if device has MPU) | Memory protection unit violation | A hard fault is generated in the CPU | | WWDT | WWDT0 violation | A BOOTRST is generated or a non-maskable interrupt is generated in the SYSCTL NMI registers depending on configuration of the WWDTLP0RSTDIS bit | | | WWDT1 violation (if present) | A BOOTRST is generated or a non-maskable interrupt is generated in the SYSCTL NMI registers depending on configuration of the WWDTLP1RSTDIS bit | | Table 2-13. Error Sources and Handling M | Mechanisms (continued) | |------------------------------------------|------------------------| |------------------------------------------|------------------------| | Error Source | Error | Handling Mechanism | |--------------|-----------------------------------------------|--------------------------------------------------------------------------| | PMU | Trim parity error | A POR is generated | | | POR0- supply error | A POR is generated | | | BOR0- supply error | A BOR is generated | | | BOR1/2/3- supply error | A BORLVL non-maskable interrupt is generated in the SYSCTL NMI registers | | CPUSS | Memory protection unit violation (if present) | A hard fault is generated in the CPU | #### **Configurable NMI Triggers** Error sources can be configured to trigger either a non-maskable interrupt or a different handling mechanism. The SYSTEMCFG register in SYSCTL may be used to specify the desired error handling mechanism. For example, the WWDT0 may be configured to generate either a BOOTRST or an NMI, with BOOTRST being the default case. Refer to the SYSTEMCFG register for the relevant device sub-family for the available error handling options. #### 2.4.11 SYSCTL Events The SYSCTL module contains two event publishers and no event subscribers. One event publisher manages SYSCTL interrupt requests (IRQs) to the CPU subsystem. The second publisher manages non-maskable interrupts to the CPU subsystem for critical diagnostics. The SYSCTL events are summarized in SYSCTL Events. Table 2-14. SYSCTL Events | Event | Туре | Source | Destination | Route | Configuration | Functionality | |-----------------------------------------|-----------|--------|---------------|--------------|----------------------------|------------------------------------------| | CPU interrupt | Publisher | SYSCTL | CPU Subsystem | Static route | SYSCTL interrupt registers | Fixed interrupt route from SYSCTL to CPU | | CPU non-<br>maskable<br>interrupt (NMI) | Publisher | SYSCTL | CPU Subsystem | Static route | NMI interrupt registers | Fixed interrupt route from SYSCTL to CPU | #### 2.4.11.1 CPU Interrupt Event (CPU\_INT) The SYSCTL module provides several interrupt sources which can be configured to source a CPU interrupt event. In order of decreasing interrupt priority, the CPU interrupt events from the SYSCTL are given in Table 2-15. Table 2-15. SYSCTL CPU Interrupt Event Sources | Index (IIDX) | Name | Description | |--------------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | NONE | No interrupt pending. | | 1 | LFOSCGOOD | Indicates when LFOSC is ready during startup, as LFOSC takes ≈1ms to start. | | 2 | ANACLKERR | Indicates that an analog function was enabled and expecting a SYSOSC to be operation at a certain frequency, but SYSOSC was either not available or not operating at the required frequency. | The CPU interrupt event configuration is managed with the SYSCTL IIDX, IMASK, RIS, MIS, ISET, and ICLR event management registers. See Section 6.2.5 for guidance on configuring these registers for CPU interrupts. #### 2.4.11.2 Non-maskable Interrupt Event (NMI) The SYSCTL module provides x interrupt sources which can be configured to source a CPU interrupt event. In order of decreasing interrupt priority, the CPU interrupt events from the SYSCTL are given in Table 2-15. Table 2-16. Non-maskable Interrupt Event Table | Index (IIDX) | Name | Description | | |--------------|--------|---------------------------------------------------------------------|--| | 0 | NONE | No NMI pending. | | | 1 | BORLVL | Indicates that VDD has dropped below the specified VBOR- threshold. | | | 2 | WWDT0 | A WWDT0 violation occurred. | | The CPU non-maskable interrupt event configuration is managed with the NMIIIDX, NMIRIS, NMIISET, and NMIICLR event management registers. See Section 6.2.5 for guidance on configuring the interrupt management registers. #### 2.5 Quick Start Reference The PMCU is designed to provide a simple, easy-to-use power management, clocking, and reset management functionality. This section describes the basic operating principles of the PMCU as well as tips and tricks for taking the default configuration out of reset and optimizing it for particular applications. #### 2.5.1 Default Device Configuration The default operating configuration of the device provides basic functionality which can be suitable for many applications without modification. MSPM0Lxx devices power up and release reset for execution of application code when the external supply (VDD and VSS) reaches 1.62 V. When the application code is released for execution, the device is in RUN mode with MCLK sourced from the internal SYSOSC at 32 MHz. The CPUCLK and ULPCLK are also 32 MHz, derived from MCLK. LFCLK starts automatically, sourced from the internal LFOSC. In RUN mode with the default configuration, all peripherals are available to be enabled. Peripherals such as the DMA and CRC run directly from MCLK at the MCLK rate. Other peripherals, such as timers and serial interfaces, can run from the bus clock at 32 MHz or from the low-frequency 32-kHz clock (LFCLK) based on their peripheral clock selection. Power consumption can be reduced by entering SLEEP, STOP, STANDBY, or SHUTDOWN mode. By default, these modes behave in the following way: - In SLEEP mode, the CPUCLK is disabled but all peripherals, including the DMA, continue to run as configured at either 32 MHz or 32 kHz. This power mode is ideal for scenarios where PD1 peripherals are used and having the lowest possible wakeup latency is more important than having the lowest power consumption. - In STOP mode, (STOP0 by default), the MCLK source to PD1 peripherals is disabled and PD1 peripherals are disabled and in retention (unavailable for use). The default STOP mode is ideal for scenarios where power optimization is important but the ADC, OPA, or a clock faster than 32 kHz is needed. - SYSOSC by default will continue to run at 32 MHz, but the MCLK tree will run at 4 MHz (SYSOSC/8) and peripherals in PD0 which are still active will see the bus clock (ULPCLK) change from 32 MHz to 4 MHz. - PD0 peripherals configured to run from LFCLK continue to run at 32 kHz. - All OPA modes can be used - The ADC will always see SYSOSC at 32 MHz for sampling - In STANDBY mode (STANDBY0 by default), the MCLK tree runs from LFCLK at 32 kHz and SYSOSC is disabled. PD0 peripherals running from the bus clock change to 32 kHz. PD0 peripherals running from LFCLK continue to run at 32 kHz with no change. #### 2.5.2 Leveraging MFCLK When running with the default PMCU configuration, timers and serial interfaces can select either the bus clock (MCLK/ULPCLK) or the LFCLK as their clock source. LFCLK is always 32 kHz in RUN, SLEEP, STOP, and STANDBY, but MCLK/ULPCLK changes to 4 MHz in STOP and to 32 kHz in STANDBY, meaning that peripherals running from the bus clock see their source clock frequency change when transitioning power modes. MFCLK, by contrast, works like LFCLK in that it provides a constant frequency clock source for peripherals across RUN, SLEEP, and STOP modes. MFCLK provides a constant 4 MHz as an alternative to LFCLK which runs at 32 kHz. The 4-MHz time base for MFCLK is always derived from SYSOSC. Peripherals, specifically PD0 peripherals which can be used in STOP mode, can select MFCLK as their clock source instead of ULPCLK. MFCLK will be maintained at 4 MHz in RUN, SLEEP and STOP, which is ideal for peripherals like UART, I2C, and low-power timers that need a consistent clock but require a clock source greater than 32 kHz. For information on using MFCLK, see the MFCLK section. #### 2.5.3 Optimizing Power Consumption in STOP Mode The STOP mode provides considerable flexibility for tailoring the device to an application's specific power and performance requirements. There are several options available for reducing power consumption in STOP mode: - Enable SYSOSC gear shift mode in STOP to reduce SYSOSC current. In STOP mode, the MCLK tree (and ULPCLK) are always limited to 4 MHz maximum. By default, SYSOSC runs in STOP mode at 32 MHz (base frequency) with a divide-by-8 to meet the 4-MHz max frequency limit in STOP mode. Alternatively, SYSOSC can be gear shifted to run natively at 4 MHz in STOP mode (STOP1), saving SYSOSC current. See SYSOSC gear shift mode. - If a 32-kHz clock is sufficient to run the needed peripherals, it is possible to run in STOP mode with MCLK sourced from LFCLK at 32 kHz. SYSOSC can be disabled to conserve power. To disable SYSOSC in STOP mode and run from LFCLK (STOP2), see disabling SYSOSC and operating mode selection. #### 2.5.4 Optimizing Power Consumption in STANDBY Mode In STANDBY mode, if only TIMG0, TIMG1, or asynchronous fast wake from GPIO, comparator (low-power mode), or a serial interface is desired, the lowest possible power consumption can be achieved by configuring the ULPCLK and LFCLK to be disabled when entering STANDBY, leaving only the TIMG0, and TIMG1 running (STANDBY1). See the LFCLK section. In this state, TIMG0, TIMG1, or asynchronous activity/event will trigger an asynchronous fast clock request to wake the system. #### 2.5.5 Optimizing for Lowest Wakeup Latency To ensure the lowest possible wakeup latency from STOP or STANDBY mode to RUN mode, set MCLK to SYSOSC with SYSOSC running at base frequency (32 MHz) before entering STOP or STANDBY. SYSOSC always starts at base frequency and latency is minimized if SYSOSC does not need to change to an alternate frequency. #### 2.5.6 Optimizing for Lowest Peak Current in RUN/SLEEP Mode In applications which are peak current limited, there are two options for reducing active current in RUN and SLEEP modes: - If 32 kHz provides sufficient performance, run MCLK from LFCLK. MCLK can be selected to run from LFCLK with SYSOSC disabled. If no fast handling of events is needed, SYSOSC asynchronous requests can be disabled to ensure that the device always runs from LFCLK. This provides the lowest possible current with the CPU still running (RUN2). See the MCLK, SYSOSC, and Operating Mode Selection sections. - If 32 kHz does not provide sufficient performance, MCLK can be selected to run from SYSOSC with SYSOSC set to low frequency (4 MHz). With MCLK running from SYSOSC, the MDIV divider for MCLK can be applied to reduce current consumption. For example, MCLK can be configured to run as low as 250kHz by setting MDIV to /16 when sourced from SYSOSC running at 4 MHz. See the MCLK section. #### 2.6 PMCU Registers The PMCU is configured through memory-mapped registers in SYSCTL which are device family specific, as not all device families have all features present. Use the relevant register map for a specific device family. #### 2.6.1 SYSCTL Registers Table 2-17 lists the memory-mapped registers for the SYSCTL registers. All register offset addresses not listed in Table 2-17 should be considered as reserved locations and the register contents should not be modified. **Table 2-17. SYSCTL Registers** | Offset | Acronym | Register Name | Section | |--------|----------------|-----------------------------------------------------|------------------| | 1020h | IIDX | SYSCTL interrupt index | Section 2.6.1.1 | | 1028h | IMASK | SYSCTL interrupt mask | Section 2.6.1.2 | | 1030h | RIS | SYSCTL raw interrupt status | Section 2.6.1.3 | | 1038h | MIS | SYSCTL masked interrupt status | Section 2.6.1.4 | | 1040h | ISET | SYSCTL interrupt set | Section 2.6.1.5 | | 1048h | ICLR | SYSCTL interrupt clear | Section 2.6.1.6 | | 1050h | NMIIIDX | NMI interrupt index | Section 2.6.1.7 | | 1060h | NMIRIS | NMI raw interrupt status | Section 2.6.1.8 | | 1070h | NMIISET | NMI interrupt set | Section 2.6.1.9 | | 1078h | NMIICLR | NMI interrupt clear | Section 2.6.1.10 | | 1100h | SYSOSCCFG | SYSOSC configuration | Section 2.6.1.11 | | 1104h | MCLKCFG | Main clock (MCLK) configuration | Section 2.6.1.12 | | 1138h | GENCLKCFG | General clock configuration | Section 2.6.1.13 | | 113Ch | GENCLKEN | General clock enable control | Section 2.6.1.14 | | 1140h | PMODECFG | Power mode configuration | Section 2.6.1.15 | | 1150h | FCC | Frequency clock counter (FCC) count | Section 2.6.1.16 | | 1170h | SYSOSCTRIMUSER | SYSOSC user-specified trim | Section 2.6.1.17 | | 1178h | SRAMBOUNDARY | SRAM Write Boundary | Section 2.6.1.18 | | 1180h | SYSTEMCFG | System configuration | Section 2.6.1.19 | | 1200h | WRITELOCK | SYSCTL register write lockout | Section 2.6.1.20 | | 1204h | CLKSTATUS | Clock module (CKM) status | Section 2.6.1.21 | | 1208h | SYSSTATUS | System status information | Section 2.6.1.22 | | 1220h | RSTCAUSE | Reset cause | Section 2.6.1.23 | | 1300h | RESETLEVEL | Reset level for application-triggered reset command | Section 2.6.1.24 | | 1304h | RESETCMD | Execute an application-triggered reset command | Section 2.6.1.25 | | 1308h | BORTHRESHOLD | BOR threshold selection | Section 2.6.1.26 | | 130Ch | BORCLRCMD | Set the BOR threshold | Section 2.6.1.27 | | 1310h | SYSOSCFCLCTL | SYSOSC frequency correction loop (FCL) ROSC enable | Section 2.6.1.28 | | 131Ch | SHDNIOREL | SHUTDOWN IO release control | Section 2.6.1.29 | | 1320h | EXRSTPIN | Disable the reset function of the NRST pin | Section 2.6.1.30 | | 1324h | SYSSTATUSCLR | Clear sticky bits of SYSSTATUS | Section 2.6.1.31 | | 1328h | SWDCFG | Disable the SWD function on the SWD pins | Section 2.6.1.32 | | 132Ch | FCCCMD | Frequency clock counter start capture | Section 2.6.1.33 | | 1380h | PMUOPAMP | GPAMP control | Section 2.6.1.34 | | 1400h | SHUTDNSTORE0 | Shutdown storage memory (byte 0) | Section 2.6.1.35 | | 1404h | SHUTDNSTORE1 | Shutdown storage memory (byte 1) | Section 2.6.1.36 | | 1408h | SHUTDNSTORE2 | Shutdown storage memory (byte 2) | Section 2.6.1.37 | | 140Ch | SHUTDNSTORE3 | Shutdown storage memory (byte 3) | Section 2.6.1.38 | | | | | | Complex bit access types are encoded to fit into small table cells. Table 2-18 shows the codes that are used for access types in this section. Table 2-18. SYSCTL Access Type Codes | Access Type | Code | Description | | | | |------------------------|-----------|----------------------------------------|--|--|--| | Read Type | Read Type | | | | | | R | R | Read | | | | | RC | R<br>C | Read<br>to Clear | | | | | Write Type | | | | | | | W | w | Write | | | | | W1C | W<br>1C | Write<br>1 to clear | | | | | W1S | W<br>1S | Write<br>1 to set | | | | | Reset or Default Value | | | | | | | -n | | Value after reset or the default value | | | | # 2.6.1.1 IIDX Register (Offset = 1020h) [Reset = X] IIDX is shown in Figure 2-11 and described in Table 2-19. Return to the Summary Table. SYSCTL interrupt index # Figure 2-11. IIDX Register Table 2-19. IIDX Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-2 | RESERVED | R | X | | | 1-0 | STAT | R | Oh | The SYSCTL interrupt index (IIDX) register generates a value corresponding to the highest priority pending interrupt source. This value may be used as an address offset for fast, deterministic handling in the interrupt service routine. A read of the IIDX register will clear the corresponding interrupt status in the RIS and MIS registers. 0h = No interrupt pending 1h = LFOSCGOOD interrupt pending 2h = 2 | # 2.6.1.2 IMASK Register (Offset = 1028h) [Reset = X] IMASK is shown in Figure 2-12 and described in Table 2-20. Return to the Summary Table. SYSCTL interrupt mask Figure 2-12. IMASK Register **Table 2-20. IMASK Register Field Descriptions** | Bit | Field | Туре | Reset | Description | |------|-----------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-2 | RESERVED | R/W | Х | | | 1 | ANACLKERR | R/W | 0h | Analog Clocking Consistency Error 0h = 0 1h = 1 | | 0 | LFOSCGOOD | R/W | Oh | Enable or disable the LFOSCGOOD interrupt. LFOSCGOOD indicates that the LFOSC has started successfully. 0h = Interrupt disabled 1h = Interrupt enabled | # 2.6.1.3 RIS Register (Offset = 1030h) [Reset = X] RIS is shown in Figure 2-13 and described in Table 2-21. Return to the Summary Table. SYSCTL raw interrupt status Figure 2-13. RIS Register #### Table 2-21. RIS Register Field Descriptions | | <b>-</b> | | | | | | | |------|-----------|------|-------|------------------------------------------------------------------------------------------|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | 31-2 | RESERVED | R | Х | | | | | | 1 | ANACLKERR | R | 0h | Analog Clocking Consistency Error 0h = 0 1h = 1 | | | | | 0 | LFOSCGOOD | R | Oh | Raw status of the LFOSCGOOD interrupt. 0h = No interrupt pending 1h = Interrupt pending | | | | # 2.6.1.4 MIS Register (Offset = 1038h) [Reset = X] MIS is shown in Figure 2-14 and described in Table 2-22. Return to the Summary Table. SYSCTL masked interrupt status Figure 2-14. MIS Register Table 2-22. MIS Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|-----------|------|-------|----------------------------------------------------------------------------------------------| | 31-2 | RESERVED | R | X | | | 1 | ANACLKERR | R | 0h | Analog Clocking Consistency Error 0h = 0 1h = 1 | | 0 | LFOSCGOOD | R | Oh | Masked status of the LFOSCGOOD interrupt. 0h = No interrupt pending 1h = Interrupt pending | # 2.6.1.5 ISET Register (Offset = 1040h) [Reset = X] ISET is shown in Figure 2-15 and described in Table 2-23. Return to the Summary Table. SYSCTL interrupt set # Figure 2-15. ISET Register # Table 2-23. ISET Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|-----------|------|-------|-------------------------------------------------------------------------------| | 31-2 | RESERVED | W | X | | | 1 | ANACLKERR | W1S | 0h | Analog Clocking Consistency Error 0h = 0 1h = 1 | | 0 | LFOSCGOOD | W1S | Oh | Set the LFOSCGOOD interrupt. 0h = Writing 0h hs no effect 1h = Set interrupt | # 2.6.1.6 ICLR Register (Offset = 1048h) [Reset = X] ICLR is shown in Figure 2-16 and described in Table 2-24. Return to the Summary Table. SYSCTL interrupt clear # Figure 2-16. ICLR Register # Table 2-24. ICLR Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|-----------|------|-------|-----------------------------------------------------------------------------------| | 31-2 | RESERVED | W | X | | | 1 | ANACLKERR | W1C | 0h | Analog Clocking Consistency Error 0h = 0 1h = 1 | | 0 | LFOSCGOOD | W1C | 0h | Clear the LFOSCGOOD interrupt. 0h = Writing 0h has no effect 1h = Clear interrupt | # 2.6.1.7 NMIIIDX Register (Offset = 1050h) [Reset = X] NMIIIDX is shown in Figure 2-17 and described in Table 2-25. Return to the Summary Table. NMI interrupt index # Figure 2-17. NMIIIDX Register Table 2-25. NMIIIDX Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-2 | RESERVED | R | Х | | | 1-0 | STAT | R | Oh | The NMI interrupt index (NMIIIDX) register generates a value corresponding to the highest priority pending NMI source. This value may be used as an address offset for fast, deterministic handling in the NMI service routine. A read of the NMIIIDX register will clear the corresponding interrupt status in the NMIRIS register. 0h = No NMI pending 1h = BOR Threshold NMI pending 2h = WWDT NMI pending | # 2.6.1.8 NMIRIS Register (Offset = 1060h) [Reset = X] NMIRIS is shown in Figure 2-18 and described in Table 2-26. Return to the Summary Table. NMI raw interrupt status Figure 2-18. NMIRIS Register Table 2-26. NMIRIS Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|-------------------------------------------------------------------------------| | 31-2 | RESERVED | R | X | | | 1 | WWDT0 | R | 0h | Watch Dog 0 Fault 0h = No interrupt pending 1h = Interrupt pending | | 0 | BORLVL | R | Oh | Raw status of the BORLVL NMI 0h = No interrupt pending 1h = Interrupt pending | # 2.6.1.9 NMIISET Register (Offset = 1070h) [Reset = X] NMIISET is shown in Figure 2-19 and described in Table 2-27. Return to the Summary Table. NMI interrupt set # Figure 2-19. NMIISET Register # Table 2-27. NMIISET Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|-------------------------------------------------------------------------| | 31-2 | RESERVED | W | X | | | 1 | WWDT0 | W1S | 0h | Watch Dog 0 Fault 0h = Writing 0h has no effect. 1h = Setting interrupt | | 0 | BORLVL | W1S | 0h | Set the BORLVL NMI 0h = Writing 0h hs no effect 1h = Set interrupt | # 2.6.1.10 NMIICLR Register (Offset = 1078h) [Reset = X] NMIICLR is shown in Figure 2-20 and described in Table 2-28. Return to the Summary Table. NMI interrupt clear # Figure 2-20. NMIICLR Register # Table 2-28. NMIICLR Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|-------------------------------------------------------------------------| | 31-2 | RESERVED | W | X | | | 1 | WWDT0 | W1C | 0h | Watch Dog 0 Fault 0h = Writing 0h has no effect 1h = Clearing interrupt | | 0 | BORLVL | W1C | Oh | Cir the BORLVL NMI 0h = Writing 0h hs no effect 1h = Clear interrupt | # 2.6.1.11 SYSOSCCFG Register (Offset = 1100h) [Reset = X] SYSOSCCFG is shown in Figure 2-21 and described in Table 2-29. Return to the Summary Table. SYSOSC configuration # Figure 2-21. SYSOSCCFG Register # Table 2-29. SYSOSCCFG Register Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|---------------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-18 | RESERVED | R/W | X | | | 17 | FASTCPUEVENT | R/W | 1h | FASTCPUEVENT may be used to assert a fast clock request when an interrupt is asserted to the CPU, reducing interrupt latency. 0h = An interrupt to the CPU will not assert a fast clock request 1h = An interrupt to the CPU will assert a fast clock request | | 16 | BLOCKASYNCALL | R/W | Oh | BLOCKASYNCALL may be used to mask block all asynchronous fast clock requests, preventing hardware from dynamically changing the active clock configuration when operating in a given mode. Oh = Asynchronous fast clock requests are controlled by the requesting peripheral 1h = All asynchronous fast clock requests are blocked | | 15-11 | RESERVED | R/W | X | | | 10 | DISABLE | R/W | 0h | DISABLE sets the SYSOSC enable/disable policy. SYSOSC may be powered off in RUN, SLEEP, and STOP modes to reduce power consumption. When SYSOSC is disabled, MCLK and ULPCLK are sourced from LFCLK. Oh = Do not disable SYSOSC 1h = Disable SYSOSC immediately and source MCLK and ULPCLK from LFCLK | | 9 | DISABLESTOP | R/W | 0h | DISABLESTOP sets the SYSOSC stop mode enable/disable policy. When operating in STOP mode, the SYSOSC may be automatically disabled. When set, ULPCLK will run from LFCLK in STOP mode and SYSOSC will be disabled to reduce power consumption. Oh = Do not disable SYSOSC in STOP mode 1h = Disable SYSOSC in STOP mode and source ULPCLK from LFCLK | | 8 | USE4MHZSTOP | R/W | 0h | USE4MHZSTOP sets the SYSOSC stop mode frequency policy. When entering STOP mode, the SYSOSC frequency may be automatically switched to 4MHz to reduce SYSOSC power consumption. Oh = Do not gear shift the SYSOSC to 4MHz in STOP mode 1h = Gear shift SYSOSC to 4MHz in STOP mode | # Table 2-29. SYSOSCCFG Register Field Descriptions (continued) | Bit | Field | Туре | Reset | Description | | | | |-----|----------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | 7-2 | RESERVED | R/W | Х | | | | | | 1-0 | FREQ | R/W | | Target operating frequency for the system oscillator (SYSOSC) 0h = Base frequency (32MHz) 1h = Low frequency (4MHz) 2h = User-trimmed frequency (16 or 24 MHz) 3h = Turbo frequency (48MHz) | | | | # 2.6.1.12 MCLKCFG Register (Offset = 1104h) [Reset = X] MCLKCFG is shown in Figure 2-22 and described in Table 2-30. Return to the Summary Table. Main clock (MCLK) configuration # Figure 2-22. MCLKCFG Register Table 2-30. MCLKCFG Register Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|-------------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-23 | RESERVED | R/W | X | 20004 | | 22 | MCLKDEADCHK | R/W | 0h | MCLKDEADCHK enables or disables the continuous MCLK dead check monitor. LFCLK must be running before MCLKDEADCHK is enabled. 0h = The MCLK dead check monitor is disabled 1h = The MCLK dead check monitor is enabled | | 21 | STOPCLKSTBY | R/W | 0h | STOPCLKSTBY sets the STANDBY mode policy (STANDBY0 or STANDBY1). When set, ULPCLK and LFCLK are disabled to all peripherals in STANDBY mode, with the exception of TIMG0 and TIMG1 which continue to run. Wake-up is only possible via an asynchronous fast clock request. Oh = ULPCLK/LFCLK runs to all PD0 peripherals in STANDBY mode 1h = ULPCLK/LFCLK is disabled to all peripherals in STANDBY mode except TIMG0 and TIMG1 | | 20 | USELFCLK | R/W | 0h | USELFCLK sets the MCLK source policy. Set USELFCLK to use LFCLK as the MCLK source. Note that setting USELFCLK does not disable SYSOSC, and SYSOSC remains available for direct use by analog modules. Oh = MCLK will not use the low frequency clock (LFCLK) 1h = MCLK will use the low frequency clock (LFCLK) | | 19-13 | RESERVED | R/W | X | | | 12 | USEMFTICK | R/W | 0h | USEMFTICK specifies whether the 4MHz constant-rate clock (MFCLK) to peripherals is enabled or disabled. When enabled, MDIV must be disabled (set to 0h=/1). Oh = The 4MHz rate MFCLK to peripherals is enabled 1h = The 4MHz rate MFCLK to peripherals is enabled. | | 11-8 | FLASHWAIT | R/W | 2h | FLASHWAIT specifies the number of flash wait states when MCLK is sourced from HSCLK. FLASHWAIT has no effect when MCLK is sourced from SYSOSC or LFCLK. Oh = No flash wait states are applied 1h = One flash wait state is applied 2h = 2 flash wait states are applied | # Table 2-30. MCLKCFG Register Field Descriptions (continued) | Bit | Field | Туре | Reset | Description | |-----|----------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7-4 | RESERVED | R/W | X | | | 3-0 | MDIV | R/W | | MDIV may be used to divide the MCLK frequency when MCLK is sourced from SYSOSC. MDIV=0h corresponds to /1 (no divider). MDIV=1h corresponds to /2 (divide-by-2). MDIV=Fh corresponds to /16 (divide-by-16). MDIV may be set between /1 and /16 on an integer basis. | # 2.6.1.13 GENCLKCFG Register (Offset = 1138h) [Reset = X] GENCLKCFG is shown in Figure 2-23 and described in Table 2-31. Return to the Summary Table. General clock configuration # Figure 2-23. GENCLKCFG Register # Table 2-31. GENCLKCFG Register Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|-------------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-29 | RESERVED | R/W | Х | | | 28-24 | FCCTRIGCNT | R/W | 0h | FCCTRIGCNT specifies the number of trigger clock periods in the trigger window. FCCTRIGCNT=0h (one trigger clock period) up to 1Fh (32 trigger clock periods) may be specified. | | 23-22 | ANACPUMPCFG | R/W | Oh | ANACPUMPCFG selects the analog mux charge pump (VBOOST) enable method. Oh = VBOOST is enabled on request from a COMP, GPAMP, or OPA 1h = VBOOST is enabled when the device is in RUN or SLEEP mode, or when a COMP/GPAMP/OPA is enabled 2h = VBOOST is always enabled | | 21 | FCCLVLTRIG | R/W | 0h | FCCLVLTRIG selects the frequency clock counter (FCC) trigger mode. 0h = Rising edge to rising edge triggered 1h = Level triggered | | 20 | FCCTRIGSRC | R/W | 0h | FCCTRIGSRC selects the frequency clock counter (FCC) trigger source. 0h = FCC trigger is the external pin 1h = FCC trigger is the LFCLK | | 19-16 | FCCSELCLK | R/W | Oh | FCCSELCLK selectes the frequency clock counter (FCC) clock source. 0h = FCC clock is MCLK 1h = FCC clock is SYSOSC 3h = FCC clock is the CLK_OUT selection 7h = FCC clock is the FCCIN external input | | 15-8 | RESERVED | R/W | X | | | 7 | EXCLKDIVEN | R/W | 0h | EXCLKDIVEN enables or disables the divider function of the CLK_OUT external clock output block. Oh = CLock divider is disabled (passthrough, EXCLKDIVVAL is not applied) 1h = Clock divider is enabled (EXCLKDIVVAL is applied) | # Table 2-31. GENCLKCFG Register Field Descriptions (continued) | Bit | Field | Туре | Reset | Description | |-----|-------------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 6-4 | EXCLKDIVVAL | R/W | Oh | EXCLKDIVVAL selects the divider value for the divider in the CLK_OUT external clock output block. 0h = CLK_OUT source is divided by 2 1h = CLK_OUT source is divided by 4 2h = CLK_OUT source is divided by 6 3h = CLK_OUT source is divided by 8 4h = CLK_OUT source is divided by 10 5h = CLK_OUT source is divided by 12 6h = CLK_OUT source is divided by 14 7h = CLK_OUT source is divided by 16 | | 3 | RESERVED | R/W | X | | | 2-0 | EXCLKSRC | R/W | Oh | EXCLKSRC selects the source for the CLK_OUT external clock output block. ULPCLK and MFPCLK require the CLK_OUT divider (EXCLKDIVEN) to be enabled 0h = CLK_OUT is SYSOSC 1h = CLK_OUT is ULPCLK (EXCLKDIVEN must be enabled) 2h = CLK_OUT is LFCLK (EXCLKDIVEN must be enabled) 3h = CLK_OUT is MFPCLK (EXCLKDIVEN must be enabled) | # 2.6.1.14 GENCLKEN Register (Offset = 113Ch) [Reset = X] GENCLKEN is shown in Figure 2-24 and described in Table 2-32. Return to the Summary Table. General clock enable control # Figure 2-24. GENCLKEN Register # **Table 2-32. GENCLKEN Register Field Descriptions** | | | | | <u> </u> | |------|----------|------|-------|-------------------------------------------------------------------------------------------------------------------------| | Bit | Field | Туре | Reset | Description | | 31-5 | RESERVED | R/W | Х | | | 4 | MFPCLKEN | R/W | 0h | MFPCLKEN enables the middle frequency precision clock (MFPCLK). 0h = MFPCLK is disabled 1h = MFPCLK is enabled | | 3-1 | RESERVED | R/W | Х | | | 0 | EXCLKEN | R/W | 0h | EXCLKEN enables the CLK_OUT external clock output block. 0h = CLK_OUT block is disabled 1h = CLK_OUT block is enabled | # 2.6.1.15 PMODECFG Register (Offset = 1140h) [Reset = X] PMODECFG is shown in Figure 2-25 and described in Table 2-33. Return to the Summary Table. Power mode configuration # Figure 2-25. PMODECFG Register Table 2-33. PMODECFG Register Field Descriptions | Table 2 00.1 Into B201 O Register 1 Total Besoriptions | | | | | | | |--------------------------------------------------------|---------------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Bit | Field | Туре | Reset | Description | | | | 31-6 | RESERVED | R/W | Х | | | | | 5 | SYSSRAMONSTOP | R/W | 0h | SYSSRAMONSTOP selects whether the SRAM controller is enabled or disabled in STOP mode. 0h = SRAM controller is disabled in STOP mode (lower power consumption) 1h = SRAM controller is left enabled in STOP mode (faster wake-up) | | | | 4-2 | RESERVED | R/W | X | | | | | 1-0 | DSLEEP | R/W | 0h | DSLEEP selects the operating mode to enter upon a DEEPSLEEP request from the CPU. 0h = STOP mode is entered 1h = STANDBY mode is entered 2h = SHUTDOWN mode is entered 3h = Reserved | | | # 2.6.1.16 FCC Register (Offset = 1150h) [Reset = X] FCC is shown in Figure 2-26 and described in Table 2-34. Return to the Summary Table. Frequency clock counter (FCC) count #### Figure 2-26. FCC Register # **Table 2-34. FCC Register Field Descriptions** | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|--------------------------------------------| | 31-22 | RESERVED | R | X | | | 21-0 | DATA | R | 0h | Frequency clock counter (FCC) count value. | # 2.6.1.17 SYSOSCTRIMUSER Register (Offset = 1170h) [Reset = X] SYSOSCTRIMUSER is shown in Figure 2-27 and described in Table 2-35. Return to the Summary Table. SYSOSC user-specified trim # Figure 2-27. SYSOSCTRIMUSER Register # Table 2-35. SYSOSCTRIMUSER Register Field Descriptions | Bit | Field | Туре | Reset | Description | | |-------|-----------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------|--| | 31-29 | RESERVED | R/W | X | | | | 28-20 | RDIV | R/W | 0h | RDIV specifies the frequency correction loop (FCL) resistor trim. This value changes with the target frequency. | | | 19-16 | RESFINE | R/W | 0h | RESFINE specifies the resister fine trim. This value changes with the target frequency. | | | 15-14 | RESERVED | R/W | X | | | | 13-8 | RESCOARSE | R/W | 0h | RESCOARSE specifies the resister coarse trim. This value changes with the target frequency. | | | 7 | RESERVED | R/W | Х | | | | 6-4 | CAP | R/W | 0h | CAP specifies the SYSOSC capacitor trim. This value changes with the target frequency. | | | 3-2 | RESERVED | R/W | X | | | | 1-0 | FREQ | R/W | 0h | FREQ specifies the target user-trimmed frequency for SYSOSC. 0h = Reserved 1h = 16MHz user frequency 2h = 24MHz user frequency 3h = Reserved | | # 2.6.1.18 SRAMBOUNDARY Register (Offset = 1178h) [Reset = X] SRAMBOUNDARY is shown in Figure 2-28 and described in Table 2-36. Return to the Summary Table. **SRAM Write Boundary** # Figure 2-28. SRAMBOUNDARY Register # Table 2-36. SRAMBOUNDARY Register Field Descriptions | | | | | <u>·</u> | |-------|----------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Field | Туре | Reset | Description | | 31-20 | RESERVED | R/W | Х | | | 19-5 | ADDR | R/W | 0h | SRAM boundary configuration. The value configured into this acts such that: SRAM accesses to addresses less than or equal value will be RW only. SRAM accesses to addresses greater than value will be RX only. Value of 0 is not valid (system will have no stack). If set to 0, the system acts as if the entire SRAM is RWX. Any non-zero value can be configured, including a value = SRAM size. | | 4-0 | RESERVED | R/W | X | | # 2.6.1.19 SYSTEMCFG Register (Offset = 1180h) [Reset = X] SYSTEMCFG is shown in Figure 2-29 and described in Table 2-37. Return to the Summary Table. System configuration # Figure 2-29. SYSTEMCFG Register # **Table 2-37. SYSTEMCFG Register Field Descriptions** | Bit | Field | Туре | Reset | Description | |-------|---------------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-24 | KEY | W | Oh | The key value of 1Bh (27) must be written to KEY together with contents to be updated. Reads as 0 1Bh = Issue write | | 23-1 | RESERVED | R/W | Х | | | 0 | WWDTLP0RSTDIS | R/W | 0h | WWDTLP0RSTDIS specifies whether a WWDT Error Event will trigger a BOOTRST or an NMI. 0h = WWDTLP0 Error Event will trigger a BOOTRST 1h = WWDTLP0 Error Event will trigger an NMI | # 2.6.1.20 WRITELOCK Register (Offset = 1200h) [Reset = X] WRITELOCK is shown in Figure 2-30 and described in Table 2-38. Return to the Summary Table. SYSCTL register write lockout # Figure 2-30. WRITELOCK Register # Table 2-38. WRITELOCK Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-1 | RESERVED | R/W | Х | | | 0 | ACTIVE | R/W | | ACTIVE controls whether critical SYSCTL registers are write protected or not. 0h = Allow writes to lockable registers 1h = Disallow writes to lockable registers | # 2.6.1.21 CLKSTATUS Register (Offset = 1204h) [Reset = X] CLKSTATUS is shown in Figure 2-31 and described in Table 2-39. Return to the Summary Table. Clock module (CKM) status # Figure 2-31. CLKSTATUS Register **Table 2-39. CLKSTATUS Register Field Descriptions** | Bit | Field | Туре | Reset | Description | |-------|-------------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 | ANACLKERR | R | 0h | ANACLKERR is set when the device clock configuration does not support an enabled analog peripheral mode and the analog peripheral may not be functioning as expected. Oh = No analog clock errors detected 1h = Analog clock error detected | | 30 | OPAMPCLKERR | R | Oh | OPAMPCLKERR is set when the device clock configuration does not support an enabled OPA mode and the OPA may not be functioning as expected. Oh = No OPA clock generation errors detected 1h = OPA clock generation error detected | | 29-26 | RESERVED | R | Х | | | 25 | FCCDONE | R | 0h | FCCDONE indicates when a frequency clock counter capture is complete. 0h = FCC capture is not done 1h = FCC capture is done | | 24 | FCLMODE | R | 0h | FCLMODE indicates if the SYSOSC frequency correction loop (FCL) is enabled. 0h = SYSOSC FCL is disabled 1h = SYSOSC FCL is enabled | | 23-18 | RESERVED | R | Х | | | 17 | CURMCLKSEL | R | 0h | CURMCLKSEL indicates if MCLK is currently sourced from LFCLK. 0h = MCLK is not sourced from LFCLK 1h = MCLK is sourced from LFCLK | | 16-12 | RESERVED | R | Х | | | 11 | LFOSCGOOD | R | 0h | LFOSCGOOD indicates when the LFOSC startup has completed and the LFOSC is ready for use. 0h = LFOSC is not ready 1h = LFOSC is ready | | 10-8 | RESERVED | R | X | | # Table 2-39. CLKSTATUS Register Field Descriptions (continued) | Bit | Field | Туре | Reset | Description | |-----|------------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7-6 | LFCLKMUX | R | Oh | LFCLKMUX indicates if LFCLK is sourced from the internal LFOSC, the low frequency crystal (LFXT), or the LFCLK_IN digital clock input. 0h = LFCLK is sourced from the internal LFOSC 1h = LFCLK is sourced from the LFXT (crystal) 2h = LFCLK is sourced from LFCLK_IN (external digital clock input) | | 5-2 | RESERVED | R | Х | | | 1-0 | SYSOSCFREQ | R | 0h | SYSOSCFREQ indicates the current SYSOSC operating frequency. 0h = SYSOSC is at base frequency (32MHz) 1h = SYSOSC is at low frequency (4MHz) 2h = SYSOSC is at the user-trimmed frequency (16 or 24MHz) 3h = Reserved | ## 2.6.1.22 SYSSTATUS Register (Offset = 1208h) [Reset = X] SYSSTATUS is shown in Figure 2-32 and described in Table 2-40. Return to the Summary Table. System status information ## Figure 2-32. SYSSTATUS Register ## Table 2-40. SYSSTATUS Register Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-30 | REBOOTATTEMPTS | R | 0h | REBOOTATTEMPTS indicates the number of boot attempts taken before the user application starts. | | 29-15 | RESERVED | R | Х | | | 14 | SHDNIOLOCK | R | Oh | SHDNIOLOCK indicates when IO is locked due to SHUTDOWN 0h = IO IS NOT Locked due to SHUTDOWN 1h = IO IS Locked due to SHUTDOWN | | 13 | SWDCFGDIS | R | Oh | SWDCFGDIS indicates when user has disabled the use of SWD Port<br>0h = SWD Port Enabled<br>1h = SWD Port Disabled | | 12 | EXTRSTPINDIS | R | 0h | EXTRSTPINDIS indicates when user has disabled the use of external reset pin 0h = External Reset Pin Enabled 1h = External Reset Pin Disabled | | 11-7 | RESERVED | R | Х | | | 6 | PMUIREFGOOD | R | 0h | PMUIREFGOOD is set by hardware when the PMU current reference is ready. 0h = IREF is not ready 1h = IREF is ready | | 5 | ANACPUMPGOOD | R | 0h | ANACPUMPGOOD is set by hardware when the VBOOST analog mux charge pump is ready. 0h = VBOOST is not ready 1h = VBOOST is ready | | 4 | BORLVL | R | 0h | BORLVL indicates if a BOR event occured and the BOR threshold was switched to BOR0 by hardware. 0h = No BOR violation occured 1h = A BOR violation occured and the BOR threshold was switched to BOR0 | # Table 2-40. SYSSTATUS Register Field Descriptions (continued) | Bit | Field | Туре | Reset | Description | | | | |-----|-----------------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | 3-2 | BORCURTHRESHOLD | R | 0h | BORCURTHRESHOLD indicates the active brown-out reset supply monitor configuration. 0h = Default minimum threshold; a BOR0- violation triggers a BOR 1h = A BOR1- violation generates a BORLVL interrupt 2h = A BOR2- violation generates a BORLVL interrupt 3h = A BOR3- violation generates a BORLVL interrupt | | | | | 1-0 | RESERVED | R | Х | | | | | # 2.6.1.23 RSTCAUSE Register (Offset = 1220h) [Reset = X] RSTCAUSE is shown in Figure 2-33 and described in Table 2-41. Return to the Summary Table. Reset cause # Figure 2-33. RSTCAUSE Register # Table 2-41. RSTCAUSE Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-5 | RESERVED | R | X | | | 4-0 | ID | RC | Oh | ID is a read-to-clear field which indicates the lowest level reset cause since the last read. 0h = No reset since last read 1h = POR- violation, SHUTDNSTOREx or PMU trim parity fault 2h = NRST triggered POR (>1s hold) 3h = Software triggered POR 4h = BOR0- violation 5h = SHUTDOWN mode exit 8h = Non-PMU trim parity fault 9h = Fatal clock failure Ch = NRST triggered BOOTRST (<1s hold) Dh = Software triggered BOOTRST Eh = WWDT0 violation 10h = BSL exit 11h = BSL entry 13h = WWDT1 violation 14h = Flash uncorrectable ECC error 15h = CPULOCK violation 1Ah = Debug triggered SYSRST 1Bh = Software triggered CPURST 1Dh = Software triggered CPURST | ## 2.6.1.24 RESETLEVEL Register (Offset = 1300h) [Reset = X] RESETLEVEL is shown in Figure 2-34 and described in Table 2-42. Return to the Summary Table. Reset level for application-triggered reset command ## Figure 2-34. RESETLEVEL Register Table 2-42. RESETLEVEL Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-3 | RESERVED | R/W | Х | | | 2-0 | LEVEL | R/W | Oh | LEVEL is used to specify the type of reset to be issued when RESETCMD is set to generate a software triggered reset. 0h = Issue a SYSRST (CPU plus peripherals only) 1h = Issue a BOOTRST (CPU, peripherals, and boot configuration routine) 2h = Issue a SYSRST and enter the boot strap loader (BSL) 3h = Issue a power-on reset (POR) 4h = Issue a SYSRST and exit the boot strap loader (BSL) | # 2.6.1.25 RESETCMD Register (Offset = 1304h) [Reset = X] RESETCMD is shown in Figure 2-35 and described in Table 2-43. Return to the Summary Table. Execute an application-triggered reset command ## Figure 2-35. RESETCMD Register ## Table 2-43. RESETCMD Register Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|------------------------------------------------------------------------------------------------------------| | 31-24 | KEY | W | 0h | The key value of E4h (228) must be written to KEY together with GO to trigger the reset. E4h = Issue reset | | 23-1 | RESERVED | W | Х | | | 0 | GO | W | Oh | Execute the reset specified in RESETLEVEL.LEVEL. Must be written together with the KEY. 1h = Issue reset | ## 2.6.1.26 BORTHRESHOLD Register (Offset = 1308h) [Reset = X] BORTHRESHOLD is shown in Figure 2-36 and described in Table 2-44. Return to the Summary Table. BOR threshold selection ## Figure 2-36. BORTHRESHOLD Register ## Table 2-44. BORTHRESHOLD Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-2 | RESERVED | R/W | X | | | 1-0 | LEVEL | R/W | 0h | LEVEL specifies the desired BOR threshold and BOR mode. 0h = Default minimum threshold; a BOR0- violation triggers a BOR 1h = A BOR1- violation generates a BORLVL interrupt 2h = A BOR2- violation generates a BORLVL interrupt 3h = A BOR3- violation generates a BORLVL interrupt | # 2.6.1.27 BORCLRCMD Register (Offset = 130Ch) [Reset = X] BORCLRCMD is shown in Figure 2-37 and described in Table 2-45. Return to the Summary Table. Set the BOR threshold ## Figure 2-37. BORCLRCMD Register ## Table 2-45. BORCLRCMD Register Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-24 | KEY | W | 0h | The key value of C7h (199) must be written to KEY together with GO to trigger the clear and BOR threshold change. C7h = Issue clear | | 23-1 | RESERVED | W | Х | | | 0 | GO | W | 0h | GO clears any prior BOR violation status indications and attempts to change the active BOR mode to that specified in the LEVEL field of the BORTHRESHOLD register. 1h = Issue clear | # 2.6.1.28 SYSOSCFCLCTL Register (Offset = 1310h) [Reset = X] SYSOSCFCLCTL is shown in Figure 2-38 and described in Table 2-46. Return to the Summary Table. SYSOSC frequency correction loop (FCL) ROSC enable # Figure 2-38. SYSOSCFCLCTL Register ## Table 2-46. SYSOSCFCLCTL Register Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|-----------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-24 | KEY | W | Oh | The key value of 2Ah (42) must be written to KEY together with SETUSEFCL to enable the FCL. 2Ah = Issue Command | | 23-1 | RESERVED | W | Х | | | 0 | SETUSEFCL | W | 0h | Set SETUSEFCL to enable the frequency correction loop in SYSOSC. Once enabled, this state is locked until the next BOOTRST. 1h = Enable the SYSOSC FCL | # 2.6.1.29 SHDNIOREL Register (Offset = 131Ch) [Reset = X] SHDNIOREL is shown in Figure 2-39 and described in Table 2-47. Return to the Summary Table. SHUTDOWN IO release control ## Figure 2-39. SHDNIOREL Register ## **Table 2-47. SHDNIOREL Register Field Descriptions** | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|----------------------------------------------------------------------------------------------------| | 31-24 | KEY | W | 0h | The key value 91h must be written to KEY together with RELEASE to set RELEASE. 91h = Issue command | | 23-1 | RESERVED | W | X | | | 0 | RELEASE | W | 0h | Set RELEASE to release the IO after a SHUTDOWN mode exit. 1h = Release IO | ## 2.6.1.30 EXRSTPIN Register (Offset = 1320h) [Reset = X] EXRSTPIN is shown in Figure 2-40 and described in Table 2-48. Return to the Summary Table. Disable the reset function of the NRST pin ## Figure 2-40. EXRSTPIN Register ## Table 2-48. EXRSTPIN Register Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-24 | KEY | W | Oh | The key value 1Eh must be written together with DISABLE to disable the reset function. 1Eh = Issue command | | 23-1 | RESERVED | W | X | | | 0 | DISABLE | W | 0h | Set DISABLE to disable the reset function of the NRST pin. Once set, this configuration is locked until the next POR. 0h = Reset function of NRST pin is enabled 1h = Reset function of NRST pin is disabled | # 2.6.1.31 SYSSTATUSCLR Register (Offset = 1324h) [Reset = X] SYSSTATUSCLR is shown in Figure 2-41 and described in Table 2-49. Return to the Summary Table. Clear sticky bits of SYSSTATUS ## Figure 2-41. SYSSTATUSCLR Register ## Table 2-49. SYSSTATUSCLR Register Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|-----------------------------------------------------------------------------------------------------------------| | 31-24 | KEY | W | 0h | The key value CEh (206) must be written to KEY together with ALLECC to clear the ECC state. CEh = Issue command | | 23-1 | RESERVED | W | X | | | 0 | ALLECC | W | 0h | Set ALLECC to clear all ECC related SYSSTATUS indicators. 1h = Clear ECC error state | ## 2.6.1.32 SWDCFG Register (Offset = 1328h) [Reset = X] SWDCFG is shown in Figure 2-42 and described in Table 2-50. Return to the Summary Table. Disable the SWD function on the SWD pins # Figure 2-42. SWDCFG Register ## Table 2-50. SWDCFG Register Field Descriptions | | | | | | <u> </u> | | | |--|-------|-------------|-------------------------------------------------------------------------------------------------------------------------------------|----|---------------------------------------------------------------------------------------------------------------------------------------|--|--| | | Bit | Field | Type Reset Description W Oh The key value 62h (98) must be written to be DISBALE to disable the SWD functions. 62h = Issue command | | Description | | | | | 31-24 | KEY | | | | | | | | 23-1 | ESERVED W X | | Х | | | | | | 0 | DISABLE | W | 0h | Set DISABLE to disable the SWD function on SWD pins, allowing the SWD pins to be used as GPIO. 1h = Disable SWD function on SWD pins | | | # 2.6.1.33 FCCCMD Register (Offset = 132Ch) [Reset = X] FCCCMD is shown in Figure 2-43 and described in Table 2-51. Return to the Summary Table. Frequency clock counter start capture ## Figure 2-43. FCCCMD Register ## **Table 2-51. FCCCMD Register Field Descriptions** | Bit | Field | Туре | Reset | Description | |-------|----------|------|----------------------------------------------------------------------------------|---------------------------------------------------------------------------| | 31-24 | KEY | W | Oh The key value 0Eh (14) must be written with GO to start a 0Eh = Issue command | | | 23-1 | RESERVED | W | Х | | | 0 | GO | W | 0h | Set GO to start a capture with the frequency clock counter (FCC). 1h = 1 | ## 2.6.1.34 PMUOPAMP Register (Offset = 1380h) [Reset = X] PMUOPAMP is shown in Figure 2-44 and described in Table 2-52. Return to the Summary Table. **GPAMP** control Figure 2-44. PMUOPAMP Register Table 2-52. PMUOPAMP Register Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|-------------|---------------------------------------------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-12 | RESERVED | RESERVED R/W X | | | | 11-10 | CHOPCLKMODE | R/W | 0h | CHOPCLKMODE selects the GPAMP chopping mode. 0h = Chopping disabled 1h = Normal chopping 2h = ADC Assisted chopping 3h = Reserved | | 9-8 | CHOPCLKFREQ | 0h = 16kHz<br>1h = 8kHz<br>2h = 4kHz<br>3h = 2kHz | | 1h = 8kHz<br>2h = 4kHz | | 7 | RESERVED | | | | | 6 | OUTENABLE | R/W | 0h | Set OUTENABLE to connect the GPAMP output signal to the GPAMP_OUT pin 0h = GPAMP_OUT signal is not connected to the GPAMP_OUT pin 1h = GPAMP_OUT signal is connected to the GPAMP_OUT pin | | 5-4 | RRI | R/W | 0h | RRI selects the rail-to-rail input mode. 0h = PMOS input pairs 1h = NMOS input pairs 2h = Rail-to-rail mode 3h = Rail-to-rail mode | | 3-2 | NSEL | R/W | 0h | NSEL selects the GPAMP negative channel input. 0h = GPAMP_OUT pin connected to negative channel 1h = GPAMP_IN- pin connected to negative channel 2h = GPAMP_OUT signal connected to negative channel 3h = No channel selected | | 1 | PCHENABLE | R/W | Oh | Set PCHENABLE to enable the positive channel input. 0h = Positive channel disabled 1h = GPAMP_IN+ connected to positive channel | | 0 | ENABLE | R/W | 0h | Set ENABLE to turn on the GPAMP. Oh = GPAMP is disabled 1h = GPAMP is enabled | # 2.6.1.35 SHUTDNSTORE0 Register (Offset = 1400h) [Reset = X] SHUTDNSTORE0 is shown in Figure 2-45 and described in Table 2-53. Return to the Summary Table. Shutdown storage memory (byte 0) ## Figure 2-45. SHUTDNSTORE0 Register ## Table 2-53. SHUTDNSTORE0 Register Field Descriptions | Bit | Field | ,, , | | Description | |-------|----------|------|----|-------------------------| | 31-10 | RESERVED | | | | | 7-0 | DATA | R/W | 0h | Shutdown storage byte 0 | ## 2.6.1.36 SHUTDNSTORE1 Register (Offset = 1404h) [Reset = X] SHUTDNSTORE1 is shown in Figure 2-46 and described in Table 2-54. Return to the Summary Table. Shutdown storage memory (byte 1) # Figure 2-46. SHUTDNSTORE1 Register ## Table 2-54. SHUTDNSTORE1 Register Field Descriptions | Bit | Field | Туре | Reset | Description | | |-------|----------|------|-------|-------------------------|--| | 31-10 | RESERVED | R/W | Х | | | | 7-0 | DATA | R/W | 0h | Shutdown storage byte 1 | | # 2.6.1.37 SHUTDNSTORE2 Register (Offset = 1408h) [Reset = X] SHUTDNSTORE2 is shown in Figure 2-47 and described in Table 2-55. Return to the Summary Table. Shutdown storage memory (byte 2) ## Figure 2-47. SHUTDNSTORE2 Register ## Table 2-55. SHUTDNSTORE2 Register Field Descriptions | Bit | Field Type Reset | | Reset | Description | |-------|------------------|--------------------------------|-------|-------------------------| | 31-10 | RESERVED | R/W | Х | | | 7-0 | DATA | R/W 0h Shutdown storage byte 2 | | Shutdown storage byte 2 | ## 2.6.1.38 SHUTDNSTORE3 Register (Offset = 140Ch) [Reset = X] SHUTDNSTORE3 is shown in Figure 2-48 and described in Table 2-56. Return to the Summary Table. Shutdown storage memory (byte 3) # Figure 2-48. SHUTDNSTORE3 Register ## Table 2-56. SHUTDNSTORE3 Register Field Descriptions | Bit | Field | Type Reset Description | | Description | |-------|----------|------------------------|----|-------------------------| | 31-10 | RESERVED | R/W | Х | | | 7-0 | DATA | R/W | 0h | Shutdown storage byte 3 | This page intentionally left blank. # Chapter 3 **CPU** The CPU subsystem (MCPUSS) includes the Arm Cortex-M0+ processor, the interrupt logic, and the prefetch and cache logic. | 3.1 Overview 166 3.2 Arm Cortex-M0+ CPU 166 3.3 Interrupts and Exceptions 170 3.4 CPU Peripherals 177 3.5 NVM Access Acceleration 178 | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 3.3 Interrupts and Exceptions 170 3.4 CPU Peripherals 177 3.5 NVM Access Acceleration 178 | | 3.4 CPU Peripherals 177 3.5 NVM Access Acceleration 178 | | 3.5 NVM Access Acceleration | | | | 3.6 Read-only Memory (ROM) | | 3.7 CPUSS Registers 180 | | 3.8 WUC Registers214 | ### 3.1 Overview The MSP CPU subsystem (MCPUSS) contains the central processing unit (CPU) itself along with its associated supporting logic and the read-only memory (ROM). The functional blocks which comprise the MCPUSS include: - The Arm Cortex-M0+ 32-bit CPU and its internal peripherals - · The CPU bus splitter/router - · The interrupt management logic and DEEPSLEEP entry/exit logic - The non-volatile memory system prefetch and cache logic - The CPU debug interface to the debug subsystem (DEBUGSS) - The read-only memory (ROM) used for the BCR and BSL The top level architecture of the MCPUSS is shown in Figure 3-1. Figure 3-1. MSPM0Lxx MCPUSS Top Level Diagram ### 3.2 Arm Cortex-M0+ CPU The MCPUSS contains an energy-efficient Arm Cortex-M0+ CPU implementing the Armv6-M instruction set architecture (ISA) with support for CPU clock speeds from 32 kHz to 32 MHz. The Cortex-M0+ is a Von Neumann style 32-bit processor with a 2-stage ultra-low power pipeline and a single-cycle access port to the GPIO registers for efficient GPIO manipulation. The Cortex-M0+ implementation on MSPM0Gxx devices has the following features: - Up to 32 MHz execution frequency - · Little-endian (least significant byte at lowest byte address location) - Support for 32-bit word instruction fetches www.ti.com CPU - Single cycle 32\*32 multiply instruction - · User and privileged execution modes - Integrated 24-bit system tick timer (SYSTICK) - Four hardware breakpoints and two hardware watchpoints for debug - Reset-all-register support - · Vector table offset support The Cortex-M0+ architecture enables excellent code density, deterministic interrupt handling, and upwards compatibility with other processor architectures in the Arm Cortex-M family. A general overview of the Arm Cortex-M0+ is given in this section to provide a basic understanding of the features of the processor. For detailed information on developing with the Arm Cortex-M0+ processor, refer to the Arm Cortex-M0+ Devices Generic User's Guide. ### 3.2.1 CPU Register File The Arm Cortex-M0+ processor instructions operate on registers in the CPU register file. The processor contains a register file consisting of 16 standard registers and 3 special registers as shown in Figure 3-2. Figure 3-2. CPU Registers ## **General Purpose Registers (R0-R12)** The processor provides 13 general purpose registers, R0-R12, for operating on data. Registers R0 to R7 (low registers) are accessible by all instructions which specify a general purpose register. Registers R8 to R12 (high registers) are not accessible by 16-bit instructions but are accessible by any 32-bit instructions which specify a general purpose register. ### **Stack Pointer Register (R13)** The stack pointer is contained in R13, and can contain the main stack pointer (MSP) or the process stack pointer (PSP). When the processor is running in handler mode, the main stack pointer (MSP) is always used. When the processor is running in thread mode, the MSP or the process stack pointer (PSP) can be used, depending on the configuration of the SPSEL bit in the CONTROL register. After a CPURST, the processor automatically and unconditionally fetches the default stack pointer from the first address of main flash (0x0000.0000) as the main stack pointer (MSP). ## Link Register (R14) R14 serves as the link register and contains the return value of function calls as well as exceptions. The link register must be set before being used as it is not reset to any known value. It is accessible in privileged and unprivileged mode. ## **Program Counter Register (R15)** The program counter register (R15) contains the address of the next instruction to be executed. The PC is accessible in privileged and unprivileged mode. After a CPURST, the processor automatically and unconditionally fetches the default PC from the second word of main flash (0x0000.0004). ### **Special Registers** Special registers include the program status register (PSR), the interrupt mask register (PRIMASK), and the control register (CONTROL). Special registers are typically accessed by using the CPS, MRS, and MSR system instructions. - Program Status Register (PSR): The PSR is a combination of the application status (APSR), interrupt status (IPSR), and execution status (EPSR) registers. Application software can access the PSR with MRS and MSR instructions, accessing either the complete PSR or a combination of one or more registers, with some restrictions. The PSR registers can be accessed with MRS and MSR instructions using the mnemonics given in Table 3-1. - The application status register (APSR) contains the N, Z, C, and V flags which are used by the processor to evaluate conditional branch instructions. These bits are located in BIT31, BIT30, BIT29, and BIT28 of the PSR, respectively. - The interrupt status register (IPSR) reports the current exception number for a currently executing exception when in handler mode. In thread mode it reads as zero. The processor ignores writes to this register. The exception number field is presented in from BIT0 to BIT5 of the PSR. - The execution status register (EPSR) contains the T bit (BIT24), which defines whether the processor is in Thumb state. This bit cannot be read or written by software, but it is used by the processor. - Interrupt Mask Register (PRIMASK): BIT0 of the PRIMASK register (PM) can be used to mask all interrupts to the processor which have configurable priority (see Section 3.3). This can be thought of as a global peripheral interrupt mask control. The processor ignores unprivileged writes to PRIMASK. Clearing PM to 0 enables interrupts. Setting PM to 1 disables interrupts. The CPS instruction can be used to change the PM bit value in the PRIMASK register. - Control Register (CONTROL): The control register can be used to define whether code executing in thread mode is privileged or unprivileged by clearing or setting the nPRIV bit (BIT0), respectively. It can also be used to select the stack pointer used in R13 as either the main stack pointer (MSP) or process stack pointer (PSP) www.ti.com CPU by clearing or setting the SPSEL bit (BIT1), respectively. A CPURST clears the CONTROL register to zero. The processor ignores unprivileged writes to the CONTROL register. The SPSEL stack pointer selection bit is updated by the processor automatically when entering and returning from exceptions. Note that software must implement an ISB barrier instruction after writing to CONTROL to ensure that any changes take effect before the next application instruction is executed by the processor. Table 3-1. Program Status Register (PSR) Access Mnemonics | Mnemonic | Subregisters Included | | | | |----------|-----------------------|--|--|--| | APSR | APSR | | | | | IPSR | IPSR | | | | | EPSR | EPSR | | | | | IAPSR | IPSR and APSR | | | | | EAPSR | EPSR and APSR | | | | | XPSR | APSR, IPSR, EPSR | | | | | IEPSR | IPSR and EPSR | | | | ### 3.2.2 Stack Behavior The Arm Cortex-M0+ processor implements a full descending stack protocol. The stack pointer register (SP) always indicates the location of the last stacked data. When new data is added to the call stack, the SP value is decremented and the data is written to the location indicated by the SP after being decremented. The Arm Cortex-M0+ supports managing two independent stacks with two pointers: the main stack (MSP) and the process stack (PSP). ### 3.2.3 Execution Modes and Privilege Levels The processor supports two primary modes of execution: - Thread mode (for executing application software) - Handler mode (for handling processor exceptions and peripheral interrupts) By default, the processor is in thread mode out of reset. If an exception is issued to the processor, the processor will handle the exception in handler mode and return to thread mode after handler execution is complete. Code running in thread mode can be configured as being privileged or unprivileged, based on the configuration of the processor's internal CONTROL register. Code running in handler mode always executes as privileged. In general, code which executes as privileged has complete control of the processor configuration, including control of the SysTick, NVIC, and SCB. Only privileged code can change the privilege level for code running in thread mode. Code that is executing in thread mode in an unprivileged state cannot access the previously mentioned resources (SysTick, NVIC, SCB). ## 3.2.4 Address Space and Supported Data Sizes MSPM0 devices implement a flat memory map with a 32-bit byte-addressable address space. Byte addresses are unsigned numbers ranging from zero to $2^{32}$ -1. ### **Address Space** The processor sees the address space as containing $2^{30}$ 32-bit words, with each word being word-aligned (4-byte aligned). Pointers are always 32 bits, and stack operations (for example, push, pop) increment the stack pointer by 4 addresses (4 bytes). Address calculations by the processor wrap around if they overflow or underflow the 32-bit memory space. Instruction fetches by the processor are always 16-bit half-word aligned. Data reads by the processor must be naturally aligned (for example, words must be word aligned, half words must be half-word aligned, etc.). ### **Supported Data Sizes** The processor supports 8-bit byte, 16-bit half-word, and 32-bit word data sizes. Signed and unsigned data is supported, and signed data is stored in CPU registers in 32-bit two's complement format. The Armv6-M instruction set does not provide native instructions supporting operations on 64-bit double-word data. Load operations from memory to a CPU register can be signed or unsigned when the data size is less than 32 bits. When loading unsigned half-word or byte data to a CPU register, the value is zero-extended to 32 bits automatically. When loading signed half-word or byte data to a CPU register, the value is sign-extended to 32 bits automatically. Stores from CPU registers to memory are sign agnostic. All instruction and data accesses use little endian byte order. ## 3.3 Interrupts and Exceptions Peripheral interrupt exceptions and system exceptions temporarily pause the processor's normal execution flow so that the processor can be used to handle an event. The following can cause interruption of normal execution flow: - A CPURST - A nonmaskable interrupt (NMI, software trigger or hardware error signal from SYSCTL) - · A fault exception in the system (HardFault) - · Execution of a supervisor call instruction (SVCall) - Setting of a pending supervisor service request (PendSV) - A SysTick exception - An enabled peripheral interrupt (IRQ) - · A breakpoint instruction (for debug) ### **Exception State** Each exception source to the processor will be in one of the below states at any given point in time: - **Inactive** (not active, not pending) - Pending (waiting to be serviced by the processor) - Active (actively being serviced by the processor) - Active and pending (actively being serviced by the processor when the same source generates another exception) ## **Exception Prioritization, Entry, and Exit** Exceptions are prioritized by the processor together with the nested vectored interrupt controller (NVIC). Each exception has either a fixed priority (reset, NMI, hard fault) or a configurable priority (SVCall, PendSV, SysTick, peripheral IRQs). Exceptions with configurable priority can be disabled by application software running in privileged mode. Exceptions with fixed priority cannot be disabled. The processor exception model supports preemption, tail-chaining, and late-arrival features to boost exception handling performance: - In the **preemption** case, if an exception of higher priority is pending when an exception of lower priority is executing, the higher priority exception will preempt the ongoing handler servicing the lower priority exception. - In the **tail-chaining** case, if a valid-for-entry exception is pending at the time of completion of an exception handler, then the application context is not restored from the stack and control is given immediately to the pending exception. - In the **late-arriving** case, if a higher priority exception occurs during entry to a lower priority exception, the higher priority exception will be serviced first after the processor state is saved to the stack. Once the higher priority exception handling is complete, the lower priority exception (which is still pending) is serviced based on the tail-chaining procedure. www.ti.com CPU An exception entry is issued if and when all of the following are true: - An exception is in a pending state - The priority of the pending exception is higher than the limit set by the exception mask register (PRIMASK) - The processor is currently in either thread mode (not servicing an exception) or the newly pending exception is higher priority than the exception which is currently being serviced (resulting in a preemption) Processor exceptions are vectored. When an exception occurs, the current processor state is pushed onto the stack which was active at the time of the event, and execution is vectored to the entry point address in the vector table corresponding to the exception which is to be processed. If the exception is tail-chained to a previous handler which has completed, then there is no need to push any state to the stack and the interrupt service routine can be vectored to immediately. Likewise, if the exception is higher priority than a previous exception which started entry but did not complete entry, then there is no need to save the context again (late arrival). Upon completion of an exception handler, if there is no exception pending which needs to be handled then the processor will pop the state from the stack and restore the processor to the previous state which it was in when the exception occurred. ### 3.3.1 Peripheral Interrupts (IRQs) Peripheral interrupt functionality is managed by several components on the device: - The nested vectored interrupt controller (NVIC) - One or more interrupt groups (INT\_GROUP) - The wake-up controller (WUC) MSPM0 devices include an Arm nested vectored interrupt controller (NVIC) with the Cortex-M0+ CPU for managing peripheral interrupts. The NVIC operation is tightly integrated with the processor and supports up to 32 native peripheral interrupt sources. In addition to the NVIC, interrupt grouping modules can be present on a device to enable interfacing of more than 32 peripheral interrupts to the NVIC. High-priority interrupt sources that might require preemption capability are mapped directly to the NVIC and behave like normal NVIC interrupts. Lower priority interrupt sources which do not commonly require preemption capability are mapped to an interrupt grouping module, the output of which is then mapped to the NVIC as a native NVIC interrupt source. This routing arrangement is shown in Figure 3-3. Figure 3-3. Peripheral Interrupt Hierarchy The wake-up controller (WUC) determines if the PD1 power domain (containing the processor) needs to be powered up to service a peripheral interrupt if the PD1 domain is powered down in STOP or STANDBY mode. ## 3.3.1.1 Nested Vectored Interrupt Controller (NVIC) The nested vectored interrupt controller (NVIC) is an industry-standard Arm component which interfaces peripheral interrupts (which are external to the processor) into the CPU. The NVIC supports connection of up to 32 native peripheral interrupt sources. The NVIC is configured through memory-mapped registers in the system private peripheral bus (PPB) region. See Table 3-2 for the list of NVIC registers. The software development kit (SDK) provided with the devices supports the standard Arm Cortex Microcontroller Software Interface Standard (CMSIS) register access definitions for the NVIC. Application software must use 32-bit aligned, word-size transactions when accessing any NVIC register. In addition to interfacing peripheral interrupts to the processor, the NVIC also supports programmable priority for each interrupt. ### **Enabling and Disabling Interrupts** Peripheral interrupt enables can be read, set, and cleared through the interrupt set-enable (ISER) and interrupt clear-enable (ICER) registers in the NVIC. The 32 interrupts are mapped to the ISER and ICER registers with interrupt zero in the BIT0 position (LSB) and interrupt 31 in the BIT31 position (MSB) of each register. To enable an interrupt, set the corresponding enable bit in the ISER register. Writing a '0' to ISER has no effect. It is possible to read the ISER register to determine which interrupts are enabled. Upon a read, a '1' indicates that an interrupt is enabled; a '0' indicates disabled. To disable an interrupt, set the corresponding enable bit in the ICER register. Writing a '0' to ICER has no effect. ### Note In addition to enabling a peripheral interrupt at the NVIC, it is generally necessary to also configure the interrupt configuration of the corresponding peripheral as well. Most peripherals have multiple interrupt sources, which are merged together in the peripheral to source a single NVIC interrupt. Masking of individual peripheral interrupts is done within the peripheral's interrupt management registers. In the event that an interrupt is disabled in the NVIC, if the interrupt is asserted by the corresponding peripheral then the NVIC interrupt will go to a pending state but the processor is not interrupted. If an interrupt is disabled when in an active state (when a handler is running) it will remain active until the exception handler returns or a reset occurs, but no further activations will happen. ### Note If a peripheral asserts an interrupt to the NVIC, but that peripheral's interrupt in the NVIC is disabled, the device may remain in a higher power mode than expected as the wake-up controller (WUC) is holding an event for the processor. To prevent this situation, ensure peripheral interrupts are masked at the peripheral directly, versus only masking interrupts at the NVIC. ### **Setting and Clearing Pending Interrupt Status** Pending interrupt status can be read, set, and cleared through the interrupt set-pending (ISPR) and interrupt clear-pending (ICPR) registers in the NVIC. The 32 interrupts are mapped to the ISPR and ICPR registers with interrupt zero in the BIT0 position (LSB) and interrupt 31 in the BIT31 position (MSB) of each register. To read if an interrupt is pending, read either the ISPR or the ICPR. Upon a read, a '1' indicates that an interrupt is pending; a '0' indicates not pending. To set an interrupt to a pending state through software, set the corresponding bit in the ISPR register. Writing a '0' to ISPR has no effect. To clear an interrupt pending state, set the corresponding bit in the ICPR register. Writing a '0' to ICPR has no effect. Note that if a peripheral interrupt condition is still present, the pending state will be set again by hardware even if it is cleared. ### **Setting Interrupt Priority** Interrupts on the NVIC have programmable priority. There are four priority levels possible. Priority is set by programming the eight IPRx registers in the NVIC. Each priority field is 8 bits in length, and the priority for 4 interrupts is configured per 32-bit register. The Arm Cortex-M0+ only implements the most significant 2 bits of each 8-bit priority field (giving the 4 priority levels). Lower priority values have higher priority. System exceptions (reset, NMI, hard fault) have fixed priorities of -3, -2, and -1, respectively. As such, these exceptions always have higher priority than peripheral interrupts. Peripheral interrupt priorities are programmable as 0, 64, 128, or 192, with 0 being highest priority and 192 being lowest priority. www.ti.com CPU If the processor is currently handling an exception, it can only be preempted by a higher priority exception. In the event that there are multiple exceptions in a pending state which all have the same priority level assigned, the exception with the lowest exception number is taken first. #### Note Application software must not change the priority of an interrupt while the corresponding interrupt is either active (being handled) or enabled. Doing so can result in unpredictable behavior. | Address | Register | CMSIS | Description | | |-------------|-----------|---------------|-------------------------------------|--| | 0xE000.E100 | NVIC_ISER | NVIC->ISER[0] | Interrupt set-enable register | | | 0xE000.E180 | NVIC_ICER | NVIC->ICER[0] | Interrupt clear-enable register | | | 0xE000.E200 | NVIC_ISPR | NVIC->ISPR[0] | Interrupt set-pending register | | | 0xE000.E280 | NVIC_ICPR | NVIC->ICPR[0] | Interrupt clear-pending register | | | 0xE000.E400 | NVIC_IPR0 | NVIC->IP[0] | Interrupt priority register (0-3) | | | 0xE000.E404 | NVIC_IPR1 | NVIC->IP[1] | Interrupt priority register (4-7) | | | 0xE000.E408 | NVIC_IPR2 | NVIC->IP[2] | Interrupt priority register (8-11) | | | 0xE000.E40C | NVIC_IPR3 | NVIC->IP[3] | Interrupt priority register (12-15) | | | 0xE000.E410 | NVIC_IPR4 | NVIC->IP[4] | Interrupt priority register (16-19) | | Interrupt priority register (20-23) Interrupt priority register (24-27) Interrupt priority register (28-31) Table 3-2. Arm Cortex-M0+ NVIC Registers ## 3.3.1.2 Interrupt Groups 0xE000.E414 0xE000.E418 0xE000.E41C **NVIC IPR5** **NVIC IPR6** NVIC\_IPR7 To support mapping of more than 32 peripheral interrupt sources to the NVIC, certain MSPM0 devices include interrupt grouping logic (INT\_GROUP) in the MCPUSS to combine several interrupts together to source one native NVIC interrupt. NVIC->IP[5] NVIC->IP[6] NVIC->IP[7] The INT\_GROUP interrupt grouping uses the MSPM0 event management register structure with the key difference being that all peripheral interrupt sources to the interrupt group are always unmasked (always enabled) such that no additional enable configuration is needed beyond the peripheral interrupt configuration and the NVIC configuration. The IMASK register itself is read-only and hardwired to enable all sources to the interrupt group. Figure 3-4 shows the INT\_GROUP structure. Figure 3-4. Interrupt Group (INT\_GROUP) Because no masking control is required, application software only needs to interface with the interrupt index (IIDX) register to efficiently handle a peripheral interrupt which is registered to the NVIC through an INT\_GROUP. Application software can read the IIDX register in the INT\_GROUP to determine and clear the highest priority pending peripheral interrupt in the group. A read to IIDX will return an index corresponding to the highest priority peripheral which set an interrupt. The read action will also simultaneously clear the RIS and MIS bits corresponding to the highest priority interrupt whose index was returned by the read. The value read from the IIDX register can then be used in a case statement, as shown below. ``` void GROUP HANDLER (void) switch(IIDX) case 0: // no IRQ pending break; // IRQ[0] case 1: do peripheral 1 ISR(); break; case 2: // IRO[1] do peripheral 2 ISR(); break; // out of range default: illegal(); ``` ### Usage Because peripheral interrupts that are grouped together into an INT\_GROUP source a single NVIC interrupt, it is not possible to have one peripheral interrupt in a group preempt the execution of an active handler for the interrupt group. For example, take the scenario where the WWDT0 interrupt request line and the PMCU interrupt request line are connected to INT\_GROUP0, and INT\_GROUP0 sources NVIC peripheral interrupt 0. If the WWDT0 interrupt is asserted, INT\_GROUP0 will assert an interrupt request to the NVIC. If no higher priority interrupt is active, the NVIC will vector the processor to the INT\_GROUP0 handler. Application software can then read the INT\_GROUP0 IIDX register to determine that it was the WWDT0 that triggered the INT\_GROUP0 interrupt on the NVIC, and software can jump to the WWDT0 handler function. If the PMCU asserts its interrupt line while the processor is still in handler mode servicing the WWDT0 function (which is really a part of the INT\_GROUP0 handler), the PMCU interrupt can not preempt the WWDT0 handler. When the WWDT0 handler completes, The INT\_GROUP0 handler will return. At that time, the processor will see that the INT\_GROUP0 request was asserted again (this time, due to the PMCU), and it will tail-chain a second entry to the interrupt handler. This time, application software will read the IIDX and determine that the PMCU was the cause of the INT\_GROUP0 interrupt being asserted to the NVIC. If there are two or more peripheral interrupts pending to a single interrupt group, software can set the priority with which the interrupts are handled by first reading the RIS or MIS register to test which peripheral interrupts are asserted, followed by executing the software-determined priority. Alternatively, if the interrupt index (IIDX) register is used, the interrupt group hardware will return the highest priority index based on the index order. ### 3.3.1.3 Wake Up Controller (WUC) The wake up controller (WUC) is responsible for monitoring for assertion of interrupts when the processor is powered down in the STOP or STANDBY operating mode. In these modes, the entire PD1 power domain is power gated, and as such, the processor and NVIC are not available to check for interrupts. The WUC retains a copy of which peripheral interrupt sources to the NVIC were enabled when the processor entered STOP or STANDBY mode. In the event that an enabled interrupt is issued, the WUC will handshake with the PMCU to bring the device out of STOP or STANDBY mode so that the CPU can service the interrupt. The WUC will capture the interrupt state and present it to the NVIC and processor when the processor is brought up, such that the processor will see the interrupt even if the raw interrupt status of the peripheral is removed before the processor finishes powering up to service the interrupt. The WUC requires no configuration by application software upon entry to or exit from low-power modes, and is transparent in its operation. ### 3.3.2 Interrupt and Exception Table MSPM0 devices share a common interrupt and exception mapping across devices. Specific devices can not implement all interrupt sources, but in the event that a peripheral is common to two devices, it will have the same mapping to the NVIC on both devices. www.ti.com CPU See the device-specific data sheet for a complete list of which interrupts a particular device supports. The Arm Cortex-M0+ interrupt vector table is 48 words long (192 bytes). The complete platform interrupt and exception table with vector table addresses is given in Table 3-3. Table 3-3. MSPM0 Platform Processor Interrupt and Exception Table | Exception<br>Number | NVIC<br>Number <sup>(1)</sup> | Priority Group | Exception or<br>Interrupt | Vector Table<br>Address | Vector Description | |---------------------|-------------------------------|----------------|---------------------------|-------------------------|------------------------------------------------------------| | - | - | - | - | 0x0000.0000 | Stack pointer | | 1 | - | -3 | Reset | 0x0000.0004 | Reset vector | | 2 | - | -2 | NMI | 0x0000.0008 | NMI handler | | 3 | - | -1 | Hard fault | 0x0000.000C | Hard fault handler | | 4 | - | - | Reserved | 0x0000.0010 | - | | 5 | - | - | Reserved | 0x0000.0014 | - | | 6 | - | - | Reserved | 0x0000.0018 | - | | 7 | - | - | Reserved | 0x0000.001C | - | | 8 | - | - | Reserved | 0x0000.0020 | - | | 9 | - | - | Reserved | 0x0000.0024 | - | | 10 | - | - | Reserved | 0x0000.0028 | - | | 11 | - | Selectable | SVCall | 0x0000.002C | Supervisor call handler | | 12 | - | - | Reserved | 0x0000.0030 | - | | 13 | - | - | Reserved | 0x0000.0034 | - | | 14 | - | Selectable | PendSV | 0x0000.0038 | Pended supervisor handler | | 15 | - | Selectable | SysTick | 0x0000.003C | SysTick handler | | 16 | 0 | Selectable | INT_GROUP0 | 0x0000.0040 | Combined peripheral group 0 handler (see INT_GROUP0 below) | | 17 | 1 | Selectable | INT_GROUP1 | 0x0000.0044 | Combined peripheral group 1 handler (see INT_GROUP1 below) | | 18 | 2 | Selectable | TIMG1 | 0x0000.0048 | Timer TIMG1 interrupt handler | | 19 | 3 | Selectable | Reserved | 0x0000.004C | - | | 20 | 4 | Selectable | ADC0 | 0x0000.0050 | ADC0 interrupt handler | | 21 | 5 | Selectable | Reserved | 0x0000.0054 | - | | 22 | 6 | Selectable | Reserved | 0x0000.0058 | - | | 23 | 7 | Selectable | Reserved | 0x0000.005C | - | | 24 | 8 | Selectable | Reserved | 0x0000.0060 | | | 25 | 9 | Selectable | SPI0 | 0x0000.0064 | SPI0 interrupt handler | | 26 | 10 | Selectable | Reserved | 0x0000.0068 | - | | 27 | 11 | Selectable | Reserved | 0x0000.006C | - | | 28 | 12 | Selectable | Reserved | 0x0000.0070 | - | | 29 | 13 | Selectable | UART1 | 0x0000.0074 | UART1 interrupt handler | | 30 | 14 | Selectable | Reserved | 0x0000.0078 | - | | 31 | 15 | Selectable | UART0 | 0x0000.007C | UART0 interrupt handler | | 32 | 16 | Selectable | TIMG0 | 0x0000.0080 | Timer TIMG0 interrupt handler | | 33 | 17 | Selectable | Reserved | 0x0000.0084 | - | | 34 | 18 | Selectable | TIMG2 | 0x0000.0088 | Timer TIMG2 interrupt handler | | 35 | 19 | Selectable | Reserved | 0x0000.008C | - | | 36 | 20 | Selectable | TIMG4 | 0x0000.0090 | Timer TIMG4 interrupt handler | | 37 | 21 | Selectable | Reserved | 0x0000.0094 | - | | 38 | 22 | Selectable | Reserved | 0x0000.0098 | - | | 39 | 23 | Selectable | Reserved | 0x0000.009C | - | | Exception<br>Number | NVIC<br>Number <sup>(1)</sup> | Priority Group | Exception or<br>Interrupt | Vector Table<br>Address | Vector Description | |---------------------|-------------------------------|----------------|---------------------------|-------------------------|------------------------| | 40 | 24 | Selectable | I2C0 | 0x0000.00A0 | I2C0 interrupt handler | | 41 | 25 | Selectable | I2C1 | 0x0000.00A4 | I2C1 interrupt handler | | 42 | 26 | Selectable | Reserved | 0x0000.00A8 | - | | 43 | 27 | Selectable | Reserved | 0x0000.00AC | - | | 44 | 28 | Selectable | Reserved | 0x0000.00B0 | - | | 45 | 29 | Selectable | Reserved | 0x0000.00B4 | - | | 46 | 30 | Selectable | Reserved | 0x0000.00B8 | - | | | 1 | | | | | Table 3-3. MSPM0 Platform Processor Interrupt and Exception Table (continued) DMA 0x0000.00BC DMA interrupt handler ## Non-Maskable Interrupt (NMI) 47 The CPU implements a non-maskable interrupt, which handles critical interrupts which must be serviced immediately by the processor. The NMI interrupt sources are managed by SYSCTL. See the corresponding NMI information in the SYSCTL section of the PMCU chapter. ### INT\_GROUP0 Peripheral Interrupt Group Selectable The INT\_GROUP0 peripheral interrupt group sources an interrupt to NVIC0 (exception 16) if any peripheral in the group has a pending interrupt. The peripheral interrupts mapped to INT\_GROUP0 are given in Table 3-4. Table 3-4. INT\_GROUP0 Interrupts | Priority | IIDX Index | Interrupt | Description | | |----------|------------|---------------|----------------------------------------------|--| | 0 | 1 | WWDT0 | WWDT0 interrupt handler | | | 1 | 2 | Reserved | - | | | 2 | 3 | DEBUGSS | Debug subsystem interrupt handler | | | 3 | 4 | FLASHCTL | Flash controller interrupt handler | | | 4 | 5 | WUC FSUB0 | Generic event subscriber 0 interrupt handler | | | 5 | 6 | WUC FSUB1 | Generic event subscriber 1 interrupt handler | | | 6 | 7 | PMCU (SYSCTL) | PMCU (system controller) interrupt handler | | | 7 | 8 | Reserved | - | | ## **INT\_GROUP1** Peripheral Interrupt Group The INT\_GROUP1 peripheral interrupt group sources an interrupt to NVIC1 (exception 17) if any peripheral in the group has a pending interrupt. The peripheral interrupts mapped to INT\_GROUP1 are given in Table 3-5. Table 3-5. INT GROUP1 Interrupts | Priority | IIDX Index | Interrupt | Description | | | |----------|------------|-----------|-------------------------|--|--| | 0 | 1 | GPIO0 | GPIO0 interrupt handler | | | | 1 | 2 | Reserved | - | | | | 2 | 3 | COMP0 | COMP0 interrupt handler | | | | 3 | 4 | Reserved | - | | | | 4 | 5 | Reserved | - | | | | 5 | 6 | Reserved | - | | | | 6 | 7 | Reserved | - | | | | | | | | | | <sup>(1)</sup> The NVIC number also indicates the relative interrupt priority if multiple NVIC interrupts have the same group priority. However, an interrupt will not preempt an active handler for another interrupt with the same group priority, even if the interrupt has a higher (numerically lower) NVIC position. For preemption to occur, the new interrupt must be configured to a higher priority group (numerically lower). www.ti.com CPU Table 3-5. INT\_GROUP1 Interrupts (continued) | Priority | IIDX Index | Interrupt | Description | |----------|------------|-----------|-------------| | 7 | 8 | Reserved | - | ## 3.3.3 Processor Lockup Scenario There are several exception conditions which can cause the processor to enter a lockup state. On MSPM0 devices, a processor lockup is considered a fatal fault which always triggers a SYSRST to clear the lockup condition and restart the system. A lockup state is entered by the processor if an SVC (supervisor call) or fault condition occurs while the processor is handling an exception with priority of -1 or higher (numerically lower). Such a fault is considered by the processor to be unexpected under normal operating conditions. The following examples are conditions that can trigger a lockup state in the processor: - The processor cannot fetch the stack pointer or reset vector at reset - · The processor cannot fetch the NMI vector - The processor cannot fetch the hard fault vector - A memory fault occurs when the processor is already handling an exception with priority of -1 or -2 (hard fault or NMI) - A supervisor call (SVC) occurs when the processor is already handling an exception with priority of -1 or -2 (hard fault or NMI) - A usage fault or undefined instruction is fetched when the processor is already handling an exception with priority of -1 or -2 (hard fault or NMI) - A BKPT instruction is executed when the processor is already handling an exception with priority of -1 or -2 (hard fault or NMI) ## 3.4 CPU Peripherals The Arm Cortex-M0+ includes tightly coupled peripherals for system timing and memory protection. ### 3.4.1 System Control Block (SCB) The system control block (SCB) provides system implementation information and system control functionality, as well as configuration, control, and reporting of processor exceptions. The SCB is configured through memory-mapped registers in the system private peripheral bus (PPB) region. See Table 3-6 for the list of SCB registers. The software development kit (SDK) provided with the devices supports the standard Arm Cortex Microcontroller Software Interface Standard (CMSIS) register access definitions for the SCB. Application software must use 32-bit aligned, word-size transactions when accessing any SCB register. Table 3-6. Arm Cortex-M0+ System Control Block Registers | Address | Register | CMSIS | Description | | |-------------|----------|-------------|--------------------------------------------------------------------------|--| | 0xE000.ED00 | CPUID | SCB->CPUID | CPUID Read-only register indicating the CPU type and revision | | | 0xE000.ED04 | ICSR | SCB->ICSR | Provides specific interrupt controls and state | | | 0xE000.ED08 | VTOR | SCB->VTOR | Used to specify the vector table offset from 0x0000.0000 | | | 0xE000.ED0C | AIRCR | SCB->AIRCR | Used to issue a CPU reset request (SYSRESETREQ) | | | 0xE000.ED10 | SCR | SCB->SCR | System control register, used to control low-power mode behavior | | | 0xE000.ED14 | CCR | SCB->CCR | Read-only register indicating behavior of the processor | | | 0xE000.ED1C | SHPR2 | SCB->SHP[2] | Used to configure the priority of the SVCall system handler | | | 0xE000.ED20 | SHPR3 | SCB->SHP[3] | Used to configure the priority of the SysTick and PendSV system handlers | | For detailed information on the system control block register configuration, see the SCB section of the Arm Cortex-M0+ devices generic user guide. ### 3.4.2 System Tick Timer (SysTick) The system tick timer (SysTick) is a tightly-coupled timer clocked by MCLK, which can be used for system time keeping. The SysTick is available in RUN and SLEEP modes but is not available for use in STOP, STANDBY, or SHUTDOWN modes. The SysTick is configured through memory-mapped registers in the system private peripheral bus (PPB) region. See Table 3-7 for the list of SysTick configuration registers. The software development kit (SDK) provided with the devices supports the standard Arm Cortex Microcontroller Software Interface Standard (CMSIS) register access definitions for the SysTick. The SysTick timer can be used in several different ways, including: - · As an RTOS timer which fires at a programmable rate (for example, 100Hz) and invokes a SysTick routine - A high-speed alarm timer - A simple counter used to measure time to completion and time used in an application - · A timeout counter to check that a routine has not timed out within a specified period The SysTick timer is a simple 24-bit down counter, which counts down from its reload value to zero. Upon reaching zero, SysTick will re-load the value programmed into the reload value register (SYST\_RVR) on the next clock cycle, and then again begin counting down to zero. A SysTick event is generated when the SysTick counter reaches zero, and which point the COUNTFLAG status flag will be set. Reading the SYST\_CSR register will clear the COUNTFLAG status bit. Writing to the current value register (SYST\_CVR) clears the register and the COUNTFLAG status but does not generate an interrupt to the CPU. Reading SYST\_CVR returns the counter value at time of access. | Address | Idress Register CMSIS Description | | Description | |-------------|-----------------------------------|-----------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------| | 0xE000.E010 | SYST_CSR | SysTick->CTRL | Control and status register, used to enable/disable SysTick and its related exception, and to check the COUNTFLAG status | | 0xE000.E014 | SYST_RVR | SysTick->LOAD Reload register used to program the counter reload value to set the interval in MCLK cycles | | | 0xE000.E018 | SYST_CVR | SysTick->VAL | Returns the current value of the SysTick counter; a write clears the counter to zero and clears COUNTFLAG in SYST_CSR | | 0xE000.E01C | SYST_CALIB | SysTick->CALIB | Not implemented | Table 3-7. SysTick Registers Application software must only use 32-bit word-aligned word accesses to the SysTick registers. To initialize the SysTick, follow the steps below: - Program the desired reload value (example: to generate a flag every 1000 MCLK cycles, program 999) to SYST\_RVR - 2. Clear the current value by writing to the SYST\_CVR register - 3. Program the SYST CSR register to enable SysTick ### Note The SysTick counter does not decrement when the CPU is halted for debug. ### 3.5 NVM Access Acceleration To improve CPU performance and minimize the impact of wait states when running the processor at speeds greater than the maximum zero-wait speed of the flash memory, a prefetch logic and cache is provided in the interface between the processor and the non-volatile flash memory system. ## 3.5.1 Prefetch The prefetch logic, when enabled, issues a new read to the flash memory in anticipation of the processor needing the next flash word. This minimizes or eliminates the impact of flash wait states for sequential code execution. www.ti.com CPU The prefetch logic is enabled by default. It can be disabled, if desired, by clearing the PREFETCH bit in the CTL local register of the MCPUSS. ### 3.5.2 Cache The cache, when enabled, stores instructions which were previously fetched from the flash memory. When the processor fetches a new instruction, the address of the fetch is checked by the cache to determine if any cache entries contain the desired data corresponding to the requested address. If the data exists in the cache, the contents of the corresponding cache line are returned to the processor with no wait states. The cache contains 2 64-bit lines (16 bytes). Running with the cache enabled primarily reduces wait states for small code loops by storing up to 8 instructions in the cache. The cache is enabled by default. It can be disabled, if desired, by clearing the ICACHE bit in the CTL local register of the MCPUSS. ## 3.6 Read-only Memory (ROM) The MCPUSS contains a read-only memory which contains the executable code for the boot configuration routine (BCR) and bootstrap loader (BSL). The ROM is active after a BOOTRST, or after a SYSRST with BSL entry/exit. The ROM is disabled automatically when the application is started and is not accessible by application software. # 3.7 CPUSS Registers Table 3-8 lists the memory-mapped registers for the CPUSS registers. All register offset addresses not listed in Table 3-8 should be considered as reserved locations and the register contents should not be modified. **Table 3-8. CPUSS Registers** | Offset | Acronym | Table 3-8. CPUSS Regi<br>Register Name | Group | Section | |--------|----------|----------------------------------------|--------------------|---------| | 10E0h | EVT_MODE | Event Mode | | Go | | 10FCh | DESC | Module Description | | Go | | 1100h | IIDX | Interrupt index | CPU_INT_GR<br>OUP0 | Go | | 1108h | IMASK | Interrupt mask | CPU_INT_GR<br>OUP0 | Go | | 1110h | RIS | Raw interrupt status | CPU_INT_GR<br>OUP0 | Go | | 1118h | MIS | Masked interrupt status | CPU_INT_GR<br>OUP0 | Go | | 1120h | ISET | Interrupt set | CPU_INT_GR<br>OUP0 | Go | | 1128h | ICLR | Interrupt clear | CPU_INT_GR<br>OUP0 | Go | | 1130h | IIDX | Interrupt index | CPU_INT_GR<br>OUP1 | Go | | 1138h | IMASK | Interrupt mask | CPU_INT_GR<br>OUP1 | Go | | 1140h | RIS | Raw interrupt status | CPU_INT_GR<br>OUP1 | Go | | 1148h | MIS | Masked interrupt status | CPU_INT_GR<br>OUP1 | Go | | 1150h | ISET | Interrupt set | CPU_INT_GR<br>OUP1 | Go | | 1158h | ICLR | Interrupt clear | CPU_INT_GR<br>OUP1 | Go | | 1160h | IIDX | Interrupt index | CPU_INT_GR<br>OUP2 | Go | | 1168h | IMASK | Interrupt mask | CPU_INT_GR<br>OUP2 | Go | | 1170h | RIS | Raw interrupt status | CPU_INT_GR<br>OUP2 | Go | | 1178h | MIS | Masked interrupt status | CPU_INT_GR<br>OUP2 | Go | | 1180h | ISET | Interrupt set | CPU_INT_GR<br>OUP2 | Go | | 1188h | ICLR | Interrupt clear | CPU_INT_GR<br>OUP2 | Go | | 1190h | IIDX | Interrupt index | CPU_INT_GR<br>OUP3 | Go | | 1198h | IMASK | Interrupt mask | CPU_INT_GR<br>OUP3 | Go | | 11A0h | RIS | Raw interrupt status | CPU_INT_GR<br>OUP3 | Go | | 11A8h | MIS | Masked interrupt status | CPU_INT_GR<br>OUP3 | Go | | 11B0h | ISET | Interrupt set | CPU_INT_GR<br>OUP3 | Go | **Table 3-8. CPUSS Registers (continued)** | Offset | Acronym | Register Name | Group | Section | |--------|---------|-------------------------|--------------------|---------| | 11B8h | ICLR | Interrupt clear | CPU_INT_GR<br>OUP3 | Go | | 11C0h | IIDX | Interrupt index | CPU_INT_GR<br>OUP4 | Go | | 11C8h | IMASK | Interrupt mask | CPU_INT_GR<br>OUP4 | Go | | 11D0h | RIS | Raw interrupt status | CPU_INT_GR<br>OUP4 | Go | | 11D8h | MIS | Masked interrupt status | CPU_INT_GR<br>OUP4 | Go | | 11E0h | ISET | Interrupt set | CPU_INT_GR<br>OUP4 | Go | | 11E8h | ICLR | Interrupt clear | CPU_INT_GR<br>OUP4 | Go | | 1300h | CTL | Prefetch/Cache control | | Go | Complex bit access types are encoded to fit into small table cells. Table 3-9 shows the codes that are used for access types in this section. Table 3-9. CPUSS Access Type Codes | | 100000 1,700 00000 | | | | | |------------------------|----------------------------------------|--|--|--|--| | Code | Description | | | | | | Read Type | | | | | | | R | Read | | | | | | | | | | | | | W | Write | | | | | | Reset or Default Value | | | | | | | | Value after reset or the default value | | | | | | | <b>Code</b> R | | | | | # 3.7.1 EVT\_MODE (Offset = 10E0h) [Reset = 00000001h] EVT\_MODE is shown in Figure 3-5 and described in Table 3-10. Return to the Summary Table. Event mode register. It is used to select whether each line is disabled, in software mode (software clears the RIS) or in hardware mode (hardware clears the RIS) Figure 3-5. EVT\_MODE ## Table 3-10. EVT\_MODE Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-2 | RESERVED | R | 0h | | | 1-0 | INT_CFG | R | 1h | Event line mode select 0h = The interrupt or event line is disabled. 1h = Event handled by software. Software must clear the associated RIS flag. 2h = Event handled by hardware. The hardware (another module) clears automatically the associated RIS flag. | ## 3.7.2 DESC (Offset = 10FCh) [Reset = 27110000h] DESC is shown in Figure 3-6 and described in Table 3-11. Return to the Summary Table. This register identifies the peripheral and its exact version. ### Figure 3-6. DESC ## Table 3-11. DESC Field Descriptions | Bit | Field | Туре | Reset | Description | | |-------|------------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | 31-16 | MODULEID | R | 2711h | Module identification contains a unique peripheral identification number. The assignments are maintained in a central database for all of the platform modules to ensure uniqueness. | | | 15-12 | FEATUREVER | R | 0h | Feature Set for the module *instance* | | | 11-8 | RESERVED | R | 0h | | | | 7-4 | MAJREV | R | 0h | Major rev of the IP | | | 3-0 | MINREV | R | 0h | Minor rev of the IP | | ## 3.7.3 IIDX (Offset = 1100h) [Reset = 00000000h] IIDX is shown in Figure 3-7 and described in Table 3-12. Return to the Summary Table. Interrupt index register. This read-only register provides the interrupt index of the pending interrupt with the highest priority. It also indicates if no interrupt is pending. The priority order is fixed: lower index equals higher priority. Alternatively to the use of IIDX, users can implement their own prioritization schemes using other registers that expose the full set of interrupts that have occurred. On each read, only one interrupt is indicated. On a read, the current interrupt (highest priority) is automatically cleared by the hardware and the corresponding interrupt flags in the RIS and MIS are cleared as well. After a read from the CPU (not from the debug interface), the register must be updated with the next highest priority interrupt or indicate that no interrupt is pending. Only interrupts which are selected via IMASK are indicated. ### Figure 3-7. IIDX #### Table 3-12. IIDX Field Descriptions | Table 4 121 H2X 1 fold 2 000 Hp. 1010 | | | | | | | |---------------------------------------|----------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Bit | Field | Туре | Reset | Description | | | | 31-8 | RESERVED | R | 0h | | | | | 7-0 | STAT | R | Oh | Interrupt index status 0h = No pending interrupt 1h = Interrupt 0 2h = Interrupt 1 3h = Interrupt 2 4h = Interrupt 3 5h = Interrupt 4 6h = Interrupt 5 7h = Interrupt 6 8h = Interrupt 7 | | | | | | | | | | | ## 3.7.4 IMASK (Offset = 1108h) [Reset = 000000FFh] IMASK is shown in Figure 3-8 and described in Table 3-13. Return to the Summary Table. Interrupt Mask. If a bit is set, then corresponding interrupt is un-masked. Un-masking the interrupt causes the raw interrupt to be visible in IIDX, as well as MIS." # Figure 3-8. IMASK ## Table 3-13. IMASK Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-8 | RESERVED | R | 0h | | | 7-0 | INT | R | FFh | Masks the corresponding interrupt 1h = Interrupt 0 2h = Interrupt 1 4h = Interrupt 2 8h = Interrupt 3 10h = Interrupt 4 20h = Interrupt 5 40h = Interrupt 6 80h = Interrupt 7 | ## 3.7.5 RIS (Offset = 1110h) [Reset = 00000000h] RIS is shown in Figure 3-9 and described in Table 3-14. Return to the Summary Table. Raw interrupt status. Reflects all pending interrupts, regardless of masking. The RIS register allows the user to implement a poll scheme. A flag set in this register can be cleared by writing 1 to the ICLR register bit even if the corresponding IMASK bit is not enabled. ### Figure 3-9. RIS #### Table 3-14. RIS Field Descriptions | | Table of the o | | | | | | | |------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | 31-8 | RESERVED | R | 0h | | | | | | 7-0 | INT | R | Oh | Raw interrupt status for INT 1h = Interrupt 0 2h = Interrupt 1 4h = Interrupt 2 8h = Interrupt 3 10h = Interrupt 4 20h = Interrupt 5 40h = Interrupt 6 80h = Interrupt 7 | | | | # 3.7.6 MIS (Offset = 1118h) [Reset = 00000000h] MIS is shown in Figure 3-10 and described in Table 3-15. Return to the Summary Table. Masked interrupt status. This is an AND of the IMASK and RIS registers. ## Figure 3-10. MIS ## Table 3-15. MIS Field Descriptions | Bit | Field | Туре | Reset | Description | | | |------|----------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | 31-8 | RESERVED | R | 0h | | | | | 7-0 | INT | R | Oh | Masked interrupt status for INT0 1h = Interrupt 0 2h = Interrupt 1 4h = Interrupt 2 8h = Interrupt 3 10h = Interrupt 4 20h = Interrupt 5 40h = Interrupt 6 80h = Interrupt 7 | | | ## 3.7.7 ISET (Offset = 1120h) [Reset = 00000000h] ISET is shown in Figure 3-11 and described in Table 3-16. Return to the Summary Table. Interrupt set. Allows interrupts to be set by software (useful in diagnostics and safety checks). Writing a 1 to a bit in ISET will set the event and therefore the related RIS bit also gets set. If the interrupt is enabled through the mask, then the corresponding MIS bit is also set. #### Figure 3-11. ISET #### **Table 3-16. ISET Field Descriptions** | | Table 6 Tel 1621 Flora 2 comparent | | | | | | | |------|------------------------------------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | 31-8 | RESERVED | W | 0h | | | | | | 7-0 | INT | W | | Sets INT in RIS register 1h = Interrupt 0 2h = Interrupt 1 4h = Interrupt 2 8h = Interrupt 3 10h = Interrupt 4 20h = Interrupt 5 40h = Interrupt 6 80h = Interrupt 7 | | | | ## 3.7.8 ICLR (Offset = 1128h) [Reset = 00000000h] ICLR is shown in Figure 3-12 and described in Table 3-17. Return to the Summary Table. Interrupt clear. Write a 1 to clear corresponding Interrupt. ### Figure 3-12. ICLR ## Table 3-17. ICLR Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-8 | RESERVED | W | 0h | | | 7-0 | INT | W | Oh | Clears INT in RIS register 1h = Interrupt 0 2h = Interrupt 1 4h = Interrupt 2 8h = Interrupt 3 10h = Interrupt 4 20h = Interrupt 5 40h = Interrupt 6 80h = Interrupt 7 | ## 3.7.9 IIDX (Offset = 1130h) [Reset = 00000000h] IIDX is shown in Figure 3-13 and described in Table 3-18. Return to the Summary Table. Interrupt index register. This read-only register provides the interrupt index of the pending interrupt with the highest priority. It also indicates if no interrupt is pending. The priority order is fixed: lower index equals higher priority. Alternatively to the use of IIDX, users can implement their own prioritization schemes using other registers that expose the full set of interrupts that have occurred. On each read, only one interrupt is indicated. On a read, the current interrupt (highest priority) is automatically cleared by the hardware and the corresponding interrupt flags in the RIS and MIS are cleared as well. After a read from the CPU (not from the debug interface), the register must be updated with the next highest priority interrupt or indicate that no interrupt is pending. Only interrupts which are selected via IMASK are indicated. ### Figure 3-13. IIDX ## Table 3-18. IIDX Field Descriptions | Table 6 for fibA filed Becompaigne | | | | | | | | |------------------------------------|----------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | 31-8 | RESERVED | R | 0h | | | | | | 7-0 | STAT | R | Oh | Interrupt index status 0h = No pending interrupt 1h = Interrupt 0 2h = Interrupt 1 3h = Interrupt 2 4h = Interrupt 3 5h = Interrupt 4 6h = Interrupt 5 7h = Interrupt 6 8h = Interrupt 7 | | | | ## 3.7.10 IMASK (Offset = 1138h) [Reset = 000000FFh] IMASK is shown in Figure 3-14 and described in Table 3-19. Return to the Summary Table. Interrupt Mask. If a bit is set, then corresponding interrupt is un-masked. Un-masking the interrupt causes the raw interrupt to be visible in IIDX, as well as MIS." ## Figure 3-14. IMASK ## Table 3-19. IMASK Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-8 | RESERVED | R | 0h | | | 7-0 | INT | R | FFh | Masks the corresponding interrupt 1h = Interrupt 0 2h = Interrupt 1 4h = Interrupt 2 8h = Interrupt 3 10h = Interrupt 4 20h = Interrupt 5 40h = Interrupt 6 80h = Interrupt 7 | ## 3.7.11 RIS (Offset = 1140h) [Reset = 00000000h] RIS is shown in Figure 3-15 and described in Table 3-20. Return to the Summary Table. Raw interrupt status. Reflects all pending interrupts, regardless of masking. The RIS register allows the user to implement a poll scheme. A flag set in this register can be cleared by writing 1 to the ICLR register bit even if the corresponding IMASK bit is not enabled. #### Figure 3-15. RIS #### Table 3-20. RIS Field Descriptions | Tubio o zarrito i inta pocomptiono | | | | | | | |------------------------------------|----------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Bit | Field | Туре | Reset | Description | | | | 31-8 | RESERVED | R | 0h | | | | | 7-0 | INT | R | Oh | Raw interrupt status for INT 1h = Interrupt 0 2h = Interrupt 1 4h = Interrupt 2 8h = Interrupt 3 10h = Interrupt 4 20h = Interrupt 5 40h = Interrupt 6 80h = Interrupt 7 | | | # 3.7.12 MIS (Offset = 1148h) [Reset = 00000000h] MIS is shown in Figure 3-16 and described in Table 3-21. Return to the Summary Table. Masked interrupt status. This is an AND of the IMASK and RIS registers. ## Figure 3-16. MIS ## **Table 3-21. MIS Field Descriptions** | | | | | · · · · · · · · · · · · · · · · · · · | |------|----------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Field | Туре | Reset | Description | | 31-8 | RESERVED | R | 0h | | | 7-0 | INT | R | Oh | Masked interrupt status for INT0 1h = Interrupt 0 2h = Interrupt 1 4h = Interrupt 2 8h = Interrupt 3 10h = Interrupt 4 20h = Interrupt 5 40h = Interrupt 6 80h = Interrupt 7 | ## 3.7.13 ISET (Offset = 1150h) [Reset = 00000000h] ISET is shown in Figure 3-17 and described in Table 3-22. Return to the Summary Table. Interrupt set. Allows interrupts to be set by software (useful in diagnostics and safety checks). Writing a 1 to a bit in ISET will set the event and therefore the related RIS bit also gets set. If the interrupt is enabled through the mask, then the corresponding MIS bit is also set. #### Figure 3-17. ISET #### **Table 3-22. ISET Field Descriptions** | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-8 | RESERVED | W | 0h | | | 7-0 | INT | W | | Sets INT in RIS register 1h = Interrupt 0 2h = Interrupt 1 4h = Interrupt 2 8h = Interrupt 3 10h = Interrupt 4 20h = Interrupt 5 40h = Interrupt 6 80h = Interrupt 7 | ## 3.7.14 ICLR (Offset = 1158h) [Reset = 00000000h] ICLR is shown in Figure 3-18 and described in Table 3-23. Return to the Summary Table. Interrupt clear. Write a 1 to clear corresponding Interrupt. ### Figure 3-18. ICLR # Table 3-23. ICLR Field Descriptions | | | . 1014 2 0001 ption0 | | | |------|----------|----------------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Field | Туре | Reset | Description | | 31-8 | RESERVED | W | 0h | | | 7-0 | INT | W | Oh | Clears INT in RIS register 1h = Interrupt 0 2h = Interrupt 1 4h = Interrupt 2 8h = Interrupt 3 10h = Interrupt 4 20h = Interrupt 5 40h = Interrupt 6 80h = Interrupt 7 | ## 3.7.15 IIDX (Offset = 1160h) [Reset = 00000000h] IIDX is shown in Figure 3-19 and described in Table 3-24. Return to the Summary Table. Interrupt index register. This read-only register provides the interrupt index of the pending interrupt with the highest priority. It also indicates if no interrupt is pending. The priority order is fixed: lower index equals higher priority. Alternatively to the use of IIDX, users can implement their own prioritization schemes using other registers that expose the full set of interrupts that have occurred. On each read, only one interrupt is indicated. On a read, the current interrupt (highest priority) is automatically cleared by the hardware and the corresponding interrupt flags in the RIS and MIS are cleared as well. After a read from the CPU (not from the debug interface), the register must be updated with the next highest priority interrupt or indicate that no interrupt is pending. Only interrupts which are selected via IMASK are indicated. ### Figure 3-19. IIDX # Table 3-24. IIDX Field Descriptions | | rabio o 241 libit i lota becompatione | | | | | | | |---|---------------------------------------|----------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | | Bit | Field | Туре | Reset | Description | | | | | 31-8 | RESERVED | R | 0h | | | | | - | 7-0 | STAT | R | Oh | Interrupt index status 0h = No pending interrupt 1h = Interrupt 0 2h = Interrupt 1 3h = Interrupt 2 4h = Interrupt 3 5h = Interrupt 4 6h = Interrupt 5 7h = Interrupt 6 8h = Interrupt 7 | | | ## 3.7.16 IMASK (Offset = 1168h) [Reset = 000000FFh] IMASK is shown in Figure 3-20 and described in Table 3-25. Return to the Summary Table. Interrupt Mask. If a bit is set, then corresponding interrupt is un-masked. Un-masking the interrupt causes the raw interrupt to be visible in IIDX, as well as MIS." ## Figure 3-20. IMASK ## Table 3-25. IMASK Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-8 | RESERVED | R | 0h | | | 7-0 | INT | R | FFh | Masks the corresponding interrupt 1h = Interrupt 0 2h = Interrupt 1 4h = Interrupt 2 8h = Interrupt 3 10h = Interrupt 4 20h = Interrupt 5 40h = Interrupt 6 80h = Interrupt 7 | ## 3.7.17 RIS (Offset = 1170h) [Reset = 00000000h] RIS is shown in Figure 3-21 and described in Table 3-26. Return to the Summary Table. Raw interrupt status. Reflects all pending interrupts, regardless of masking. The RIS register allows the user to implement a poll scheme. A flag set in this register can be cleared by writing 1 to the ICLR register bit even if the corresponding IMASK bit is not enabled. #### Figure 3-21. RIS #### Table 3-26. RIS Field Descriptions | | 14.5.0 0 201 14.0 1 10.4 20001.p.1.01.0 | | | | | | | |------|-----------------------------------------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | 31-8 | RESERVED | R | 0h | | | | | | 7-0 | INT | R | | Raw interrupt status for INT 1h = Interrupt 0 2h = Interrupt 1 4h = Interrupt 2 8h = Interrupt 3 10h = Interrupt 4 20h = Interrupt 5 40h = Interrupt 6 80h = Interrupt 7 | | | | ## 3.7.18 MIS (Offset = 1178h) [Reset = 00000000h] MIS is shown in Figure 3-22 and described in Table 3-27. Return to the Summary Table. Masked interrupt status. This is an AND of the IMASK and RIS registers. ### Figure 3-22. MIS ## Table 3-27. MIS Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-8 | RESERVED | R | 0h | | | 7-0 | INT | R | Oh | Masked interrupt status for INT0 1h = Interrupt 0 2h = Interrupt 1 4h = Interrupt 2 8h = Interrupt 3 10h = Interrupt 4 20h = Interrupt 5 40h = Interrupt 6 80h = Interrupt 7 | ## 3.7.19 ISET (Offset = 1180h) [Reset = 00000000h] ISET is shown in Figure 3-23 and described in Table 3-28. Return to the Summary Table. Interrupt set. Allows interrupts to be set by software (useful in diagnostics and safety checks). Writing a 1 to a bit in ISET will set the event and therefore the related RIS bit also gets set. If the interrupt is enabled through the mask, then the corresponding MIS bit is also set. #### Figure 3-23. ISET ### Table 3-28. ISET Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-8 | RESERVED | W | 0h | | | 7-0 | INT | W | Oh | Sets INT in RIS register 1h = Interrupt 0 2h = Interrupt 1 4h = Interrupt 2 8h = Interrupt 3 10h = Interrupt 4 20h = Interrupt 5 40h = Interrupt 6 80h = Interrupt 7 | ## 3.7.20 ICLR (Offset = 1188h) [Reset = 00000000h] ICLR is shown in Figure 3-24 and described in Table 3-29. Return to the Summary Table. Interrupt clear. Write a 1 to clear corresponding Interrupt. ### Figure 3-24. ICLR # Table 3-29. ICLR Field Descriptions | | | | 1014 2 000 1 pti 0 1 1 2 | | |------|----------|------|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Field | Туре | Reset | Description | | 31-8 | RESERVED | W | 0h | | | 7-0 | INT | W | Oh | Clears INT in RIS register 1h = Interrupt 0 2h = Interrupt 1 4h = Interrupt 2 8h = Interrupt 3 10h = Interrupt 4 20h = Interrupt 5 40h = Interrupt 6 80h = Interrupt 7 | ## 3.7.21 IIDX (Offset = 1190h) [Reset = 00000000h] IIDX is shown in Figure 3-25 and described in Table 3-30. Return to the Summary Table. Interrupt index register. This read-only register provides the interrupt index of the pending interrupt with the highest priority. It also indicates if no interrupt is pending. The priority order is fixed: lower index equals higher priority. Alternatively to the use of IIDX, users can implement their own prioritization schemes using other registers that expose the full set of interrupts that have occurred. On each read, only one interrupt is indicated. On a read, the current interrupt (highest priority) is automatically cleared by the hardware and the corresponding interrupt flags in the RIS and MIS are cleared as well. After a read from the CPU (not from the debug interface), the register must be updated with the next highest priority interrupt or indicate that no interrupt is pending. Only interrupts which are selected via IMASK are indicated. ### Figure 3-25. IIDX ## Table 3-30. IIDX Field Descriptions | Table 6 do: IIBX 1 loid becomptions | | | | | | | | |-------------------------------------|----------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | 31-8 | RESERVED | R | 0h | | | | | | 7-0 | STAT | R | Oh | Interrupt index status 0h = No pending interrupt 1h = Interrupt 0 2h = Interrupt 1 3h = Interrupt 2 4h = Interrupt 3 5h = Interrupt 4 6h = Interrupt 5 7h = Interrupt 6 8h = Interrupt 7 | | | | ## 3.7.22 IMASK (Offset = 1198h) [Reset = 000000FFh] IMASK is shown in Figure 3-26 and described in Table 3-31. Return to the Summary Table. Interrupt Mask. If a bit is set, then corresponding interrupt is un-masked. Un-masking the interrupt causes the raw interrupt to be visible in IIDX, as well as MIS." ## Figure 3-26. IMASK ## Table 3-31. IMASK Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-8 | RESERVED | R | 0h | | | 7-0 | INT | R | FFh | Masks the corresponding interrupt 1h = Interrupt 0 2h = Interrupt 1 4h = Interrupt 2 8h = Interrupt 3 10h = Interrupt 4 20h = Interrupt 5 40h = Interrupt 6 80h = Interrupt 7 | ## 3.7.23 RIS (Offset = 11A0h) [Reset = 00000000h] RIS is shown in Figure 3-27 and described in Table 3-32. Return to the Summary Table. Raw interrupt status. Reflects all pending interrupts, regardless of masking. The RIS register allows the user to implement a poll scheme. A flag set in this register can be cleared by writing 1 to the ICLR register bit even if the corresponding IMASK bit is not enabled. #### Figure 3-27. RIS #### Table 3-32. RIS Field Descriptions | 14010 0 021 1410 1 1014 2 0001 ption 0 | | | | | | | | |----------------------------------------|----------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | 31-8 | RESERVED | R | 0h | | | | | | 7-0 | INT | R | Oh | Raw interrupt status for INT 1h = Interrupt 0 2h = Interrupt 1 4h = Interrupt 2 8h = Interrupt 3 10h = Interrupt 4 20h = Interrupt 5 40h = Interrupt 6 80h = Interrupt 7 | | | | # 3.7.24 MIS (Offset = 11A8h) [Reset = 00000000h] MIS is shown in Figure 3-28 and described in Table 3-33. Return to the Summary Table. Masked interrupt status. This is an AND of the IMASK and RIS registers. ### Figure 3-28. MIS # **Table 3-33. MIS Field Descriptions** | Table & Got line 1 lots 2 Good parents | | | | | | | | |----------------------------------------|----------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | 31-8 | RESERVED | R | 0h | | | | | | 7-0 | INT | R | 0h | Masked interrupt status for INT0 1h = Interrupt 0 2h = Interrupt 1 4h = Interrupt 2 8h = Interrupt 3 10h = Interrupt 4 20h = Interrupt 5 40h = Interrupt 6 80h = Interrupt 7 | | | | ## 3.7.25 ISET (Offset = 11B0h) [Reset = 00000000h] ISET is shown in Figure 3-29 and described in Table 3-34. Return to the Summary Table. Interrupt set. Allows interrupts to be set by software (useful in diagnostics and safety checks). Writing a 1 to a bit in ISET will set the event and therefore the related RIS bit also gets set. If the interrupt is enabled through the mask, then the corresponding MIS bit is also set. #### Figure 3-29. ISET #### **Table 3-34. ISET Field Descriptions** | 14010 0 0 11 1011 1 1014 2 0 0 0 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | | | | | | |------------------------------------------------------------------|----------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Bit | Field | Туре | Reset | Description | | | | 31-8 | RESERVED | W | 0h | | | | | 7-0 | INT | W | | Sets INT in RIS register 1h = Interrupt 0 2h = Interrupt 1 4h = Interrupt 2 8h = Interrupt 3 10h = Interrupt 4 20h = Interrupt 5 40h = Interrupt 6 80h = Interrupt 7 | | | ## 3.7.26 ICLR (Offset = 11B8h) [Reset = 00000000h] ICLR is shown in Figure 3-30 and described in Table 3-35. Return to the Summary Table. Interrupt clear. Write a 1 to clear corresponding Interrupt. ### Figure 3-30. ICLR # Table 3-35. ICLR Field Descriptions | Table C College Total Decomposition | | | | | | | | |-------------------------------------|----------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | 31-8 | RESERVED | W | 0h | | | | | | 7-0 | INT | W | 0h | Clears INT in RIS register 1h = Interrupt 0 2h = Interrupt 1 4h = Interrupt 2 8h = Interrupt 3 10h = Interrupt 4 20h = Interrupt 5 40h = Interrupt 6 80h = Interrupt 7 | | | | ## 3.7.27 IIDX (Offset = 11C0h) [Reset = 00000000h] IIDX is shown in Figure 3-31 and described in Table 3-36. Return to the Summary Table. Interrupt index register. This read-only register provides the interrupt index of the pending interrupt with the highest priority. It also indicates if no interrupt is pending. The priority order is fixed: lower index equals higher priority. Alternatively to the use of IIDX, users can implement their own prioritization schemes using other registers that expose the full set of interrupts that have occurred. On each read, only one interrupt is indicated. On a read, the current interrupt (highest priority) is automatically cleared by the hardware and the corresponding interrupt flags in the RIS and MIS are cleared as well. After a read from the CPU (not from the debug interface), the register must be updated with the next highest priority interrupt or indicate that no interrupt is pending. Only interrupts which are selected via IMASK are indicated. ### Figure 3-31. IIDX ## Table 3-36. IIDX Field Descriptions | Table 6 60 HBX 1 lold 5000 lption6 | | | | | | | | | |------------------------------------|----------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | | 31-8 | RESERVED | R | 0h | | | | | | | 7-0 | STAT | R | Oh | Interrupt index status 0h = No pending interrupt 1h = Interrupt 0 2h = Interrupt 1 3h = Interrupt 2 4h = Interrupt 3 5h = Interrupt 4 6h = Interrupt 5 7h = Interrupt 6 8h = Interrupt 7 | | | | | ## 3.7.28 IMASK (Offset = 11C8h) [Reset = 000000FFh] IMASK is shown in Figure 3-32 and described in Table 3-37. Return to the Summary Table. Interrupt Mask. If a bit is set, then corresponding interrupt is un-masked. Un-masking the interrupt causes the raw interrupt to be visible in IIDX, as well as MIS." ## Figure 3-32. IMASK ## Table 3-37. IMASK Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-8 | RESERVED | R | 0h | | | 7-0 | INT | R | FFh | Masks the corresponding interrupt 1h = Interrupt 0 2h = Interrupt 1 4h = Interrupt 2 8h = Interrupt 3 10h = Interrupt 4 20h = Interrupt 5 40h = Interrupt 6 80h = Interrupt 7 | ## 3.7.29 RIS (Offset = 11D0h) [Reset = 00000000h] RIS is shown in Figure 3-33 and described in Table 3-38. Return to the Summary Table. Raw interrupt status. Reflects all pending interrupts, regardless of masking. The RIS register allows the user to implement a poll scheme. A flag set in this register can be cleared by writing 1 to the ICLR register bit even if the corresponding IMASK bit is not enabled. #### Figure 3-33. RIS #### Table 3-38. RIS Field Descriptions | | Table 6 del Title 1 lota Becomptions | | | | | | | | |------|--------------------------------------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | | 31-8 | RESERVED | R | 0h | | | | | | | 7-0 | INT | R | Oh | Raw interrupt status for INT 1h = Interrupt 0 2h = Interrupt 1 4h = Interrupt 2 8h = Interrupt 3 10h = Interrupt 4 20h = Interrupt 5 40h = Interrupt 6 80h = Interrupt 7 | | | | | # 3.7.30 MIS (Offset = 11D8h) [Reset = 00000000h] MIS is shown in Figure 3-34 and described in Table 3-39. Return to the Summary Table. Masked interrupt status. This is an AND of the IMASK and RIS registers. ### Figure 3-34. MIS ## Table 3-39. MIS Field Descriptions | Bit | Field | Туре | Reset | Description | | | | |------|----------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | 31-8 | RESERVED | R | 0h | | | | | | 7-0 | INT | R | 0h | Masked interrupt status for INT0 1h = Interrupt 0 2h = Interrupt 1 4h = Interrupt 2 8h = Interrupt 3 10h = Interrupt 4 20h = Interrupt 5 40h = Interrupt 6 80h = Interrupt 7 | | | | ## 3.7.31 ISET (Offset = 11E0h) [Reset = 00000000h] ISET is shown in Figure 3-35 and described in Table 3-40. Return to the Summary Table. Interrupt set. Allows interrupts to be set by software (useful in diagnostics and safety checks). Writing a 1 to a bit in ISET will set the event and therefore the related RIS bit also gets set. If the interrupt is enabled through the mask, then the corresponding MIS bit is also set. #### Figure 3-35. ISET #### **Table 3-40. ISET Field Descriptions** | | idalo o ionio in iona poconipalono | | | | | | | | |------|------------------------------------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | | 31-8 | RESERVED | W | 0h | | | | | | | 7-0 | INT | W | | Sets INT in RIS register 1h = Interrupt 0 2h = Interrupt 1 4h = Interrupt 2 8h = Interrupt 3 10h = Interrupt 4 20h = Interrupt 5 40h = Interrupt 6 80h = Interrupt 7 | | | | | # 3.7.32 ICLR (Offset = 11E8h) [Reset = 00000000h] ICLR is shown in Figure 3-36 and described in Table 3-41. Return to the Summary Table. Interrupt clear. Write a 1 to clear corresponding Interrupt. ### Figure 3-36. ICLR ## Table 3-41. ICLR Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-8 | RESERVED | W | 0h | | | 7-0 | INT | W | 0h | Clears INT in RIS register 1h = Interrupt 0 2h = Interrupt 1 4h = Interrupt 2 8h = Interrupt 3 10h = Interrupt 4 20h = Interrupt 5 40h = Interrupt 6 80h = Interrupt 7 | ## 3.7.33 CTL (Offset = 1300h) [Reset = 00000007h] CTL is shown in Figure 3-37 and described in Table 3-42. Return to the Summary Table. Flash prefetch and cache control register. Figure 3-37. CTL | | | | 9 | 07.0.0 | | | | |--------|----------|----------|------|--------|--------|--------|----------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | RESE | RVED | | | | | | R/W-0h | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | RESERVED | | | | | | | | R/W-0h | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | RESE | RVED | | | | | | | | R/V | V-0h | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | RESERVED | | | LITEN | ICACHE | PREFETCH | | | | R/W-0h | | | R/W-1h | R/W-1h | R/W-1h | # Table 3-42. CTL Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-3 | RESERVED | R/W | 0h | | | 2 | LITEN | R/W | 1h | Literal caching and prefetch enable. This bit is a subset of ICACHE/PREFETCH bit i.e. literal caching or literal prefetching will only happen if ICACHE or PREFETCH bits have been set respectively When enabled, the cache and prefetcher structures inside CPUSS will cache and prefetch literals When disabled, the cache and prefetcher structures inside CPUSS will not cache and prefetch literals 0h = Literal caching disabled 1h = Literal caching enabled | | 1 | ICACHE | R/W | 1h | Used to enable/disable Instruction caching on flash access. 0h = Disable instruction caching. 1h = Enable instruction caching. | | 0 | PREFETCH | R/W | 1h | Used to enable/disable instruction prefetch to Flash. 0h = Disable instruction prefetch. 1h = Enable instruction prefetch. | # 3.8 WUC Registers Table 3-43 lists the memory-mapped registers for the WUC registers. All register offset addresses not listed in Table 3-43 should be considered as reserved locations and the register contents should not be modified. ## Table 3-43. WUC Registers | Offset | Acronym | Register Name | Section | |--------|---------|-------------------|-----------------------------------------------------| | 400h | FSUB_0 | Subscriber Port 0 | FSUB_0 Register<br>(Offset = 400h)<br>[Reset = 00h] | | 404h | FSUB_1 | Subscriber Port 1 | FSUB_1 Register<br>(Offset = 404h)<br>[Reset = 00h] | ## 3.8.1 FSUB\_0 Register (Offset = 400h) [Reset = 00h] FSUB\_0 is shown in Figure 3-38 and described in Table 3-44. Return to the Summary Table. Subscriber port ### Figure 3-38. FSUB 0 Register | | | | | | | - | | _ | _ | | | | | | | |--------|----------|----|----|----|----|----|----|----|----|-----|------|------|----|----|----| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | RESERVED | | | | | | | | | | | | | | | | R/W-0h | | | | | | | | | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | RESERVED | | | | | | | | | | CHA | ANID | | | | | R/W-0h | | | | | | | | | | R/V | V-0h | | | | | | | | | | | | | | | | | | | | | | Table 3-44. FSUB\_0 Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-4 | RESERVED | R/W | 0h | | | 3-0 | CHANID | R/W | 1 | 0 = disconnected. 1-15 = connected to channel ID = CHANID. 0h = A value of 0 specifies that the event is not connected Fh = Consult your device data sheet as the actual allowed maximum can be less than 15. | ## 3.8.2 FSUB\_1 Register (Offset = 404h) [Reset = 00h] FSUB\_1 is shown in Figure 3-39 and described in Table 3-45. Return to the Summary Table. Subscriber port ### Figure 3-39. FSUB\_1 Register ## Table 3-45. FSUB\_1 Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-4 | RESERVED | R/W | 0h | | | 3-0 | CHANID | R/W | Oh | 0 = disconnected. 1-15 = connected to channel ID = CHANID. 0h = A value of 0 specifies that the event is not connected Fh = Consult your device data sheet as the actual allowed maximum can be less than15. | This page intentionally left blank. # Chapter 4 **DMA** The direct memory access (DMA) controller module transfers data from one address to another, without CPU intervention. This chapter describes the operation of the DMA controller. | 4.1 DMA Overview | 218 | |--------------------|-----| | 4.2 DMA Operation | | | 4.3 DMA Registers | | | TIO DINA I TOGISTO | | #### 4.1 DMA Overview The DMA controller transfers data from a source address to a destination address without CPU intervention. For example, the DMA controller can be used to move data from ADC conversion memory to SRAM. Devices can have up to sixteen DMA channels available. Therefore, depending on the number of DMA channels available, some features described in this chapter are not applicable to all devices. Please refer to the device-specific data sheet for the actual channel count of the DMA. Using the DMA controller can increase the throughput of peripheral modules. It can also reduce system power consumption by allowing the CPU to remain in a low-power mode, without having to awaken to move data to or from a peripheral. #### DMA controller features include: - Up to sixteen independent transfer channels - Configurable DMA channel priorities - Byte (8-bit), short word (16-bit), word (32-bit) and long word (64-bit) or mixed byte and word transfer capability - · Transfer counter block size supports up to 64k transfers of any data type - Configurable DMA transfer trigger selection - Six flexible addressing modes - · Single or block transfer modes The DMA controller block diagram is shown in Figure 4-1. Figure 4-1. DMA Block Diagram # 4.2 DMA Operation The DMA controller is configured with user software. The setup and operation of the DMA is discussed in the following sections. ## 4.2.1 Addressing Modes The DMA controller has six addressing modes. The addressing mode for each DMA channel is independently configurable. For example, channel 0 can transfer between two fixed addresses, while channel 1 transfers between two blocks of addresses. The addressing modes are shown in Figure 4-2. The addressing modes are: - 1. Fixed address to fixed address - 2. Fixed address to block of addresses - 3. Block of addresses to fixed address - 4. Block of addresses to block of addresses - 5. Fill data to block of addresses - 6. Data table to specific address Addressing modes 1-4 shown above are simply configured with the DMASRCINCR and DMADSTINCR control bits. The DMASRCINCR bits select if the source address is incremented, decremented, or unchanged after each transfer. The DMADSTINCR bits select if the destination address is incremented, decremented, or unchanged after each transfer. Addressing modes 5 and 6 shown above are also configured with the DMASRCINCR and DMADSTINCR control bits along with the help of additional parameters such as DMAEM for leveraging the extended modes of the DMA. Refer to Section 4.2.4.1 and Section 4.2.4.2 for more details on how to properly configure and use the DMA in Fill Mode and Table Mode. Transfers can be byte to byte, short word to short word, word to word, long word to long word, or any combination of the four. When transferring (short/long) word to byte, only the lower byte of the source data transfers. When transferring (long) word to short word, only the lower short word of the source data transfers. When transferring byte to (short/long) word, the upper byte(s) of the destination word is cleared when the transfer occurs. When transferring short word to (long) word, the upper short word is cleared when the transfer occurs. When transferring word to long word, the upper word is cleared. There is no packing or unpacking support by combining several source byte transfers to one single destination (short) word or the reverse. Figure 4-2. DMA Addressing Modes ## 4.2.2 Channel Types There are two types of DMA channels: basic (BASIC) and full-featured (FULL) channels. BASIC channels support only single or block transfers, and FULL channels support repeated single and repeated block transfers with additional features such as early interrupt request generation and extended table and fill modes. The highest priority DMA channels (starting with DMA0) are FULL channels, and the remaining priority channels are BASIC channels. Note Please see the device-specific data sheet to determine how many BASIC and FULL channels are available. Table 4-1 shows the features supported in basic and full-feature DMA channels. Table 4-1. Feature comparison of basic and full-feature DMA channels | DMA feature | Full-feature channel | Basic Channel | |-------------------------------------|----------------------|---------------| | Repeated mode | ✓ | - | | Early IRQ notification | ✓ | - | | Block burst mode | ✓ | <b>√</b> | | Stride mode | ✓ | ✓ | | Internal channel as trigger source | ✓ | <b>✓</b> | | Extended Mode (Table and Fill Mode) | <b>√</b> | - | #### 4.2.3 Transfer Modes The DMA controller has four transfer modes selected by the DMATM bits as listed in Table 4-2. Each channel is individually configurable for its transfer mode. For example, channel 0 can be configured in repeated block transfer mode, while channel 1 is configured for block transfer mode, and channel 2 operates in single transfer mode. The transfer mode is configured independently from the addressing mode. Any addressing mode can be used with any transfer mode. Four types of data can be transferred selectable by the DMADSTWDTH and DMASRCWDTH control bits. The source and destination locations can be either byte, short word, word, or long word data. It is also possible to transfer byte to byte, short word to short word, word to word, long word to long word, or any combination. Additionally, all transfers modes support a stride mode where the DMA source and destination can be incremented to a higher value to support re-organization of data. **Table 4-2. DMA Transfer Modes** | DMATM | Transfer Mode | Description | Channel Type | | | |-------|--------------------------|--------------------------------------------------------------------------------------------------------------------|--------------|--|--| | 0h | Single transfer | Each transfer requires a trigger. DMAEN is automatically cleared when DMASZx transfers have been made. | Basic | | | | 1h | Block transfer | A complete block is transferred with one trigger. DMAEN is automatically cleared at the end of the block transfer. | Basic | | | | 2h | Repeated single transfer | Each transfer requires a trigger. DMAEN remains enabled. | Full-feature | | | | 3h | Repeated block transfer | A complete block is transferred with one trigger. DMAEN remains enabled. | Full-feature | | | ## 4.2.3.1 Single Transfer In single transfer mode (DMATM = 0h), each byte, half-word, word, or long-word transfer requires a separate trigger. Single transfer mode is available in basic and full-feature DMA channels. The DMASZx register defines the number of transfers to be made. The DMADSTINCR and DMASRCINCR bits select if the destination address and the source address are incremented or decremented after each transfer. If DMASZx = 0, no transfers occur. The DMASAx, DMADAx, and DMASZx registers are incremented or decremented after each transfer. The DMADSTWDTH will indicate whether the destination address will increment or decrement by 1, 2, 4, or 8 with each transfer cycle. The same is true for the DMASRCWDTH and the source address respectively. When the DMASZx register decrements to zero, the corresponding RIS flag is set. The DMAEN bit is cleared automatically when DMASZx decrements to zero and must be set again for another transfer to occur. #### 4.2.3.2 Block Transfer In block transfer mode (DMATM = 1h), a transfer of a complete block of data occurs after one trigger. Block transfer mode is available in basic DMA channels only. The DMASZx register defines the size of the block, and the DMADSTINCR and DMASRCINCR bits select if the destination address and the source address are incremented or decremented after each transfer of the block. If DMASZx = 0, no transfers occur. The DMASAx, DMADAx, and DMASZx registers are copied into temporary registers. The temporary values of DMASAx and DMADAx are incremented or decremented after each transfer in the block. The DMADSTWDTH will indicate whether the destination address will increment or decrement by 1, 2, 4 or 8 with each transfer cycle. The same is true for the DMASRCWDTH and the source address respectively. The DMASZx register is decremented after each transfer of the block and shows the number of transfers remaining in the block. When DMATM = 01, the DMAEN bit is cleared automatically when DMASZx decrements to zero and must be set again for another transfer to occur. The DMAEN bit is cleared after the completion of the block transfer and must be set again before another block transfer can be triggered. After a block transfer has started, another trigger signal that occurs during the block transfer is ignored. #### 4.2.3.3 Repeated Single Transfer In repeated single transfer mode (DMATM = 2h), the DMA controller remains enabled with DMAEN = 1, and a transfer occurs every time a trigger occurs. Repeated single transfer modes are available in full-featured DMA channels only. The DMASAx, DMADAx, and DMASZx registers are copied into temporary registers. The temporary values of DMASAx and DMADAx are incremented or decremented after each transfer. The DMASZx register is decremented after each register. The DMADSTWDTH will indicate whether the destination address will increment or decrement by 1, 2, 4, or 8 with each transfer cycle. The same is true for the DMASRCWDTH and the source address respectively. When the DMASZx register decrements to zero, it is reloaded from its temporary register and the corresponding RIS flag is set. #### Note When using repeated single transfer mode, the DMA does not support pausing and continuing a transfer by disabling a channel (to pause) and then re-enabling the channel (to continue). ## 4.2.3.4 Repeated Block Transfer In repeated block transfer mode (DMATM = 11), the DMAEN bit remains set after completion of the block transfer. The next trigger after the completion of a repeated block transfer starts another block transfer. Repeated block transfer modes are available in full-featured DMA channels only. The DMASAx, DMADAx, and DMASZx registers are copied into temporary registers. The temporary values of DMASAx and DMADAx are incremented or decremented after each transfer in the block. The DMADSTWDTH will indicate whether the destination address will increment or decrement by 1, 2, 4 or 8 with each transfer cycle. The same is true for the DMASRCWDTH and the source address respectively. The DMASZx register is decremented after each transfer of the block and shows the number of transfers remaining in the block. #### 4.2.3.5 Stride Mode All transfer modes support a "stride" mode where the DMA source and destination can be incremented to a higher value (rather than +1) after a transfer. This is helpful for re-organizing the order of data between the source and destination. To support incremental strides, set the DMADSTINCR and/or DMASRCINCR to STRIDE\_n, where n is the number of destination and/or source increments. The real increments are based in terms of the definitions DMADSTWDTH and/or DMASRCWDTH, respectively. For example, if external ADC data is transmitted to the MCU as a six-word SPI frame, DMADSTINCR can be set to STRIDE\_6 during a block transfer so that the destination address is incremented by 6 and the data is organized to make processing easier. #### 4.2.4 Extended Modes In FULL channels, the DMA controller has two extended modes selected by the DMAEM bits as listed in Table 4-3. Each channel is individually configurable for the extended mode. For example, channel 0 can be configured in table mode while channel 1 is configured in fill mode. DMAEM Extended Mode Description 00 , 01 Normal mode Operation is defined by DMATM 10 Fill mode Used to fill predefined data patterns into memory 11 Table mode Used to help configure a table of peripheral control registers **Table 4-3. DMA Extended Modes** #### 4.2.4.1 Fill Mode In fill mode (DMAEM = 10b), the DMA controller takes a predefined FILL pattern and writes the pattern to a user defined segment of memory. The DMATM bits are ignored and the automatic transfer mode used is "block transfer". The DMASAx register is used as the FILL pattern data. The DMASRCINCR bit field is used to indicate whether the FILL pattern data should be constant or incremented/decremented with every write cycle. This feature allows for filling a memory block with a sequential pattern (for example. 0, 1, 2, 3, ...). The DMASRCWDTH bit field indicates the magnitude of increment of the FILL mode data. Refer to Table 4-4 for how to use DMASRCWDTH in fill mode. | DMASRCWDTH | FILL Mode Data Increment Value | | | | |------------|--------------------------------|--|--|--| | 0 | ±1 | | | | | 1 | ±2 | | | | | 2 | ±4 | | | | | 3 | ±8 | | | | Table 4-4. DMASRCWDTH in Fill Mode The destination registers and bit fields DMADAx, DMADSTINCR, and DMADSTWDTH all behave as expected and influence where and how in memory the FILL pattern is written. #### 4.2.4.2 Table Mode In table mode (DMAEM = 11b), the DMA controller executes 2 reads from the source and one write to a determined destination. This feature can be leveraged to interpret a table of addresses and data and uses the DMA to efficiently program that data to their associated addresses without CPU intervention. Table mode allows you to parse through a table of addresses and data to configure peripheral memory mapped registers in a single block transfer. The DMASRCWDTH bit field should be set to "3" (64-bit mode) and the DMADSTWDTH bit field should be set to "2" (32-bit mode). The DMASRCINCR bit field can be set to 10b to decrement the source address or 11b to increment the source address after transfers. DMASZ is set to represent the number of entries in the table and DMATM should be set to "01" for block transfer mode. DMADAx and DMADSTINCR are ignored in table mode and can be treated as "don't care" values. The DMASAx register needs to be programmed with the start address of the table, which needs to be aligned to 64-bit data (that is, DMASAx[2:0] = "000"). The address stored in the table needs to be on the lower word of a 64-bit data (ADDR[2:0] = "000" while the data needs to be on the upper word of a 64-bit data (ADDR[2:0] = "100"). Table 4-5 is an example of a table in memory compatible with the DMA table mode. | Table 4-5. Example of all informental Table Compatible with DMA Table Mode | | | | | |----------------------------------------------------------------------------|------------|--|--|--| | Table Address | Table Data | | | | | 0x0000 | Address 0 | | | | | 0x0004 | Data 0 | | | | | 0x0008 | Address 1 | | | | | 0x000C | Data 1 | | | | Table 4-5. Example of an Incremental Table Compatible with DMA Table Mode ## 4.2.5 Initiating DMA Transfers Each DMA channel is independently configured for its trigger source with DMATSEL. The DMATSEL bits should be modified only when the DMACTLx.DMAEN bit is 0; otherwise, unpredictable DMA triggers can occur. See the device-specific data sheet for the list of triggers available, along with their respective DMATSEL values. When selecting the trigger, the trigger must not have already occurred, or the transfer does not take place. DMA channels can be internally triggered upon the completion of activity on another channel to support cascading. Completion of activity occurs when a DMA channel's DMASZ counter reaches zero. This is beneficial for applications where data can be retrieved, transferred, and/or error-checked without an interrupt or event configuration. Set the DMATINT bit to internally trigger the next DMA channel based on the DMATSEL trigger source. Once the DMATSEL trigger occurs, the next DMA channel begins to automatically execute. For example, if UART data is received and transmitted to SRAM through DMA channel 0 and DMATSEL is set to UART RX, then DMA channel 1 can be internally triggered when the UART is finished receiving data. If DMA channel 1 is configured to transmit the data from SRAM to CRC, then the DMA transfer will trigger once the UART data is received. In this case, the DMA channels are cascaded from Channel 0 to Channel 1. Figure 4-3. DMA Cascading Channels #### 4.2.6 Stopping DMA Transfers A DMA block transfer in progress can be stopped by clearing the DMAEN bit. The DMA will stop after the completion of the ongoing transfer cycle and all the channel registers will stay in the current state. The block transfer can be continued as originally configured after setting the DMAEN bit again. #### Note A single transfer in progress cannot be interrupted. #### 4.2.7 Channel Priorities The default DMA channel priorities are DMA0 through DMA15. If two or three triggers happen simultaneously or are pending, the channel with the highest priority completes its transfer (single or block transfer) first, then the second priority channel, then the third priority channel. Transfers in progress are not halted if a higher-priority channel is triggered. The higher-priority channel waits until the transfer in progress completes before starting. The DMA channel priorities are configurable with the ROUNDROBIN bit. When the ROUNDROBIN bit is set, the channel that completes a transfer becomes the lowest priority. The order of the priority of the channels always stays the same, DMA0-DMA1-DMA2, for example, for three channels. When the ROUNDROBIN bit is cleared, the channel priority returns to the default priority. | Table 4-6. Round- | Robin DMA | Priority | Example | |-------------------|-----------|----------|---------| |-------------------|-----------|----------|---------| | Current DMA Priority | Transfer Occurs | New DMA Priority | |----------------------|-----------------|--------------------| | DMA0 - DMA1 - DMA2 | DMA1 | DMA2 - DMA0 - DMA1 | | DMA2 - DMA0 - DMA1 | DMA2 | DMA0 - DMA1 - DMA2 | | DMA2 - DMA0 - DMA1 | DMA0 | DMA1 - DMA2 - DMA0 | #### 4.2.8 Burst Block Mode The DMA module supports a burst block mode for suspending an active channel after a configurable number of transfers in order to service other pending channels. The burst block size is configurable by setting DMAPRIO.BURSTSZ to 8, 16, 32, or an infinite number of transfers. If a higher priority channel is pending after the burst block, the DMA will execute the higher priority channel and resume on the suspended channel once the higher priority channel is complete. If no other channel is pending, the priority logic assigns the control back to the block transfer for the next burst. #### 4.2.9 Using DMA with System Interrupts System interrupt service routines are interrupted by DMA transfers. If an interrupt service routine or other routine must execute with no interruptions, the DMA controller should be disabled before executing the routine. #### 4.2.10 DMA Controller Interrupts Each DMA channel has its own RIS flag. Each RIS flag is set in any mode when the corresponding DMASZx register counts to zero. If the corresponding MASK and RIS bits are set, an interrupt request is generated. All RIS flags are prioritized, with DMA0 being the highest, and combined to source a single interrupt vector. The highest-priority enabled interrupt generates a number in the IIDX register. This number can be evaluated or added to the program counter (PC) to automatically enter the appropriate software routine. Any access, read or write, of the IIDX register automatically resets the highest pending interrupt flag. If another interrupt flag is set, another interrupt is immediately generated after servicing the initial interrupt. For example, assume that DMA0 has the highest priority. If the DMA0-RIS and DMA2-RIS flags are set when the interrupt service routine accesses the IIDX register, DMA0-RIS is reset automatically. After the interrupt service routine is executed, the DMA2-RIS generates another interrupt. # 4.2.11 DMA Trigger Event Status The DMA controller supports dedicated DMA events. See Section 6.2.2 for details on the DMA event trigger protocol. The idea is that the DMA can inform the event triggering peripheral about the status of the assigned DMA channel. This will allow the triggering peripheral to issue an interrupt itself after the completion of a repeated transfer, instead of the DMA issuing an interrupt event. The advantage is, that the DMA interrupt service routine does not need to keep track of the assigned function of the channel. As a result, the DMA triggering peripheral interrupt service routine will deal with the completion of the DMA transfer. The status will reflect the value of the DMASZx register. If the last DMA transfer resulted in a size decrement to zero, the DMA will return the status of 1, indicating the end of the transfer. Otherwise the status will be 0. Additionally, the DMA module can generate an early interrupt request to the CPU to indicate that a transfer will complete within a configurable number of transfers (1, 2, 4, 8, 32, 64, half-DMASZ). An early IRQ event is enabled by setting DMAPREIRQ to the desired number of transfers. When the DMA has reached the number of transfers, the corresponding DMA channel's PREIRQ interrupt is set. Early DMA interrupt generation is useful to: - Reduce the interrupt latency in timing-critical applications where it would be beneficial to let the DMA preemptively generate the IRQ before the DMA transfer is complete - · Serve as a "progress notification" when scheduling other tasks for the CPU to complete - Transfer weights of a neural network layer and notify the CPU to complete software configuration writes to the IP - Implement a ping-pong buffer (by setting DMAPREIRQ to half) Note This feature is available on repeat-capable channels only. ## **4.2.12 DMA Operating Mode Support** The DMA supports triggered transfers in RUN mode, as well as in the SLEEP, STOP, and STANDBY low-power modes. Refer to the following sections for more details. #### 4.2.12.1 Transfer in RUN Mode In RUN mode the system is fully operational. The CPU and all other peripherals and resources are available, therefore there is no restriction on the DMA functionality in RUN mode. #### 4.2.12.2 Transfer in SLEEP Mode In SLEEP mode only the CPU is halted. All other peripherals and resources are available as when in RUN mode, therefore there is no restriction on the DMA functionality in SLEEP mode. All peripherals that can trigger a DMA transfer in RUN mode will also be able to trigger a DMA transfer in SLEEP mode. #### 4.2.12.3 Transfer in STOP Mode In STOP mode the CPU is halted and the ULPCLK is limited to 4 MHz operation. The DMA itself is clock gated and thus in a disabled state. All other peripherals and resources are available as when in RUN mode and are therefore able to trigger a DMA transfer in STOP mode. The event manager will detect a DMA trigger event and request the PMU to enter a "suspended STOP" state. For more info on this state refer to Section 2.1.2.7. While STOP mode is suspended, the DMA is fully functional and will work on the pending DMA trigger request. Once the DMA transfer is complete, the DMA will acknowledge the pending trigger event and the event subsystem removes the power mode request from the PMU. If the PMU has no other pending requests, the SoC will transition back into normal STOP mode. #### 4.2.12.4 Transfers in STANDBY Mode In STANDBY mode the CPU is halted and the ULPCLK is limited to 32 kHz operation. The DMA itself is clock gated and thus in a disabled state. With the exception of ADC, OPA, and GPAMP, all other peripherals and resources are available as when in RUN mode and are therefore able to trigger a DMA transfer in STANDBY mode. The event manager will detect a DMA trigger event and request the PMU to enter a "suspended STANDBY" state. For more info on this state refer to Section 2.1.2.7. While STANDBY mode is suspended, the DMA is fully functional and will work on the pending DMA trigger request. Once the DMA transfer is complete, the DMA will acknowledge the pending trigger event and the event subsystem removes the power mode request from the PMU. If the PMU has no other pending requests, the SoC will transition back into normal STANDBY mode. ## 4.2.13 DMA Address and Data Errors The DMA itself has the ability to flag address or data errors. Source or destination address errors can come from accessing a protected or non-existing memory range. If an address error occurs, the interrupt index IIDX[j].STAT flags a DMA address error (11h). Address error interrupts can be masked, set, and cleared using the ADDERR bit. #### Note The DMA itself does not perform range checking. If the DMA transfer occurs over a protected memory range, the destination data will report zeros (0h) for each byte of the DMA transaction that overlaps the protected or non-existing memory range. Data errors can occur in SRAM or flash if it has an ECC or parity error. If a data error occurs, the interrupt index IIDX[j].STAT flags a DMA data error (12h). Data error interrupts can be masked, set, and cleared using the DATERR bit. #### 4.2.14 Interrupt and Event Support The DMA module contains one event publishers and two event subscribers. - One event publisher (CPU\_INT) manages DMA interrupt requests (IRQs) to the CPU subsystem through a static event route. - The second and third event (GEN\_EVENT) are used to setup the generic event publishers and subscribers through Generic route. DMA events are summarized in Table 4-7. Table 4-7. DMA Events | Event | Type | Source | Destination | Route | Configuration | Functionality | |-----------------------------|------------|-------------------|-------------------|---------------|--------------------------------|------------------------------------------------------------| | CPU interrupt | Publisher | DMA | CPU Subsystem | Static route | CPU_INT registers | Fixed interrupt route from TIMx to CPU | | Generic publisher event | Publisher | DMA | Other peripherals | Generic route | GEN_EVENT and FPUB_1 registers | Configurable interrupt route from DMA to other peripherals | | Generic<br>subscriber event | Subscriber | Other peripherals | DMA | Generic route | FSUB_0 | Configurable interrupt route from other peripherals to DMA | | Generic<br>subscriber event | Subscriber | Other peripherals | DMA | Generic route | FSUB_1 | Configurable interrupt route from other peripherals to DMA | # 4.3 DMA Registers Table 4-8 lists the memory-mapped registers for the DMA registers. All register offset addresses not listed in Table 4-8 should be considered as reserved locations and the register contents should not be modified. Table 4-8. DMA Registers | Offset | Acronym | Register Name | Group | Section | | |--------------------|------------|------------------------------------|---------------------------------|---------|--| | 400h | FSUB_0 | Subscriber Port 0 Go | | | | | 404h | FSUB_1 | Subscriber Port 1 Go | | | | | 444h | FPUB_1 | Publisher Port 1 | Publisher Port 1 Go | | | | 1018h | PDBGCTL | Peripheral Debug Control | | Go | | | 1020h | IIDX | Interrupt index | CPU_INT | Go | | | 1028h | IMASK | Interrupt mask | CPU_INT | Go | | | 1030h | RIS | Raw interrupt status | CPU_INT | Go | | | 1038h | MIS | Masked interrupt status | CPU_INT | Go | | | 1040h | ISET | Interrupt set | CPU_INT | Go | | | 1048h | ICLR | Interrupt clear | CPU_INT | Go | | | 1050h | IIDX | Interrupt index | GEN_EVENT | Go | | | 1058h | IMASK | Interrupt mask | <del>_</del> | | | | 1060h | RIS | Raw interrupt status | Raw interrupt status GEN_EVENT | | | | 1068h | MIS | Masked interrupt status GEN_EVENT | | Go | | | 1070h | ISET | nterrupt set GEN_EVENT | | Go | | | 1078h | ICLR | nterrupt clear GEN_EVENT Go | | Go | | | 10E0h | EVT_MODE | Event Mode Go | | | | | 10FCh | DESC | Module Description Go | | | | | 1100h | DMAPRIO | DMA Channel Priority Control | DMA Channel Priority Control Go | | | | 1110h +<br>formula | DMATCTL[j] | DMA Trigger Select | • | | | | 1200h +<br>formula | DMACTL[j] | DMA Channel Control Go | | | | | 1204h +<br>formula | DMASA[j] | DMA Channel Source Address Go | | | | | 1208h +<br>formula | DMADA[j] | DMA Channel Destination Address Go | | | | | 120Ch +<br>formula | DMASZ[j] | DMA Channel Size Go | | | | Complex bit access types are encoded to fit into small table cells. Table 4-9 shows the codes that are used for access types in this section. Table 4-9. DMA Access Type Codes | Access Type | Code | Description | | | |--------------------------|------------------------|----------------------------------------|--|--| | Read Type | | | | | | R | R | Read | | | | Write Type | | | | | | W | W Write | | | | | Reset or Default Val | Reset or Default Value | | | | | -n | | Value after reset or the default value | | | | Register Array Variables | | | | | # Table 4-9. DMA Access Type Codes (continued) | Access Type | Code | Description | |-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | i,j,k,l,m,n | | When these variables are used in a register name, an offset, or an address, they refer to the value of a register array where the register is part of a group of repeating registers. The register groups form a hierarchical structure and the array is represented with a formula. | | У | | When this variable is used in a register name, an offset, or an address it refers to the value of a register array. | # 4.3.1 FSUB\_0 (Offset = 400h) [Reset = 00000000h] FSUB\_0 is shown in Figure 4-4 and described in Table 4-10. Return to the Summary Table. Subscriber port # Figure 4-4. FSUB\_0 # Table 4-10. FSUB\_0 Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-8 | RESERVED | R/W | 0h | | | 7-0 | CHANID | R/W | 0h | 0 = disconnected. 1-255 = connected to channelID = CHANID. 0h = A value of 0 specifies that the event is not connected FFh = Consult your device data sheet as the actual allowed maximum may be less than 255. | # 4.3.2 FSUB\_1 (Offset = 404h) [Reset = 00000000h] FSUB\_1 is shown in Figure 4-5 and described in Table 4-11. Return to the Summary Table. Subscriber port # Figure 4-5. FSUB\_1 # Table 4-11. FSUB\_1 Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-8 | RESERVED | R/W | 0h | | | 7-0 | CHANID | R/W | 0h | 0 = disconnected. 1-255 = connected to channelID = CHANID. 0h = A value of 0 specifies that the event is not connected FFh = Consult your device data sheet as the actual allowed maximum may be less than 255. | # 4.3.3 FPUB\_1 (Offset = 444h) [Reset = 00000000h] FPUB\_1 is shown in Figure 4-6 and described in Table 4-12. Return to the Summary Table. Publisher port # Figure 4-6. FPUB\_1 # Table 4-12. FPUB\_1 Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-8 | RESERVED | R/W | 0h | | | 7-0 | CHANID | R/W | 0h | 0 = disconnected. 1-255 = connected to channelID = CHANID. 0h = A value of 0 specifies that the event is not connected FFh = Consult your device data sheet as the actual allowed maximum may be less than 255. | # 4.3.4 PDBGCTL (Offset = 1018h) [Reset = 00000003h] PDBGCTL is shown in Figure 4-7 and described in Table 4-13. Return to the Summary Table. This register can be used by the software developer to control the behavior of the peripheral relative to the 'Core Halted' input Figure 4-7. PDBGCTL ## **Table 4-13. PDBGCTL Field Descriptions** | 14510 1 1011 2200121 1014 20001110110 | | | | | | | |---------------------------------------|----------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Bit | Field | Туре | Reset | Description | | | | 31-2 | RESERVED | R/W | 0h | | | | | 1 | SOFT | R/W | 1h | Soft halt boundary control. This function is only available, if FREE is set to 'STOP' 0h = The peripheral will halt immediately, even if the resultant state will result in corruption if the system is restarted 1h = The peripheral blocks the debug freeze until it has reached a boundary where it can resume without corruption | | | | 0 | FREE | R/W | 1h | Free run control 0h = The peripheral freezes functionality while the Core Halted input is asserted and resumes when it is deasserted. 1h = The peripheral ignores the state of the Core Halted input | | | ## 4.3.5 IIDX (Offset = 1020h) [Reset = 00000000h] IIDX is shown in Figure 4-8 and described in Table 4-14. Return to the Summary Table. This register provides the highest priority enabled interrupt index. Value 0x00 means no event pending. Interrupt 1 is the highest priority, IIDX next highest, 4, 8, . . . IIDX^31 is the least priority. That is, the least bit position that is set to 1 denotes the highest priority pending interrupt. The priority order is fixed. However, users can implement their own prioritization schemes using other registers that expose the full set of interrupts that have occurred. On each read, only one interrupt is indicated. On a read, the current interrupt (highest priority) is automatically cleared by the hardware and the corresponding interrupt flag in RIS [RIS] and MIS [MIS] are cleared as well. After a read from the CPU (not from the debug interface), the register is updated with the next highest priority interrupt, if none are pending, then it should display 0x0. Note: The number of DMACH is device dependent. Please consult the data sheet of the specific device to map which channel number is implemented. #### Figure 4-8. IIDX #### Table 4-14. IIDX Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-8 | RESERVED | R | 0h | | | 7-0 | STAT | R | Oh | Interrupt index status 00h = No bit is set means there is no pending interrupt request 01h = DMA Channel 0 size counter reached zero (DMASZ=0). 02h = DMA Channel 1 size counter reached zero (DMASZ=0). 03h = DMA Channel 2 size counter reached zero (DMASZ=0). 04h = DMA Channel 3 size counter reached zero (DMASZ=0). 05h = DMA Channel 4 size counter reached zero (DMASZ=0). 06h = DMA Channel 5 size counter reached zero (DMASZ=0). 07h = DMA Channel 6 size counter reached zero (DMASZ=0). 08h = DMA Channel 7 size counter reached zero (DMASZ=0). 09h = DMA Channel 8 size counter reached zero (DMASZ=0). 09h = DMA Channel 9 size counter reached zero (DMASZ=0). 0Ah = DMA Channel 10 size counter reached zero (DMASZ=0). 0Bh = DMA Channel 11 size counter reached zero (DMASZ=0). 0Ch = DMA Channel 12 size counter reached zero (DMASZ=0). 0Dh = DMA Channel 13 size counter reached zero (DMASZ=0). 0Fh = DMA Channel 14 size counter reached zero (DMASZ=0). 10h = DMA Channel 15 size counter reached zero (DMASZ=0). 10h = DMA Channel 15 size counter reached zero (DMASZ=0). 11h = PRE-IRQ event for DMA Channel 0. 12h = PRE-IRQ event for DMA Channel 1. 13h = PRE-IRQ event for DMA Channel 2. 14h = PRE-IRQ event for DMA Channel 3. 15h = PRE-IRQ event for DMA Channel 4. 16h = PRE-IRQ event for DMA Channel 5. 17h = PRE-IRQ event for DMA Channel 6. 18h = PRE-IRQ event for DMA Channel 7. 19h = DMA address error, SRC address not reachable. 1Ah = DMA data error, SRC data might be corrupted (PAR or ECC error). | # 4.3.6 IMASK (Offset = 1028h) [Reset = 00000000h] IMASK is shown in Figure 4-9 and described in Table 4-15. Return to the Summary Table. Interrupt Mask. If a bit is set, then the corresponding interrupt is un-masked. Un-masking the interrupt causes the raw interrupt to be visible in IIDX [IIDX], as well as MIS [MIS]. Note: The number of DMACH is device dependent. Please consult the data sheet of the specific device to map which channel number is implemented. Figure 4-9. IMASK | | | | 9 | J. 1111/AUIX | | | | |-----------|-----------|-----------|-----------|--------------|-----------|-----------|-----------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | DATAERR | ADDRERR | | | | | | | R/V | V-0h | | | R/W-0h | R/W-0h | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | PREIRQCH7 | PREIRQCH6 | PREIRQCH5 | PREIRQCH4 | PREIRQCH3 | PREIRQCH2 | PREIRQCH1 | PREIRQCH0 | | R/W-0h | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | DMACH15 | DMACH14 | DMACH13 | DMACH12 | DMACH11 | DMACH10 | DMACH9 | DMACH8 | | R/W-0h | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | DMACH7 | DMACH6 | DMACH5 | DMACH4 | DMACH3 | DMACH2 | DMACH1 | DMACH0 | | R/W-0h # **Table 4-15. IMASK Field Descriptions** | Bit | Field | Туре | Reset | Description | |-------|-----------|------|-------|-----------------------------------------------------------------------------------------------------------------------------| | 31-26 | RESERVED | R/W | 0h | | | 25 | DATAERR | R/W | 0h | DMA data error, SRC data might be corrupted (PAR or ECC error). 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | 24 | ADDRERR | R/W | 0h | DMA address error, SRC address not reachable. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | 23 | PREIRQCH7 | R/W | 0h | Pre-IRQ for Channel 7. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | 22 | PREIRQCH6 | R/W | 0h | Pre-IRQ for Channel 6. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | 21 | PREIRQCH5 | R/W | 0h | Pre-IRQ for Channel 5. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | 20 | PREIRQCH4 | R/W | 0h | Pre-IRQ for Channel 4. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | 19 | PREIRQCH3 | R/W | 0h | Pre-IRQ for Channel 3. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | 18 | PREIRQCH2 | R/W | Oh | Pre-IRQ for Channel 2. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | 17 | PREIRQCH1 | R/W | 0h | Pre-IRQ for Channel 1. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | # **Table 4-15. IMASK Field Descriptions (continued)** | Bit | Field | Туре | Reset | Description (continued) | |-----|-----------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------| | 16 | PREIRQCH0 | R/W | 0h | Pre-IRQ for Channel 0. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | 15 | DMACH15 | R/W | 0h | DMA Channel 15 interrupt signal. Size counter reached zero (DMASZ=0). Oh = Clear interrupt mask bit 1h = Set interrupt mask bit | | 14 | DMACH14 | R/W | 0h | DMA Channel 14 interrupt signal. Size counter reached zero (DMASZ=0). Oh = Clear interrupt mask bit 1h = Set interrupt mask bit | | 13 | DMACH13 | R/W | 0h | DMA Channel 13 interrupt signal. Size counter reached zero (DMASZ=0). Oh = Clear interrupt mask bit 1h = Set interrupt mask bit | | 12 | DMACH12 | R/W | 0h | DMA Channel 12 interrupt signal. Size counter reached zero (DMASZ=0). Oh = Clear interrupt mask bit 1h = Set interrupt mask bit | | 11 | DMACH11 | R/W | 0h | DMA Channel 11 interrupt signal. Size counter reached zero (DMASZ=0). Oh = Clear interrupt mask bit 1h = Set interrupt mask bit | | 10 | DMACH10 | R/W | 0h | DMA Channel 10 interrupt signal. Size counter reached zero (DMASZ=0). Oh = Clear interrupt mask bit 1h = Set interrupt mask bit | | 9 | DMACH9 | R/W | 0h | DMA Channel 9 interrupt signal. Size counter reached zero (DMASZ=0). Oh = Clear interrupt mask bit 1h = Set interrupt mask bit | | 8 | DMACH8 | R/W | 0h | DMA Channel 8 interrupt signal. Size counter reached zero (DMASZ=0). Oh = Clear interrupt mask bit 1h = Set interrupt mask bit | | 7 | DMACH7 | R/W | 0h | DMA Channel 7 interrupt signal. Size counter reached zero (DMASZ=0). Oh = Clear interrupt mask bit 1h = Set interrupt mask bit | | 6 | DMACH6 | R/W | 0h | DMA Channel 6 interrupt signal. Size counter reached zero (DMASZ=0). Oh = Clear interrupt mask bit 1h = Set interrupt mask bit | | 5 | DMACH5 | R/W | 0h | DMA Channel 5 interrupt signal. Size counter reached zero (DMASZ=0). Oh = Clear interrupt mask bit 1h = Set interrupt mask bit | | 4 | DMACH4 | R/W | 0h | DMA Channel 4 interrupt signal. Size counter reached zero (DMASZ=0). Oh = Clear interrupt mask bit 1h = Set interrupt mask bit | | 3 | DMACH3 | R/W | 0h | DMA Channel 3 interrupt signal. Size counter reached zero (DMASZ=0). Oh = Clear interrupt mask bit 1h = Set interrupt mask bit | | 2 | DMACH2 | R/W | Oh | DMA Channel 2 interrupt signal. Size counter reached zero (DMASZ=0). Oh = Clear interrupt mask bit 1h = Set interrupt mask bit | # **Table 4-15. IMASK Field Descriptions (continued)** | Bit | Field | Туре | Reset | Description | |-----|--------|------|-------|---------------------------------------------------------------------------------------------------------------------------------| | 1 | DMACH1 | R/W | 0h | DMA Channel 1 interrupt signal. Size counter reached zero (DMASZ=0). 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | 0 | DMACH0 | R/W | 0h | DMA Channel 0 interrupt signal. Size counter reached zero (DMASZ=0). 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | # 4.3.7 RIS (Offset = 1030h) [Reset = 00000000h] RIS is shown in Figure 4-10 and described in Table 4-16. Return to the Summary Table. Raw interrupt status. Reflects all pending interrupts, regardless of masking. The RIS register allows the user to implement a poll scheme. A flag set in this register can be cleared by writing 1 to the ICLR [ICLR] register bit even if the corresponding IMASK [IMASK] bit is not enabled. Note: The number of DMACH is device dependent. Please consult the data sheet of the specific device to map which channel number is implemented. Figure 4-10. RIS | | | | 9 | | | | | | |-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | DATAERR | ADDRERR | | | | | | | | R-0h | | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | PREIRQCH7 | PREIRQCH6 | PREIRQCH5 | PREIRQCH4 | PREIRQCH3 | PREIRQCH2 | PREIRQCH1 | PREIRQCH0 | | | R-0h | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | DMACH15 | DMACH14 | DMACH13 | DMACH12 | DMACH11 | DMACH10 | DMACH9 | DMACH8 | | | R-0h | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | DMACH7 | DMACH6 | DMACH5 | DMACH4 | DMACH3 | DMACH2 | DMACH1 | DMACH0 | | | R-0h | Table 4-16. RIS Field Descriptions | Bit | Field | Туре | Reset | Description | | |-------|-----------|------|-------|----------------------------------------------------------------------------------------------------------------------------|--| | 31-26 | RESERVED | R | 0h | | | | 25 | DATAERR | R | 0h | DMA data error, SRC data might be corrupted (PAR or ECC error). 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | | 24 | ADDRERR | R | 0h | DMA address error, SRC address not reachable. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | | 23 | PREIRQCH7 | R | 0h | Pre-IRQ for Channel 7. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | | 22 | PREIRQCH6 | R | 0h | Pre-IRQ for Channel 6. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | | 21 | PREIRQCH5 | R | 0h | Pre-IRQ for Channel 5. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | | 20 | PREIRQCH4 | R | 0h | Pre-IRQ for Channel 4. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | | 19 | PREIRQCH3 | R | 0h | Pre-IRQ for Channel 3. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | | 18 | PREIRQCH2 | R | Oh | Pre-IRQ for Channel 2. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | | 17 | PREIRQCH1 | R | 0h | Pre-IRQ for Channel 1. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | # **Table 4-16. RIS Field Descriptions (continued)** | | Table 4-16. RIS Field Descriptions (continued) | | | | | | | |-----|------------------------------------------------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | 16 | PREIRQCH0 | R | 0h | Pre-IRQ for Channel 0. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | | | | 15 | DMACH15 | R | 0h | DMA Channel 15 interrupt signals that size counter reached zero (DMASZ=0). Oh = Interrupt did not occur 1h = Interrupt occurred | | | | | 14 | DMACH14 | R | 0h | DMA Channel 14 interrupt signals that size counter reached zero (DMASZ=0). Oh = Interrupt did not occur 1h = Interrupt occurred | | | | | 13 | DMACH13 | R | 0h | DMA Channel 13 interrupt signals that size counter reached zero (DMASZ=0). Oh = Interrupt did not occur 1h = Interrupt occurred | | | | | 12 | DMACH12 | R | 0h | DMA Channel 12 interrupt signals that size counter reached zero (DMASZ=0). Oh = Interrupt did not occur 1h = Interrupt occurred | | | | | 11 | DMACH11 | R | 0h | DMA Channel 11 interrupt signals that size counter reached zero (DMASZ=0). Oh = Interrupt did not occur 1h = Interrupt occurred | | | | | 10 | DMACH10 | R | 0h | DMA Channel 10 interrupt signals that size counter reached zero (DMASZ=0). 0h = Interrupt did not occur 1h = Interrupt occurred | | | | | 9 | DMACH9 | R | 0h | DMA Channel 9 interrupt signals that size counter reached zero (DMASZ=0). Oh = Interrupt did not occur 1h = Interrupt occurred | | | | | 8 | DMACH8 | R | 0h | DMA Channel 8 interrupt signals that size counter reached zero (DMASZ=0). Oh = Interrupt did not occur 1h = Interrupt occurred | | | | | 7 | DMACH7 | R | 0h | DMA Channel 7 interrupt signals that size counter reached zero (DMASZ=0). Oh = Interrupt did not occur 1h = Interrupt occurred | | | | | 6 | DMACH6 | R | 0h | DMA Channel 6 interrupt signals that size counter reached zero (DMASZ=0). Oh = Interrupt did not occur 1h = Interrupt occurred | | | | | 5 | DMACH5 | R | 0h | DMA Channel 5 interrupt signals that size counter reached zero (DMASZ=0). Oh = Interrupt did not occur 1h = Interrupt occurred | | | | | 4 | DMACH4 | R | 0h | DMA Channel 4 interrupt signals that size counter reached zero (DMASZ=0). Oh = Interrupt did not occur 1h = Interrupt occurred | | | | | 3 | DMACH3 | R | 0h | DMA Channel 3 interrupt signals that size counter reached zero (DMASZ=0). Oh = Interrupt did not occur 1h = Interrupt occurred | | | | | 2 | DMACH2 | R | Oh | DMA Channel 2 interrupt signals that size counter reached zero (DMASZ=0). Oh = Interrupt did not occur 1h = Interrupt occurred | | | | # **Table 4-16. RIS Field Descriptions (continued)** | Bit | Field | Туре | Reset | Description | |-----|--------|------|-------|----------------------------------------------------------------------------------------------------------------------------------| | 1 | DMACH1 | R | 0h | DMA Channel 1 interrupt signals that size counter reached zero (DMASZ=0). 0h = Interrupt did not occur 1h = Interrupt occurred | | 0 | DMACH0 | R | 0h | DMA Channel 0 interrupt signals that size counter reached zero (DMASZ=0). 0h = Interrupt did not occur 1h = Interrupt occurred | # 4.3.8 MIS (Offset = 1038h) [Reset = 00000000h] MIS is shown in Figure 4-11 and described in Table 4-17. Return to the Summary Table. Masked interrupt status. This is an AND of the IMASK [IMASK] and RIS [RIS] registers. Note: The number of DMACH is device dependent. Please consult the data sheet of the specific device to map which channel number is implemented. Figure 4-11. MIS | | | | i iguic ¬ | | | | | |-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | DATAERR | ADDRERR | | | | | | | | R- | 0h | | | R-0h | R-0h | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | PREIRQCH7 | PREIRQCH6 | PREIRQCH5 | PREIRQCH4 | PREIRQCH3 | PREIRQCH2 | PREIRQCH1 | PREIRQCH0 | | R-0h | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | DMACH15 | DMACH14 | DMACH13 | DMACH12 | DMACH11 | DMACH10 | DMACH9 | DMACH8 | | R-0h | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | DMACH7 | DMACH6 | DMACH5 | DMACH4 | DMACH3 | DMACH2 | DMACH1 | DMACH0 | | R-0h ## **Table 4-17. MIS Field Descriptions** | Bit | Field | Туре | Reset | Description | |-------|-----------|------|-------|----------------------------------------------------------------------------------------------------------------------------| | 31-26 | RESERVED | R | 0h | | | 25 | DATAERR | R | Oh | DMA data error, SRC data might be corrupted (PAR or ECC error). 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | 24 | ADDRERR | R | 0h | DMA address error, SRC address not reachable. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | 23 | PREIRQCH7 | R | 0h | Pre-IRQ for Channel 7. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | 22 | PREIRQCH6 | R | 0h | Pre-IRQ for Channel 6. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | 21 | PREIRQCH5 | R | 0h | Pre-IRQ for Channel 5. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | 20 | PREIRQCH4 | R | 0h | Pre-IRQ for Channel 4. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | 19 | PREIRQCH3 | R | Oh | Pre-IRQ for Channel 3. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | 18 | PREIRQCH2 | R | Oh | Pre-IRQ for Channel 2. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | 17 | PREIRQCH1 | R | 0h | Pre-IRQ for Channel 1. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | # **Table 4-17. MIS Field Descriptions (continued)** | Bit | Field | Туре | Reset | Descriptions (continued) Description | |-----|-----------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------| | 16 | PREIRQCH0 | R | 0h | Pre-IRQ for Channel 0. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | 15 | DMACH15 | R | 0h | DMA Channel 15 interrupt signals that size counter reached zero (DMASZ=0). Oh = Interrupt did not occur or is masked out 1h = Interrupt occurred | | 14 | DMACH14 | R | Oh | DMA Channel 14 interrupt signals that size counter reached zero (DMASZ=0). Oh = Interrupt did not occur or is masked out 1h = Interrupt occurred | | 13 | DMACH13 | R | 0h | DMA Channel 13 interrupt signals that size counter reached zero (DMASZ=0). Oh = Interrupt did not occur or is masked out 1h = Interrupt occurred | | 12 | DMACH12 | R | Oh | DMA Channel 12 interrupt signals that size counter reached zero (DMASZ=0). Oh = Interrupt did not occur or is masked out 1h = Interrupt occurred | | 11 | DMACH11 | R | 0h | DMA Channel 11 interrupt signals that size counter reached zero (DMASZ=0). Oh = Interrupt did not occur or is masked out 1h = Interrupt occurred | | 10 | DMACH10 | R | 0h | DMA Channel 10 interrupt signals that size counter reached zero (DMASZ=0). Oh = Interrupt did not occur or is masked out 1h = Interrupt occurred | | 9 | DMACH9 | R | 0h | DMA Channel 9 interrupt signals that size counter reached zero (DMASZ=0). Oh = Interrupt did not occur or is masked out 1h = Interrupt occurred | | 8 | DMACH8 | R | 0h | DMA Channel 8 interrupt signals that size counter reached zero (DMASZ=0). Oh = Interrupt did not occur or is masked out 1h = Interrupt occurred | | 7 | DMACH7 | R | 0h | DMA Channel 7 interrupt signals that size counter reached zero (DMASZ=0). Oh = Interrupt did not occur or is masked out 1h = Interrupt occurred | | 6 | DMACH6 | R | Oh | DMA Channel 6 interrupt signals that size counter reached zero (DMASZ=0). Oh = Interrupt did not occur or is masked out 1h = Interrupt occurred | | 5 | DMACH5 | R | 0h | DMA Channel 5 interrupt signals that size counter reached zero (DMASZ=0). Oh = Interrupt did not occur or is masked out 1h = Interrupt occurred | | 4 | DMACH4 | R | Oh | DMA Channel 4 interrupt signals that size counter reached zero (DMASZ=0). Oh = Interrupt did not occur or is masked out 1h = Interrupt occurred | | 3 | DMACH3 | R | Oh | DMA Channel 3 interrupt signals that size counter reached zero (DMASZ=0). Oh = Interrupt did not occur or is masked out 1h = Interrupt occurred | | 2 | DMACH2 | R | Oh | DMA Channel 2 interrupt signals that size counter reached zero (DMASZ=0). Oh = Interrupt did not occur or is masked out 1h = Interrupt occurred | # **Table 4-17. MIS Field Descriptions (continued)** | Bit | Field | Туре | Reset | Description | |-----|--------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------| | 1 | DMACH1 | R | 0h | DMA Channel 1 interrupt signals that size counter reached zero (DMASZ=0). 0h = Interrupt did not occur or is masked out 1h = Interrupt occurred | | 0 | DMACH0 | R | 0h | DMA Channel 0 interrupt signals that size counter reached zero (DMASZ=0). 0h = Interrupt did not occur or is masked out 1h = Interrupt occurred | # 4.3.9 ISET (Offset = 1040h) [Reset = 00000000h] ISET is shown in Figure 4-12 and described in Table 4-18. Return to the Summary Table. Interrupt set. Allows interrupts to be set by software (useful in diagnostics and safety checks). Writing a 1 to a bit in ISET will set the event and therefore the related RIS [RIS] bit also gets set. If the interrupt is enabled through the mask, then the corresponding MIS [MIS] bit is also set. Note: The number of DMACH is device dependent. Please consult the data sheet of the specific device to map which channel number is implemented. Figure 4-12. ISET | | | | i iguic <del>T</del> | 12.1021 | | | | |-----------|-----------|-----------|----------------------|-----------|-----------|-----------|-----------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | DATAERR | ADDRERR | | | | | | | | W- | ·0h | | | W-0h | W-0h | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | PREIRQCH7 | PREIRQCH6 | PREIRQCH5 | PREIRQCH4 | PREIRQCH3 | PREIRQCH2 | PREIRQCH1 | PREIRQCH0 | | W-0h | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | DMACH15 | DMACH14 | DMACH13 | DMACH12 | DMACH11 | DMACH10 | DMACH9 | DMACH8 | | W-0h | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | DMACH7 | DMACH6 | DMACH5 | DMACH4 | DMACH3 | DMACH2 | DMACH1 | DMACH0 | | W-0h **Table 4-18. ISET Field Descriptions** | Bit | Field | Туре | Reset | Description | |-------|-----------|------|-------|----------------------------------------------------------------------------------------------------------------------------| | 31-26 | RESERVED | W | 0h | | | 25 | DATAERR | W | 0h | DMA data error, SRC data might be corrupted (PAR or ECC error). 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | 24 | ADDRERR | W | 0h | DMA address error, SRC address not reachable. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | 23 | PREIRQCH7 | W | 0h | Pre-IRQ for Channel 7. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | 22 | PREIRQCH6 | W | 0h | Pre-IRQ for Channel 6. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | 21 | PREIRQCH5 | W | 0h | Pre-IRQ for Channel 5. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | 20 | PREIRQCH4 | W | 0h | Pre-IRQ for Channel 4. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | 19 | PREIRQCH3 | W | 0h | Pre-IRQ for Channel 3. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | 18 | PREIRQCH2 | W | Oh | Pre-IRQ for Channel 2. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | 17 | PREIRQCH1 | W | 0h | Pre-IRQ for Channel 1. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | # **Table 4-18. ISET Field Descriptions (continued)** | Bit | Field | Type | Reset | Descriptions (continued) | |-----|-----------|------|-------|------------------------------------------------------------------------------------------------------------------------------| | 16 | PREIRQCH0 | W | Oh | Pre-IRQ for Channel 0. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | 15 | DMACH15 | W | 0h | DMA Channel 0 interrupt signals that size counter reached zero (DMASZ=0). 0h = Writing 0 has no effect 1h = Set interrupt | | 14 | DMACH14 | W | 0h | DMA Channel 14 interrupt signals that size counter reached zero (DMASZ=0). Oh = Writing 0 has no effect 1h = Set interrupt | | 13 | DMACH13 | W | 0h | DMA Channel 13 interrupt signals that size counter reached zero (DMASZ=0). 0h = Writing 0 has no effect 1h = Set interrupt | | 12 | DMACH12 | W | 0h | DMA Channel 12 interrupt signals that size counter reached zero (DMASZ=0). 0h = Writing 0 has no effect 1h = Set interrupt | | 11 | DMACH11 | W | Oh | DMA Channel 11 interrupt signals that size counter reached zero (DMASZ=0). Oh = Writing 0 has no effect 1h = Set interrupt | | 10 | DMACH10 | W | Oh | DMA Channel 0 interrupt signals that size counter reached zero (DMASZ=0). Oh = Writing 0 has no effect 1h = Set interrupt | | 9 | DMACH9 | W | Oh | DMA Channel 9 interrupt signals that size counter reached zero (DMASZ=0). Oh = Writing 0 has no effect 1h = Set interrupt | | 8 | DMACH8 | W | Oh | DMA Channel 8 interrupt signals that size counter reached zero (DMASZ=0). Oh = Writing 0 has no effect 1h = Set interrupt | | 7 | DMACH7 | W | 0h | DMA Channel 7 interrupt signals that size counter reached zero (DMASZ=0). Oh = Writing 0 has no effect 1h = Set interrupt | | 6 | DMACH6 | W | Oh | DMA Channel 6 interrupt signals that size counter reached zero (DMASZ=0). Oh = Writing 0 has no effect 1h = Set interrupt | | 5 | DMACH5 | W | Oh | DMA Channel 5 interrupt signals that size counter reached zero (DMASZ=0). Oh = Writing 0 has no effect 1h = Set interrupt | | 4 | DMACH4 | W | Oh | DMA Channel 4 interrupt signals that size counter reached zero (DMASZ=0). Oh = Writing 0 has no effect 1h = Set interrupt | | 3 | DMACH3 | W | Oh | DMA Channel 3 interrupt signals that size counter reached zero (DMASZ=0). Oh = Writing 0 has no effect 1h = Set interrupt | | 2 | DMACH2 | W | Oh | DMA Channel 2 interrupt signals that size counter reached zero (DMASZ=0). Oh = Writing 0 has no effect 1h = Set interrupt | # Table 4-18. ISET Field Descriptions (continued) | Bit | Field | Туре | Reset | Description | |-----|--------|------|-------|----------------------------------------------------------------------------------------------------------------------------| | 1 | DMACH1 | W | 0h | DMA Channel 1 interrupt signals that size counter reached zero (DMASZ=0). 0h = Writing 0 has no effect 1h = Set interrupt | | 0 | DMACH0 | W | 0h | DMA Channel 0 interrupt signals that size counter reached zero (DMASZ=0). 0h = Writing 0 has no effect 1h = Set interrupt | # 4.3.10 ICLR (Offset = 1048h) [Reset = 00000000h] ICLR is shown in Figure 4-13 and described in Table 4-19. Return to the Summary Table. Interrupt clear. Write a 1 to clear corresponding Interrupt. Note: The number of DMACH is device dependent. Please consult the data sheet of the specific device to map which channel number is implemented. Figure 4-13. ICLR | | | | I iguic + | | | | | |-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | DATAERR | ADDRERR | | | | | | | | W- | ·0h | | | W-0h | W-0h | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | PREIRQCH7 | PREIRQCH6 | PREIRQCH5 | PREIRQCH4 | PREIRQCH3 | PREIRQCH2 | PREIRQCH1 | PREIRQCH0 | | W-0h | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | DMACH15 | DMACH14 | DMACH13 | DMACH12 | DMACH11 | DMACH10 | DMACH9 | DMACH8 | | W-0h | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | DMACH7 | DMACH6 | DMACH5 | DMACH4 | DMACH3 | DMACH2 | DMACH1 | DMACH0 | | W-0h ## **Table 4-19. ICLR Field Descriptions** | Bit | Field | Туре | Reset | Description | |-------|-----------|------|-------|-----------------------------------------------------------------------------------------------------------------------------| | 31-26 | RESERVED | W | 0h | | | 25 | DATAERR | W | Oh | DMA data error, SRC data might be corrupted (PAR or ECC error). 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | 24 | ADDRERR | W | 0h | DMA address error, SRC address not reachable. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | 23 | PREIRQCH7 | W | Oh | Pre-IRQ for Channel 7. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | 22 | PREIRQCH6 | W | Oh | Pre-IRQ for Channel 6. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | 21 | PREIRQCH5 | W | Oh | Pre-IRQ for Channel 5. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | 20 | PREIRQCH4 | W | Oh | Pre-IRQ for Channel 4. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | 19 | PREIRQCH3 | W | Oh | Pre-IRQ for Channel 3. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | 18 | PREIRQCH2 | W | Oh | Pre-IRQ for Channel 2. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | 17 | PREIRQCH1 | W | Oh | Pre-IRQ for Channel 1. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | # **Table 4-19. ICLR Field Descriptions (continued)** | Bit | Field | Type | Reset | Descriptions (continued) | |-----|-----------|------|-------|--------------------------------------------------------------------------------------------------------------------------------| | 16 | PREIRQCH0 | W | 0h | Pre-IRQ for Channel 0. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | 15 | DMACH15 | W | 0h | DMA Channel 15 interrupt signals that size counter reached zero (DMASZ=0). 0h = Writing 0 has no effect 1h = Clear interrupt | | 14 | DMACH14 | W | 0h | DMA Channel 14 interrupt signals that size counter reached zero (DMASZ=0). Oh = Writing 0 has no effect 1h = Clear interrupt | | 13 | DMACH13 | W | 0h | DMA Channel 13 interrupt signals that size counter reached zero (DMASZ=0). 0h = Writing 0 has no effect 1h = Clear interrupt | | 12 | DMACH12 | W | 0h | DMA Channel 12 interrupt signals that size counter reached zero (DMASZ=0). 0h = Writing 0 has no effect 1h = Clear interrupt | | 11 | DMACH11 | W | Oh | DMA Channel 11 interrupt signals that size counter reached zero (DMASZ=0). Oh = Writing 0 has no effect 1h = Clear interrupt | | 10 | DMACH10 | W | Oh | DMA Channel 10 interrupt signals that size counter reached zero (DMASZ=0). Oh = Writing 0 has no effect 1h = Clear interrupt | | 9 | DMACH9 | W | Oh | DMA Channel 9 interrupt signals that size counter reached zero (DMASZ=0). Oh = Writing 0 has no effect 1h = Clear interrupt | | 8 | DMACH8 | W | 0h | DMA Channel 8 interrupt signals that size counter reached zero (DMASZ=0). Oh = Writing 0 has no effect 1h = Clear interrupt | | 7 | DMACH7 | W | 0h | DMA Channel 7 interrupt signals that size counter reached zero (DMASZ=0). Oh = Writing 0 has no effect 1h = Clear interrupt | | 6 | DMACH6 | W | 0h | DMA Channel 6 interrupt signals that size counter reached zero (DMASZ=0). Oh = Writing 0 has no effect 1h = Clear interrupt | | 5 | DMACH5 | W | 0h | DMA Channel 5 interrupt signals that size counter reached zero (DMASZ=0). Oh = Writing 0 has no effect 1h = Clear interrupt | | 4 | DMACH4 | W | 0h | DMA Channel 4 interrupt signals that size counter reached zero (DMASZ=0). Oh = Writing 0 has no effect 1h = Clear interrupt | | 3 | DMACH3 | W | Oh | DMA Channel 3 interrupt signals that size counter reached zero (DMASZ=0). Oh = Writing 0 has no effect 1h = Clear interrupt | | 2 | DMACH2 | W | Oh | DMA Channel 2 interrupt signals that size counter reached zero (DMASZ=0). Oh = Writing 0 has no effect 1h = Clear interrupt | # Table 4-19. ICLR Field Descriptions (continued) | Bit | Field | Туре | Reset | Description | |-----|--------|------|-------|------------------------------------------------------------------------------------------------------------------------------| | 1 | DMACH1 | W | 0h | DMA Channel 1 interrupt signals that size counter reached zero (DMASZ=0). 0h = Writing 0 has no effect 1h = Clear interrupt | | 0 | DMACH0 | W | 0h | DMA Channel 0 interrupt signals that size counter reached zero (DMASZ=0). 0h = Writing 0 has no effect 1h = Clear interrupt | ## 4.3.11 IIDX (Offset = 1050h) [Reset = 00000000h] IIDX is shown in Figure 4-14 and described in Table 4-20. Return to the Summary Table. This register provides the highest priority enabled interrupt index. Value 0x00 means no event pending. Interrupt 1 is the highest priority, IIDX next highest, 4, 8, . . . IIDX^31 is the least priority. That is, the least bit position that is set to 1 denotes the highest priority pending interrupt. The priority order is fixed. However, users can implement their own prioritization schemes using other registers that expose the full set of interrupts that have occurred. On each read, only one interrupt is indicated. On a read, the current interrupt (highest priority) is automatically cleared by the hardware and the corresponding interrupt flag in RIS [RIS] and MIS [MIS] are cleared as well. After a read from the CPU (not from the debug interface), the register is updated with the next highest priority interrupt, if none are pending, then it should display 0x0. Note: The number of DMACH is device dependent. Please consult the data sheet of the specific device to map which channel number is implemented. #### Figure 4-14. IIDX #### Table 4-20. IIDX Field Descriptions | D:4 | t Field Type Reset Description | | | | | | |------|--------------------------------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Bit | rieiu | Туре | Reset | Description | | | | 31-8 | RESERVED | R | 0h | | | | | 7-0 | STAT | R | Oh | Interrupt index status 00h = No bit is set means there is no pending interrupt request 01h = DMA Channel 0 size counter reached zero (DMASZ=0). 02h = DMA Channel 1 size counter reached zero (DMASZ=0). 03h = DMA Channel 2 size counter reached zero (DMASZ=0). 04h = DMA Channel 3 size counter reached zero (DMASZ=0). 05h = DMA Channel 4 size counter reached zero (DMASZ=0). 06h = DMA Channel 5 size counter reached zero (DMASZ=0). 07h = DMA Channel 6 size counter reached zero (DMASZ=0). 08h = DMA Channel 7 size counter reached zero (DMASZ=0). 09h = DMA Channel 8 size counter reached zero (DMASZ=0). 09h = DMA Channel 9 size counter reached zero (DMASZ=0). 08h = DMA Channel 10 size counter reached zero (DMASZ=0). 06h = DMA Channel 11 size counter reached zero (DMASZ=0). 06h = DMA Channel 12 size counter reached zero (DMASZ=0). 06h = DMA Channel 13 size counter reached zero (DMASZ=0). 07h = DMA Channel 14 size counter reached zero (DMASZ=0). 07h = DMA Channel 15 size counter reached zero (DMASZ=0). 17h = PRE-IRQ event for DMA Channel 0. 17h = PRE-IRQ event for DMA Channel 1. 17h = PRE-IRQ event for DMA Channel 2. 17h = PRE-IRQ event for DMA Channel 3. 17h = PRE-IRQ event for DMA Channel 5. 17h = PRE-IRQ event for DMA Channel 6. 18h = PRE-IRQ event for DMA Channel 7. 19h = DMA address error, SRC address not reachable. 17h = DMA data error, SRC data might be corrupted (PAR or ECC error). | | | # 4.3.12 IMASK (Offset = 1058h) [Reset = 00000000h] IMASK is shown in Figure 4-15 and described in Table 4-21. Return to the Summary Table. Interrupt Mask. If a bit is set, then the corresponding interrupt is un-masked. Un-masking the interrupt causes the raw interrupt to be visible in IIDX [IIDX], as well as MIS [MIS]. Note: The number of DMACH is device dependent. Please consult the data sheet of the specific device to map which channel number is implemented. Figure 4-15. IMASK | rigare 4 to: mixore | | | | | | | | |---------------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | RESERVED | | | | | | | ADDRERR | | R/W-0h | | | | | | R/W-0h | R/W-0h | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | PREIRQCH7 | PREIRQCH6 | PREIRQCH5 | PREIRQCH4 | PREIRQCH3 | PREIRQCH2 | PREIRQCH1 | PREIRQCH0 | | R/W-0h | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | DMACH15 | DMACH14 | DMACH13 | DMACH12 | DMACH11 | DMACH10 | DMACH9 | DMACH8 | | R/W-0h | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | DMACH7 | DMACH6 | DMACH5 | DMACH4 | DMACH3 | DMACH2 | DMACH1 | DMACH0 | | R/W-0h # **Table 4-21. IMASK Field Descriptions** | Bit | Field | Туре | Reset | Description | | | |-------|-----------|------|-------|-----------------------------------------------------------------------------------------------------------------------------|--|--| | 31-26 | RESERVED | R/W | 0h | | | | | 25 | DATAERR | R/W | 0h | DMA data error, SRC data might be corrupted (PAR or ECC error). 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | | | 24 | ADDRERR | R/W | 0h | DMA address error, SRC address not reachable. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | | | 23 | PREIRQCH7 | R/W | 0h | Pre-IRQ for Channel 7. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | | | 22 | PREIRQCH6 | R/W | 0h | Pre-IRQ for Channel 6. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | | | 21 | PREIRQCH5 | R/W | 0h | Pre-IRQ for Channel 5. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | | | 20 | PREIRQCH4 | R/W | 0h | Pre-IRQ for Channel 4. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | | | 19 | PREIRQCH3 | R/W | 0h | Pre-IRQ for Channel 3. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | | | 18 | PREIRQCH2 | R/W | 0h | Pre-IRQ for Channel 2. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | | | 17 | PREIRQCH1 | R/W | 0h | Pre-IRQ for Channel 1. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | | # **Table 4-21. IMASK Field Descriptions (continued)** | D:4 | Field | | | Descriptions (continued) | | | |-----|-----------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------|--|--| | Bit | Field | Туре | Reset | Description | | | | 16 | PREIRQCH0 | R/W | 0h | Pre-IRQ for Channel 0. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | | | 15 | DMACH15 | R/W | 0h | DMA Channel 15 interrupt signal. Size counter reached zero (DMASZ=0). Oh = Clear interrupt mask bit 1h = Set interrupt mask bit | | | | 14 | DMACH14 | R/W | 0h | DMA Channel 14 interrupt signal. Size counter reached zero (DMASZ=0). Oh = Clear interrupt mask bit 1h = Set interrupt mask bit | | | | 13 | DMACH13 | R/W | 0h | DMA Channel 13 interrupt signal. Size counter reached zero (DMASZ=0). Oh = Clear interrupt mask bit 1h = Set interrupt mask bit | | | | 12 | DMACH12 | R/W | Oh | DMA Channel 12 interrupt signal. Size counter reached zero (DMASZ=0). Oh = Clear interrupt mask bit 1h = Set interrupt mask bit | | | | 11 | DMACH11 | R/W | 0h | DMA Channel 11 interrupt signal. Size counter reached zero (DMASZ=0). Oh = Clear interrupt mask bit 1h = Set interrupt mask bit | | | | 10 | DMACH10 | R/W | 0h | DMA Channel 10 interrupt signal. Size counter reached zero (DMASZ=0). Oh = Clear interrupt mask bit 1h = Set interrupt mask bit | | | | 9 | DMACH9 | R/W | Oh | DMA Channel 9 interrupt signal. Size counter reached zero (DMASZ=0). Oh = Clear interrupt mask bit 1h = Set interrupt mask bit | | | | 8 | DMACH8 | R/W | 0h | DMA Channel 8 interrupt signal. Size counter reached zero (DMASZ=0). 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | | | 7 | DMACH7 | R/W | 0h | DMA Channel 7 interrupt signal. Size counter reached zero (DMASZ=0). 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | | | 6 | DMACH6 | R/W | 0h | DMA Channel 6 interrupt signal. Size counter reached zero (DMASZ=0). 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | | | 5 | DMACH5 | R/W | 0h | DMA Channel 5 interrupt signal. Size counter reached zero (DMASZ=0). 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | | | 4 | DMACH4 | R/W | Oh | DMA Channel 4 interrupt signal. Size counter reached zero (DMASZ=0). Oh = Clear interrupt mask bit 1h = Set interrupt mask bit | | | | 3 | DMACH3 | R/W | 0h | DMA Channel 3 interrupt signal. Size counter reached zero (DMASZ=0). Oh = Clear interrupt mask bit 1h = Set interrupt mask bit | | | | 2 | DMACH2 | R/W | Oh | DMA Channel 2 interrupt signal. Size counter reached zero (DMASZ=0). Oh = Clear interrupt mask bit 1h = Set interrupt mask bit | | | # **Table 4-21. IMASK Field Descriptions (continued)** | Bit | Field | Туре | Reset | Description | |-----|--------|------|-------|----------------------------------------------------------------------------------------------------------------------------------| | 1 | DMACH1 | R/W | 0h | DMA Channel 1 interrupt signal. Size counter reached zero (DMASZ=0). 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | 0 | DMACH0 | R/W | 0h | DMA Channel 0 interrupt signal. Size counter reached zero (DMASZ=0). 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | ## 4.3.13 RIS (Offset = 1060h) [Reset = 00000000h] RIS is shown in Figure 4-16 and described in Table 4-22. Return to the Summary Table. Raw interrupt status. Reflects all pending interrupts, regardless of masking. The RIS register allows the user to implement a poll scheme. A flag set in this register can be cleared by writing 1 to the ICLR [ICLR] register bit even if the corresponding IMASK [IMASK] bit is not enabled. Note: The number of DMACH is device dependent. Please consult the data sheet of the specific device to map which channel number is implemented. Figure 4-16. RIS | | | | 1 19410 1 | | | | | |-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | DATAERR | ADDRERR | | | | | | | | R- | 0h | | | R-0h | R-0h | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | PREIRQCH7 | PREIRQCH6 | PREIRQCH5 | PREIRQCH4 | PREIRQCH3 | PREIRQCH2 | PREIRQCH1 | PREIRQCH0 | | R-0h | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | DMACH15 | DMACH14 | DMACH13 | DMACH12 | DMACH11 | DMACH10 | DMACH9 | DMACH8 | | R-0h | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | DMACH7 | DMACH6 | DMACH5 | DMACH4 | DMACH3 | DMACH2 | DMACH1 | DMACH0 | | R-0h ## **Table 4-22. RIS Field Descriptions** | Bit | Field | Туре | Reset | Description | |-------|-----------|------|-------|----------------------------------------------------------------------------------------------------------------------------| | 31-26 | RESERVED | R | 0h | | | 25 | DATAERR | R | 0h | DMA data error, SRC data might be corrupted (PAR or ECC error). 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | 24 | ADDRERR | R | 0h | DMA address error, SRC address not reachable. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | 23 | PREIRQCH7 | R | 0h | Pre-IRQ for Channel 7. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | 22 | PREIRQCH6 | R | 0h | Pre-IRQ for Channel 6. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | 21 | PREIRQCH5 | R | 0h | Pre-IRQ for Channel 5. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | 20 | PREIRQCH4 | R | 0h | Pre-IRQ for Channel 4. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | 19 | PREIRQCH3 | R | 0h | Pre-IRQ for Channel 3. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | 18 | PREIRQCH2 | R | Oh | Pre-IRQ for Channel 2. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | 17 | PREIRQCH1 | R | 0h | Pre-IRQ for Channel 1. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | # **Table 4-22. RIS Field Descriptions (continued)** | | | | | Descriptions (continued) | |-----|-----------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------| | Bit | Field | Туре | Reset | Description | | 16 | PREIRQCH0 | R | Oh | Pre-IRQ for Channel 0. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | 15 | DMACH15 | R | Oh | DMA Channel 15 interrupt signals that size counter reached zero (DMASZ=0). Oh = Interrupt did not occur Th = Interrupt occurred | | 14 | DMACH14 | R | Oh | DMA Channel 14 interrupt signals that size counter reached zero (DMASZ=0). Oh = Interrupt did not occur 1h = Interrupt occurred | | 13 | DMACH13 | R | 0h | DMA Channel 13 interrupt signals that size counter reached zero (DMASZ=0). Oh = Interrupt did not occur 1h = Interrupt occurred | | 12 | DMACH12 | R | Oh | DMA Channel 12 interrupt signals that size counter reached zero (DMASZ=0). Oh = Interrupt did not occur 1h = Interrupt occurred | | 11 | DMACH11 | R | Oh | DMA Channel 11 interrupt signals that size counter reached zero (DMASZ=0). Oh = Interrupt did not occur 1h = Interrupt occurred | | 10 | DMACH10 | R | Oh | DMA Channel 10 interrupt signals that size counter reached zero (DMASZ=0). Oh = Interrupt did not occur 1h = Interrupt occurred | | 9 | DMACH9 | R | 0h | DMA Channel 9 interrupt signals that size counter reached zero (DMASZ=0). Oh = Interrupt did not occur 1h = Interrupt occurred | | 8 | DMACH8 | R | Oh | DMA Channel 8 interrupt signals that size counter reached zero (DMASZ=0). Oh = Interrupt did not occur 1h = Interrupt occurred | | 7 | DMACH7 | R | Oh | DMA Channel 7 interrupt signals that size counter reached zero (DMASZ=0). Oh = Interrupt did not occur 1h = Interrupt occurred | | 6 | DMACH6 | R | Oh | DMA Channel 6 interrupt signals that size counter reached zero (DMASZ=0). Oh = Interrupt did not occur 1h = Interrupt occurred | | 5 | DMACH5 | R | Oh | DMA Channel 5 interrupt signals that size counter reached zero (DMASZ=0). Oh = Interrupt did not occur 1h = Interrupt occurred | | 4 | DMACH4 | R | Oh | DMA Channel 4 interrupt signals that size counter reached zero (DMASZ=0). Oh = Interrupt did not occur 1h = Interrupt occurred | | 3 | DMACH3 | R | Oh | DMA Channel 3 interrupt signals that size counter reached zero (DMASZ=0). Oh = Interrupt did not occur 1h = Interrupt occurred | | 2 | DMACH2 | R | Oh | DMA Channel 2 interrupt signals that size counter reached zero (DMASZ=0). Oh = Interrupt did not occur 1h = Interrupt occurred | # **Table 4-22. RIS Field Descriptions (continued)** | Bit | Field | Туре | Reset | Description | |-----|--------|------|-------|----------------------------------------------------------------------------------------------------------------------------------| | 1 | DMACH1 | R | 0h | DMA Channel 1 interrupt signals that size counter reached zero (DMASZ=0). 0h = Interrupt did not occur 1h = Interrupt occurred | | 0 | DMACH0 | R | 0h | DMA Channel 0 interrupt signals that size counter reached zero (DMASZ=0). 0h = Interrupt did not occur 1h = Interrupt occurred | ## 4.3.14 MIS (Offset = 1068h) [Reset = 00000000h] MIS is shown in Figure 4-17 and described in Table 4-23. Return to the Summary Table. Masked interrupt status. This is an AND of the IMASK [IMASK] and RIS [RIS] registers. Note: The number of DMACH is device dependent. Please consult the data sheet of the specific device to map which channel number is implemented. Figure 4-17. MIS | | | | 1 19410 1 | | | | | | | |-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|--|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | RESERVED | | | | | | | | | | | | R- | 0h | | | R-0h | R-0h | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | PREIRQCH7 | PREIRQCH6 | PREIRQCH5 | PREIRQCH4 | PREIRQCH3 | PREIRQCH2 | PREIRQCH1 | PREIRQCH0 | | | | R-0h | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | DMACH15 | DMACH14 | DMACH13 | DMACH12 | DMACH11 | DMACH10 | DMACH9 | DMACH8 | | | | R-0h | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | DMACH7 | DMACH6 | DMACH5 | DMACH4 | DMACH3 | DMACH2 | DMACH1 | DMACH0 | | | | R-0h | | ## **Table 4-23. MIS Field Descriptions** | Bit | Field | Туре | Reset | Description | | |-------|-----------|------|-------|----------------------------------------------------------------------------------------------------------------------------|--| | 31-26 | RESERVED | R | 0h | | | | 25 | DATAERR | R | 0h | DMA data error, SRC data might be corrupted (PAR or ECC error). 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | | 24 | ADDRERR | R | 0h | DMA address error, SRC address not reachable. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | | 23 | PREIRQCH7 | R | 0h | Pre-IRQ for Channel 7. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | | 22 | PREIRQCH6 | R | 0h | Pre-IRQ for Channel 6. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | | 21 | PREIRQCH5 | R | 0h | Pre-IRQ for Channel 5. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | | 20 | PREIRQCH4 | R | 0h | Pre-IRQ for Channel 4. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | | 19 | PREIRQCH3 | R | Oh | Pre-IRQ for Channel 3. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | | 18 | PREIRQCH2 | R | 0h | Pre-IRQ for Channel 2. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | | 17 | PREIRQCH1 | R | 0h | Pre-IRQ for Channel 1. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | # **Table 4-23. MIS Field Descriptions (continued)** | Bit | Field | Туре | Reset | Descriptions (continued) Description | |-----|-----------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------| | 16 | PREIRQCH0 | R | 0h | Pre-IRQ for Channel 0. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | 15 | DMACH15 | R | Oh | DMA Channel 15 interrupt signals that size counter reached zero (DMASZ=0). Oh = Interrupt did not occur or is masked out 1h = Interrupt occurred | | 14 | DMACH14 | R | 0h | DMA Channel 14 interrupt signals that size counter reached zero (DMASZ=0). Oh = Interrupt did not occur or is masked out 1h = Interrupt occurred | | 13 | DMACH13 | R | 0h | DMA Channel 13 interrupt signals that size counter reached zero (DMASZ=0). Oh = Interrupt did not occur or is masked out 1h = Interrupt occurred | | 12 | DMACH12 | R | Oh | DMA Channel 12 interrupt signals that size counter reached zero (DMASZ=0). Oh = Interrupt did not occur or is masked out 1h = Interrupt occurred | | 11 | DMACH11 | R | Oh | DMA Channel 11 interrupt signals that size counter reached zero (DMASZ=0). Oh = Interrupt did not occur or is masked out 1h = Interrupt occurred | | 10 | DMACH10 | R | Oh | DMA Channel 10 interrupt signals that size counter reached zero (DMASZ=0). Oh = Interrupt did not occur or is masked out 1h = Interrupt occurred | | 9 | DMACH9 | R | Oh | DMA Channel 9 interrupt signals that size counter reached zero (DMASZ=0). Oh = Interrupt did not occur or is masked out 1h = Interrupt occurred | | 8 | DMACH8 | R | Oh | DMA Channel 8 interrupt signals that size counter reached zero (DMASZ=0). Oh = Interrupt did not occur or is masked out 1h = Interrupt occurred | | 7 | DMACH7 | R | Oh | DMA Channel 7 interrupt signals that size counter reached zero (DMASZ=0). Oh = Interrupt did not occur or is masked out 1h = Interrupt occurred | | 6 | DMACH6 | R | Oh | DMA Channel 6 interrupt signals that size counter reached zero (DMASZ=0). Oh = Interrupt did not occur or is masked out 1h = Interrupt occurred | | 5 | DMACH5 | R | Oh | DMA Channel 5 interrupt signals that size counter reached zero (DMASZ=0). Oh = Interrupt did not occur or is masked out 1h = Interrupt occurred | | 4 | DMACH4 | R | Oh | DMA Channel 4 interrupt signals that size counter reached zero (DMASZ=0). Oh = Interrupt did not occur or is masked out 1h = Interrupt occurred | | 3 | DMACH3 | R | Oh | DMA Channel 3 interrupt signals that size counter reached zero (DMASZ=0). Oh = Interrupt did not occur or is masked out 1h = Interrupt occurred | | 2 | DMACH2 | R | Oh | DMA Channel 2 interrupt signals that size counter reached zero (DMASZ=0). Oh = Interrupt did not occur or is masked out 1h = Interrupt occurred | # **Table 4-23. MIS Field Descriptions (continued)** | Bit | Field | Туре | Reset | Description | |-----|--------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------| | 1 | DMACH1 | R | 0h | DMA Channel 1 interrupt signals that size counter reached zero (DMASZ=0). 0h = Interrupt did not occur or is masked out 1h = Interrupt occurred | | 0 | DMACH0 | R | 0h | DMA Channel 0 interrupt signals that size counter reached zero (DMASZ=0). 0h = Interrupt did not occur or is masked out 1h = Interrupt occurred | ## 4.3.15 ISET (Offset = 1070h) [Reset = 00000000h] ISET is shown in Figure 4-18 and described in Table 4-24. Return to the Summary Table. Interrupt set. Allows interrupts to be set by software (useful in diagnostics and safety checks). Writing a 1 to a bit in ISET will set the event and therefore the related RIS [RIS] bit also gets set. If the interrupt is enabled through the mask, then the corresponding MIS [MIS] bit is also set. Note: The number of DMACH is device dependent. Please consult the data sheet of the specific device to map which channel number is implemented. Figure 4-18. ISET | | | | . igaio i | | | | | |-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | DATAERR | ADDRERR | | | | | | | | W- | -0h | | | W-0h | W-0h | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | PREIRQCH7 | PREIRQCH6 | PREIRQCH5 | PREIRQCH4 | PREIRQCH3 | PREIRQCH2 | PREIRQCH1 | PREIRQCH0 | | W-0h | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | DMACH15 | DMACH14 | DMACH13 | DMACH12 | DMACH11 | DMACH10 | DMACH9 | DMACH8 | | W-0h | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | DMACH7 | DMACH6 | DMACH5 | DMACH4 | DMACH3 | DMACH2 | DMACH1 | DMACH0 | | W-0h **Table 4-24. ISET Field Descriptions** | Bit | Field | Туре | Reset | Description | |-------|-----------|------|-------|----------------------------------------------------------------------------------------------------------------------------| | 31-26 | RESERVED | W | 0h | | | 25 | DATAERR | W | 0h | DMA data error, SRC data might be corrupted (PAR or ECC error). 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | 24 | ADDRERR | W | 0h | DMA address error, SRC address not reachable. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | 23 | PREIRQCH7 | W | 0h | Pre-IRQ for Channel 7. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | 22 | PREIRQCH6 | W | 0h | Pre-IRQ for Channel 6. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | 21 | PREIRQCH5 | W | 0h | Pre-IRQ for Channel 5. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | 20 | PREIRQCH4 | W | 0h | Pre-IRQ for Channel 4. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | 19 | PREIRQCH3 | W | 0h | Pre-IRQ for Channel 3. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | 18 | PREIRQCH2 | W | Oh | Pre-IRQ for Channel 2. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | 17 | PREIRQCH1 | W | 0h | Pre-IRQ for Channel 1. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | # **Table 4-24. ISET Field Descriptions (continued)** | | | | | Descriptions (continued) | |-----|-----------|------|-------|------------------------------------------------------------------------------------------------------------------------------| | Bit | Field | Туре | Reset | Description | | 16 | PREIRQCH0 | W | 0h | Pre-IRQ for Channel 0. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | 15 | DMACH15 | W | Oh | DMA Channel 0 interrupt signals that size counter reached zero (DMASZ=0). Oh = Writing 0 has no effect 1h = Set interrupt | | 14 | DMACH14 | W | Oh | DMA Channel 14 interrupt signals that size counter reached zero (DMASZ=0). Oh = Writing 0 has no effect 1h = Set interrupt | | 13 | DMACH13 | W | Oh | DMA Channel 13 interrupt signals that size counter reached zero (DMASZ=0). Oh = Writing 0 has no effect 1h = Set interrupt | | 12 | DMACH12 | W | Oh | DMA Channel 12 interrupt signals that size counter reached zero (DMASZ=0). Oh = Writing 0 has no effect 1h = Set interrupt | | 11 | DMACH11 | W | Oh | DMA Channel 11 interrupt signals that size counter reached zero (DMASZ=0). Oh = Writing 0 has no effect 1h = Set interrupt | | 10 | DMACH10 | W | Oh | DMA Channel 0 interrupt signals that size counter reached zero (DMASZ=0). Oh = Writing 0 has no effect 1h = Set interrupt | | 9 | DMACH9 | W | Oh | DMA Channel 9 interrupt signals that size counter reached zero (DMASZ=0). Oh = Writing 0 has no effect 1h = Set interrupt | | 8 | DMACH8 | W | Oh | DMA Channel 8 interrupt signals that size counter reached zero (DMASZ=0). Oh = Writing 0 has no effect 1h = Set interrupt | | 7 | DMACH7 | W | Oh | DMA Channel 7 interrupt signals that size counter reached zero (DMASZ=0). Oh = Writing 0 has no effect 1h = Set interrupt | | 6 | DMACH6 | W | Oh | DMA Channel 6 interrupt signals that size counter reached zero (DMASZ=0). Oh = Writing 0 has no effect 1h = Set interrupt | | 5 | DMACH5 | W | Oh | DMA Channel 5 interrupt signals that size counter reached zero (DMASZ=0). Oh = Writing 0 has no effect 1h = Set interrupt | | 4 | DMACH4 | W | Oh | DMA Channel 4 interrupt signals that size counter reached zero (DMASZ=0). Oh = Writing 0 has no effect 1h = Set interrupt | | 3 | DMACH3 | W | Oh | DMA Channel 3 interrupt signals that size counter reached zero (DMASZ=0). Oh = Writing 0 has no effect 1h = Set interrupt | | 2 | DMACH2 | W | Oh | DMA Channel 2 interrupt signals that size counter reached zero (DMASZ=0). Oh = Writing 0 has no effect 1h = Set interrupt | # Table 4-24. ISET Field Descriptions (continued) | Bit | Field | Туре | Reset | Description | |-----|--------|------|-------|----------------------------------------------------------------------------------------------------------------------------| | 1 | DMACH1 | W | Oh | DMA Channel 1 interrupt signals that size counter reached zero (DMASZ=0). 0h = Writing 0 has no effect 1h = Set interrupt | | 0 | DMACH0 | W | Oh | DMA Channel 0 interrupt signals that size counter reached zero (DMASZ=0). 0h = Writing 0 has no effect 1h = Set interrupt | ## 4.3.16 ICLR (Offset = 1078h) [Reset = 00000000h] ICLR is shown in Figure 4-19 and described in Table 4-25. Return to the Summary Table. Interrupt clear. Write a 1 to clear corresponding Interrupt. Note: The number of DMACH is device dependent. Please consult the data sheet of the specific device to map which channel number is implemented. Figure 4-19. ICLR | | | | 9 | | | | | |-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | DATAERR | ADDRERR | | | | | | | | W-0h | W-0h | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | PREIRQCH7 | PREIRQCH6 | PREIRQCH5 | PREIRQCH4 | PREIRQCH3 | PREIRQCH2 | PREIRQCH1 | PREIRQCH0 | | W-0h | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | DMACH15 | DMACH14 | DMACH13 | DMACH12 | DMACH11 | DMACH10 | DMACH9 | DMACH8 | | W-0h | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | DMACH7 | DMACH6 | DMACH5 | DMACH4 | DMACH3 | DMACH2 | DMACH1 | DMACH0 | | W-0h ## **Table 4-25. ICLR Field Descriptions** | Bit | Field | Туре | Reset | Description | |-------|-----------|------|-------|-----------------------------------------------------------------------------------------------------------------------------| | 31-26 | RESERVED | W | 0h | · | | 25 | DATAERR | W | Oh | DMA data error, SRC data might be corrupted (PAR or ECC error). 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | 24 | ADDRERR | W | Oh | DMA address error, SRC address not reachable. Oh = Clear interrupt mask bit 1h = Set interrupt mask bit | | 23 | PREIRQCH7 | W | 0h | Pre-IRQ for Channel 7. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | 22 | PREIRQCH6 | W | Oh | Pre-IRQ for Channel 6. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | 21 | PREIRQCH5 | W | Oh | Pre-IRQ for Channel 5. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | 20 | PREIRQCH4 | W | Oh | Pre-IRQ for Channel 4. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | 19 | PREIRQCH3 | W | Oh | Pre-IRQ for Channel 3. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | 18 | PREIRQCH2 | W | Oh | Pre-IRQ for Channel 2. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | 17 | PREIRQCH1 | W | Oh | Pre-IRQ for Channel 1. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | # **Table 4-25. ICLR Field Descriptions (continued)** | Bit | Field | Туре | Reset | Descriptions (continued) | |-----|-----------|------|-------|--------------------------------------------------------------------------------------------------------------------------------| | 16 | PREIRQCH0 | W | 0h | Pre-IRQ for Channel 0. Size counter reached Pre-IRQ threshold. 0h = Clear interrupt mask bit 1h = Set interrupt mask bit | | 15 | DMACH15 | W | 0h | DMA Channel 15 interrupt signals that size counter reached zero (DMASZ=0). Oh = Writing 0 has no effect 1h = Clear interrupt | | 14 | DMACH14 | W | 0h | DMA Channel 14 interrupt signals that size counter reached zero (DMASZ=0). Oh = Writing 0 has no effect 1h = Clear interrupt | | 13 | DMACH13 | W | 0h | DMA Channel 13 interrupt signals that size counter reached zero (DMASZ=0). 0h = Writing 0 has no effect 1h = Clear interrupt | | 12 | DMACH12 | W | Oh | DMA Channel 12 interrupt signals that size counter reached zero (DMASZ=0). Oh = Writing 0 has no effect 1h = Clear interrupt | | 11 | DMACH11 | W | 0h | DMA Channel 11 interrupt signals that size counter reached zero (DMASZ=0). Oh = Writing 0 has no effect 1h = Clear interrupt | | 10 | DMACH10 | W | 0h | DMA Channel 10 interrupt signals that size counter reached zero (DMASZ=0). Oh = Writing 0 has no effect 1h = Clear interrupt | | 9 | DMACH9 | W | 0h | DMA Channel 9 interrupt signals that size counter reached zero (DMASZ=0). Oh = Writing 0 has no effect 1h = Clear interrupt | | 8 | DMACH8 | W | 0h | DMA Channel 8 interrupt signals that size counter reached zero (DMASZ=0). Oh = Writing 0 has no effect 1h = Clear interrupt | | 7 | DMACH7 | W | 0h | DMA Channel 7 interrupt signals that size counter reached zero (DMASZ=0). Oh = Writing 0 has no effect 1h = Clear interrupt | | 6 | DMACH6 | W | 0h | DMA Channel 6 interrupt signals that size counter reached zero (DMASZ=0). Oh = Writing 0 has no effect 1h = Clear interrupt | | 5 | DMACH5 | W | 0h | DMA Channel 5 interrupt signals that size counter reached zero (DMASZ=0). Oh = Writing 0 has no effect 1h = Clear interrupt | | 4 | DMACH4 | W | Oh | DMA Channel 4 interrupt signals that size counter reached zero (DMASZ=0). Oh = Writing 0 has no effect 1h = Clear interrupt | | 3 | DMACH3 | W | Oh | DMA Channel 3 interrupt signals that size counter reached zero (DMASZ=0). Oh = Writing 0 has no effect 1h = Clear interrupt | | 2 | DMACH2 | W | Oh | DMA Channel 2 interrupt signals that size counter reached zero (DMASZ=0). Oh = Writing 0 has no effect 1h = Clear interrupt | # Table 4-25. ICLR Field Descriptions (continued) | Bit | Field | Туре | Reset | Description | |-----|--------|------|-------|------------------------------------------------------------------------------------------------------------------------------| | 1 | DMACH1 | W | Oh | DMA Channel 1 interrupt signals that size counter reached zero (DMASZ=0). 0h = Writing 0 has no effect 1h = Clear interrupt | | 0 | DMACH0 | W | Oh | DMA Channel 0 interrupt signals that size counter reached zero (DMASZ=0). 0h = Writing 0 has no effect 1h = Clear interrupt | ## 4.3.17 EVT\_MODE (Offset = 10E0h) [Reset = 00000009h] EVT\_MODE is shown in Figure 4-20 and described in Table 4-26. Return to the Summary Table. Event mode register. It is used to select whether each line is disabled, in software mode (software clears the RIS) or in hardware mode (hardware clears the RIS) Figure 4-20. EVT\_MODE ## Table 4-26. EVT\_MODE Field Descriptions | Bit | Field | Туре | Reset | Description | | | | |------|----------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | 31-4 | RESERVED | R/W | 0h | | | | | | 3-2 | EVT1_CFG | R | 2h | Event line mode select for event corresponding to generic event INT_EVENT[1] 0h = The interrupt or event line is disabled. 1h = The interrupt or event line is in software mode. Software must clear the RIS. 2h = The interrupt or event line is in hardware mode. The hardware (another module) clears automatically the associated RIS flag. | | | | | 1-0 | INT0_CFG | R | 1h | Event line mode select for event corresponding to interrupt event INT_EVENT[0] Oh = The interrupt or event line is disabled. 1h = The interrupt or event line is in software mode. Software must clear the RIS. 2h = The interrupt or event line is in hardware mode. The hardware (another module) clears automatically the associated RIS flag. | | | | # 4.3.18 DESC (Offset = 10FCh) [Reset = 2511F000h] DESC is shown in Figure 4-21 and described in Table 4-27. Return to the Summary Table. This register identifies the peripheral and its exact version. # Figure 4-21. DESC ## Table 4-27. DESC Field Descriptions | | Table 4 211 B200 1 lota B00011ptions | | | | | | | |-------|--------------------------------------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | 31-16 | MODULEID | R | 2511h | Module identification contains a unique peripheral identification number. The assignments are maintained in a central database for all of the platform modules to ensure uniqueness. 0h = Smallest value FFFFh = Highest possible value | | | | | 15-12 | FEATUREVER | R | Fh | Feature Set for the DMA: number of DMA channel minus one (e.g. 0->1ch, 2->3ch, 15->16ch). 0h = Smallest value (1 channel) Fh = Highest value (16 channel) | | | | | 11-8 | RESERVED | R | 0h | | | | | | 7-4 | MAJREV | R | Oh | Major rev of the IP 0h = Smallest value Fh = Highest possible value | | | | | 3-0 | MINREV | R | Oh | Minor rev of the IP 0h = Smallest value Fh = Highest possible value | | | | # 4.3.19 DMAPRIO (Offset = 1100h) [Reset = 00000000h] DMAPRIO is shown in Figure 4-22 and described in Table 4-28. Return to the Summary Table. **DMA Channel Priority Control** ## Figure 4-22. DMAPRIO ## **Table 4-28. DMAPRIO Field Descriptions** | Bit | Field | Туре | Reset | Description | |-------|------------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-18 | RESERVED | R/W | 0h | | | 17-16 | BURSTSZ | R/W | Oh | Define the burst size of a block transfer, before the priority is re- evaluated 0h = There is no burst size, the whole block transfer is completed on one transfer without interruption 1h = The burst size is 8, after 8 transfers the block transfer is interrupted and the priority is reevaluated 2h = The burst size is 16, after 16 transfers the block transfer is interrupted and the priority is reevaluated 3h = The burst size is 32, after 32 transfers the block transfer is interrupted and the priority is reevaluated | | 15-1 | RESERVED | R/W | 0h | | | 0 | ROUNDROBIN | R/W | Oh | Round robin. This bit enables the round-robin DMA channel priorities. 0h = Roundrobin priority disabled, DMA channel priority is fixed: DMA0-DMA1-DMA2DMA16 1h = Roundrobin priority enabled, DMA channel priority changes with each transfer | # 4.3.20 DMATCTL[j] (Offset = 1110h + formula) [Reset = 00000000h] DMATCTL[j] is shown in Figure 4-23 and described in Table 4-29. Return to the Summary Table. **DMA Trigger Control** Offset = 1110h + (j \* 4h); where j = 0h to Fh Figure 4-23. DMATCTL[j] Table 4-29. DMATCTL[j] Field Descriptions | | | | | | <b>U</b> 1 | |---|-----|----------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | E | 3it | Field | Туре | Reset | Description | | 3 | 1-8 | RESERVED | R/W | 0h | | | | 7 | DMATINT | R/W | Oh | DMA Trigger by Internal Channel 0h = DMATSEL will define external trigger select as transfer trigger. 1h = DMATSEL will define internal channel as transfer trigger select. 0-> Channel0-done, 1-> Channel1-done, | | | 6 | RESERVED | R/W | 0h | | | 5 | i-0 | DMATSEL | R/W | 0h | DMA Trigger Select Note: Reference the data sheet of the device to see the specific trigger mapping. 00h = Software trigger request 3Fh = Highest possible value | # 4.3.21 DMACTL[j] (Offset = 1200h + formula) [Reset = 00000000h] DMACTL[j] is shown in Figure 4-24 and described in Table 4-30. Return to the Summary Table. **DMA Channel Control** Offset = 1200h + (j \* 10h); where j = 0h to Fh ## Figure 4-24. DMACTL[j] | | | | 9 | []] | | | | | |----------|-------------|-----------|-------|---------------------|--------|--------|--------|--| | 31 | 30 | 29 28 | | 27 | 26 | 25 | 24 | | | RESE | RVED | DM. | ATM | RESERVED DMAEM | | | AEM | | | R/\ | R/W- R/W-0h | | | R/ | R/W-0h | | | | | 23 | 22 | 21 20 | | 19 | 18 | 17 | 16 | | | | DMAD | STINCR | | | DMASR | CINCR | | | | R/W-0h | | | | R/W-0h | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | RESE | RVED | DMADS | TWDTH | RESERVED DMASRCWDTH | | | CWDTH | | | R/\ | W- | R/V | V-0h | R/W- | | R/V | R/W-0h | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | RESERVED | | DMAPREIRQ | | | RVED | DMAEN | DMAREQ | | | R/W- | R/W-0h | | | R/ | W- | R/W-0h | R/W-0h | | ## Table 4-30. DMACTL[j] Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-30 | RESERVED | R/W | 0h | | | 29-28 | DMATM | R/W | Oh | DMA transfer mode register Note: The repeat-single (2h) and repeat-block (3h) transfer are only available in a FULL-channel configuration. Please consult the data sheet of the specific device to map which channel number has FULL or BASIC capability. In a BASIC channel configuration only the values for single (0h) and block (1h) transfer can be set. Oh = Single transfer. Each transfers requires a new trigger. When the DMASZ counts down to zero an event can be generated and the DMAEN is cleared. 1h = Block transfer. Each trigger transfers the complete block defined in DMASZ. After the transfer is complete an event can be generated and the DMAEN is cleared. 2h = Repeated single transfer. Each transfers requires a new trigger. When the DMASZ counts down to zero an event can be generated. After the last transfer the DMASA, DMADA, DAMSZ registers are restored to its initial value and the DMAEN stays enabled. 3h = Repeated block transfer. Each trigger transfers the complete block defined in DMASZ. After the last transfer the DMASA, DMADA, DAMSZ registers are restored to its initial value and the DMAEN stays enabled. | | 27-26 | RESERVED | R/W | 0h | | | 25-24 | DMAEM | R/W | Oh | DMA extended mode Note: The extended transfer modes are only available in a FULL- channel configuration. Please consult the data sheet of the specific device to map which channel number has FULL or BASIC capability. In a BASIC channel configuration this register is a read-only register and reads 0x0. 0h = Normal mode is related to transfers from SRC to DST 2h = Fill mode will copy the SA register content as data to DA 3h = Table mode will read an address and data value from SA and write the data to address | # Table 4-30. DMACTL[j] Field Descriptions (continued) | Bit | Field | Туре | Reset | Description | | |-------|------------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | 23-20 | DMADSTINCR | R/W | Oh | DMA destination increment. This bit selects automatic incrementing or decrementing of the destination address DMADA for each transfer. The amount of change to the DMADA is based on the definitin in the DMADSTWDTH. For example an increment of 1 (+1) on a WORD transfer will increment the DMADA by 4. 0h = Address is unchanged (+0) 2h = Decremented by 1 (-1 * DMADSTWDTH) 3h = Incremented by 1 (+1 * DMADSTWDTH) 8h = Stride size 2 (+2 * DMADSTWDTH) 9h = Stride size 3 (+3 * DMADSTWDTH) Ah = Stride size 4 (+4 * DMADSTWDTH) Bh = Stride size 5 (+5 * DMADSTWDTH) Ch = Stride size 6 (+6 * DMADSTWDTH) Dh = Stride size 7 (+7 * DMADSTWDTH) Eh = Stride size 8 (+8 * DMADSTWDTH) Fh = Stride size 9 (+9 * DMADSTWDTH) | | | 19-16 | DMASRCINCR | R/W | Oh | DMA source increment. This bit selects automatic incrementing or decrementing of the source address DMASA for each transfer. The amount of change to the DMASA is based on the definitin in the DMASRCWDTH. For example an increment of 1 (+1) on a WORD transfer will increment the DMASA by 4. Oh = Address is unchanged (+0) 2h = Decremented by 1 (-1 * DMASRCWDTH) 3h = Incremented by 1 (+1 * DMASRCWDTH) 8h = Stride size 2 (+2 * DMASRCWDTH) 9h = Stride size 3 (+3 * DMASRCWDTH) Ah = Stride size 4 (+4 * DMASRCWDTH) Bh = Stride size 5 (+5 * DMASRCWDTH) Ch = Stride size 6 (+6 * DMASRCWDTH) Dh = Stride size 7 (+7 * DMASRCWDTH) Eh = Stride size 8 (+8 * DMASRCWDTH) Fh = Stride size 9 (+9 * DMASRCWDTH) | | | 15-14 | RESERVED | R/W | 0h | | | | 13-12 | DMADSTWDTH | R/W | Oh | DMA destination width. This bit selects the destination as a byte, haword, word or long word. 0h = Destination data width is BYTE (8-bit) 1h = Destination data width is HALF-WORD (16-bit) 2h = Destination data width is WORD (32-bit) 3h = Destination data width is LONG-WORD (64-bit) | | | 11-10 | RESERVED | R/W | 0h | | | | 9-8 | DMASRCWDTH | R/W | Oh | DMA source width. This bit selects the source data width as a byte, half word, word or long word. 0h = Source data width is BYTE (8-bit) 1h = Source data width is HALF-WORD (16-bit) 2h = Source data width is WORD (32-bit) 3h = Source data width is LONG-WORD (64-bit) | | | 7 | RESERVED | R/W | 0h | | | # Table 4-30. DMACTL[j] Field Descriptions (continued) | | Table 4-50. District Light lend bescriptions (continued) | | | | | | | | |-----|----------------------------------------------------------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | | 6-4 | DMAPREIRQ | R/W | Oh | Enable an early IRQ event. This can help software to react quicker to and DMA done event or allows some additional configuration before the channel is complete. Note: This register is only available in a FULL-channel configuration Please consult the data sheet of the specific device to map which channel number has FULL or BASIC capability. In a BASIC configuration this register is a read only value and always reads as 0x0. 0h = Pre-IRQ event disabled. 1h = Issure Pre-IRQ event when DMASZ=1 2h = Issure Pre-IRQ event when DMASZ=2 3h = Issure Pre-IRQ event when DMASZ=4 4h = Issure Pre-IRQ event when DMASZ=8 5h = Issure Pre-IRQ event when DMASZ=32 6h = Issure Pre-IRQ event when DMASZ=64 7h = Issure Pre-IRQ event when DMASZ reached the half size point of the original transfer size | | | | | | 3-2 | RESERVED | R/W | 0h | | | | | | | 1 | DMAEN | R/W | Oh | DMA enable 0h = DMA channel disabled 1h = DMA channel enabled | | | | | | 0 | DMAREQ | R/W | 0h | DMA request. Software-controlled DMA start. DMAREQ is reset automatically. 0h = Default read value 1h = DMA transfer request (start DMA) | | | | | # 4.3.22 DMASA[j] (Offset = 1204h + formula) [Reset = 00000000h] DMASA[j] is shown in Figure 4-25 and described in Table 4-31. Return to the Summary Table. **DMA Channel Source Address** Offset = 1204h + (j \* 10h); where j = 0h to Fh ## Figure 4-25. DMASA[j] Table 4-31. DMASA[j] Field Descriptions | Bit | Field | Туре | Reset | Description | | | |------|-------|------|---------------------|-----------------------------------|--|--| | 31-0 | ADDR | R/W | 0h | DMA Channel Source Address | | | | | | | 0h = Smallest value | | | | | | | | | FFFFFFFh = Highest possible value | | | ## 4.3.23 DMADA[j] (Offset = 1208h + formula) [Reset = 00000000h] DMADA[j] is shown in Figure 4-26 and described in Table 4-32. Return to the Summary Table. **DMA Channel Destination Address** Offset = 1208h + (j \* 10h); where j = 0h to Fh ## Figure 4-26. DMADA[j] # Table 4-32. DMADA[j] Field Descriptions | <del></del> | | | | | | | |-------------|-------|------|---------------------|-----------------------------------|--|--| | Bit | Field | Туре | Reset | Description | | | | 31-0 | ADDR | R/W | 0h | h DMA Channel Destination Address | | | | | | | 0h = Smallest value | | | | | | | | | FFFFFFFh = Highest possible value | | | # 4.3.24 DMASZ[j] (Offset = 120Ch + formula) [Reset = 00000000h] DMASZ[j] is shown in Figure 4-27 and described in Table 4-33. Return to the Summary Table. **DMA Channel Size** Offset = 120Ch + (j \* 10h); where j = 0h to Fh ## Figure 4-27. DMASZ[j] Table 4-33. DMASZ[j] Field Descriptions | Bit | Field | Туре | Reset | Description | | |-------|----------|------|-------|----------------------------------------------------------------------------------------------|--| | 31-16 | RESERVED | R/W | 0h | | | | 15-0 | SIZE | R/W | | DMA Channel Size in number of transfers 0h = Smallest value FFFFh = Highest possible value | | # Chapter 5 **NVM (Flash)** The non-volatile memory (NVM) system provides non-volatile flash memory for storing executable code and data. | 5.1 NVM Overview | 278 | |------------------------------------|------------------| | 5.2 Flash Memory Bank Organization | <mark>279</mark> | | 5.3 Flash Controller | | | 5.4 Write Protection | 290 | | 5.5 Read Interface | 292 | | 5.6 FLASHCTL Registers | 293 | | <b>3</b> *** *** | | NVM (Flash) www.ti.com #### 5.1 NVM Overview The nonvolatile memory system provides in-system programmable flash memory for storing executable code and data. This chapter describes the entire functionality provided by the nonvolatile memory system. #### 5.1.1 Key Features Key features of the nonvolatile memory system include: - · In-circuit program and erase supported across the entire supply voltage range - Internal programming voltage generation - 64-bit flash word size (72-bit when optional ECC is present) - Static write protection (latched at boot and held until BOR or POR) - Dynamic write protection (configurable at runtime) - · Sector (1KB) and bank (up to 256KB) erase - Automatic hardware preverification to extend flash bank longevity - Automatic hardware post-verification of program/erase - Optional ECC protection (SECDED) - Optional bank address swap mode (for seamless dual-image firmware updates) - Optional program register cache for time efficient programming (2, 4, or 8 flash words) #### Note To determine if a device has any of the optional features described above, review the nonvolatile memory system detailed description in the corresponding device data sheet. #### 5.1.2 System Components The nonvolatile memory system consists of three components (listed below): - One or more flash memory banks (for storing code and data) - The flash controller (for managing all program/erase operations on the flash banks) - The read interface (for interfacing the flash banks to the CPU and peripheral bus) Figure 5-1. Non-volatile Memory System Components #### 5.1.3 Terminology Key flash bank terms are defined in this section to be used as a reference for the rest of this chapter. Table 5-1. NVM System Terminology | Term | Definition | Size | |------------|-------------------------------------------------------------------------------------------------------------|----------------------------------------------------------| | Flash word | Basic data size for program and read operations on the flash memory (also the read bus width to the system) | 64 data bits (72 bits with ECC) | | Word line | Group of flash words within a sector, with maximum program operation limit before sector erase | 16 flash words (128 data bytes, optionally 16 ECC bytes) | | Sector | Group of word lines that are erased together (minimum erase resolution of the flash memory) | 8 word lines (1024 data bytes, optionally 128 ECC bytes) | www.ti.com NVM (Flash) Table 5-1. NVM System Terminology (continued) | Term | Definition | Size | |--------|-----------------------------------------------------------------------------------------------------------------------------------------------------|----------| | Bank | Group of sectors that can be mass erased in one operation. Only one read, program, erase, or verify operation can run concurrently on a given bank. | Variable | | Region | Logical assignment of a region of flash memory from a bank. | Variable | ## 5.2 Flash Memory Bank Organization The flash memory is used for storing application code and data, the device boot configuration, and parameters which are preprogrammed by TI from the factory. The flash memory is organized into one or more banks, and the memory in each bank is further mapped into one or more logical memory regions and assigned system address space for use by the application. #### **5.2.1 Banks** The nonvolatile memory system provides support for up to 5 flash memory banks (enumerated as BANK0 through BANK4). The number of flash banks present is device dependent. To determine the bank scheme of a particular device, review the detailed description section of the specific device data sheet. Most devices implement a single flash bank (BANK0). On devices with a single flash bank, an ongoing program/erase operation will stall all read requests to the flash memory until the operation has completed and the flash controller has released control of the bank. On devices with more than one flash bank, a program/erase operation on a bank will also stall read requests issued to the bank which is executing the program/erase operation, but it will not stall read requests issued to any other bank. As such, the presence of multiple banks enables application cases such as: - Dual-image firmware updates (an application can execute code out of one flash bank while a second image is programmed to a second symmetrical flash bank without stalling the application execution) - EEPROM emulation (an application can execute code out of one flash bank while a second flash bank is used for writing data without stalling the application execution) #### 5.2.2 Flash Memory Regions The memory within each bank is mapped to one or more logical regions based upon the functions that the memory in each bank supports. There are four regions: FACTORY, NONMAIN, MAIN, and DATA. **Table 5-2. Flash Memory Regions** | Flash Memory Region | Region Contents | Executable | Used by | Programmed by | |---------------------|-----------------------------------------|------------|-------------|--------------------------| | FACTORY | Device ID and other parameters | No | Application | TI only (not modifiable) | | NONMAIN | Device boot configuration (BCR and BSL) | No | Boot ROM | TI, User | | MAIN | Application code and data | Yes | Application | User | | DATA | Data, or EEPROM emulation | No | Application | User | Devices with one bank implement the FACTORY, NONMAIN, and MAIN regions on BANK0 (the only bank present), and the data region is not available. Devices with multiple banks also implement FACTORY, NONMAIN, and MAIN regions on BANK0, but include additional banks (BANK1 through BANK4) that can implement MAIN or DATA regions. For a detailed description of the contents of the read-only FACTORY region, see Section 1.5. #### 5.2.3 Addressing The flash memory regions are assigned to address space in the system memory map. The NONMAIN, DATA, and FACTORY regions are assigned to the peripheral address space (0x4000.0000) as they do not contain any executable code. The CPU should not fetch executable instructions from this region. NVM (Flash) www.ti.com The MAIN region is assigned to both the code address space (0x0000.0000) and the peripheral address space (0x4000.0000). Instruction and data fetches are recommended to always be done through the code address space as this gives the best performance. The CPU should not fetch executable instructions from this region. #### ECC On devices which have error correction code (ECC) support, the ECC codes for all memory regions are also assigned to address space and it is possible for software to read the ECC codes as data for diagnostic purposes. It is also possible to read the contents of any of the memory regions without ECC correction applied. #### 5.2.3.1 Flash Memory Map The system address space assignments are given in Table 5-3 and are consistent for all devices. **Table 5-3. Flash Region Memory Map** | Region | Read Type | ECC Behavior | Base Address | |---------|--------------------------------|--------------|--------------| | | | Corrected | 0x41C0.0000 | | NONMAIN | Data read | Uncorrected | 0x41C1.0000 | | | | ECC code | 0x41C2.0000 | | | Instruction fetch or data read | Corrected | 0x0000.0000 | | | instruction leten of data read | Uncorrected | 0x0040.0000 | | MAIN | | Corrected | 0x4100.0000 | | | Data read | Uncorrected | 0x4140.0000 | | | | ECC code | 0x4180.0000 | | | | Corrected | 0x41D0.0000 | | DATA | Data read | Uncorrected | 0x41E0.0000 | | | | ECC code | 0x41F0.0000 | | | | Corrected | 0x41C4.0000 | | FACTORY | Data read | Uncorrected | 0x41C5.0000 | | | | ECC code | 0x41C6.0000 | NONMAIN, DATA, and FACTORY data reads are processed through the peripheral bus and peripheral address space only. MAIN regions can be accessed through either the CPU bus matrix or through the peripheral bus, depending on whether code address space or peripheral address space is used. The code address space is recommended for CPU accesses (instruction fetches or data reads), as these accesses do not cross the peripheral bus and thus do not compete with the DMA for control of the peripheral bus. See the bus architecture section for a detailed description of the bus interconnect. On devices that have ECC, an access to an ECC code address returns the 8-bit ECC value for the entire 64-bit flash word that was accessed. On devices that do not have ECC, accesses to the corrected and uncorrected ECC address spaces with the same offset read the same, and ECC code addresses read as 0x0. ## 5.2.4 Memory Organization Examples Figure 5-2 is an example of a single bank configuration with a 64KB MAIN region. NONMAIN and FACTORY regions are also included in the single bank (BANK0) with the MAIN region. Most devices with a main region ≤128KB in size implement a single-bank configuration. www.ti.com NVM (Flash) Figure 5-2. Memory Organization Example - Single Bank Configuration Figure 5-3 is an example of a three bank configuration with a 512KB MAIN region split across BANK0 and BANK1, with a 16KB DATA region provided in BANK2. Like the single bank example, NONMAIN and FACTORY regions are included in BANK0. This example supports EEPROM emulation in the DATA region without stalling fetches to MAIN, and it also supports dual-image applications where BANK0 main can be written to without stalling fetches to BANK1 main (and the reverse). Most devices with a main region ≥256KB in size implement a multibank configuration. Figure 5-3. Memory Organization Example - Multiple Bank Configuration #### 5.3 Flash Controller The flash controller manages all program, erase, and verification operations performed on the nonvolatile memory system. It contains memory-mapped registers in the peripheral region of the device memory map which must be configured by software to perform operations on the flash memory. TI provides software abstraction for the flash controller as a part of the DriverLib layer of the software development kit (SDK). It is recommended to use the DriverLib abstraction layer when operating on the flash memory with software, but it is not mandatory to do so. To use the DriverLib software abstraction layer to perform operations on the flash memory, review the software development kit (SDK) documentation provided separately from this document. To directly operate on the flash memory with using low level register accesses to the flash controller, review the remainder of this section in detail. #### Note The FLASHCTL registers may not always be configured to default values after a reset. This may occur if the boot configuration routine (BCR) or boot strap loader (BSL) perform an operation on the flash memory during boot. When configuring the FLASHCTL registers for an operation, ensure that all registers which are relevant for the operation are correctly configured. NVM (Flash) www.ti.com #### 5.3.1 Overview of Flash Controller Commands Operations on the flash memory are executed by configuring the CMDTYPE and CMDCTL registers for the desired command, along with any other registers which must be configured for a particular command, and writing 0x01 to the CMDEXEC register to initiate the command. When 0x01 is set in CMDEXEC, the commanded operation begins executing. While an operation is executing, most configuration registers are blocked for writes until the operation completes. Some registers (for example, mask registers) can change state under hardware control while the operation runs to completion. The flash controller indicates completion of the commanded operation by setting the CMDDONE bit in the STATCMD register. The flash controller also sources an interrupt vector to the CPU subsystem to indicate a "DONE" status when an operation has completed. The software sequence of setting the CMDEXEC bit and waiting for the CMDDONE response must be executed from either the device SRAM or from a different flash bank from the bank which is being operated on, as the flash controller will take control of the flash bank undergoing the operation. Reads to the flash bank which is being operated on while the flash controller is executing the command are not guaranteed. The flash controller provides five basic commands for operating on the flash memory, specified in the COMMAND field of the CMDTYPE register. These commands are described in Table 5-4. | Command | Description | |-------------|--------------------------------------------------| | NOOP | No operation (default setting). | | PROGRAM | Selects a program operation on the flash memory. | | ERASE | Selects an erase operation on the flash memory. | | READVERIFY | Selects a standalone read verify operation. | | BLANKVERIFY | Selects a standalone blank verify operation. | **Table 5-4. Flash Controller Commands** #### 5.3.2 NOOP Command When not using the flash controller, it is best to set the COMMAND field to NOOP to prevent any unintentional operations on the flash memory in the event that the VAL bit in CMDEXEC is unintentionally set. Executing a NOOP command has no effect on the flash memory. #### 5.3.3 PROGRAM Command The program command is used to write (program) the flash memory. Specifically, the purpose of a PROGRAM operation is to configure the flash bits in one or more flash words from the non-deterministic erased state to the deterministic programmed state. Once a byte is programmed using the PROGRAM command, the byte can not be re-programmed unless the sector is erased using the ERASE command. All devices support single flash word programming of 64 data bits (plus 8 ECC bits on devices with ECC) at a time, with control to limit the scope of a program operation to specific bytes within a 64-bit flash word. Some devices additionally have support for a multi-word programming mode where 2, 4, or 8 flash words can be written with a single commanded operation. Multi-word programming, when available, significantly speeds up programming when multiple words need to be programmed (for example, during production programming or firmware updates). See the device-specific data sheet to determine if multi-word programming is supported, and if so, how many flash word buffers are provided. ## 5.3.3.1 Program Bit Masking Behavior The flash controller provides a program verification mechanism to extend the lifetime of the flash bank. During program operations, the CMDDATAx registers are used by the flash controller as a programming bit mask to indicate which specific bits in the flash word require program pulses. As a result, data which is loaded into the CMDDATAx registers before starting the program operation will be lost from the CMDDATAx registers during and/or upon completion of the program operation. If the same data is to be programmed again, the CMDDATAx registers must be re-loaded by software with the correct data values to be programmed. www.ti.com NVM (Flash) ## 5.3.3.2 Programming Less Than One Flash Word In general, the simplest way to program the flash memory is one flash word at a time (64 bits plus 8 ECC bits if ECC is present). It is possible to program the flash memory with 32-, 16-, or 8-bit (byte) resolution, but special care must be taken when doing so to ensure the following: - 1. On devices with ECC, ECC bits must be handled properly to prevent inadvertent ECC errors. - 2. The number of program operations applied to a given word line must be monitored to ensure that the maximum word line program limit before erase is not violated. - 3. Once a byte has been programmed, the sector containing the byte must be erased before attempting to re-program the same byte. To program less than one flash word, the CMDBYTEN register must be configured to indicate which bytes in the flash word are to be programmed before starting the program operation. Each bit in CMDBYTEN corresponds to a byte in the flash word to be programmed, including the ECC bits. #### **Handling ECC** On devices with ECC, programming 64 bits of data at a time ensures that the 8 ECC bits which correspond to the 64-bit data word are also programmed both correctly and at the same time. Doing so prevents ECC errors from occurring if the memory locations are read by the CPU or DMA after programming. If use of ECC is planned and partial programming is required, one approach is to mask (not program) the ECC bits until all 64 bits of a flash word are programmed, at which time the ECC bits can also be programmed. Programming of ECC bits is masked by clearing BIT8 (0x100) in the CMDBYTEN register. This prevents a situation where the entire sector must be erased each time a program operation is done to re-program ECC bits to match the new 64-bit data. However, in this case, a read to a partially programmed word where the ECC bits are not yet written would result in an ECC error. To avoid an ECC error, the software must either wait until the full 64-bit flash word and the 8 ECC bits are written, or read the data from the uncorrected address space. #### Maximum Program Operations per Word Line Before Erase The device data sheet specifies a maximum limit on the number of program operations per word line before erasure of the sector containing the word line is required. Exceeding this maximum can result in data corruption within the word line. If 16-bit or greater program operations are performed, and no 16-bit location is programmed more than once before a sector is erased, **the maximum limit will never be reached and thus does not need to be considered**. If 8-bit (byte) program operations are performed, the maximum program limit per word line must be considered and not exceeded. Program operations performed on ECC locations, if done independently from other program operations, count towards the number of writes before an erase is required. #### 5.3.3.3 Target Data Alignment (Devices with Single Flash Word Programming Only) For devices which only support single word programming, only the CMDDATA0, CMDDATA1, and CMDECC0 registers are used to load data to be programmed to the flash memory. CMDDATA0 is always loaded with BIT31-BIT0 of the target data, and CMDDATA1 is always loaded with BIT63-BIT32 of the target data. ECC data, if specified directly and not computed automatically, is loaded into BIT7-BIT0 of CMDECC0. No other CMDDATAx or CMDECCx registers are used, and CMDDATAINDEX is not used. If fewer than 64 data bits are being programmed, see the special handling requirements section above for programming less than one flash word. Single-word program operations must be flash word (64-bit) aligned. This means that the target system address specified in CMDADDR must be aligned to a 0b000 boundary (for example, the 3 LSBs in CMDADDR must be zero). NVM (Flash) www.ti.com #### 5.3.3.4 Target Data Alignment (Devices With Multiword Programming) For devices that support 2-, 4-, or 8-word programming, there are two options for loading data to be programmed: direct mode or indexed mode. The programmer must select the mode that is most suitable to the application requirements. Additional alignment rules apply when loading data into the CMDDATAx and CMDECCx registers on devices that support multiword programming, even if the multiword programming feature is not used and only single word programming is not used. - 1-word program operations must have CMDADDR (the target system address) aligned to a 0b000 boundary (for example, the 3 LSBs in CMDADDR must be zero). - 2-word program operations must have CMDADDR (the target system address) aligned to a 0b0000 boundary (for example, the 4 LSBs in CMDADDR must be zero). - 4-word program operations must have CMDADDR (the target system address) aligned to a 0b0.0000 boundary (for example, the 5 LSBs in CMDADDR must be zero). - 8-word program operations must have CMDADDR (the target system address) aligned to a 0b00.0000 boundary (for example, the 6 LSBs in CMDADDR must be zero). #### **Direct Data Load** To configure a program operation with direct data loading, the target data is loaded into the appropriate CMDDATAx registers based on the number of flash words supported by the device, the target address alignment, and the target data size. For example, if a 4-word program operation is to be initiated on a device supporting 4-word programming, the CMDDATA0-CMDDATA7 registers would be populated with the target data. If ECC is being specified directly (rather than automatically calculated by the flash controller) then the appropriate CMDECCx registers also needs to be populated with the ECC values for each data word being programmed. #### **Indexed Data Load** Rather than buffering data into all the CMDDATAx registers individually, it is possible to use only the CMDDATA0-CMDDATA1 registers in combination with an index register (CMDDATAINDEX) to indicate the flash word offset of the data being loaded. In this way, the index can be adjusted for each word loaded, and each target data word can be written to the same 64-bit space (CMDDATA0-CMDDATA1). When an index is applied, the loaded data will be mapped by the hardware into the appropriate CMDDATAx register. For example, if a 4-word program operation is to be initiated on a device supporting 4-word programming, the CMDDATA1:0 registers are loaded 4 times with the target data, with CMDDATAINDEX being incremented by one before each new word is loaded into CMDDATA1:0. ## **Alignment Rules** The alignment rules for each device configuration (2, 4, or 8 words) is given in the tables below with guidance on how target data must be placed with the CMDDATAX, CMDECCx, and CMDDATAINDEX registers for 1, 2, 4, or 8 word programming operations. Table 5-5. Data Load Alignment for Devices Supporting Programming of 2 Flash Words | Direct Load<br>Registers | Indexed Load<br>Index | 1 Word Aligned to 0b000 | 2 Words Aligned to 0b0000 | 4 Words Aligned<br>to 0b0.0000 | 8 Words Aligned<br>to 0b00.0000 | |--------------------------|-----------------------|---------------------------------------------------------|---------------------------|--------------------------------|---------------------------------| | CMDDATA1:0 /<br>CMDECC0 | CMDINDEX = 0 | Target data word 0 if the target address ends in 0b0000 | Target data word 0 | Not supported | Not supported | | CMDDATA3:2 /<br>CMDECC1 | CMDINDEX = 1 | Target data word 0 if the target address ends in 0b1000 | Target data word 1 | Not supported | | www.ti.com NVM (Flash) Table 5-6. Data Load Alignment for Devices Supporting Programming of 4 Flash Words | Direct Load<br>Registers | Indexed Load<br>Index | 1 Word Aligned to 0b000 | 2 Words Aligned to 0b0000 | 4 Words Aligned<br>to 0b0.0000 | 8 Words Aligned<br>to 0b00.0000 | |--------------------------|-----------------------|-----------------------------------------------------------|-----------------------------------------------------------|--------------------------------|---------------------------------| | CMDDATA1:0 /<br>CMDECC0 | CMDINDEX= 0 | Target data word 0 if the target address ends in 0b0.0000 | Target data word 0 if the target address ends in 0b0.0000 | Target data word 0 | Not supported | | CMDDATA3:2 /<br>CMDECC1 | CMDINDEX= 1 | Target data word 0 if the target address ends in 0b0.1000 | Target data word 1 if the target address ends in 0b0.0000 | Target data word 1 | | | CMDDATA5:4 /<br>CMDECC2 | CMDINDEX= 2 | Target data word 0 if the target address ends in 0b1.0000 | Target data word 0 if the target address ends in 0b1.0000 | Target data word 2 | | | CMDDATA7:6 /<br>CMDECC3 | CMDINDEX= 3 | Target data word 0 if the target address ends in 0b1.1000 | Target data word 1 if the target address ends in 0b1.0000 | Target data word 3 | | Table 5-7. Data Load Alignment for Devices Supporting Programming of 8 Flash Words | Direct Load<br>Registers | Indexed Load Index | 1 Word Aligned to<br>0b000 | 2 Words Aligned to<br>0b0000 | 4 Words Aligned to<br>0b0.0000 | 8 Words Aligned to<br>0b00.0000 | |---------------------------|--------------------|------------------------------------------------------------|------------------------------------------------------------------|------------------------------------------------------------|---------------------------------| | CMDDATA1:0 /<br>CMDECC0 | CMDINDEX = 0 | Target data word 0 if the target address ends in 0b00.0000 | Target data word 0 if the target address ends in 0b00.0000 | Target data word 0 if the target address ends in 0b00.0000 | Target data word 0 | | CMDDATA3:2 /<br>CMDECC1 | CMDINDEX = 1 | Target data word 0 if the target address ends in 0b00.1000 | Target data word 1 if the target address ends in 0b00.0000 | Target data word 1 if the target address ends in 0b00.0000 | Target data word 1 | | CMDDATA5:4 /<br>CMDECC2 | CMDINDEX = 2 | Target data word 0 if the target address ends in 0b01.0000 | Target data word 0 if the target address ends in 0b01.0000 | Target data word 2 if the target address ends in 0b00.0000 | Target data word 2 | | CMDDATA7:6 /<br>CMDECC3 | CMDINDEX = 3 | Target data word 0 if the target address ends in 0b01.1000 | Target data word 1 if the target address ends in 0b01.0000 | Target data word 3 if the target address ends in 0b00.0000 | Target data word 3 | | CMDDATA9:8 /<br>CMDECC4 | CMDINDEX = 4 | Target data word 0 if the target address ends in 0b10.0000 | Target data word 0 if the target address ends in 0b10.0000 | Target data word 0 if the target address ends in 0b10.0000 | Target data word 4 | | CMDDATA11:10 /<br>CMDECC5 | CMDINDEX = 5 | Target data word 0 if the target address ends in 0b10.1000 | Target data word 1 if the target address ends in 0b10.0000 | Target data word 1 if the target address ends in 0b10.0000 | Target data word 5 | | CMDDATA13:12 /<br>CMDECC6 | CMDINDEX = 6 | Target data word 0 if the target address ends in 0b11.0000 | Target data word 0 if the target address ends in 0b11.0000 | Target data word 2 if the target address ends in 0b10.0000 | Target data word 6 | | CMDDATA15:14 /<br>CMDECC7 | CMDINDEX = 7 | Target data word 0 if the target address ends in 0b11.1000 | Target data word 1<br>if the target address<br>ends in 0b11.0000 | Target data word 3 if the target address ends in 0b10.0000 | Target data word 7 | ## 5.3.3.5 Executing a PROGRAM Operation To program the flash memory, follow these steps: - 1. Select the command in the CMDTYPE register: - a. Set the COMMAND field in the CMDTYPE register to PROGRAM. - b. Set the SIZE field in the CMDTYPE register to the desired size (1, 2, 4, or 8 flash words). If a device does not support multi-word programming, select ONEWORD. If a device supports multi-word programming, and multi-word programming is desired, select the desired size which is less than or equal to the max size supported by the target device. The hardware will not check for invalid configuration of the SIZE field; software must ensure that the selection option is supported by the device. Note that SECTOR and BANK sizes are not valid sizes for PROGRAM operations. These sizes only apply to erase operations. - 2. Configure the program command in the CMDCTL register: NVM (Flash) www.ti.com - a. On devices with ECC, the flash controller by default will generate the needed ECC bits from the data during the PROGRAM operation. Optionally, software can override the hardware ECC code generation and manually provide the ECC code to be programmed by setting the ECCGENOVR bit in CMDCTL register. - 3. Select the target programming address in the CMDADDR and CMDBYTEN register: - a. Load the target system address into the CMDADDR register to indicate the base address from which programming will start. The target address must be a flash word address (64-bit aligned). The flash controller will translate the system address into the applicable flash region, bank ID, and bank address. If desired, after the operation completes the flash region, bank ID, and bank address can be read from the STATADDR register. In a multi-word program, STATADDR will indicate the bank ID and the final address which was programmed. - b. If sub-word programming (programming of less than the full 64 or 72 bit flash word) is desired, configure the CMDBYTEN register to set the bytes within the addressed flash word which are to be programmed. Each bit in CMDBYTEN corresponds to a byte in the addressed flash word to be programmed, including the ECC byte. For example, programming of the ECC code can be masked by clearing bit 8 in CMDBYTEN while programming the data bytes of the flash word. Note that there is a maximum number of program operations allowed per word line before a sector erase must be applied (see the device specific data sheet for the maximum). - 4. Load the data to program into the CMDDATAx registers: - a. For a single flash word programming operation (64 or 72 bits depending on the presence of ECC), load the data into the CMDDATAx registers consistent with the alignment requirements (for devices which only support single-word programming, CMDDATA0 and CMDDATA1 are always used regardless of the target address). - b. For multi-word programming (if available and selected), load data into the CMDDATAx registers consistent with the alignment rules and the size of the multi-word program operation specified in step 1. - c. If ECCGENOVR in the CMDCTL register was set above (disabling hardware ECC code generation), then write the ECC data in the CMDDATAECC0 register (for single word programming) and optionally additional CMDDATAECCx registers as applicable for multi-word programming. - d. Note that the CMDDATA registers are used as bit masking registers by the flash controller during the program operation; after the operation completes, the values written to these registers will have been overwritten by the flash controller. - 5. Ensure the write protection scheme is configured to allow writes to the target addresses (see the write protection section of this guide for additional information on configuring write protection). - 6. Execute the program operation by writing 0x1 to the CMDEXEC register. - 7. Monitor for completion of the program operation: - a. The STATCMD register can be polled to determine the status of the program operation. The CMDINPROGRESS bit will be set by hardware as soon as the command is initiated. The CMDDONE bit will be set when the operation terminates. - b. When CMDDONE is set, the CMDPASS bit will be reset or set at the same time to indicate whether the operation completed successfully or failed. If a program was attempted on a protected region, the FAILWEPROT bit is asserted. If the program operation cannot be completed successfully within the maximum program pulse count limit FAILVERIFY will be asserted. See the device-specific data sheet for maximum program times. - 8. After completion of a program operation, the flash controller will configure several settings: - a. All dynamic write protection registers are set to a protected state (to protect against inadvertent programming) - b. All data registers are set to 1. - c. All program byte enables are cleared to 0. - 9. Following programming of the flash memory, it is possible that there may be stale data in the processor's cache and prefetch logic. Before reading locations which were programmed, it is recommended to first flush the cache in the CPU subsystem. www.ti.com NVM (Flash) #### 5.3.4 ERASE Command The erase command is used to erase individual sectors of flash memory (for MAIN, NONMAIN, or DATA regions) or a complete bank of flash memory (for MAIN regions only). From this erased state, bits can later be programmed to a '0' state or a '1' state as desired using the PROGRAM command. It is not possible to erase with a resolution lower than one sector (1KB) with sector alignment. For devices with multiple banks, a bank erase must be executed on all banks to erase the entire MAIN region on the device. #### Note After erasure, the memory contents of a sector are not deterministic until programmed. It is not guaranteed that erased bits will read as '1' after an erase. A memory location must be successfully programmed using the PROGRAM command before the memory location can be considered deterministic. ## 5.3.4.1 Erase Sector Masking Behavior The flash controller provides an erase verification mechanism to extend the lifetime of the flash bank. The CMDWEPROTx registers are used as an erase mask and are manipulated by the flash controller during the execution of the erase operation. At the end of all erase operations, the CMDWEPROTx registers are set to a fully protected state to prevent against inadvertent programming and must be re-configured before attempting another program or erase operation. #### 5.3.4.2 Executing an ERASE Operation To erase a sector or bank of the flash memory, follow these steps: - 1. Select the command in the CMDTYPE register: - a. Set the COMMAND field in the CMDTYPE register to ERASE. - b. Set the SIZE field in the CMDTYPE register to SECTOR or BANK. Sizes other than SECTOR or BANK (for example, ONEWORD) are not supported by the ERASE command. It is the responsibility of software to check the configuration before issuing an ERASE command. - 2. Select the target erase address in the CMDADDR register: - a. Store the target system address into the CMDADDR register to indicate the base address of the sector or bank to be erased. The flash controller will translate the system address into the applicable flash region, bank ID, and bank address. If desired, after the operation completes the flash region, bank ID, and bank address can be read from the STATADDR register. - 3. Ensure the write protection scheme is configured to allow writes to the target sector(s) (see the write protection section of this guide for additional information on configuring write protection). - 4. Execute the erase operation by writing 0x1 to the CMDEXEC register. - 5. Monitor for completion of the erase operation: - a. The STATCMD register can be polled to determine the status of the erase operation. The CMDINPROGRESS bit will be set by hardware as soon as the command is initiated. The CMDDONE bit will be set when the operation terminates. When CMDDONE is set, the CMDPASS bit will be reset or set at the same time to indicate whether the operation completed successfully or failed. - b. If an erase was attempted on a protected region, the FAILWEPROT bit is asserted. - c. If the erase operation cannot be completed successfully within the maximum erase pulse count limit, FAILVERIFY will be asserted. - 6. After completion of the erase operation, the flash controller will configure several settings to protect against inadvertent programming: - a. All dynamic write protection registers are set to a protected state. #### 5.3.5 READVERIFY Command The read verify command can be used to read a flash location and compare the data to data which is preloaded into the CMDDATA registers of the flash controller. The command can be applied to a single flash word, multiple flash words (if the device supports multi-word programming), an entire sector, or an entire bank. When performing a read verify on an entire sector or bank, the data in CMDDATAx will be re-used. NVM (Flash) www.ti.com ## 5.3.5.1 Executing a READVERIFY Operation To execute a read verify command, follow these steps: - 1. Select the command in the CMDTYPE register: - a. Set the COMMAND field in the CMDTYPE register to READVERIFY. - b. Set the SIZE field in the CMDTYPE register to the desired size. - 2. Configure the read verify command in the CMDCTL register: - a. If the desire is to manually provide ECC bits along with the data, set the ECCGENOVR bit in the CMDCTL register. If ECCGENOVR is cleared, the flash controller will generate ECC bits for comparison based on the provided compare data. - 3. Select the target address to verify on the CMDADDR register: - a. Load the target system address into the CMDADDR register to indicate the base address to be verified. The flash controller will translate the system address into the applicable flash region, bank ID, and bank address. If desired, after the operation completes the flash region, bank ID, and bank address can be read from the STATADDR register. - 4. Load the data to verify into the CMDDATAx registers: - a. For single word verification, write the data to be verified to the CMDDATA0 and CMDDATA1 registers. For multi-word verification, if available on the target device, write the data to be verified to the appropriate CMDDATAx registers beyond CMDDATA0 and CMDDATA1. - 5. Configure the byte enable settings in the CMDBYTEN register: - a. Any CMDBYTEN bit set to logic "0" will mask the associated data byte from being compared during the execution of the READVERIFY command. This can be used to verify data less than one flash word (less than 64 bits). - 6. Execute the read verify operation by writing 0x1 to the CMDEXEC register. - 7. Monitor for completion of the read verify operation: - a. The STATCMD register can be polled to determine the status of the erase operation. The CMDINPROGRESS bit will be set by hardware as soon as the command is initiated. The CMDDONE bit will be set when the operation terminates. When CMDDONE is set, the CMDPASS bit will be reset or set at the same time to indicate whether the read verification passed or failed. - b. The FAILVERIFY bit in STATCMD will be set if any data read from the flash did not match the expected data loaded in CMDDATAx. - 8. After completion of the read verify operation, the flash controller will configure several settings: - a. All dynamic write protection registers are set to a protected state (to protect against inadvertent programming). - b. All data registers are set to '1's. - c. All program byte enables are cleared to '0's. #### **5.3.6 BLANKVERIFY Command** The blank verify (BLANKVERIFY) command can be used by application software to verify that a flash word is blank. A blank flash word is defined as a flash word which has been successfully erased with the ERASE command and not yet programmed away from that non-erased state with the PROGRAM command. After erase, a flash word is not guaranteed to be in a deterministic state until it is programmed using the PROGRAM command. This means that application software can not expect that erased bits will read back as '1's' after an erase. A memory location must be successfully programmed using the PROGRAM command before a read of that memory location can be considered deterministic and used by application software. Because it is not possible to determine if a flash word is in an erased state by simply reading the location directly (as an erased location will return non-deterministic data when read), the BLANKVERIFY command can be used to test if a flash word is in a blank state, indicating it has not yet been programmed away from an erased state. The BLANKVERIFY command can only be applied to a single flash word at a time. ## 5.3.6.1 Executing a BLANKVERIFY Operation To execute a blank verify operation, follow these steps: - 1. Select the command in the CMDTYPE register: - a. Set the COMMAND field in the CMDTYPE register to BLANKVERIFY. - b. Set the SIZE field in the CMDTYPE register to one word. - 2. Select the target address to verify in the CMDADDR register: - a. Store the target system address into the CMDADDR register to indicate the base address to be verified. The flash controller will translate the system address into the applicable flash region, bank ID, and bank address. If desired, after the operation completes the flash region, bank ID, and bank address can be read from the STATADDR register. All 8 data bytes in the specified flash word, and the corresponding ECC byte, will be checked by BLANKVERIFY. - 3. Execute the blank verify operation by writing 0x1 to the CMDEXEC register. - 4. Monitor for completion of the blank verify operation: - a. The STATCMD register can be polled to determine the status of the erase operation. The CMDINPROGRESS bit will be set by hardware as soon as the command is initiated. The CMDDONE bit will be set when the operation terminates. When CMDDONE is set, the CMDPASS bit will be reset or set at the same time to indicate whether the blank verification passed or failed. - b. The FAILVERIFY bit in STATCMD will be set if the flash location is not erased. - 5. After completion of the blank verify operation, the flash controller will configure several settings: - a. All dynamic write protection registers are set to a protected state ( to protect against inadvertent programming) - b. All data registers are set to '1's. - c. All program byte enables are cleared to '0's. ### **5.3.7 Command Diagnostics** The flash controller updates several software-readable registers to communicate information about an initiated operation. #### 5.3.7.1 Command Status The STATCMD register is a read-only register which provides diagnostic information about an operation which is been initiated or completed. The CMDINPROGRESS bit indicates that an operation is currently ongoing. The CMDDONE bit indicates that an operation has completed. These bits can be polled by software to determine the state of the flash controller during operations. #### 5.3.7.2 Address Translation The STATADDR register is a read-only register which can be read to determine the current bank ID, region ID, and bank address which the flash controller is pointing to. These values can increment during execution of certain commands, in which case the value present after the completion of a command indicates the last address touched by the flash controller. #### 5.3.7.3 Pulse Counts The STATPCNT register is a read-only register which can be read to determine the current pulse count applied during a program or erase operation. # 5.3.8 Overriding the System Address With a Bank ID, Region ID, and Bank Address Normally, flash controller commands are targeted to a specific flash location by loading a system memory map address into the CMDADDR register. This is the recommended way to specify the target address for a PROGRAM, ERASE, READVERIFY, or BLANKVERIFY command. In this mode of operation, the flash controller will automatically translate the system address into the corresponding bank ID, region ID, and bank address which are used to execute the command on the flash memory. Application software does not need to specify these items individually; only the system address is needed. However, in some circumstances it can be desirable to directly specify the target flash bank, region, and address in the specified bank/region. For example, if the desire is to erase a complete bank when doing a mass erase operation on the device, application software actually does not need to have any knowledge of the system address of the bank to be erased- it only needs to specify the bank ID and region ID to the flash controller to erase the bank. To use the flash controller to execute a command in address override mode, set the ADDRXLATEOVR bit in the CMDCTL register, and specify the bank ID, region, and bank address before executing the command. To return to system addressed mode, clear ADDRXLATEOVR. ADDRXLATEOVR is cleared by default (supporting system address operation). #### **Example Case - Bank Erase with ADDRXLATEOVR** To erase the MAIN region of BANK0 by specifying the bank ID and region instead of the system address, follow the steps in Section 5.3.4.2, but replace step 2 with the alternate steps given below: - 1. Set the ADDRXLATEOVR bit in CMDCTL to enable address translation override mode - 2. Specify BANK0 by setting the BANKSEL field to 0x1 in the CMDCTL register - 3. Specify the MAIN region by setting the REGIONSEL field to 0x1 in the CMDCTL register - 4. Set the CMDADDR register to 0x0000.0000 #### 5.3.9 FLASHCTL Events The flash controller contains one event publisher and no event subscribers. One event publisher (CPU\_INT) manages FLASHCTL interrupt requests (IRQs) to the CPU subsystem through a static event route. The FLASHCTL events are summarized in Table 5-8. ### **Table 5-8. FLASHCTL Events** | Event | Туре | Source | Destination | Route | Configuration | Functionality | |---------------|-----------|----------|---------------|--------------|---------------|----------------------------| | CPU Interrupt | Publisher | FLASHCTL | CPU Subsystem | Static route | CPU_INT | Fixed interrupt route from | | Event | | | | | registers | FLASHCTL to CPU | #### 5.3.9.1 CPU Interrupt Event Publisher The FLASHCTL module provides one interrupt source which can be configured to source a CPU interrupt event. The FLASHCTL interrupt conditions are given in Table 5-9. ### **Table 5-9. FLASHCTL CPU Interrupt Conditions** | Index (IIDX) | Name | Description | |--------------|------|------------------------------------------------------| | 0 | DONE | Indicating that the FLASHCTL operation has completed | The CPU interrupt event configuration is managed with the CPU\_INT event management registers. See Section 6.2.5 for guidance on configuring these registers. ### **5.4 Write Protection** The flash controller provides two write protection mechanisms (one static, one dynamic) which are applied in parallel (logical OR) to protect user-specified sectors during any attempted program or erase operation. If a program or erase operation is issued to a write protected flash sector, the operation will terminate with a FAILWEPROT error reported in the STATCMD register. #### 5.4.1 Write Protection Resolution The write protection resolution for both the static and dynamic write protection mechanisms is dependent on the flash bank and memory region which is being protected. Table 5-10. Write Protection Resolution by Region | | Flash Bank | Memory Region | Write Protection Resolution | |--|------------|---------------|----------------------------------------------------------------------------------| | | | NONMAIN | 512B (entire region) | | | 0 | MAIN | 1KB (1 sector) for first 32KB (32 sectors) 8KB (8 sectors) for remaining sectors | | | 1-4 | MAIN | 8KB (8 sectors) | | | 1-4 | DATA | 1KB (1 sector) | #### 5.4.2 Static Write Protection The static write protection scheme is configured and latched during device boot by the immutable ROM boot code before the main application in flash can execute. After a flash sector is configured to be write protected through the static write protection mechanism, it is not possible to remove the protection with software at runtime without a reboot. Thus, sectors protected by static write protection can be thought of as immutable after boot. This type of protection is very useful for protecting a custom bootloader in a dual-image application, or for extending the secure root of trust from the ROM boot code into a portion of the main flash region to enable a secure boot manager with locked public keys. The static write protection scheme is configured by programming the appropriate bits in the NONMAIN flash region, which is read by the boot code before the main application starts. It is also possible to statically write protect the NONMAIN flash sector itself, thus resulting in a system where the static write protection scheme is fully permanent and cannot be modified. If the NONMAIN sector is configured to be statically protected, along with any other flash sectors, all statically protected flash sectors can be functionally viewed as read only memory which cannot be updated by any means. Static write protection can be configured for all sectors of flash memory across all banks present on a device. Instructions for configuring the static write protection, along with the rest of the NONMAIN region, are given in Section 1.4 of this document. #### 5.4.3 Dynamic Write Protection The dynamic write protection scheme is intended to be configured at runtime by software. This scheme provides a simple way for application software to specify sectors to protect from modification by any program or erase operations that are issued with the flash controller. Unlike the static write protection mechanism, the dynamic mechanism is not lockable and thus does not provide any level of data security. There are two primary uses for dynamic write protection. First, it provides an extra level of robustness against unintentional program or erase of specified sectors in applications that involve in-system programming for either firmware updates or EEPROM emulation. Second, it provides a way to simplify a situation where a bank erase is desired but a small number of sectors should not be erased when a bank erase command is issued. One example would be an application running on a single-bank device in which most of the MAIN region sectors are used to store the executable image, but a few sectors are used to store device-specific data that should not be erased during a firmware update. In that case, the sectors containing the device-specific data can be protected with dynamic write protection, and a bank erase command can be issued to erase all other sectors. This has the benefit that the majority of the MAIN region can be erased with a single command (a bank erase) rather than individual sector-by-sector commands, which would have a longer overall erase time and use more energy. The dynamic write protection scheme is configured by setting up the CMDWEPROTx registers in the flash controller. The CMDWEPROTx registers cover one flash bank at a time. This means that these registers must be configured with knowledge of which flash bank an attempted program or erase operation will be applied to. Note that the CMDWEPROTx registers are reset to a protected state at the end of all program and erase operations. These registers must be re-configured by software before a new operation is initiated. ### 5.4.3.1 Configuring Protection for the MAIN Region The CMDWEPROTA register is used to configure the dynamic write protection for the first 32 sectors (32KB) of the MAIN region in BANK0. Each bit corresponds to one sector of the MAIN region, starting from the beginning of the MAIN region. CMDWEPROTA is only applicable to operations on the lower 32 sectors of the MAIN region of BANK0 (sectors 0-31). It is not used during program/erase operations applied to other sectors. The CMDWEPROTB register is also used to configure the dynamic write protection for the MAIN region. There are two modes in which CMDWEPROTB is applied, depending on whether the program/erase operation is being applied to BANK0 or BANK1-4. In the case of a program/erase operation on BANK0, CMDWEPROTB protects sectors 32-255 in 8-sector increments (1 bit per 8KB), starting from BIT4. BIT0-BIT3 in CMDWEPROTB are ignored. The lower 32 sectors (sectors 0-31 of BANK0) are protected by CMDWEPROTA. In the case of a program/erase operation on BANK1-4, CMDWEPROTB protects sectors 0-255 in 8-sector increments (1 bit per 8 sectors), starting from BIT0 in CMDWEPROTB. The CMDWEPROTC register configures the dynamic write protection for the MAIN region. For BANK0-4, CMDWEPROTC protects sectors 256-511 in 8-sector increments (1 bit per 8 sectors). ### 5.4.3.2 Configuring Protection for the NONMAIN Region The CMDWEPROTNM register protects the NONMAIN region from program and erase. One protection bit is provided per sector. Devices only have one NONMAIN sector and it will be in BANK0. #### 5.5 Read Interface The read interface provides the read path to the CPU subsystem (for instruction/data fetch), the read path to the peripheral bus (for use by the DMA controller or CPU), main bank address swapping, and detection and reporting of ECC SEC or DED errors. #### 5.5.1 Bank Address Swapping Devices that contain more than one bank support swapping of the MAIN regions of the banks within the address space. This mechanism enables two versions of application firmware to be programmed into the device without the firmware needing to know which physical bank it exists in. Table 5-11 gives an example of the mapping before and after a bank swap is requested for a device with a 512KB main flash split across 2 banks (256KB each). | Bank and Region | Address Space Before Swap | Address Space After Swap | |-----------------|---------------------------|---------------------------| | BANKO MAIN | 0x0000.0000 - 0x0003.FFFF | 0x0004.0000 - 0x0007.FFFF | | BANK1 MAIN | 0x0004.0000 - 0x0007.FFFF | 0x0000.0000 - 0x0003.FFFF | After a device reset, the MAIN region of the lower bank is always mapped to the lowest address space. The application software is responsible for determining if a bank address swap is to be applied. The bank address swap control is contained within the SYSCTL module; see the SYSCTL chapter for register and bit definitions. During an address swap, the application software must meet the following constraints: - 1. The software must disable interrupts before issuing the bank swap command. - 2. The software must poll the bank swap status after issuing the bank swap command before proceeding with execution. - 3. If the swap command and poll status routines are executing from flash, they must exist at the exact same location in both banks such that execution resumes from where it left off after the bank swap. This restriction does not apply if the bank swap and status polling is done from SRAM and not from flash memory. # **5.6 FLASHCTL Registers** Table 5-12 lists the memory-mapped registers for the FLASHCTL registers. All register offset addresses not listed in Table 5-12 should be considered as reserved locations and the register contents should not be modified. Table 5-12. FLASHCTL Registers | Offset | Acronym | Register Name | Group | Section | | | | | |--------|--------------|-----------------------------|---------------------------------------------|---------|--|--|--|--| | 1020h | IIDX | Interrupt Index Register | CPU INT | Go | | | | | | 1028h | IMASK | <u> </u> | Interrupt Mask Register CPU_INT Go | | | | | | | 1030h | RIS | | Raw Interrupt Status Register CPU_INT Go | | | | | | | 1038h | MIS | i | Masked Interrupt Status Register CPU INT Go | | | | | | | 1040h | ISET | Interrupt Set Register | CPU_INT | Go | | | | | | 1048h | ICLR | Interrupt Clear Register | CPU_INT | Go | | | | | | 1100h | CMDEXEC | Command Execute Register | <u> </u> | Go | | | | | | 1104h | CMDTYPE | Command Type Register | | Go | | | | | | 1108h | CMDCTL | Command Control Register | | Go | | | | | | 1120h | CMDADDR | Command Address Register | | Go | | | | | | 1124h | CMDBYTEN | Command Program Byte Enable | | Go | | | | | | | | Register | | | | | | | | 112Ch | CMDDATAINDEX | Command Data Index Register | | Go | | | | | | 1130h | CMDDATA0 | Command Data Register 0 | | Go | | | | | | 1134h | CMDDATA1 | Command Data Register 1 | | Go | | | | | | 1138h | CMDDATA2 | Command Data Register 2 | | Go | | | | | | 113Ch | CMDDATA3 | Command Data Register 3 | | Go | | | | | | 1140h | CMDDATA4 | Command Data Register 4 | Command Data Register 4 Go | | | | | | | 1144h | CMDDATA5 | Command Data Register 5 | Command Data Register 5 Go | | | | | | | 1148h | CMDDATA6 | Command Data Register 6 | Command Data Register 6 Go | | | | | | | 114Ch | CMDDATA7 | Command Data Register 7 | Command Data Register 7 Go | | | | | | | 1150h | CMDDATA8 | Command Data Register 8 | Command Data Register 8 Go | | | | | | | 1154h | CMDDATA9 | Command Data Register 9 | Command Data Register 9 Go | | | | | | | 1158h | CMDDATA10 | Command Data Register 10 | Command Data Register 10 Go | | | | | | | 115Ch | CMDDATA11 | Command Data Register 11 | Command Data Register 11 Go | | | | | | | 1160h | CMDDATA12 | Command Data Register 12 | Command Data Register 12 Go | | | | | | | 1164h | CMDDATA13 | Command Data Register 13 | Command Data Register 13 Go | | | | | | | 1168h | CMDDATA14 | Command Data Register 14 | | Go | | | | | | 116Ch | CMDDATA15 | Command Data Register 15 | | Go | | | | | | 1170h | CMDDATA16 | Command Data Register 16 | | Go | | | | | | 1174h | CMDDATA17 | Command Data Register 17 | | Go | | | | | | 1178h | CMDDATA18 | Command Data Register 18 | | Go | | | | | | 117Ch | CMDDATA19 | Command Data Register 19 | | Go | | | | | | 1180h | CMDDATA20 | Command Data Register 20 | | Go | | | | | | 1184h | CMDDATA21 | Command Data Register 21 | | Go | | | | | | 1188h | CMDDATA22 | Command Data Register 22 | | Go | | | | | | 118Ch | CMDDATA23 | Command Data Register 23 | | Go | | | | | | 1190h | CMDDATA24 | Command Data Register 24 | Command Data Register 24 Go | | | | | | | 1194h | CMDDATA25 | Command Data Register 25 | | Go | | | | | | 1198h | CMDDATA26 | Command Data Register 26 | | Go | | | | | | 119Ch | CMDDATA27 | Command Data Register 27 | | Go | | | | | | 11A0h | CMDDATA28 | Command Data Register 28 | Command Data Register 28 Go | | | | | | **Table 5-12. FLASHCTL Registers (continued)** | Offset | Acronym | Register Name | Group | Section | | | | | |--------|-------------|---------------------------------------------------|--------------------------------|---------|--|--|--|--| | 11A4h | CMDDATA29 | Command Data Register 29 | Command Data Register 29 Go | | | | | | | 11A8h | CMDDATA30 | Command Data Register 30 | Command Data Register 30 Go | | | | | | | 11ACh | CMDDATA31 | Command Data Register 31 | | Go | | | | | | 11B0h | CMDDATAECC0 | Command Data Register ECC 0 | | Go | | | | | | 11B4h | CMDDATAECC1 | Command Data Register ECC 1 | | Go | | | | | | 11B8h | CMDDATAECC2 | Command Data Register ECC 2 | | Go | | | | | | 11BCh | CMDDATAECC3 | Command Data Register ECC 3 | | Go | | | | | | 11C0h | CMDDATAECC4 | Command Data Register ECC 4 | | Go | | | | | | 11C4h | CMDDATAECC5 | Command Data Register ECC 5 | | Go | | | | | | 11C8h | CMDDATAECC6 | Command Data Register ECC 6 | Command Data Register ECC 6 Go | | | | | | | 11CCh | CMDDATAECC7 | Command Data Register ECC 7 | Command Data Register ECC 7 Go | | | | | | | 11D0h | CMDWEPROTA | Command Write Erase Protect A<br>Register | • | | | | | | | 11D4h | CMDWEPROTB | Command Write Erase Protect B<br>Register | | | | | | | | 11D8h | CMDWEPROTC | Command Write Erase Protect C<br>Register | | Go | | | | | | 1210h | CMDWEPROTNM | Command Write Erase Protect Non-<br>Main Register | | Go | | | | | | 13B4h | CFGPCNT | Pulse Counter Configuration Register | | Go | | | | | | 13D0h | STATCMD | Command Status Register | | Go | | | | | | 13D4h | STATADDR | Address Status Register | | Go | | | | | | 13D8h | STATPCNT | Pulse Count Status Register | | Go | | | | | Complex bit access types are encoded to fit into small table cells. Table 5-13 shows the codes that are used for access types in this section. Table 5-13. FLASHCTL Access Type Codes | Access Type | Code | Description | | | | | | |------------------------|------------|----------------------------------------|--|--|--|--|--| | Read Type | Read Type | | | | | | | | R | R | Read | | | | | | | Write Type | Write Type | | | | | | | | W | W | Write | | | | | | | Reset or Default Value | | | | | | | | | -n | | Value after reset or the default value | | | | | | # 5.6.1 IIDX (Offset = 1020h) [Reset = 00000000h] IIDX is shown in Figure 5-4 and described in Table 5-14. Return to the Summary Table. The interrupt index (IIDX) register provides the index of the highest priority pending and enabled interrupt. # Figure 5-4. IIDX | | | | i igaic ( | J- <del>T</del> . IIDA | | | | |----------|------|----|-----------|------------------------|----|------|------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | RESERVED | | | | | | | | | | R-0h | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | RESE | RVED | | | | | | R-0h | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | RESE | RVED | | | | | | | | R- | ·0h | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | RESERVED | | | | | | STAT | | | | | | R-0h | | | | R-0h | | | | | | | | | i i | # **Table 5-14. IIDX Field Descriptions** | | Bit | Field | Туре | Reset | Description | |---|------|----------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 3 | 31-1 | RESERVED | R | 0h | Reserved | | | 0 | STAT | R | 0h | Index corresponding to the highest priority pending interrupt source. This value may be used as an address offset for fast, deterministic handling in the interrupt service routine. A read of the IIDX register will clear the corresponding interrupt status in the RIS and MIS registers. 0h (R/W) = No Interrupt Pending 1h (R/W) = DONE Interrupt Pending | # 5.6.2 IMASK (Offset = 1028h) [Reset = 00000000h] IMASK is shown in Figure 5-5 and described in Table 5-15. Return to the Summary Table. The interrupt mask (IMASK) register holds the current interrupt mask settings. # Figure 5-5. IMASK | | | J | | | | | | |----------|----------|----------------|--------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|--| | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | RESERVED | | | | | | | | | R/W-0h | | | | | | | | | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | RESE | RVED | | | | | | R/W-0h | | | | | | | | | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | RESE | RVED | | | | | | R/W-0h | | | | | | | | | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | RESERVED | | | | | | DONE | | | R/W-0h | | | | | | R/W-0h | | | | 22<br>14 | 22 21<br>14 13 | 30 29 28 RESE R/V 22 21 20 RESE R/V 14 13 12 RESE R/V 6 5 4 RESERVED | 30 29 28 27 RESERVED R/W-0h 22 21 20 19 RESERVED R/W-0h 14 13 12 11 RESERVED R/W-0h 6 5 4 3 RESERVED | 30 29 28 27 26 RESERVED R/W-0h 22 21 20 19 18 RESERVED R/W-0h 14 13 12 11 10 RESERVED R/W-0h 6 5 4 3 2 RESERVED | 30 29 28 27 26 25 RESERVED R/W-0h 22 21 20 19 18 17 RESERVED R/W-0h 14 13 12 11 10 9 RESERVED R/W-0h 6 5 4 3 2 1 RESERVED | | # Table 5-15. IMASK Field Descriptions | | Bit | Field | Туре | Reset | Description | |---|------|----------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 3 | 31-1 | RESERVED | R/W | 0h | Reserved | | | 0 | DONE | R/W | 0h | Enable or disable the DONE interrupt. 0h (R/W) = Interrupt is masked out 1h (R/W) = Interrupt will request an interrupt service routine and corresponding bit in [IPSTANDARD.MIS] will be set | # 5.6.3 RIS (Offset = 1030h) [Reset = 00000000h] RIS is shown in Figure 5-6 and described in Table 5-16. Return to the Summary Table. The raw interrupt status (RIS) register holds the current raw interrupt status. # Figure 5-6. RIS | | | | i iguie . | 0 0. 11.0 | | | | | | |------|----------|----|-----------|-----------|----|----|------|--|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | RESERVED | | | | | | | | | | | R-0h | | | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | | | RESE | RVED | | | | | | | R-0h | | | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | | RESE | RVED | | | | | | | | | | R- | 0h | | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | RESERVED | | | | DONE | | | | | | | R-0h | | | | R-0h | | | # Table 5-16. RIS Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|-----------------------------------------------------------------------------------------------------| | 31-1 | RESERVED | R | 0h | Reserved | | 0 | DONE | R | | Raw status of the DONE interrupt. 0h (R/W) = Interrupt did not occur 1h (R/W) = Interrupt occurred | # 5.6.4 MIS (Offset = 1038h) [Reset = 00000000h] MIS is shown in Figure 5-7 and described in Table 5-17. Return to the Summary Table. The masked interrupt status (MIS) register holds the current masked interrupt status. # Figure 5-7. MIS | | | | 9 | <del>5 7 1 1111 5</del> | | | | | | |----|------|----|----------|-------------------------|----|----|------|--|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | | | RESE | RVED | | | | | | | | R-0h | | | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | | | RESE | RVED | | | | | | | | R-0h | | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | | RESE | RVED | | | | | | | | | | R- | 0h | | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | RESERVED | | | | DONE | | | | | | | R-0h | | | | R-0h | | | | 1 | | | | | | | | | | # **Table 5-17. MIS Field Descriptions** | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|----------------------------------------------------------------------------------------------------------------------| | 31-1 | RESERVED | R | 0h | Reserved | | 0 | DONE | R | | Masked status of the DONE interrupt. 0h (R/W) = Masked interrupt did not occur 1h (R/W) = Masked interrupt occurred | # 5.6.5 ISET (Offset = 1040h) [Reset = 00000000h] ISET is shown in Figure 5-8 and described in Table 5-18. Return to the Summary Table. The interrupt set (ISET) register may be used to set an interrupt to pending from software. # Figure 5-8. ISET | | | | . igaio c | | | | | | | |------|----------|----|-----------|------|----|----|------|--|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | RESERVED | | | | | | | | | | | W-0h | | | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | | | RESE | RVED | | | | | | | W-0h | | | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | | RESE | RVED | | | | | | | | | | W- | -0h | | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | RESERVED | | | | DONE | | | | | | | W-0h | | | | W-0h | | | # **Table 5-18. ISET Field Descriptions** | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|--------------------------------------------------------------------------------------------------| | 31-1 | RESERVED | W | 0h | Reserved | | 0 | DONE | W | | Set the DONE interrupt. 0h (R/W) = Writing a 0 has no effect 1h (R/W) = Set [IPSTANDARD.RIS] bit | # 5.6.6 ICLR (Offset = 1048h) [Reset = 00000000h] ICLR is shown in Figure 5-9 and described in Table 5-19. Return to the Summary Table. The interrupt clear (ICLR) register may be used to clear a pending interrupt. # Figure 5-9. ICLR | | | | J | | | | | | |----------|------|----|----------|------|----|----|------|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | RESERVED | | | | | | | | | | | W-0h | | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | | RESE | RVED | | | | | | | W-0h | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | RESE | RVED | | | | | | | | | W | -0h | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | RESERVED | | | | DONE | | | | | | W-0h | | | | W-0h | | | | | | | | | | | | # Table 5-19. ICLR Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|------------------------------------------------------------------------------------------------------| | 31-1 | RESERVED | W | 0h | Reserved | | 0 | DONE | W | | Clear the DONE interrupt. 0h (R/W) = Writing a 0 has no effect 1h (R/W) = Clear [IPSTANDARD.RIS] bit | # 5.6.7 CMDEXEC (Offset = 1100h) [Reset = 00000000h] CMDEXEC is shown in Figure 5-10 and described in Table 5-20. Return to the Summary Table. # Command Execute Register Initiates execution of the command specified in the CMDTYPE register. This register is blocked for writes after being written to 1 and prior to STATCMD.DONE being set by hardware. Hardware clears this register after the processing of the command has completed. Figure 5-10. CMDEXEC #### **Table 5-20. CMDEXEC Field Descriptions** | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-1 | RESERVED | R/W | 0h | Reserved | | 0 | VAL | R/W | 0h | Command Execute value Initiates execution of the command specified in the CMDTYPE register. 0h (R/W) = Command will not execute or is not executing in hardware 1h (R/W) = Command will execute or is executing in hardware | # 5.6.8 CMDTYPE (Offset = 1104h) [Reset = 00000000h] CMDTYPE is shown in Figure 5-11 and described in Table 5-21. Return to the Summary Table. # Command Type Register Specifies the type of command to be executed by hardware. This register is blocked for writes after CMDEXEC is written to a 1 and prior to STATCMD.DONE being set by the hardware to indicate that command execution has completed. Figure 5-11. CMDTYPE ### Table 5-21. CMDTYPE Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-7 | RESERVED | R/W | 0h | Reserved | | 6-4 | SIZE | R/W | 0h | Command size 0h (R/W) = Operate on 1 flash word 1h (R/W) = Operate on 2 flash words 2h (R/W) = Operate on 4 flash words 3h (R/W) = Operate on 8 flash words 4h (R/W) = Operate on a flash sector 5h (R/W) = Operate on an entire flash bank | | 3 | RESERVED | R/W | 0h | Reserved | | 2-0 | COMMAND | R/W | Oh | Command type 0h (R/W) = No Operation 1h (R/W) = Program 2h (R/W) = Erase 3h (R/W) = Read Verify - Perform a standalone read verify operation. 6h (R/W) = Blank Verify - Check whether a flash word is in the erased state. This command may only be used with CMDTYPE.SIZE = ONEWORD | # 5.6.9 CMDCTL (Offset = 1108h) [Reset = 00000000h] CMDCTL is shown in Figure 5-12 and described in Table 5-22. Return to the Summary Table. Command Control Register This register configures specific capabilities of the state machine for related to the execution of a command. This register is blocked for writes after CMDEXEC is written to a 1 and prior to STATCMD.DONE being set by the hardware to indicate that command execution has completed. Figure 5-12. CMDCTL Table 5-22. CMDCTL Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|--------------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-22 | RESERVED | R/W | 0h | Reserved | | 21 | RESERVED | R/W | 0h | | | 20 | SSERASEDIS | R/W | Oh | Disable Stair-Step Erase. If set, the default VHV trim voltage setting will be used for all erase pulses. By default, this bit is reset, meaning that the VHV voltage will be stepped during successive erase pulses. The step count, step voltage, begin and end voltages are all hardwired. 0h (R/W) = Enable 1h (R/W) = Disable | | 19-18 | RESERVED | R/W | 0h | | | 17 | ECCGENOVR | R/W | Oh | Override hardware generation of ECC data for program. Use data written to CMDDATAECC*. 0h (R/W) = Do not override 1h (R/W) = Override | | 16 | ADDRXLATEOVR | R/W | Oh | Override hardware address translation of address in CMDADDR from a system address to the corresponding bank address and bank ID. When set, CMDADDR will be used directly as the bank address, CMDCTL.REGIONSEL will be used directly as the region ID, and CMDCTL.BANKSEL will be used directly as the bank ID (if the device contains multiple banks). Oh (R/W) = Do not override 1h (R/W) = Override | | 15-14 | RESERVED | R/W | 0h | | | 13 | RESERVED | R/W | 0h | Reserved | | 12-9 | REGIONSEL | R/W | 0h | Bank Region A specific region ID can be written to this field to indicate to which region an operation should be applied if CMDCTL.ADDRXLATEOVR is set. 1h (R/W) = Main Region 2h (R/W) = Non-Main Region | # **Table 5-22. CMDCTL Field Descriptions (continued)** | Bit | Field | Туре | Reset | Description | | | | | |-----|----------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | 8-5 | RESERVED | R/W | 0h | | | | | | | 4 | BANKSEL | R/W | Oh | Bank Select A specific Bank ID can be written to this field to indicate to which bank an operation should be applied if CMDCTL.ADDRXLATEOVR is set. 1h (R/W) = Bank 0 2h (R/W) = Bank 1 4h (R/W) = Bank 2 8h (R/W) = Bank 3 10h (R/W) = Bank 4 | | | | | | 3-0 | RESERVED | R/W | 0h | | | | | | # 5.6.10 CMDADDR (Offset = 1120h) [Reset = 00000000h] CMDADDR is shown in Figure 5-13 and described in Table 5-23. Return to the Summary Table. ### Command Address Register: This register forms the target address of a command. The use cases are as follows: - 1) For single-word program, this address indicates the flash bank word to be programmed. - 2) For multi-word program, this address indicates the first flash bank address for the program. The address will be incremented for further words. - 3) For sector erase, this address indicates the sector to be erased. - 4) For bank erase, the address indicates the bank to be erased. - 5) For read verify, the address indications follow program/erase listed above. Note the address written to this register will be submitted for translation to the flash address translation interface, and the translated address will be used to access the bank. However, if the CMDCTL.ADDRXLATEOVR bit is set, then the address written to this register will be used directly as the bank address. This register is blocked for writes after a 1 is written to the CMDEXEC register and prior to STATCMD.DONE being set by hardware. #### Figure 5-13. CMDADDR ### **Table 5-23. CMDADDR Field Descriptions** | _ | | | | | • | |---|------|-------|------|-------|-----------------------------------------------------------------------------| | | Bit | Field | Туре | Reset | Description | | | 31-0 | VAL | R/W | | Address value 0h = Minimum value of [VAL] FFFFFFFh = Maximum value of [VAL] | # 5.6.11 CMDBYTEN (Offset = 1124h) [Reset = 00000000h] CMDBYTEN is shown in Figure 5-14 and described in Table 5-24. Return to the Summary Table. #### Command Program Byte Enable Register: This register forms a per-byte enable for programming data. For data bytes to be programmed, a 1 must be written to the corresponding bit in this register. Normally, all bits are written to 1, allowing program of full flash words. However, leaving some bits 0 allows programming of 8-bit, 16-bit, 32-bit or 64-bit portions of a flash word. In addition, the read verify command will ignore data bytes read from the flash in its comparison if the corresponding CMDBYTEN bit is 0. ECC data bytes are protected by the 1-2 MSB bits in this register, depending on the presence of ECC and the flash word data width. This register is blocked for writes after a 1 is written to the CMDEXEC register and prior to STATCMD.DONE being set by hardware. This register is written to all 0 after the completion of all commands. ### Figure 5-14. CMDBYTEN #### **Table 5-24. CMDBYTEN Field Descriptions** | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-18 | RESERVED | R/W | 0h | Reserved | | 17-8 | RESERVED | R/W | 0h | | | 7-0 | VAL | R/W | Oh | Command Byte Enable value. A 1-bit per flash word byte value is placed in this register. 0h = Minimum value of [VAL] 0003FFFh = Maximum value of [VAL] | # 5.6.12 CMDDATAINDEX (Offset = 112Ch) [Reset = 00000000h] CMDDATAINDEX is shown in Figure 5-15 and described in Table 5-25. Return to the Summary Table. Command Program Data Index Register: When multiple data registers are available for multi-word program, this register can be written with an index which points to one of the data registers. When a write to CMDDATA\* is done, the data will be written to the physical data register indexed by the value in this register. Up to 8 data registers can be present, so this register can be written with 0x0 to 0x7. If less than 8 data registers are present, successive MSB bits of this register are ignored when indexing the CMDDATA\* registers. This register is blocked for writes after a 1 is written to the CMDEXEC register and prior to STATCMD.DONE being set by hardware. #### Figure 5-15. CMDDATAINDEX #### **Table 5-25. CMDDATAINDEX Field Descriptions** | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|-----------------------------------------------------------------------------| | 31-3 | RESERVED | R/W | 0h | Reserved | | 2-0 | VAL | R/W | 0h | Data register index 0h = Minimum value of [VAL] 7h = Maximum value of [VAL] | # 5.6.13 CMDDATA0 (Offset = 1130h) [Reset = FFFFFFFh] CMDDATA0 is shown in Figure 5-16 and described in Table 5-26. Return to the Summary Table. ### Command Data Register 0 This register contains the data for a command. This register represents bits 31:0 of flash word data register 0. This register is blocked for writes after a 1 is written to the CMDEXEC register and prior to STATCMD.DONE being set by hardware. This register is used to aggregate masking for bits that do not require additional program pulses during program operations, and will be written to all 1 after the completion of all NoWrapper commands. Use cases for the CMDDATA\* registers are as follows: - 1) Program These registers contain the data to be programmed. - 2) Erase These registers are not used. - 3) Read Verify These registers contain data to be verified. ### Figure 5-16. CMDDATA0 #### Table 5-26. CMDDATA0 Field Descriptions | Bit | Field | Туре | Reset | Description | |------|-------|------|-------|--------------------------------------------------------------------------------------------------------------| | 31-0 | VAL | R/W | | A 32-bit data value is placed in this field. 0h = Minimum value of [VAL] FFFFFFFF = Maximum value of [VAL] | # 5.6.14 CMDDATA1 (Offset = 1134h) [Reset = FFFFFFFh] CMDDATA1 is shown in Figure 5-17 and described in Table 5-27. Return to the Summary Table. ### Command Data Register 1 This register contains the data for a command. This register represents bits 63:32 of flash word data register 0. This register is blocked for writes after a 1 is written to the CMDEXEC register and prior to STATCMD.DONE being set by hardware. This register is used to aggregate masking for bits that do not require additional program pulses during program operations, and will be written to all 1 after the completion of all NoWrapper commands. Use cases for the CMDDATA\* registers are as follows: - 1) Program These registers contain the data to be programmed. - 2) Erase These registers are not used. - 3) Read Verify These registers contain data to be verified. ### Figure 5-17. CMDDATA1 #### Table 5-27. CMDDATA1 Field Descriptions | Bit | Field | Туре | Reset | Description | |------|-------|------|-------|--------------------------------------------------------------------------------------------------------------| | 31-0 | VAL | R/W | | A 32-bit data value is placed in this field. 0h = Minimum value of [VAL] FFFFFFFF = Maximum value of [VAL] | # 5.6.15 CMDDATA2 (Offset = 1138h) [Reset = FFFFFFFh] CMDDATA2 is shown in Figure 5-18 and described in Table 5-28. Return to the Summary Table. ### Command Data Register 2 This register contains the data for a command. This register represents bits 31:0 of flash word data register 1. This register is blocked for writes after a 1 is written to the CMDEXEC register and prior to STATCMD.DONE being set by hardware. This register is used to aggregate masking for bits that do not require additional program pulses during program operations, and will be written to all 1 after the completion of all NoWrapper commands. Use cases for the CMDDATA\* registers are as follows: - 1) Program These registers contain the data to be programmed. - 2) Erase These registers are not used. - 3) Read Verify These registers contain data to be verified. ### Figure 5-18. CMDDATA2 # Table 5-28. CMDDATA2 Field Descriptions | Bit | Field | Туре | Reset | Description | |------|-------|------|-------|--------------------------------------------------------------------------------------------------------------| | 31-0 | VAL | R/W | | A 32-bit data value is placed in this field. 0h = Minimum value of [VAL] FFFFFFFF = Maximum value of [VAL] | # 5.6.16 CMDDATA3 (Offset = 113Ch) [Reset = FFFFFFFh] CMDDATA3 is shown in Figure 5-19 and described in Table 5-29. Return to the Summary Table. Command Data Register 3 This register contains the data for a command. This register represents bits 63:32 of flash word data register 1. This register is blocked for writes after a 1 is written to the CMDEXEC register and prior to STATCMD.DONE being set by hardware. This register is used to aggregate masking for bits that do not require additional program pulses during program operations, and will be written to all 1 after the completion of all NoWrapper commands. Use cases for the CMDDATA\* registers are as follows: - 1) Program These registers contain the data to be programmed. - 2) Erase These registers are not used. - 3) Read Verify These registers contain data to be verified. ### Figure 5-19. CMDDATA3 ### Table 5-29. CMDDATA3 Field Descriptions | | Bit | Field | Туре | Reset | Description | |--|------|-------|------|----------|----------------------------------------------| | | 31-0 | VAL | R/W | FFFFFFFh | A 32-bit data value is placed in this field. | | | | | | | 0h = Minimum value of [VAL] | | | | | | | FFFFFFFh = Maximum value of [VAL] | # 5.6.17 CMDDATA4 (Offset = 1140h) [Reset = FFFFFFFh] CMDDATA4 is shown in Figure 5-20 and described in Table 5-30. Return to the Summary Table. ### Command Data Register 4 This register contains the data for a command. This register represents bits 31:0 of flash word data register 2. This register is blocked for writes after a 1 is written to the CMDEXEC register and prior to STATCMD.DONE being set by hardware. This register is used to aggregate masking for bits that do not require additional program pulses during program operations, and will be written to all 1 after the completion of all NoWrapper commands. Use cases for the CMDDATA\* registers are as follows: - 1) Program These registers contain the data to be programmed. - 2) Erase These registers are not used. - 3) Read Verify These registers contain data to be verified. ### Figure 5-20. CMDDATA4 #### Table 5-30. CMDDATA4 Field Descriptions | Bit | Field | Туре | Reset | Description | |------|-------|------|-------|--------------------------------------------------------------------------------------------------------------| | 31-0 | VAL | R/W | | A 32-bit data value is placed in this field. T 0h = Minimum value of [VAL] FFFFFFFF = Maximum value of [VAL] | # 5.6.18 CMDDATA5 (Offset = 1144h) [Reset = FFFFFFFh] CMDDATA5 is shown in Figure 5-21 and described in Table 5-31. Return to the Summary Table. Command Data Register 5 This register contains the data for a command. This register represents bits 63:32 of flash word data register 2. This register is blocked for writes after a 1 is written to the CMDEXEC register and prior to STATCMD.DONE being set by hardware. This register is used to aggregate masking for bits that do not require additional program pulses during program operations, and will be written to all 1 after the completion of all NoWrapper commands. Use cases for the CMDDATA\* registers are as follows: - 1) Program These registers contain the data to be programmed. - 2) Erase These registers are not used. - 3) Read Verify These registers contain data to be verified. ### Figure 5-21. CMDDATA5 #### Table 5-31. CMDDATA5 Field Descriptions | Bit | Field | Туре | Reset | Description | |------|-------|------|-------|--------------------------------------------------------------------------------------------------------------| | 31-0 | VAL | R/W | | A 32-bit data value is placed in this field. 0h = Minimum value of [VAL] FFFFFFFF = Maximum value of [VAL] | # 5.6.19 CMDDATA6 (Offset = 1148h) [Reset = FFFFFFFh] CMDDATA6 is shown in Figure 5-22 and described in Table 5-32. Return to the Summary Table. ### Command Data Register 6 This register contains the data for a command. This register represents bits 31:0 of flash word data register 3. This register is blocked for writes after a 1 is written to the CMDEXEC register and prior to STATCMD.DONE being set by hardware. This register is used to aggregate masking for bits that do not require additional program pulses during program operations, and will be written to all 1 after the completion of all NoWrapper commands. Use cases for the CMDDATA\* registers are as follows: - 1) Program These registers contain the data to be programmed. - 2) Erase These registers are not used. - 3) Read Verify These registers contain data to be verified. ### Figure 5-22. CMDDATA6 #### Table 5-32. CMDDATA6 Field Descriptions | Bit | Field | Туре | Reset | Description | |------|-------|------|-------|--------------------------------------------------------------------------------------------------------------| | 31-0 | VAL | R/W | | A 32-bit data value is placed in this field. 0h = Minimum value of [VAL] FFFFFFFF = Maximum value of [VAL] | # 5.6.20 CMDDATA7 (Offset = 114Ch) [Reset = FFFFFFFh] CMDDATA7 is shown in Figure 5-23 and described in Table 5-33. Return to the Summary Table. Command Data Register 7 This register contains the data for a command. This register represents bits 63:32 of flash word data register 3. This register is blocked for writes after a 1 is written to the CMDEXEC register and prior to STATCMD.DONE being set by hardware. This register is used to aggregate masking for bits that do not require additional program pulses during program operations, and will be written to all 1 after the completion of all NoWrapper commands. Use cases for the CMDDATA\* registers are as follows: - 1) Program These registers contain the data to be programmed. - 2) Erase These registers are not used. - 3) Read Verify These registers contain data to be verified. ### Figure 5-23. CMDDATA7 #### Table 5-33. CMDDATA7 Field Descriptions | Bit | Field | Туре | Reset | Description | |------|-------|------|-------|--------------------------------------------------------------------------------------------------------------| | 31-0 | VAL | R/W | | A 32-bit data value is placed in this field. 0h = Minimum value of [VAL] FFFFFFFF = Maximum value of [VAL] | # 5.6.21 CMDDATA8 (Offset = 1150h) [Reset = FFFFFFFh] CMDDATA8 is shown in Figure 5-24 and described in Table 5-34. Return to the Summary Table. ### Command Data Register 8 This register contains the data for a command. This register represents bits 31:0 of flash word data register 4. This register is blocked for writes after a 1 is written to the CMDEXEC register and prior to STATCMD.DONE being set by hardware. This register is used to aggregate masking for bits that do not require additional program pulses during program operations, and will be written to all 1 after the completion of all NoWrapper commands. Use cases for the CMDDATA\* registers are as follows: - 1) Program These registers contain the data to be programmed. - 2) Erase These registers are not used. - 3) Read Verify These registers contain data to be verified. ### Figure 5-24. CMDDATA8 #### Table 5-34. CMDDATA8 Field Descriptions | Bit | Field | Туре | Reset | Description | |------|-------|------|-------|--------------------------------------------------------------------------------------------------------------| | 31-0 | VAL | R/W | | A 32-bit data value is placed in this field. 0h = Minimum value of [VAL] FFFFFFFF = Maximum value of [VAL] | # 5.6.22 CMDDATA9 (Offset = 1154h) [Reset = FFFFFFFh] CMDDATA9 is shown in Figure 5-25 and described in Table 5-35. Return to the Summary Table. Command Data Register 9 This register contains the data for a command. This register represents bits 63:32 of flash word data register 4. This register is blocked for writes after a 1 is written to the CMDEXEC register and prior to STATCMD.DONE being set by hardware. This register is used to aggregate masking for bits that do not require additional program pulses during program operations, and will be written to all 1 after the completion of all NoWrapper commands. Use cases for the CMDDATA\* registers are as follows: - 1) Program These registers contain the data to be programmed. - 2) Erase These registers are not used. - 3) Read Verify These registers contain data to be verified. ### Figure 5-25. CMDDATA9 #### Table 5-35. CMDDATA9 Field Descriptions | Bit | Field | Туре | Reset | Description | |------|-------|------|-------|--------------------------------------------------------------------------------------------------------------| | 31-0 | VAL | R/W | | A 32-bit data value is placed in this field. 0h = Minimum value of [VAL] FFFFFFFF = Maximum value of [VAL] | # 5.6.23 CMDDATA10 (Offset = 1158h) [Reset = FFFFFFFh] CMDDATA10 is shown in Figure 5-26 and described in Table 5-36. Return to the Summary Table. Command Data Register 10 This register contains the data for a command. This register represents bits 31:0 of flash word data register 5. This register is blocked for writes after a 1 is written to the CMDEXEC register and prior to STATCMD.DONE being set by hardware. This register is used to aggregate masking for bits that do not require additional program pulses during program operations, and will be written to all 1 after the completion of all NoWrapper commands. Use cases for the CMDDATA\* registers are as follows: - 1) Program These registers contain the data to be programmed. - 2) Erase These registers are not used. - 3) Read Verify These registers contain data to be verified. ### Figure 5-26. CMDDATA10 #### Table 5-36. CMDDATA10 Field Descriptions | Bit | Field | Туре | Reset | Description | |------|-------|------|-------|--------------------------------------------------------------------------------------------------------------| | 31-0 | VAL | R/W | | A 32-bit data value is placed in this field. 0h = Minimum value of [VAL] FFFFFFFF = Maximum value of [VAL] | # 5.6.24 CMDDATA11 (Offset = 115Ch) [Reset = FFFFFFFh] CMDDATA11 is shown in Figure 5-27 and described in Table 5-37. Return to the Summary Table. Command Data Register 11 This register contains the data for a command. This register represents bits 63:32 of flash word data register 5. This register is blocked for writes after a 1 is written to the CMDEXEC register and prior to STATCMD.DONE being set by hardware. This register is used to aggregate masking for bits that do not require additional program pulses during program operations, and will be written to all 1 after the completion of all NoWrapper commands. Use cases for the CMDDATA\* registers are as follows: - 1) Program These registers contain the data to be programmed. - 2) Erase These registers are not used. - 3) Read Verify These registers contain data to be verified. ### Figure 5-27. CMDDATA11 #### Table 5-37. CMDDATA11 Field Descriptions | Bit | Field | Туре | Reset | Description | |------|-------|------|-------|--------------------------------------------------------------------------------------------------------------| | 31-0 | VAL | R/W | | A 32-bit data value is placed in this field. 0h = Minimum value of [VAL] FFFFFFFF = Maximum value of [VAL] | # 5.6.25 CMDDATA12 (Offset = 1160h) [Reset = FFFFFFFh] CMDDATA12 is shown in Figure 5-28 and described in Table 5-38. Return to the Summary Table. Command Data Register 12 This register contains the data for a command. This register represents bits 31:0 of flash word data register 6. This register is blocked for writes after a 1 is written to the CMDEXEC register and prior to STATCMD.DONE being set by hardware. This register is used to aggregate masking for bits that do not require additional program pulses during program operations, and will be written to all 1 after the completion of all NoWrapper commands. Use cases for the CMDDATA\* registers are as follows: - 1) Program These registers contain the data to be programmed. - 2) Erase These registers are not used. - 3) Read Verify These registers contain data to be verified. ### Figure 5-28. CMDDATA12 #### Table 5-38. CMDDATA12 Field Descriptions | Bit | Field | Туре | Reset | Description | |------|-------|------|-------|--------------------------------------------------------------------------------------------------------------| | 31-0 | VAL | R/W | | A 32-bit data value is placed in this field. 0h = Minimum value of [VAL] FFFFFFFF = Maximum value of [VAL] | # 5.6.26 CMDDATA13 (Offset = 1164h) [Reset = FFFFFFFh] CMDDATA13 is shown in Figure 5-29 and described in Table 5-39. Return to the Summary Table. Command Data Register 13 This register contains the data for a command. This register represents bits 63:32 of flash word data register 6. This register is blocked for writes after a 1 is written to the CMDEXEC register and prior to STATCMD.DONE being set by hardware. This register is used to aggregate masking for bits that do not require additional program pulses during program operations, and will be written to all 1 after the completion of all NoWrapper commands. Use cases for the CMDDATA\* registers are as follows: - 1) Program These registers contain the data to be programmed. - 2) Erase These registers are not used. - 3) Read Verify These registers contain data to be verified. ### Figure 5-29. CMDDATA13 #### Table 5-39. CMDDATA13 Field Descriptions | Bit | Field | Туре | Reset | Description | |------|-------|------|-------|--------------------------------------------------------------------------------------------------------------| | 31-0 | VAL | R/W | | A 32-bit data value is placed in this field. 0h = Minimum value of [VAL] FFFFFFFF = Maximum value of [VAL] | # 5.6.27 CMDDATA14 (Offset = 1168h) [Reset = FFFFFFFh] CMDDATA14 is shown in Figure 5-30 and described in Table 5-40. Return to the Summary Table. Command Data Register 14 This register contains the data for a command. This register represents bits 31:0 of flash word data register 7. This register is blocked for writes after a 1 is written to the CMDEXEC register and prior to STATCMD.DONE being set by hardware. This register is used to aggregate masking for bits that do not require additional program pulses during program operations, and will be written to all 1 after the completion of all NoWrapper commands. Use cases for the CMDDATA\* registers are as follows: - 1) Program These registers contain the data to be programmed. - 2) Erase These registers are not used. - 3) Read Verify These registers contain data to be verified. ### Figure 5-30. CMDDATA14 #### Table 5-40. CMDDATA14 Field Descriptions | Bit | Field | Туре | Reset | Description | |------|-------|------|-------|--------------------------------------------------------------------------------------------------------------| | 31-0 | VAL | R/W | | A 32-bit data value is placed in this field. 0h = Minimum value of [VAL] FFFFFFFF = Maximum value of [VAL] | # 5.6.28 CMDDATA15 (Offset = 116Ch) [Reset = FFFFFFFh] CMDDATA15 is shown in Figure 5-31 and described in Table 5-41. Return to the Summary Table. Command Data Register 15 This register contains the data for a command. This register represents bits 63:32 of flash word data register 7. This register is blocked for writes after a 1 is written to the CMDEXEC register and prior to STATCMD.DONE being set by hardware. This register is used to aggregate masking for bits that do not require additional program pulses during program operations, and will be written to all 1 after the completion of all NoWrapper commands. Use cases for the CMDDATA\* registers are as follows: - 1) Program These registers contain the data to be programmed. - 2) Erase These registers are not used. - 3) Read Verify These registers contain data to be verified. ### Figure 5-31. CMDDATA15 #### Table 5-41. CMDDATA15 Field Descriptions | Bit | Field | Туре | Reset | Description | |------|-------|------|-------|--------------------------------------------------------------------------------------------------------------| | 31-0 | VAL | R/W | | A 32-bit data value is placed in this field. 0h = Minimum value of [VAL] FFFFFFFF = Maximum value of [VAL] | # 5.6.29 CMDDATA16 (Offset = 1170h) [Reset = FFFFFFFh] CMDDATA16 is shown in Figure 5-32 and described in Table 5-42. Return to the Summary Table. Command Data Register 16 This register forms the data for a command. For DATAWIDTH == 128: This register represents bits 31:0 of flash word data register 4. This register is blocked for writes after a 1 is written to the CMDEXEC register and prior to STATCMD.DONE being set by the flash wrapper hardware. This register is used to aggregate masking for bits that do not require additional program pulses during program operations, and will be written to all 1 after the completion of all flash wrapper commands. - Use cases for the CMDDATA\* registers are as follows: 1) Program These registers contain the data to be programmed. - 2) Erase These registers are not used. - 3) Read Verify These registers contain data to be verified. # Figure 5-32. CMDDATA16 ### **Table 5-42. CMDDATA16 Field Descriptions** | Bit | Field | Туре | Reset | Description | |------|-------|------|-------|--------------------------------------------------------------------------------------------------------------| | 31-0 | VAL | R/W | | A 32-bit data value is placed in this field. 0h = Minimum value of [VAL] FFFFFFFF = Maximum value of [VAL] | # 5.6.30 CMDDATA17 (Offset = 1174h) [Reset = FFFFFFFh] CMDDATA17 is shown in Figure 5-33 and described in Table 5-43. Return to the Summary Table. Command Data Register 17 This register forms the data for a command. For DATAWIDTH == 128: This register represents bits 63:32 of flash word data register 4. This register is blocked for writes after a 1 is written to the CMDEXEC register and prior to STATCMD.DONE being set by the flash wrapper hardware. This register is used to aggregate masking for bits that do not require additional program pulses during program operations, and will be written to all 1 after the completion of all flash wrapper commands. - Use cases for the CMDDATA\* registers are as follows: 1) Program These registers contain the data to be programmed. - 2) Erase These registers are not used. - 3) Read Verify These registers contain data to be verified. #### Figure 5-33. CMDDATA17 #### Table 5-43. CMDDATA17 Field Descriptions | Bit | Field | Туре | Reset | Description | |------|-------|------|-------|--------------------------------------------------------------------------------------------------------------| | 31-0 | VAL | R/W | | A 32-bit data value is placed in this field. 0h = Minimum value of [VAL] FFFFFFFF = Maximum value of [VAL] | # 5.6.31 CMDDATA18 (Offset = 1178h) [Reset = FFFFFFFh] CMDDATA18 is shown in Figure 5-34 and described in Table 5-44. Return to the Summary Table. Command Data Register 18 This register forms the data for a command. For DATAWIDTH == 128: This register represents bits 95:64 of flash word data register 4. This register is blocked for writes after a 1 is written to the CMDEXEC register and prior to STATCMD.DONE being set by the flash wrapper hardware. This register is used to aggregate masking for bits that do not require additional program pulses during program operations, and will be written to all 1 after the completion of all flash wrapper commands. Use cases for the CMDDATA\* registers are as follows: - 1) Program These registers contain the data to be programmed. - 2) Erase These registers are not used. - 3) Read Verify These registers contain data to be verified. #### Figure 5-34. CMDDATA18 #### **Table 5-44. CMDDATA18 Field Descriptions** | Bit | Field | Туре | Reset | Description | |------|-------|------|-------|--------------------------------------------------------------------------------------------------------------| | 31-0 | VAL | R/W | | A 32-bit data value is placed in this field. 0h = Minimum value of [VAL] FFFFFFFF = Maximum value of [VAL] | # 5.6.32 CMDDATA19 (Offset = 117Ch) [Reset = FFFFFFFh] CMDDATA19 is shown in Figure 5-35 and described in Table 5-45. Return to the Summary Table. Command Data Register 19 This register forms the data for a command. For DATAWIDTH == 128: This register represents bits 127:96 of flash word data register 4. This register is blocked for writes after a 1 is written to the CMDEXEC register and prior to STATCMD.DONE being set by the flash wrapper hardware. This register is used to aggregate masking for bits that do not require additional program pulses during program operations, and will be written to all 1 after the completion of all flash wrapper commands. Use cases for the CMDDATA\* registers are as follows: - 1) Program These registers contain the data to be programmed. - 2) Erase These registers are not used. - 3) Read Verify These registers contain data to be verified. #### Figure 5-35. CMDDATA19 #### Table 5-45. CMDDATA19 Field Descriptions | Bit | Field | Туре | Reset | Description | |------|-------|------|-------|--------------------------------------------------------------------------------------------------------------| | 31-0 | VAL | R/W | | A 32-bit data value is placed in this field. 0h = Minimum value of [VAL] FFFFFFFF = Maximum value of [VAL] | # 5.6.33 CMDDATA20 (Offset = 1180h) [Reset = FFFFFFFh] CMDDATA20 is shown in Figure 5-36 and described in Table 5-46. Return to the Summary Table. Command Data Register 20 This register forms the data for a command. For DATAWIDTH == 128: This register represents bits 31:0 of flash word data register 5. This register is blocked for writes after a 1 is written to the CMDEXEC register and prior to STATCMD.DONE being set by the flash wrapper hardware. This register is used to aggregate masking for bits that do not require additional program pulses during program operations, and will be written to all 1 after the completion of all flash wrapper commands. Use cases for the CMDDATA\* registers are as follows: - 1) Program These registers contain the data to be programmed. - 2) Erase These registers are not used. - 3) Read Verify These registers contain data to be verified. #### Figure 5-36. CMDDATA20 #### **Table 5-46. CMDDATA20 Field Descriptions** | Bit | Field | Туре | Reset | Description | |------|-------|------|-------|--------------------------------------------------------------------------------------------------------------| | 31-0 | VAL | R/W | | A 32-bit data value is placed in this field. 0h = Minimum value of [VAL] FFFFFFFF = Maximum value of [VAL] | # 5.6.34 CMDDATA21 (Offset = 1184h) [Reset = FFFFFFFh] CMDDATA21 is shown in Figure 5-37 and described in Table 5-47. Return to the Summary Table. Command Data Register 21 This register forms the data for a command. For DATAWIDTH == 128: This register represents bits 63:32 of flash word data register 5. This register is blocked for writes after a 1 is written to the CMDEXEC register and prior to STATCMD.DONE being set by the flash wrapper hardware. This register is used to aggregate masking for bits that do not require additional program pulses during program operations, and will be written to all 1 after the completion of all flash wrapper commands. - Use cases for the CMDDATA\* registers are as follows: 1) Program These registers contain the data to be programmed. - 2) Erase These registers are not used. - 3) Read Verify These registers contain data to be verified. #### Figure 5-37. CMDDATA21 #### Table 5-47. CMDDATA21 Field Descriptions | Bit | Field | Туре | Reset | Description | |------|-------|------|-------|--------------------------------------------------------------------------------------------------------------| | 31-0 | VAL | R/W | | A 32-bit data value is placed in this field. 0h = Minimum value of [VAL] FFFFFFFF = Maximum value of [VAL] | # 5.6.35 CMDDATA22 (Offset = 1188h) [Reset = FFFFFFFh] CMDDATA22 is shown in Figure 5-38 and described in Table 5-48. Return to the Summary Table. Command Data Register 22 This register forms the data for a command. For DATAWIDTH == 128: This register represents bits 95:64 of flash word data register 5. This register is blocked for writes after a 1 is written to the CMDEXEC register and prior to STATCMD.DONE being set by the flash wrapper hardware. This register is used to aggregate masking for bits that do not require additional program pulses during program operations, and will be written to all 1 after the completion of all flash wrapper commands. Use cases for the CMDDATA\* registers are as follows: - 1) Program These registers contain the data to be programmed. - 2) Erase These registers are not used. - 3) Read Verify These registers contain data to be verified. #### Figure 5-38. CMDDATA22 #### **Table 5-48. CMDDATA22 Field Descriptions** | Bit | Field | Туре | Reset | Description | |------|-------|------|-------|--------------------------------------------------------------------------------------------------------------| | 31-0 | VAL | R/W | | A 32-bit data value is placed in this field. 0h = Minimum value of [VAL] FFFFFFFF = Maximum value of [VAL] | # 5.6.36 CMDDATA23 (Offset = 118Ch) [Reset = FFFFFFFh] CMDDATA23 is shown in Figure 5-39 and described in Table 5-49. Return to the Summary Table. Command Data Register 23 This register forms the data for a command. For DATAWIDTH == 128: This register represents bits 127:96 of flash word data register 5. This register is blocked for writes after a 1 is written to the CMDEXEC register and prior to STATCMD.DONE being set by the flash wrapper hardware. This register is used to aggregate masking for bits that do not require additional program pulses during program operations, and will be written to all 1 after the completion of all flash wrapper commands. Use cases for the CMDDATA\* registers are as follows: - Program These registers contain the data to be programmed. - 2) Erase These registers are not used. - 3) Read Verify These registers contain data to be verified. #### Figure 5-39. CMDDATA23 #### Table 5-49. CMDDATA23 Field Descriptions | Bit | Field | Туре | Reset | Description | |------|-------|------|-------|--------------------------------------------------------------------------------------------------------------| | 31-0 | VAL | R/W | | A 32-bit data value is placed in this field. 0h = Minimum value of [VAL] FFFFFFFF = Maximum value of [VAL] | # 5.6.37 CMDDATA24 (Offset = 1190h) [Reset = FFFFFFFh] CMDDATA24 is shown in Figure 5-40 and described in Table 5-50. Return to the Summary Table. Command Data Register 24 This register forms the data for a command. For DATAWIDTH == 128: This register represents bits 31:0 of flash word data register 6. This register is blocked for writes after a 1 is written to the CMDEXEC register and prior to STATCMD.DONE being set by the flash wrapper hardware. This register is used to aggregate masking for bits that do not require additional program pulses during program operations, and will be written to all 1 after the completion of all flash wrapper commands. Use cases for the CMDDATA\* registers are as follows: - 1) Program These registers contain the data to be programmed. - 2) Erase These registers are not used. - 3) Read Verify These registers contain data to be verified. #### Figure 5-40. CMDDATA24 #### **Table 5-50. CMDDATA24 Field Descriptions** | Bit | Field | Туре | Reset | Description | |------|-------|------|-------|--------------------------------------------------------------------------------------------------------------| | 31-0 | VAL | R/W | | A 32-bit data value is placed in this field. 0h = Minimum value of [VAL] FFFFFFFF = Maximum value of [VAL] | # 5.6.38 CMDDATA25 (Offset = 1194h) [Reset = FFFFFFFh] CMDDATA25 is shown in Figure 5-41 and described in Table 5-51. Return to the Summary Table. Command Data Register 25 This register forms the data for a command. For DATAWIDTH == 128: This register represents bits 63:32 of flash word data register 6. This register is blocked for writes after a 1 is written to the CMDEXEC register and prior to STATCMD.DONE being set by the flash wrapper hardware. This register is used to aggregate masking for bits that do not require additional program pulses during program operations, and will be written to all 1 after the completion of all flash wrapper commands. - Use cases for the CMDDATA\* registers are as follows: 1) Program These registers contain the data to be programmed. - 2) Erase These registers are not used. - 3) Read Verify These registers contain data to be verified. #### Figure 5-41. CMDDATA25 # Table 5-51. CMDDATA25 Field Descriptions | Bit | Field | Туре | Reset | Description | |------|-------|------|-------|--------------------------------------------------------------------------------------------------------------| | 31-0 | VAL | R/W | | A 32-bit data value is placed in this field. 0h = Minimum value of [VAL] FFFFFFFF = Maximum value of [VAL] | # 5.6.39 CMDDATA26 (Offset = 1198h) [Reset = FFFFFFFh] CMDDATA26 is shown in Figure 5-42 and described in Table 5-52. Return to the Summary Table. Command Data Register 26 This register forms the data for a command. For DATAWIDTH == 128: This register represents bits 95:64 of flash word data register 6. This register is blocked for writes after a 1 is written to the CMDEXEC register and prior to STATCMD.DONE being set by the flash wrapper hardware. This register is used to aggregate masking for bits that do not require additional program pulses during program operations, and will be written to all 1 after the completion of all flash wrapper commands. Use cases for the CMDDATA\* registers are as follows: - 1) Program These registers contain the data to be programmed. - 2) Erase These registers are not used. - 3) Read Verify These registers contain data to be verified. #### Figure 5-42. CMDDATA26 #### **Table 5-52. CMDDATA26 Field Descriptions** | Bit | Field | Туре | Reset | Description | |------|-------|------|-------|--------------------------------------------------------------------------------------------------------------| | 31-0 | VAL | R/W | | A 32-bit data value is placed in this field. 0h = Minimum value of [VAL] FFFFFFFF = Maximum value of [VAL] | # 5.6.40 CMDDATA27 (Offset = 119Ch) [Reset = FFFFFFFh] CMDDATA27 is shown in Figure 5-43 and described in Table 5-53. Return to the Summary Table. Command Data Register 27 This register forms the data for a command. For DATAWIDTH == 128: This register represents bits 127:96 of flash word data register 6. This register is blocked for writes after a 1 is written to the CMDEXEC register and prior to STATCMD.DONE being set by the flash wrapper hardware. This register is used to aggregate masking for bits that do not require additional program pulses during program operations, and will be written to all 1 after the completion of all flash wrapper commands. Use cases for the CMDDATA\* registers are as follows: - 1) Program These registers contain the data to be programmed. - 2) Erase These registers are not used. - 3) Read Verify These registers contain data to be verified. # Figure 5-43. CMDDATA27 #### Table 5-53. CMDDATA27 Field Descriptions | Bit | Field | Туре | Reset | Description | |------|-------|------|-------|--------------------------------------------------------------------------------------------------------------| | 31-0 | VAL | R/W | | A 32-bit data value is placed in this field. 0h = Minimum value of [VAL] FFFFFFFF = Maximum value of [VAL] | # 5.6.41 CMDDATA28 (Offset = 11A0h) [Reset = FFFFFFFh] CMDDATA28 is shown in Figure 5-44 and described in Table 5-54. Return to the Summary Table. Command Data Register 28 This register forms the data for a command. For DATAWIDTH == 128: This register represents bits 31:0 of flash word data register 7. This register is blocked for writes after a 1 is written to the CMDEXEC register and prior to STATCMD.DONE being set by the flash wrapper hardware. This register is used to aggregate masking for bits that do not require additional program pulses during program operations, and will be written to all 1 after the completion of all flash wrapper commands. Use cases for the CMDDATA\* registers are as follows: - 1) Program These registers contain the data to be programmed. - 2) Erase These registers are not used. - 3) Read Verify These registers contain data to be verified. #### Figure 5-44. CMDDATA28 #### **Table 5-54. CMDDATA28 Field Descriptions** | Bit | Field | Туре | Reset | Description | |------|-------|------|-------|--------------------------------------------------------------------------------------------------------------| | 31-0 | VAL | R/W | | A 32-bit data value is placed in this field. 0h = Minimum value of [VAL] FFFFFFFF = Maximum value of [VAL] | # 5.6.42 CMDDATA29 (Offset = 11A4h) [Reset = FFFFFFFh] CMDDATA29 is shown in Figure 5-45 and described in Table 5-55. Return to the Summary Table. Command Data Register 29 This register forms the data for a command. For DATAWIDTH == 128: This register represents bits 63:32 of flash word data register 7. This register is blocked for writes after a 1 is written to the CMDEXEC register and prior to STATCMD.DONE being set by the flash wrapper hardware. This register is used to aggregate masking for bits that do not require additional program pulses during program operations, and will be written to all 1 after the completion of all flash wrapper commands. Use cases for the CMDDATA\* registers are as follows: - 1) Program These registers contain the data to be programmed. - 2) Erase These registers are not used. - 3) Read Verify These registers contain data to be verified. #### Figure 5-45. CMDDATA29 #### Table 5-55. CMDDATA29 Field Descriptions | Bit | Field | Туре | Reset | Description | |------|-------|------|-------|--------------------------------------------------------------------------------------------------------------| | 31-0 | VAL | R/W | | A 32-bit data value is placed in this field. 0h = Minimum value of [VAL] FFFFFFFF = Maximum value of [VAL] | # 5.6.43 CMDDATA30 (Offset = 11A8h) [Reset = FFFFFFFh] CMDDATA30 is shown in Figure 5-46 and described in Table 5-56. Return to the Summary Table. Command Data Register 30 This register forms the data for a command. For DATAWIDTH == 128: This register represents bits 95:64 of flash word data register 7. This register is blocked for writes after a 1 is written to the CMDEXEC register and prior to STATCMD.DONE being set by the flash wrapper hardware. This register is used to aggregate masking for bits that do not require additional program pulses during program operations, and will be written to all 1 after the completion of all flash wrapper commands. Use cases for the CMDDATA\* registers are as follows: - 1) Program These registers contain the data to be programmed. - 2) Erase These registers are not used. - 3) Read Verify These registers contain data to be verified. #### Figure 5-46. CMDDATA30 #### **Table 5-56. CMDDATA30 Field Descriptions** | Bit | Field | Туре | Reset | Description | |------|-------|------|-------|--------------------------------------------------------------------------------------------------------------| | 31-0 | VAL | R/W | | A 32-bit data value is placed in this field. 0h = Minimum value of [VAL] FFFFFFFF = Maximum value of [VAL] | # 5.6.44 CMDDATA31 (Offset = 11ACh) [Reset = FFFFFFFh] CMDDATA31 is shown in Figure 5-47 and described in Table 5-57. Return to the Summary Table. Command Data Register 31 This register forms the data for a command. For DATAWIDTH == 128: This register represents bits 127:96 of flash word data register 7. This register is blocked for writes after a 1 is written to the CMDEXEC register and prior to STATCMD.DONE being set by the flash wrapper hardware. This register is used to aggregate masking for bits that do not require additional program pulses during program operations, and will be written to all 1 after the completion of all flash wrapper commands. Use cases for the CMDDATA\* registers are as follows: - 1) Program These registers contain the data to be programmed. - 2) Erase These registers are not used. - 3) Read Verify These registers contain data to be verified. #### Figure 5-47. CMDDATA31 #### Table 5-57. CMDDATA31 Field Descriptions | Bit | Field | Туре | Reset | Description | |------|-------|------|-------|--------------------------------------------------------------------------------------------------------------| | 31-0 | VAL | R/W | | A 32-bit data value is placed in this field. 0h = Minimum value of [VAL] FFFFFFFF = Maximum value of [VAL] | # 5.6.45 CMDDATAECC0 (Offset = 11B0h) [Reset = 0000FFFFh] CMDDATAECC0 is shown in Figure 5-48 and described in Table 5-58. Return to the Summary Table. #### Command Data Register 0 This register forms the ECC portion of the data for a command. This ECC data in this register covers flash data register 0. The hardware ECC generation can be overridden and ECC data developed elsewhere can be used. ECC data is placed in this register. This register is blocked for writes after a 1 is written to the CMDEXEC register and prior to STATCMD.DONE being set by hardware. Use cases for the CMDDATA\* registers are as follows: - 1) Program These registers contain the data to be programmed. - 2) Erase These registers are not used. - 3) Read Verify These registers contain data to be verified. This register is used to aggregate masking for bits that do not require additional program pulses during program operations, and will be written to all 1 after the completion of all commands. #### Figure 5-48. CMDDATAECC0 | 3 | 1 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 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 | ESE | RVE | D | | | | | | | | | | VA | L1 | | | | | | | VA | L0 | | | | | | | | | | | | | R/W | V-0h | | | | | | | | | | | R/W | -FFh | l | | | | | | R/W- | -FFh | | | | #### **Table 5-58. CMDDATAECCO Field Descriptions** | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|----------------------------------------------------------------------------------------------| | 31-16 | RESERVED | R/W | 0h | Reserved | | 15-8 | VAL1 | R/W | FFh | ECC data for bits 127:64 of the data is placed here. 0h = Minimum value FFh = Maximum value | | 7-0 | VAL0 | R/W | FFh | ECC data for bits 63:0 of the data is placed here. 0h = Minimum value FFh = Maximum value | # 5.6.46 CMDDATAECC1 (Offset = 11B4h) [Reset = 0000FFFFh] CMDDATAECC1 is shown in Figure 5-49 and described in Table 5-59. Return to the Summary Table. # Command Data Register 1 This register forms the ECC portion of the data for a command. This ECC data in this register covers flash data register 1. The hardware ECC generation can be overridden and ECC data developed elsewhere can be used. ECC data is placed in this register. This register is blocked for writes after a 1 is written to the CMDEXEC register and prior to STATCMD.DONE being set by hardware. Use cases for the CMDDATA\* registers are as follows: - 1) Program These registers contain the data to be programmed. - 2) Erase These registers are not used. - 3) Read Verify These registers contain data to be verified. This register is used to aggregate masking for bits that do not require additional program pulses during program operations, and will be written to all 1 after the completion of all commands. # Figure 5-49. CMDDATAECC1 | 3 | 3 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 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 | ESE | RVE | D | | | | | | | | | | VA | L1 | | | | | | | VA | L0 | | | | | | | | | | | | | R/W | V-0h | | | | | | | | | | | R/W | -FFh | 1 | | | | | | R/W | -FFh | ı | | | # Table 5-59. CMDDATAECC1 Field Descriptions | | | | = 2= | | |-------|----------|------|-------|-----------------------------------------------------------------------------------------------| | Bit | Field | Туре | Reset | Description | | 31-16 | RESERVED | R/W | 0h | Reserved | | 15-8 | VAL1 | R/W | FFh | ECC data for bits 127:64 of the data is placed here. 0h = Minimum value FFh = Maximum value | | 7-0 | VAL0 | R/W | FFh | ECC data for bits 63:0 of the data is placed here. 0h = Minimum value FFh = Maximum value | # 5.6.47 CMDDATAECC2 (Offset = 11B8h) [Reset = 0000FFFFh] CMDDATAECC2 is shown in Figure 5-50 and described in Table 5-60. Return to the Summary Table. # Command Data Register 2 This register forms the ECC portion of the data for a command. This ECC data in this register covers flash data register 2. The hardware ECC generation can be overridden and ECC data developed elsewhere can be used. ECC data is placed in this register. This register is blocked for writes after a 1 is written to the CMDEXEC register and prior to STATCMD.DONE being set by hardware. Use cases for the CMDDATA\* registers are as follows: - 1) Program These registers contain the data to be programmed. - 2) Erase These registers are not used. - 3) Read Verify These registers contain data to be verified. This register is used to aggregate masking for bits that do not require additional program pulses during program operations, and will be written to all 1 after the completion of all commands. #### Figure 5-50. CMDDATAECC2 #### **Table 5-60. CMDDATAECC2 Field Descriptions** | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|-----------------------------------------------------------------------------------------------| | 31-16 | RESERVED | R/W | 0h | Reserved | | 15-8 | VAL1 | R/W | FFh | ECC data for bits 127:64 of the data is placed here. 0h = Minimum value FFh = Maximum value | | 7-0 | VAL0 | R/W | FFh | ECC data for bits 63:0 of the data is placed here. 0h = Minimum value FFh = Maximum value | # 5.6.48 CMDDATAECC3 (Offset = 11BCh) [Reset = 0000FFFFh] CMDDATAECC3 is shown in Figure 5-51 and described in Table 5-61. Return to the Summary Table. #### Command Data Register 3 This register forms the ECC portion of the data for a command. This ECC data in this register covers flash data register 3. The hardware ECC generation can be overridden and ECC data developed elsewhere can be used. ECC data is placed in this register. This register is blocked for writes after a 1 is written to the CMDEXEC register and prior to STATCMD.DONE being set by hardware. Use cases for the CMDDATA\* registers are as follows: - 1) Program These registers contain the data to be programmed. - 2) Erase These registers are not used. - 3) Read Verify These registers contain data to be verified. This register is used to aggregate masking for bits that do not require additional program pulses during program operations, and will be written to all 1 after the completion of all commands. # Figure 5-51. CMDDATAECC3 #### Table 5-61. CMDDATAECC3 Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|-----------------------------------------------------------------------------------------------| | 31-16 | RESERVED | R/W | 0h | Reserved | | 15-8 | VAL1 | R/W | FFh | ECC data for bits 127:64 of the data is placed here. 0h = Minimum value FFh = Maximum value | | 7-0 | VAL0 | R/W | FFh | ECC data for bits 63:0 of the data is placed here. 0h = Minimum value FFh = Maximum value | # 5.6.49 CMDDATAECC4 (Offset = 11C0h) [Reset = 0000FFFFh] CMDDATAECC4 is shown in Figure 5-52 and described in Table 5-62. Return to the Summary Table. # Command Data Register 4 This register forms the ECC portion of the data for a command. This ECC data in this register covers flash data register 4. The hardware ECC generation can be overridden and ECC data developed elsewhere can be used. ECC data is placed in this register. This register is blocked for writes after a 1 is written to the CMDEXEC register and prior to STATCMD.DONE being set by hardware. Use cases for the CMDDATA\* registers are as follows: - 1) Program These registers contain the data to be programmed. - 2) Erase These registers are not used. - 3) Read Verify These registers contain data to be verified. This register is used to aggregate masking for bits that do not require additional program pulses during program operations, and will be written to all 1 after the completion of all commands. #### Figure 5-52. CMDDATAECC4 | 3 | 1 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 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 | ESE | RVE | D | | | | | | | | | | VA | L1 | | | | | | | VA | L0 | | | | | | | | | | | | | R/W | V-0h | | | | | | | | | | | R/W | -FFh | l | | | | | | R/W- | -FFh | | | | #### **Table 5-62. CMDDATAECC4 Field Descriptions** | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|-----------------------------------------------------------------------------------------------| | 31-16 | RESERVED | R/W | 0h | Reserved | | 15-8 | VAL1 | R/W | FFh | ECC data for bits 127:64 of the data is placed here. 0h = Minimum value FFh = Maximum value | | 7-0 | VAL0 | R/W | FFh | ECC data for bits 63:0 of the data is placed here. 0h = Minimum value FFh = Maximum value | # 5.6.50 CMDDATAECC5 (Offset = 11C4h) [Reset = 0000FFFFh] CMDDATAECC5 is shown in Figure 5-53 and described in Table 5-63. Return to the Summary Table. # Command Data Register 5 This register forms the ECC portion of the data for a command. This ECC data in this register covers flash data register 5. The hardware ECC generation can be overridden and ECC data developed elsewhere can be used. ECC data is placed in this register. This register is blocked for writes after a 1 is written to the CMDEXEC register and prior to STATCMD.DONE being set by hardware. Use cases for the CMDDATA\* registers are as follows: - 1) Program These registers contain the data to be programmed. - 2) Erase These registers are not used. - 3) Read Verify These registers contain data to be verified. This register is used to aggregate masking for bits that do not require additional program pulses during program operations, and will be written to all 1 after the completion of all commands. #### Figure 5-53. CMDDATAECC5 | 3 | 1 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 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 | ESE | RVE | D | | | | | | | | | | VA | L1 | | | | | | | VA | L0 | | | | | | | | | | | | | R/W | V-0h | | | | | | | | | | | R/W | -FFh | l | | | | | | R/W- | -FFh | | | | # Table 5-63. CMDDATAECC5 Field Descriptions | | Bit | Field | Туре | Reset | Description | | | | | |--|-------|----------|---------|-------|-----------------------------------------------------------------------------------------------|--|--|--|--| | | 31-16 | RESERVED | R/W | 0h | Reserved | | | | | | | 15-8 | VAL1 | R/W | FFh | ECC data for bits 127:64 of the data is placed here. 0h = Minimum value FFh = Maximum value | | | | | | | 7-0 | VAL0 | R/W FFh | | ECC data for bits 63:0 of the data is placed here. 0h = Minimum value FFh = Maximum value | | | | | # 5.6.51 CMDDATAECC6 (Offset = 11C8h) [Reset = 0000FFFFh] CMDDATAECC6 is shown in Figure 5-54 and described in Table 5-64. Return to the Summary Table. # Command Data Register 6 This register forms the ECC portion of the data for a command. This ECC data in this register covers flash data register 6. The hardware ECC generation can be overridden and ECC data developed elsewhere can be used. ECC data is placed in this register. This register is blocked for writes after a 1 is written to the CMDEXEC register and prior to STATCMD.DONE being set by hardware. Use cases for the CMDDATA\* registers are as follows: - 1) Program These registers contain the data to be programmed. - 2) Erase These registers are not used. - 3) Read Verify These registers contain data to be verified. This register is used to aggregate masking for bits that do not require additional program pulses during program operations, and will be written to all 1 after the completion of all commands. #### Figure 5-54. CMDDATAECC6 | 3 | 1 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|----------|----|----|----|----|----|----|----|----|----|------|----|-----|------|----|----|------|----|----|----|------|------|---|---|---|---|---|---|---|---|---|---| | | RESERVED | | | | | | | | | | VAL1 | | | | | | VAL0 | | | | | | | | | | | | | | | | | | R/W-0h | | | | | | | | | | | | R/W | -FFh | l | | | | | | R/W- | -FFh | | | | | | | | | | | #### **Table 5-64. CMDDATAECC6 Field Descriptions** | Bit | Field | Туре | Reset | Description | | | |-------|----------|------|-------|-----------------------------------------------------------------------------------------------|--|--| | 31-16 | RESERVED | R/W | 0h | Reserved | | | | 15-8 | VAL1 | R/W | FFh | ECC data for bits 127:64 of the data is placed here. 0h = Minimum value FFh = Maximum value | | | | 7-0 | VAL0 | R/W | FFh | ECC data for bits 63:0 of the data is placed here. 0h = Minimum value FFh = Maximum value | | | # 5.6.52 CMDDATAECC7 (Offset = 11CCh) [Reset = 0000FFFFh] CMDDATAECC7 is shown in Figure 5-55 and described in Table 5-65. Return to the Summary Table. #### Command Data Register 7 This register forms the ECC portion of the data for a command. This ECC data in this register covers flash data register 7. The hardware ECC generation can be overridden and ECC data developed elsewhere can be used. ECC data is placed in this register. This register is blocked for writes after a 1 is written to the CMDEXEC register and prior to STATCMD.DONE being set by hardware. Use cases for the CMDDATA\* registers are as follows: - 1) Program These registers contain the data to be programmed. - 2) Erase These registers are not used. - 3) Read Verify These registers contain data to be verified. This register is used to aggregate masking for bits that do not require additional program pulses during program operations, and will be written to all 1 after the completion of all commands. #### Figure 5-55. CMDDATAECC7 #### Table 5-65. CMDDATAECC7 Field Descriptions | Bit | Field | Туре | Reset | Description | | | |-------|----------|------|-------|-----------------------------------------------------------------------------------------------|--|--| | 31-16 | RESERVED | R/W | 0h | Reserved | | | | 15-8 | VAL1 | R/W | FFh | ECC data for bits 127:64 of the data is placed here. 0h = Minimum value FFh = Maximum value | | | | 7-0 | VAL0 | R/W | FFh | ECC data for bits 63:0 of the data is placed here. 0h = Minimum value FFh = Maximum value | | | # 5.6.53 CMDWEPROTA (Offset = 11D0h) [Reset = FFFFFFFh] CMDWEPROTA is shown in Figure 5-56 and described in Table 5-66. Return to the Summary Table. Command WriteErase Protect A Register This register allows the first 32 sectors of the main region to be protected from program or erase, with 1 bit protecting each sector. If the main region size is smaller than 32 sectors, then this register provides protection for the whole region. This register is blocked for writes after a 1 is written to the CMDEXEC register and prior to STATCMD.DONE being set by hardware. In addition, this register is used to aggregate masking for sectors that do not require additional erase pulses during bank erase operations, and will be written to all 1 after the completion of all commands. #### Figure 5-56. CMDWEPROTA #### **Table 5-66. CMDWEPROTA Field Descriptions** | Bit | Field | Туре | Reset | Description | |------|-------|------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-0 | VAL | R/W | FFFFFFFh | Each bit protects 1 sector. bit [0]: When 1, sector 0 of the flash memory will be protected from program and erase. bit [1]: When 1, sector 1 of the flash memory will be protected from program and erase. : bit [31]: When 1, sector 31 of the flash memory will be protected from program and erase. 0h = Minimum value of [VAL] FFFFFFFFF = Maximum value of [VAL] | #### 5.6.54 CMDWEPROTB (Offset = 11D4h) [Reset = FFFFFFFh] CMDWEPROTB is shown in Figure 5-57 and described in Table 5-67. Return to the Summary Table. Command WriteErase Protect B Register This register allows main region sectors to be protected from program and erase. Each bit corresponds to a group of 8 sectors. There are 3 cases for how these protect bits are applied: #### 1. Single-bank system: In the case where only a single flash bank is present, the first 32 sectors are protected via the CMDWEPROTA register. Thus, the protection give by the bits in CMDWEPROTB begin with sector 32. #### 2. Multi-bank system, Bank 0: When multiple flash banks are present, the first 32 sectors of bank 0 are protected via the CMDWEPROTA register. Thus, only bits 4 and above of CMDWEPROTB would be applicable to bank 0. The protection of bit 4 and above would begin at sector 32. Bits 3:0 of WEPROTB are ignored for bank 0. 3. Multi-bank system, Banks 1-N: For banks other than bank 0 in a multi-bank system, CMDWEPROTA has no effect, so the bits in CMDWEPROTB will protect these banks starting from sector 0. This register is blocked for writes after a 1 is written to the CMDEXEC register and prior to STATCMD.DONE being set by hardware. In addition, this register is used to aggregate masking for sectors that do not require additional erase pulses during bank erase operations, and will be written to all 1 after the completion of all commands. # Figure 5-57. CMDWEPROTB #### Table 5-67. CMDWEPROTB Field Descriptions | Bit | t | Field | Туре | Reset | Description | |-----|---|-------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31- | 0 | VAL | R/W | | Each bit protects a group of 8 sectors. When a bit is 1, the associated 8 sectors in the flash will be protected from program and erase. A maximum of 256 sectors can be protected with this register. 0h = Minimum value of [VAL] FFFFFFFF = Maximum value of [VAL] | # 5.6.55 CMDWEPROTC (Offset = 11D8h) [Reset = FFFFFFFh] CMDWEPROTC is shown in Figure 5-58 and described in Table 5-68. Return to the Summary Table. Command WriteErase Protect C Register This register allows main region sectors to be protected from program and erase. Each bit corresponds to a group of 8 sectors. This register extends the protection bits from the CMDWEPROTB register to cover bank sizes larger than 32\*8=256 sectors. This register is blocked for writes after a 1 is written to the CMDEXEC register and prior to STATCMD.DONE being set by hardware. In addition, this register is used to aggregate masking for sectors that do not require additional erase pulses during bank erase operations, and will be written to all 1 after the completion of all commands. #### Figure 5-58. CMDWEPROTC #### **Table 5-68. CMDWEPROTC Field Descriptions** | _ | | | | | | |---|------|-------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | Bit | Field | Туре | Reset | Description | | | 31-0 | VAL | R/W | | Each bit protects a group of 8 sectors. When a bit is 1, the associated 8 sectors in the flash will be protected from program and erase. Note that the sectors protected with this register start at sector 256 in the flash, where the sectors protected by the CMDWEPROTB register end. 0h = Minimum value of [VAL] FFFFFFFF = Maximum value of [VAL] | # 5.6.56 CMDWEPROTNM (Offset = 1210h) [Reset = FFFFFFFh] CMDWEPROTNM is shown in Figure 5-59 and described in Table 5-69. Return to the Summary Table. Command WriteErase Protect Non-Main Register This register allows non-main region region sectors to be protected from program and erase. Each bit corresponds to 1 sector. This register is blocked for writes after a 1 is written to the CMDEXEC register and prior to STATCMD.DONE being set by hardware. In addition, this register is used to aggregate masking for sectors that do not require additional erase pulses during bank erase operations, and will be written to all 1 after the completion of all commands. #### Figure 5-59. CMDWEPROTNM #### Table 5-69. CMDWEPROTNM Field Descriptions | Bit | Field | Туре | Reset | Description | |------|-------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-0 | VAL | R/W | | Each bit protects 1 sector. bit [0]: When 1, sector 0 of the non-main region will be protected from program and erase. bit [1]: When 1, sector 1 of the non-main region will be protected from program and erase. : bit [31]: When 1, sector 31 of the non-main will be protected from program and erase. Oh = Minimum value of [VAL] FFFFFFFF = Maximum value of [VAL] | # 5.6.57 CFGPCNT (Offset = 13B4h) [Reset = 00000000h] CFGPCNT is shown in Figure 5-60 and described in Table 5-70. Return to the Summary Table. Pulse Counter Configuration Register This register allows further configuration of maximum pulse counts for program and erase operations. This register is blocked for writes after a 1 is written to the CMDEXEC register and prior to STATCMD.DONE being set by hardware. Figure 5-60. CFGPCNT | | | | i igui e 3-00 | . 01 01 011 | | | | | | |----|--------|---------|---------------|---------------|----------|-------|-------------------|--|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | | | MAXERS | PCNTVAL | | | | | | | | | | R/V | V-0h | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | MAXERS | PCNTVAL | | | RESERVED | | MAXERSPCNT<br>OVR | | | | | R/V | V-0h | | R/W-0h R/W-0h | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | RESE | RVED | | | MAXPC | NTVAL | | | | | | R/V | V-0h | | | R/W- | ·0h | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | MAXPO | CNTVAL | | | RESERVED | | MAXPCNTOVR | | | | | R/V | V-0h | | | R/W-0h | | R/W-0h | | | | | | | | | | | | | | # Table 5-70. CFGPCNT Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|---------------|------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-20 | MAXERSPCNTVAL | R/W | Oh | Override maximum pulse count for erase with this value. If MAXERSPCNTOVR = 0, then this field is ignored. If MAXERSPCNTOVR = 1, then this value will be used to override the max pulse count for erase. Oh = Minimum value FFFh = Maximum value | | 19-17 | RESERVED | R/W | 0h | Reserved | | 16 | MAXERSPCNTOVR | OVR R/W 0h | | Override hard-wired maximum pulse count for erase. If set, then the value in MAXERSPCNTVAL will be used as the max pulse count for erase operations. By default, this bit is 0, and a hard-wired max pulse count is used. Oh = Use hard-wired (default) value for maximum pulse count 1h = Use value from MAXERSPCNTVAL field as maximum erase pulse count | | 15-12 | RESERVED | R/W | 0h | Reserved | | 11-4 | MAXPCNTVAL | R/W | 0h | Override maximum pulse counter with this value. If MAXPCNTOVR = 0, then this field is ignored. If MAXPCNTOVR = 1 and MAXERSPCNTOVR = 0, then this value will be used to override the max pulse count for both program and erase. Full max value will be {4'h0, MAXPCNTVAL}. If MAXPCNTOVR = 1 and MAXERSPCNTOVR = 1, then this value will be used to override the max pulse count for program only. Full max value will be {4'h0, MAXPCNTVAL}. Oh = Minimum value FFh = Maximum value | | 3-1 | RESERVED | R/W | 0h | Reserved | # Table 5-70. CFGPCNT Field Descriptions (continued) | | | | | • • • | |-----|------------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Field | Туре | Reset | Description | | 0 | MAXPCNTOVR | R/W | Oh | Override hard-wired maximum pulse count. If MAXERSPCNTOVR is not set, then setting this value alone will override the max pulse count for both program and erase. If MAXERSPCNTOVR is set, then this bit will only control the max pulse count setting for program. By default, this bit is 0, and a hard-wired max pulse count is used. 0h = Use hard-wired (default) value for maximum pulse count 1h = Use value from MAXPCNTVAL field as maximum puse count | # 5.6.58 STATCMD (Offset = 13D0h) [Reset = 00000000h] STATCMD is shown in Figure 5-61 and described in Table 5-71. Return to the Summary Table. Command Status Register This register contains status regarding completion and errors of command execution. # Figure 5-61. STATCMD | | | | i igaic o o i | | | | | | | | | |----------|-------------|------------|---------------|----------|-------------------|---------|----------|--|--|--|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | | | RESERVED | | | | | | | | | | | | R-0h | | | | | | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | | | | | RESE | RVED | | | | | | | | | | | | R- | 0h | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | | RESERVED | | FAILMISC | | RESERVED | | RESERVED | | | | | | | R-0h | | R-0h | | R-0h | | R- | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | FAILMODE | FAILILLADDR | FAILVERIFY | FAILWEPROT | RESERVED | CMDINPROGR<br>ESS | CMDPASS | CMDDONE | | | | | | R-0h | | | | # **Table 5-71. STATCMD Field Descriptions** | Bit | Field | Туре | Reset | Description | |-------|---------------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-13 | RESERVED | R | 0h | Reserved | | 12 | FAILMISC | R | 0h | Command failed due to error other than write/erase protect violation or verify error. This is an extra bit in case a new failure mechanism is added which requires a status bit. Oh = No Fail 1h = Fail | | 11-9 | RESERVED | R | 0h | Reserved | | 8 | RESERVED | R | 0h | | | 7 | FAILMODE | R | 0h | Command failed because a bank has been set to a mode other than READ. Program and Erase commands cannot be initiated unless all banks are in READ mode. 0h = No Fail 1h = Fail | | 6 | FAILILLADDR | R | 0h | Command failed due to the use of an illegal address 0h = No Fail 1h = Fail | | 5 | FAILVERIFY | R | 0h | Command failed due to verify error 0h = No Fail 1h = Fail | | 4 | FAILWEPROT | R | Oh | Command failed due to Write/Erase Protect Sector Violation 0h = No Fail 1h = Fail | | 3 | RESERVED | R | 0h | Reserved | | 2 | CMDINPROGRESS | R | Oh | Command In Progress 0h = Complete 1h = In Progress | | 1 | CMDPASS | R | Oh | Command Pass - valid when CMD_DONE field is 1 0h = Fail 1h = Pass | # **Table 5-71. STATCMD Field Descriptions (continued)** | Bi | it | Field | Туре | Reset | Description | |----|----|---------|------|-------|--------------------------------------| | 0 | ) | CMDDONE | R | 0h | Command Done 0h = Not Done 1h = Done | # 5.6.59 STATADDR (Offset = 13D4h) [Reset = 00010000h] STATADDR is shown in Figure 5-62 and described in Table 5-72. Return to the Summary Table. Current Address Counter Value Read only register giving read access to the state machine current address. A bank id, region id and address are stored in this register and are incremented as necessary during execution of a command. Figure 5-62. STATADDR Table 5-72. STATADDR Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-26 | RESERVED | R | 0h | Reserved | | 25-21 | BANKID | R | Oh | Current Bank ID A bank indicator is stored in this register which represents the current bank on which the state machine is operating. There is 1 bit per bank. 1h (R/W) = Bank 0 2h (R/W) = Bank 1 4h (R/W) = Bank 2 8h (R/W) = Bank 3 10h (R/W) = Bank 4 | | 20-16 | REGIONID | R | 1h | Current Region ID A region indicator is stored in this register which represents the current flash region on which the state machine is operating. 1h (R/W) = Main Region 2h (R/W) = Non-Main Region 4h (R/W) = Trim Region 8h (R/W) = Engr Region | | 15-0 | BANKADDR | R | 0h | Current Bank Address A bank offset address is stored in this register. 0h = Minimum value FFFFh = Maximum value | # 5.6.60 STATPCNT (Offset = 13D8h) [Reset = 00000000h] STATPCNT is shown in Figure 5-63 and described in Table 5-73. Return to the Summary Table. Current Pulse Count Register: Read only register giving read access to the state machine current pulse count value for program/erase operations. #### Figure 5-63. STATPCNT # Table 5-73. STATPCNT Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|---------------------------------------------------------------------| | 31-12 | RESERVED | R | 0h | Reserved | | 11-0 | PULSECNT | R | | Current Pulse Counter Value 0h = Minimum value FFFh = Maximum value | This page intentionally left blank. # Chapter 6 **Events** The event manager provides the peripheral-to-peripheral, peripheral-to-DMA, and peripheral-to-CPU (IRQ) event connections. | 6.1 Events Overview | 360 | |----------------------|-----| | 6.2 Events Operation | 363 | Events www.ti.com #### 6.1 Events Overview The event manager transfers digital events from one entity (for example, a peripheral) to another (for example, a second peripheral, the DMA, or the CPU). The event manager implements event transfer through a defined set of event publishers (generators) and subscribers (receivers) which are interconnected through an event fabric containing a combination of fixed (static) and programmable routes. Events which are transferred by the event manager include: - Peripheral event transferred to the CPU as an interrupt request (IRQ) - Example: RTC interrupt is sent to the CPU - Peripheral event transferred to the DMA as a DMA trigger - Example: UART data receive trigger to DMA to request a DMA transfer - · Peripheral event transferred to another peripheral to directly trigger an action in hardware - Example: TIMx timer peripheral publishes a periodic event to the ADC subscriber port, and the ADC uses the event to trigger start-of-sampling In addition to providing the event transfer logic, the event manager also interfaces with the power management and clock unit (PMCU) if an event requires the power and/or clock configuration of the device to change to handle the event properly. For example, if a peripheral asserts an event that targets the DMA, and the device is in a STOP or STANDBY operating mode (DMA is disabled), the event manager will handshake with the PMCU to suspend the low power operating mode state temporarily and enable the DMA such that the DMA transfer can be processed. The event manager configuration is device dependent, as different devices support different peripherals. See the device-specific data sheet for information on the device-specific event implementation. #### 6.1.1 Event Publisher An event publisher is the source of an event which is propagated on the event fabric. Peripherals contain event publishers for publishing CPU interrupts, DMA triggers and generic events to the event fabric through the publishing port FPUB x. Publisher behavior is configured with standardized event management registers. #### 6.1.2 Event Subscriber Event subscribers are included within the processor, the DMA, and certain peripherals (see Section 6.1.4). Event subscribers subscribe the events through the subscribing port FSUB\_x. Event subscribers enable modules to be able to subscribe to, and take a predefined action upon, events which are published to the event fabric by an event publisher. #### 6.1.3 Event Fabric Routing There are three different types of routes through the event fabric which are used to connect a publisher to a subscriber: CPU interrupt events, DMA trigger events, and generic events. # 6.1.3.1 CPU Interrupt Event Route (CPU\_INT) A CPU interrupt event route is a fixed, point-to-point connection between one event publisher (inside a peripheral module) and one event subscriber (the CPU subsystem) used to propagate CPU interrupts. Figure 6-1. CPU Interrupt (Fixed Event Route) www.ti.com Events For each peripheral which is capable of generating a CPU interrupt, a fixed route is provided from the peripheral's masked interrupt status (MIS) register to the CPU subsystem's interrupt management logic. If software does not clear the interrupt request in the peripheral's event management registers, the request will remain pending to the CPU subsystem. See Section 6.2.5.3 for guidance on setting and clearing interrupt status with the event management registers. ## 6.1.3.2 DMA Trigger Event Route (DMA TRIGX) A DMA route is a fixed route between a peripheral and the DMA controller, which optionally has additional side-band signals to pass a DMA done condition from the DMA controller back to the triggering peripheral to indicate when a DMA activity has run to completion. The DMA trigger route is shown in Figure 6-2. Figure 6-2. DMA Route Most peripherals capable of generating a DMA trigger have an additional set of event management registers (in addition to the CPU\_INT registers used for the CPU interrupt and any GEN\_EVENTx generic route publishers). These registers can be used to select which peripheral condition to use for generating the DMA trigger. When a trigger is received by the DMA, the DMA acknowledges the request and the peripheral clears the request. The DMA also acknowledges the cleared request, after which a new request can be asserted by the peripheral. The DMA route can also contain status signals (for specific peripherals) to indicate to the triggering peripheral that a DMA transfer sequence has completed. For example, the DMA can be set up to transfer *N* number of bytes from an SRAM buffer into the UART TX data register based on the UART TX DMA trigger. Upon each trigger from the UART, the DMA will acknowledge that the transfer was successful. On the *N*th byte, the DMA will send a complete status signal to the UART, which the UART can use to propagate a transfer completion interrupt to the CPU. ## **Special Cases** Certain peripherals (for example, the 12-bit DAC) do not implement an event management register set for managing their DMA triggers. In these cases, the peripheral implements specific DMA configuration logic such that the management registers are not needed to interface with the DMA. Figure 6-3 shows the model when the event management registers are not implemented. See the peripheral-specific section of this document for guidance on how to configure DMA channels in this case. Figure 6-3. DMA Route without Event Management Registers Events www.ti.com ## 6.1.3.3 Generic Event Route (GEN EVENTx) A generic route is either a point-to-point (1:1) route or a point-to-two (1:2) splitter route in which the peripheral publishing the event uses one of several available generic route channels to publish its event to another entity (or entities, in the case of a splitter route), where an entity can be another peripheral, a generic DMA trigger event, or a generic CPU event, as shown in Figure 6-4. Figure 6-4. Generic Route Peripherals capable of generating a generic event have an additional group (our groups) of GEN\_EVENTx event management registers (in addition to the CPU\_INT registers used for the CPU interrupt or DMA\_TRIGx for DMA, if present). These registers can be used to select the peripheral condition to use for publishing a generic event. When configured, the event will broadcast out to the generic route channel selected by the FPUB\_x register. A second peripheral, the DMA, or the CPU can subscribe to this event by configuring its generic subscriber port (FSUB x) to listen on the same generic route channel to which the publishing peripheral is connected to. Generic route channels can be configured with one subscriber (1:1 route) or two subscribers (1:2 splitter route), depending on which channel is selected. See the device data sheet for a complete listing of the available generic route channels and their type (1:1 or 1:2). Generic route channels can only be configured with one publishing peripheral at a time. Once a peripheral subscribes to a 1:1 generic route channel, no other peripheral will be able to select that channel to subscribe to, unless the originally connected peripheral is disconnected first. Generic route channels with splitter capability (1:2) enable exactly two peripherals to subscribe to the channel, after which additional attempts to add subscribers will be blocked by hardware until both of the two connected peripherals are disconnected from the splitter channel. Each peripheral type has unique capabilities in terms of what can generate an event to publish, and what a subscribed event is capable of triggering within the peripheral. Review the chapter of this guide which corresponds to the peripheral of interest to understand what the publisher and subscriber ports on a given peripheral are capable of. ## 6.1.4 Event Routing Map The event capabilities of each peripheral type are shown in Figure 6-5. Peripherals such as UART, SPI, and I2C generate CPU interrupt events which are routed to the CPU, and they also generate DMA trigger events which are routed to the DMA. Peripherals such as GPIO and ADC generate CPU interrupt events as well, but they also support generating and receiving events routed through a generic channel. For example, through the use of a generic event channel, it is possible to directly start an ADC conversion from a GPIO event by connecting a GPIO FPUB x and ADC FSUB 0 to the same generic event channel. www.ti.com Events Figure 6-5. Event Map ## **6.1.5 Event Propagation Latency** Generic route channels implement a four-way hardware handshake between the publishing entity and the subscribing entity. This handshake requires four ULPCLK cycles to complete: - 1. Request from publisher to subscriber - 2. Acknowledge from subscriber to publisher - 3. De-assert of request from publisher to subscriber - 4. Acknowledge of de-assert from subscriber to publisher If the publishing peripheral sends two requests and the first request has not cleared the handshake, the second request is dropped. ## **6.2 Events Operation** This section describes how to configure peripherals to use the event manager. Note that the event manager itself does not contain any configuration registers. All event configuration is done through the publishing and subscribing peripherals. Events www.ti.com ## 6.2.1 CPU Interrupt Peripheral interrupt requests (IRQs) are propagated to the CPU subsystem through the event manager. Peripheral interrupt requests use fixed routes, but in addition the CPU subsystem may provide two generic event subscriber ports which can be used to trigger CPU interrupts through a generic route. See the device-specific data sheet for the complete list of interrupt assignments for a given device. ## **Standard CPU Interrupt Requests** No special configuration is required for fixed route interrupts. Interrupts can be managed through the peripheral's CPU\_INT event management registers (IIDX, IMASK, RIS, MIS, ISET, and ICLR) and through the CPU subsystem interrupt configuration (see Section 3.3). ## **Generic Event Based CPU Interrupt Requests** The CPU subsystem contains two generic event subscriber ports (FSUB\_x) which can be used to source a CPU interrupt from any of the device's generic event channels. This can be used to enable special cases where a particular function on a peripheral generates a dedicated interrupt to the CPU subsystem which is independent from, and in addition to, that peripheral's standard interrupt mechanism. Consider the GPIO peripheral, which has a standard interrupt request as well as 2 publishers which can route a GPIO event to any of the generic event channels based on a defined state in the GPIO. For example, it can be desirable to have most GPIO events configured to source the standard interrupt, while a single specific GPIO event sources a second dedicated CPU interrupt through a generic route. This enables the application software to have two completely independent interrupt handlers for the GPIO. To configure the event manager to trigger a CPU interrupt from a generic route, follow the steps below: - 1. Configure the GEN\_EVENT registers of the peripheral generating the event to select the desired peripheral state as an event generator. - 2. Configure the FPUB\_x register of the peripheral generating the event with the generic route channel ID which is to be used. This channel must not be in use by another peripheral. - 3. Configure the FSUB\_x register of the wake up controller (WUC), which captures generic route channel events to forward to the CPU subsystem. - 4. Configure the CPU subsystem interrupt management to enable the GENSUBx interrupt. Note that when generating a CPU interrupt through a generic route, the generic event logic will automatically clear the pending interrupt request as a part of the four-way event handshake. Application software will not be able to read the cause of the interrupt from the peripheral registers, and it does not need to clear any interrupt status bits. Software can only read that the FSUB\_x generic event generated an interrupt. This reduces the interrupt overhead. ## 6.2.2 DMA Trigger DMA triggers are propagated to the DMA through the event manager. Most DMA triggers use fixed routes, but the DMA does provide two generic event subscriber ports which can be used to trigger DMA transfers through a generic route channel. See the device-specific data sheet for the complete list of DMA trigger assignments for a given device. ## Standard DMA Triggers To determine if a particular peripheral on a device provides a fixed DMA trigger (DMA\_TRIGx) from the peripheral directly to the DMA, review the DMA triggers table in the detailed description section of the device-specific data sheet. Certain peripherals can have more than one DMA trigger (for example, to enable a TX trigger and an RX trigger on a serial communication peripheral). To select the specific peripheral event which triggers a static DMA route, configure the peripheral's DMA\_TRIGX event management register set (IIDX, IMASK, RIS, MIS, ISET, and ICLR) which corresponds to the targeted DMA route. To determine which DMA\_TRIGX register set corresponds with which DMA trigger, review the relevant chapter of this guide for the corresponding peripheral, or review Section 6.1.4. www.ti.com Events Certain peripherals (such as the 12-bit DAC) do not implement a DMA\_TRIGx register set for managing DMA triggers. In these cases, the DMA trigger configuration is done through peripheral-specific configuration registers. ## **Generic Event Based DMA Triggers** The DMA contains two generic event subscriber ports (FSUB\_x) which can be used to source a DMA trigger from any of the device's generic event channels. This can be used to enable special cases where a particular function on a peripheral generates a DMA trigger. For example, it can be desirable to trigger a DMA transfer from a timer. To configure the event manager to trigger a DMA channel from a generic route, follow the steps below: - 1. Configure the GEN\_EVENTx registers of the peripheral generating the event to select the desired peripheral state as an event generator. - 2. Configure the FPUB\_x register of the peripheral generating the event with the generic event channel ID which is to be used. This channel must not be in use by another peripheral. - 3. Configure the FSUB\_x register of the DMA, which captures generic event channel events to be used as triggers in the DMA. - 4. Configure the DMA according to the configuration instructions in the DMA chapter. ## 6.2.3 Peripheral to Peripheral Event Peripheral to peripheral events enable a condition in one peripheral to trigger an action in a second (or third) peripheral, completely in hardware without any CPU interaction. The device provides a certain number of generic route channels which can be either published to or subscribed to by peripherals which include publisher and subscriber ports. Before establishing a configuration, follow these steps: - 1. Review the device specific data sheet to determine the generic route channel count and channel type available on the target device. Select an appropriate channel type (point to point or splitter) based on the desired functionality, and determine the channel number to use for the connection (the channel must not already be used by other peripherals). - 2. Review the publisher and subscriber capabilities of the peripherals which are to be connected. Some peripherals have more than one publisher and/or more than one subscriber port, and some peripherals have no publisher or subscriber ports. To understand the available ports for a peripheral, review the peripheral's reference chapter in this guide, or check the generic event channel connections in Section 6.1.4. Once the channel to be used is determined, and both the publisher and subscriber ports for the peripherals being connected are known, use the steps below to establish the event connection. In this example, a timer triggered ADC application will be configured, using TIMG0 to publish an event to generic channel 1, with ADC0 subscribing to generic channel 1 as a start-of-conversion trigger. - 1. Configure the GEN\_EVENTx event management registers of TIMG0 to set the event request based on the appropriate timer event (for example, a zero event). - 2. Store 0x1 into the FPUB\_0 register of TIMG0 to publish the TIMG0 event selected by the GEN\_EVENTx registers to generic route channel 1. Channel 1 must not be in use by another peripheral. - 3. Store 0x1 the FSUB\_0 register of ADC0 so that ADC0 is listening for events published by the timer to channel 1. - 4. Configure ADC0 to trigger from the subscriber port according to the configuration instructions in Section 9.2.8. - 5. Configure and enable TIMG0. #### 6.2.4 Extended Module Description Register The DESC\_EX register is a read-only register in the event manager which can be read by application software to determine how many point to point (single) generic route channels and splitter (dual) generic route channels are available on a given device. ## 6.2.5 Using Event Registers The event management register group is a set of standard registers which are implemented by all peripherals capable of generating events (CPU interrupts, DMA triggers, or generic events). Each event generator in a peripheral contains its own event management register set. For example, if a peripheral supports generating a Events www.ti.com CPU interrupt and a DMA trigger, it will have an event management register set for the CPU interrupt (with the group name of CPU\_INT) as well as a second event management register set for the DMA trigger (with the group name of DMA\_TRIG). The event management registers are used to: - Configure which peripheral conditions are used to generate the event (masking) - · Communicate raw and masked peripheral event status - · Set or clear peripheral event status by software In the "Registers" section for a given peripheral, the "Group" column displays the Group Name to indicate what functionality is mapped to each event management register group. See Table 6-1 for which event management groups are mapped to specific functions in the group name for a peripheral's "Registers" section. Table 6-1. Event Management Group Functionality and Mapping | Group Name (in Registers) | Functionality | | | | | |---------------------------|---------------------------------------------------------------------------|--|--|--|--| | CPU_INT | CPU interrupt (fixed route to the CPU subsystem) | | | | | | DMA_TRIGx | DMA trigger (fixed route to the DMA controller) | | | | | | GEN_EVENT | Generic event (programmable route for other module-to-module connections) | | | | | ## 6.2.5.1 Event Registers The event management register set contains 6 standard registers: RIS, IMASK, MIS, ISET, ICLR, and IIDX, given in Table 6-2. The event registers are interconnected as shown in Figure 6-6. Figure 6-6. Event Management Register Relationship The peripheral generating the event will contain one or more interrupt source signals which connect to the raw interrupt status (RIS) register. Software can poll RIS at any time to check the raw interrupt status. Software can also clear pending interrupts in the RIS register by writing to the corresponding bit position in the ICLR register. The RIS and IMASK registers are combined through a bit-wise AND function in the MIS register (masked interrupt status). To unmask an interrupt, set the corresponding bit in the IMASK register. Once unmasked, a pending interrupt will be indicated in both the RIS and MIS registers, and an event will be generated. The IIDX register will also be updated with the index of the highest priority pending interrupt. In the case of a CPU interrupt (CPU\_INT) with a CPU interrupt event route, a read of the IIDX register will clear the highest priority pending interrupt in the RIS and MIS registers and return the index of the highest priority pending interrupt to application software. In the case of a hardware event DMA trigger route (DMA\_TRIGx) or generic event route (GEN\_EVENTx), the hardware four-way handshake will send an ACK signal to the ICLR mechanism which will clear the pending interrupt in the RIS and MIS registers. Table 6-2. Standardized Event Management Registers (Used for CPU\_INT, DMA\_TRIGx, GEN\_EVENTx Configuration) | Register | Description | R/W | Functionality | | |----------|----------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | RIS | Raw interrupt status | | Indicates the current pending interrupt status, with one bit provided per interrupt condition. Writing to ICLR will clear the corresponding bit in the RIS register if the interrupt condition is no longer present. | | www.ti.com Events Table 6-2. Standardized Event Management Registers (Used for CPU\_INT, DMA\_TRIGx, GEN\_EVENTx Configuration) (continued) | Register | Description | R/W | Functionality | |----------|----------------------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | IMASK | Interrupt mask | RW | Used by application software to configure which interrupt conditions propagate into an event, with one bit provided per interrupt condition. | | MIS | Masked interrupt status | R | Indicates the current pending masked interrupt status to software and hardware, with one bit provided per interrupt condition. MIS is the bit-wise AND of the RIS and IMASK registers. Writing to ICLR will clear the corresponding bit in the RIS register if the interrupt condition is no longer present. If RIS is cleared, the corresponding bit in the MIS register is also automatically cleared. | | ISET | Software interrupt set control | W | Used by application software to force an interrupt condition for diagnostics. Writing to ISET will set the corresponding bit in the RIS register. If the interrupt condition is enabled in IMASK, the corresponding bit in the MIS register is also set. Writing a '1' to a bit location in ISET sets the respective interrupt status. | | ICLR | Software interrupt clear control | W | Used by application software to clear a pending interrupt status in RIS. Writing a '1' to a bit location in ICLR clears the respective interrupt status. If an interrupt is enabled in IMASK, the corresponding bit location in MIS is also cleared automatically when RIS clears. If the interrupt condition is still present, clearing the status has no effect and the RIS will remain set. | | IIDX | Pending interrupt index | R | Used by application software to read the highest priority pending interrupt while simultaneously clearing the highest priority interrupt status in RIS and MIS. A read of IIDX returns 0 if no unmasked interrupts are pending (MIS==0), else it returns an index value indicating the highest priority pending interrupt. | ## 6.2.5.2 Configuring Events To configure which peripheral interrupt source is to be used to trigger an event, set the bit which corresponds to the desired interrupt source in the IMASK register which corresponds to the desired event. Setting a bit in IMASK will cause the raw interrupt status in the RIS register to propagate to the MIS register. When an interrupt status bit in the MIS register is set (due to the interrupt being unmasked in the IMASK register and a raw interrupt being pending in the RIS register), an event is generated. Multiple interrupt sources can be enabled for CPU interrupt events, as application software can determine the cause of the interrupt by reading the IIDX or MIS register. For hardware events such as DMA triggers and generic event publishers, only one interrupt source should be unmasked in IMASK. ## 6.2.5.3 Responding to CPU Interrupts in Application Software In the case of an event which generates a CPU interrupt, application software can determine which peripheral interrupt triggered the generation of the event by either reading the IIDX register or by reading the MIS and writing the ICLR registers. ## CPU IRQ Interrupt Service Routine using CPU\_INT IIDX Register Application software can read the IIDX register in CPU\_INT group to determine and clear the highest priority pending interrupt. A read to IIDX will return an index corresponding to the highest priority interrupt which was both set and unmasked. The read action will also simultaneously clear the RIS and MIS bits corresponding to the highest priority interrupt whose index was returned by the read. The read value from the IIDX register can then be used in a case statement, as shown below. Events www.ti.com # CPU IRQ Interrupt Service Routine using CPU\_INT MIS and ICLR Registers Alternatively, application software can read the MIS register to determine which bits are set, followed by using the ICLR register to clear the pending interrupt status bits. ## 6.2.5.4 Hardware Event Handling In the case of an event which sources a DMA trigger (DMA\_TRIG) or a generic event (GEN\_EVENT), the IIDX register is not used. A four-way event handshake is performed between the peripheral generating the event and the hardware entity which is subscribed to the event (for example, the DMA or a secondary peripheral). The four-way event handshake will clear the corresponding interrupt status bits in the RIS and MIS registers automatically. # Chapter 7 IOMUX The IOMUX controls the configuration of all device pins with digital input-output (IO) functions, including: digital function selection, inversion control, drive strength (if applicable), the pullup or pulldown resistor (if applicable), and wake-up configuration (if applicable on certain IOs for wakeup from SHUTDOWN mode). | 7.1 IOMUX Overview | 370 | |------------------------------------|-----| | | | | 7.2 IOMUX Operation | | | 7.3 IOMUX (PINCMx) Register Format | 377 | | 7.4 IOMUX Registers | | | 7.4 IOMOA Negisters | | IOMUX www.ti.com #### 7.1 IOMUX Overview The IOMUX manages the configuration of the digital IO. Key functions configured by IOMUX include: - Selection of which peripheral is multiplexed to each digital IO pin (for example, a GPIO or UART peripheral) - Digital input path configuration - Hysteresis control - Input path enable/disable - Input logic inversion control - Digital output path configuration - Drive strength control - Output connection enable/disable - Output logic inversion (control shared with input logic inversion) - Logic-high to High-Z output conversion (for open-drain style interfaces) - Retention of "last state" when a peripheral connected to an IO is disabled - Wakeup configuration (for wakeup from SHUTDOWN mode) - Read wake up source from the wake stat bit from the PINCM Register - Wake up compare level - Release SHDNIOREL - Wakeup enable/disable - · Pullup and pulldown resistor control ## 7.1.1 IO Types and Analog Sharing The IOMUX manages the selection of which peripheral function is to be used on a digital IO. It also provides the controls for the output driver, input path, and the wakeup logic for wakeup from SHUTDOWN mode. # **Digital IO Types** There are several digital IO types which can be included on a given device. Each digital IO type supports different features. Table 7-1 lists the features which are included with each IO type. See the device-specific data sheet for which IO type is used on a given package pin. Table 7-1. Digital IO Features by IO Type | IO Structure | Inversion<br>Control | Drive<br>Strength<br>Control | Hysteresis<br>Control | Pullup<br>Resistor | Pulldown<br>Resistor | Wakeup<br>Logic | | |--------------------------|----------------------|------------------------------|-----------------------|--------------------|----------------------|-----------------|--| | Standard-drive | Y | | | Y | Y | | | | Standard-drive with wake | Y | | | Y | Y | Y | | | High-drive | Y | Y | | Y | Y | Υ | | | High-speed | Y | Y | | Y | Y | | | | 5V tolerant open drain | Y | | Y | | Y | Υ | | Please note that the IOMUX will not support the inversion control and pesudo-open drain (output-high translated to high-impedance) setting on the SPI POCI pins. Also the IOMUX will not support inversion control on the SPI SCLK pins connected on an HSIO pin. ## **Digital IO Shared with Analog Functions** Certain pins on a device will be digital only and will not have any analog functions connected to the pin. Other pins can have one or more analog functions connected to the pin in addition to the digital IO functions. Analog functions are never selected within the IOMUX; they are always configured within of the respective analog peripheral. Analog peripherals have no knowledge of, or interaction with, the IOMUX. In general, when analog functionality is used on a pin which also has digital functions, the IOMUX configuration for that pin should be left in its default (high-Z) state so as to not interfere with the proper operation of the analog function. However, it is possible to have the IOMUX active on a pin when an analog peripheral is also interacting www.ti.com IOMUX with the pin, provided that the application software ensures that there is not a conflict between the functions. For example, it is possible to have the pullup or pulldown resistor on an IO enabled at the same time that the ADC is running a conversion on the same IO. However, an invalid configuration would be enabling the output driver on an IO at the same time that an analog peripheral is driving the IO (for example, a DAC or OPA output). This would create an IO conflict. Application software is responsible for ensuring that the IOMUX settings do not conflict with any analog peripheral functions which can be enabled on a shared pad. ## **IO Slice** The mixed-signal IO pin slice diagram for a full featured IO pin is shown in Figure 7-1. Not all pins will have analog functions, wake-up logic, drive strength control, and pullup or pulldown resistors available. See the device-specific data sheet for detailed information on what features are supported for a specific pin. IOMUX www.ti.com Figure 7-1. Superset IO Slice # **Default IOMUX State** The initial state of the IOMUX pin slice for all digital IO after a BOOTRST is as follows: - The digital IO is in a high-impedance state - The peripheral function selection field (PF) is cleared (no peripheral function selected) and the peripheral connect (PC) and input enable states are cleared (disabled) - · The inversion logic is disabled - The Hi-Z output high mode is disabled - The pullup/pulldown resistors (if present) are disabled - · The input hysteresis control (if present) is disabled to save power - The drive strength control (if present) is reset www.ti.com IOMUX · The wakeup logic (if present) is disabled #### Note The SWD pins are a specific exception to the above default state. The SWD debug pins are configured in SWD mode by default, and may be switched to an alternate setting after start-up. See Section 2.4.1.4 in the SYSCTL section of the PMCU chapter. ## 7.2 IOMUX Operation Each digital IO on a device has a dedicated 32-bit PINCM register in the IOMUX peripheral register space which is used to configure the digital functions of the respective IO. See the device specific data sheet for determining the PINCM register index which corresponds to the IO to be configured. ## 7.2.1 Peripheral Function (PF) Assignment When setting up the initial IOMUX configuration for an IO after a BOOTRST, application software can select which digital peripheral from the supported options is to be connect to an IO by writing the appropriate peripheral select value to the PF field while simultaneously setting the PC and INENA bits in the PINCMx register corresponding to the targeted pin. The IOMUX configurations for a given peripheral must be set before the peripheral connected to the IOs has been initialized for operation. To change the peripheral function selection for a digital IO at runtime after a peripheral function has already been configured for that IO, the following procedure should be followed: - 1. Disable the currently connected peripheral function - 2. Clear the PC bit (output connect bit) and INENA (input connect bit) in the corresponding PINCMx register - 3. Write 0x0 to the PF field in the PINCMx to clear the logic in the data path - 4. Select the new peripheral function by writing the peripheral function ID to the PF register - 5. Set the PC and INENA bits in the PINCMx register to connect the newly selected peripheral - 6. Enable the newly selected peripheral for operation At runtime, the INENA bit can be used to mask the input from the IO to the peripheral, if desired. When INENA is cleared, a connected peripheral function will see logic low (0) from the IO, regardless of the external state of the IO. If an IO supports wakeup from SHUTDOWN mode, the INENA bit also controls propagation of the IO state to the SHUTDOWN mode wakeup logic. If a peripheral is assigned to an IO, but the peripheral is itself in a disabled state, the last valid output conditions (output logic level and Hi-Z state) are latched in the IOMUX output logic. When the peripheral is enabled, the IOMUX will release the latched state to allow the (now enabled) peripheral's output state to propagate to the IO. The PMCU indicates to the IOMUX when a peripheral is entering a disabled state via the IORET signal, which is combined with the PC signal via a logic OR to control the output state latches. This mechanism handles preservation of the last valid output state of peripherals in power domain 1 (PD1) when entering STOP or STANDBY mode, as PD1 peripherals are always temporarily disabled upon entry to STOP/STANDBY, and re-enabled upon exit from STOP/STANDBY modes. When no peripheral function is selected (PF==0) the output latches are put into a reset state, causing the output NMOS and PMOS to be disabled (leaving the IO pin in a Hi-Z state with the exception of any enabled pullup/pulldown resistors). Note that the pullup/pulldown resistors are never controlled by either a connected peripheral or the peripheral muxing logic. They are only controlled by the IOMUX control bits (see pullup/pulldown). ## 7.2.2 Logic High to Hi-Z Conversion The IOMUX supports translating an output high signal from a connected peripheral into a Hi-Z output state at the IO pin. This functionality is particularly useful for open-drain digital input/output applications. When this functionality is enabled, the IO pin state as a function of the peripheral output is as shown in Table 7-2. Table 7-2. Logic High to Hi-Z Truth Table | Connected Peripheral Output | IO Pin State (Z1 = 0x0) | IO Pin State (Z1 = 0x1) | |-----------------------------|-------------------------|-------------------------| | Logic low (0) | Output low | Output low | IOMUX www.ti.com ## Table 7-2. Logic High to Hi-Z Truth Table (continued) | Connected Peripheral Output | IO Pin State (Z1 = 0x0) | IO Pin State (Z1 = 0x1) | |-----------------------------|-------------------------|-------------------------| | Logic high (1) | Output high | High impedance (Hi-Z) | To enable logic high to Hi-Z conversion on a digital IO, set the Z1 bit in the corresponding PINCMx register. Note that for 5-V tolerant open-drain IO pins, the Z1 control has no effect as there is no high-side driver present. On these pins, a logic high output from the peripheral to the IO pin always results in a Hi-Z state. # 7.2.3 Logic Inversion The IOMUX supports logic inversion of the digital input/output path. Logic inversion is useful for scenarios where opposite polarity is required for UART functions or SPI chip select functions. To enable logic inversion on a digital IO, set the INV bit in the corresponding PINCMx register. To disable logic inversion, clear the corresponding bit. Logic inversion is disabled by default. When logic inversion is enabled for a 5V tolerant open drain IO, a connected peripheral which outputs a logic low state will cause the IO pin to go to a Hi-Z state. When the peripheral applies a logic high state, the IO pin will go to an output low state. ## 7.2.4 SHUTDOWN Mode Wakeup Logic In SHUTDOWN mode, the entire regulated core supply of the device is disabled and the device wakes only from a wake-capable IO that is configured for wakeup, from NRST, or from a debug connection. The IO wake mechanism for exiting SHUTDOWN is managed by IOMUX and is level based. The 5-V tolerant open-drain IOs, high-drive IOs, and certain standard-drive IOs include the additional wakeup logic that can be used to wake the device from a SHUTDOWN operating mode upon a level match. To configure a wake-capable IO for wakeup from SHUTDOWN mode: - Set the INENA bit to let the input state propagate from the IO to the wakeup logic. - 2. Select the compare level to use for wake by setting or clearing the WCOMP bit in the PINCMx register corresponding to the targeted pin. - 3. Enable wakeup by setting the WUEN bit in the PINCMx register corresponding to the targeted pin. After the previous configuration, SHUTDOWN mode can be entered through the appropriate command in SYSCTL. Pins on the device that contain digital IO controlled by IOMUX retain their current state when the device enters into SHUTDOWN. While the digital IO state is latched upon entry into SHUTDOWN mode, the IOMUX configuration registers (all PINCMx registers) lose their contents as the regulated core supply is shut down. After SHUTDOWN is entered, a level match on any pin configured for wakeup triggers the exit sequence from SHUTDOWN. When the device exits SHUTDOWN, a BOR-level reset occurs but the state of the digital IO remains latched through the reset, keeping the IO state that was present upon entry into SHUTDOWN. This state is held until the IO are released in SYSCTL. After the BOR, SYSCTL captures the cause of the reset as a SHUTDOWN exit so that software can identify this and take appropriate action to reconfigure the device. If multiple pins were configured for wakeup from SHUTDOWN, application software can determine which wakeup-configured IO generated the wake by polling the WAKESTATE bit in any IOs that were enabled for wake before the SHUTDOWN exit. Application software must apply the following process to restore the IO state upon exit from SHUTDOWN: - 1. Check which IO triggered the wakeup from SHUTDOWN, if necessary, as follows: - a. Reconfigure the PINCMx register corresponding to the IO to be tested for wakeup status and set the peripheral connect (PC) bit (the PC bit gates the WAKESTATE indication). - b. Test the WAKESTATE bit in the PINCMx register corresponding to the IO to be tested to determine if that particular IO received a WAKE status based on the previously configured WCOMP and WUEN configuration. - 2. Reconfigure any remaining IOMUX PINCM registers to the correct states. www.ti.com IOMUX - 3. Reconfigure the peripherals that are connected to pins through IOMUX, and enable them. - Release the SHUTDOWN IO lock in SYSCTL. - 5. Clear the WUEN bit in the PINCMx register to reset the WAKESTATE status. #### Note After waking from SHUTDOWN, if the WUEN bit not cleared and the shutdown release bit in SYSCTL is not set, then reentering SHUTDOWN results in an immediate wake event, because the WAKESTATE status was not cleared from the previous wake event. #### 7.2.5 Pullup/Pulldown Resistors Programmable pullup/pulldown resistors are provided on most digital IO types, and are connected to VDD/VSS, respectively. The 5V tolerant open drain digital IO does not provide a pullup resistor due to the open drain configuration. To enable the pullup or pulldown resistor on a digital IO, set the PIPU or PIPD bit, respectively, in the corresponding PINCMx register. To disable the pullup or pulldown resistor, clear the corresponding bit. The pullup/pulldown resistors can be enabled at any time, and their configuration is independent from the peripheral function configuration. It is possible to enable a pullup/pulldown resistor while changing the selected peripheral function. ## 7.2.6 Drive Strength Control The high-drive and high-speed digital IO types have programmable drive strength (low drive and high drive). The default drive strength is low drive. Application software can request high drive by setting the DRV bit in the PINCMx register corresponding to the target digital IO. Drive strength control is not available for standard drive and open drain IO types. The drive strength control is completely independent of the selected peripheral function (PF) and can be changed by application software at any time. For detailed electrical specifications on the drive performance in each drive mode for a given IO, see the Digital IO parameters in the device-specific data sheet. ## 7.2.7 Hysteresis and Logic Level Control The 5V-tolerant open drain digital IOs provide a hysteresis and logic level control to enable operation in input mode with standard CMOS logic (hysteresis enabled, CMOS logic levels) and TTL logic (hysteresis disabled, TTL logic levels). The default mode for the 5V-tolerant open drain digital IO is TLL mode (HYSTEN bit in the PINCMx register is cleared). To use a 5V-tolerant open drain digital IO in CMOS mode with hysteresis enabled, set the HYSTEN bit in the PINCMx register which corresponds to the targeted IO. The input logic level differences between TTL mode (left) and CMOS mode (right) are shown in Figure 7-2. IOMUX www.ti.com Figure 7-2. Input Logic Levels - 5V Tolerant Open Drain Digital IO www.ti.com /OMUX # 7.3 IOMUX (PINCMx) Register Format IOMUX www.ti.com # 7.3.1 PINCM (Offset = 4h) [Reset = X] Pin Control Management Register Figure 7-3. PINCM | | | | 1.94.67 | • • • • • • • • • • • • • • • • • • • • | | | | |--------|----------|----------|---------|-----------------------------------------|----------|--------|----------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | RESERVED | | WCOMP | WUEN | INV | HIZ1 | RESERVED | | | R/W-0h | | R/W-0h | R/W-0h | R/W-0h | R/W-0h | R/W-0h | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | RESERVED | | DRV | HYSTEN | INENA | PIPU | PIPD | | | R/W-0h | | R/W-0h | R/W-0h | R/W-0h | R/W-0h | R/W-0h | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | RESE | RVED | WAKESTAT | | | RESERVED | | | | R/W | /-0h | R-0h | | | R/W-0h | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | PC | RESERVED | | | F | PF | | | | R/W-0h | R/W-0h | | | R/V | V-0h | | | **Table 7-3. PINCM Field Descriptions** | Table 7-3. PINCM Field Descriptions | | | | | | | |-------------------------------------|----------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------|--|--| | Bit | Field | Туре | Reset | Description | | | | 31-29 | RESERVED | R/W | 0h | | | | | 28 | WCOMP | R/W | Oh | Wakeup Compare Value bit 0h = Wakeup on a match of 0 1h = Wakeup on a match of 1 | | | | 27 | WUEN | R/W | Oh | Wakeup Enable bit 0h = wakeup is disabled. 1h = wakeup is enabled | | | | 26 | INV | R/W | Oh | Data inversion selection 0h = Data inversion is disabled. 1h = Data inversion is enabled | | | | 25 | HIZ1 | R/W | Oh | High output value will tri-state the output when this bit is enabled 0h = open-drain is disabled. 1h = open-drain is enabled. | | | | 24-21 | RESERVED | R/W | 0h | | | | | 20 | DRV | R/W | Oh | Drive strength control selection, for HS IOCELL only 0h = Drive setting of 0 selected 1h = Drive setting of 1 selected | | | | 19 | HYSTEN | R/W | Oh | Hysteresis Enable Control Selection 0h = hysteresis is disabled. 1h = hysteresis is enabled | | | | 18 | INENA | R/W | Oh | Input Enable Control Selection Oh = Input enable is disabled. 1h = Input enable is enabled. | | | | 17 | PIPU | R/W | Oh | Pull Up control selection 0h = Pull up is disabled. 1h = Pull up is enabled | | | | 16 | PIPD | R/W | Oh | Pull Down control selection 0h = Pull down is disabled. 1h = Pull down is enabled | | | | 15-14 | RESERVED | R/W | 0h | | | | | 13 | WAKESTAT | R | 0h | This has the IOPAD WAKEUP signal as status bit. 0h = wakeup source is NOT from this IOCELL 1h = wakeup source is from this IOCELL | | | | 12-8 | RESERVED | R/W | 0h | | | | www.ti.com IOMUX # **Table 7-3. PINCM Field Descriptions (continued)** | Bit | Field | Туре | Reset | Description | | | |-----|----------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | 7 | PC | R/W | 0h | Peripheral is "Connected" 0h = The output of the peripheral (and its output enable) will not propagate to the IOCELL 1h = The output latch of the dataflow will be "transparent" | | | | 6 | RESERVED | R/W | 0h | | | | | 5-0 | PF | R/W | 0h | P channel Function selection bits 0h = Reserved as unconnected 3Fh = An encoding per function that can be connected to this pin. | | | IOMUX www.ti.com # 7.4 IOMUX Registers Table 7-4 lists the memory-mapped registers for the IOMUX registers. All register offset addresses not listed in Table 7-4 should be considered as reserved locations and the register contents should not be modified. # **Table 7-4. IOMUX Registers** | Offset | Acronym | Register Name | Group | Section | |--------|---------|--------------------------------------------------|-------|---------| | 4h | PINCM | Pin Control Management Register in SECCFG region | | Go | Complex bit access types are encoded to fit into small table cells. Table 7-5 shows the codes that are used for access types in this section. Table 7-5. IOMUX Access Type Codes | Access Type Code | | Description | | | | | | |------------------------|---|----------------------------------------|--|--|--|--|--| | Read Type | | | | | | | | | R | R | Read | | | | | | | Write Type | | | | | | | | | W | W | Write | | | | | | | Reset or Default Value | | | | | | | | | -n | | Value after reset or the default value | | | | | | www.ti.com IOMUX # 7.4.1 PINCM (Offset = 4h) [Reset = X] PINCM is shown in Figure 7-4 and described in Table 7-6. Return to the Summary Table. Pin Control Management Register # Figure 7-4. PINCM | | | | J | | | | | |--------|----------|----------|--------|--------|----------|--------|----------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | RESERVED | | WCOMP | WUEN | INV | HIZ1 | RESERVED | | | R/W-0h | | R/W-0h | R/W-0h | R/W-0h | R/W-0h | R/W-0h | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | RESERVED | DRV | HYSTEN | INENA | PIPU | PIPD | | | | R/W-0h | R/W-0h | R/W-0h | R/W-0h | R/W-0h | R/W-0h | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | RESE | RVED | WAKESTAT | | | RESERVED | | | | R/M | V-0h | R-0h | | | R/W-0h | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | PC | RESERVED | | | Р | F | | | | R/W-0h | R/W-0h | | | R/V | V-0h | | | # **Table 7-6. PINCM Field Descriptions** | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|-------------------------------------------------------------------------------------------------------------------------------| | 31-29 | RESERVED | R/W | 0h | | | 28 | WCOMP | R/W | Oh | Wakeup Compare Value bit 0h = Wakeup on a match of 0 1h = Wakeup on a match of 1 | | 27 | WUEN | R/W | 0h | Wakeup Enable bit 0h = wakeup is disabled. 1h = wakeup is enabled | | 26 | INV | R/W | 0h | Data inversion selection 0h = Data inversion is disabled. 1h = Data inversion is enabled | | 25 | HIZ1 | R/W | 0h | High output value will tri-state the output when this bit is enabled 0h = open-drain is disabled. 1h = open-drain is enabled. | | 24 | RESERVED | R/W | 0h | | | 21 | RESERVED | R/W | 0h | | | 20 | DRV | R/W | 0h | Drive strength control selection, for HS IOCELL only 0h = Drive setting of 0 selected 1h = Drive setting of 1 selected | | 19 | HYSTEN | R/W | Oh | Hysteresis Enable Control Selection Oh = hysteresis is disabled. 1h = hysteresis is enabled | | 18 | INENA | R/W | Oh | Input Enable Control Selection Oh = Input enable is disabled. 1h = Input enable is enabled. | | 17 | PIPU | R/W | Oh | Pull Up control selection 0h = Pull up is disabled. 1h = Pull up is enabled | | 16 | PIPD | R/W | Oh | Pull Down control selection 0h = Pull down is disabled. 1h = Pull down is enabled | | 15-14 | RESERVED | R/W | 0h | | IOMUX www.ti.com # **Table 7-6. PINCM Field Descriptions (continued)** | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 13 | WAKESTAT | R | Oh | This has the IOPAD WAKEUP signal as status bit. 0h = wakeup source is NOT from this IOCELL 1h = wakeup source is from this IOCELL | | 12-8 | RESERVED | R/W | 0h | | | 7 | PC | R/W | 0h | Peripheral is "Connected" 0h = The output of the peripheral (and its output enable) will not propagate to the IOCELL 1h = The output latch of the dataflow will be "transparent" | | 6 | RESERVED | R/W | 0h | | | 5-0 | PF | R/W | Oh | Peripheral Function selection bits 0h = Reserved as unconnected 3Fh = An encoding per function that can be connected to this pin. | # Chapter 8 **GPIO** The GPIO peripheral provides the user with a means to write data out and read data in to and from the device pins. It also provides a way to detect wakeup events while the device is in a low power state. This chapter describes the operation of the GPIO peripheral. | 8.1 GPIO Overview | 384 | |--------------------|-----| | 8.2 GPIO Operation | | | 8.3 GPIO Registers | | | | | GPIO www.ti.com #### 8.1 GPIO Overview The GPIO is used to read in digital data from the device pins and to send digital data out to the device pins. The GPIO module features include: - 0 wait state MMR access from CPU - Set/Clear/Toggle multiple bits without the need of a read-modify-write construct in software - Direct writes to individual GPIO output bits (DOUT) without the need of a read-modify-write construct in software - · Direct read comparisons of individual GPIO input bits (DIN) without the need to use masking in software - DOUT serviceable by DMA to generate a predefined output sequence on specified pins - "FastWake" feature enables low-power wakeup from STOP and STANDBY modes for any GPIO port - · User controlled input filtering Figure 8-1 shows the block diagram of the GPIO peripheral. Figure 8-1. GPIO Block Diagram #### **Note** The GPIO module for the MSPM0 platform does not manage the complete digital IO functionality (for example, pullup, pulldown, or other functional muxing). For complete digital IO control details, refer to Chapter 7. Similar to any other peripheral, the GPIO has inputs and outputs (with output enable) that allow the GPIO to interface with the IOMUX to make connections to the IO pins. # 8.2 GPIO Operation The GPIO peripheral is configured with user software. The setup and operation of the GPIO is discussed in the following sections. ## 8.2.1 GPIO Ports An instance of the GPIO peripheral in the MSPM0 platform supports up to 32 data input/output (DIO) bits. For devices with greater than 32 GPIOs, multiple instances of the GPIO peripheral are used to address all of the www.ti.com GPIO device pins. The GPIO port and bit names are directly mapped to the signal names associated with each device pin in the *Pin Configuration and Functions* section of the device data sheet. Table 8-1. GPIO Port and Device Pin Mapping | GPIO Port and Bit Name | Device Pin Signal Name | |--------------------------|------------------------| | GPIO Port A Bit 0 (DIO0) | PA0 | | GPIO Port A Bit 1 (DIO1) | PA1 | | GPIO Port B Bit 0 (DIO0) | PB0 | | GPIO Port B Bit 1 (DIO1) | PB1 | | GPIO Port x Bit y (DIOy) | Pxy | # 8.2.2 GPIO Read/Write Interface The GPIO peripheral has features and dedicated registers to allow for advanced bit manipulations without the need to execute a read-modify-write construct in software. These features are outlined below. #### **Read Interface** The DIN31\_0 register is the data input register for a given GPIO port. Reading a bit in the DIN31\_0 register corresponds to reading the signal voltage level on the associated device pin signal. The GPIO peripheral provides single-bit byte-read addresses for all bits of DIN. These registers are named DIN31\_28, DIN27\_24, ..., DIN3\_0 and are essentially alias registers for all of the bits in the DIN31\_0 data input register. Reading from the DIN31\_28 register grants you byte level access to DIN31:28 which allows you to perform direct read comparisons without masking. #### **Write Interface** In many cases it is useful to write specific values for device pin signals based on the user's system. Register DOUT31\_0 is the physical data output register for a given GPIO port. Setting a bit in the DOUT31\_0 register sets the corresponding device pin signal when the output is enabled through the DOE31\_0 register. Conversely, clearing a bit in the DOUT31\_0 register clears the corresponding device pin signal. The GPIO peripheral also provides single-bit byte-write addresses for all bits of DOUT. These registers are named DOUT31\_28, DOUT27\_24, ..., DOUT3\_0 and are essentially alias registers for all of the bits in the DOUT31\_0 data output register. Writing to the DOUT31\_28 register grants you byte level access to DOUT31:28 which allows you to directly write to these individual bits without the need to use a read-modify-write construct. ## Set/Clear/Toggle Similar to the use-cases described above, it is also useful in an application to set, clear, or toggle a device pin or a collection of pins. The MSPM0 platform lets you execute these functions in one write cycle using the DOUTSET31\_0, DOUTCLR31\_0, and DOUTTGL31\_0 registers. Setting a bit in these registers implements the corresponding function while writing a '0' has no effect. This feature allows you to directly set, clear, and toggle any bit in the DOUT31\_0 register using a single command per GPIO port. In the same way one can set and clear the data output bits, there are registers to do the same functionality with the data output enable register, DOE31\_0. Writing a '1' to bits in the DOESET31\_0 and DOECLR31\_0 register implements the corresponding function while writing a '0' has no effect. This feature allows you to directly set or clear any bit in the DOE31\_0 register using a single command per GPIO port. ## 8.2.3 GPIO Input Glitch Filtering and Synchronization The GPIO module evaluates the state of input pins at the ULPCLK (PD0 bus clock) rate, synchronizing the pin state to ULPCLK through a 2-stage synchronizer before passing the GPIO state to the input glitch filter. GPIO www.ti.com Figure 8-2. GPIO Input Synchronizer A programmable input glitch filter is provided for suppressing noise on digital input pins. The glitch filter runs at ULPCLK rate. Four levels of user-specified input filtering are possible: - Sampled input without filtering (the minimum reliably detected pulse width is one ULPCLK cycle due to synchronization of the pin state with ULPCLK +Delay time from edge of asynchronous request to first 32MHz MCLK edge in case of fast wake enable for STANDBY0/1, STOP1/2 and SLEEP2 modes) - Synchronized inputs which are not greater than 1 ULPCLK periods are filtered out - Synchronized inputs which are not greater than 3 ULPCLK periods are filtered out - Synchronized inputs which are not greater than 8 ULPCLK periods are filtered out This feature allows users to easily implement input filtering in hardware for cases where fast switching on the input pin is needed to be filtered out. The bit fields in the FILTEREN31\_16 and FILTEREN15\_0 registers allow users to configure the level of filtering needed for the corresponding GPIO bit. Input pulses of the same pulse length can be passed in some cases while being filtered in other cases, due to 1 ULPCLK cycle of uncertainty in the synchronization. Figure 8-3. GPIO Input Synchronizer and Glitch Filtering Scenarios - In Scenario A, the input pulse is less than one ULPCLK cycle. Pulses less than one ULPCLK cycle may not be captured. To ensure that GPIO inputs are always captured, the GPIO input pulse width must be greater than the ULPCLK period. - In Scenario B, the input pulse is nearly two ULPCLK cycles in length, but because the rising edge occurs just after the ULPCLK edge, the GPIO synchronizer only views the input pin as having been high for 1 ULPCLK period. This scenario would not be filtered out by the glitch filter when the glitch filter is disabled, but a glitch filter value of >1 would result in this pulse being filtered. Conversely, the same input pulse width in Scenario C results in the input pin being considered high for two ULPCLK periods, as the rising edge occurred just before the ULPCLK edge. In this case, this scenario would not be filtered out when a glitch filter value of >1 is specified. - In Scenario D, three ULPCLK cycles are passed to the glitch filter. In this case, the scenario would not be filtered out when a glitch filter value of >1 is specified, but it would be filtered out for a glitch filter value of >3 or >8. www.ti.com GPIO #### **Note** When the fast wake mode is enabled (SYSOSC is requested asynchronously upon input pin activity), the ULPCLK will switch from off (as would be the case in STANDBY1) or 32kHz (as would be the case in STANDBY0) to 32MHz, resulting in the input synchronization logic and glitch filter running at 32MHz after some latency. See the device specific data sheet for the asynchronous fast clock request wake time, and budget this time into any minimum pulse width calculations when using fast wake. ## 8.2.4 GPIO Fast Wake The fast wake feature in the MSPM0 GPIO peripheral allows the GPIO module to stay in a low power state and detect interrupt events on the device pins without requiring a high-speed clock. This allows the device to support fast wakeup from low-power modes, such as STOP and STANDBY, on any GPIO pin. Fast wake can be enabled on a bit-wise basis using the FASTWAKE register. Setting a bit in the FASTWAKE register enables the corresponding device pin signal to support fast wakeup functionality. The CTL register contains a bit field named FASTWAKEONLY which allows for global control of the fast wake feature. Setting the FASTWAKEONLY bit enables all of the bits in the corresponding GPIO port to support fast wakeup functionality. #### Note Do not enable fast wake in the GPIO while simultaneously blocking asynchronous fast clock requests in SYSCTL. When fast wake is enabled, the GPIO expects to handshake with SYSCTL for the fast clock. If SYSCTL ignores the request, the GPIO will not receive a clock until SYSCTL completes the asynchronous fast clock request handshake. # 8.2.5 GPIO DMA Interface The GPIO peripheral allows the DMA write-access to the DOUT31\_0 register. This functionality allows users to generate predefined output sequences on specified device pins. Some applications require preloaded sequences of GPIO pin changes and the MSPM0 platform allows for the DMA to run that sequence so that the CPU can remain asleep and conserve energy. The DMAMASK register is used to indicate which GPIO bits the DMA is allowed to modify. Setting a bit in the DMAMASK register enables the corresponding DOUT bit to be modified by the DMA. #### **Note** The CPU can write to any DOUT31\_0 bit regardless of the DMAMASK value. In cases where the DMA and the CPU both attempt to access and modify the DOUT31\_0 register concurrently, it is the user's responsibility to manage the DMA and CPU bus transactions that are targeting the same bit to be modified. - If a DMAMASK bit is set, the DMA will be prioritized to modify the corresponding DOUT bit. - If a DMAMASK bit is cleared, the CPU will be prioritized to modify the corresponding DOUT bit. #### 8.2.6 Event Publishers and Subscribers There are three independent event publishers available for a GPIO peripheral: - 1. First Event Publisher (CPU INT) - Used for generating CPU interrupt - Interrupt (RIS) flags are cleared upon software reading the IIDX register or writing to the respective ICLR register bits. - An event to the CPU can be individually specified for each GPIO bit through the POLARITY register: - 0: Disabled - 1: Rise Event - 2: Fall Event - 3: Rise or Fall Event - Second Event Publisher (GEN\_EVENT0) GPIO www.ti.com - · Uses the same POLARITY register definition as CPU\_INT - Applies to GPIO bits 15 down to 0 (DIO15:0) - 3. Third Event Publisher (GEN\_EVENT1) - Uses the same POLARITY register definition as CPU\_INT - Applies to GPIO bits 31 down to 16 (DIO31:16) ## There are **two event subscribers** available for a GPIO peripheral: - 1. First Event Subscriber (FSUB\_0) - A specific pin can be directed to change state on an event - A subscriber event can only cause one single bit to have an action - Applies to GPIO bits 15 down to 0 (DIO15:0) - SUB0CFG register is used to enable the FSUB\_0 event and define the output policy for a specific GPIO pin - 2. Second Event Subscriber (FSUB\_1) - A specific pin can be directed to change state on an event - A subscriber event can only cause one single bit to have an action - Applies to GPIO bits 31 down to 16 (DIO31:16) - SUB1CFG register is used to enable the FSUB\_1 event and define the output policy for a specific GPIO pin www.ti.com GPIO # 8.3 GPIO Registers Table 8-2 lists the memory-mapped registers for the GPIO registers. All register offset addresses not listed in Table 8-2 should be considered as reserved locations and the register contents should not be modified. **Table 8-2. GPIO Registers** | Offset | Acronym | Register Name | Group | Section | |--------|-----------|--------------------------|----------------|---------| | 400h | FSUB_0 | Subsciber Port 0 | | Go | | 404h | FSUB_1 | Subscriber Port 1 | | Go | | 444h | FPUB_0 | Publisher Port 0 | | Go | | 448h | FPUB_1 | Publisher Port 1 | | Go | | 800h | PWREN | Power enable | Go | | | 804h | RSTCTL | Reset Control | | Go | | 814h | STAT | Status Register | | Go | | 1010h | CLKOVR | Clock Override | | Go | | 1018h | PDBGCTL | Peripheral Debug Control | | Go | | 1020h | IIDX | Interrupt index | CPU_INT | Go | | 1028h | IMASK | Interrupt mask | CPU_INT | Go | | 1030h | RIS | Raw interrupt status | CPU_INT | Go | | 1038h | MIS | Masked interrupt status | CPU_INT | Go | | 1040h | ISET | Interrupt set | CPU_INT | Go | | 1048h | ICLR | Interrupt clear | CPU_INT | Go | | 1050h | IIDX | Interrupt index | GEN_EVENT<br>0 | Go | | 1058h | IMASK | Interrupt mask | GEN_EVENT<br>0 | Go | | 1060h | RIS | Raw interrupt status | GEN_EVENT<br>0 | Go | | 1068h | MIS | Masked interrupt status | GEN_EVENT<br>0 | Go | | 1070h | ISET | Interrupt set | GEN_EVENT<br>0 | Go | | 1078h | ICLR | Interrupt clear | GEN_EVENT<br>0 | Go | | 1080h | IIDX | Interrupt index | GEN_EVENT<br>1 | Go | | 1088h | IMASK | Interrupt mask | GEN_EVENT<br>1 | Go | | 1090h | RIS | Raw interrupt status | GEN_EVENT<br>1 | Go | | 1098h | MIS | Masked interrupt status | GEN_EVENT<br>1 | Go | | 10A0h | ISET | Interrupt set | GEN_EVENT<br>1 | Go | | 10A8h | ICLR | Interrupt clear | GEN_EVENT<br>1 | Go | | 10E0h | EVT_MODE | Event Mode | | Go | | 10FCh | DESC | Module Description | | Go | | 1200h | DOUT3_0 | Data output 3 to 0 | | Go | | 1204h | DOUT7_4 | Data output 7 to 4 | | Go | | 1208h | DOUT11_8 | Data output 11 to 8 | | Go | | 120Ch | DOUT15_12 | Data output 15 to 12 | | Go | GPIO www.ti.com **Table 8-2. GPIO Registers (continued)** | Offset | Acronym | Register Name | Group | Section | | | | | |--------|---------------|----------------------------------|----------------------|---------|--|--|--|--| | 1210h | DOUT19_16 | Data output 19 to 16 | Data output 19 to 16 | | | | | | | 1214h | DOUT23_20 | Data output 23 to 20 | Go | | | | | | | 1218h | DOUT27_24 | Data output 27 to 24 Go | | | | | | | | 121Ch | DOUT31_28 | Data output 31 to 28 Go | | | | | | | | 1280h | DOUT31_0 | Data output 31 to 0 Go | | | | | | | | 1290h | DOUTSET31_0 | Data output set 31 to 0 | | Go | | | | | | 12A0h | DOUTCLR31_0 | Data output clear 31 to 0 | | Go | | | | | | 12B0h | DOUTTGL31_0 | Data output toggle 31 to 0 | | Go | | | | | | 12C0h | DOE31_0 | Data output enable 31 to 0 | | Go | | | | | | 12D0h | DOESET31_0 | Data output enable set 31 to 0 | | Go | | | | | | 12E0h | DOECLR31_0 | Data output enable clear 31 to 0 | | Go | | | | | | 1300h | DIN3_0 | Data input 3 to 0 | | | | | | | | 1304h | DIN7_4 | Data input 7 to 4 Go | | | | | | | | 1308h | DIN11_8 | Data input 11 to 8 Go | | | | | | | | 130Ch | DIN15_12 | Data input 15 to 12 | | | | | | | | 1310h | DIN19_16 | Data input 19 to 16 Go | | | | | | | | 1314h | DIN23_20 | Data input 23 to 20 Go | | | | | | | | 1318h | DIN27_24 | Data input 27 to 24 Go | | | | | | | | 131Ch | DIN31_28 | Data input 31 to 28 | · | | | | | | | 1380h | DIN31_0 | Data input 31 to 0 | | Go | | | | | | 1390h | POLARITY15_0 | Polarity 15 to 0 | | Go | | | | | | 13A0h | POLARITY31_16 | Polarity 31 to 16 | | Go | | | | | | 1400h | CTL | FAST WAKE GLOBAL EN | | Go | | | | | | 1404h | FASTWAKE | FAST WAKE ENABLE | | Go | | | | | | 1500h | SUB0CFG | Subscriber 0 configuration | | Go | | | | | | 1508h | FILTEREN15_0 | Filter Enable 15 to 0 | | Go | | | | | | 150Ch | FILTEREN31_16 | Filter Enable 31 to 16 | | Go | | | | | | 1510h | DMAMASK | DMA Write MASK | | Go | | | | | | 1520h | SUB1CFG | Subscriber 1 configuration | | Go | | | | | Complex bit access types are encoded to fit into small table cells. Table 8-3 shows the codes that are used for access types in this section. **Table 8-3. GPIO Access Type Codes** | Access Type | Code | Description | | | | | |------------------------|-----------|----------------------------------------|--|--|--|--| | Access Type | Code | Description | | | | | | Read Type | Read Type | | | | | | | R | R | Read | | | | | | Write Type | | | | | | | | К | К | Write protected by a key | | | | | | W | W | Write | | | | | | WK | W<br>K | Write<br>Write protected by a key | | | | | | Reset or Default Value | | | | | | | | -n | | Value after reset or the default value | | | | | www.ti.com GPIO # 8.3.1 FSUB\_0 (Offset = 400h) [Reset = 00000000h] FSUB\_0 is shown in Figure 8-4 and described in Table 8-4. Return to the Summary Table. Subscriber port # Figure 8-4. FSUB\_0 # Table 8-4. FSUB\_0 Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-4 | RESERVED | R/W | 0h | | | 3-0 | CHANID | R/W | | 0 = disconnected. 1-15 = connected to channelID = CHANID. 0h = A value of 0 specifies that the event is not connected Fh = Consult your device data sheet as the actual allowed maximum may be less than 15. | GPIO www.ti.com # 8.3.2 FSUB\_1 (Offset = 404h) [Reset = 00000000h] FSUB\_1 is shown in Figure 8-5 and described in Table 8-5. Return to the Summary Table. Subscriber port # Figure 8-5. FSUB\_1 Table 8-5. FSUB\_1 Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-4 | RESERVED | R/W | 0h | | | 3-0 | CHANID | R/W | 0h | 0 = disconnected. 1-15 = connected to channelID = CHANID. 0h = A value of 0 specifies that the event is not connected Fh = Consult your device data sheet as the actual allowed maximum may be less than 15. | www.ti.com GPIO # 8.3.3 FPUB\_0 (Offset = 444h) [Reset = 00000000h] FPUB\_0 is shown in Figure 8-6 and described in Table 8-6. Return to the Summary Table. Publisher port # Figure 8-6. FPUB\_0 # Table 8-6. FPUB\_0 Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-4 | RESERVED | R/W | 0h | | | 3-0 | CHANID | R/W | | 0 = disconnected. 1-15 = connected to channelID = CHANID. 0h = A value of 0 specifies that the event is not connected Fh = Consult your device data sheet as the actual allowed maximum may be less than 15. | GPIO www.ti.com # 8.3.4 FPUB\_1 (Offset = 448h) [Reset = 00000000h] FPUB\_1 is shown in Figure 8-7 and described in Table 8-7. Return to the Summary Table. Publisher port # Figure 8-7. FPUB\_1 Table 8-7. FPUB\_1 Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-4 | RESERVED | R/W | 0h | | | 3-0 | CHANID | R/W | | 0 = disconnected. 1-15 = connected to channelID = CHANID. 0h = A value of 0 specifies that the event is not connected Fh = Consult your device data sheet as the actual allowed maximum may be less than 15. | www.ti.com GPIO # 8.3.5 PWREN (Offset = 800h) [Reset = 00000000h] PWREN is shown in Figure 8-8 and described in Table 8-8. Return to the Summary Table. Register to control the power state # Figure 8-8. PWREN # **Table 8-8. PWREN Field Descriptions** | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|----------------------------------------------------------------------------------------------------| | 31-24 | KEY | W | 0h | KEY to allow Power State Change<br>26h = KEY to allow write access to this register | | 23-1 | RESERVED | R/W | 0h | | | 0 | ENABLE | К | 0h | Enable the power KEY must be set to 26h to write to this bit. 0h = Disable Power 1h = Enable Power | GPIO www.ti.com # 8.3.6 RSTCTL (Offset = 804h) [Reset = 00000000h] RSTCTL is shown in Figure 8-9 and described in Table 8-9. Return to the Summary Table. Register to control reset assertion and de-assertion # Figure 8-9. RSTCTL # **Table 8-9. RSTCTL Field Descriptions** | Bit | Field | Туре | Reset | Description | |-------|--------------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------| | 31-24 | KEY | W | 0h | Unlock key B1h = KEY to allow write access to this register | | 23-2 | RESERVED | W | 0h | | | 1 | RESETSTKYCLR | WK | 0h | Clear the RESETSTKY bit in the STAT register KEY must be set to B1h to write to this bit. 0h = Writing 0 has no effect 1h = Clear reset sticky bit | | 0 | RESETASSERT | WK | 0h | Assert reset to the peripheral KEY must be set to B1h to write to this bit. 0h = Writing 0 has no effect 1h = Assert reset | ## 8.3.7 STAT (Offset = 814h) [Reset = 00000000h] STAT is shown in Figure 8-10 and described in Table 8-10. Return to the Summary Table. peripheral enable and reset status ### Figure 8-10. STAT #### **Table 8-10. STAT Field Descriptions** | Bit | Field | Туре | Reset | Description | | | | | |-------|-----------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | 31-17 | RESERVED | R | 0h | | | | | | | 16 | RESETSTKY | R | 0h | This bit indicates, if the peripheral was reset, since this bit was cleared by RESETSTKYCLR in the RSTCTL register 0h = The peripheral has not been reset since this bit was last cleared by RESETSTKYCLR in the RSTCTL register 1h = The peripheral was reset since the last bit clear | | | | | | 15-0 | RESERVED | R | 0h | | | | | | ## 8.3.8 CLKOVR (Offset = 1010h) [Reset = 00000000h] CLKOVR is shown in Figure 8-11 and described in Table 8-11. Return to the Summary Table. This register overrides the functional clock request by this peripheral to the system ### Figure 8-11. CLKOVR ### Table 8-11. CLKOVR Field Descriptions | 1440 0 111 0 <u>111 0 111 1 1014 2 0 0 0 1 </u> | | | | | | | | |-------------------------------------------------|----------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | 31-2 | RESERVED | R/W | 0h | | | | | | 1 | RUN_STOP | R/W | Oh | If OVERRIDE is enabled, this register is used to manually control the peripheral's clock request to the system 0h = Run/ungate functional clock 1h = Stop/gate functional clock | | | | | 0 | OVERRIDE | R/W | Oh | Unlocks the functionality of RUN_STOP to override the automatic peripheral clock request 0h = Override disabled 1h = Override enabled | | | | ### 8.3.9 PDBGCTL (Offset = 1018h) [Reset = 00000001h] PDBGCTL is shown in Figure 8-12 and described in Table 8-12. Return to the Summary Table. This register can be used by the software developer to control the behavior of the peripheral relative to the 'Core Halted' input Figure 8-12. PDBGCTL ### **Table 8-12. PDBGCTL Field Descriptions** | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-1 | RESERVED | R/W | 0h | | | 0 | FREE | R/W | | Free run control 0h = The peripheral freezes functionality while the Core Halted input is asserted and resumes when it is deasserted. 1h = The peripheral ignores the state of the Core Halted input | ### 8.3.10 IIDX (Offset = 1020h) [Reset = 00000000h] IIDX is shown in Figure 8-13 and described in Table 8-13. Return to the Summary Table. This register provides the highest priority enabled interrupt index. Value 0x00 means no event pending. Interrupt 1 is the highest priority, IIDX next highest, 4, 8, ... IIDX^31 is the least priority. That is, the least bit position that is set to 1 denotes the highest priority pending interrupt. The priority order is fixed. However, users can implement their own prioritization schemes using other registers that expose the full set of interrupts that have occurred. On each read, only one interrupt is indicated. On a read, the current interrupt (highest priority) is automatically cleared by the hardware and the corresponding interrupt flag in [RIS] and [MIS] are cleared as well. After a read from the CPU (not from the debug interface), the register is updated with the next highest priority interrupt, if none are pending, then it should display 0x0. #### Figure 8-13. IIDX Table 8-13. IIDX Field Descriptions | Bit | Field | Type | Reset | Description | | |------|----------|------|-------|----------------------------------------------------------------|--| | 31-8 | RESERVED | R | 0h | | | | 7-0 | STAT | R | 0h | Interrupt index status | | | | | | | 0h = No bit is set means there is no pending interrupt request | | | | | | | 1h = DIO0 interrupt | | | | | | | 2h = DIO1 interrupt | | | | | | | 3h = DIO2 interrupt | | | | | | | 4h = DIO3 interrupt | | | | | | | 5h = DIO4 interrupt | | | | | | | 6h = DIO5 interrupt | | | | | | | 7h = DIO6 interrupt | | | | | | | 8h = DIO7 interrupt | | | | | | | 9h = DIO8 interrupt | | | | | | | Ah = DIO9 interrupt | | | | | | | Bh = DIO10 interrupt | | | | | | | Ch = DIO11 interrupt | | | | | | | Dh = DIO12 interrupt | | | | | | | Eh = DIO13 interrupt | | | | | | | Fh = DIO14 interrupt | | | | | | | 10h = DIO15 interrupt | | | | | | | 11h = DIO16 interrupt | | | | | | | 12h = DIO17 interrupt | | | | | | | 13h = DIO18 interrupt | | | | | | | 14h = DIO19 interrupt | | | | | | | 15h = DIO20 interrupt | | | | | | | 16h = DIO21 interrupt | | | | | | | 17h = DIO22 interrupt | | | | | | | 18h = DIO23 interrupt | | | | | | | 19h = DIO24 interrupt | | | | | | | 1Ah = DIO25 interrupt | | | | | | | 1Bh = DIO26 interrupt | | | | | | | 1Ch = DIO27 interrupt | | | | | | | 1Dh = DIO28 interrupt | | | | | | | 1Eh = DIO29 interrupt | | | | | | | 1Fh = DIO30 interrupt | | | | | | | 20h = DIO31 interrupt | | ### 8.3.11 IMASK (Offset = 1028h) [Reset = 00000000h] IMASK is shown in Figure 8-14 and described in Table 8-14. Return to the Summary Table. Interrupt Mask. If a bit is set, then corresponding interrupt is un-masked. Un-masking the interrupt causes the raw interrupt to be visible in IIDX, as well as MIS. Figure 8-14. IMASK | | | | rigule o- | 14. IIVIASK | | | | |--------|--------|--------|-----------|-------------|--------|--------|--------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | DIO31 | DIO30 | DIO29 | DIO28 | DIO27 | DIO26 | DIO25 | DIO24 | | R/W-0h | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | DIO23 | DIO22 | DIO21 | DIO20 | DIO19 | DIO18 | DIO17 | DIO16 | | R/W-0h | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | DIO15 | DIO14 | DIO13 | DIO12 | DIO11 | DIO10 | DIO9 | DIO8 | | R/W-0h | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | DIO7 | DIO6 | DIO5 | DIO4 | DIO3 | DIO2 | DIO1 | DIO0 | | R/W-0h **Table 8-14. IMASK Field Descriptions** | Bit | Field | Туре | Reset | Description | |-----|-------|------|-------|--------------------------------------------------------------| | 31 | DIO31 | R/W | 0h | DIO31 event mask 0h = Event is masked 1h = Event is unmasked | | 30 | DIO30 | R/W | 0h | DIO30 event mask 0h = Event is masked 1h = Event is unmasked | | 29 | DIO29 | R/W | 0h | DIO29 event mask 0h = Event is masked 1h = Event is unmasked | | 28 | DIO28 | R/W | 0h | DIO28 event mask 0h = Event is masked 1h = Event is unmasked | | 27 | DIO27 | R/W | 0h | DIO27 event mask 0h = Event is masked 1h = Event is unmasked | | 26 | DIO26 | R/W | 0h | DIO26 event mask 0h = Event is masked 1h = Event is unmasked | | 25 | DIO25 | R/W | 0h | DIO25 event mask 0h = Event is masked 1h = Event is unmasked | | 24 | DIO24 | R/W | 0h | DIO24 event mask 0h = Event is masked 1h = Event is unmasked | | 23 | DIO23 | R/W | 0h | DIO23 event mask 0h = Event is masked 1h = Event is unmasked | | 22 | DIO22 | R/W | 0h | DIO22 event mask 0h = Event is masked 1h = Event is unmasked | ## **Table 8-14. IMASK Field Descriptions (continued)** | Bit | Field | Type | Reset | Description (continued) | |-----|-------|------|-------|--------------------------------------------------------------| | 21 | DIO21 | R/W | Oh | DIO21 event mask 0h = Event is masked 1h = Event is unmasked | | 20 | DIO20 | R/W | Oh | DIO20 event mask 0h = Event is masked 1h = Event is unmasked | | 19 | DIO19 | R/W | 0h | DIO19 event mask 0h = Event is masked 1h = Event is unmasked | | 18 | DIO18 | R/W | 0h | DIO18 event mask 0h = Event is masked 1h = Event is unmasked | | 17 | DIO17 | R/W | 0h | DIO17 event mask 0h = Event is masked 1h = Event is unmasked | | 16 | DIO16 | R/W | 0h | DIO16 event mask 0h = Event is masked 1h = Event is unmasked | | 15 | DIO15 | R/W | 0h | DIO15 event mask 0h = Event is masked 1h = Event is unmasked | | 14 | DIO14 | R/W | 0h | DIO14 event mask 0h = Event is masked 1h = Event is unmasked | | 13 | DIO13 | R/W | 0h | DIO13 event mask 0h = Event is masked 1h = Event is unmasked | | 12 | DIO12 | R/W | 0h | DIO12 event mask 0h = Event is masked 1h = Event is unmasked | | 11 | DIO11 | R/W | 0h | DIO11 event mask 0h = Event is masked 1h = Event is unmasked | | 10 | DIO10 | R/W | 0h | DIO10 event mask 0h = Event is masked 1h = Event is unmasked | | 9 | DIO9 | R/W | 0h | DIO9 event mask 0h = Event is masked 1h = Event is unmasked | | 8 | DIO8 | R/W | 0h | DIO8 event mask 0h = Event is masked 1h = Event is unmasked | | 7 | DIO7 | R/W | Oh | DIO7 event mask 0h = Event is masked 1h = Event is unmasked | | 6 | DIO6 | R/W | Oh | DIO6 event mask 0h = Event is masked 1h = Event is unmasked | | 5 | DIO5 | R/W | Oh | DIO5 event mask 0h = Event is masked 1h = Event is unmasked | | 4 | DIO4 | R/W | 0h | DIO4 event mask 0h = Event is masked 1h = Event is unmasked | | 3 | DIO3 | R/W | 0h | DIO3 event mask 0h = Event is masked 1h = Event is unmasked | # Table 8-14. IMASK Field Descriptions (continued) | Bit | Field | Туре | Reset | Description | |-----|-------|------|-------|-------------------------------------------------------------| | 2 | DIO2 | R/W | 0h | DIO2 event mask 0h = Event is masked 1h = Event is unmasked | | 1 | DIO1 | R/W | Oh | DIO1 event mask 0h = Event is masked 1h = Event is unmasked | | 0 | DIO0 | R/W | Oh | DIO0 event mask 0h = Event is masked 1h = Event is unmasked | ### 8.3.12 RIS (Offset = 1030h) [Reset = 00000000h] RIS is shown in Figure 8-15 and described in Table 8-15. Return to the Summary Table. Raw interrupt status. Reflects all pending interrupts, regardless of masking. The RIS register allows the user to implement a poll scheme. A flag set in this register can be cleared by writing 1 to the ICLR register bit even if the corresponding IMASK bit is not enabled. Figure 8-15. RIS | | | | 9 | | | | | |-------|-------|-------|-------|-------|-------|-------|-------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | DIO31 | DIO30 | DIO29 | DIO28 | DIO27 | DIO26 | DIO25 | DIO24 | | R-0h | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | DIO23 | DIO22 | DIO21 | DIO20 | DIO19 | DIO18 | DIO17 | DIO16 | | R-0h | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | DIO15 | DIO14 | DIO13 | DIO12 | DIO11 | DIO10 | DIO9 | DIO8 | | R-0h | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | DIO7 | DIO6 | DIO5 | DIO4 | DIO3 | DIO2 | DIO1 | DIO0 | | R-0h #### **Table 8-15. RIS Field Descriptions** | D:4 | Plata. | T | D | Description | | |-----|--------|------|-------|----------------------------------------------------------------------------|--| | Bit | Field | Туре | Reset | Description | | | 31 | DIO31 | R | 0h | DIO31 event 0h = DIO31 event did not occur 1h = DIO31 event occurred | | | 30 | DIO30 | R | 0h | DIO30 event 0h = DIO30 event did not occur 1h = DIO30 event occurred | | | 29 | DIO29 | R | 0h | DIO29 event 0h = DIO29 event did not occur 1h = DIO29 event occurred | | | 28 | DIO28 | R | 0h | DIO28 event 0h = DIO28 event did not occur 1h = DIO28 event occurred | | | 27 | DIO27 | R | 0h | DIO27 event 0h = DIO27 event did not occur 1h = DIO27 event occurred | | | 26 | DIO26 | R | 0h | DIO26 event 0h = DIO26 event did not occur 1h = DIO26 event occurred | | | 25 | DIO25 | R | 0h | DIO25 event 0h = DIO25 event did not occur 1h = DIO25 event occurred | | | 24 | DIO24 | R | 0h | DIO24 event<br>0h = DIO24 event did not occur<br>1h = DIO24 event occurred | | | 23 | DIO23 | R | 0h | DIO23 event 0h = DIO23 event did not occur 1h = DIO23 event occurred | | | 22 | DIO22 | R | 0h | DIO22 event<br>0h = DIO22 event did not occur<br>1h = DIO22 event occurred | | ## **Table 8-15. RIS Field Descriptions (continued)** | Bit | Field | Type | Reset | Descriptions (continued) Description | |-----|-------|------|-------|----------------------------------------------------------------------| | 21 | DIO21 | R | 0h | DIO21 event | | 21 | DIOZI | K | On | 0h = DIO21 event did not occur 1h = DIO21 event occurred | | 20 | DIO20 | R | 0h | DIO20 event 0h = DIO20 event did not occur 1h = DIO20 event occurred | | 19 | DIO19 | R | 0h | DIO19 event 0h = DIO19 event did not occur 1h = DIO19 event occurred | | 18 | DIO18 | R | 0h | DIO18 event 0h = DIO18 event did not occur 1h = DIO18 event occurred | | 17 | DIO17 | R | 0h | DIO17 event 0h = DIO17 event did not occur 1h = DIO17 event occurred | | 16 | DIO16 | R | 0h | DIO16 event 0h = DIO16 event did not occur 1h = DIO16 event occurred | | 15 | DIO15 | R | 0h | DIO15 event 0h = DIO15 event did not occur 1h = DIO15 event occurred | | 14 | DIO14 | R | 0h | DIO14 event 0h = DIO14 event did not occur 1h = DIO14 event occurred | | 13 | DIO13 | R | 0h | DIO13 event 0h = DIO13 event did not occur 1h = DIO13 event occurred | | 12 | DIO12 | R | 0h | DIO12 event 0h = DIO12 event did not occur 1h = DIO12 event occurred | | 11 | DIO11 | R | 0h | DIO11 event 0h = DIO11 event did not occur 1h = DIO11 event occurred | | 10 | DIO10 | R | 0h | DIO10 event 0h = DIO10 event did not occur 1h = DIO10 event occurred | | 9 | DIO9 | R | 0h | DIO9 event 0h = DIO9 event did not occur 1h = DIO9 event occurred | | 8 | DIO8 | R | 0h | DIO8 event 0h = DIO8 event did not occur 1h = DIO8 event occurred | | 7 | DIO7 | R | 0h | DIO7 event 0h = DIO7 event did not occur 1h = DIO7 event occurred | | 6 | DIO6 | R | 0h | DIO6 event 0h = DIO6 event did not occur 1h = DIO6 event occurred | | 5 | DIO5 | R | 0h | DIO5 event 0h = DIO5 event did not occur 1h = DIO5 event occurred | | 4 | DIO4 | R | 0h | DIO4 event 0h = DIO4 event did not occur 1h = DIO4 event occurred | | 3 | DIO3 | R | 0h | DIO3 event 0h = DIO3 event did not occur 1h = DIO3 event occurred | # **Table 8-15. RIS Field Descriptions (continued)** | Bit | Field | Туре | Reset | Description | |-----|-------|------|-------|-------------------------------------------------------------------------| | 2 | DIO2 | R | 0h | DIO2 event<br>0h = DIO2 event did not occur<br>1h = DIO2 event occurred | | 1 | DIO1 | R | Oh | DIO1 event 0h = DIO1 event did not occur 1h = DIO1 event occurred | | 0 | DIO0 | R | Oh | DIO0 event 0h = DIO0 event did not occur 1h = DIO0 event occurred | ## 8.3.13 MIS (Offset = 1038h) [Reset = 00000000h] MIS is shown in Figure 8-16 and described in Table 8-16. Return to the Summary Table. Masked interrupt status. This is an AND of the IMASK and RIS registers. # Figure 8-16. MIS | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------|-------|-------|-------|-------|-------|-------|-------| | DIO31 | DIO30 | DIO29 | DIO28 | DIO27 | DIO26 | DIO25 | DIO24 | | R-0h | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | DIO23 | DIO22 | DIO21 | DIO20 | DIO19 | DIO18 | DIO17 | DIO16 | | R-0h | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | DIO15 | DIO14 | DIO13 | DIO12 | DIO11 | DIO10 | DIO9 | DIO8 | | R-0h | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | DIO7 | DIO6 | DIO5 | DIO4 | DIO3 | DIO2 | DIO1 | DIO0 | | R-0h ### **Table 8-16. MIS Field Descriptions** | Bit | Field | Туре | Reset | Description | |-----|-------|------|-------|----------------------------------------------------------------------| | 31 | DIO31 | R | 0h | DIO31 event 0h = DIO31 event did not occur 1h = DIO31 event occurred | | 30 | DIO30 | R | 0h | DIO30 event 0h = DIO30 event did not occur 1h = DIO30 event occurred | | 29 | DIO29 | R | 0h | DIO29 event 0h = DIO29 event did not occur 1h = DIO29 event occurred | | 28 | DIO28 | R | 0h | DIO28 event 0h = DIO28 event did not occur 1h = DIO28 event occurred | | 27 | DIO27 | R | 0h | DIO27 event 0h = DIO27 event did not occur 1h = DIO27 event occurred | | 26 | DIO26 | R | 0h | DIO26 event 0h = DIO26 event did not occur 1h = DIO26 event occurred | | 25 | DIO25 | R | 0h | DIO25 event 0h = DIO25 event did not occur 1h = DIO25 event occurred | | 24 | DIO24 | R | 0h | DIO24 event 0h = DIO24 event did not occur 1h = DIO24 event occurred | | 23 | DIO23 | R | Oh | DIO23 event 0h = DIO23 event did not occur 1h = DIO23 event occurred | | 22 | DIO22 | R | 0h | DIO22 event 0h = DIO22 event did not occur 1h = DIO22 event occurred | ## **Table 8-16. MIS Field Descriptions (continued)** | Bit | Field | Туре | Reset | Descriptions (continued) | |-----|-------|------|-------|----------------------------------------------------------------------------| | 21 | DIO21 | R | Oh | DIO21 event 0h = DIO21 event did not occur 1h = DIO21 event occurred | | 20 | DIO20 | R | 0h | DIO20 event<br>0h = DIO20 event did not occur<br>1h = DIO20 event occurred | | 19 | DIO19 | R | 0h | DIO19 event 0h = DIO19 event did not occur 1h = DIO19 event occurred | | 18 | DIO18 | R | 0h | DIO18 event 0h = DIO18 event did not occur 1h = DIO18 event occurred | | 17 | DIO17 | R | 0h | DIO17 event 0h = DIO17 event did not occur 1h = DIO17 event occurred | | 16 | DIO16 | R | 0h | DIO16 event 0h = DIO16 event did not occur 1h = DIO16 event occurred | | 15 | DIO15 | R | 0h | DIO15 event 0h = DIO15 event did not occur 1h = DIO15 event occurred | | 14 | DIO14 | R | 0h | DIO14 event 0h = DIO14 event did not occur 1h = DIO14 event occurred | | 13 | DIO13 | R | 0h | DIO13 event 0h = DIO13 event did not occur 1h = DIO13 event occurred | | 12 | DIO12 | R | 0h | DIO12 event 0h = DIO12 event did not occur 1h = DIO12 event occurred | | 11 | DIO11 | R | 0h | DIO11 event 0h = DIO11 event did not occur 1h = DIO11 event occurred | | 10 | DIO10 | R | 0h | DIO10 event 0h = DIO10 event did not occur 1h = DIO10 event occurred | | 9 | DIO9 | R | 0h | DIO9 event 0h = DIO9 event did not occur 1h = DIO9 event occurred | | 8 | DIO8 | R | 0h | DIO8 event 0h = DIO8 event did not occur 1h = DIO8 event occurred | | 7 | DIO7 | R | 0h | DIO7 event 0h = DIO7 event did not occur 1h = DIO7 event occurred | | 6 | DIO6 | R | 0h | DIO6 event 0h = DIO6 event did not occur 1h = DIO6 event occurred | | 5 | DIO5 | R | 0h | DIO5 event 0h = DIO5 event did not occur 1h = DIO5 event occurred | | 4 | DIO4 | R | 0h | DIO4 event 0h = DIO4 event did not occur 1h = DIO4 event occurred | | 3 | DIO3 | R | 0h | DIO3 event 0h = DIO3 event did not occur 1h = DIO3 event occurred | # **Table 8-16. MIS Field Descriptions (continued)** | Bit | Field | Туре | Reset | Description | |-----|-------|------|-------|-------------------------------------------------------------------| | 2 | DIO2 | R | Oh | DIO2 event 0h = DIO2 event did not occur 1h = DIO2 event occurred | | 1 | DIO1 | R | Oh | DIO1 event 0h = DIO1 event did not occur 1h = DIO1 event occurred | | 0 | DIO0 | R | Oh | DIO0 event 0h = DIO0 event did not occur 1h = DIO0 event occurred | ### 8.3.14 ISET (Offset = 1040h) [Reset = 00000000h] ISET is shown in Figure 8-17 and described in Table 8-17. Return to the Summary Table. Interrupt set. Allows interrupts to be set by software (useful in diagnostics and safety checks). Writing a 1 to a bit in ISET will set the event and therefore the related RIS bit also gets set. If the interrupt is enabled through the mask, then the corresponding MIS bit is also set. Figure 8-17. ISET | | | | i igaic o | | | | | |-------|-------|-------|-----------|-------|-------|-------|-------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | DIO31 | DIO30 | DIO29 | DIO28 | DIO27 | DIO26 | DIO25 | DIO24 | | W-0h | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | DIO23 | DIO22 | DIO21 | DIO20 | DIO19 | DIO18 | DIO17 | DIO16 | | W-0h | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | DIO15 | DIO14 | DIO13 | DIO12 | DIO11 | DIO10 | DIO9 | DIO8 | | W-0h | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | DIO7 | DIO6 | DIO5 | DIO4 | DIO3 | DIO2 | DIO1 | DIO0 | | W-0h #### **Table 8-17. ISET Field Descriptions** | | | | _ | | |-----|-------|------|-------|------------------------------------------------------------------| | Bit | Field | Туре | Reset | Description | | 31 | DIO31 | W | 0h | DIO31 event 0h = No effect 1h = Sets DIO31 in RIS register | | 30 | DIO30 | W | 0h | DIO30 event 0h = No effect 1h = Sets DIO30 in RIS register | | 29 | DIO29 | W | 0h | DIO29 event<br>0h = No effect<br>1h = Sets DIO29 in RIS register | | 28 | DIO28 | W | 0h | DIO28 event 0h = No effect 1h = Sets DIO28 in RIS register | | 27 | DIO27 | W | 0h | DIO27 event 0h = No effect 1h = Sets DIO27 in RIS register | | 26 | DIO26 | W | 0h | DIO26 event<br>0h = No effect<br>1h = Sets DIO26 in RIS register | | 25 | DIO25 | W | 0h | DIO25 event<br>0h = No effect<br>1h = Sets DIO25 in RIS register | | 24 | DIO24 | W | 0h | DIO24 event<br>0h = No effect<br>1h = Sets DIO24 in RIS register | | 23 | DIO23 | W | Oh | DIO23 event 0h = No effect 1h = Sets DIO23 in RIS register | | 22 | DIO22 | W | Oh | DIO22 event<br>0h = No effect<br>1h = Sets DIO22 in RIS register | ## **Table 8-17. ISET Field Descriptions (continued)** | Bit | Field | Type | Reset | Descriptions (continued) | |-----|-------|------|-------|------------------------------------------------------------------| | | DIO21 | W | Oh | DIO21 event | | 21 | DIOZI | VV | UII | Oh = No effect 1h = Sets DIO21 in RIS register | | 20 | DIO20 | W | 0h | DIO20 event<br>0h = No effect<br>1h = Sets DIO20 in RIS register | | 19 | DIO19 | W | 0h | DIO19 event 0h = No effect 1h = Sets DIO19 in RIS register | | 18 | DIO18 | W | 0h | DIO18 event<br>0h = No effect<br>1h = Sets DIO18 in RIS register | | 17 | DIO17 | W | 0h | DIO17 event 0h = No effect 1h = Sets DIO17 in RIS register | | 16 | DIO16 | W | 0h | DIO16 event 0h = No effect 1h = Sets DIO16 in RIS register | | 15 | DIO15 | W | 0h | DIO15 event<br>0h = No effect<br>1h = Sets DIO15 in RIS register | | 14 | DIO14 | W | 0h | DIO14 event 0h = No effect 1h = Sets DIO14 in RIS register | | 13 | DIO13 | W | 0h | DIO13 event<br>0h = No effect<br>1h = Sets DIO13 in RIS register | | 12 | DIO12 | W | 0h | DIO12 event 0h = No effect 1h = Sets DIO12 in RIS register | | 11 | DIO11 | W | 0h | DIO11 event 0h = No effect 1h = Sets DIO11 in RIS register | | 10 | DIO10 | W | 0h | DIO10 event<br>0h = No effect<br>1h = Sets DIO10 in RIS register | | 9 | DIO9 | W | 0h | DIO9 event 0h = No effect 1h = Sets DIO9 in RIS register | | 8 | DIO8 | W | 0h | DIO8 event 0h = No effect 1h = Sets DIO8 in RIS register | | 7 | DIO7 | W | 0h | DIO7 event 0h = No effect 1h = Sets DIO7 in RIS register | | 6 | DIO6 | W | 0h | DIO6 event 0h = No effect 1h = Sets DIO6 in RIS register | | 5 | DIO5 | W | 0h | DIO5 event 0h = No effect 1h = Sets DIO5 in RIS register | | 4 | DIO4 | W | 0h | DIO4 event 0h = No effect 1h = Sets DIO4 in RIS register | | 3 | DIO3 | W | 0h | DIO3 event 0h = No effect 1h = Sets DIO3 in RIS register | # **Table 8-17. ISET Field Descriptions (continued)** | Bit | Field | Туре | Reset | Description | |-----|-------|------|-------|----------------------------------------------------------------| | 2 | DIO2 | W | 0h | DIO2 event<br>0h = No effect<br>1h = Sets DIO2 in RIS register | | 1 | DIO1 | W | Oh | DIO1 event 0h = No effect 1h = Sets DIO1 in RIS register | | 0 | DIO0 | W | Oh | DIO0 event 0h = No effect 1h = Sets DIO0 in RIS register | ## 8.3.15 ICLR (Offset = 1048h) [Reset = 00000000h] ICLR is shown in Figure 8-18 and described in Table 8-18. Return to the Summary Table. Interrupt clear. Write a 1 to clear corresponding Interrupt. ### Figure 8-18. ICLR | | | | J · · · | | | | | |-------|-------|-------|---------|-------|-------|-------|-------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | DIO31 | DIO30 | DIO29 | DIO28 | DIO27 | DIO26 | DIO25 | DIO24 | | W-0h | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | DIO23 | DIO22 | DIO21 | DIO20 | DIO19 | DIO18 | DIO17 | DIO16 | | W-0h | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | DIO15 | DIO14 | DIO13 | DIO12 | DIO11 | DIO10 | DIO9 | DIO8 | | W-0h | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | DIO7 | DIO6 | DIO5 | DIO4 | DIO3 | DIO2 | DIO1 | DIO0 | | W-0h ### Table 8-18. ICLR Field Descriptions | | | | | . 1014 2 0001 public | |-----|-------|------|-------|--------------------------------------------------------------| | Bit | Field | Туре | Reset | Description | | 31 | DIO31 | W | 0h | DIO31 event 0h = No effect 1h = Clears DIO31 in RIS register | | 30 | DIO30 | W | 0h | DIO30 event 0h = No effect 1h = Clears DIO30 in RIS register | | 29 | DIO29 | W | 0h | DIO29 event 0h = No effect 1h = Clears DIO29 in RIS register | | 28 | DIO28 | W | 0h | DIO28 event 0h = No effect 1h = Clears DIO28 in RIS register | | 27 | DIO27 | W | 0h | DIO27 event 0h = No effect 1h = Clears DIO27 in RIS register | | 26 | DIO26 | W | 0h | DIO26 event 0h = No effect 1h = Clears DIO26 in RIS register | | 25 | DIO25 | W | 0h | DIO25 event 0h = No effect 1h = Clears DIO25 in RIS register | | 24 | DIO24 | W | 0h | DIO24 event 0h = No effect 1h = Clears DIO24 in RIS register | | 23 | DIO23 | W | Oh | DIO23 event 0h = No effect 1h = Clears DIO23 in RIS register | | 22 | DIO22 | W | 0h | DIO22 event 0h = No effect 1h = Clears DIO22 in RIS register | ## Table 8-18. ICLR Field Descriptions (continued) | Bit | Field | Туре | Reset | Descriptions (continued) Description | |-----|-------|------|-------|--------------------------------------------------------------------| | 21 | DIO21 | W | 0h | DIO21 event 0h = No effect 1h = Clears DIO21 in RIS register | | 20 | DIO20 | W | 0h | DIO20 event<br>0h = No effect<br>1h = Clears DIO20 in RIS register | | 19 | DIO19 | W | 0h | DIO19 event 0h = No effect 1h = Clears DIO19 in RIS register | | 18 | DIO18 | W | 0h | DIO18 event 0h = No effect 1h = Clears DIO18 in RIS register | | 17 | DIO17 | W | 0h | DIO17 event 0h = No effect 1h = Clears DIO17 in RIS register | | 16 | DIO16 | W | 0h | DIO16 event 0h = No effect 1h = Clears DIO16 in RIS register | | 15 | DIO15 | W | 0h | DIO15 event 0h = No effect 1h = Clears DIO15 in RIS register | | 14 | DIO14 | W | 0h | DIO14 event 0h = No effect 1h = Clears DIO14 in RIS register | | 13 | DIO13 | W | 0h | DIO13 event 0h = No effect 1h = Clears DIO13 in RIS register | | 12 | DIO12 | W | 0h | DIO12 event 0h = No effect 1h = Clears DIO12 in RIS register | | 11 | DIO11 | W | 0h | DIO11 event 0h = No effect 1h = Clears DIO11 in RIS register | | 10 | DIO10 | W | 0h | DIO10 event 0h = No effect 1h = Clears DIO10 in RIS register | | 9 | DIO9 | W | 0h | DIO9 event 0h = No effect 1h = Clears DIO9 in RIS register | | 8 | DIO8 | W | 0h | DIO8 event 0h = No effect 1h = Clears DIO8 in RIS register | | 7 | DIO7 | W | 0h | DIO7 event 0h = No effect 1h = Clears DIO7 in RIS register | | 6 | DIO6 | W | 0h | DIO6 event 0h = No effect 1h = Clears DIO6 in RIS register | | 5 | DIO5 | W | 0h | DIO5 event 0h = No effect 1h = Clears DIO5 in RIS register | | 4 | DIO4 | W | 0h | DIO4 event 0h = No effect 1h = Clears DIO4 in RIS register | | 3 | DIO3 | W | 0h | DIO3 event<br>0h = No effect<br>1h = Clears DIO3 in RIS register | # Table 8-18. ICLR Field Descriptions (continued) | Bit | Field | Туре | Reset | Description | |-----|-------|------|-------|------------------------------------------------------------------| | 2 | DIO2 | W | 0h | DIO2 event<br>0h = No effect<br>1h = Clears DIO2 in RIS register | | 1 | DIO1 | W | Oh | DIO1 event 0h = No effect 1h = Clears DIO1 in RIS register | | 0 | DIO0 | W | Oh | DIO0 event 0h = No effect 1h = Clears DIO0 in RIS register | ### 8.3.16 IIDX (Offset = 1050h) [Reset = 00000000h] IIDX is shown in Figure 8-19 and described in Table 8-19. Return to the Summary Table. This register provides the highest priority enabled interrupt index. Value 0x00 means no event pending. Interrupt 1 is the highest priority, IIDX next highest, 4, 8, ... IIDX^31 is the least priority. That is, the least bit position that is set to 1 denotes the highest priority pending interrupt. The priority order is fixed. However, users can implement their own prioritization schemes using other registers that expose the full set of interrupts that have occurred. On each read, only one interrupt is indicated. On a read, the current interrupt (highest priority) is automatically cleared by the hardware and the corresponding interrupt flag in [RIS] and [MIS] are cleared as well. After a read from the CPU (not from the debug interface), the register is updated with the next highest priority interrupt, if none are pending, then it should display 0x0. #### Figure 8-19. IIDX Table 8-19. IIDX Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-8 | RESERVED | R | 0h | | | 7-0 | STAT | R | Oh | Interrupt index status 0h = No bit is set means there is no pending interrupt request 1h = DIO0 interrupt 2h = DIO1 interrupt 3h = DIO2 interrupt 4h = DIO3 interrupt 5h = DIO4 interrupt 6h = DIO5 interrupt 7h = DIO6 interrupt 8h = DIO7 interrupt 9h = DIO8 interrupt Ah = DIO9 interrupt Bh = DIO10 interrupt Ch = DIO11 interrupt Ch = DIO11 interrupt Dh = DIO12 interrupt Eh = DIO13 interrupt Fh = DIO14 interrupt 10h = DIO15 interrupt | ### 8.3.17 IMASK (Offset = 1058h) [Reset = 00000000h] IMASK is shown in Figure 8-20 and described in Table 8-20. Return to the Summary Table. Interrupt Mask. If a bit is set, then corresponding interrupt is un-masked. Un-masking the interrupt causes the raw interrupt to be visible in IIDX, as well as MIS. Figure 8-20. IMASK | | | | i iguie 0-2 | 20. IIVIASK | | | | | | | |--------|----------|--------|-------------|-------------|--------|--------|--------|--|--|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | | RESERVED | | | | | | | | | | | | R/W-0h | | | | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | | RESERVED | | | | | | | | | | | | R/W-0h | | | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | DIO15 | DIO14 | DIO13 | DIO12 | DIO11 | DIO10 | DIO9 | DIO8 | | | | | R/W-0h | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | DIO7 | DIO6 | DIO5 | DIO4 | DIO3 | DIO2 | DIO1 | DIO0 | | | | | R/W-0h | | | ### Table 8-20. IMASK Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|--------------------------------------------------------------| | 31-16 | RESERVED | R/W | 0h | | | 15 | DIO15 | R/W | 0h | DIO15 event mask 0h = Event is masked 1h = Event is unmasked | | 14 | DIO14 | R/W | 0h | DIO14 event mask 0h = Event is masked 1h = Event is unmasked | | 13 | DIO13 | R/W | 0h | DIO13 event mask 0h = Event is masked 1h = Event is unmasked | | 12 | DIO12 | R/W | 0h | DIO12 event mask 0h = Event is masked 1h = Event is unmasked | | 11 | DIO11 | R/W | 0h | DIO11 event mask 0h = Event is masked 1h = Event is unmasked | | 10 | DIO10 | R/W | 0h | DIO10 event mask 0h = Event is masked 1h = Event is unmasked | | 9 | DIO9 | R/W | 0h | DIO9 event mask 0h = Event is masked 1h = Event is unmasked | | 8 | DIO8 | R/W | 0h | DIO8 event mask 0h = Event is masked 1h = Event is unmasked | | 7 | DIO7 | R/W | 0h | DIO7 event mask 0h = Event is masked 1h = Event is unmasked | | 6 | DIO6 | R/W | 0h | DIO6 event mask 0h = Event is masked 1h = Event is unmasked | ## Table 8-20. IMASK Field Descriptions (continued) | Bit | Field | Туре | Reset | Description | |-----|-------|------|-------|-------------------------------------------------------------| | 5 | DIO5 | R/W | 0h | DIO5 event mask 0h = Event is masked 1h = Event is unmasked | | 4 | DIO4 | R/W | 0h | DIO4 event mask 0h = Event is masked 1h = Event is unmasked | | 3 | DIO3 | R/W | 0h | DIO3 event mask 0h = Event is masked 1h = Event is unmasked | | 2 | DIO2 | R/W | 0h | DIO2 event mask 0h = Event is masked 1h = Event is unmasked | | 1 | DIO1 | R/W | 0h | DIO1 event mask 0h = Event is masked 1h = Event is unmasked | | 0 | DIO0 | R/W | 0h | DIO0 event mask 0h = Event is masked 1h = Event is unmasked | ### 8.3.18 RIS (Offset = 1060h) [Reset = 00000000h] RIS is shown in Figure 8-21 and described in Table 8-21. Return to the Summary Table. Raw interrupt status. Reflects all pending interrupts, regardless of masking. The RIS register allows the user to implement a poll scheme. A flag set in this register can be cleared by writing 1 to the ICLR register bit even if the corresponding IMASK bit is not enabled. Figure 8-21. RIS | | | | i iguic c | | | | | | | | |-------|----------|-------|-----------|-------|-------|------|------|--|--|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | | RESERVED | | | | | | | | | | | | R-0h | | | | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | | RESERVED | | | | | | | | | | | | | | R- | 0h | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | DIO15 | DIO14 | DIO13 | DIO12 | DIO11 | DIO10 | DIO9 | DIO8 | | | | | R-0h | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | DIO7 | DIO6 | DIO5 | DIO4 | DIO3 | DIO2 | DIO1 | DIO0 | | | | | R-0h | | | ### Table 8-21. RIS Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|----------------------------------------------------------------------| | 31-16 | RESERVED | R | 0h | | | 15 | DIO15 | R | Oh | DIO15 event 0h = DIO15 event did not occur 1h = DIO15 event occurred | | 14 | DIO14 | R | 0h | DIO14 event 0h = DIO14 event did not occur 1h = DIO14 event occurred | | 13 | DIO13 | R | 0h | DIO13 event 0h = DIO13 event did not occur 1h = DIO13 event occurred | | 12 | DIO12 | R | 0h | DIO12 event 0h = DIO12 event did not occur 1h = DIO12 event occurred | | 11 | DIO11 | R | 0h | DIO11 event 0h = DIO11 event did not occur 1h = DIO11 event occurred | | 10 | DIO10 | R | 0h | DIO10 event 0h = DIO10 event did not occur 1h = DIO10 event occurred | | 9 | DIO9 | R | 0h | DIO9 event 0h = DIO9 event did not occur 1h = DIO9 event occurred | | 8 | DIO8 | R | 0h | DIO8 event 0h = DIO8 event did not occur 1h = DIO8 event occurred | | 7 | DIO7 | R | 0h | DIO7 event 0h = DIO7 event did not occur 1h = DIO7 event occurred | ## **Table 8-21. RIS Field Descriptions (continued)** | rable of 211 rate i lota Becompations (contamaca) | | | | | | | |---------------------------------------------------|-------|------|-------|-------------------------------------------------------------------|--|--| | Bit | Field | Туре | Reset | Description | | | | 6 | DIO6 | R | 0h | DIO6 event 0h = DIO6 event did not occur 1h = DIO6 event occurred | | | | 5 | DIO5 | R | 0h | DIO5 event 0h = DIO5 event did not occur 1h = DIO5 event occurred | | | | 4 | DIO4 | R | Oh | DIO4 event 0h = DIO4 event did not occur 1h = DIO4 event occurred | | | | 3 | DIO3 | R | 0h | DIO3 event 0h = DIO3 event did not occur 1h = DIO3 event occurred | | | | 2 | DIO2 | R | 0h | DIO2 event 0h = DIO2 event did not occur 1h = DIO2 event occurred | | | | 1 | DIO1 | R | Oh | DIO1 event 0h = DIO1 event did not occur 1h = DIO1 event occurred | | | | 0 | DIO0 | R | 0h | DIO0 event 0h = DIO0 event did not occur 1h = DIO0 event occurred | | | ## 8.3.19 MIS (Offset = 1068h) [Reset = 00000000h] MIS is shown in Figure 8-22 and described in Table 8-22. Return to the Summary Table. Masked interrupt status. This is an AND of the IMASK and RIS registers. ## Figure 8-22. MIS | | | | J | | | | | | | | | |-------|----------|-------|-------|-------|-------|------|------|--|--|--|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | | | RESERVED | | | | | | | | | | | | | R-0h | | | | | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | | | | | RESE | RVED | | | | | | | | | | | | R- | ·0h | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | DIO15 | DIO14 | DIO13 | DIO12 | DIO11 | DIO10 | DIO9 | DIO8 | | | | | | R-0h | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | DIO7 | DIO6 | DIO5 | DIO4 | DIO3 | DIO2 | DIO1 | DIO0 | | | | | | R-0h | | | | ### **Table 8-22. MIS Field Descriptions** | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|----------------------------------------------------------------------------| | 31-16 | RESERVED | R | 0h | | | 15 | DIO15 | R | Oh | DIO15 event 0h = DIO15 event did not occur 1h = DIO15 event occurred | | 14 | DIO14 | R | 0h | DIO14 event<br>0h = DIO14 event did not occur<br>1h = DIO14 event occurred | | 13 | DIO13 | R | 0h | DIO13 event 0h = DIO13 event did not occur 1h = DIO13 event occurred | | 12 | DIO12 | R | 0h | DIO12 event 0h = DIO12 event did not occur 1h = DIO12 event occurred | | 11 | DIO11 | R | 0h | DIO11 event 0h = DIO11 event did not occur 1h = DIO11 event occurred | | 10 | DIO10 | R | 0h | DIO10 event 0h = DIO10 event did not occur 1h = DIO10 event occurred | | 9 | DIO9 | R | 0h | DIO9 event 0h = DIO9 event did not occur 1h = DIO9 event occurred | | 8 | DIO8 | R | 0h | DIO8 event 0h = DIO8 event did not occur 1h = DIO8 event occurred | | 7 | DIO7 | R | Oh | DIO7 event 0h = DIO7 event did not occur 1h = DIO7 event occurred | | 6 | DIO6 | R | 0h | DIO6 event 0h = DIO6 event did not occur 1h = DIO6 event occurred | # **Table 8-22. MIS Field Descriptions (continued)** | Bit | Field | Туре | Reset | Description | |-----|-------|------|-------|-------------------------------------------------------------------| | 5 | DIO5 | R | 0h | DIO5 event 0h = DIO5 event did not occur 1h = DIO5 event occurred | | 4 | DIO4 | R | Oh | DIO4 event 0h = DIO4 event did not occur 1h = DIO4 event occurred | | 3 | DIO3 | R | 0h | DIO3 event 0h = DIO3 event did not occur 1h = DIO3 event occurred | | 2 | DIO2 | R | Oh | DIO2 event 0h = DIO2 event did not occur 1h = DIO2 event occurred | | 1 | DIO1 | R | Oh | DIO1 event 0h = DIO1 event did not occur 1h = DIO1 event occurred | | 0 | DIO0 | R | 0h | DIO0 event 0h = DIO0 event did not occur 1h = DIO0 event occurred | ### 8.3.20 ISET (Offset = 1070h) [Reset = 00000000h] ISET is shown in Figure 8-23 and described in Table 8-23. Return to the Summary Table. Interrupt set. Allows interrupts to be set by software (useful in diagnostics and safety checks). Writing a 1 to a bit in ISET will set the event and therefore the related RIS bit also gets set. If the interrupt is enabled through the mask, then the corresponding MIS bit is also set. Figure 8-23. ISET | | | | i igui e o | -23. IOL I | | | | | | | |-------|----------|-------|------------|------------|-------|------|------|--|--|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | | RESERVED | | | | | | | | | | | | W-0h | | | | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | | RESERVED | | | | | | | | | | | | W-0h | | | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | DIO15 | DIO14 | DIO13 | DIO12 | DIO11 | DIO10 | DIO9 | DIO8 | | | | | W-0h | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | DIO7 | DIO6 | DIO5 | DIO4 | DIO3 | DIO2 | DIO1 | DIO0 | | | | | W-0h | | | #### **Table 8-23. ISET Field Descriptions** | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|------------------------------------------------------------| | 31-16 | RESERVED | W | 0h | | | 15 | DIO15 | W | 0h | DIO15 event 0h = No effect 1h = Sets DIO15 in RIS register | | 14 | DIO14 | W | 0h | DIO14 event 0h = No effect 1h = Sets DIO14 in RIS register | | 13 | DIO13 | W | 0h | DIO13 event 0h = No effect 1h = Sets DIO13 in RIS register | | 12 | DIO12 | W | 0h | DIO12 event 0h = No effect 1h = Sets DIO12 in RIS register | | 11 | DIO11 | W | 0h | DIO11 event 0h = No effect 1h = Sets DIO11 in RIS register | | 10 | DIO10 | W | 0h | DIO10 event 0h = No effect 1h = Sets DIO10 in RIS register | | 9 | DIO9 | W | 0h | DIO9 event 0h = No effect 1h = Sets DIO9 in RIS register | | 8 | DIO8 | W | 0h | DIO8 event 0h = No effect 1h = Sets DIO8 in RIS register | | 7 | DIO7 | W | 0h | DIO7 event 0h = No effect 1h = Sets DIO7 in RIS register | ## **Table 8-23. ISET Field Descriptions (continued)** | | rabio o zor roza i riora bosoriptiono (sontinava) | | | | | | | | | |-----|---------------------------------------------------|------|-------|----------------------------------------------------------|--|--|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | | | 6 | DIO6 | W | 0h | DIO6 event 0h = No effect 1h = Sets DIO6 in RIS register | | | | | | | 5 | DIO5 | W | 0h | DIO5 event 0h = No effect 1h = Sets DIO5 in RIS register | | | | | | | 4 | DIO4 | W | 0h | DIO4 event 0h = No effect 1h = Sets DIO4 in RIS register | | | | | | | 3 | DIO3 | W | 0h | DIO3 event 0h = No effect 1h = Sets DIO3 in RIS register | | | | | | | 2 | DIO2 | W | 0h | DIO2 event 0h = No effect 1h = Sets DIO2 in RIS register | | | | | | | 1 | DIO1 | W | 0h | DIO1 event 0h = No effect 1h = Sets DIO1 in RIS register | | | | | | | 0 | DIO0 | W | 0h | DIO0 event 0h = No effect 1h = Sets DIO0 in RIS register | | | | | | ## 8.3.21 ICLR (Offset = 1078h) [Reset = 00000000h] ICLR is shown in Figure 8-24 and described in Table 8-24. Return to the Summary Table. Interrupt clear. Write a 1 to clear corresponding Interrupt. ### Figure 8-24. ICLR | | | | J | | | | | | | | | | |-------|----------|-------|-------|-------|-------|------|------|--|--|--|--|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | | | | RESERVED | | | | | | | | | | | | | W-0h | | | | | | | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | | | | RESERVED | | | | | | | | | | | | | | | | W | -0h | | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | | DIO15 | DIO14 | DIO13 | DIO12 | DIO11 | DIO10 | DIO9 | DIO8 | | | | | | | W-0h | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | DIO7 | DIO6 | DIO5 | DIO4 | DIO3 | DIO2 | DIO1 | DIO0 | | | | | | | W-0h | | | | | | | | | | | | | | | | | | | ### Table 8-24. ICLR Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|--------------------------------------------------------------| | 31-16 | RESERVED | W | 0h | | | 15 | DIO15 | W | 0h | DIO15 event 0h = No effect 1h = Clears DIO15 in RIS register | | 14 | DIO14 | W | 0h | DIO14 event 0h = No effect 1h = Clears DIO14 in RIS register | | 13 | DIO13 | W | 0h | DIO13 event 0h = No effect 1h = Clears DIO13 in RIS register | | 12 | DIO12 | W | 0h | DIO12 event 0h = No effect 1h = Clears DIO12 in RIS register | | 11 | DIO11 | W | 0h | DIO11 event 0h = No effect 1h = Clears DIO11 in RIS register | | 10 | DIO10 | W | Oh | DIO10 event 0h = No effect 1h = Clears DIO10 in RIS register | | 9 | DIO9 | W | 0h | DIO9 event 0h = No effect 1h = Clears DIO9 in RIS register | | 8 | DIO8 | W | 0h | DIO8 event 0h = No effect 1h = Clears DIO8 in RIS register | | 7 | DIO7 | W | Oh | DIO7 event 0h = No effect 1h = Clears DIO7 in RIS register | | 6 | DIO6 | W | 0h | DIO6 event 0h = No effect 1h = Clears DIO6 in RIS register | # Table 8-24. ICLR Field Descriptions (continued) | Bit | Field | Туре | Reset | Description | |-----|-------|------|-------|------------------------------------------------------------------| | 5 | DIO5 | W | 0h | DIO5 event 0h = No effect 1h = Clears DIO5 in RIS register | | 4 | DIO4 | W | 0h | DIO4 event<br>0h = No effect<br>1h = Clears DIO4 in RIS register | | 3 | DIO3 | W | 0h | DIO3 event 0h = No effect 1h = Clears DIO3 in RIS register | | 2 | DIO2 | W | 0h | DIO2 event<br>0h = No effect<br>1h = Clears DIO2 in RIS register | | 1 | DIO1 | W | 0h | DIO1 event 0h = No effect 1h = Clears DIO1 in RIS register | | 0 | DIO0 | W | 0h | DIO0 event 0h = No effect 1h = Clears DIO0 in RIS register | ### 8.3.22 IIDX (Offset = 1080h) [Reset = 00000000h] IIDX is shown in Figure 8-25 and described in Table 8-25. Return to the Summary Table. This register provides the highest priority enabled interrupt index. Value 0x00 means no event pending. Interrupt 1 is the highest priority, IIDX next highest, 4, 8, ... IIDX^31 is the least priority. That is, the least bit position that is set to 1 denotes the highest priority pending interrupt. The priority order is fixed. However, users can implement their own prioritization schemes using other registers that expose the full set of interrupts that have occurred. On each read, only one interrupt is indicated. On a read, the current interrupt (highest priority) is automatically cleared by the hardware and the corresponding interrupt flag in [RIS] and [MIS] are cleared as well. After a read from the CPU (not from the debug interface), the register is updated with the next highest priority interrupt, if none are pending, then it should display 0x0. #### Figure 8-25. IIDX #### Table 8-25. IIDX Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-8 | RESERVED | R | 0h | | | 7-0 | STAT | R | Oh | Interrupt index status 0h = No bit is set means there is no pending interrupt request 1h = DIO0 interrupt 2h = DIO1 interrupt 3h = DIO2 interrupt 4h = DIO3 interrupt 5h = DIO4 interrupt 6h = DIO5 interrupt 7h = DIO6 interrupt 8h = DIO7 interrupt 9h = DIO8 interrupt Ah = DIO9 interrupt Bh = DIO10 interrupt Ch = DIO11 interrupt Ch = DIO11 interrupt Dh = DIO12 interrupt Eh = DIO13 interrupt Fh = DIO14 interrupt 10h = DIO15 interrupt | ### 8.3.23 IMASK (Offset = 1088h) [Reset = 00000000h] IMASK is shown in Figure 8-26 and described in Table 8-26. Return to the Summary Table. Interrupt Mask. If a bit is set, then corresponding interrupt is un-masked. Un-masking the interrupt causes the raw interrupt to be visible in IIDX, as well as MIS. Figure 8-26. IMASK | rigare 0-20. Innact | | | | | | | | | | | |---------------------|----------|--------|--------|--------|--------|--------|--------|--|--|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | DIO31 | DIO30 | DIO29 | DIO28 | DIO27 | DIO26 | DIO25 | DIO24 | | | | | R/W-0h | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | DIO23 | DIO22 | DIO21 | DIO20 | DIO19 | DIO18 | DIO17 | DIO16 | | | | | R/W-0h | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | | | RESE | RVED | | | | | | | | | | | R/V | /-0h | | | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | RESERVED | | | | | | | | | | | | | | R/V | /-0h | | | | | | | | l . | | | | | | | | | | | **Table 8-26. IMASK Field Descriptions** | Bit | Field | Туре | Reset | Description | |-----|-------|------|-------|--------------------------------------------------------------| | 31 | DIO31 | R/W | 0h | DIO31 event mask 0h = Event is masked 1h = Event is unmasked | | 30 | DIO30 | R/W | 0h | DIO30 event mask 0h = Event is masked 1h = Event is unmasked | | 29 | DIO29 | R/W | Oh | DIO29 event mask 0h = Event is masked 1h = Event is unmasked | | 28 | DIO28 | R/W | Oh | DIO28 event mask 0h = Event is masked 1h = Event is unmasked | | 27 | DIO27 | R/W | Oh | DIO27 event mask 0h = Event is masked 1h = Event is unmasked | | 26 | DIO26 | R/W | Oh | DIO26 event mask 0h = Event is masked 1h = Event is unmasked | | 25 | DIO25 | R/W | Oh | DIO25 event mask 0h = Event is masked 1h = Event is unmasked | | 24 | DIO24 | R/W | Oh | DIO24 event mask 0h = Event is masked 1h = Event is unmasked | | 23 | DIO23 | R/W | Oh | DIO23 event mask 0h = Event is masked 1h = Event is unmasked | | 22 | DIO22 | R/W | 0h | DIO22 event mask 0h = Event is masked 1h = Event is unmasked | ## Table 8-26. IMASK Field Descriptions (continued) | | Table 0-20: IMAON Tield Descriptions (continued) | | | | | | | | | |------|--------------------------------------------------|------|-------|--------------------------------------------------------------|--|--|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | | | 21 | DIO21 | R/W | 0h | DIO21 event mask 0h = Event is masked 1h = Event is unmasked | | | | | | | 20 | DIO20 | R/W | Oh | DIO20 event mask 0h = Event is masked 1h = Event is unmasked | | | | | | | 19 | DIO19 | R/W | Oh | DIO19 event mask 0h = Event is masked 1h = Event is unmasked | | | | | | | 18 | DIO18 | R/W | Oh | DIO18 event mask 0h = Event is masked 1h = Event is unmasked | | | | | | | 17 | DIO17 | R/W | Oh | DIO17 event mask 0h = Event is masked 1h = Event is unmasked | | | | | | | 16 | DIO16 | R/W | Oh | DIO16 event mask 0h = Event is masked 1h = Event is unmasked | | | | | | | 15-0 | RESERVED | R/W | 0h | | | | | | | ### 8.3.24 RIS (Offset = 1090h) [Reset = 00000000h] RIS is shown in Figure 8-27 and described in Table 8-27. Return to the Summary Table. Raw interrupt status. Reflects all pending interrupts, regardless of masking. The RIS register allows the user to implement a poll scheme. A flag set in this register can be cleared by writing 1 to the ICLR register bit even if the corresponding IMASK bit is not enabled. Figure 8-27. RIS | riguic o-zr. No | | | | | | | | | | | |-----------------|----------|-------|-------|-------|-------|-------|-------|--|--|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | DIO31 | DIO30 | DIO29 | DIO28 | DIO27 | DIO26 | DIO25 | DIO24 | | | | | R-0h | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | DIO23 | DIO22 | DIO21 | DIO20 | DIO19 | DIO18 | DIO17 | DIO16 | | | | | R-0h | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | | | RESE | RVED | | | | | | | | | | | R- | 0h | | | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | RESERVED | | | | | | | | | | | | | | R- | 0h | | | | | | | | 1 | | | | | | | ı | | | | #### **Table 8-27. RIS Field Descriptions** | Bit | Field | Туре | Reset | Description | |-----|-------|------|-------|----------------------------------------------------------------------------| | 31 | DIO31 | R | 0h | DIO31 event 0h = DIO31 event did not occur 1h = DIO31 event occurred | | 30 | DIO30 | R | 0h | DIO30 event 0h = DIO30 event did not occur 1h = DIO30 event occurred | | 29 | DIO29 | R | 0h | DIO29 event<br>0h = DIO29 event did not occur<br>1h = DIO29 event occurred | | 28 | DIO28 | R | 0h | DIO28 event 0h = DIO28 event did not occur 1h = DIO28 event occurred | | 27 | DIO27 | R | 0h | DIO27 event 0h = DIO27 event did not occur 1h = DIO27 event occurred | | 26 | DIO26 | R | 0h | DIO26 event 0h = DIO26 event did not occur 1h = DIO26 event occurred | | 25 | DIO25 | R | 0h | DIO25 event 0h = DIO25 event did not occur 1h = DIO25 event occurred | | 24 | DIO24 | R | 0h | DIO24 event 0h = DIO24 event did not occur 1h = DIO24 event occurred | | 23 | DIO23 | R | 0h | DIO23 event 0h = DIO23 event did not occur 1h = DIO23 event occurred | | 22 | DIO22 | R | 0h | DIO22 event<br>0h = DIO22 event did not occur<br>1h = DIO22 event occurred | ## **Table 8-27. RIS Field Descriptions (continued)** | | rabio o ziri kio i iola zooonphono (oonanaoa) | | | | | | | | | |------|-----------------------------------------------|------|-------|----------------------------------------------------------------------------|--|--|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | | | 21 | DIO21 | R | 0h | DIO21 event 0h = DIO21 event did not occur 1h = DIO21 event occurred | | | | | | | 20 | DIO20 | R | 0h | DIO20 event<br>0h = DIO20 event did not occur<br>1h = DIO20 event occurred | | | | | | | 19 | DIO19 | R | 0h | DIO19 event 0h = DIO19 event did not occur 1h = DIO19 event occurred | | | | | | | 18 | DIO18 | R | 0h | DIO18 event 0h = DIO18 event did not occur 1h = DIO18 event occurred | | | | | | | 17 | DIO17 | R | 0h | DIO17 event 0h = DIO17 event did not occur 1h = DIO17 event occurred | | | | | | | 16 | DIO16 | R | Oh | DIO16 event 0h = DIO16 event did not occur 1h = DIO16 event occurred | | | | | | | 15-0 | RESERVED | R | 0h | | | | | | | ## 8.3.25 MIS (Offset = 1098h) [Reset = 00000000h] MIS is shown in Figure 8-28 and described in Table 8-28. Return to the Summary Table. Masked interrupt status. This is an AND of the IMASK and RIS registers. ### Figure 8-28. MIS | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | |-------|----------|-------|-------|-------|-------|-------|-------|--|--|--| | DIO31 | DIO30 | DIO29 | DIO28 | DIO27 | DIO26 | DIO25 | DIO24 | | | | | R-0h | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | DIO23 | DIO22 | DIO21 | DIO20 | DIO19 | DIO18 | DIO17 | DIO16 | | | | | R-0h | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | | | RESE | RVED | | | | | | | | | | | R- | 0h | | | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | RESERVED | | | | | | | | | | | | | | R- | 0h | | | | | | | | | | | | | | | | | | | ### Table 8-28. MIS Field Descriptions | Bit | Field | Туре | Reset | Description | |-----|-------|------|-------|----------------------------------------------------------------------------| | 31 | DIO31 | R | 0h | DIO31 event 0h = DIO31 event did not occur 1h = DIO31 event occurred | | 30 | DIO30 | R | 0h | DIO30 event<br>0h = DIO30 event did not occur<br>1h = DIO30 event occurred | | 29 | DIO29 | R | 0h | DIO29 event<br>0h = DIO29 event did not occur<br>1h = DIO29 event occurred | | 28 | DIO28 | R | 0h | DIO28 event 0h = DIO28 event did not occur 1h = DIO28 event occurred | | 27 | DIO27 | R | 0h | DIO27 event 0h = DIO27 event did not occur 1h = DIO27 event occurred | | 26 | DIO26 | R | 0h | DIO26 event 0h = DIO26 event did not occur 1h = DIO26 event occurred | | 25 | DIO25 | R | 0h | DIO25 event 0h = DIO25 event did not occur 1h = DIO25 event occurred | | 24 | DIO24 | R | 0h | DIO24 event<br>0h = DIO24 event did not occur<br>1h = DIO24 event occurred | | 23 | DIO23 | R | 0h | DIO23 event 0h = DIO23 event did not occur 1h = DIO23 event occurred | | 22 | DIO22 | R | 0h | DIO22 event<br>0h = DIO22 event did not occur<br>1h = DIO22 event occurred | ## **Table 8-28. MIS Field Descriptions (continued)** | | Table 0-20. Milo 1 leia Descriptions (continued) | | | | | | | | | |------|--------------------------------------------------|------|-------|----------------------------------------------------------------------------|--|--|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | | | 21 | DIO21 | R | 0h | DIO21 event 0h = DIO21 event did not occur 1h = DIO21 event occurred | | | | | | | 20 | DIO20 | R | 0h | DIO20 event<br>0h = DIO20 event did not occur<br>1h = DIO20 event occurred | | | | | | | 19 | DIO19 | R | 0h | DIO19 event 0h = DIO19 event did not occur 1h = DIO19 event occurred | | | | | | | 18 | DIO18 | R | 0h | DIO18 event 0h = DIO18 event did not occur 1h = DIO18 event occurred | | | | | | | 17 | DIO17 | R | 0h | DIO17 event 0h = DIO17 event did not occur 1h = DIO17 event occurred | | | | | | | 16 | DIO16 | R | 0h | DIO16 event 0h = DIO16 event did not occur 1h = DIO16 event occurred | | | | | | | 15-0 | RESERVED | R | 0h | | | | | | | #### 8.3.26 ISET (Offset = 10A0h) [Reset = 00000000h] ISET is shown in Figure 8-29 and described in Table 8-29. Return to the Summary Table. Interrupt set. Allows interrupts to be set by software (useful in diagnostics and safety checks). Writing a 1 to a bit in ISET will set the event and therefore the related RIS bit also gets set. If the interrupt is enabled through the mask, then the corresponding MIS bit is also set. Figure 8-29. ISET | g v = -ve | | | | | | | | | | | | |-----------|----------|-------|-------|-------|-------|-------|-------|--|--|--|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | | DIO31 | DIO30 | DIO29 | DIO28 | DIO27 | DIO26 | DIO25 | DIO24 | | | | | | W-0h | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | | DIO23 | DIO22 | DIO21 | DIO20 | DIO19 | DIO18 | DIO17 | DIO16 | | | | | | W-0h | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | | | | RESE | RVED | | | | | | | | | | | | W- | ·0h | | | | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | RESERVED | | | | | | | | | | | | | | | W- | ·0h | | | | | | | | #### **Table 8-29. ISET Field Descriptions** | Bit | Field | Туре | Reset | Description | |-----|-------|------|-------|------------------------------------------------------------------| | 31 | DIO31 | W | Oh | DIO31 event<br>0h = No effect<br>1h = Sets DIO31 in RIS register | | 30 | DIO30 | W | 0h | DIO30 event<br>0h = No effect<br>1h = Sets DIO30 in RIS register | | 29 | DIO29 | W | Oh | DIO29 event<br>0h = No effect<br>1h = Sets DIO29 in RIS register | | 28 | DIO28 | W | 0h | DIO28 event 0h = No effect 1h = Sets DIO28 in RIS register | | 27 | DIO27 | W | Oh | DIO27 event 0h = No effect 1h = Sets DIO27 in RIS register | | 26 | DIO26 | W | Oh | DIO26 event 0h = No effect 1h = Sets DIO26 in RIS register | | 25 | DIO25 | W | Oh | DIO25 event 0h = No effect 1h = Sets DIO25 in RIS register | | 24 | DIO24 | W | Oh | DIO24 event<br>0h = No effect<br>1h = Sets DIO24 in RIS register | | 23 | DIO23 | W | Oh | DIO23 event<br>0h = No effect<br>1h = Sets DIO23 in RIS register | | 22 | DIO22 | W | Oh | DIO22 event<br>0h = No effect<br>1h = Sets DIO22 in RIS register | # Table 8-29. ISET Field Descriptions (continued) | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|------------------------------------------------------------------| | 21 | DIO21 | W | Oh | DIO21 event 0h = No effect 1h = Sets DIO21 in RIS register | | 20 | DIO20 | W | 0h | DIO20 event<br>0h = No effect<br>1h = Sets DIO20 in RIS register | | 19 | DIO19 | W | 0h | DIO19 event 0h = No effect 1h = Sets DIO19 in RIS register | | 18 | DIO18 | W | Oh | DIO18 event 0h = No effect 1h = Sets DIO18 in RIS register | | 17 | DIO17 | W | Oh | DIO17 event 0h = No effect 1h = Sets DIO17 in RIS register | | 16 | DIO16 | W | Oh | DIO16 event<br>0h = No effect<br>1h = Sets DIO16 in RIS register | | 15-0 | RESERVED | W | 0h | | ## 8.3.27 ICLR (Offset = 10A8h) [Reset = 00000000h] ICLR is shown in Figure 8-30 and described in Table 8-30. Return to the Summary Table. Interrupt clear. Write a 1 to clear corresponding Interrupt. ## Figure 8-30. ICLR | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | |-------|----------|-------|-------|-------|-------|-------|-------|--|--|--|--| | DIO31 | DIO30 | DIO29 | DIO28 | DIO27 | DIO26 | DIO25 | DIO24 | | | | | | W-0h | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | | DIO23 | DIO22 | DIO21 | DIO20 | DIO19 | DIO18 | DIO17 | DIO16 | | | | | | W-0h | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | | | | RESE | RVED | | | | | | | | | | | | W- | ·0h | | | | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | RESERVED | | | | | | | | | | | | | W-0h | | | | | | | | | | | #### Table 8-30. ICLR Field Descriptions | | | | | . 1014 20001 [p.1010 | |-----|-------|------|-------|--------------------------------------------------------------| | Bit | Field | Туре | Reset | Description | | 31 | DIO31 | W | Oh | DIO31 event 0h = No effect 1h = Clears DIO31 in RIS register | | 30 | DIO30 | W | 0h | DIO30 event 0h = No effect 1h = Clears DIO30 in RIS register | | 29 | DIO29 | W | Oh | DIO29 event 0h = No effect 1h = Clears DIO29 in RIS register | | 28 | DIO28 | W | Oh | DIO28 event 0h = No effect 1h = Clears DIO28 in RIS register | | 27 | DIO27 | W | Oh | DIO27 event 0h = No effect 1h = Clears DIO27 in RIS register | | 26 | DIO26 | W | Oh | DIO26 event 0h = No effect 1h = Clears DIO26 in RIS register | | 25 | DIO25 | W | Oh | DIO25 event 0h = No effect 1h = Clears DIO25 in RIS register | | 24 | DIO24 | W | Oh | DIO24 event 0h = No effect 1h = Clears DIO24 in RIS register | | 23 | DIO23 | W | Oh | DIO23 event 0h = No effect 1h = Clears DIO23 in RIS register | | 22 | DIO22 | W | Oh | DIO22 event 0h = No effect 1h = Clears DIO22 in RIS register | ## Table 8-30. ICLR Field Descriptions (continued) | table of the letter lota becompared (continued) | | | | | | | | | |-------------------------------------------------|----------|------|-------|--------------------------------------------------------------|--|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | | 21 | DIO21 | W | 0h | DIO21 event 0h = No effect 1h = Clears DIO21 in RIS register | | | | | | 20 | DIO20 | W | 0h | DIO20 event 0h = No effect 1h = Clears DIO20 in RIS register | | | | | | 19 | DIO19 | W | 0h | DIO19 event 0h = No effect 1h = Clears DIO19 in RIS register | | | | | | 18 | DIO18 | W | 0h | DIO18 event 0h = No effect 1h = Clears DIO18 in RIS register | | | | | | 17 | DIO17 | W | 0h | DIO17 event 0h = No effect 1h = Clears DIO17 in RIS register | | | | | | 16 | DIO16 | W | 0h | DIO16 event 0h = No effect 1h = Clears DIO16 in RIS register | | | | | | 15-0 | RESERVED | W | 0h | | | | | | ## 8.3.28 EVT\_MODE (Offset = 10E0h) [Reset = 00000029h] EVT\_MODE is shown in Figure 8-31 and described in Table 8-31. Return to the Summary Table. Event mode register. It is used to select whether each line is disabled, in software mode (software clears the RIS) or in hardware mode (hardware clears the RIS) Figure 8-31. EVT\_MODE ## Table 8-31. EVT\_MODE Field Descriptions | | Table 0-31. EVI_MODE Field Descriptions | | | | | | | | | |------|-----------------------------------------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | | | 31-6 | RESERVED | R/W | 0h | | | | | | | | 5-4 | EVT2_CFG | R | 2h | Event line mode select for event corresponding to none.GEN_EVENT1 0h = The interrupt or event line is disabled. 1h = The interrupt or event line is in software mode. Software must clear the RIS. 2h = The interrupt or event line is in hardware mode. The hardware (another module) clears automatically the associated RIS flag. | | | | | | | 3-2 | EVT1_CFG | R | 2h | Event line mode select for event corresponding to none.GEN_EVENT0 0h = The interrupt or event line is disabled. 1h = The interrupt or event line is in software mode. Software must clear the RIS. 2h = The interrupt or event line is in hardware mode. The hardware (another module) clears automatically the associated RIS flag. | | | | | | | 1-0 | INT0_CFG | R | 1h | Event line mode select for event corresponding to none.CPU_INT 0h = The interrupt or event line is disabled. 1h = The interrupt or event line is in software mode. Software must clear the RIS. 2h = The interrupt or event line is in hardware mode. The hardware (another module) clears automatically the associated RIS flag. | | | | | | ## 8.3.29 DESC (Offset = 10FCh) [Reset = 16110000h] DESC is shown in Figure 8-32 and described in Table 8-32. Return to the Summary Table. This register identifies the peripheral and its exact version. #### Figure 8-32. DESC #### Table 8-32. DESC Field Descriptions | | 14510 0 02. 5200 1 1014 5000 1 ption0 | | | | | | | | |-------|---------------------------------------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | | 31-16 | MODULEID | R | 1611h | Module identification contains a unique peripheral identification number. The assignments are maintained in a central database for all of the platform modules to ensure uniqueness. 0h = Smallest value FFFFh = Highest possible value | | | | | | 15-12 | FEATUREVER | R | 0h | Feature Set for the module *instance* 0h = Smallest value Fh = Highest possible value | | | | | | 11-8 | RESERVED | R | 0h | | | | | | | 7-4 | MAJREV | R | 0h | Major rev of the IP 0h = Smallest value Fh = Highest possible value | | | | | | 3-0 | MINREV | R | 0h | Minor rev of the IP 0h = Smallest value Fh = Highest possible value | | | | | ## 8.3.30 DOUT3\_0 (Offset = 1200h) [Reset = 00000000h] DOUT3\_0 is shown in Figure 8-33 and described in Table 8-33. Return to the Summary Table. Data output for pins configured as DIO3 to DIO0. This is an alias register for byte access to bits 3 to 0 in DOUT31\_0 register. Figure 8-33. DOUT3 0 | Figure 6-33. DO013_0 | | | | | | | | | | | |----------------------|----|----|----------|----|----|----|------|--|--|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | | | | RESERVED | | | | DIO3 | | | | | | | | W-0h | | | | W-0h | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | | | | RESERVED | | | | DIO2 | | | | | | | | W-0h | | | | W-0h | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | | | RESERVED | | | | DIO1 | | | | | | | | W-0h | | | | W-0h | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | RESERVED | | | | DIO0 | | | | | | | | W-0h | | | | W-0h | | | | ## Table 8-33. DOUT3\_0 Field Descriptions | Bit | Field | Туре | Reset | Description | | | |-------|----------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | 31-25 | RESERVED | W | 0h | | | | | 24 | DIO3 | W | 0h | This bit sets the value of the pin configured as DIO3 when the outp is enabled through DOE31_0 register. Oh = Output is set to 0 1h = Output is set to 1 | | | | 23-17 | RESERVED | W | 0h | | | | | 16 | DIO2 | W | 0h | This bit sets the value of the pin configured as DIO2 when the output is enabled through DOE31_0 register. 0h = Output is set to 0 1h = Output is set to 1 | | | | 15-9 | RESERVED | W | 0h | | | | | 8 | DIO1 | W | 0h | This bit sets the value of the pin configured as DIO1 when the output is enabled through DOE31_0 register. 0h = Output is set to 0 1h = Output is set to 1 | | | | 7-1 | RESERVED | W | 0h | | | | | 0 | DIO0 | W | 0h | This bit sets the value of the pin configured as DIO0 when the output is enabled through DOE31_0 register. 0h = Output is set to 0 1h = Output is set to 1 | | | #### 8.3.31 DOUT7\_4 (Offset = 1204h) [Reset = 00000000h] DOUT7\_4 is shown in Figure 8-34 and described in Table 8-34. Return to the Summary Table. Data output for pins configured as DIO7 to DIO4. This is an alias register for byte access to bits 7 to 4 in DOUT31\_0 register. Figure 8-34. DOUT7 4 | | | | i iguie o-o- | . DOO 17_ <del>-</del> | | | | |----|----|----|--------------|------------------------|----|----|------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | RESERVED | | | | DIO7 | | | | | W-0h | | | | W-0h | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | RESERVED | | | | DIO6 | | | | | W-0h | | | | W-0h | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | RESERVED | | | | DIO5 | | | | | W-0h | | | | W-0h | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | RESERVED | | | | DIO4 | | | | | W-0h | | | | W-0h | #### Table 8-34. DOUT7\_4 Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-25 | RESERVED | W | 0h | | | 24 | DIO7 | W | 0h | This bit sets the value of the pin configured as DIO7 when the output is enabled through DOE31_0 register. 0h = Output is set to 0 1h = Output is set to 1 | | 23-17 | RESERVED | W | 0h | | | 16 | DIO6 | W | 0h | This bit sets the value of the pin configured as DIO6 when the output is enabled through DOE31_0 register. 0h = Output is set to 0 1h = Output is set to 1 | | 15-9 | RESERVED | W | 0h | | | 8 | DIO5 | W | 0h | This bit sets the value of the pin configured as DIO5 when the output is enabled through DOE31_0 register. 0h = Output is set to 0 1h = Output is set to 1 | | 7-1 | RESERVED | W | 0h | | | 0 | DIO4 | W | 0h | This bit sets the value of the pin configured as DIO4 when the output is enabled through DOE31_0 register. 0h = Output is set to 0 1h = Output is set to 1 | ## 8.3.32 DOUT11\_8 (Offset = 1208h) [Reset = 00000000h] DOUT11\_8 is shown in Figure 8-35 and described in Table 8-35. Return to the Summary Table. Data output for pins configured as DIO11 to DIO8. This is an alias register for byte access to bits 11 to 8 in DOUT31\_0 register. Figure 8-35. DOUT11 8 | | | | i igule 0-33. | DO0111_0 | | | | |----|----|----|---------------|----------|----|----|-------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | RESERVED | | | | DIO11 | | | | | W-0h | | | | W-0h | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | RESERVED | | | | DIO10 | | | | | W-0h | | | | W-0h | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | RESERVED | | | | DIO9 | | | | | W-0h | | | | W-0h | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | RESERVED | | | | DIO8 | | | | | W-0h | | | | W-0h | Table 8-35. DOUT11\_8 Field Descriptions | Table Cost Boot II _ o Tista Booth phone | | | | | | | | | |------------------------------------------|----------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | | 31-25 | RESERVED | W | 0h | | | | | | | 24 | DIO11 | W | 0h | This bit sets the value of the pin configured as DIO11 when the output is enabled through DOE31_0 register. 0h = Output is set to 0 1h = Output is set to 1 | | | | | | 23-17 | RESERVED | W | 0h | | | | | | | 16 | DIO10 | W | 0h | This bit sets the value of the pin configured as DIO10 when the output is enabled through DOE31_0 register. 0h = Output is set to 0 1h = Output is set to 1 | | | | | | 15-9 | RESERVED | W | 0h | | | | | | | 8 | DIO9 | W | 0h | This bit sets the value of the pin configured as DIO9 when the output is enabled through DOE31_0 register. 0h = Output is set to 0 1h = Output is set to 1 | | | | | | 7-1 | RESERVED | W | 0h | | | | | | | 0 | DIO8 | W | 0h | This bit sets the value of the pin configured as DIO8 when the output is enabled through DOE31_0 register. 0h = Output is set to 0 1h = Output is set to 1 | | | | | ## 8.3.33 DOUT15\_12 (Offset = 120Ch) [Reset = 00000000h] DOUT15\_12 is shown in Figure 8-36 and described in Table 8-36. Return to the Summary Table. Data output for pins configured as DIO15 to DIO12. This is an alias register for byte access to bits 15 to 12 in DOUT31\_0 register. Figure 8-36. DOUT15 12 | | | | rigule 0-30. | 000113_12 | | | | |----|----|----|--------------|-----------|----|----|-------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | RESERVED | | | | DIO15 | | | | | W-0h | | | | W-0h | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | RESERVED | | | | DIO14 | | | | | W-0h | | | | W-0h | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | RESERVED | | | | DIO13 | | | | | W-0h | | | | W-0h | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | RESERVED | | | | DIO12 | | | | | W-0h | | | | W-0h | ## Table 8-36. DOUT15\_12 Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-25 | RESERVED | W | 0h | | | 24 | DIO15 | W | 0h | This bit sets the value of the pin configured as DIO15 when the output is enabled through DOE31_0 register. 0h = Output is set to 0 1h = Output is set to 1 | | 23-17 | RESERVED | W | 0h | | | 16 | DIO14 | W | 0h | This bit sets the value of the pin configured as DIO14 when the output is enabled through DOE31_0 register. 0h = Output is set to 0 1h = Output is set to 1 | | 15-9 | RESERVED | W | 0h | | | 8 | DIO13 | W | 0h | This bit sets the value of the pin configured as DIO13 when the output is enabled through DOE31_0 register. 0h = Output is set to 0 1h = Output is set to 1 | | 7-1 | RESERVED | W | 0h | | | 0 | DIO12 | W | 0h | This bit sets the value of the pin configured as DIO12 when the output is enabled through DOE31_0 register. 0h = Output is set to 0 1h = Output is set to 1 | ## 8.3.34 DOUT19\_16 (Offset = 1210h) [Reset = 00000000h] DOUT19\_16 is shown in Figure 8-37 and described in Table 8-37. Return to the Summary Table. Data output for pins configured as DIO19 to DIO16. This is an alias register for byte access to bits 19 to 16 in DOUT31\_0 register. Figure 8-37. DOUT19 16 | | | | rigule 6-37. | | | | | |----|----|----|--------------|----|----|----|-------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | RESERVED | | | | DIO19 | | | | | W-0h | | | | W-0h | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | RESERVED | | | | DIO18 | | | | | W-0h | | | | W-0h | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | RESERVED | | | | DIO17 | | | | | W-0h | | | | W-0h | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | RESERVED | | | | DIO16 | | | | | W-0h | | | | W-0h | #### Table 8-37. DOUT19\_16 Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-25 | RESERVED | W | 0h | | | 24 | DIO19 | W | 0h | This bit sets the value of the pin configured as DIO19 when the output is enabled through DOE31_0 register. 0h = Output is set to 0 1h = Output is set to 1 | | 23-17 | RESERVED | W | 0h | | | 16 | DIO18 | W | 0h | This bit sets the value of the pin configured as DIO18 when the output is enabled through DOE31_0 register. 0h = Output is set to 0 1h = Output is set to 1 | | 15-9 | RESERVED | W | 0h | | | 8 | DIO17 | W | 0h | This bit sets the value of the pin configured as DIO17 when the output is enabled through DOE31_0 register. 0h = Output is set to 0 1h = Output is set to 1 | | 7-1 | RESERVED | W | 0h | | | 0 | DIO16 | W | 0h | This bit sets the value of the pin configured as DIO16 when the output is enabled through DOE31_0 register. 0h = Output is set to 0 1h = Output is set to 1 | ## 8.3.35 DOUT23\_20 (Offset = 1214h) [Reset = 00000000h] DOUT23\_20 is shown in Figure 8-38 and described in Table 8-38. Return to the Summary Table. Data output for pins configured as DIO23 to DIO20. This is an alias register for byte access to bits 23 to 20 in DOUT31\_0 register. Figure 8-38. DOUT23 20 | | | | rigare o oo. | 500.20_20 | | | | |----|----|----|--------------|-----------|----|----|-------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | RESERVED | | | | DIO23 | | | | | W-0h | | | | W-0h | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | RESERVED | | | | DIO22 | | | | | W-0h | | | | W-0h | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | RESERVED | | | | DIO21 | | | | | W-0h | | | | W-0h | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | RESERVED | | | | DIO20 | | | | | W-0h | | | | W-0h | | | | | | | | | | #### Table 8-38. DOUT23\_20 Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-25 | RESERVED | W | 0h | | | 24 | DIO23 | W | Oh | This bit sets the value of the pin configured as DIO23 when the output is enabled through DOE31_0 register. 0h = Output is set to 0 1h = Output is set to 1 | | 23-17 | RESERVED | W | 0h | | | 16 | DIO22 | W | Oh | This bit sets the value of the pin configured as DIO22 when the output is enabled through DOE31_0 register. 0h = Output is set to 0 1h = Output is set to 1 | | 15-9 | RESERVED | W | 0h | | | 8 | DIO21 | W | Oh | This bit sets the value of the pin configured as DIO21 when the output is enabled through DOE31_0 register. 0h = Output is set to 0 1h = Output is set to 1 | | 7-1 | RESERVED | W | 0h | | | 0 | DIO20 | W | Oh | This bit sets the value of the pin configured as DIO20 when the output is enabled through DOE31_0 register. 0h = Output is set to 0 1h = Output is set to 1 | #### 8.3.36 DOUT27\_24 (Offset = 1218h) [Reset = 00000000h] DOUT27\_24 is shown in Figure 8-39 and described in Table 8-39. Return to the Summary Table. Data output for pins configured as DIO27 to DIO24. This is an alias register for byte access to bits 27 to 24 in DOUT31\_0 register. Figure 8-39. DOUT27 24 | | | | rigule 0-39. | DO0121_24 | | | | |----|----|----|--------------|-----------|----|----|-------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | RESERVED | | | | DIO27 | | | | | W-0h | | | | W-0h | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | RESERVED | | | | DIO26 | | | | | W-0h | | | | W-0h | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | RESERVED | | | | DIO25 | | | | | W-0h | | | | W-0h | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | RESERVED | | | | DIO24 | | | | | W-0h | | | | W-0h | #### Table 8-39. DOUT27\_24 Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-25 | RESERVED | W | 0h | | | 24 | DIO27 | W | 0h | This bit sets the value of the pin configured as DIO27 when the output is enabled through DOE31_0 register. 0h = Output is set to 0 1h = Output is set to 1 | | 23-17 | RESERVED | W | 0h | | | 16 | DIO26 | W | 0h | This bit sets the value of the pin configured as DIO26 when the output is enabled through DOE31_0 register. 0h = Output is set to 0 1h = Output is set to 1 | | 15-9 | RESERVED | W | 0h | | | 8 | DIO25 | W | 0h | This bit sets the value of the pin configured as DIO25 when the output is enabled through DOE31_0 register. 0h = Output is set to 0 1h = Output is set to 1 | | 7-1 | RESERVED | W | 0h | | | 0 | DIO24 | W | 0h | This bit sets the value of the pin configured as DIO24 when the output is enabled through DOE31_0 register. 0h = Output is set to 0 1h = Output is set to 1 | ## 8.3.37 DOUT31\_28 (Offset = 121Ch) [Reset = 00000000h] DOUT31\_28 is shown in Figure 8-40 and described in Table 8-40. Return to the Summary Table. Data output for pins configured as DIO31 to DIO28. This is an alias register for byte access to bits 31 to 28 in DOUT31\_0 register. Figure 8-40. DOUT31 28 | | | | rigule 6-40. i | 000131_28 | | | | |----|----|----|----------------|-----------|----|----|-------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | RESERVED | | | | DIO31 | | | | | W-0h | | | | W-0h | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | RESERVED | | | | DIO30 | | | | | W-0h | | | | W-0h | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | RESERVED | | | | DIO29 | | | | | W-0h | | | | W-0h | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | RESERVED | | | | DIO28 | | | | | W-0h | | | | W-0h | #### Table 8-40. DOUT31\_28 Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-25 | RESERVED | W | 0h | | | 24 | DIO31 | W | 0h | This bit sets the value of the pin configured as DIO31 when the output is enabled through DOE31_0 register. 0h = Output is set to 0 1h = Output is set to 1 | | 23-17 | RESERVED | W | 0h | | | 16 | DIO30 | W | 0h | This bit sets the value of the pin configured as DIO30 when the output is enabled through DOE31_0 register. 0h = Output is set to 0 1h = Output is set to 1 | | 15-9 | RESERVED | W | 0h | | | 8 | DIO29 | W | 0h | This bit sets the value of the pin configured as DIO29 when the output is enabled through DOE31_0 register. 0h = Output is set to 0 1h = Output is set to 1 | | 7-1 | RESERVED | W | 0h | | | 0 | DIO28 | W | 0h | This bit sets the value of the pin configured as DIO28 when the output is enabled through DOE31_0 register. 0h = Output is set to 0 1h = Output is set to 1 | ## 8.3.38 DOUT31\_0 (Offset = 1280h) [Reset = 00000000h] DOUT31\_0 is shown in Figure 8-41 and described in Table 8-41. Return to the Summary Table. Data output for pins configured as DIO31 to DIO0. ## Figure 8-41. DOUT31\_0 | | | | J | _ | | | | |--------|--------|--------|--------|--------|--------|--------|--------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | DIO31 | DIO30 | DIO29 | DIO28 | DIO27 | DIO26 | DIO25 | DIO24 | | R/W-0h | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | DIO23 | DIO22 | DIO21 | DIO20 | DIO19 | DIO18 | DIO17 | DIO16 | | R/W-0h | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | DIO15 | DIO14 | DIO13 | DIO12 | DIO11 | DIO10 | DIO9 | DIO8 | | R/W-0h | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | DIO7 | DIO6 | DIO5 | DIO4 | DIO3 | DIO2 | DIO1 | DIO0 | | R/W-0h ## Table 8-41. DOUT31\_0 Field Descriptions | Bit | Field | Туре | Reset | Description | |-----|-------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 | DIO31 | R/W | 0h | This bit sets the value of the pin configured as DIO31 when the output is enabled through DOE31_0 register. 0h = Output is set to 0 1h = Output is set to 1 | | 30 | DIO30 | R/W | 0h | This bit sets the value of the pin configured as DIO30 when the output is enabled through DOE31_0 register. 0h = Output is set to 0 1h = Output is set to 1 | | 29 | DIO29 | R/W | 0h | This bit sets the value of the pin configured as DIO29 when the output is enabled through DOE31_0 register. 0h = Output is set to 0 1h = Output is set to 1 | | 28 | DIO28 | R/W | 0h | This bit sets the value of the pin configured as DIO28 when the output is enabled through DOE31_0 register. 0h = Output is set to 0 1h = Output is set to 1 | | 27 | DIO27 | R/W | 0h | This bit sets the value of the pin configured as DIO27 when the output is enabled through DOE31_0 register. 0h = Output is set to 0 1h = Output is set to 1 | | 26 | DIO26 | R/W | 0h | This bit sets the value of the pin configured as DIO26 when the output is enabled through DOE31_0 register. 0h = Output is set to 0 1h = Output is set to 1 | | 25 | DIO25 | R/W | 0h | This bit sets the value of the pin configured as DIO25 when the output is enabled through DOE31_0 register. 0h = Output is set to 0 1h = Output is set to 1 | | 24 | DIO24 | R/W | 0h | This bit sets the value of the pin configured as DIO24 when the output is enabled through DOE31_0 register. 0h = Output is set to 0 1h = Output is set to 1 | ## Table 8-41. DOUT31\_0 Field Descriptions (continued) | Bit | Field | Туре | Reset | Description (continued) | |-----|-------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------| | 23 | DIO23 | R/W | Oh | This bit sets the value of the pin configured as DIO23 when the output is enabled through DOE31_0 register. 0h = Output is set to 0 1h = Output is set to 1 | | 22 | DIO22 | R/W | Oh | This bit sets the value of the pin configured as DIO22 when the output is enabled through DOE31_0 register. 0h = Output is set to 0 1h = Output is set to 1 | | 21 | DIO21 | R/W | 0h | This bit sets the value of the pin configured as DIO21 when the output is enabled through DOE31_0 register. 0h = Output is set to 0 1h = Output is set to 1 | | 20 | DIO20 | R/W | Oh | This bit sets the value of the pin configured as DIO20 when the output is enabled through DOE31_0 register. 0h = Output is set to 0 1h = Output is set to 1 | | 19 | DIO19 | R/W | Oh | This bit sets the value of the pin configured as DIO19 when the output is enabled through DOE31_0 register. 0h = Output is set to 0 1h = Output is set to 1 | | 18 | DIO18 | R/W | Oh | This bit sets the value of the pin configured as DIO18 when the output is enabled through DOE31_0 register. 0h = Output is set to 0 1h = Output is set to 1 | | 17 | DIO17 | R/W | 0h | This bit sets the value of the pin configured as DIO17 when the output is enabled through DOE31_0 register. 0h = Output is set to 0 1h = Output is set to 1 | | 16 | DIO16 | R/W | 0h | This bit sets the value of the pin configured as DIO16 when the output is enabled through DOE31_0 register. 0h = Output is set to 0 1h = Output is set to 1 | | 15 | DIO15 | R/W | 0h | This bit sets the value of the pin configured as DIO15 when the output is enabled through DOE31_0 register. 0h = Output is set to 0 1h = Output is set to 1 | | 14 | DIO14 | R/W | 0h | This bit sets the value of the pin configured as DIO14 when the output is enabled through DOE31_0 register. 0h = Output is set to 0 1h = Output is set to 1 | | 13 | DIO13 | R/W | 0h | This bit sets the value of the pin configured as DIO13 when the output is enabled through DOE31_0 register. 0h = Output is set to 0 1h = Output is set to 1 | | 12 | DIO12 | R/W | 0h | This bit sets the value of the pin configured as DIO12 when the output is enabled through DOE31_0 register. 0h = Output is set to 0 1h = Output is set to 1 | | 11 | DIO11 | R/W | 0h | This bit sets the value of the pin configured as DIO11 when the output is enabled through DOE31_0 register. 0h = Output is set to 0 1h = Output is set to 1 | | 10 | DIO10 | R/W | 0h | This bit sets the value of the pin configured as DIO10 when the output is enabled through DOE31_0 register. 0h = Output is set to 0 1h = Output is set to 1 | ## Table 8-41. DOUT31\_0 Field Descriptions (continued) | Bit | Field | Type | Reset | Description (Continued) | |-----|-------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------| | 9 | DIO9 | R/W | Oh | This bit sets the value of the pin configured as DIO9 when the output is enabled through DOE31_0 register. 0h = Output is set to 0 1h = Output is set to 1 | | 8 | DIO8 | R/W | 0h | This bit sets the value of the pin configured as DIO8 when the output is enabled through DOE31_0 register. 0h = Output is set to 0 1h = Output is set to 1 | | 7 | DIO7 | R/W | 0h | This bit sets the value of the pin configured as DIO7 when the output is enabled through DOE31_0 register. 0h = Output is set to 0 1h = Output is set to 1 | | 6 | DIO6 | R/W | 0h | This bit sets the value of the pin configured as DIO6 when the output is enabled through DOE31_0 register. 0h = Output is set to 0 1h = Output is set to 1 | | 5 | DIO5 | R/W | 0h | This bit sets the value of the pin configured as DIO5 when the output is enabled through DOE31_0 register. 0h = Output is set to 0 1h = Output is set to 1 | | 4 | DIO4 | R/W | 0h | This bit sets the value of the pin configured as DIO4 when the output is enabled through DOE31_0 register. 0h = Output is set to 0 1h = Output is set to 1 | | 3 | DIO3 | R/W | 0h | This bit sets the value of the pin configured as DIO3 when the output is enabled through DOE31_0 register. 0h = Output is set to 0 1h = Output is set to 1 | | 2 | DIO2 | R/W | 0h | This bit sets the value of the pin configured as DIO2 when the output is enabled through DOE31_0 register. 0h = Output is set to 0 1h = Output is set to 1 | | 1 | DIO1 | R/W | 0h | This bit sets the value of the pin configured as DIO1 when the output is enabled through DOE31_0 register. 0h = Output is set to 0 1h = Output is set to 1 | | 0 | DIO0 | R/W | 0h | This bit sets the value of the pin configured as DIO0 when the output is enabled through DOE31_0 register. 0h = Output is set to 0 1h = Output is set to 1 | ## 8.3.39 DOUTSET31\_0 (Offset = 1290h) [Reset = 00000000h] DOUTSET31\_0 is shown in Figure 8-42 and described in Table 8-42. Return to the Summary Table. Writing 1 to a bit position in this register sets the corresponding bit in the DOUT31\_0 register. ## Figure 8-42. DOUTSET31\_0 | | | | J | _ · · · _ · | | | | |-------|-------|-------|-------|-------------|-------|-------|-------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | DIO31 | DIO30 | DIO29 | DIO28 | DIO27 | DIO26 | DIO25 | DIO24 | | W-0h | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | DIO23 | DIO22 | DIO21 | DIO20 | DIO19 | DIO18 | DIO17 | DIO16 | | W-0h | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | DIO15 | DIO14 | DIO13 | DIO12 | DIO11 | DIO10 | DIO9 | DIO8 | | W-0h | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | DIO7 | DIO6 | DIO5 | DIO4 | DIO3 | DIO2 | DIO1 | DIO0 | | W-0h | | | | | | | | | #### Table 8-42. DOUTSET31\_0 Field Descriptions | Bit | Field | Туре | Reset | Description | |-----|-------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------| | 31 | DIO31 | W | Oh | Writing 1 to this bit sets the DIO31 bit in the DOUT31_0 register. Writing 0 has no effect. 0h = No effect 1h = Sets DIO31 in DOUT31_0 | | 30 | DIO30 | W | Oh | Writing 1 to this bit sets the DIO30 bit in the DOUT31_0 register. Writing 0 has no effect. 0h = No effect 1h = Sets DIO30 in DOUT31_0 | | 29 | DIO29 | W | Oh | Writing 1 to this bit sets the DIO29 bit in the DOUT31_0 register. Writing 0 has no effect. 0h = No effect 1h = Sets DIO29 in DOUT31_0 | | 28 | DIO28 | W | Oh | Writing 1 to this bit sets the DIO28 bit in the DOUT31_0 register. Writing 0 has no effect. 0h = No effect 1h = Sets DIO28 in DOUT31_0 | | 27 | DIO27 | W | Oh | Writing 1 to this bit sets the DIO27 bit in the DOUT31_0 register. Writing 0 has no effect. 0h = No effect 1h = Sets DIO27 in DOUT31_0 | | 26 | DIO26 | W | Oh | Writing 1 to this bit sets the DIO26 bit in the DOUT31_0 register. Writing 0 has no effect. 0h = No effect 1h = Sets DIO26 in DOUT31_0 | | 25 | DIO25 | W | Oh | Writing 1 to this bit sets the DIO25 bit in the DOUT31_0 register. Writing 0 has no effect. 0h = No effect 1h = Sets DIO25 in DOUT31_0 | | 24 | DIO24 | W | Oh | Writing 1 to this bit sets the DIO24 bit in the DOUT31_0 register. Writing 0 has no effect. 0h = No effect 1h = Sets DIO24 in DOUT31_0 | ## Table 8-42. DOUTSET31\_0 Field Descriptions (continued) | Bit | Field | Type | Reset | Description (continued) | |-----|-------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------| | 23 | DIO23 | W | 0h | Writing 1 to this bit sets the DIO23 bit in the DOUT31_0 register. Writing 0 has no effect. 0h = No effect 1h = Sets DIO23 in DOUT31_0 | | 22 | DIO22 | W | Oh | Writing 1 to this bit sets the DIO22 bit in the DOUT31_0 register. Writing 0 has no effect. 0h = No effect 1h = Sets DIO22 in DOUT31_0 | | 21 | DIO21 | W | Oh | Writing 1 to this bit sets the DIO21 bit in the DOUT31_0 register. Writing 0 has no effect. 0h = No effect 1h = Sets DIO21 in DOUT31_0 | | 20 | DIO20 | W | Oh | Writing 1 to this bit sets the DIO20 bit in the DOUT31_0 register. Writing 0 has no effect. 0h = No effect 1h = Sets DIO20 in DOUT31_0 | | 19 | DIO19 | W | Oh | Writing 1 to this bit sets the DIO19 bit in the DOUT31_0 register. Writing 0 has no effect. 0h = No effect 1h = Sets DIO19 in DOUT31_0 | | 18 | DIO18 | W | Oh | Writing 1 to this bit sets the DIO18 bit in the DOUT31_0 register. Writing 0 has no effect. 0h = No effect 1h = Sets DIO18 in DOUT31_0 | | 17 | DIO17 | W | Oh | Writing 1 to this bit sets the DIO17 bit in the DOUT31_0 register. Writing 0 has no effect. 0h = No effect 1h = Sets DIO17 in DOUT31_0 | | 16 | DIO16 | W | Oh | Writing 1 to this bit sets the DIO16 bit in the DOUT31_0 register. Writing 0 has no effect. 0h = No effect 1h = Sets DIO16 in DOUT31_0 | | 15 | DIO15 | W | Oh | Writing 1 to this bit sets the DIO15 bit in the DOUT31_0 register. Writing 0 has no effect. 0h = No effect 1h = Sets DIO15 in DOUT31_0 | | 14 | DIO14 | W | Oh | Writing 1 to this bit sets the DIO14 bit in the DOUT31_0 register. Writing 0 has no effect. 0h = No effect 1h = Sets DIO14 in DOUT31_0 | | 13 | DIO13 | W | Oh | Writing 1 to this bit sets the DIO13 bit in the DOUT31_0 register. Writing 0 has no effect. 0h = No effect 1h = Sets DIO13 in DOUT31_0 | | 12 | DIO12 | W | Oh | Writing 1 to this bit sets the DIO12 bit in the DOUT31_0 register. Writing 0 has no effect. 0h = No effect 1h = Sets DIO12 in DOUT31_0 | | 11 | DIO11 | W | Oh | Writing 1 to this bit sets the DIO11 bit in the DOUT31_0 register. Writing 0 has no effect. 0h = No effect 1h = Sets DIO11 in DOUT31_0 | | 10 | DIO10 | W | 0h | Writing 1 to this bit sets the DIO10 bit in the DOUT31_0 register. Writing 0 has no effect. 0h = No effect 1h = Sets DIO10 in DOUT31_0 | # Table 8-42. DOUTSET31\_0 Field Descriptions (continued) | Bit | Field | Type | Reset | Description (continued) | |-----|-------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------| | 9 | DIO9 | W | 0h | Writing 1 to this bit sets the DIO9 bit in the DOUT31_0 register. Writing 0 has no effect. 0h = No effect 1h = Sets DIO9 in DOUT31_0 | | 8 | DIO8 | W | 0h | Writing 1 to this bit sets the DIO8 bit in the DOUT31_0 register. Writing 0 has no effect. 0h = No effect 1h = Sets DIO8 in DOUT31_0 | | 7 | DIO7 | W | 0h | Writing 1 to this bit sets the DIO7 bit in the DOUT31_0 register. Writing 0 has no effect. 0h = No effect 1h = Sets DIO7 in DOUT31_0 | | 6 | DIO6 | W | 0h | Writing 1 to this bit sets the DIO6 bit in the DOUT31_0 register. Writing 0 has no effect. 0h = No effect 1h = Sets DIO6 in DOUT31_0 | | 5 | DIO5 | W | 0h | Writing 1 to this bit sets the DIO5 bit in the DOUT31_0 register. Writing 0 has no effect. 0h = No effect 1h = Sets DIO5 in DOUT31_0 | | 4 | DIO4 | W | 0h | Writing 1 to this bit sets the DIO4 bit in the DOUT31_0 register. Writing 0 has no effect. 0h = No effect 1h = Sets DIO4 in DOUT31_0 | | 3 | DIO3 | W | 0h | Writing 1 to this bit sets the DIO3 bit in the DOUT31_0 register. Writing 0 has no effect. 0h = No effect 1h = Sets DIO3 in DOUT31_0 | | 2 | DIO2 | W | 0h | Writing 1 to this bit sets the DIO2 bit in the DOUT31_0 register. Writing 0 has no effect. 0h = No effect 1h = Sets DIO2 in DOUT31_0 | | 1 | DIO1 | W | 0h | Writing 1 to this bit sets the DIO1 bit in the DOUT31_0 register. Writing 0 has no effect. 0h = No effect 1h = Sets DIO1 in DOUT31_0 | | 0 | DIO0 | W | 0h | Writing 1 to this bit sets the DIO0 bit in the DOUT31_0 register. Writing 0 has no effect. 0h = No effect 1h = Sets DIO0 in DOUT31_0 | ## 8.3.40 DOUTCLR31\_0 (Offset = 12A0h) [Reset = 00000000h] DOUTCLR31\_0 is shown in Figure 8-43 and described in Table 8-43. Return to the Summary Table. Writing 1 to a bit position in this register clears the corresponding bit in the DOUT31\_0 register. ## Figure 8-43. DOUTCLR31\_0 | | | | • | _ | | | | |-------|-------|-------|-------|-------|-------|-------|-------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | DIO31 | DIO30 | DIO29 | DIO28 | DIO27 | DIO26 | DIO25 | DIO24 | | W-0h | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | DIO23 | DIO22 | DIO21 | DIO20 | DIO19 | DIO18 | DIO17 | DIO16 | | W-0h | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | DIO15 | DIO14 | DIO13 | DIO12 | DIO11 | DIO10 | DIO9 | DIO8 | | W-0h | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | DIO7 | DIO6 | DIO5 | DIO4 | DIO3 | DIO2 | DIO1 | DIO0 | | W-0h ## Table 8-43. DOUTCLR31\_0 Field Descriptions | Bit | Field | Туре | Reset | Description | |-----|-------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------| | 31 | DIO31 | W | 0h | Writing 1 to this bit clears the DIO31 bit in the DOUT31_0 register. Writing 0 has no effect. 0h = No effect 1h = Clears DIO31 in DOUT31_0 | | 30 | DIO30 | W | 0h | Writing 1 to this bit clears the DIO30 bit in the DOUT31_0 register. Writing 0 has no effect. 0h = No effect 1h = Clears DIO30 in DOUT31_0 | | 29 | DIO29 | W | 0h | Writing 1 to this bit clears the DIO29 bit in the DOUT31_0 register. Writing 0 has no effect. 0h = No effect 1h = Clears DIO29 in DOUT31_0 | | 28 | DIO28 | W | 0h | Writing 1 to this bit clears the DIO28 bit in the DOUT31_0 register. Writing 0 has no effect. 0h = No effect 1h = Clears DIO28 in DOUT31_0 | | 27 | DIO27 | W | 0h | Writing 1 to this bit clears the DIO27 bit in the DOUT31_0 register. Writing 0 has no effect. 0h = No effect 1h = Clears DIO27 in DOUT31_0 | | 26 | DIO26 | W | 0h | Writing 1 to this bit clears the DIO26 bit in the DOUT31_0 register. Writing 0 has no effect. 0h = No effect 1h = Clears DIO26 in DOUT31_0 | | 25 | DIO25 | W | Oh | Writing 1 to this bit clears the DIO25 bit in the DOUT31_0 register. Writing 0 has no effect. 0h = No effect 1h = Clears DIO25 in DOUT31_0 | | 24 | DIO24 | W | 0h | Writing 1 to this bit clears the DIO24 bit in the DOUT31_0 register. Writing 0 has no effect. 0h = No effect 1h = Clears DIO24 in DOUT31_0 | ## Table 8-43. DOUTCLR31\_0 Field Descriptions (continued) | Bit | Field | Type | Reset | Description (continued) | |-----|-------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------| | 23 | DIO23 | W | 0h | Writing 1 to this bit clears the DIO23 bit in the DOUT31_0 register. Writing 0 has no effect. 0h = No effect 1h = Clears DIO23 in DOUT31_0 | | 22 | DIO22 | W | Oh | Writing 1 to this bit clears the DIO22 bit in the DOUT31_0 register. Writing 0 has no effect. 0h = No effect 1h = Clears DIO22 in DOUT31_0 | | 21 | DIO21 | W | Oh | Writing 1 to this bit clears the DIO21 bit in the DOUT31_0 register. Writing 0 has no effect. 0h = No effect 1h = Clears DIO21 in DOUT31_0 | | 20 | DIO20 | W | Oh | Writing 1 to this bit clears the DIO20 bit in the DOUT31_0 register. Writing 0 has no effect. 0h = No effect 1h = Clears DIO20 in DOUT31_0 | | 19 | DIO19 | W | Oh | Writing 1 to this bit clears the DIO19 bit in the DOUT31_0 register. Writing 0 has no effect. 0h = No effect 1h = Clears DIO19 in DOUT31_0 | | 18 | DIO18 | W | Oh | Writing 1 to this bit clears the DIO18 bit in the DOUT31_0 register. Writing 0 has no effect. 0h = No effect 1h = Clears DIO18 in DOUT31_0 | | 17 | DIO17 | W | Oh | Writing 1 to this bit clears the DIO17 bit in the DOUT31_0 register. Writing 0 has no effect. 0h = No effect 1h = Clears DIO17 in DOUT31_0 | | 16 | DIO16 | W | Oh | Writing 1 to this bit clears the DIO16 bit in the DOUT31_0 register. Writing 0 has no effect. 0h = No effect 1h = Clears DIO16 in DOUT31_0 | | 15 | DIO15 | W | Oh | Writing 1 to this bit clears the DIO15 bit in the DOUT31_0 register. Writing 0 has no effect. 0h = No effect 1h = Clears DIO15 in DOUT31_0 | | 14 | DIO14 | W | Oh | Writing 1 to this bit clears the DIO14 bit in the DOUT31_0 register. Writing 0 has no effect. 0h = No effect 1h = Clears DIO14 in DOUT31_0 | | 13 | DIO13 | W | Oh | Writing 1 to this bit clears the DIO13 bit in the DOUT31_0 register. Writing 0 has no effect. 0h = No effect 1h = Clears DIO13 in DOUT31_0 | | 12 | DIO12 | W | Oh | Writing 1 to this bit clears the DIO12 bit in the DOUT31_0 register. Writing 0 has no effect. 0h = No effect 1h = Clears DIO12 in DOUT31_0 | | 11 | DIO11 | W | Oh | Writing 1 to this bit clears the DIO11 bit in the DOUT31_0 register. Writing 0 has no effect. 0h = No effect 1h = Clears DIO11 in DOUT31_0 | | 10 | DIO10 | W | Oh | Writing 1 to this bit clears the DIO10 bit in the DOUT31_0 register. Writing 0 has no effect. 0h = No effect 1h = Clears DIO10 in DOUT31_0 | ## Table 8-43. DOUTCLR31\_0 Field Descriptions (continued) | Bit | Field | Туре | Reset | Description (Continued) | |-----|-------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------| | 9 | DIO9 | W | Oh | Writing 1 to this bit clears the DIO9 bit in the DOUT31_0 register. Writing 0 has no effect. 0h = No effect 1h = Clears DIO9 in DOUT31_0 | | 8 | DIO8 | W | 0h | Writing 1 to this bit clears the DIO8 bit in the DOUT31_0 register. Writing 0 has no effect. 0h = No effect 1h = Clears DIO8 in DOUT31_0 | | 7 | DIO7 | W | 0h | Writing 1 to this bit clears the DIO7 bit in the DOUT31_0 register. Writing 0 has no effect. 0h = No effect 1h = Clears DIO7 in DOUT31_0 | | 6 | DIO6 | W | 0h | Writing 1 to this bit clears the DIO6 bit in the DOUT31_0 register. Writing 0 has no effect. 0h = No effect 1h = Clears DIO6 in DOUT31_0 | | 5 | DIO5 | W | 0h | Writing 1 to this bit clears the DIO5 bit in the DOUT31_0 register. Writing 0 has no effect. 0h = No effect 1h = Clears DIO5 in DOUT31_0 | | 4 | DIO4 | W | 0h | Writing 1 to this bit clears the DIO4 bit in the DOUT31_0 register. Writing 0 has no effect. 0h = No effect 1h = Clears DIO4 in DOUT31_0 | | 3 | DIO3 | W | 0h | Writing 1 to this bit clears the DIO3 bit in the DOUT31_0 register. Writing 0 has no effect. 0h = No effect 1h = Clears DIO3 in DOUT31_0 | | 2 | DIO2 | W | 0h | Writing 1 to this bit clears the DIO2 bit in the DOUT31_0 register. Writing 0 has no effect. 0h = No effect 1h = Clears DIO2 in DOUT31_0 | | 1 | DIO1 | W | 0h | Writing 1 to this bit clears the DIO1 bit in the DOUT31_0 register. Writing 0 has no effect. 0h = No effect 1h = Clears DIO1 in DOUT31_0 | | 0 | DIO0 | W | 0h | Writing 1 to this bit clears the DIO0 bit in the DOUT31_0 register. Writing 0 has no effect. 0h = No effect 1h = Clears DIO0 in DOUT31_0 | ## 8.3.41 DOUTTGL31\_0 (Offset = 12B0h) [Reset = 00000000h] DOUTTGL31\_0 is shown in Figure 8-44 and described in Table 8-44. Return to the Summary Table. Writing 1 to a bit position in this register will invert the corresponding DIO output. ## Figure 8-44. DOUTTGL31\_0 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------|-------|-------|-------|-------|-------|-------|-------| | DIO31 | DIO30 | DIO29 | DIO28 | DIO27 | DIO26 | DIO25 | DIO24 | | W-0h | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | DIO23 | DIO22 | DIO21 | DIO20 | DIO19 | DIO18 | DIO17 | DIO16 | | W-0h | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | DIO15 | DIO14 | DIO13 | DIO12 | DIO11 | DIO10 | DIO9 | DIO8 | | W-0h | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | DIO7 | DIO6 | DIO5 | DIO4 | DIO3 | DIO2 | DIO1 | DIO0 | | W-0h ## Table 8-44. DOUTTGL31\_0 Field Descriptions | Bit | Field | Туре | Reset | Description | |-----|-------|------|-------|------------------------------------------------------------------------------| | 31 | DIO31 | W | 0h | This bit is used to toggle DIO31 output. 0h = No effect 1h = Toggle output | | 30 | DIO30 | W | 0h | This bit is used to toggle DIO30 output. 0h = No effect 1h = Toggle output | | 29 | DIO29 | W | Oh | This bit is used to toggle DIO29 output. 0h = No effect 1h = Toggle output | | 28 | DIO28 | W | Oh | This bit is used to toggle DIO28 output. 0h = No effect 1h = Toggle output | | 27 | DIO27 | W | Oh | This bit is used to toggle DIO27 output. 0h = No effect 1h = Toggle output | | 26 | DIO26 | W | Oh | This bit is used to toggle DIO26 output. 0h = No effect 1h = Toggle output | | 25 | DIO25 | W | Oh | This bit is used to toggle DIO25 output. 0h = No effect 1h = Toggle output | | 24 | DIO24 | W | Oh | This bit is used to toggle DIO24 output. 0h = No effect 1h = Toggle output | | 23 | DIO23 | W | Oh | This bit is used to toggle DIO23 output. 0h = No effect 1h = Toggle output | | 22 | DIO22 | W | Oh | This bit is used to toggle DIO22 output. 0h = No effect 1h = Toggle output | ## Table 8-44. DOUTTGL31\_0 Field Descriptions (continued) | Bit | Field | Type | Reset | Description (continued) | |-----|--------|---------------------------------------|-------|------------------------------------------------------------| | 21 | DIO21 | W | 0h | This bit is used to toggle DIO21 output. | | 21 | DIOZ I | ** | OII | Oh = No effect | | | | | | 1h = Toggle output | | 20 | DIO20 | W | 0h | This bit is used to toggle DIO20 output. | | | | | | 0h = No effect<br>1h = Toggle output | | 19 | DIO19 | W | 0h | This bit is used to toggle DIO19 output. | | 19 | DIO19 | VV | OII | Oh = No effect | | | | | | 1h = Toggle output | | 18 | DIO18 | W | 0h | This bit is used to toggle DIO18 output. | | | | | | 0h = No effect<br>1h = Toggle output | | 17 | DIO17 | W | 0h | This bit is used to toggle DIO17 output. | | '' | DIOTI | \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ | OII | Oh = No effect | | | | | | 1h = Toggle output | | 16 | DIO16 | W | 0h | This bit is used to toggle DIO16 output. | | | | | | 0h = No effect<br>1h = Toggle output | | 15 | DIO15 | W | 0h | This bit is used to toggle DIO15 output. | | 10 | DIO 13 | ** | OII | Oh = No effect | | | | | | 1h = Toggle output | | 14 | DIO14 | W | 0h | This bit is used to toggle DIO14 output. | | | | | | 0h = No effect<br>1h = Toggle output | | 13 | DIO13 | W | 0h | This bit is used to toggle DIO13 output. | | 10 | BIO 10 | ** | 011 | Oh = No effect | | | | | | 1h = Toggle output | | 12 | DIO12 | W | 0h | This bit is used to toggle DIO12 output. | | | | | | 0h = No effect<br>1h = Toggle output | | 11 | DIO11 | W | 0h | This bit is used to toggle DIO11 output. | | | | | | 0h = No effect | | | | | | 1h = Toggle output | | 10 | DIO10 | W | 0h | This bit is used to toggle DIO10 output. Oh = No effect | | | | | | 1h = Toggle output | | 9 | DIO9 | W | 0h | This bit is used to toggle DIO9 output. | | | | | | 0h = No effect | | | 15100 | ļ | - | 1h = Toggle output | | 8 | DIO8 | W | 0h | This bit is used to toggle DIO8 output. Oh = No effect | | | | | | 1h = Toggle output | | 7 | DIO7 | W | 0h | This bit is used to toggle DIO7 output. | | | | | | Oh = No effect | | | DIOS | 101 | Oh | 1h = Toggle output This bit is used to toggle DIOS output | | 6 | DIO6 | W | 0h | This bit is used to toggle DIO6 output. Oh = No effect | | | | | | 1h = Toggle output | | 5 | DIO5 | W | 0h | This bit is used to toggle DIO5 output. | | | | | | 0h = No effect<br>1h = Toggle output | | 4 | DIO4 | W | 0h | 35 1 | | 4 | DIO4 | vv | UII | This bit is used to toggle DIO4 output. Oh = No effect | | | | | | 1h = Toggle output | | 3 | DIO3 | W | 0h | This bit is used to toggle DIO3 output. | | | | | | 0h = No effect<br>1h = Toggle output | | | | | | III – Toggle output | ## Table 8-44. DOUTTGL31\_0 Field Descriptions (continued) | Bit | Field | Туре | Reset | Description | |-----|-------|------|-------|----------------------------------------------------------------------------| | 2 | DIO2 | W | 0h | This bit is used to toggle DIO2 output. 0h = No effect 1h = Toggle output | | 1 | DIO1 | W | Oh | This bit is used to toggle DIO1 output. 0h = No effect 1h = Toggle output | | 0 | DIO0 | W | Oh | This bit is used to toggle DIO0 output. 0h = No effect 1h = Toggle output | ## 8.3.42 DOE31\_0 (Offset = 12C0h) [Reset = 00000000h] DOE31\_0 is shown in Figure 8-45 and described in Table 8-45. Return to the Summary Table. This register is used to enable the data outputs for DIO31 to DIO0. ## Figure 8-45. DOE31\_0 | 31 30 29 28 27 26 25 24 DIO31 DIO30 DIO29 DIO28 DIO27 DIO26 DIO25 DIO24 R/W-0h DIO17 DIO16 DIO18 DIO17 DIO16 DIO16 DIO17 DIO16 DIO16 R/W-0h | | | | J | _ | | | | |-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|--------|--------|--------|--------|--------|--------|--------| | R/W-0h DIO17 DIO16 DIO17 DIO16 DIO17 DIO16 DIO17 DIO16 DIO17 DIO16 DIO17 DIO18 DIO17 DIO16 DIO17 DIO18 DIO2 DIO1 DIO2 DIO1 DIO2 DIO1 DIO0 DIO2 DIO1 DIO0 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | 23 22 21 20 19 18 17 16 DIO23 DIO22 DIO21 DIO20 DIO19 DIO18 DIO17 DIO16 R/W-0h DIO3 DIO3 DIO11 DIO10 DIO9 DIO8 R/W-0h DIO3 DIO2 DIO1 DIO0 <th>DIO31</th> <th>DIO30</th> <th>DIO29</th> <th>DIO28</th> <th>DIO27</th> <th>DIO26</th> <th>DIO25</th> <th>DIO24</th> | DIO31 | DIO30 | DIO29 | DIO28 | DIO27 | DIO26 | DIO25 | DIO24 | | DIO23 DIO22 DIO21 DIO20 DIO19 DIO18 DIO17 DIO16 R/W-0h DIO3 DIO11 DIO10 DIO9 DIO8 R/W-0h DIO3 DIO2 DIO1 DIO0 | R/W-0h | R/W-0h DIO1 DIO1 DIO2 DIO3 DIO4 DIO3 DIO2 DIO1 DIO3 DIO2 DIO1 DIO0 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | 15 14 13 12 11 10 9 8 DIO15 DIO14 DIO13 DIO12 DIO11 DIO10 DIO9 DIO8 R/W-0h R/W-0h R/W-0h R/W-0h R/W-0h R/W-0h R/W-0h 7 6 5 4 3 2 1 0 DIO7 DIO6 DIO5 DIO4 DIO3 DIO2 DIO1 DIO0 | DIO23 | DIO22 | DIO21 | DIO20 | DIO19 | DIO18 | DIO17 | DIO16 | | DIO15 DIO14 DIO13 DIO12 DIO11 DIO10 DIO9 DIO8 R/W-0h DIO1 DIO2 DIO1 DIO0 <t< th=""><th>R/W-0h</th><th>R/W-0h</th><th>R/W-0h</th><th>R/W-0h</th><th>R/W-0h</th><th>R/W-0h</th><th>R/W-0h</th><th>R/W-0h</th></t<> | R/W-0h | R/W-0h R/W-0h< | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | 7 6 5 4 3 2 1 0 DIO7 DIO6 DIO5 DIO4 DIO3 DIO2 DIO1 DIO0 | DIO15 | DIO14 | DIO13 | DIO12 | DIO11 | DIO10 | DIO9 | DIO8 | | DIO7 DIO6 DIO5 DIO4 DIO3 DIO2 DIO1 DIO0 | R/W-0h | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | R/W-0h R/W-0h R/W-0h R/W-0h R/W-0h R/W-0h R/W-0h | DIO7 | DIO6 | DIO5 | DIO4 | DIO3 | DIO2 | DIO1 | DIO0 | | | R/W-0h ## Table 8-45. DOE31\_0 Field Descriptions | Bit | Field | Туре | Reset | Description | |-----|-------|------|-------|---------------------------------------------------------------------------| | 31 | DIO31 | R/W | 0h | Enables data output for DIO31. 0h = Output disabled 1h = Output enabled | | 30 | DIO30 | R/W | 0h | Enables data output for DIO30. 0h = Output disabled 1h = Output enabled | | 29 | DIO29 | R/W | 0h | Enables data output for DIO29. 0h = Output disabled 1h = Output enabled | | 28 | DIO28 | R/W | 0h | Enables data output for DIO28. 0h = Output disabled 1h = Output enabled | | 27 | DIO27 | R/W | 0h | Enables data output for DIO27. 0h = Output disabled 1h = Output enabled | | 26 | DIO26 | R/W | 0h | Enables data output for DIO26. 0h = Output disabled 1h = Output enabled | | 25 | DIO25 | R/W | 0h | Enables data output for DIO25. 0h = Output disabled 1h = Output enabled | | 24 | DIO24 | R/W | 0h | Enables data output for DIO24. 0h = Output disabled 1h = Output enabled | | 23 | DIO23 | R/W | 0h | Enables data output for DIO23. 0h = Output disabled 1h = Output enabled | | 22 | DIO22 | R/W | 0h | Enables data output for DIO22. 0h = Output disabled 1h = Output enabled | ## Table 8-45. DOE31\_0 Field Descriptions (continued) | Bit | Field | Type | Reset | Description (continued) | |-----|-------|------|-------|---------------------------------------------------------------------------| | 21 | DIO21 | R/W | 0h | - | | 21 | DIOZI | R/VV | UII | Enables data output for DIO21. 0h = Output disabled 1h = Output enabled | | 20 | DIO20 | R/W | 0h | Enables data output for DIO20. 0h = Output disabled 1h = Output enabled | | 19 | DIO19 | R/W | 0h | Enables data output for DIO19. 0h = Output disabled 1h = Output enabled | | 18 | DIO18 | R/W | 0h | Enables data output for DIO18. 0h = Output disabled 1h = Output enabled | | 17 | DIO17 | R/W | 0h | Enables data output for DIO17. Oh = Output disabled 1h = Output enabled | | 16 | DIO16 | R/W | 0h | Enables data output for DIO16. 0h = Output disabled 1h = Output enabled | | 15 | DIO15 | R/W | 0h | Enables data output for DIO15. 0h = Output disabled 1h = Output enabled | | 14 | DIO14 | R/W | 0h | Enables data output for DIO14. 0h = Output disabled 1h = Output enabled | | 13 | DIO13 | R/W | 0h | Enables data output for DIO13. Oh = Output disabled 1h = Output enabled | | 12 | DIO12 | R/W | 0h | Enables data output for DIO12. Oh = Output disabled 1h = Output enabled | | 11 | DIO11 | R/W | 0h | Enables data output for DIO11. Oh = Output disabled 1h = Output enabled | | 10 | DIO10 | R/W | 0h | Enables data output for DIO10. 0h = Output disabled 1h = Output enabled | | 9 | DIO9 | R/W | 0h | Enables data output for DIO9. 0h = Output disabled 1h = Output enabled | | 8 | DIO8 | R/W | 0h | Enables data output for DIO8. 0h = Output disabled 1h = Output enabled | | 7 | DIO7 | R/W | 0h | Enables data output for DIO7. 0h = Output disabled 1h = Output enabled | | 6 | DIO6 | R/W | 0h | Enables data output for DIO6. 0h = Output disabled 1h = Output enabled | | 5 | DIO5 | R/W | 0h | Enables data output for DIO5. 0h = Output disabled 1h = Output enabled | | 4 | DIO4 | R/W | 0h | Enables data output for DIO4. 0h = Output disabled 1h = Output enabled | | 3 | DIO3 | R/W | 0h | Enables data output for DIO3. Oh = Output disabled 1h = Output enabled | # Table 8-45. DOE31\_0 Field Descriptions (continued) | Bit | Field | Туре | Reset | Description | |-----|-------|------|-------|--------------------------------------------------------------------------| | 2 | DIO2 | R/W | 0h | Enables data output for DIO2. 0h = Output disabled 1h = Output enabled | | 1 | DIO1 | R/W | Oh | Enables data output for DIO1. 0h = Output disabled 1h = Output enabled | | 0 | DIO0 | R/W | 0h | Enables data output for DIO0. 0h = Output disabled 1h = Output enabled | ## 8.3.43 DOESET31\_0 (Offset = 12D0h) [Reset = 00000000h] DOESET31\_0 is shown in Figure 8-46 and described in Table 8-46. Return to the Summary Table. Writing 1 to a bit position in this register sets the corresponding bit in the DOE31\_0 register. ## Figure 8-46. DOESET31\_0 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------|-------|-------|-------|-------|-------|-------|-------| | DIO31 | DIO30 | DIO29 | DIO28 | DIO27 | DIO26 | DIO25 | DIO24 | | W-0h | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | DIO23 | DIO22 | DIO21 | DIO20 | DIO19 | DIO18 | DIO17 | DIO16 | | W-0h | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | DIO15 | DIO14 | DIO13 | DIO12 | DIO11 | DIO10 | DIO9 | DIO8 | | W-0h | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | DIO7 | DIO6 | DIO5 | DIO4 | DIO3 | DIO2 | DIO1 | DIO0 | | W-0h # Table 8-46. DOESET31\_0 Field Descriptions | Bit | Field | Туре | Reset | Description | |-----|-------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------| | 31 | DIO31 | W | 0h | Writing 1 to this bit sets the DIO31 bit in the DOE31_0 register. Writing 0 has no effect. 0h = No effect 1h = Sets DIO31 in DOE31_0 | | 30 | DIO30 | W | 0h | Writing 1 to this bit sets the DIO30 bit in the DOE31_0 register. Writing 0 has no effect. 0h = No effect 1h = Sets DIO30 in DOE31_0 | | 29 | DIO29 | W | 0h | Writing 1 to this bit sets the DIO29 bit in the DOE31_0 register. Writing 0 has no effect. 0h = No effect 1h = Sets DIO29 in DOE31_0 | | 28 | DIO28 | W | 0h | Writing 1 to this bit sets the DIO28 bit in the DOE31_0 register. Writing 0 has no effect. 0h = No effect 1h = Sets DIO28 in DOE31_0 | | 27 | DIO27 | W | 0h | Writing 1 to this bit sets the DIO27 bit in the DOE31_0 register. Writing 0 has no effect. 0h = No effect 1h = Sets DIO27 in DOE31_0 | | 26 | DIO26 | W | 0h | Writing 1 to this bit sets the DIO26 bit in the DOE31_0 register. Writing 0 has no effect. 0h = No effect 1h = Sets DIO26 in DOE31_0 | | 25 | DIO25 | W | 0h | Writing 1 to this bit sets the DIO25 bit in the DOE31_0 register. Writing 0 has no effect. 0h = No effect 1h = Sets DIO25 in DOE31_0 | | 24 | DIO24 | W | 0h | Writing 1 to this bit sets the DIO24 bit in the DOE31_0 register. Writing 0 has no effect. 0h = No effect 1h = Sets DIO24 in DOE31_0 | ## Table 8-46. DOESET31\_0 Field Descriptions (continued) | Table 8-46. DOESET31_0 Field Descriptions (continued) | | | | | | |-------------------------------------------------------|-------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------|--| | Bit | Field | Туре | Reset | Description | | | 23 | DIO23 | W | 0h | Writing 1 to this bit sets the DIO23 bit in the DOE31_0 register. Writing 0 has no effect. 0h = No effect 1h = Sets DIO23 in DOE31_0 | | | 22 | DIO22 | W | 0h | Writing 1 to this bit sets the DIO22 bit in the DOE31_0 register. Writing 0 has no effect. 0h = No effect 1h = Sets DIO22 in DOE31_0 | | | 21 | DIO21 | W | 0h | Writing 1 to this bit sets the DIO21 bit in the DOE31_0 register. Writing 0 has no effect. 0h = No effect 1h = Sets DIO21 in DOE31_0 | | | 20 | DIO20 | W | 0h | Writing 1 to this bit sets the DIO20 bit in the DOE31_0 register. Writing 0 has no effect. 0h = No effect 1h = Sets DIO20 in DOE31_0 | | | 19 | DIO19 | W | 0h | Writing 1 to this bit sets the DIO19 bit in the DOE31_0 register. Writing 0 has no effect. 0h = No effect 1h = Sets DIO19 in DOE31_0 | | | 18 | DIO18 | W | 0h | Writing 1 to this bit sets the DIO18 bit in the DOE31_0 register. Writing 0 has no effect. 0h = No effect 1h = Sets DIO18 in DOE31_0 | | | 17 | DIO17 | W | 0h | Writing 1 to this bit sets the DIO17 bit in the DOE31_0 register. Writing 0 has no effect. 0h = No effect 1h = Sets DIO17 in DOE31_0 | | | 16 | DIO16 | W | 0h | Writing 1 to this bit sets the DIO16 bit in the DOE31_0 register. Writing 0 has no effect. 0h = No effect 1h = Sets DIO16 in DOE31_0 | | | 15 | DIO15 | W | 0h | Writing 1 to this bit sets the DIO15 bit in the DOE31_0 register. Writing 0 has no effect. 0h = No effect 1h = Sets DIO15 in DOE31_0 | | | 14 | DIO14 | W | 0h | Writing 1 to this bit sets the DIO14 bit in the DOE31_0 register. Writing 0 has no effect. 0h = No effect 1h = Sets DIO14 in DOE31_0 | | | 13 | DIO13 | W | 0h | Writing 1 to this bit sets the DIO13 bit in the DOE31_0 register. Writing 0 has no effect. 0h = No effect 1h = Sets DIO13 in DOE31_0 | | | 12 | DIO12 | W | Oh | Writing 1 to this bit sets the DIO12 bit in the DOE31_0 register. Writing 0 has no effect. 0h = No effect 1h = Sets DIO12 in DOE31_0 | | | 11 | DIO11 | W | 0h | Writing 1 to this bit sets the DIO11 bit in the DOE31_0 register. Writing 0 has no effect. 0h = No effect 1h = Sets DIO11 in DOE31_0 | | | 10 | DIO10 | W | 0h | Writing 1 to this bit sets the DIO10 bit in the DOE31_0 register. Writing 0 has no effect. 0h = No effect 1h = Sets DIO10 in DOE31_0 | | ## Table 8-46. DOESET31\_0 Field Descriptions (continued) | Bit | Field | Туре | Reset | Description (Continued) | |-----|-------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------| | 9 | DIO9 | W | 0h | Writing 1 to this bit sets the DIO9 bit in the DOE31_0 register. Writing 0 has no effect. 0h = No effect 1h = Sets DIO9 in DOE31_0 | | 8 | DIO8 | W | 0h | Writing 1 to this bit sets the DIO8 bit in the DOE31_0 register. Writing 0 has no effect. 0h = No effect 1h = Sets DIO8 in DOE31_0 | | 7 | DIO7 | W | 0h | Writing 1 to this bit sets the DIO7 bit in the DOE31_0 register. Writing 0 has no effect. 0h = No effect 1h = Sets DIO7 in DOE31_0 | | 6 | DIO6 | W | 0h | Writing 1 to this bit sets the DIO6 bit in the DOE31_0 register. Writing 0 has no effect. 0h = No effect 1h = Sets DIO6 in DOE31_0 | | 5 | DIO5 | W | 0h | Writing 1 to this bit sets the DIO5 bit in the DOE31_0 register. Writing 0 has no effect. 0h = No effect 1h = Sets DIO5 in DOE31_0 | | 4 | DIO4 | W | 0h | Writing 1 to this bit sets the DIO4 bit in the DOE31_0 register. Writing 0 has no effect. 0h = No effect 1h = Sets DIO4 in DOE31_0 | | 3 | DIO3 | W | 0h | Writing 1 to this bit sets the DIO3 bit in the DOE31_0 register. Writing 0 has no effect. 0h = No effect 1h = Sets DIO3 in DOE31_0 | | 2 | DIO2 | W | 0h | Writing 1 to this bit sets the DIO2 bit in the DOE31_0 register. Writing 0 has no effect. 0h = No effect 1h = Sets DIO2 in DOE31_0 | | 1 | DIO1 | W | 0h | Writing 1 to this bit sets the DIO1 bit in the DOE31_0 register. Writing 0 has no effect. 0h = No effect 1h = Sets DIO1 in DOE31_0 | | 0 | DIO0 | W | Oh | Writing 1 to this bit sets the DIO0 bit in the DOE31_0 register. Writing 0 has no effect. 0h = No effect 1h = Sets DIO0 in DOE31_0 | ## 8.3.44 DOECLR31\_0 (Offset = 12E0h) [Reset = 00000000h] DOECLR31\_0 is shown in Figure 8-47 and described in Table 8-47. Return to the Summary Table. Writing 1 to a bit position in this register clears the corresponding bit in the DOE31\_0 register. ## Figure 8-47. DOECLR31\_0 | | | | • | _ | | | | |-------|-------|-------|-------|-------|-------|-------|-------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | DIO31 | DIO30 | DIO29 | DIO28 | DIO27 | DIO26 | DIO25 | DIO24 | | W-0h | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | DIO23 | DIO22 | DIO21 | DIO20 | DIO19 | DIO18 | DIO17 | DIO16 | | W-0h | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | DIO15 | DIO14 | DIO13 | DIO12 | DIO11 | DIO10 | DIO9 | DIO8 | | W-0h | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | DIO7 | DIO6 | DIO5 | DIO4 | DIO3 | DIO2 | DIO1 | DIO0 | | W-0h ## Table 8-47. DOECLR31\_0 Field Descriptions | Bit | Field | Туре | Reset | Description | |-----|-------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------| | 31 | DIO31 | W | Oh | Writing 1 to this bit clears the DIO31 bit in the DOE31_0 register. Writing 0 has no effect. 0h = No effect 1h = Clears DIO31 in DOE31_0 | | 30 | DIO30 | W | Oh | Writing 1 to this bit clears the DIO30 bit in the DOE31_0 register. Writing 0 has no effect. 0h = No effect 1h = Clears DIO30 in DOE31_0 | | 29 | DIO29 | W | Oh | Writing 1 to this bit clears the DIO29 bit in the DOE31_0 register. Writing 0 has no effect. 0h = No effect 1h = Clears DIO29 in DOE31_0 | | 28 | DIO28 | W | Oh | Writing 1 to this bit clears the DIO28 bit in the DOE31_0 register. Writing 0 has no effect. 0h = No effect 1h = Clears DIO28 in DOE31_0 | | 27 | DIO27 | W | Oh | Writing 1 to this bit clears the DIO27 bit in the DOE31_0 register. Writing 0 has no effect. 0h = No effect 1h = Clears DIO27 in DOE31_0 | | 26 | DIO26 | W | Oh | Writing 1 to this bit clears the DIO26 bit in the DOE31_0 register. Writing 0 has no effect. 0h = No effect 1h = Clears DIO26 in DOE31_0 | | 25 | DIO25 | W | Oh | Writing 1 to this bit clears the DIO25 bit in the DOE31_0 register. Writing 0 has no effect. 0h = No effect 1h = Clears DIO25 in DOE31_0 | | 24 | DIO24 | W | Oh | Writing 1 to this bit clears the DIO24 bit in the DOE31_0 register. Writing 0 has no effect. 0h = No effect 1h = Clears DIO24 in DOE31_0 | ## Table 8-47. DOECLR31\_0 Field Descriptions (continued) | Bit | Field | Type | Reset | Descriptions (continued) | |-----|-------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------| | 23 | DIO23 | W | 0h | Writing 1 to this bit clears the DIO23 bit in the DOE31_0 register. Writing 0 has no effect. 0h = No effect 1h = Clears DIO23 in DOE31_0 | | 22 | DIO22 | W | Oh | Writing 1 to this bit clears the DIO22 bit in the DOE31_0 register. Writing 0 has no effect. 0h = No effect 1h = Clears DIO22 in DOE31_0 | | 21 | DIO21 | W | Oh | Writing 1 to this bit clears the DIO21 bit in the DOE31_0 register. Writing 0 has no effect. 0h = No effect 1h = Clears DIO21 in DOE31_0 | | 20 | DIO20 | W | 0h | Writing 1 to this bit clears the DIO20 bit in the DOE31_0 register. Writing 0 has no effect. 0h = No effect 1h = Clears DIO20 in DOE31_0 | | 19 | DIO19 | W | 0h | Writing 1 to this bit clears the DIO19 bit in the DOE31_0 register. Writing 0 has no effect. 0h = No effect 1h = Clears DIO19 in DOE31_0 | | 18 | DIO18 | W | 0h | Writing 1 to this bit clears the DIO18 bit in the DOE31_0 register. Writing 0 has no effect. 0h = No effect 1h = Clears DIO18 in DOE31_0 | | 17 | DIO17 | W | 0h | Writing 1 to this bit clears the DIO17 bit in the DOE31_0 register. Writing 0 has no effect. 0h = No effect 1h = Clears DIO17 in DOE31_0 | | 16 | DIO16 | W | Oh | Writing 1 to this bit clears the DIO16 bit in the DOE31_0 register. Writing 0 has no effect. 0h = No effect 1h = Clears DIO16 in DOE31_0 | | 15 | DIO15 | W | Oh | Writing 1 to this bit clears the DIO15 bit in the DOE31_0 register. Writing 0 has no effect. 0h = No effect 1h = Clears DIO15 in DOE31_0 | | 14 | DIO14 | W | Oh | Writing 1 to this bit clears the DIO14 bit in the DOE31_0 register. Writing 0 has no effect. 0h = No effect 1h = Clears DIO14 in DOE31_0 | | 13 | DIO13 | W | Oh | Writing 1 to this bit clears the DIO13 bit in the DOE31_0 register. Writing 0 has no effect. 0h = No effect 1h = Clears DIO13 in DOE31_0 | | 12 | DIO12 | W | Oh | Writing 1 to this bit clears the DIO12 bit in the DOE31_0 register. Writing 0 has no effect. 0h = No effect 1h = Clears DIO12 in DOE31_0 | | 11 | DIO11 | W | Oh | Writing 1 to this bit clears the DIO11 bit in the DOE31_0 register. Writing 0 has no effect. 0h = No effect 1h = Clears DIO11 in DOE31_0 | | 10 | DIO10 | W | Oh | Writing 1 to this bit clears the DIO10 bit in the DOE31_0 register. Writing 0 has no effect. 0h = No effect 1h = Clears DIO10 in DOE31_0 | ## Table 8-47. DOECLR31\_0 Field Descriptions (continued) | Bit | Field | Туре | Reset | Description (continued) | | |-----|-------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------|--| | 9 | DIO9 | W | Oh | Writing 1 to this bit clears the DIO9 bit in the DOE31_0 register. Writing 0 has no effect. 0h = No effect 1h = Clears DIO9 in DOE31_0 | | | 8 | DIO8 | W | 0h | Writing 1 to this bit clears the DIO8 bit in the DOE31_0 register. Writing 0 has no effect. 0h = No effect 1h = Clears DIO8 in DOE31_0 | | | 7 | DIO7 | W | 0h | Writing 1 to this bit clears the DIO7 bit in the DOE31_0 register. Writing 0 has no effect. 0h = No effect 1h = Clears DIO7 in DOE31_0 | | | 6 | DIO6 | W | Oh | Writing 1 to this bit clears the DIO6 bit in the DOE31_0 register. Writing 0 has no effect. 0h = No effect 1h = Clears DIO6 in DOE31_0 | | | 5 | DIO5 | W | Oh | Writing 1 to this bit clears the DIO5 bit in the DOE31_0 register. Writing 0 has no effect. 0h = No effect 1h = Clears DIO5 in DOE31_0 | | | 4 | DIO4 | W | 0h | Writing 1 to this bit clears the DIO4 bit in the DOE31_0 register. Writing 0 has no effect. 0h = No effect 1h = Clears DIO4 in DOE31_0 | | | 3 | DIO3 | W | 0h | Writing 1 to this bit clears the DIO3 bit in the DOE31_0 register. Writing 0 has no effect. 0h = No effect 1h = Clears DIO3 in DOE31_0 | | | 2 | DIO2 | W | 0h | Writing 1 to this bit clears the DIO2 bit in the DOE31_0 register. Writing 0 has no effect. 0h = No effect 1h = Clears DIO2 in DOE31_0 | | | 1 | DIO1 | W | 0h | Writing 1 to this bit clears the DIO1 bit in the DOE31_0 register. Writing 0 has no effect. 0h = No effect 1h = Clears DIO1 in DOE31_0 | | | 0 | DIO0 | W | 0h | Writing 1 to this bit clears the DIO0 bit in the DOE31_0 register. Writing 0 has no effect. 0h = No effect 1h = Clears DIO0 in DOE31_0 | | #### 8.3.45 DIN3\_0 (Offset = 1300h) [Reset = 00000000h] DIN3\_0 is shown in Figure 8-48 and described in Table 8-48. Return to the Summary Table. Data input from pins configured as DIO3 to DIO0. This is an alias register for byte access to bits 3 to 0 in DIN31\_0 register. Figure 8-48. DIN3 0 | | | | rigule 6-4 | 0. DIN3_0 | | | | |----|----|----|------------|-----------|----|----|------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | RESERVED | | | | DIO3 | | | | | R-0h | | | | R-0h | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | RESERVED | | | | DIO2 | | | | | R-0h | | | | R-0h | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | RESERVED | | | | DIO1 | | | | | R-0h | | | | R-0h | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | RESERVED | | | | DIO0 | | | | | R-0h | | | | R-0h | #### Table 8-48. DIN3 0 Field Descriptions | Bit | Field | Type | Reset | Description | |-------|----------|------|-------|--------------------------------------------------------------------------------------------| | 31-25 | RESERVED | R | 0h | | | 24 | DIO3 | R | Oh | This bit reads the data input value of DIO3. 0h = Input value is 0 1h = Input value is 1 | | 23-17 | RESERVED | R | 0h | | | 16 | DIO2 | R | Oh | This bit reads the data input value of DIO2. 0h = Input value is 0 1h = Input value is 1 | | 15-9 | RESERVED | R | 0h | | | 8 | DIO1 | R | Oh | This bit reads the data input value of DIO1. 0h = Input value is 0 1h = Input value is 1 | | 7-1 | RESERVED | R | 0h | | | 0 | DIO0 | R | Oh | This bit reads the data input value of DIO0. 0h = Input value is 0 1h = Input value is 1 | # 8.3.46 DIN7\_4 (Offset = 1304h) [Reset = 00000000h] DIN7\_4 is shown in Figure 8-49 and described in Table 8-49. Return to the Summary Table. Data input from pins configured as DIO7 to DIO4. This is an alias register for byte access to bits 7 to 4 in DIN31\_0 register. Figure 8-49. DIN7 4 | | | | i iguic o- <del>-</del> | 3. DII 1/_ <del>-</del> | | | | |----|----|----|-------------------------|-------------------------|----|----|------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | RESERVED | | | | DIO7 | | | | | R-0h | | | | R-0h | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | RESERVED | | | | DIO6 | | | | | R-0h | | | | R-0h | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | RESERVED | | | | DIO5 | | | | | R-0h | | | | R-0h | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | RESERVED | | | | DIO4 | | | | | R-0h | | | | R-0h | Table 8-49. DIN7\_4 Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|--------------------------------------------------------------------------------------------| | 31-25 | RESERVED | R | 0h | | | 24 | DIO7 | R | 0h | This bit reads the data input value of DIO7. 0h = Input value is 0 1h = Input value is 1 | | 23-17 | RESERVED | R | 0h | | | 16 | DIO6 | R | 0h | This bit reads the data input value of DIO6. 0h = Input value is 0 1h = Input value is 1 | | 15-9 | RESERVED | R | 0h | | | 8 | DIO5 | R | 0h | This bit reads the data input value of DIO5. 0h = Input value is 0 1h = Input value is 1 | | 7-1 | RESERVED | R | 0h | | | 0 | DIO4 | R | 0h | This bit reads the data input value of DIO4. 0h = Input value is 0 1h = Input value is 1 | # 8.3.47 DIN11\_8 (Offset = 1308h) [Reset = 00000000h] DIN11\_8 is shown in Figure 8-50 and described in Table 8-50. Return to the Summary Table. Data input from pins configured as DIO11 to DIO8. This is an alias register for byte access to bits 11 to 8 in DIN31\_0 register. Figure 8-50. DIN11 8 | | | | Figure 6-50 | . DIN I I_0 | | | | |----|----|----|-------------|-------------|----|----|-------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | RESERVED | | | | DIO11 | | | | | R-0h | | | | R-0h | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | RESERVED | | | | DIO10 | | | | | R-0h | | | | R-0h | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | RESERVED | | | | DIO9 | | | | | R-0h | | | | R-0h | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | RESERVED | | | | DIO8 | | | | | R-0h | | | | R-0h | #### Table 8-50. DIN11 8 Field Descriptions | Table 0-30. Dil Ti_o i leid Descriptions | | | | | | | | |------------------------------------------|----------|------|-------|---------------------------------------------------------------------------------------------|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | 31-25 | RESERVED | R | 0h | | | | | | 24 | DIO11 | R | Oh | This bit reads the data input value of DIO11. Oh = Input value is 0 1h = Input value is 1 | | | | | 23-17 | RESERVED | R | 0h | | | | | | 16 | DIO10 | R | Oh | This bit reads the data input value of DIO10. Oh = Input value is 0 1h = Input value is 1 | | | | | 15-9 | RESERVED | R | 0h | | | | | | 8 | DIO9 | R | Oh | This bit reads the data input value of DIO9. 0h = Input value is 0 1h = Input value is 1 | | | | | 7-1 | RESERVED | R | 0h | | | | | | 0 | DIO8 | R | Oh | This bit reads the data input value of DIO8. 0h = Input value is 0 1h = Input value is 1 | | | | # 8.3.48 DIN15\_12 (Offset = 130Ch) [Reset = 00000000h] DIN15\_12 is shown in Figure 8-51 and described in Table 8-51. Return to the Summary Table. Data input from pins configured as DIO15 to DIO12. This is an alias register for byte access to bits 15 to 12 in DIN31\_0 register. Figure 8-51. DIN15 12 | | | | rigule o-51. | DIN 13_12 | | | | |----|----|----|--------------|-----------|----|----|-------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | RESERVED | | | | DIO15 | | | | | R-0h | | | | R-0h | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | RESERVED | | | | DIO14 | | | | | R-0h | | | | R-0h | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | RESERVED | | | | DIO13 | | | | | R-0h | | | | R-0h | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | RESERVED | | | | DIO12 | | | | | R-0h | | | | R-0h | # Table 8-51. DIN15\_12 Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|---------------------------------------------------------------------------------------------| | 31-25 | RESERVED | R | 0h | | | 24 | DIO15 | R | 0h | This bit reads the data input value of DIO15. 0h = Input value is 0 1h = Input value is 1 | | 23-17 | RESERVED | R | 0h | | | 16 | DIO14 | R | Oh | This bit reads the data input value of DIO14. 0h = Input value is 0 1h = Input value is 1 | | 15-9 | RESERVED | R | 0h | | | 8 | DIO13 | R | 0h | This bit reads the data input value of DIO13. 0h = Input value is 0 1h = Input value is 1 | | 7-1 | RESERVED | R | 0h | | | 0 | DIO12 | R | Oh | This bit reads the data input value of DIO12. 0h = Input value is 0 1h = Input value is 1 | # 8.3.49 DIN19\_16 (Offset = 1310h) [Reset = 00000000h] DIN19\_16 is shown in Figure 8-52 and described in Table 8-52. Return to the Summary Table. Data input from pins configured as DIO19 to DIO16. This is an alias register for byte access to bits 19 to 16 in DIN31\_0 register. Figure 8-52. DIN19 16 | | | | rigule 0-32. | ם _פואוום. | | | | |----|----|----|--------------|------------|----|----|-------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | RESERVED | | | | DIO19 | | | | | R-0h | | | | R-0h | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | RESERVED | | | | DIO18 | | | | | R-0h | | | | R-0h | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | RESERVED | | | | DIO17 | | | | | R-0h | | | | R-0h | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | RESERVED | | | | DIO16 | | | | | R-0h | | | | R-0h | #### Table 8-52. DIN19 16 Field Descriptions | Table 0-32. Dil 13_10 Tield Descriptions | | | | | | | | |------------------------------------------|----------|------|-------|---------------------------------------------------------------------------------------------|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | 31-25 | RESERVED | R | 0h | | | | | | 24 | DIO19 | R | Oh | This bit reads the data input value of DIO19. 0h = Input value is 0 1h = Input value is 1 | | | | | 23-17 | RESERVED | R | 0h | | | | | | 16 | DIO18 | R | Oh | This bit reads the data input value of DIO18. 0h = Input value is 0 1h = Input value is 1 | | | | | 15-9 | RESERVED | R | 0h | | | | | | 8 | DIO17 | R | Oh | This bit reads the data input value of DIO17. 0h = Input value is 0 1h = Input value is 1 | | | | | 7-1 | RESERVED | R | 0h | | | | | | 0 | DIO16 | R | Oh | This bit reads the data input value of DIO16. 0h = Input value is 0 1h = Input value is 1 | | | | #### 8.3.50 DIN23\_20 (Offset = 1314h) [Reset = 00000000h] DIN23\_20 is shown in Figure 8-53 and described in Table 8-53. Return to the Summary Table. Data input from pins configured as DIO23 to DIO20. This is an alias register for byte access to bits 23 to 20 in DIN31\_0 register. Figure 8-53, DIN23 20 | | | | rigule 0-55. | DIN23_20 | | | | |----|----|----|--------------|----------|----|----|-------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | RESERVED | | | | DIO23 | | | | | R-0h | | | | R-0h | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | RESERVED | | | | DIO22 | | | | | R-0h | | | | R-0h | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | RESERVED | | | | DIO21 | | | | | R-0h | | | | R-0h | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | RESERVED | | | | DIO20 | | | | | R-0h | | | | R-0h | #### Table 8-53. DIN23\_20 Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|---------------------------------------------------------------------------------------------| | 31-25 | RESERVED | R | 0h | | | 24 | DIO23 | R | 0h | This bit reads the data input value of DIO23. 0h = Input value is 0 1h = Input value is 1 | | 23-17 | RESERVED | R | 0h | | | 16 | DIO22 | R | Oh | This bit reads the data input value of DIO22. 0h = Input value is 0 1h = Input value is 1 | | 15-9 | RESERVED | R | 0h | | | 8 | DIO21 | R | 0h | This bit reads the data input value of DIO21. 0h = Input value is 0 1h = Input value is 1 | | 7-1 | RESERVED | R | 0h | | | 0 | DIO20 | R | Oh | This bit reads the data input value of DIO20. 0h = Input value is 0 1h = Input value is 1 | #### 8.3.51 DIN27\_24 (Offset = 1318h) [Reset = 00000000h] DIN27\_24 is shown in Figure 8-54 and described in Table 8-54. Return to the Summary Table. Data input from pins configured as DIO27 to DIO24. This is an alias register for byte access to bits 27 to 24 in DIN31\_0 register. Figure 8-54. DIN27 24 | | | | i igaic o o- | | | | | | | | | |----|----------|----|--------------|----|----|----|-------|--|--|--|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | | | | | RESERVED | | | | DIO27 | | | | | | | | | R-0h | | | | R-0h | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | | | RESERVED | | | | | | | | | | | | | R-0h | | | | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | | | | RESERVED | | | | DIO25 | | | | | | | | | R-0h | | | | R-0h | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | RESERVED | | | | DIO24 | | | | | | | | | R-0h | | | | R-0h | | | | | #### Table 8-54. DIN27 24 Field Descriptions | | | Table 0 | 7-04. DINZ | _24 i leid Descriptions | |-------|----------|---------|------------|---------------------------------------------------------------------------------------------| | Bit | Field | Туре | Reset | Description | | 31-25 | RESERVED | R | 0h | | | 24 | DIO27 | R | Oh | This bit reads the data input value of DIO27. 0h = Input value is 0 1h = Input value is 1 | | 23-17 | RESERVED | R | 0h | | | 16 | DIO26 | R | Oh | This bit reads the data input value of DIO26. 0h = Input value is 0 1h = Input value is 1 | | 15-9 | RESERVED | R | 0h | | | 8 | DIO25 | R | Oh | This bit reads the data input value of DIO25. 0h = Input value is 0 1h = Input value is 1 | | 7-1 | RESERVED | R | 0h | | | 0 | DIO24 | R | Oh | This bit reads the data input value of DIO24. 0h = Input value is 0 1h = Input value is 1 | # 8.3.52 DIN31\_28 (Offset = 131Ch) [Reset = 00000000h] DIN31\_28 is shown in Figure 8-55 and described in Table 8-55. Return to the Summary Table. Data input from pins configured as DIO31 to DIO28. This is an alias register for byte access to bits 31 to 28 in DIN31\_0 register. Figure 8-55. DIN31 28 | | Figure 6-55. Dil451_26 | | | | | | | | | | | | | |----|------------------------|----|----------|----|----|----|-------|--|--|--|--|--|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | | | | | RESERVED | | | | | | | | | | | | | | | R-0h | | | | | | | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | | | | | RESERVED | | | | | | | | | | | | | | | R-0h | | | | | | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | | | | | | RESERVED | | | | DIO29 | | | | | | | | | | | R-0h | | | | R-0h | | | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | | | RESERVED | | | | DIO28 | | | | | | | | | | | R-0h | | | | R-0h | | | | | | | #### Table 8-55. DIN31\_28 Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|---------------------------------------------------------------------------------------------| | 31-25 | RESERVED | R | 0h | | | 24 | DIO31 | R | 0h | This bit reads the data input value of DIO31. 0h = Input value is 0 1h = Input value is 1 | | 23-17 | RESERVED | R | 0h | | | 16 | DIO30 | R | Oh | This bit reads the data input value of DIO30. 0h = Input value is 0 1h = Input value is 1 | | 15-9 | RESERVED | R | 0h | | | 8 | DIO29 | R | 0h | This bit reads the data input value of DIO29. 0h = Input value is 0 1h = Input value is 1 | | 7-1 | RESERVED | R | 0h | | | 0 | DIO28 | R | Oh | This bit reads the data input value of DIO28. 0h = Input value is 0 1h = Input value is 1 | # 8.3.53 DIN31\_0 (Offset = 1380h) [Reset = 00000000h] DIN31\_0 is shown in Figure 8-56 and described in Table 8-56. Return to the Summary Table. Data input value for pins configured as DIO31 to DIO0. # Figure 8-56. DIN31\_0 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-------|-------|-------|-------|-----------|-------|-------|-------| | DIO31 | DIO30 | DIO29 | DIO28 | DIO27 | DIO26 | DIO25 | DIO24 | | R-0h | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | DIO23 | DIO22 | DIO21 | DIO20 | DIO19 | DIO18 | DIO17 | DIO16 | | R-0h | R-0h | R-0h | R-0h | R-0h R-0h | | R-0h | R-0h | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | DIO15 | DIO14 | DIO13 | DIO12 | DIO11 | DIO10 | DIO9 | DIO8 | | R-0h | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | DIO7 | DIO6 | DIO5 | DIO4 | DIO3 | DIO2 | DIO1 | DIO0 | | R-0h # Table 8-56. DIN31\_0 Field Descriptions | Bit | Field | Туре | Reset | Description | |-----|-------|------|-------|---------------------------------------------------------------------------------------------| | 31 | DIO31 | R | 0h | This bit reads the data input value of DIO31. 0h = Input value is 0 1h = Input value is 1 | | 30 | DIO30 | R | 0h | This bit reads the data input value of DIO30. 0h = Input value is 0 1h = Input value is 1 | | 29 | DIO29 | R | 0h | This bit reads the data input value of DIO29. 0h = Input value is 0 1h = Input value is 1 | | 28 | DIO28 | R | Oh | This bit reads the data input value of DIO28. 0h = Input value is 0 1h = Input value is 1 | | 27 | DIO27 | R | 0h | This bit reads the data input value of DIO27. 0h = Input value is 0 1h = Input value is 1 | | 26 | DIO26 | R | Oh | This bit reads the data input value of DIO26. 0h = Input value is 0 1h = Input value is 1 | | 25 | DIO25 | R | Oh | This bit reads the data input value of DIO25. 0h = Input value is 0 1h = Input value is 1 | | 24 | DIO24 | R | Oh | This bit reads the data input value of DIO24. 0h = Input value is 0 1h = Input value is 1 | | 23 | DIO23 | R | 0h | This bit reads the data input value of DIO23. 0h = Input value is 0 1h = Input value is 1 | | 22 | DIO22 | R | 0h | This bit reads the data input value of DIO22. 0h = Input value is 0 1h = Input value is 1 | # Table 8-56. DIN31\_0 Field Descriptions (continued) | D:4 | Table 8-56. DIN31_0 Field Descriptions (continued) | | | | | | | | | | | | |-----|----------------------------------------------------|------|-------|---------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | | | | | | 21 | DIO21 | R | Oh | This bit reads the data input value of DIO21. 0h = Input value is 0 1h = Input value is 1 | | | | | | | | | | 20 | DIO20 | R | 0h | This bit reads the data input value of DIO20. 0h = Input value is 0 1h = Input value is 1 | | | | | | | | | | 19 | DIO19 | R | 0h | This bit reads the data input value of DIO19. 0h = Input value is 0 1h = Input value is 1 | | | | | | | | | | 18 | DIO18 | R | 0h | This bit reads the data input value of DIO18. 0h = Input value is 0 1h = Input value is 1 | | | | | | | | | | 17 | DIO17 | R | 0h | This bit reads the data input value of DIO17. 0h = Input value is 0 1h = Input value is 1 | | | | | | | | | | 16 | DIO16 | R | 0h | This bit reads the data input value of DIO16. 0h = Input value is 0 1h = Input value is 1 | | | | | | | | | | 15 | DIO15 | R | 0h | This bit reads the data input value of DIO15. 0h = Input value is 0 1h = Input value is 1 | | | | | | | | | | 14 | DIO14 | R | 0h | This bit reads the data input value of DIO14. 0h = Input value is 0 1h = Input value is 1 | | | | | | | | | | 13 | DIO13 | R | 0h | This bit reads the data input value of DIO13. 0h = Input value is 0 1h = Input value is 1 | | | | | | | | | | 12 | DIO12 | R | 0h | This bit reads the data input value of DIO12. 0h = Input value is 0 1h = Input value is 1 | | | | | | | | | | 11 | DIO11 | R | 0h | This bit reads the data input value of DIO11. 0h = Input value is 0 1h = Input value is 1 | | | | | | | | | | 10 | DIO10 | R | 0h | This bit reads the data input value of DIO10. 0h = Input value is 0 1h = Input value is 1 | | | | | | | | | | 9 | DIO9 | R | 0h | This bit reads the data input value of DIO9. 0h = Input value is 0 1h = Input value is 1 | | | | | | | | | | 8 | DIO8 | R | 0h | This bit reads the data input value of DIO8. 0h = Input value is 0 1h = Input value is 1 | | | | | | | | | | 7 | DIO7 | R | Oh | This bit reads the data input value of DIO7. 0h = Input value is 0 1h = Input value is 1 | | | | | | | | | | 6 | DIO6 | R | Oh | This bit reads the data input value of DIO6. 0h = Input value is 0 1h = Input value is 1 | | | | | | | | | | 5 | DIO5 | R | 0h | This bit reads the data input value of DIO5. 0h = Input value is 0 1h = Input value is 1 | | | | | | | | | | 4 | DIO4 | R | Oh | This bit reads the data input value of DIO4. 0h = Input value is 0 1h = Input value is 1 | | | | | | | | | | 3 | DIO3 | R | 0h | This bit reads the data input value of DIO3. 0h = Input value is 0 1h = Input value is 1 | | | | | | | | | # Table 8-56. DIN31\_0 Field Descriptions (continued) | Bit | Field | Туре | Reset | Description | |-----|-------|------|-------|--------------------------------------------------------------------------------------------| | 2 | DIO2 | R | 0h | This bit reads the data input value of DIO2. 0h = Input value is 0 1h = Input value is 1 | | 1 | DIO1 | R | Oh | This bit reads the data input value of DIO1. 0h = Input value is 0 1h = Input value is 1 | | 0 | DIO0 | R | Oh | This bit reads the data input value of DIO0. 0h = Input value is 0 1h = Input value is 1 | #### 8.3.54 POLARITY15\_0 (Offset = 1390h) [Reset = 00000000h] POLARITY15\_0 is shown in Figure 8-57 and described in Table 8-57. Return to the Summary Table. This register is used to enable and configure the polarity for input edge detection on DIO15 to DIO0. The corresponding DIO bits in RIS register will be set when the input event matches the configured polarity. #### Figure 8-57. POLARITY15\_0 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |-----|------|-----|------------|--------|------|--------|------|--------|------|--------|----|--------|----|--------|----| | DIC | )15 | DIC | )14 | DIO13 | | DIO12 | | DIO11 | | DIO10 | | DIO9 | | DIO8 | | | R/W | /-0h | R/W | /-0h | R/W | /-0h | R/W | /-0h | R/W | /-0h | R/W-0h | | R/W-0h | | R/W-0h | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | DIC | 07 | DIC | <b>D</b> 6 | DI | 05 | DIO4 | | DIO3 | | DIO2 | | DIO1 | | DIO0 | | | R/W | /-0h | R/W | /-0h | R/W-0h | | R/W-0h | | R/W-0h | | R/W-0h | | R/W-0h | | R/W-0h | | # Table 8-57. POLARITY15\_0 Field Descriptions | Bit | Field | Туре | Reset | Description Descriptions | |-------|-------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-30 | DIO15 | R/W | Oh | Enables and configures edge detection polarity for DIO15. 0h = Edge detection disabled 1h = Detects rising edge of input event 2h = Detects falling edge of input event 3h = Detects both rising and falling edge of input event | | 29-28 | DIO14 | R/W | Oh | Enables and configures edge detection polarity for DIO14. 0h = Edge detection disabled 1h = Detects rising edge of input event 2h = Detects falling edge of input event 3h = Detects both rising and falling edge of input event | | 27-26 | DIO13 | R/W | Oh | Enables and configures edge detection polarity for DIO13. 0h = Edge detection disabled 1h = Detects rising edge of input event 2h = Detects falling edge of input event 3h = Detects both rising and falling edge of input event | | 25-24 | DIO12 | R/W | Oh | Enables and configures edge detection polarity for DIO12. 0h = Edge detection disabled 1h = Detects rising edge of input event 2h = Detects falling edge of input event 3h = Detects both rising and falling edge of input event | | 23-22 | DIO11 | R/W | Oh | Enables and configures edge detection polarity for DIO11. 0h = Edge detection disabled 1h = Detects rising edge of input event 2h = Detects falling edge of input event 3h = Detects both rising and falling edge of input event | | 21-20 | DIO10 | R/W | 0h | Enables and configures edge detection polarity for DIO10. 0h = Edge detection disabled 1h = Detects rising edge of input event 2h = Detects falling edge of input event 3h = Detects both rising and falling edge of input event | | 19-18 | DIO9 | R/W | Oh | Enables and configures edge detection polarity for DIO9. 0h = Edge detection disabled 1h = Detects rising edge of input event 2h = Detects falling edge of input event 3h = Detects both rising and falling edge of input event | | 17-16 | DIO8 | R/W | 0h | Enables and configures edge detection polarity for DIO8. Oh = Edge detection disabled 1h = Detects rising edge of input event 2h = Detects falling edge of input event 3h = Detects both rising and falling edge of input event | # Table 8-57. POLARITY15\_0 Field Descriptions (continued) | Bit | Field | Туре | Reset | Description (continued) | |-------|-------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-14 | DIO7 | R/W | 0h | Enables and configures edge detection polarity for DIO7. 0h = Edge detection disabled 1h = Detects rising edge of input event 2h = Detects falling edge of input event 3h = Detects both rising and falling edge of input event | | 13-12 | DIO6 | R/W | 0h | Enables and configures edge detection polarity for DIO6. 0h = Edge detection disabled 1h = Detects rising edge of input event 2h = Detects falling edge of input event 3h = Detects both rising and falling edge of input event | | 11-10 | DIO5 | R/W | 0h | Enables and configures edge detection polarity for DIO5. 0h = Edge detection disabled 1h = Detects rising edge of input event 2h = Detects falling edge of input event 3h = Detects both rising and falling edge of input event | | 9-8 | DIO4 | R/W | 0h | Enables and configures edge detection polarity for DIO4. 0h = Edge detection disabled 1h = Detects rising edge of input event 2h = Detects falling edge of input event 3h = Detects both rising and falling edge of input event | | 7-6 | DIO3 | R/W | 0h | Enables and configures edge detection polarity for DIO3. 0h = Edge detection disabled 1h = Detects rising edge of input event 2h = Detects falling edge of input event 3h = Detects both rising and falling edge of input event | | 5-4 | DIO2 | R/W | 0h | Enables and configures edge detection polarity for DIO2. Oh = Edge detection disabled 1h = Detects rising edge of input event 2h = Detects falling edge of input event 3h = Detects both rising and falling edge of input event | | 3-2 | DIO1 | R/W | 0h | Enables and configures edge detection polarity for DIO1. Oh = Edge detection disabled 1h = Detects rising edge of input event 2h = Detects falling edge of input event 3h = Detects both rising and falling edge of input event | | 1-0 | DIO0 | R/W | 0h | Enables and configures edge detection polarity for DIO0. 0h = Edge detection disabled 1h = Detects rising edge of input event 2h = Detects falling edge of input event 3h = Detects both rising and falling edge of input event | #### 8.3.55 POLARITY31\_16 (Offset = 13A0h) [Reset = 00000000h] POLARITY31\_16 is shown in Figure 8-58 and described in Table 8-58. Return to the Summary Table. This register is used to enable and configure the polarity for input edge detection on DIO31 to DIO16. The corresponding DIO bits in RIS register will be set when the input event matches the configured polarity. #### Figure 8-58. POLARITY31\_16 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |-----|------|-----|-----------|--------|------|-------|---------------|-------|--------|-------|--------|-------|--------|--------|----| | DIC | )31 | DIC | 030 DIO29 | | DIC | DIO28 | | DIO27 | | DIO26 | | )25 | DIO24 | | | | R/W | /-0h | R/W | /-0h | R/W | /-0h | R/W | /-0h | R/W | /-0h | R/V | R/W-0h | | /-0h | R/W-0h | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | DIC | )23 | DIC | )22 | DIO21 | | DIO20 | | DIO19 | | DIO18 | | DIO17 | | DIO16 | | | R/W | /-0h | R/W | /-0h | R/W-0h | | R/W | R/W-0h R/W-0h | | R/W-0h | | R/W-0h | | R/W-0h | | | # Table 8-58. POLARITY31\_16 Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|-------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-30 | DIO31 | R/W | Oh | Enables and configures edge detection polarity for DIO31. 0h = Edge detection disabled 1h = Detects rising edge of input event 2h = Detects falling edge of input event 3h = Detects both rising and falling edge of input event | | 29-28 | DIO30 | R/W | Oh | Enables and configures edge detection polarity for DIO30. 0h = Edge detection disabled 1h = Detects rising edge of input event 2h = Detects falling edge of input event 3h = Detects both rising and falling edge of input event | | 27-26 | DIO29 | R/W | Oh | Enables and configures edge detection polarity for DIO29. 0h = Edge detection disabled 1h = Detects rising edge of input event 2h = Detects falling edge of input event 3h = Detects both rising and falling edge of input event | | 25-24 | DIO28 | R/W | Oh | Enables and configures edge detection polarity for DIO28. Oh = Edge detection disabled 1h = Detects rising edge of input event 2h = Detects falling edge of input event 3h = Detects both rising and falling edge of input event | | 23-22 | DIO27 | R/W | Oh | Enables and configures edge detection polarity for DIO27. Oh = Edge detection disabled 1h = Detects rising edge of input event 2h = Detects falling edge of input event 3h = Detects both rising and falling edge of input event | | 21-20 | DIO26 | R/W | Oh | Enables and configures edge detection polarity for DIO26. Oh = Edge detection disabled 1h = Detects rising edge of input event 2h = Detects falling edge of input event 3h = Detects both rising and falling edge of input event | | 19-18 | DIO25 | R/W | Oh | Enables and configures edge detection polarity for DIO25. 0h = Edge detection disabled 1h = Detects rising edge of input event 2h = Detects falling edge of input event 3h = Detects both rising and falling edge of input event | | 17-16 | DIO24 | R/W | Oh | Enables and configures edge detection polarity for DIO24. 0h = Edge detection disabled 1h = Detects rising edge of input event 2h = Detects falling edge of input event 3h = Detects both rising and falling edge of input event | # Table 8-58. POLARITY31\_16 Field Descriptions (continued) | Bit | Field | Туре | Reset | Description (continued) | |-------|-------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-14 | DIO23 | R/W | 0h | Enables and configures edge detection polarity for DIO23. Oh = Edge detection disabled 1h = Detects rising edge of input event 2h = Detects falling edge of input event 3h = Detects both rising and falling edge of input event | | 13-12 | DIO22 | R/W | 0h | Enables and configures edge detection polarity for DIO22. 0h = Edge detection disabled 1h = Detects rising edge of input event 2h = Detects falling edge of input event 3h = Detects both rising and falling edge of input event | | 11-10 | DIO21 | R/W | 0h | Enables and configures edge detection polarity for DIO21. 0h = Edge detection disabled 1h = Detects rising edge of input event 2h = Detects falling edge of input event 3h = Detects both rising and falling edge of input event | | 9-8 | DIO20 | R/W | 0h | Enables and configures edge detection polarity for DIO20. 0h = Edge detection disabled 1h = Detects rising edge of input event 2h = Detects falling edge of input event 3h = Detects both rising and falling edge of input event | | 7-6 | DIO19 | R/W | 0h | Enables and configures edge detection polarity for DIO19. 0h = Edge detection disabled 1h = Detects rising edge of input event 2h = Detects falling edge of input event 3h = Detects both rising and falling edge of input event | | 5-4 | DIO18 | R/W | 0h | Enables and configures edge detection polarity for DIO18. 0h = Edge detection disabled 1h = Detects rising edge of input event 2h = Detects falling edge of input event 3h = Detects both rising and falling edge of input event | | 3-2 | DIO17 | R/W | 0h | Enables and configures edge detection polarity for DIO17. 0h = Edge detection disabled 1h = Detects rising edge of input event 2h = Detects falling edge of input event 3h = Detects both rising and falling edge of input event | | 1-0 | DIO16 | R/W | 0h | Enables and configures edge detection polarity for DIO16. 0h = Edge detection disabled 1h = Detects rising edge of input event 2h = Detects falling edge of input event 3h = Detects both rising and falling edge of input event | # 8.3.56 CTL (Offset = 1400h) [Reset = 00000000h] CTL is shown in Figure 8-59 and described in Table 8-59. Return to the Summary Table. **GPIO Control Register** Figure 8-59. CTL **Table 8-59. CTL Field Descriptions** | Bit | Field | Туре | Reset | Description | |------|--------------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-1 | RESERVED | R/W | 0h | | | 0 | FASTWAKEONLY | R/W | | FASTWAKEONLY for the global control of fastwake 0h = The global control of fastwake is not enabled, per bit fast wake feature depends on FASTWAKE.DIN 1h = The global control of fastwake is enabled | #### 8.3.57 FASTWAKE (Offset = 1404h) [Reset = 00000000h] FASTWAKE is shown in Figure 8-60 and described in Table 8-60. Return to the Summary Table. This is per bit fast wake enable for the bit slice, allows the GPIO module to stay in a low power state and not require high speed clocking of the input synchronizer or filter #### Figure 8-60. FASTWAKE | | <b>y</b> | | | | | | | | |--------|----------|--------|--------|--------|--------|--------|--------|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | DIN31 | DIN30 | DIN29 | DIN28 | DIN27 | DIN26 | DIN25 | DIN24 | | | R/W-0h | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | DIN23 | DIN22 | DIN21 | DIN20 | DIN19 | DIN18 | DIN17 | DIN16 | | | R/W-0h | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | DIN15 | DIN14 | DIN13 | DIN12 | DIN11 | DIN10 | DIN9 | DIN8 | | | R/W-0h | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | DIN7 | DIN6 | DIN5 | DIN4 | DIN3 | DIN2 | DIN1 | DIN0 | | | R/W-0h | #### Table 8-60. FASTWAKE Field Descriptions | Bit | Field | Туре | Reset | Description | | | | | |-----|-------|------|-------|--------------------------------------------------------------------------------------------------------|--|--|--|--| | 31 | DIN31 | R/W | 0h | Enable fastwake feature for DIN31 0h = fastwake feature is disabled 1h = fastwake feature is enabled | | | | | | 30 | DIN30 | R/W | 0h | Enable fastwake feature for DIN30 Oh = fastwake feature is disabled 1h = fastwake feature is enabled | | | | | | 29 | DIN29 | R/W | 0h | Enable fastwake feature for DIN29 Oh = fastwake feature is disabled 1h = fastwake feature is enabled | | | | | | 28 | DIN28 | R/W | 0h | Enable fastwake feature for DIN29 0h = fastwake feature is disabled 1h = fastwake feature is enabled | | | | | | 27 | DIN27 | R/W | 0h | Enable fastwake feature for DIN27 Oh = fastwake feature is disabled 1h = fastwake feature is enabled | | | | | | 26 | DIN26 | R/W | 0h | Enable fastwake feature for DIN26 0h = fastwake feature is disabled 1h = fastwake feature is enabled | | | | | | 25 | DIN25 | R/W | 0h | Enable fastwake feature for DIN25 Oh = fastwake feature is disabled 1h = fastwake feature is enabled | | | | | | 24 | DIN24 | R/W | 0h | Enable fastwake feature for DIN24 0h = fastwake feature is disabled 1h = fastwake feature is enabled | | | | | | 23 | DIN23 | R/W | 0h | Enable fastwake feature for DIN23 0h = fastwake feature is disabled 1h = fastwake feature is enabled | | | | | | 22 | DIN22 | R/W | 0h | Enable fastwake feature for DIN22 Oh = fastwake feature is disabled 1h = fastwake feature is enabled | | | | | # Table 8-60. FASTWAKE Field Descriptions (continued) | Bit | Field | Type | Reset Description (continued) | | | | | | | | | |-----|--------|---------|-------------------------------|-----------------------------------------------------------------------|--|--|--|--|--|--|--| | | | | | · | | | | | | | | | 21 | DIN21 | R/W | 0h | Enable fastwake feature for DIN21 Oh = fastwake feature is disabled | | | | | | | | | | | | | 1h = fastwake feature is enabled | | | | | | | | | 20 | DIN20 | R/W | 0h | Enable fastwake feature for DIN20 | | | | | | | | | 20 | BIIVEO | | 011 | 0h = fastwake feature is disabled | | | | | | | | | | | | | 1h = fastwake feature is enabled | | | | | | | | | 19 | DIN19 | R/W | 0h | Enable fastwake feature for DIN19 | | | | | | | | | | | | | 0h = fastwake feature is disabled | | | | | | | | | | | | | 1h = fastwake feature is enabled | | | | | | | | | 18 | DIN18 | R/W | 0h | Enable fastwake feature for DIN18 | | | | | | | | | | | | | 0h = fastwake feature is disabled<br>1h = fastwake feature is enabled | | | | | | | | | 17 | DIN17 | R/W | 0h | Enable fastwake feature for DIN17 | | | | | | | | | '' | DINT | 17/00 | OII | 0h = fastwake feature is disabled | | | | | | | | | | | | | 1h = fastwake feature is enabled | | | | | | | | | 16 | DIN16 | R/W | 0h | Enable fastwake feature for DIN16 | | | | | | | | | | | | | 0h = fastwake feature is disabled | | | | | | | | | | | | | 1h = fastwake feature is enabled | | | | | | | | | 15 | DIN15 | R/W | 0h | Enable fastwake feature for DIN15 | | | | | | | | | | | | | 0h = fastwake feature is disabled<br>1h = fastwake feature is enabled | | | | | | | | | 14 | DIN14 | R/W | 0h | Enable fastwake feature for DIN14 | | | | | | | | | 14 | DIN 14 | IN/VV | OII | 0h = fastwake feature is disabled | | | | | | | | | | | | | 1h = fastwake feature is enabled | | | | | | | | | 13 | DIN13 | R/W | 0h | Enable fastwake feature for DIN13 | | | | | | | | | | | | | 0h = fastwake feature is disabled | | | | | | | | | | | | | 1h = fastwake feature is enabled | | | | | | | | | 12 | DIN12 | R/W | 0h | Enable fastwake feature for DIN12 | | | | | | | | | | | | | 0h = fastwake feature is disabled<br>1h = fastwake feature is enabled | | | | | | | | | 11 | DIN11 | R/W | 0h | Enable fastwake feature for DIN11 | | | | | | | | | 11 | DINTI | 17,44 | 011 | 0h = fastwake feature is disabled | | | | | | | | | | | | | 1h = fastwake feature is enabled | | | | | | | | | 10 | DIN10 | R/W | 0h | Enable fastwake feature for DIN10 | | | | | | | | | | | | | 0h = fastwake feature is disabled | | | | | | | | | | | | | 1h = fastwake feature is enabled | | | | | | | | | 9 | DIN9 | R/W | 0h | Enable fastwake feature for DIN9 | | | | | | | | | | | | | 0h = fastwake feature is disabled<br>1h = fastwake feature is enabled | | | | | | | | | 8 | DIN8 | R/W | 0h | Enable fastwake feature for DIN8 | | | | | | | | | | 5.140 | 1.7.4.4 | 011 | Oh = fastwake feature is disabled | | | | | | | | | | | | | 1h = fastwake feature is enabled | | | | | | | | | 7 | DIN7 | R/W | 0h | Enable fastwake feature for DIN7 | | | | | | | | | | | | | 0h = fastwake feature is disabled | | | | | | | | | | | <br> | | 1h = fastwake feature is enabled | | | | | | | | | 6 | DIN6 | R/W | 0h | Enable fastwake feature for DIN6 0h = fastwake feature is disabled | | | | | | | | | | | | | 1h = fastwake feature is disabled | | | | | | | | | 5 | DIN5 | R/W | 0h | Enable fastwake feature for DIN5 | | | | | | | | | | 2 | | " | 0h = fastwake feature is disabled | | | | | | | | | | | | | 1h = fastwake feature is enabled | | | | | | | | | 4 | DIN4 | R/W | 0h | Enable fastwake feature for DIN4 | | | | | | | | | | | | | 0h = fastwake feature is disabled | | | | | | | | | | | | | 1h = fastwake feature is enabled | | | | | | | | | 3 | DIN3 | R/W | 0h | Enable fastwake feature for DIN3 0h = fastwake feature is disabled | | | | | | | | | | | | | 1h = fastwake feature is disabled | | | | | | | | | | | I | l | | | | | | | | | # Table 8-60. FASTWAKE Field Descriptions (continued) | Bit | Field | Туре | Reset | Description | |-----|-------|------|-------|-------------------------------------------------------------------------------------------------------| | 2 | DIN2 | R/W | Oh | Enable fastwake feature for DIN2 0h = fastwake feature is disabled 1h = fastwake feature is enabled | | 1 | DIN1 | R/W | Oh | Enable fastwake feature for DIN1 0h = fastwake feature is disabled 1h = fastwake feature is enabled | | 0 | DIN0 | R/W | Oh | Enable fastwake feature for DIN0 0h = fastwake feature is disabled 1h = fastwake feature is enabled | #### 8.3.58 SUB0CFG (Offset = 1500h) [Reset = 00000000h] SUB0CFG is shown in Figure 8-61 and described in Table 8-61. Return to the Summary Table. This register is used to enable the subscriber 0 event and define the output policy on the selected DIO 0-15 pins. Figure 8-61. SUB0CFG Table 8-61. SUB0CFG Field Descriptions | Bit | Field | Туре | Reset | Description | | | | | | | | | | |-------|-----------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--| | 31-20 | RESERVED | R/W | 0h | | | | | | | | | | | | 19-16 | INDEX | R/W | Oh | Indicates the specific bit among lower 16 bits that is targeted by the subscriber action 0h = specific bit targeted by the subscriber action is bit0 Fh = specific bit targeted by the subscriber action is bit15 | | | | | | | | | | | 15-10 | RESERVED | R/W | 0h | | | | | | | | | | | | 9-8 | OUTPOLICY | R/W | Oh | These bits configure the output policy for subscriber 0 event. 0h = Selected DIO pins are set 1h = Selected DIO pins are cleared 2h = Selected DIO pins are toggled | | | | | | | | | | | 7-1 | RESERVED | R/W | 0h | | | | | | | | | | | | 0 | ENABLE | R/W | Oh | This bit is used to enable subscriber 0 event. 0h = Subscriber 0 event is disabled 1h = Subscriber 0 event is enabled | | | | | | | | | | # 8.3.59 FILTEREN15\_0 (Offset = 1508h) [Reset = 00000000h] FILTEREN15\_0 is shown in Figure 8-62 and described in Table 8-62. Return to the Summary Table. Programmable counter length of digital glitch filter for DIN0-DIN15 #### Figure 8-62. FILTEREN15\_0 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | |-----|------|--------|------|--------|------|-----|--------|-----|--------|-----|--------|-----|--------|--------|--------|--| | DIN | N15 | DIN | N14 | DIN | N13 | DIN | N12 | DII | N11 | DII | N10 | DI | N9 | DII | DIN8 | | | R/W | /-0h | R/W | /-0h | R/W | /-0h | R/W | /-0h | R/V | V-0h | R/V | V-0h | R/V | V-0h | R/W-0h | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | DII | N7 | DII | N6 | DI | N5 | DI | N4 | DI | N3 | DI | N2 | DI | N1 | DII | N0 | | | R/W | /-0h | R/W-0h | | R/W-0h | | R/W | R/W-0h | | R/W-0h | | R/W-0h | | R/W-0h | | R/W-0h | | | | | | | | | | | | | | | | | | | | #### Table 8-62. FILTEREN15\_0 Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|-------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-30 | DIN15 | R/W | 0h | Programmable counter length of digital glitch filter for DIN15 0h = No additional filter beyond the CDC synchronization sample 1h = 1 ULPCLK minimum sample 2h = 3 ULPCLK minimum sample 3h = 8 ULPCLK minimum sample | | 29-28 | DIN14 | R/W | 0h | Programmable counter length of digital glitch filter for DIN14 0h = No additional filter beyond the CDC synchronization sample 1h = 1 ULPCLK minimum sample 2h = 3 ULPCLK minimum sample 3h = 8 ULPCLK minimum sample | | 27-26 | DIN13 | R/W | 0h | Programmable counter length of digital glitch filter for DIN13 0h = No additional filter beyond the CDC synchronization sample 1h = 1 ULPCLK minimum sample 2h = 3 ULPCLK minimum sample 3h = 8 ULPCLK minimum sample | | 25-24 | DIN12 | R/W | 0h | Programmable counter length of digital glitch filter for DIN12 0h = No additional filter beyond the CDC synchronization sample 1h = 1 ULPCLK minimum sample 2h = 3 ULPCLK minimum sample 3h = 8 ULPCLK minimum sample | | 23-22 | DIN11 | R/W | 0h | Programmable counter length of digital glitch filter for DIN11 0h = No additional filter beyond the CDC synchronization sample 1h = 1 ULPCLK minimum sample 2h = 3 ULPCLK minimum sample 3h = 8 ULPCLK minimum sample | | 21-20 | DIN10 | R/W | 0h | Programmable counter length of digital glitch filter for DIN10 0h = No additional filter beyond the CDC synchronization sample 1h = 1 ULPCLK minimum sample 2h = 3 ULPCLK minimum sample 3h = 8 ULPCLK minimum sample | | 19-18 | DIN9 | R/W | 0h | Programmable counter length of digital glitch filter for DIN9 0h = No additional filter beyond the CDC synchronization sample 1h = 1 ULPCLK minimum sample 2h = 3 ULPCLK minimum sample 3h = 8 ULPCLK minimum sample | | 17-16 | DIN8 | R/W | 0h | Programmable counter length of digital glitch filter for DIN8 0h = No additional filter beyond the CDC synchronization sample 1h = 1 ULPCLK minimum sample 2h = 3 ULPCLK minimum sample 3h = 8 ULPCLK minimum sample | # Table 8-62. FILTEREN15\_0 Field Descriptions (continued) | Bit | Field | Туре | Reset | Description (Continued) | |-------|-------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-14 | DIN7 | R/W | Oh | Programmable counter length of digital glitch filter for DIN7 0h = No additional filter beyond the CDC synchronization sample 1h = 1 ULPCLK minimum sample 2h = 3 ULPCLK minimum sample 3h = 8 ULPCLK minimum sample | | 13-12 | DIN6 | R/W | Oh | Programmable counter length of digital glitch filter for DIN6 0h = No additional filter beyond the CDC synchronization sample 1h = 1 ULPCLK minimum sample 2h = 3 ULPCLK minimum sample 3h = 8 ULPCLK minimum sample | | 11-10 | DIN5 | R/W | Oh | Programmable counter length of digital glitch filter for DIN5 0h = No additional filter beyond the CDC synchronization sample 1h = 1 ULPCLK minimum sample 2h = 3 ULPCLK minimum sample 3h = 8 ULPCLK minimum sample | | 9-8 | DIN4 | R/W | Oh | Programmable counter length of digital glitch filter for DIN4 0h = No additional filter beyond the CDC synchronization sample 1h = 1 ULPCLK minimum sample 2h = 3 ULPCLK minimum sample 3h = 8 ULPCLK minimum sample | | 7-6 | DIN3 | R/W | Oh | Programmable counter length of digital glitch filter for DIN3 0h = No additional filter beyond the CDC synchronization sample 1h = 1 ULPCLK minimum sample 2h = 3 ULPCLK minimum sample 3h = 8 ULPCLK minimum sample | | 5-4 | DIN2 | R/W | Oh | Programmable counter length of digital glitch filter for DIN2 0h = No additional filter beyond the CDC synchronization sample 1h = 1 ULPCLK minimum sample 2h = 3 ULPCLK minimum sample 3h = 8 ULPCLK minimum sample | | 3-2 | DIN1 | R/W | Oh | Programmable counter length of digital glitch filter for DIN1 0h = No additional filter beyond the CDC synchronization sample 1h = 1 ULPCLK minimum sample 2h = 3 ULPCLK minimum sample 3h = 8 ULPCLK minimum sample | | 1-0 | DIN0 | R/W | Oh | Programmable counter length of digital glitch filter for DIN0 0h = No additional filter beyond the CDC synchronization sample 1h = 1 ULPCLK minimum sample 2h = 3 ULPCLK minimum sample 3h = 8 ULPCLK minimum sample | # 8.3.60 FILTEREN31\_16 (Offset = 150Ch) [Reset = 00000000h] FILTEREN31\_16 is shown in Figure 8-63 and described in Table 8-63. Return to the Summary Table. Programmable counter length of digital glitch filter for DIN16-DIN31 #### Figure 8-63. FILTEREN31\_16 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |------|-----|-----|------|--------|------|--------|-------------|--------|------|--------|------|--------|------|--------|----| | DIN: | 31 | DIN | 130 | DIN | 129 | DIN | 128 | DIN | N27 | DIN | N26 | DIN | N25 | DIN24 | | | R/W- | -0h | R/W | ′-0h | R/W | /-0h | R/M | /-0h | R/W | /-0h | R/V | /-0h | R/V | V-0h | R/W-0h | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | DIN: | 23 | DIN | 122 | DIN | N21 | DIN | DIN20 DIN19 | | N19 | DIN18 | | DIN17 | | DIN16 | | | R/W- | -0h | R/W | ′-0h | R/W-0h | | R/W-0h | | R/W-0h | | R/W-0h | | R/W-0h | | R/W-0h | | # Table 8-63. FILTEREN31\_16 Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|-------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-30 | DIN31 | R/W | 0h | Programmable counter length of digital glitch filter for DIN31 0h = No additional filter beyond the CDC synchronization sample 1h = 1 ULPCLK minimum sample 2h = 3 ULPCLK minimum sample 3h = 8 ULPCLK minimum sample | | 29-28 | DIN30 | R/W | Oh | Programmable counter length of digital glitch filter for DIN30 0h = No additional filter beyond the CDC synchronization sample 1h = 1 ULPCLK minimum sample 2h = 3 ULPCLK minimum sample 3h = 8 ULPCLK minimum sample | | 27-26 | DIN29 | R/W | Oh | Programmable counter length of digital glitch filter for DIN29 0h = No additional filter beyond the CDC synchronization sample 1h = 1 ULPCLK minimum sample 2h = 3 ULPCLK minimum sample 3h = 8 ULPCLK minimum sample | | 25-24 | DIN28 | R/W | Oh | Programmable counter length of digital glitch filter for DIN28 0h = No additional filter beyond the CDC synchronization sample 1h = 1 ULPCLK minimum sample 2h = 3 ULPCLK minimum sample 3h = 8 ULPCLK minimum sample | | 23-22 | DIN27 | R/W | Oh | Programmable counter length of digital glitch filter for DIN27 0h = No additional filter beyond the CDC synchronization sample 1h = 1 ULPCLK minimum sample 2h = 3 ULPCLK minimum sample 3h = 8 ULPCLK minimum sample | | 21-20 | DIN26 | R/W | Oh | Programmable counter length of digital glitch filter for DIN26 0h = No additional filter beyond the CDC synchronization sample 1h = 1 ULPCLK minimum sample 2h = 3 ULPCLK minimum sample 3h = 8 ULPCLK minimum sample | | 19-18 | DIN25 | R/W | 0h | Programmable counter length of digital glitch filter for DIN25 0h = No additional filter beyond the CDC synchronization sample 1h = 1 ULPCLK minimum sample 2h = 3 ULPCLK minimum sample 3h = 8 ULPCLK minimum sample | | 17-16 | DIN24 | R/W | 0h | Programmable counter length of digital glitch filter for DIN24 0h = No additional filter beyond the CDC synchronization sample 1h = 1 ULPCLK minimum sample 2h = 3 ULPCLK minimum sample 3h = 8 ULPCLK minimum sample | # Table 8-63. FILTEREN31\_16 Field Descriptions (continued) | Bit | Field | Туре | Reset | Description (continued) | |-------|-------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-14 | DIN23 | R/W | Oh | Programmable counter length of digital glitch filter for DIN23 0h = No additional filter beyond the CDC synchronization sample 1h = 1 ULPCLK minimum sample 2h = 3 ULPCLK minimum sample 3h = 8 ULPCLK minimum sample | | 13-12 | DIN22 | R/W | Oh | Programmable counter length of digital glitch filter for DIN22 0h = No additional filter beyond the CDC synchronization sample 1h = 1 ULPCLK minimum sample 2h = 3 ULPCLK minimum sample 3h = 8 ULPCLK minimum sample | | 11-10 | DIN21 | R/W | Oh | Programmable counter length of digital glitch filter for DIN21 0h = No additional filter beyond the CDC synchronization sample 1h = 1 ULPCLK minimum sample 2h = 3 ULPCLK minimum sample 3h = 8 ULPCLK minimum sample | | 9-8 | DIN20 | R/W | Oh | Programmable counter length of digital glitch filter for DIN20 0h = No additional filter beyond the CDC synchronization sample 1h = 1 ULPCLK minimum sample 2h = 3 ULPCLK minimum sample 3h = 8 ULPCLK minimum sample | | 7-6 | DIN19 | R/W | Oh | Programmable counter length of digital glitch filter for DIN19 0h = No additional filter beyond the CDC synchronization sample 1h = 1 ULPCLK minimum sample 2h = 3 ULPCLK minimum sample 3h = 8 ULPCLK minimum sample | | 5-4 | DIN18 | R/W | Oh | Programmable counter length of digital glitch filter for DIN18 0h = No additional filter beyond the CDC synchronization sample 1h = 1 ULPCLK minimum sample 2h = 3 ULPCLK minimum sample 3h = 8 ULPCLK minimum sample | | 3-2 | DIN17 | R/W | Oh | Programmable counter length of digital glitch filter for DIN17 0h = No additional filter beyond the CDC synchronization sample 1h = 1 ULPCLK minimum sample 2h = 3 ULPCLK minimum sample 3h = 8 ULPCLK minimum sample | | 1-0 | DIN16 | R/W | Oh | Programmable counter length of digital glitch filter for DIN16 0h = No additional filter beyond the CDC synchronization sample 1h = 1 ULPCLK minimum sample 2h = 3 ULPCLK minimum sample 3h = 8 ULPCLK minimum sample | # 8.3.61 DMAMASK (Offset = 1510h) [Reset = 00000000h] DMAMASK is shown in Figure 8-64 and described in Table 8-64. Return to the Summary Table. DMA MASK which indicates which bit lanes the DMA is allowed to modify. #### Figure 8-64. DMAMASK | | | | J | | | | | |--------|--------|--------|--------|--------|--------|--------|--------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | DOUT31 | DOUT30 | DOUT29 | DOUT28 | DOUT27 | DOUT26 | DOUT25 | DOUT24 | | R/W-0h | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | DOUT23 | DOUT22 | DOUT21 | DOUT20 | DOUT19 | DOUT18 | DOUT17 | DOUT16 | | R/W-0h | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | DOUT15 | DOUT14 | DOUT13 | DOUT12 | DOUT11 | DOUT10 | DOUT9 | DOUT8 | | R/W-0h | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | DOUT7 | DOUT6 | DOUT5 | DOUT4 | DOUT3 | DOUT2 | DOUT1 | DOUT0 | | R/W-0h #### Table 8-64. DMAMASK Field Descriptions | Bit | Field | Туре | Reset | Description | |-----|--------|------|-------|-------------------------------------------------------------------------------------------------------------------------------| | 31 | DOUT31 | R/W | 0h | DMA is allowed to modify DOUT31 Oh = DMA is not allowed to modify this bit lane 1h = DMA is allowed to modify this bit lane | | 30 | DOUT30 | R/W | 0h | DMA is allowed to modify DOUT30 Oh = DMA is not allowed to modify this bit lane 1h = DMA is allowed to modify this bit lane | | 29 | DOUT29 | R/W | 0h | DMA is allowed to modify DOUT29 Oh = DMA is not allowed to modify this bit lane 1h = DMA is allowed to modify this bit lane | | 28 | DOUT28 | R/W | 0h | DMA is allowed to modify DOUT28 0h = DMA is not allowed to modify this bit lane 1h = DMA is allowed to modify this bit lane | | 27 | DOUT27 | R/W | 0h | DMA is allowed to modify DOUT27 Oh = DMA is not allowed to modify this bit lane 1h = DMA is allowed to modify this bit lane | | 26 | DOUT26 | R/W | 0h | DMA is allowed to modify DOUT26 Oh = DMA is not allowed to modify this bit lane 1h = DMA is allowed to modify this bit lane | | 25 | DOUT25 | R/W | 0h | DMA is allowed to modify DOUT25 Oh = DMA is not allowed to modify this bit lane 1h = DMA is allowed to modify this bit lane | | 24 | DOUT24 | R/W | 0h | DMA is allowed to modify DOUT24 Oh = DMA is not allowed to modify this bit lane 1h = DMA is allowed to modify this bit lane | | 23 | DOUT23 | R/W | 0h | DMA is allowed to modify DOUT23 Oh = DMA is not allowed to modify this bit lane 1h = DMA is allowed to modify this bit lane | | 22 | DOUT22 | R/W | 0h | DMA is allowed to modify DOUT22 Oh = DMA is not allowed to modify this bit lane 1h = DMA is allowed to modify this bit lane | # Table 8-64. DMAMASK Field Descriptions (continued) | Bit | Bit Field Type Reset Description (continued) | | | | | | |-----|----------------------------------------------|-------|-----|-------------------------------------------------------------------------------------------------------------------------------|--|--| | 21 | DOUT21 | R/W | 0h | DMA is allowed to modify DOUT21 | | | | 21 | 000121 | IN/VV | OII | Oh = DMA is not allowed to modify this bit lane 1h = DMA is allowed to modify this bit lane | | | | 20 | DOUT20 | R/W | 0h | DMA is allowed to modify DOUT20 Oh = DMA is not allowed to modify this bit lane 1h = DMA is allowed to modify this bit lane | | | | 19 | DOUT19 | R/W | 0h | DMA is allowed to modify DOUT19 Oh = DMA is not allowed to modify this bit lane 1h = DMA is allowed to modify this bit lane | | | | 18 | DOUT18 | R/W | 0h | DMA is allowed to modify DOUT18 Oh = DMA is not allowed to modify this bit lane 1h = DMA is allowed to modify this bit lane | | | | 17 | DOUT17 | R/W | 0h | DMA is allowed to modify DOUT17 Oh = DMA is not allowed to modify this bit lane 1h = DMA is allowed to modify this bit lane | | | | 16 | DOUT16 | R/W | 0h | DMA is allowed to modify DOUT16 Oh = DMA is not allowed to modify this bit lane 1h = DMA is allowed to modify this bit lane | | | | 15 | DOUT15 | R/W | 0h | DMA is allowed to modify DOUT15 Oh = DMA is not allowed to modify this bit lane 1h = DMA is allowed to modify this bit lane | | | | 14 | DOUT14 | R/W | 0h | DMA is allowed to modify DOUT14 Oh = DMA is not allowed to modify this bit lane 1h = DMA is allowed to modify this bit lane | | | | 13 | DOUT13 | R/W | 0h | DMA is allowed to modify DOUT13 Oh = DMA is not allowed to modify this bit lane 1h = DMA is allowed to modify this bit lane | | | | 12 | DOUT12 | R/W | 0h | DMA is allowed to modify DOUT12 Oh = DMA is not allowed to modify this bit lane 1h = DMA is allowed to modify this bit lane | | | | 11 | DOUT11 | R/W | 0h | DMA is allowed to modify DOUT11 Oh = DMA is not allowed to modify this bit lane 1h = DMA is allowed to modify this bit lane | | | | 10 | DOUT10 | R/W | 0h | DMA is allowed to modify DOUT10 0h = DMA is not allowed to modify this bit lane 1h = DMA is allowed to modify this bit lane | | | | 9 | DOUT9 | R/W | 0h | DMA is allowed to modify DOUT9 0h = DMA is not allowed to modify this bit lane 1h = DMA is allowed to modify this bit lane | | | | 8 | DOUT8 | R/W | 0h | DMA is allowed to modify DOUT8 0h = DMA is not allowed to modify this bit lane 1h = DMA is allowed to modify this bit lane | | | | 7 | DOUT7 | R/W | 0h | DMA is allowed to modify DOUT7 0h = DMA is not allowed to modify this bit lane 1h = DMA is allowed to modify this bit lane | | | | 6 | DOUT6 | R/W | 0h | DMA is allowed to modify DOUT6 0h = DMA is not allowed to modify this bit lane 1h = DMA is allowed to modify this bit lane | | | | 5 | DOUT5 | R/W | 0h | DMA is allowed to modify DOUT5 0h = DMA is not allowed to modify this bit lane 1h = DMA is allowed to modify this bit lane | | | | 4 | DOUT4 | R/W | 0h | DMA is allowed to modify DOUT4 0h = DMA is not allowed to modify this bit lane 1h = DMA is allowed to modify this bit lane | | | | 3 | DOUT3 | R/W | 0h | DMA is allowed to modify DOUT3 Oh = DMA is not allowed to modify this bit lane 1h = DMA is allowed to modify this bit lane | | | # Table 8-64. DMAMASK Field Descriptions (continued) | Bit | Field | Туре | Reset | Description | |-----|-------|------|-------|-----------------------------------------------------------------------------------------------------------------------------| | 2 | DOUT2 | R/W | 0h | DMA is allowed to modify DOUT2 0h = DMA is not allowed to modify this bit lane 1h = DMA is allowed to modify this bit lane | | 1 | DOUT1 | R/W | Oh | DMA is allowed to modify DOUT1 0h = DMA is not allowed to modify this bit lane 1h = DMA is allowed to modify this bit lane | | 0 | DOUT0 | R/W | 0h | DMA is allowed to modify DOUT0 0h = DMA is not allowed to modify this bit lane 1h = DMA is allowed to modify this bit lane | #### 8.3.62 SUB1CFG (Offset = 1520h) [Reset = 00000000h] SUB1CFG is shown in Figure 8-65 and described in Table 8-65. Return to the Summary Table. This register is used to enable the subscriber 1 event and define the output policy on the selected DIO 16-31 pins. Figure 8-65. SUB1CFG # Table 8-65. SUB1CFG Field Descriptions | Bit | Field | Туре | Reset | Description | | | |-------|-----------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | 31-20 | RESERVED | R/W | 0h | | | | | 19-16 | INDEX | R/W | 0h | indicates the specific bit in the upper 16 bits that is targeted by the subscriber action 0h = specific bit targeted by the subscriber action is bit16 Fh = specific bit targeted by the subscriber action is bit31 | | | | 15-10 | RESERVED | R/W | 0h | | | | | 9-8 | OUTPOLICY | R/W | 0h | These bits configure the output policy for subscriber 1 event. 0h = Selected DIO pins are set 1h = Selected DIO pins are cleared 2h = Selected DIO pins are toggled | | | | 7-1 | RESERVED | R/W | 0h | | | | | 0 | ENABLE | R/W | 0h | This bit is used to enable subscriber 1 event. 0h = Subscriber 1 event is disabled 1h = Subscriber 1 event is enabled | | | # Chapter 9 **ADC** The ADC is a high-performance successive-approximation-register (SAR) analog-to-digital converter. This chapter describes the features and operation of the ADC peripheral. | 9.1 ADC Overview | 498 | |---------------------|-----| | | | | 9.2 ADC Operation | 499 | | 9.3 ADC12 Registers | 515 | | <b>-</b> | | ADC www.ti.com #### 9.1 ADC Overview The ADC supports measure analog signals and convert them to a digital representation with minimal CPU intervention. The ADC supports fast 12-, 10-, and 8-bit analog-to-digital conversions. It implements a 12-bit SAR core, sample and conversion mode control, and up to 4 independent conversion-and-control buffers. The ADC allows up to 4 independent analog-to-digital converter (ADC) samples to be converted and stored without any CPU intervention. #### ADC features include: - 1.68-Msps conversion rate at a resolution of 12 bits - Integrated hardware oversampling for averaging up to 128 samples - · Full-scale ADC operating voltage range - Sample-and-hold with programmable sampling periods controlled by software or timers - Two sampling trigger sources: software trigger and event trigger - Software-selectable on-chip reference voltage of 1.4 V or 2.5 V - Configurable ADC reference source: VDD, internal reference (VREF), or external reference (VREF+ and VREF-) - · Up to 16 individually configurable analog input channels - Internal conversion channels for temperature sensing, supply monitoring, and analog signal chain (see the device-specific data sheet for availability and channel mapping) - Configurable ADC clock source - Single-channel, repeat-single-channel, sequence (autoscan), and repeat-sequence (repeated autoscan) conversion modes - 4 conversion-result storage registers (MEMRES0:3) - · Window comparator for low-power monitoring of input signals from conversion-result registers - DMA support with interrupt event generation on completion of transfer - · Operates in RUN, SLEEP, and STOP modes - · Can be triggered in any operating mode except for SHUTDOWN - Automatic power, reference, and clock control for low-power operation - · Semi-automatic calibration of CDAC trim values Figure 9-1 shows the functional block diagram of the ADC peripheral. Figure 9-1. ADC Block Diagram www.ti.com ADC #### 9.2 ADC Operation The ADC is configured with user software. The following sections describe the setup and operation of the ADC. #### Note The ADC result registers (MEMRES) are aliased between two address regions on the device: - The primary region, through which all ADC registers can be accessed by the CPU or DMA at the ULPCLK rate - The aliased region, through which the ADC MEMRES registers can be accessed by the CPU or DMA at the MCLK rate for fast read-out of ADC results On devices which run MCLK and ULPCLK at the same frequency, there is not a performance benefit to accessing the ADC MEMRES registers through the aliased region. On device configurations where MCLK is greater than ULPCLK, the aliased region is recommended to be used. However, application software can use the aliased region on all devices for MEMRES access to keep the software implementation consistent. #### 9.2.1 ADC Core The ADC core converts an analog input to its digital representation. The core uses two voltage levels ( $V_{R+}$ and $V_{R-}$ ) to define the upper and lower limits of the conversion. The digital output ( $N_{ADC}$ ) is full scale when the input ADC www.ti.com signal is equal to or higher than $V_{R+}$ , and is zero when the input signal is equal to or lower than $V_{R-}$ . The input channel and the positive reference voltage level ( $V_{R+}$ ) are defined in the conversion-control memory. Equation 7 below shows the conversion formula for the ADC result, N<sub>ADC</sub>, for n-bit resolution mode. $$N_{ADC} = \left(2^{n} - 1\right) \times \frac{(V_{in} + 0.5LSB) - V_{R-}}{V_{R+} - V_{R-}}$$ Where, LSB = $\frac{V_{R+} - V_{R-}}{2^{n}}$ (7) #### Note The supported $V_{R-}$ for this ADC is 0V. All subsequent equations and sections will reflect this inherent property. Given that $V_{R-}$ is 0V in this ADC, the equation for $N_{ADC}$ becomes: $$N_{ADC} = \left(2^{n} - 1\right) \times \frac{\left(V_{in} + 0.5 LSB\right)}{V_{R} +} \qquad Where, \quad LSB = \frac{V_{R} + 1}{2^{n}}$$ (8) Equation 9 below describes the input voltage at which the ADC output saturates: $$V_{in} = V_{R+} - 1.5LSB \tag{9}$$ #### Note The ADC is NOT functional in STANDBY or SHUTDOWN mode. #### 9.2.2 Voltage Reference Options The ADC voltage reference ( $V_{R+}$ ) can be configured through the VRSEL bits in the MEMCTL register. Different reference sources can be selected for conversion on different channels. There are three options available for supplying a reference voltage to the ADC: - 1. External reference supplied to the ADC through the VREF+ and VREF- pins - 2. MCU supply voltage (VDD) - 3. Configurable internal reference voltage of 1.4 V and 2.5 V (VREF) When supplying an external reference to the ADC, connect the VREF+ pin to the reference source with the appropriate decoupling circuitry, and connect the VREF- pin to ground. The internal reference (VREF) is a dedicated voltage reference module for the ADC peripheral and does not require external decoupling circuitry to operate. When supplying the internal reference as the reference to the ADC, the maximum ADC sampling rate is limited to approximately 200 ksps. #### 9.2.3 Generic Resolution Modes The ADC supports operation in 12-bit (default), 10-bit, and 8-bit resolution modes. The resolution mode is configured using the RES bits in the CTL2 register. - When 12-bit mode is selected, the conversion phase requires a total of 14 conversion clock cycles - When 10-bit mode is selected, the conversion phase requires a total of 12 conversion clock cycles - When 8-bit mode is selected, the conversion phase requires a total of 9 conversion clock cycles #### 9.2.4 Hardware Averaging This ADC implements digital sample averaging in hardware (HW averaging) to efficiently increase the effective resolution of the ADC without the need for SW or CPU intervention. The HW averaging functionality is configured using the AVGN and AVGD bits in the CTL1 register. - AVGN defines the number of conversions to accumulate for the current MEMCTLx - · AVGD defines what the accumulated value gets divided by using bit shifting www.ti.com ADC #### Note The MEMRES result register is a maximum of 16 bits long. If not shifted appropriately, the result will be truncated. Table 9-1. Available Hardware Averaging Settings | Bit Field Value | AVGN Settings (number of samples accumulated) | AVGD Settings (number of bits to right shift) | |-----------------|-----------------------------------------------|-----------------------------------------------| | 0x0 | 0 | 0 | | 0x1 | 2 | 1 | | 0x2 | 4 | 2 | | 0x3 | 8 | 3 | | 0x4 | 16 | 4 | | 0x5 | 32 | 5 | | 0x6 | 64 | 6 | | 0x7 | 128 | 7 | The averaging configuration is global and it holds for any channel that enables the averaging feature. It is not possible to have different averaging configurations defined per channel. The averaging feature for each individual channel can be enabled though the AVGEN bit in the MEMCTL register. When the sample trigger is received for a channel with averaging enabled, the required number of conversions are performed automatically back-to-back and the final averaged value is stored in the MEMRES register or FIFODAT. #### Note The data format must be selected as unsigned binary while using the hardware averaging feature. #### 9.2.5 ADC Clocking The ADC peripheral clock (ADCCLK) is provided by the Section 2.4 and is used for both sampling and conversion. SYSOSC and ULPCLK are the available clock sources available for ADCCLK, which can support up to 32Mhz. Refer to the device-specific data sheet for supported ADCCLK frequencies. Using the ULPCLK, which is the bus clock for all peripherals, is very useful for deterministic start of sampling. The ADC clock source can be selected by programming the SAMPCLK bits in the CLKCFG register. SYSOSC needs to be active for the ADC to operate properly. If SYSOSC is not running and the ADC is triggered, the ADC will automatically request SYSCTL to enable and set SYSOSC to base frequency during the conversion. If SYSOSC is already enabled, it will remain the same frequency. The only exception to this is in STOP1 operating mode where SYSOSC will go to base frequency when the ADC is triggered. In order to provide a way to ensure predictable sample rate operation between power modes, the CCONRUN and CCONSTOP bits can be set to signal the ADC that it can expect that the SYSOSC will already be ON when the device is in RUN and STOP modes respectively. When these bits are set, the ADC will not wait for an ACK from SYSCTL to make sure SYSOSC is running before starting sampling. This feature gives users the flexibility to save power in applications where deterministic sample timing is not a requirement. Refer to Section 9.2.6 for examples on how to properly use the CCONRUN and CCONSTOP control bits. The user must configure the FRANGE bits in the CLKFREQ register to the appropriate setting based on the expected ADCCLK frequency. See Table 9-2 below for more details on how to properly configure the CLKFREQ register. Table 9-2. CLKFREQ Register Configuration | CLKFREQ.FRANGE Values | ADCCLK Frequency Range (MHz) | |-----------------------|------------------------------| | 0 | >1 to 4 | | 1 | >4 to 8 | | 2 | >8 to 16 | | 3 | >16 to 20 | ADC www.ti.com | Table 9-2. CLKFREC | Register Confi | guration ( | (continued) | ) | |--------------------|----------------|------------|-------------|---| | | | | | | | CLKFREQ.FRANGE Values | ADCCLK Frequency Range (MHz) | |-----------------------|------------------------------| | 4 | >20 to 24 | | 5 | >24 to 32 | When the internal voltage reference is used for ADC operation, the conversion clock (CONVCLK) frequency is not to exceed 4 MHz. This requirement is satisfied using clock dividers that are applied on ADCCLK based on CLKFREQ. When CLKFREQ.FRANGE is set to a value from 0 to 5 and the internal voltage reference is not used, the ADCCLK is used directly as CONVCLK. When CLKFREQ.FRANGE is set to 6 or 7 and the internal voltage reference is not used, the ADCCLK is divided by 2 and then used as CONVCLK. The conversion clock generation from ADCCLK for various CLKFREQ.FRANGE values and reference selections are depicted below. Figure 9-2. ADC Conversion Clock Generation Logic #### 9.2.6 Common ADC Use Cases There are many ADC use-cases from an operating mode and clocking standpoint but the majority of them will fit into one of the items below: - Triggers in RUN or SLEEP mode - If ADC is triggered to start a conversion (SW or Event), and the device is in RUN0 or RUN1 or SLEEP0 or SLEEP1 mode (SYSOSC is already running at any frequency), then: - · Sample clock can be ULPCLK, or SYSOSC in this mode - · The conversion will run without changing SYSOSC frequency - 4-MHz, 16-MHz, 24-MHz, or 32-MHz SYSOSC frequencies are allowed - If ADC is triggered to start a conversion (SW or Event), and the device is in RUN2 or SLEEP2 mode (SYSOSC is disabled, MCLK = LFCLK = 32 kHz), then: - Sample clock can be ULPCLK or SYSOSC in this mode - SYSCTL will interpret the ADC CLK REQ as an asynchronous fast clock request, enabling SYSOSC at 32 MHz and forcing MCLK or ULPCLK to 32 MHz until the ADC de-asserts the request www.ti.com ADC - CCONRUN must be cleared in this use case - CCONSTOP must be cleared in this use case - · Triggers in STOP mode - Sample clock can be ULPCLK or SYSOSC in this mode - If ADC is triggered to start a conversion (Event), and the device is in STOP0 mode (SYSOSC runs at any frequency, ULPCLK=4 MHz), then: - The conversion will run without changing SYSOSC frequency - 4-MHz, 16-MHz, 24-MHz, or 32-MHz SYSOSC frequencies are allowed - If ADC is triggered to start a conversion (Event), and the device is in STOP1 mode (SYSOSC was gear shifted to 4 MHz), then: - SYSCTL will force SYSOSC to BASE (consistent with RUN mode since USE4MHZSTOP was set) when receiving ADC CLK REQ, and SYSCTL will release SYSOSC back to 4 MHz after the ADC CLK REQ is removed - CCONRUN must be cleared - CCONSTOP must be cleared - If ADC is triggered to start a conversion (Event), and the device is in STOP2 mode (SYSOSC disabled), then: - The trigger event propagates through the event fabric at 32 kHz, the ADC receives the trigger and assert the ADC CLK REQ (CPCLK REQ) to SYSCTL, and SYSCTL receives the ADC CLK REQ as an asynchronous fast clock request, suspending STOP, enabling SYSOSC at 32 MHz, and forcing MCLK or ULPCLK to 32 MHz until the ADC de-asserts the ADC CLK REQ - · CCONRUN must be cleared - · CCONSTOP must be cleared - · Triggers in STANDBY mode - Sample clock can be ULPCLK or SYSOSC in this mode - If ADC is triggered to start a conversion (Event), and the device is in STANDBY0 mode (SYSOSC is disabled but ULPCLK is running), then: - The trigger event will propagate through event fabric at 32 kHz, the ADC will see the trigger and assert the ADC CLK REQ (CPCLK REQ) to SYSCTL, and SYSCTL will interpret the ADC CLK REQ as an asynchronous fast clock request, suspending STANDBY, enabling SYSOSC at 32 MHz, and forcing MCLK/ULPCLK to 32 MHz until the ADC de-asserts the ADC CLK REQ - CCONRUN must be cleared - CCONSTOP must be cleared - If ADC is triggered to start a conversion (Event-TIMG0 or TIMG1), and the device is in STANDBY1 (ULPCLK is gated with STOPCLKSTBY set), then: - The TIMG0 or TIMG1 event itself will trigger an asynchronous fast clock request to suspend STANDBY mode, start SYSOSC at 32 MHz, and force MCLK or ULPCLK to 32 MHz; there are then 32 SYSOSC cycles for the TIMG0 or TIMG1 event to proceed through the event fabric and for the ADC to capture the timer event and assert the ADC CLK REQ to hold the SYSOSC enabled to run the conversion - When the ADC de-asserts the ADC CLK REQ, ULPCLK will run for 32 additional cycles to allow any ADC event (DMA request or IRQ) to propagate, after which SYSCTL resumes STANDBY with STOPCLKSTBY (STANDBY1) - CCONRUN must be cleared - CCONSTOP must be cleared #### 9.2.7 Power Down Behavior The ENABLE bit in the PWREN register enables or disables the ADC peripheral. The ADC should be disabled when it is not in use to save power. The PWRDN bit in the CTL0 register selects the ADC power down policy between AUTO and MANUAL. This takes effect when the ADC operates in RUN, SLEEP, and STOP MCU power modes. PWRDN should be configured based on the max ADC sampling rate required and the operational needs in different MCU power modes. ADC hardware does not force the power down policy to AUTO during operation in STOP mode. It follows the user setting irrespective of the device power modes. ADC www.ti.com The reset value of PWRDN is 0, which has the default behavior of automatic power down of the ADC peripheral at the end of a conversion and when the next sample signal is not required to be asserted immediately. When the PWRDN bit is set to '1' it selects manual power down behavior. In this setting, the ADC is not powered down at the end of a conversion and remains enabled. This means that the ADC peripheral would only be powered down using the PWREN register. #### Note Refer to the device-specific data sheet for specifications on the ADC wakeup and enable time. #### 9.2.8 Sampling Trigger Sources and Sampling Modes #### **Sample Triggers** There are two sampling trigger sources available which can be selected through the TRIGSRC bit in the CTL1 register; one is a software trigger and the other is an event trigger. When the software trigger is selected as the source, the application software can set the SC bit in the CTL1 register to initiate the sample phase. When the event trigger is selected as the source, a rising edge on the selected event from the event manager will initiate the sample phase. An event is always edge triggered. #### **Sampling Modes** There are two sampling modes available, AUTO and MANUAL, which can be selected through the SAMPMODE bit in the CTL1 register. #### 9.2.8.1 AUTO Sampling Mode In AUTO mode, the sample signal is generated synchronous to the sampling clock (SAMPCLK) and can be programmed using an internal sampling timer to determine the duration of the sampling window. The sample timer is 10-bits wide and there are two sample time compare registers (SCOMPx) available to account for various source impedances to measure signals from. One of these two SCOMP registers can be selected using the STIME bit in the MEMCTL register. There is a 2-3 cycle latency from when the sampling is triggered and when the sampling period starts. This latency can be bypassed by setting ULPCLK as the source for ADCCLK. This synchronization bypass feature is very useful for deterministic sampling Figure 9-3 shows the ADC sample and conversion timing diagram when the ADC is configured in AUTO sampling mode. Figure 9-3. AUTO Sampling Mode ADC Sample and Conversion Timing Diagram #### **Note** When the reset value of PWRDN is set as '0' which has the default behavior of automatic power down, ADC wakeup/enable time needs to be considered in each sample window. Refer to the device-specific data sheet for specifications on the ADC wakeup/enable time. For example, if the maximum ADC wakeup/enable time is 5uS, it means the duration set by SCOMPx should be > (5uS + Duration for sample window). #### 9.2.8.2 MANUAL Sampling Mode In MANUAL mode, the sample signal is generated when the SC bit is set which can be asynchronous to the sampling clock. The duration of the sampling window is controlled by software by holding the SC bit high. Because an event is always edge triggered, manual mode with event trigger is not supported for any of the conversion modes. Software trigger with manual sampling mode is supported only for single channel single conversion mode and it is not supported for any of the other three conversion modes. There is a 2-3 cycle synchronization latency from when the sample window ends to when the conversion window begins. Figure 9-4 shows the ADC sample and conversion timing diagram when the ADC is configured in MANUAL sampling mode: Figure 9-4. MANUAL Sampling Mode ADC Sample and Conversion Timing Diagram #### Note - 1. In MANUAL sampling mode the CCONRUN bit in the CLKCFG register must be set to 1. - 2. When the reset value of PWRDN is set as '0' which has the default behavior of automatic power down, ADC wakeup/enable time needs to be considered before sample window. It means that after setting ENABLE bit in the PWREN register to enable ADC, then application software should set up a delay to wait the ADC wakeup/enable time before starting sampling. Refer to the device-specific data sheet for specifications on the ADC wakeup/enable time. - Once SC bit set by software, the SC bit is automatically cleared by hardware after the sample duration, which is the duration during which the analog signal is sampled. If the software attempts to set the SC bit before the sample duration + 2-3 cycles synchronization latency, TOVIFG flag will not be set. #### 9.2.9 Sampling Period The sampling clock source is selected in the SYSCTL module using the SAMPCLK bits in the CLKCFG register. The desired sampling period for ADC operation can be generated using the internal clock divider and/or the sample timer, which applies to AUTO sampling mode. The internal clock divider is configured using the SCLKDIV bits in the CTL0 register and has divide options of 1, 2, 4, 8, 16, 24, 32, and 48. The duration of the sampling period can be programmed to one of two user-defined values set by the SCOMP0 and SCOMP1 sample timer registers. The value in SCOMPx configures the sampling period by defining the number of sample time clocks to set the sample window to. The default SCOMPx sample timer value translates to 1 cycle wide sample pulse which allows the sampling period to be solely based on the sample clock and SCLKDIV. In general, there are three knobs that can be leveraged to control the sample period: SCOMPx, SCLKDIV, and the source of the sample clock. When AUTO power down mode is selected using PWRDN=0, the module enable signal to the ADC peripheral is generated one sampling clock cycle after the sample signal is asserted. This should be considered by the user in the sample window calculation in addition to the ADC power time or settling time needs of other analog modules such as the Temperature Sensor, VREF, OPA, etc. #### 9.2.10 Conversion Modes There are four conversion modes available in the ADC: - 1. Single channel single conversion - The channel can be selected using MEMCTL - The selected channel is sampled and converted only once - · Multiple conversions are performed when HW averaging is enabled - 2. Repeat single channel conversion - · The channel can be selected using MEMCTL - The selected channel is repeatedly sampled and converted until ENC is cleared by software - If the TRIG bit is set, a trigger is needed to move to the next conversion - Multiple conversions are performed when HW averaging is enabled - 3. Sequence of channels conversion - · Groups of channels can be formed using STARTADD, ENDADD, and MEMCTL registers - Each of the channels in the group is sampled and converted only once - · Multiple conversions are performed on a channel during the sequence when HW averaging is enabled - The sequence will complete even if ENC is cleared in the middle of the sequence - 4. Repeat sequence of channels conversion - · Groups of channels can be formed using STARTADD, ENDADD, and MEMCTL registers - · The group of channels are sampled and converted repeatedly until ENC is cleared by software - If the TRIG bit is set, a trigger is needed to move to the next conversion - When ENC is cleared the operation stops at the end of the last conversion - Multiple conversions are performed on a channel during a sequence when averaging is enabled The following steps outline the recommended process for configuring the ADC for a desired conversion mode: - 1. Use the CONSEQ bits in the CTL1 register to select the desired ADC conversion mode - 2. Use the STARTADD bits in the CTL2 register to select which MEMCTLx is used for single conversion or as first MEMCTL for a sequence mode - 3. If using a sequence mode, use the ENDADD bits in the CTL2 register to select which MEMCTLx is used for the last conversion of the sequence - 4. Assign an ADC input channel to the appropriate MEMCTLx register using the CHANSEL bits - For sequence modes, you must assign an ADC input channel for each MEMCTLx that is part of the configured sequence - 5. Select HW or SW trigger using the TRIGSRC bit in the CTL1 register - Select AUTO or MANUAL sampling mode using the SAMPMODE bit in the CTL1 register - If using AUTO mode, program the desired sample timer value in the SCOMPx register and use the STIME bits in the MEMCTLx register to select the appropriate sample timer source (SCOMP0 or SCOMP1) - 7. If using repeat single channel or sequence conversion modes, program the TRIG bit in each MEMCTLx register to indicate if a trigger will be needed to step to the next MEMCTL in the sequence - 8. Set the ENC bit in the CTL1 register to enable ADC conversions - 9. The following table matrix depicts the next step of ADC configuration and usage based on the selected trigger and sampling modes: #### Table 9-3. Trigger and Sample Mode ADC Usage Matrix | Trigger Mode | | | | | |--------------|---------------|--|--|--| | SW Trigger | Event Trigger | | | | | | Ta | ble 9-3. Trigger and Sample Mode ADC U | sage Matrix (continued) | |------------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Sampling<br>Mode | AUTO | Set SC bit to start the sample phase (duration determined by sample timer) Conversion starts once sample phase is over In single channel single conversion, ENC is cleared when conversion is over SC bit is automatically cleared once the trigger is captured For repeat and sequence modes, if TRIG is set in MEMCTL, the SC bit needs to be set for the next conversion to proceed | <ul> <li>HW trigger starts the sample phase (duration determined by sample timer)</li> <li>Conversion starts once sample phase is over</li> <li>In single channel single conversion, ENC is cleared when conversion is over</li> <li>For repeat and sequence modes, ADC waits for HW trigger or automatically starts the next conversion based on TRIG setting</li> </ul> | | | MANUAL | <ul> <li>Set SC bit to start the sample phase (SC bit is not automatically reset)</li> <li>Clear the SC bit to end the sample phase and start the conversion</li> <li>In single channel single conversion, ENC bit is cleared when conversion is over</li> </ul> | ADC operation is NOT supported in this configuration | 10. The ADC results are stored in the MEMRES register of the associated MEMCTL (for example, the MEMCTL0 result is stored in MEMRES0). Repeated/sequential conversion modes are NOT - For repeat conversion modes, the result in MEMRES is updated after every associated MEMCTL conversion - 11. For repeated conversion modes, clear the ENC bit to stop ADC operation supported in this configuration #### 9.2.11 Data Format The ADC supports two data formats – unsigned binary and 2's complement signed binary. Unsigned binary results are stored right-justified in the MEMRES register or FIFO. Signed binary results are stored left justified in the MEMRES register or FIFO. **Data Format** Resolution Result Range (decimal) Result Range (hex) 8-bit 0 to 255 0000h to 00FFh Unsigned 10-bit 0 to 1023 0000h to 03FFh 12-bit 0 to 4095 0000h 0FFFh 8-bit -128 to 127 8000h to 7F00h -512 to 511 8000h to 7FC0h Signed 10-bit 12-bit -2048 to 2047 8000h to 7FF0h **Table 9-4. ADC Data Formats** #### 9.2.12 Advanced Features The following sections describe the additional features and benefits provided with the ADC peripheral and how to leverage them in an application. #### 9.2.12.1 Window Comparator There is one window comparator unit available in the ADC which can be used to check if the input signal is within predefined threshold values set by software. The ADC result that goes into MEMRES or FIFO is what gets checked against the threshold values of the window comparator. Based on the comparison it can generate 3 interrupt conditions: - 1. LOWIFG Conversion result is below the Low threshold (WCLOW) - HIGHIFG Conversion result is above the High threshold (WCHIGH) ### 3. INIFG - Conversion result is in between or equal to the Low and High thresholds The window comparator low and high threshold values are global for all channels and the window comparison feature can be enabled for each channel as needed using the WINCOMP bit in the MEMCTL register. When the ADC result data format (CTL2.DF) or resolution (CTL2.RES) configuration is changed, the window comparator threshold values are not reset by hardware and are retained as is. The software application is expected to reconfigure the threshold values as appropriate after changing the data format and/or resolution configuration. #### 9.2.12.2 DMA and FIFO Operation The ADC has a dedicated interface for communicating to and from the DMA. This interface is useful to offload work from the CPU by using the DMA to store ADC results to memory automatically. Figure 9-5 shows the signals that make up this interface: Figure 9-5. Internal ADC-DMA Interface #### Note The "DMA trigger count" signal indicates the number of samples that can be transferred by the DMA upon one trigger request. The "DONE status" signal is used by the ADC to generate the DMA DONE interrupt and it indicates if the DMA data transfer of programmed block size is completed. The DMAEN bit in the CTL2 register is used to enable the DMA for ADC data transfer. The DMAEN bit is cleared by ADC hardware when the DMA "DONE status" signal is asserted. Software is expected to re-enable the DMA using DMAEN to arm the ADC to generate the next DMA trigger. The ADC also incorporates an optional First-In-First-Out buffer to provide a way for ADC results to be stored for future use, such as transferring to memory by the DMA. Either the CPU or the DMA can be used to move data from the ADC regardless of whether the FIFO is enabled or disabled. The memory result flags in the RIS register of the third event publisher serve as the FIFO threshold and can be unmasked to generate the DMA trigger. The following sections explain the details of using the ADC+DMA/CPU in various conversion modes and with the FIFO enabled or disabled #### ADC-DMA/CPU Operation in Non-FIFO Mode (FIFOEN=0) ADC-DMA/CPU Operation in Non-FIFO Mode (FIFOEN=0) - Single Conversion and Repeat Single Conversion - Configure STARTADD bits to select the desired MEMCTLx register - MEMCTLx is correlated to MEMRESx - MEMRESx is correlated to MEMRESIFGx - Configure MEMCTL CHANSEL bits to select the desired ADC channel - Conversion data is available in MEMRESx - MEMRESIFGx can be set to generate a CPU interrupt or the DMA trigger - SAMPCNT must be programmed to 1 by SW for DMA operation - The conversion overflow flag OVIFG is set when the ADC updates MEMRESx before the previous sample is read by the CPU or DMA - The conversion underflow flag UVIFG is set when the CPU or DMA reads the MEMRESx register before the next conversion result is available - Sequence Conversion and Repeat Sequence Conversion - Configure STARTADD bits to select the first MEMCTL in the sequence - Configure ENDADD bits to select the last MEMCTL in the sequence - MEMCTLx is correlated to MEMRESx - MEMRESx is correlated to MEMRESIFGx - Configure each MEMCTLx CHANSEL bits to select the desired ADC channels - Conversion data is available in MEMRESx - MEMRESIFGx can be set to generate a CPU interrupt or the DMA trigger - SAMPCNT must be programmed by SW to a suitable value based on threshold setting by SW for DMA operation - The conversion overflow flag OVIFG is set when the ADC updates MEMRESx before the previous sample is read by the CPU or DMA - The conversion underflow flag UVIFG is set when the CPU or DMA reads the MEMRESx register before the next conversion result is available #### Note For DMA based operation, the MEMCTL start address should be smaller than the end address for single sequence conversion as DMA source does not roll back. Repeat sequence conversion mode does not support DMA based data transfer because the DMA does not support circular addressing mode. #### ADC-DMA/CPU Operation in FIFO Mode (FIFOEN=1) - Single Conversion and Repeat Single Conversion - Configure STARTADD bits to select the desired MEMCTLx register - MEMCTLx is NOT correlated to MEMRESx - MEMRESx is correlated to MEMRESIFGx - Configure MEMCTL CHANSEL bits to select the desired ADC channel - Conversion data is loaded sequentially into MEMRES0,1,2,....N (organized as a FIFO) - The CPU or DMA must read ADC samples from the dedicated FIFODAT register and not from MEMRES registers directly - Data in the FIFO is always compacted with two samples and provided as 32-bit data upon a FIFODAT read by CPU or DMA - MEMRESIFGx can be used as a threshold condition to generate a CPU interrupt or DMA trigger - · For full use of the FIFO, the last MEMRESIFG can be used - SAMPCNT must be programmed by SW to a suitable value based on threshold setting for DMA operation - The conversion overflow flag OVIFG is set when the ADC updates MEMRESx before the previous sample is read by the CPU or DMA - The conversion underflow flag UVIFG is set when the CPU or DMA reads the FIFODAT register before the conversion result is available in the MEMRESx registers. #### Note Single conversion mode with FIFO enabled is not recommended for CPU or DMA based operation. It will lead to underflow condition and unwanted 16-bit data will have to be discarded in software. - Sequence Conversion and Repeat Sequence Conversion - Configure STARTADD bits to select the first MEMCTL in the sequence - Configure ENDADD bits to select the last MEMCTL in the sequence ADC www ti com - MEMCTLx is NOT correlated to MEMRESx - MEMRESx is correlated to MEMRESIFGx - Configure each MEMCTLx CHANSEL bits to select the desired ADC channels - Conversion data is loaded sequentially into MEMRES0,1,2,....N (organized as a FIFO) - The CPU or DMA must read ADC samples from the dedicated FIFODAT register and not from MEMRES registers directly - Data in the FIFO is always compacted with two samples and provided as 32-bit data upon a FIFODAT read by CPU or DMA - MEMRESIFGx can be used as a threshold condition to generate a CPU interrupt or DMA trigger - For full use of the FIFO, the last MEMRESIFG can be used - SAMPCNT must be programmed by SW to a suitable value based on threshold setting for DMA operation - The conversion overflow flag OVIFG is set when the ADC updates MEMRESx before the previous sample is read by the CPU or DMA - The conversion underflow flag UVIFG is set when the CPU or DMA reads the FIFODAT register before the conversion result is available in the MEMRESx registers #### Note - The data in FIFODAT register won't be cleared automatically after CPU or DMA reads. New conversion data overwrites the previous data in FIFODAT register. - To ensure synchronized reading of bytes from the 32-bit FIFO, which stores 16-bit samples, specific DMA triggers can be used. In particular, selecting MEMRES1 and MEMRES3 will synchronize the reading of bytes from the FIFO with the corresponding MEMRESx bytes. - If the ADC is disabled during either the repeat sequence mode or normal repeat mode, it's worth noting that an additional conversion may occur before the ADC completely stops. | Table 9-5. ADC-DMA/CPU Operation Summary Matrix | | | | | | |-------------------------------------------------|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------|--| | <b>Conversion Mode</b> | Samples not compacted | | FIFO Enabled (FIFOEN=1) Samples always compacted Read from FIFODAT register only | | | | | CPU Read/Write | DMA Read/Write | CPU Read/Write | DMA Read/Write | | | Single | Supported | Supported<br>SAMPCNT=1<br>Sample in 16 bits | Not recommended<br>Underflow flag will set<br>Unwanted 16-bits should be<br>ignored | Not recommended<br>Underflow flag will set<br>Unwanted 16-bits should be<br>ignored | | | Repeat Single | Supported | Supported<br>SAMPCNT=1<br>Sample in 16 bits | Supported MEMRESIFG=CPU interrupt FIFODAT read in 32-bits | Supported MEMRESIFG=DMA trigger SAMPCNT=Samples in 32-bits | | | Sequence | Supported | Supported SAMPCNT=Sample in 16 bits STARTADD <endadd< td=""><td>Supported MEMRESIFG=CPU interrupt FIFODAT read in 32-bits</td><td>Supported MEMRESIFG=DMA trigger SAMPCNT=Samples in 32-bits</td></endadd<> | Supported MEMRESIFG=CPU interrupt FIFODAT read in 32-bits | Supported MEMRESIFG=DMA trigger SAMPCNT=Samples in 32-bits | | | Repeat Sequence | Supported | Not Supported | Supported MEMRESIFG=CPU interrupt FIFODAT read in 32-bits | Supported MEMRESIFG=DMA trigger SAMPCNT=Samples in 32-bits | | ### 9.2.12.3 Analog Peripheral Interconnection The MSPM0 platform of MCUs provides a rich set of high-performance analog peripherals which can interact with each other to perform various analog signal chain functions. The items below describe how the ADC interacts with the other on-board analog peripherals: #### **ADC** with Internal Reference Module (VREF) The ADC has a dedicated enable request and ready interface with the internal voltage reference module. VREF enable is asserted upon sample trigger while internal reference buffer is selected for ADC operation. The ready response from VREF is captured in the ADC status register (REFBUFRDY). The ready response from VREF **does not** gate the sample phase in the ADC. The ADC sample window is started upon the sample trigger and the settling time of the internal reference buffer needs to be considered in the sample period as appropriate. Software can enable the VREF module using the software enable bit so that it is already settled by the time the ADC starts sampling the input channel. In this case, the sampling time can be smaller and does not have to account for the enable time of VREF. #### **ADC** with OPA The ADC provides a burnout current source (BCS) enable signal to an OPA peripheral when it is selected as the ADC input channel and the BCSEN bit is set in the MEMCTL register. This signal allows the ADC peripheral to work in unison with the OPA peripheral to monitor sensor health and detect faults. The BCS enable signal remains high for all conversions during hardware averaging operation. The ADC receives a chop request signal and provides a chop state control signal to the OPA peripheral when ADC-assisted OPA chopping is activated and the hardware averaging feature is enabled. The chop state control signal toggles at the end of each conversion during hardware averaging operation. The number of samples averaged should be programmed to an even value when ADC-assisted OPA chopping is activated. ### **ADC** with Temperature Sensor The temperature sensor module enable signal is generated by the ADC when the temp sense channel is selected. The settling time of the temperature sensor should be accounted for in the sample period as there is no ready response from the temperature sensor. ### 9.2.13 Status Register The ADC status register, STATUS, contains two bits - REFBUFRDY and BUSY. - REFBUFRDY is set when the ADC receives the ready signal from the internal reference buffer (VREF/ REFBUF) after asserting the enable request - BUSY equaling '1' indicates that the ADC is busy performing a sample or convert operation - For single channel single conversion, it signals that a trigger has been received and sample or conversion is ongoing. BUSY will be cleared when the conversion completes - For repeat single conversion, it signals that repeat single operation has begun and has not ended. BUSY will be cleared when ENC is written '0' and the last conversion completes - For sequence of channels conversion, it signals that the sequence of channels conversion has started. BUSY will be cleared at the end of the sequence - For repeat sequence of channels conversion, it signals the repeat sequence is ongoing. BUSY will be cleared when ENC is written '0' and the last conversion completes #### 9.2.14 ADC Events The ADC peripheral contains three event publishers and one event subscriber. One event publisher (CPU\_INT) manages ADC interrupt requests (IRQs) to the CPU subsystem through a static event route. The second event publisher (GEN\_EVENT) can be used to publish ADC events to a subscriber through a generic event route channel. The third event publisher (DMA\_TRIG) can be used as an ADC-to-DMA trigger to send ADC events directly to the DMA through a DMA event route. The event subscriber (FSUB\_0) can be used to subscribe to events which are published to the event fabric through a generic event route channel. The ADC events are summarized in Table 9-6. #### Table 9-6. ADC Events | Event | Туре | Source | Destination | Route | Configuration | Functionality | |---------------|-----------|--------|---------------|--------------|---------------|--------------------------------| | CPU interrupt | Publisher | ADC | CPU Subsystem | Static route | CPU_INT | Fixed interrupt route from ADC | | event | | | | | registers | to CPU | #### Table 9-6. ADC Events (continued) | Event | Туре | Source | Destination | Route | Configuration | Functionality | |--------------------------|------------|-------------------|-----------------------|---------------------------|--------------------------------------|-------------------------------------------| | Generic publisher event | Publisher | ADC | Generic event channel | Generic route<br>(FPUB_0) | GEN_EVENT registers, FPUB_0 register | Trigger generic event channel from ADC | | DMA trigger event | Publisher | ADC | DMA | DMA route | DMA_TRIG registers | Fixed trigger route from ADC to DMA | | Generic subscriber event | Subscriber | Other peripherals | ADC | Generic route(FSUB_0) | FSUB_0 | ADC subscription to generic event channel | #### 9.2.14.1 CPU Interrupt Event Publisher (CPU\_INT) The ADC peripheral provides many interrupt sources which can be configured to source a CPU interrupt event. In order of decreasing interrupt priority, the CPU interrupt events from the ADC are given in Table 9-7. Table 9-7. ADC CPU Interrupt Event Conditions (CPU\_INT) | Index (IIDX) | Name | Description | |----------------|--------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0x0 | NO_INTR | No bit set (IIDX.STAT = 0) means there is no pending interrupt request | | 0x1 | OVIFG | Conversion overflow interrupt flag is set when the ADC updates MEMRESx before the previous sample is read by the CPU or DMA | | 0x2 | TOVIFG | Sequence conversion time overflow interrupt flag is set when the ADC receives a new sampling trigger while the previous sample+conversion is still in progress | | 0x3 | HIGHIFG | High threshold compare interrupt flag is set when the MEMRESx result register is higher than the WCHIGH threshold of the window comparator | | 0x4 | LOWIFG | Low threshold compare interrupt flag is set when the MEMRESx result register is lower than the WCLOW threshold of the window comparator | | 0x5 | INIFG | In-range comparator interrupt flag is set when the MEMRESx result register is within the range of WCLOW and WCHIGH of the window comparator | | 0x6 | DMADONE | DMA done interrupt flag is set when the DMA data transfer of programmed block size is completed | | 0x7 | UVIFG | Conversion underflow interrupt flag, the UVIFG flag is set when the CPU or DMA reads the MEMRESx register before the next conversion result is available | | 0x9 up to 0x20 | MEMRESIFG[0 up to 24] <sup>(1)</sup> | Memory register interrupt flag is set when MEMRESx is loaded with a new conversion result | <sup>(1)</sup> Refer to the device-specific data sheet to see how many conversion-result storage registers (MEMRES) your device supports. The CPU interrupt event configuration is managed with the CPU\_INT event management registers. Interrupt (RIS) flags are cleared upon software reading the IIDX register or writing to the respective ICLR register bits. See Section 6.2.5 for guidance on configuring the Event registers for CPU interrupts. #### 9.2.14.2 Generic Event Publisher (GEN EVENT) The ADC peripheral provides 4 interrupt sources, one of which can be configured to publish an event to a generic event route channel. Table 9-8 lists these interrupt sources. Table 9-8. ADC Generic Event Publisher Conditions (GEN\_EVENT) | Index | Name | Description | |-------|---------|--------------------------------------------------------------------------------------------------------------------------------------------| | 0x0 | NO_INTR | No bit set means there is no pending interrupt request | | 0x3 | HIGHIFG | High threshold compare interrupt flag is set when the MEMRESx result register is higher than the WCHIGH threshold of the window comparator | | 0x4 | LOWIFG | Low threshold compare interrupt flag is set when the MEMRESx result register is lower than the WCLOW threshold of the window comparator | | Index | Name | Description | |-------|------------|---------------------------------------------------------------------------------------------------------------------------------------------| | 0x5 | | In-range comparator interrupt flag is set when the MEMRESx result register is within the range of WCLOW and WCHIGH of the window comparator | | 0x9 | MEMRESIFG0 | Memory register interrupt flag is set when MEMRES0 is loaded with a new conversion result | The generic event publisher configuration is managed with the GEN\_EVENT event management registers. Interrupt (RIS) flags are cleared based on acknowledgment (ACK) signal from the subscriber module received over the event fabric. See Section 6.2.5 for guidance on configuring the Event registers for generic event publishers. The generic event channel which GEN\_EVENT is to publish to must be selected by writing the target generic channel ID to the **FPUB\_0** register in the ADC. See Section 6.1.3.3 for guidance on configuring generic event routes. If this publisher is not used in an application, the FPUB\_0 register can be left in a disconnected state (set equal to zero) and no events should be unmasked through the MIS register in the ADC GEN\_EVENT register set. #### 9.2.14.3 DMA Trigger Event Publisher (DMA TRIG) The ADC module provides many interrupt sources which can be configured to source the DMA trigger. In order of decreasing interrupt priority, the DMA trigger events from the ADC are given in Table 9-9. When the DMA channel is needed by the ADC, the DMA trigger should be unmasked in the IMASK register of DMA\_TRIG and the DMA should be configured as needed to support the ADC operation. Table 9-9. ADC DMA Trigger Event Conditions (DMA\_TRIG) | Index (IIDX) | Name | Description | |----------------|--------------------------------------|-------------------------------------------------------------------------------------------| | 0x0 | NO_INTR | No bit set (IIDX.STAT = 0) means there is no pending interrupt request | | 0x9 up to 0x20 | MEMRESIFG[0 up to 24] <sup>(1)</sup> | Memory register interrupt flag is set when MEMRESx is loaded with a new conversion result | (1) Check the device-specific data sheet to see how many conversion-result storage registers (MEMRES) your device supports. The DMA trigger event configuration is managed with the DMA\_TRIG event management registers. The interrupt (RIS) flags are cleared based on ACK from DMA. See Section 6.2.5 for guidance on configuring the Event registers for DMA triggers. #### 9.2.14.4 Generic Event Subscriber (FSUB\_0) The ADC peripheral supports receiving events routed through a generic channel from other peripherals. Refer to Section 6.1.3.3 and Section 6.2.3 for how generic event route works. Once the channel to be used is determined, and both the publisher and subscriber ports for the peripherals being connected are known, use the steps below to establish the event connection. In this example, a GPIO triggered ADC application will be configured, using GPIO Port A to publish an event to generic channel 1, with ADC0 subscribing to generic channel 1 as a start-of-conversion trigger. - Configure the GEN\_EVENT registers of GPIO Port A to set the event request based on the appropriate event (for example, a DIN rise event). - 2. Store 0x1 into the FPUB\_0 register of GPIO Port A to publish the GPIO event selected by the GEN\_EVENT registers to generic route channel 1. Channel 1 must not be in use by another peripheral. - 3. Store 0x1 the FSUB\_0 register of ADC0 so that ADC0 is listening for events published by the timer to channel 1. - 4. Configure ADC0 to trigger from the subscriber port according to the configuration instructions in Section 9.2.8 - 5. Configure and enable the appropriate GPIO pin to monitor input voltage events # 9.3 ADC12 Registers Table 9-10 lists the memory-mapped registers for the ADC12 registers. All register offset addresses not listed in Table 9-10 should be considered as reserved locations and the register contents should not be modified. Table 9-10. ADC12 Registers | Offset | Acronym | Register Name | Group | Section | |--------------------|------------|----------------------------------------------|--------------|---------| | 400h | FSUB_0 | Subscriber Configuration Register. | • | Go | | 444h | <br>FPUB_1 | Publisher Configuration Register. | | Go | | 800h | PWREN | Power enable | | Go | | 804h | RSTCTL | Reset Control | | Go | | 808h | CLKCFG | ADC clock configuration Register | | Go | | 814h | STAT | Status Register | | Go | | 1020h | IIDX | Interrupt index | CPU_INT | Go | | 1028h | IMASK | Interrupt mask | CPU_INT | Go | | 1030h | RIS | Raw interrupt status | CPU_INT | Go | | 1038h | MIS | Masked interrupt status | CPU_INT | Go | | 1040h | ISET | Interrupt set | <br>CPU_INT | Go | | 1048h | ICLR | Interrupt clear | CPU_INT | Go | | 1050h | IIDX | Interrupt index | GEN EVENT | Go | | 1058h | IMASK | Interrupt mask | GEN_EVENT | Go | | 1060h | RIS | Raw interrupt status | GEN_EVENT | Go | | 1068h | MIS | Masked interrupt status | GEN EVENT | Go | | 1070h | ISET | Interrupt set | GEN_EVENT | Go | | 1078h | ICLR | Interrupt clear | GEN_EVENT | Go | | 1080h | IIDX | Interrupt index | DMA_TRIG | Go | | 1088h | IMASK | Interrupt mask extension | DMA_TRIG | Go | | 1090h | RIS | Raw interrupt status extension | <br>DMA_TRIG | Go | | 1098h | MIS | Masked interrupt status extension | DMA TRIG | Go | | 10A0h | ISET | Interrupt set extension | DMA_TRIG | Go | | 10A8h | ICLR | Interrupt clear extension | <br>DMA_TRIG | Go | | 10E0h | EVT_MODE | Event Mode | | Go | | 10FCh | DESC | Module Description | | Go | | 1100h | CTL0 | Control Register 0 | | Go | | 1104h | CTL1 | Control Register 1 | | Go | | 1108h | CTL2 | Control Register 2 | | Go | | 110Ch | CTL3 | Control Register 3 | | Go | | 1110h | CLKFREQ | Sample Clock Frequency Range<br>Register | | Go | | 1114h | SCOMP0 | Sample Time Compare 0 Register | | Go | | 1118h | SCOMP1 | Sample Time Compare 1 Register | | Go | | 111Ch | REFCFG | Reference Buffer Configuration Register | | Go | | 1148h | WCLOW | Window Comparator Low Threshold Register | | Go | | 1150h | WCHIGH | Window Comparator High Threshold<br>Register | | Go | | 1160h | FIFODATA | FIFO Data Register | | Go | | 1170h | ASCRES | ASC Result Register | | Go | | 1180h +<br>formula | MEMCTL[y] | Conversion Memory Control Register | | Go | Table 9-10. ADC12 Registers (continued) | Offset A | Acronym | Register Name | Group | Section | |----------------------|-----------|------------------------|-------|---------| | 1280h + M<br>formula | MEMRES[y] | Memory Result Register | | Go | | 1340h S | STATUS | Status Register | | Go | Complex bit access types are encoded to fit into small table cells. Table 9-11 shows the codes that are used for access types in this section. Table 9-11. ADC12 Access Type Codes | | | 100000 1300 00000 | | | |--------------------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Access Type | Code | Description | | | | Read Type | | | | | | R | R | Read | | | | RH | R<br>H | Read<br>Set or cleared by hardware | | | | Write Type | 11 | Set of Geared by Hardware | | | | W | W | Write | | | | WK | W<br>K | Write<br>Write protected by a key | | | | Reset or Default Value | | | | | | -n | | Value after reset or the default value | | | | Register Array Variables | 5 | | | | | i,j,k,l,m,n | | When these variables are used in a register name, an offset, or an address, they refer to the value of a register array where the register is part of a group of repeating registers. The register groups form a hierarchical structure and the array is represented with a formula. | | | | У | | When this variable is used in a register name, an offset, or an address it refers to the value of a register array. | | | # 9.3.1 FSUB\_0 (Offset = 400h) [Reset = 00000000h] FSUB\_0 is shown in Figure 9-6 and described in Table 9-12. Return to the Summary Table. Subscriber port ### Figure 9-6. FSUB\_0 # Table 9-12. FSUB\_0 Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-4 | RESERVED | R/W | 0h | | | 3-0 | CHANID | R/W | | 0 = disconnected. 1-15 = connected to channelID = CHANID. 0h = A value of 0 specifies that the event is not connected Fh = Consult your device data sheet as the actual allowed maximum may be less than 255. | # 9.3.2 FPUB\_1 (Offset = 444h) [Reset = 00000000h] FPUB\_1 is shown in Figure 9-7 and described in Table 9-13. Return to the Summary Table. Publisher port ### Figure 9-7. FPUB\_1 Table 9-13. FPUB\_1 Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-4 | RESERVED | R/W | 0h | | | 3-0 | CHANID | R/W | | 0 = disconnected. 1-15 = connected to channelID = CHANID. 0h = A value of 0 specifies that the event is not connected Fh = Consult your device data sheet as the actual allowed maximum may be less than 255. | # 9.3.3 PWREN (Offset = 800h) [Reset = 00000000h] PWREN is shown in Figure 9-8 and described in Table 9-14. Return to the Summary Table. Register to control the power state ### Figure 9-8. PWREN ### **Table 9-14. PWREN Field Descriptions** | Bit | Field | Туре | Reset | Description | |-------|----------|------|----------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------| | 31-24 | KEY | W | 0h KEY to allow Power State Change<br>26h = KEY to allow write access to this register | | | 23-1 | RESERVED | R/W | 0h | | | 0 | ENABLE | R/WK | 0h | Enable the power KEY must be set to 26h to write to this bit. 0h = Disable Power 1h = Enable Power | # 9.3.4 RSTCTL (Offset = 804h) [Reset = 00000000h] RSTCTL is shown in Figure 9-9 and described in Table 9-15. Return to the Summary Table. Register to control reset assertion and de-assertion ### Figure 9-9. RSTCTL ### **Table 9-15. RSTCTL Field Descriptions** | Bit | Field | Туре | Reset | Description | |-------|--------------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------| | 31-24 | KEY | W | 0h | Unlock key B1h = KEY to allow write access to this register | | 23-2 | RESERVED | W | 0h | | | 1 | RESETSTKYCLR | WK | 0h | Clear the RESETSTKY bit in the STAT register KEY must be set to B1h to write to this bit. 0h = Writing 0 has no effect 1h = Clear reset sticky bit | | 0 | RESETASSERT | WK | 0h | Assert reset to the peripheral KEY must be set to B1h to write to this bit. 0h = Writing 0 has no effect 1h = Assert reset | # 9.3.5 CLKCFG (Offset = 808h) [Reset = 00000000h] CLKCFG is shown in Figure 9-10 and described in Table 9-16. Return to the Summary Table. ADC clock configuration ### Figure 9-10. CLKCFG ### Table 9-16. CLKCFG Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-24 | KEY | W | 0h | Unlock key A9h = KEY to allow write access to this register | | 23-6 | RESERVED | R/W | 0h | | | 5 | CCONSTOP | R/W | Oh | CCONSTOP: Forces SYSOSC to run at base frequency when device is in STOP mode which can be used as ADC sample or conversion clock source. Oh = ADC conversion clock source is not kept continuously on during STOP mode. 1h = ADC conversion clock source kept continuously on during STOP mode. | | 4 | CCONRUN | R/W | Oh | CCONRUN: Forces SYSOSC to run at base frequency when device is in RUN mode which can be used as ADC sample or conversion clock source. Oh = ADC conversion clock source is not kept continuously on during RUN mode. 1h = ADC conversion clock source kept continuously on during RUN mode. | | 3-2 | RESERVED | R/W | 0h | | | 1-0 | SAMPCLK | R/W | 0h | ADC sample clock source selection. 0h = ULPCLK is the source of ADC sample clock. 1h = SYSOSC is the source of ADC sample clock. 2h = HFCLK clock is the source of ADC sample clock. Note : HFCLK may not be available on all the devices. | # 9.3.6 STAT (Offset = 814h) [Reset = 00000000h] STAT is shown in Figure 9-11 and described in Table 9-17. Return to the Summary Table. peripheral enable and reset status ### Figure 9-11. STAT ### **Table 9-17. STAT Field Descriptions** | Bit | Field | Туре | Reset | Description | |-------|-----------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-17 | RESERVED | R | 0h | | | 16 | RESETSTKY | R | 0h | This bit indicates, if the peripheral was reset, since this bit was cleared by RESETSTKYCLR in the RSTCTL register 0h = The peripheral has not been reset since this bit was last cleared by RESETSTKYCLR in the RSTCTL register 1h = The peripheral was reset since the last bit clear | | 15-0 | RESERVED | R | 0h | | ### 9.3.7 IIDX (Offset = 1020h) [Reset = 00000000h] IIDX is shown in Figure 9-12 and described in Table 9-18. Return to the Summary Table. This register provides the highest priority enabled interrupt index. 0x0 means no event pending. Interrupt 1 is the highest priority, 2 next highest, 4, 8, ... 2<sup>31</sup> is the least priority. That is, the least bit position that is set to 1 denotes the highest priority pending interrupt. The priority order is fixed. However, users can implement their own prioritization schemes using other registers that expose the full set of interrupts that have occurred. On each read, only one interrupt is indicated. On a read, the current interrupt (highest priority) is automatically cleared by the hardware and the corresponding interrupt flag in the RIS and MIS are cleared as well. After a read from the CPU (not from the debug interface), the register must be updated with the next highest priority interrupt, if none are pending, then it should display 0x0. #### Figure 9-12. IIDX ## Table 9-18. IIDX Field Descriptions | | Table 9-16. IIDA Fleid Descriptions | | | | | | | |-------|-------------------------------------|------|-------|-----------------------------------------------------------------|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | 31-10 | RESERVED | R | 0h | | | | | | 9-0 | STAT | R | 0h | Interrupt index status | | | | | | | | | 00h = No bit is set means there is no pending interrupt request | | | | | | | | | 01h = MEMRESx overflow interrupt | | | | | | | | | 02h = Sequence Conversion time overflow interrupt | | | | | | | | | 03h = High threshold compare interrupt | | | | | | | | | 04h = Low threshold compare interrupt | | | | | | | | | 05h = Primary Sequence In range comparator interrupt | | | | | | | | | 6h = DMA done interrupt, generated on DMA transfer completion, | | | | | | | | | 07h = MEMRESx underflow interrupt | | | | | | | | | 9h = MEMRES0 data loaded interrupt | | | | | | | | | Ah = MEMRES1 data loaded interrupt | | | | | | | | | Bh = MEMRES2 data loaded interrupt | | | | | | | | | Ch = MEMRES3 data loaded interrupt | | | | | | | | | Dh = MEMRES4 data loaded interrupt | | | | | | | | | Eh = MEMRES5 data loaded interrupt | | | | | | | | | Fh = MEMRES6 data loaded interrupt | | | | | | | | | 10h = MEMRES7 data loaded interrupt | | | | | | | | | 11h = MEMRES8 data loaded interrupt | | | | | | | | | 12h = MEMRES9 data loaded interrupt | | | | | | | | | 13h = MEMRES10 data loaded interrupt | | | | | | | | | 14h = MEMRES11 data loaded interrupt | | | | | | | | | 15h = MEMRES12 data loaded interrupt | | | | | | | | | 16h = MEMRES13 data loaded interrupt | | | | | | | | | 17h = MEMRES14 data loaded interrupt | | | | | | | | | 18h = MEMRES15 data loaded interrupt | | | | | | | | | 19h = MEMRES16 data loaded interrupt | | | | | | | | | 1Ah = MEMRES17 data loaded interrupt | | | | | | | | | 1Bh = MEMRES18 data loaded interrupt | | | | | | | | | 1Ch = MEMRES19 data loaded interrupt | | | | | | | | | 1Dh = MEMRES20 data loaded interrupt | | | | | | | | | 1Eh = MEMRES21 data loaded interrupt | | | | | | | | | 1Fh = MEMRES22 data loaded interrupt | | | | | | | | | 20h = MEMRES23 data loaded interrupt | | | | ### 9.3.8 IMASK (Offset = 1028h) [Reset = 00000000h] IMASK is shown in Figure 9-13 and described in Table 9-19. Return to the Summary Table. Interrupt Mask. If a bit is set, then corresponding interrupt is un-masked. Un-masking the interrupt causes the raw interrupt to be visible in IIDX, as well as MIS. Figure 9-13. IMASK | Figure 9-13. INVASK | | | | | | | | |---------------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | MEMRESIFG23 | MEMRESIFG22 | MEMRESIFG21 | MEMRESIFG20 | MEMRESIFG19 | MEMRESIFG18 | MEMRESIFG17 | MEMRESIFG16 | | R/W-0h | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | MEMRESIFG15 | MEMRESIFG14 | MEMRESIFG13 | MEMRESIFG12 | MEMRESIFG11 | MEMRESIFG10 | MEMRESIFG9 | MEMRESIFG8 | | R/W-0h | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | MEMRESIFG7 | MEMRESIFG6 | MEMRESIFG5 | MEMRESIFG4 | MEMRESIFG3 | MEMRESIFG2 | MEMRESIFG1 | MEMRESIFG0 | | R/W-0h | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | ASCDONE | UVIFG | DMADONE | INIFG | LOWIFG | HIGHIFG | TOVIFG | OVIFG | | R/W-0h ### Table 9-19. IMASK Field Descriptions | Bit | Field | Туре | Reset | Description | |-----|-------------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 | MEMRESIFG23 | R/W | 0h | Raw interrupt status for MEMRES23. This bit is set to 1 when MEMRES23 is loaded with a new conversion result. Reading MEMRES23 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 30 | MEMRESIFG22 | R/W | 0h | Raw interrupt status for MEMRES22. This bit is set to 1 when MEMRES22 is loaded with a new conversion result. Reading MEMRES22 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 29 | MEMRESIFG21 | R/W | Oh | Raw interrupt status for MEMRES21. This bit is set to 1 when MEMRES21 is loaded with a new conversion result. Reading MEMRES21 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 28 | MEMRESIFG20 | R/W | Oh | Raw interrupt status for MEMRES20. This bit is set to 1 when MEMRES20 is loaded with a new conversion result. Reading MEMRES20 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | | | Descriptions (continued) | | | |-----|-------------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Bit | Field | Туре | Reset | Description | | | | 27 | MEMRESIFG19 | R/W | 0h | Raw interrupt status for MEMRES19. This bit is set to 1 when MEMRES19 is loaded with a new conversion result. Reading MEMRES19 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | 26 | MEMRESIFG18 | R/W | 0h | Raw interrupt status for MEMRES18. This bit is set to 1 when MEMRES18 is loaded with a new conversion result. Reading MEMRES18 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | 25 | MEMRESIFG17 | R/W | 0h | Raw interrupt status for MEMRES17. This bit is set to 1 when MEMRES17 is loaded with a new conversion result. Reading MEMRES17 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | 24 | MEMRESIFG16 | R/W | 0h | Raw interrupt status for MEMRES16. This bit is set to 1 when MEMRES16 is loaded with a new conversion result. Reading MEMRES16 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | 23 | MEMRESIFG15 | R/W | 0h | Raw interrupt status for MEMRES15. This bit is set to 1 when MEMRES15 is loaded with a new conversion result. Reading MEMRES15 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | 22 | MEMRESIFG14 | R/W | 0h | Raw interrupt status for MEMRES14. This bit is set to 1 when MEMRES14 is loaded with a new conversion result. Reading MEMRES14 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | 21 | MEMRESIFG13 | R/W | 0h | Raw interrupt status for MEMRES13. This bit is set to 1 when MEMRES13 is loaded with a new conversion result. Reading MEMRES13 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | 20 | MEMRESIFG12 | R/W | 0h | Raw interrupt status for MEMRES12. This bit is set to 1 when MEMRES12 is loaded with a new conversion result. Reading MEMRES12 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | | Table 9-19. IMASK Field Descriptions (continued) | | | | | | | |-----|--------------------------------------------------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | 19 | MEMRESIFG11 | R/W | Oh | Raw interrupt status for MEMRES11. This bit is set to 1 when MEMRES11 is loaded with a new conversion result. Reading MEMRES11 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | | 18 | MEMRESIFG10 | R/W | Oh | Raw interrupt status for MEMRES10. This bit is set to 1 when MEMRES10 is loaded with a new conversion result. Reading MEMRES10 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | | 17 | MEMRESIFG9 | R/W | Oh | Raw interrupt status for MEMRES9. This bit is set to 1 when MEMRES9 is loaded with a new conversion result. Reading MEMRES9 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | | 16 | MEMRESIFG8 | R/W | Oh | Raw interrupt status for MEMRES8. This bit is set to 1 when MEMRES8 is loaded with a new conversion result. Reading MEMRES8 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | | 15 | MEMRESIFG7 | R/W | Oh | Raw interrupt status for MEMRES7. This bit is set to 1 when MEMRES7 is loaded with a new conversion result. Reading MEMRES7 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | | 14 | MEMRESIFG6 | R/W | Oh | Raw interrupt status for MEMRES6. This bit is set to 1 when MEMRES6 is loaded with a new conversion result. Reading MEMRES6 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | | 13 | MEMRESIFG5 | R/W | Oh | Raw interrupt status for MEMRES5. This bit is set to 1 when MEMRES5 is loaded with a new conversion result. Reading MEMRES5 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | | 12 | MEMRESIFG4 | R/W | 0h | Raw interrupt status for MEMRES4. This bit is set to 1 when MEMRES4 is loaded with a new conversion result. Reading MEMRES4 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | | | | Table 9-19. | INIASK FIEID | Descriptions (continued) | | | |-----|------------|-------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Bit | Field | Type | Reset | Description | | | | 11 | MEMRESIFG3 | R/W | Oh | Raw interrupt status for MEMRES3. This bit is set to 1 when MEMRES3 is loaded with a new conversion result. Reading MEMRES3 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | 10 | MEMRESIFG2 | R/W | Oh | Raw interrupt status for MEMRES2. This bit is set to 1 when MEMRES2 is loaded with a new conversion result. Reading MEMRES2 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | 9 | MEMRESIFG1 | R/W | Oh | Raw interrupt status for MEMRES1. This bit is set to 1 when MEMRES1 is loaded with a new conversion result. Reading MEMRES1 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | 8 | MEMRESIFG0 | R/W | Oh | Raw interrupt status for MEMRES0. This bit is set to 1 when MEMRES0 is loaded with a new conversion result. Reading MEMRES0 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | 7 | ASCDONE | R/W | 0h | Mask for ASC done raw interrupt flag 0h = Interrupt is not pending. 1h = Interrupt is pending. | | | | 6 | UVIFG | R/W | 0h | Raw interrupt flag for MEMRESx underflow. This bit is reset to 0 by IIDX read or when corresponding bit in ICLR is set to 1. 0h = Interrupt is not pending. 1h = Interrupt is pending. | | | | 5 | DMADONE | R/W | 0h | Raw interrupt flag for DMADONE. This bit is reset to 0 by IIDX read or when corresponding bit in ICLR_EX is set to 1. 0h = Interrupt is not pending. 1h = Interrupt is pending. | | | | 4 | INIFG | R/W | 0h | Mask INIFG in MIS_EX register. 0h = Interrupt is not pending. 1h = Interrupt is pending. | | | | 3 | LOWIFG | R/W | Oh | Raw interrupt flag for the MEMRESx result register being below than the WCLOWx threshold of the window comparator. This bit is reset to 0 by IIDX read or when corresponding bit in ICLR_EX is set to 1. 0h = Interrupt is not pending. 1h = Interrupt is pending. | | | | 2 | HIGHIFG | R/W | Oh | Raw interrupt flag for the MEMRESx result register being higher than the WCHIGHx threshold of the window comparator. This bit is reset to 0 by IIDX read or when corresponding bit in ICLR_EX is set to 1. 0h = Interrupt is not pending. 1h = Interrupt is pending. | | | | 1 | TOVIFG | R/W | Oh | Raw interrupt flag for sequence conversion timeout overflow. This bit is reset to 0 by IIDX read or when corresponding bit in ICLR_EX is set to 1. 0h = Interrupt is not pending. 1h = Interrupt is pending. | | | | Bit | Field | Туре | Reset | Description | |-----|-------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | OVIFG | R/W | | Raw interrupt flag for MEMRESx overflow. This bit is reset to 0 by IIDX read or when corresponding bit in ICLR_EX is set to 1. 0h = Interrupt is not pending. 1h = Interrupt is pending. | ### 9.3.9 RIS (Offset = 1030h) [Reset = 00000000h] RIS is shown in Figure 9-14 and described in Table 9-20. Return to the Summary Table. Raw interrupt status. Reflects all pending interrupts, regardless of masking. The RIS register allows the user to implement a poll scheme. A flag set in this register can be cleared by writing 1 to the ICLR register bit even if the corresponding IMASK bit is not enabled. Figure 9-14. RIS | rigure 3-14. INS | | | | | | | | |------------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | MEMRESIFG23 | MEMRESIFG22 | MEMRESIFG21 | MEMRESIFG20 | MEMRESIFG19 | MEMRESIFG18 | MEMRESIFG17 | MEMRESIFG16 | | R-0h | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | MEMRESIFG15 | MEMRESIFG14 | MEMRESIFG13 | MEMRESIFG12 | MEMRESIFG11 | MEMRESIFG10 | MEMRESIFG9 | MEMRESIFG8 | | R-0h | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | MEMRESIFG7 | MEMRESIFG6 | MEMRESIFG5 | MEMRESIFG4 | MEMRESIFG3 | MEMRESIFG2 | MEMRESIFG1 | MEMRESIFG0 | | R-0h | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | ASCDONE | UVIFG | DMADONE | INIFG | LOWIFG | HIGHIFG | TOVIFG | OVIFG | | R-0h ## Table 9-20. RIS Field Descriptions | Bit | Field | Туре | Reset | Description | |-----|-------------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 | MEMRESIFG23 | R | Oh | Raw interrupt status for MEMRES23. This bit is set to 1 when MEMRES23 is loaded with a new conversion result. Reading MEMRES23 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 30 | MEMRESIFG22 | R | 0h | Raw interrupt status for MEMRES22. This bit is set to 1 when MEMRES22 is loaded with a new conversion result. Reading MEMRES22 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 29 | MEMRESIFG21 | R | Oh | Raw interrupt status for MEMRES21. This bit is set to 1 when MEMRES21 is loaded with a new conversion result. Reading MEMRES21 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 28 | MEMRESIFG20 | R | Oh | Raw interrupt status for MEMRES20. This bit is set to 1 when MEMRES20 is loaded with a new conversion result. Reading MEMRES20 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | Table 9-20. RIS Field Descriptions (continued) | | | | | | | | |------------------------------------------------|-------------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | 27 | MEMRESIFG19 | R | Oh | Raw interrupt status for MEMRES19. This bit is set to 1 when MEMRES19 is loaded with a new conversion result. Reading MEMRES19 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | | 26 | MEMRESIFG18 | R | Oh | Raw interrupt status for MEMRES18. This bit is set to 1 when MEMRES18 is loaded with a new conversion result. Reading MEMRES18 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | | 25 | MEMRESIFG17 | R | Oh | Raw interrupt status for MEMRES17. This bit is set to 1 when MEMRES17 is loaded with a new conversion result. Reading MEMRES17 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | | 24 | MEMRESIFG16 | R | Oh | Raw interrupt status for MEMRES16. This bit is set to 1 when MEMRES16 is loaded with a new conversion result. Reading MEMRES16 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | | 23 | MEMRESIFG15 | R | 0h | Raw interrupt status for MEMRES15. This bit is set to 1 when MEMRES15 is loaded with a new conversion result. Reading MEMRES15 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | | 22 | MEMRESIFG14 | R | 0h | Raw interrupt status for MEMRES14. This bit is set to 1 when MEMRES14 is loaded with a new conversion result. Reading MEMRES14 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | | 21 | MEMRESIFG13 | R | 0h | Raw interrupt status for MEMRES13. This bit is set to 1 when MEMRES13 is loaded with a new conversion result. Reading MEMRES13 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | | 20 | MEMRESIFG12 | R | 0h | Raw interrupt status for MEMRES12. This bit is set to 1 when MEMRES12 is loaded with a new conversion result. Reading MEMRES12 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | | Bit Field Type Reset Description | | | | | | | |----------------------------------|--------------|---|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | 19 | MEMRESIFG11 | R | 0h | · | | | | 19 | MEMIKESIFGII | K | On | Raw interrupt status for MEMRES11. This bit is set to 1 when MEMRES11 is loaded with a new conversion result. Reading MEMRES11 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | 18 | MEMRESIFG10 | R | 0h | Raw interrupt status for MEMRES10. This bit is set to 1 when MEMRES10 is loaded with a new conversion result. Reading MEMRES10 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | 17 | MEMRESIFG9 | R | Oh | Raw interrupt status for MEMRES9. This bit is set to 1 when MEMRES9 is loaded with a new conversion result. Reading MEMRES9 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | 16 | MEMRESIFG8 | R | 0h | Raw interrupt status for MEMRES8. This bit is set to 1 when MEMRES8 is loaded with a new conversion result. Reading MEMRES8 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | 15 | MEMRESIFG7 | R | 0h | Raw interrupt status for MEMRES7. This bit is set to 1 when MEMRES7 is loaded with a new conversion result. Reading MEMRES7 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | 14 | MEMRESIFG6 | R | Oh | Raw interrupt status for MEMRES6. This bit is set to 1 when MEMRES6 is loaded with a new conversion result. Reading MEMRES6 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | 13 | MEMRESIFG5 | R | Oh | Raw interrupt status for MEMRES5. This bit is set to 1 when MEMRES5 is loaded with a new conversion result. Reading MEMRES5 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | 12 | MEMRESIFG4 | R | Oh | Raw interrupt status for MEMRES4. This bit is set to 1 when MEMRES4 is loaded with a new conversion result. Reading MEMRES4 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | Table 9-20. RIS Field Descriptions (continued) | | | | | | | |------------------------------------------------|------------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Bit | Field | Туре | Reset | Description | | | | 11 | MEMRESIFG3 | R | Oh | Raw interrupt status for MEMRES3. This bit is set to 1 when MEMRES3 is loaded with a new conversion result. Reading MEMRES3 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | 10 | MEMRESIFG2 | R | 0h | Raw interrupt status for MEMRES2. This bit is set to 1 when MEMRES2 is loaded with a new conversion result. Reading MEMRES2 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | 9 | MEMRESIFG1 | R | 0h | Raw interrupt status for MEMRES1. This bit is set to 1 when MEMRES1 is loaded with a new conversion result. Reading MEMRES1 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | 8 | MEMRESIFG0 | R | 0h | Raw interrupt status for MEMRES0. This bit is set to 1 when MEMRES0 is loaded with a new conversion result. Reading MEMRES0 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | 7 | ASCDONE | R | 0h | Raw interrupt flag for ASC done 0h = Interrupt is not pending. 1h = Interrupt is pending. | | | | 6 | UVIFG | R | Oh | Raw interrupt flag for MEMRESx underflow. This bit is reset to 0 by IIDX read or when corresponding bit in ICLR is set to 1. 0h = Interrupt is not pending. 1h = Interrupt is pending. | | | | 5 | DMADONE | R | Oh | Raw interrupt flag for DMADONE. This bit is reset to 0 by IIDX read or when corresponding bit in ICLR_EX is set to 1. 0h = Interrupt is not pending. 1h = Interrupt is pending. | | | | 4 | INIFG | R | 0h | Mask INIFG in MIS_EX register. 0h = Interrupt is not pending. 1h = Interrupt is pending. | | | | 3 | LOWIFG | R | 0h | Raw interrupt flag for the MEMRESx result register being below than the WCLOWx threshold of the window comparator. This bit is reset to 0 by IIDX read or when corresponding bit in ICLR_EX is set to 1. 0h = Interrupt is not pending. 1h = Interrupt is pending. | | | | 2 | HIGHIFG | R | Oh | Raw interrupt flag for the MEMRESx result register being higher than the WCHIGHx threshold of the window comparator. This bit is reset to 0 by IIDX read or when corresponding bit in ICLR_EX is set to 1. 0h = Interrupt is not pending. 1h = Interrupt is pending. | | | | 1 | TOVIFG | R | 0h | Raw interrupt flag for sequence conversion trigger overflow. This bit is reset to 0 by IIDX read or when corresponding bit in ICLR_EX is set to 1. 0h = Interrupt is not pending. 1h = Interrupt is pending. | | | | Bit | Field | Туре | Reset | Description | |-----|-------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | OVIFG | R | | Raw interrupt flag for MEMRESx overflow. This bit is reset to 0 by IIDX read or when corresponding bit in ICLR_EX is set to 1. 0h = Interrupt is not pending. 1h = Interrupt is pending. | # 9.3.10 MIS (Offset = 1038h) [Reset = 00000000h] MIS is shown in Figure 9-15 and described in Table 9-21. Return to the Summary Table. Masked interrupt status. This is an AND of the IMASK and RIS registers. ### Figure 9-15. MIS | | | | 9 | | | | | |-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | MEMRESIFG23 | MEMRESIFG22 | MEMRESIFG21 | MEMRESIFG20 | MEMRESIFG19 | MEMRESIFG18 | MEMRESIFG17 | MEMRESIFG16 | | R-0h | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | MEMRESIFG15 | MEMRESIFG14 | MEMRESIFG13 | MEMRESIFG12 | MEMRESIFG11 | MEMRESIFG10 | MEMRESIFG9 | MEMRESIFG8 | | R-0h | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | MEMRESIFG7 | MEMRESIFG6 | MEMRESIFG5 | MEMRESIFG4 | MEMRESIFG3 | MEMRESIFG2 | MEMRESIFG1 | MEMRESIFG0 | | R-0h | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | ASCDONE | UVIFG | DMADONE | INIFG | LOWIFG | HIGHIFG | TOVIFG | OVIFG | | R-0h ### **Table 9-21. MIS Field Descriptions** | Bit | Field | Туре | Reset | Description | |-----|-------------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 | MEMRESIFG23 | R | Oh | Raw interrupt status for MEMRES23. This bit is set to 1 when MEMRES23 is loaded with a new conversion result. Reading MEMRES23 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 30 | MEMRESIFG22 | R | Oh | Raw interrupt status for MEMRES22. This bit is set to 1 when MEMRES22 is loaded with a new conversion result. Reading MEMRES22 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 29 | MEMRESIFG21 | R | Oh | Raw interrupt status for MEMRES21. This bit is set to 1 when MEMRES21 is loaded with a new conversion result. Reading MEMRES21 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 28 | MEMRESIFG20 | R | Oh | Raw interrupt status for MEMRES20. This bit is set to 1 when MEMRES20 is loaded with a new conversion result. Reading MEMRES20 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 27 | MEMRESIFG19 | R | 0h | Raw interrupt status for MEMRES19. This bit is set to 1 when MEMRES19 is loaded with a new conversion result. Reading MEMRES19 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | Bit Field Type Reset Description | | | | | | |----------------------------------|--------------|---|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | 26 | MEMRESIFG18 | R | 0h | Raw interrupt status for MEMRES18. | | | 20 | WEWIXESH 910 | K | OII | This bit is set to 1 when MEMRES18 is loaded with a new conversion result. Reading MEMRES18 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | 25 | MEMRESIFG17 | R | 0h | Raw interrupt status for MEMRES17. This bit is set to 1 when MEMRES17 is loaded with a new conversion result. Reading MEMRES17 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | 24 | MEMRESIFG16 | R | Oh | Raw interrupt status for MEMRES16. This bit is set to 1 when MEMRES16 is loaded with a new conversion result. Reading MEMRES16 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | 23 | MEMRESIFG15 | R | 0h | Raw interrupt status for MEMRES15. This bit is set to 1 when MEMRES15 is loaded with a new conversion result. Reading MEMRES15 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | 22 | MEMRESIFG14 | R | 0h | Raw interrupt status for MEMRES14. This bit is set to 1 when MEMRES14 is loaded with a new conversion result. Reading MEMRES14 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | 21 | MEMRESIFG13 | R | 0h | Raw interrupt status for MEMRES13. This bit is set to 1 when MEMRES13 is loaded with a new conversion result. Reading MEMRES13 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | 20 | MEMRESIFG12 | R | Oh | Raw interrupt status for MEMRES12. This bit is set to 1 when MEMRES12 is loaded with a new conversion result. Reading MEMRES12 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | 19 | MEMRESIFG11 | R | Oh | Raw interrupt status for MEMRES11. This bit is set to 1 when MEMRES11 is loaded with a new conversion result. Reading MEMRES11 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | Table 9-21. MIS Field Descriptions (continued) | | | | | | | | |------------------------------------------------|-------------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | 18 | MEMRESIFG10 | R | Oh | Raw interrupt status for MEMRES10. This bit is set to 1 when MEMRES10 is loaded with a new conversion result. Reading MEMRES10 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | | 17 | MEMRESIFG9 | R | Oh | Raw interrupt status for MEMRES9. This bit is set to 1 when MEMRES9 is loaded with a new conversion result. Reading MEMRES9 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | | 16 | MEMRESIFG8 | R | Oh | Raw interrupt status for MEMRES8. This bit is set to 1 when MEMRES8 is loaded with a new conversion result. Reading MEMRES8 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | | 15 | MEMRESIFG7 | R | Oh | Raw interrupt status for MEMRES7. This bit is set to 1 when MEMRES7 is loaded with a new conversion result. Reading MEMRES7 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | | 14 | MEMRESIFG6 | R | 0h | Raw interrupt status for MEMRES6. This bit is set to 1 when MEMRES6 is loaded with a new conversion result. Reading MEMRES6 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | | 13 | MEMRESIFG5 | R | 0h | Raw interrupt status for MEMRES5. This bit is set to 1 when MEMRES5 is loaded with a new conversion result. Reading MEMRES5 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | | 12 | MEMRESIFG4 | R | Oh | Raw interrupt status for MEMRES4. This bit is set to 1 when MEMRES4 is loaded with a new conversion result. Reading MEMRES4 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | | 11 | MEMRESIFG3 | R | 0h | Raw interrupt status for MEMRES3. This bit is set to 1 when MEMRES3 is loaded with a new conversion result. Reading MEMRES3 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | | D:4 | Table 9-21. MIS Field Descriptions (continued) | | | | | | |-----|------------------------------------------------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Bit | Field | Туре | Reset | Description Description | | | | 10 | MEMRESIFG2 | R | Oh | Raw interrupt status for MEMRES2. This bit is set to 1 when MEMRES2 is loaded with a new conversion result. Reading MEMRES2 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | 9 | MEMRESIFG1 | R | Oh | Raw interrupt status for MEMRES1. This bit is set to 1 when MEMRES1 is loaded with a new conversion result. Reading MEMRES1 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | 8 | MEMRESIFG0 | R | Oh | Raw interrupt status for MEMRES0. This bit is set to 1 when MEMRES0 is loaded with a new conversion result. Reading MEMRES0 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | 7 | ASCDONE | R | 0h | Masked interrupt status for ASC done 0h = Interrupt is not pending. 1h = Interrupt is pending. | | | | 6 | UVIFG | R | 0h | Raw interrupt flag for MEMRESx underflow. This bit is reset to 0 by IIDX read or when corresponding bit in ICLR is set to 1. 0h = Interrupt is not pending. 1h = Interrupt is pending. | | | | 5 | DMADONE | R | Oh | Raw interrupt flag for DMADONE. This bit is reset to 0 by IIDX read or when corresponding bit in ICLR_EX is set to 1. 0h = Interrupt is not pending. 1h = Interrupt is pending. | | | | 4 | INIFG | R | 0h | Mask INIFG in MIS_EX register. 0h = Interrupt is not pending. 1h = Interrupt is pending. | | | | 3 | LOWIFG | R | Oh | Raw interrupt flag for the MEMRESx result register being below than the WCLOWx threshold of the window comparator. This bit is reset to 0 by IIDX read or when corresponding bit in ICLR_EX is set to 1. 0h = Interrupt is not pending. 1h = Interrupt is pending. | | | | 2 | HIGHIFG | R | Oh | Raw interrupt flag for the MEMRESx result register being higher than the WCHIGHx threshold of the window comparator. This bit is reset to 0 by IIDX read or when corresponding bit in ICLR_EX is set to 1. 0h = Interrupt is not pending. 1h = Interrupt is pending. | | | | 1 | TOVIFG | R | Oh | Raw interrupt flag for sequence conversion timeout overflow. This bit is reset to 0 by IIDX read or when corresponding bit in ICLR_EX is set to 1. 0h = Interrupt is not pending. 1h = Interrupt is pending. | | | | 0 | OVIFG | R | Oh | Raw interrupt flag for MEMRESx overflow. This bit is reset to 0 by IIDX read or when corresponding bit in ICLR_EX is set to 1. 0h = Interrupt is not pending. 1h = Interrupt is pending. | | | ### 9.3.11 ISET (Offset = 1040h) [Reset = 00000000h] ISET is shown in Figure 9-16 and described in Table 9-22. Return to the Summary Table. Interrupt set. Allows interrupts to be set by software (useful in diagnostics and safety checks). Writing a 1 to a bit in ISET will set the event and therefore the related RIS bit also gets set. If the interrupt is enabled through the mask, then the corresponding MIS bit is also set. Figure 9-16. ISET | | | | i iguie 3 | - 10. IOL I | | | | |-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | MEMRESIFG23 | MEMRESIFG22 | MEMRESIFG21 | MEMRESIFG20 | MEMRESIFG19 | MEMRESIFG18 | MEMRESIFG17 | MEMRESIFG16 | | W-0h | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | MEMRESIFG15 | MEMRESIFG14 | MEMRESIFG13 | MEMRESIFG12 | MEMRESIFG11 | MEMRESIFG10 | MEMRESIFG9 | MEMRESIFG8 | | W-0h | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | MEMRESIFG7 | MEMRESIFG6 | MEMRESIFG5 | MEMRESIFG4 | MEMRESIFG3 | MEMRESIFG2 | MEMRESIFG1 | MEMRESIFG0 | | W-0h | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | ASCDONE | UVIFG | DMADONE | INIFG | LOWIFG | HIGHIFG | TOVIFG | OVIFG | | W-0h ### **Table 9-22. ISET Field Descriptions** | Bit | Field | Туре | Reset | Description | |-----|-------------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 | MEMRESIFG23 | W | 0h | Raw interrupt status for MEMRES23. This bit is set to 1 when MEMRES23 is loaded with a new conversion result. Reading MEMRES23 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 30 | MEMRESIFG22 | W | Oh | Raw interrupt status for MEMRES22. This bit is set to 1 when MEMRES22 is loaded with a new conversion result. Reading MEMRES22 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 29 | MEMRESIFG21 | W | Oh | Raw interrupt status for MEMRES21. This bit is set to 1 when MEMRES21 is loaded with a new conversion result. Reading MEMRES21 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 28 | MEMRESIFG20 | W | Oh | Raw interrupt status for MEMRES20. This bit is set to 1 when MEMRES20 is loaded with a new conversion result. Reading MEMRES20 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | Bit | Field | Type | Reset | Descriptions (continued) | |-----|--------------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 27 | MEMRESIFG19 | W | 0h | Raw interrupt status for MEMRES19. | | 21 | WEWINESH G19 | | | This bit is set to 1 when MEMRES19 is loaded with a new conversion result. Reading MEMRES19 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 26 | MEMRESIFG18 | W | Oh | Raw interrupt status for MEMRES18. This bit is set to 1 when MEMRES18 is loaded with a new conversion result. Reading MEMRES18 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 25 | MEMRESIFG17 | W | Oh | Raw interrupt status for MEMRES17. This bit is set to 1 when MEMRES17 is loaded with a new conversion result. Reading MEMRES17 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 24 | MEMRESIFG16 | W | Oh | Raw interrupt status for MEMRES16. This bit is set to 1 when MEMRES16 is loaded with a new conversion result. Reading MEMRES16 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 23 | MEMRESIFG15 | W | Oh | Raw interrupt status for MEMRES15. This bit is set to 1 when MEMRES15 is loaded with a new conversion result. Reading MEMRES15 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 22 | MEMRESIFG14 | W | Oh | Raw interrupt status for MEMRES14. This bit is set to 1 when MEMRES14 is loaded with a new conversion result. Reading MEMRES14 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 21 | MEMRESIFG13 | W | Oh | Raw interrupt status for MEMRES13. This bit is set to 1 when MEMRES13 is loaded with a new conversion result. Reading MEMRES13 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 20 | MEMRESIFG12 | W | 0h | Raw interrupt status for MEMRES12. This bit is set to 1 when MEMRES12 is loaded with a new conversion result. Reading MEMRES12 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | Bit | Field | Type | Reset | Descriptions (continued) | |-----|--------------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 19 | MEMRESIFG11 | W | 0h | Raw interrupt status for MEMRES11. | | 19 | MEMIXESH STI | VV | UII | This bit is set to 1 when MEMRES11 is loaded with a new conversion result. Reading MEMRES11 register will clear this bit, or when the corresponding bit in ICLR is set to 1 Oh = No new data ready. 1h = A new data is ready to be read. | | 18 | MEMRESIFG10 | W | Oh | Raw interrupt status for MEMRES10. This bit is set to 1 when MEMRES10 is loaded with a new conversion result. Reading MEMRES10 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 17 | MEMRESIFG9 | W | 0h | Raw interrupt status for MEMRES9. This bit is set to 1 when MEMRES9 is loaded with a new conversion result. Reading MEMRES9 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 16 | MEMRESIFG8 | W | Oh | Raw interrupt status for MEMRES8. This bit is set to 1 when MEMRES8 is loaded with a new conversion result. Reading MEMRES8 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 15 | MEMRESIFG7 | W | Oh | Raw interrupt status for MEMRES7. This bit is set to 1 when MEMRES7 is loaded with a new conversion result. Reading MEMRES7 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 14 | MEMRESIFG6 | W | Oh | Raw interrupt status for MEMRES6. This bit is set to 1 when MEMRES6 is loaded with a new conversion result. Reading MEMRES6 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 13 | MEMRESIFG5 | W | 0h | Raw interrupt status for MEMRES5. This bit is set to 1 when MEMRES5 is loaded with a new conversion result. Reading MEMRES5 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 12 | MEMRESIFG4 | W | 0h | Raw interrupt status for MEMRES4. This bit is set to 1 when MEMRES4 is loaded with a new conversion result. Reading MEMRES4 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | ## **Table 9-22. ISET Field Descriptions (continued)** | | | | | Descriptions (continued) | |-----|------------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Field | Туре | Reset | Description | | 11 | MEMRESIFG3 | W | Oh | Raw interrupt status for MEMRES3. This bit is set to 1 when MEMRES3 is loaded with a new conversion result. Reading MEMRES3 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 10 | MEMRESIFG2 | W | Oh | Raw interrupt status for MEMRES2. This bit is set to 1 when MEMRES2 is loaded with a new conversion result. Reading MEMRES2 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 9 | MEMRESIFG1 | W | Oh | Raw interrupt status for MEMRES1. This bit is set to 1 when MEMRES1 is loaded with a new conversion result. Reading MEMRES1 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 8 | MEMRESIFG0 | W | Oh | Raw interrupt status for MEMRES0. This bit is set to 1 when MEMRES0 is loaded with a new conversion result. Reading MEMRES0 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 7 | ASCDONE | W | 0h | Set ASC done flag in RIS 0h = Interrupt is not pending. 1h = Interrupt is pending. | | 6 | UVIFG | W | Oh | Raw interrupt flag for MEMRESx underflow. This bit is reset to 0 by IIDX read or when corresponding bit in ICLR_EX is set to 1. 0h = Interrupt is not pending. 1h = Interrupt is pending. | | 5 | DMADONE | W | Oh | Raw interrupt flag for DMADONE. This bit is reset to 0 by IIDX read or when corresponding bit in ICLR_EX is set to 1. 0h = Interrupt is not pending. 1h = Interrupt is pending. | | 4 | INIFG | W | 0h | Mask INIFG in MIS_EX register. 0h = Interrupt is not pending. 1h = Interrupt is pending. | | 3 | LOWIFG | W | Oh | Raw interrupt flag for the MEMRESx result register being below than the WCLOWx threshold of the window comparator. This bit is reset to 0 by IIDX read or when corresponding bit in ICLR_EX is set to 1. 0h = Interrupt is not pending. 1h = Interrupt is pending. | | 2 | HIGHIFG | W | Oh | Raw interrupt flag for the MEMRESx result register being higher than the WCHIGHx threshold of the window comparator. This bit is reset to 0 by IIDX read or when corresponding bit in ICLR_EX is set to 1. 0h = Interrupt is not pending. 1h = Interrupt is pending. | | 1 | TOVIFG | W | 0h | Raw interrupt flag for sequence conversion timeout overflow. This bit is reset to 0 by IIDX read or when corresponding bit in ICLR_EX is set to 1. 0h = Interrupt is not pending. 1h = Interrupt is pending. | # Table 9-22. ISET Field Descriptions (continued) | Bit | Field | Туре | Reset | Description | |-----|-------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | OVIFG | W | | Raw interrupt flag for MEMRESx overflow. This bit is reset to 0 by IIDX read or when corresponding bit in ICLR_EX is set to 1. 0h = Interrupt is not pending. 1h = Interrupt is pending. | ## 9.3.12 ICLR (Offset = 1048h) [Reset = 00000000h] ICLR is shown in Figure 9-17 and described in Table 9-23. Return to the Summary Table. Interrupt clear. Write a 1 to clear corresponding Interrupt. ### Figure 9-17. ICLR | | | | 9 | | | | | |-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | MEMRESIFG23 | MEMRESIFG22 | MEMRESIFG21 | MEMRESIFG20 | MEMRESIFG19 | MEMRESIFG18 | MEMRESIFG17 | MEMRESIFG16 | | W-0h | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | MEMRESIFG15 | MEMRESIFG14 | MEMRESIFG13 | MEMRESIFG12 | MEMRESIFG11 | MEMRESIFG10 | MEMRESIFG9 | MEMRESIFG8 | | W-0h | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | MEMRESIFG7 | MEMRESIFG6 | MEMRESIFG5 | MEMRESIFG4 | MEMRESIFG3 | MEMRESIFG2 | MEMRESIFG1 | MEMRESIFG0 | | W-0h | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | ASCDONE | UVIFG | DMADONE | INIFG | LOWIFG | HIGHIFG | TOVIFG | OVIFG | | W-0h ### Table 9-23. ICLR Field Descriptions | Bit | Field | Туре | Reset | Description | |-----|-------------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 | MEMRESIFG23 | W | Oh | Raw interrupt status for MEMRES23. This bit is set to 1 when MEMRES23 is loaded with a new conversion result. Reading MEMRES23 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 30 | MEMRESIFG22 | W | Oh | Raw interrupt status for MEMRES22. This bit is set to 1 when MEMRES22 is loaded with a new conversion result. Reading MEMRES22 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 29 | MEMRESIFG21 | W | Oh | Raw interrupt status for MEMRES21. This bit is set to 1 when MEMRES21 is loaded with a new conversion result. Reading MEMRES21 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 28 | MEMRESIFG20 | W | 0h | Raw interrupt status for MEMRES20. This bit is set to 1 when MEMRES20 is loaded with a new conversion result. Reading MEMRES20 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 27 | MEMRESIFG19 | W | Oh | Raw interrupt status for MEMRES19. This bit is set to 1 when MEMRES19 is loaded with a new conversion result. Reading MEMRES19 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | ## Table 9-23. ICLR Field Descriptions (continued) | Bit | Field | Type | Reset | Descriptions (continued) | |-----|---------------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 26 | MEMRESIFG18 | W | 0h | Raw interrupt status for MEMRES18. | | 20 | WEIWINEON GTO | W | OII | This bit is set to 1 when MEMRES18 is loaded with a new conversion result. Reading MEMRES18 register will clear this bit, or when the corresponding bit in ICLR is set to 1 Oh = No new data ready. 1h = A new data is ready to be read. | | 25 | MEMRESIFG17 | W | Oh | Raw interrupt status for MEMRES17. This bit is set to 1 when MEMRES17 is loaded with a new conversion result. Reading MEMRES17 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 24 | MEMRESIFG16 | W | Oh | Raw interrupt status for MEMRES16. This bit is set to 1 when MEMRES16 is loaded with a new conversion result. Reading MEMRES16 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 23 | MEMRESIFG15 | W | Oh | Raw interrupt status for MEMRES15. This bit is set to 1 when MEMRES15 is loaded with a new conversion result. Reading MEMRES15 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 22 | MEMRESIFG14 | W | Oh | Raw interrupt status for MEMRES14. This bit is set to 1 when MEMRES14 is loaded with a new conversion result. Reading MEMRES14 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 21 | MEMRESIFG13 | W | Oh | Raw interrupt status for MEMRES13. This bit is set to 1 when MEMRES13 is loaded with a new conversion result. Reading MEMRES13 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 20 | MEMRESIFG12 | W | Oh | Raw interrupt status for MEMRES12. This bit is set to 1 when MEMRES12 is loaded with a new conversion result. Reading MEMRES12 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 19 | MEMRESIFG11 | W | Oh | Raw interrupt status for MEMRES11. This bit is set to 1 when MEMRES11 is loaded with a new conversion result. Reading MEMRES11 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | ## Table 9-23. ICLR Field Descriptions (continued) | Bit | Field | Type | Reset | Descriptions (continued) | |-----|-------------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 18 | MEMRESIFG10 | W | Oh | Raw interrupt status for MEMRES10. This bit is set to 1 when MEMRES10 is loaded with a new conversion result. Reading MEMRES10 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 17 | MEMRESIFG9 | W | Oh | Raw interrupt status for MEMRES9. This bit is set to 1 when MEMRES9 is loaded with a new conversion result. Reading MEMRES9 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 16 | MEMRESIFG8 | W | Oh | Raw interrupt status for MEMRES8. This bit is set to 1 when MEMRES8 is loaded with a new conversion result. Reading MEMRES8 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 15 | MEMRESIFG7 | W | Oh | Raw interrupt status for MEMRES7. This bit is set to 1 when MEMRES7 is loaded with a new conversion result. Reading MEMRES7 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 14 | MEMRESIFG6 | W | Oh | Raw interrupt status for MEMRES6. This bit is set to 1 when MEMRES6 is loaded with a new conversion result. Reading MEMRES6 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 13 | MEMRESIFG5 | W | Oh | Raw interrupt status for MEMRES5. This bit is set to 1 when MEMRES5 is loaded with a new conversion result. Reading MEMRES5 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 12 | MEMRESIFG4 | W | Oh | Raw interrupt status for MEMRES4. This bit is set to 1 when MEMRES4 is loaded with a new conversion result. Reading MEMRES4 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 11 | MEMRESIFG3 | W | Oh | Raw interrupt status for MEMRES3. This bit is set to 1 when MEMRES3 is loaded with a new conversion result. Reading MEMRES3 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | ### Table 9-23. ICLR Field Descriptions (continued) | D:4 | Field | | | Descriptions (continued) | |-----|------------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Field | Туре | Reset | Description | | 10 | MEMRESIFG2 | W | Oh | Raw interrupt status for MEMRES2. This bit is set to 1 when MEMRES2 is loaded with a new conversion result. Reading MEMRES2 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 9 | MEMRESIFG1 | W | Oh | Raw interrupt status for MEMRES1. This bit is set to 1 when MEMRES1 is loaded with a new conversion result. Reading MEMRES1 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 8 | MEMRESIFG0 | W | Oh | Raw interrupt status for MEMRES0. This bit is set to 1 when MEMRES0 is loaded with a new conversion result. Reading MEMRES0 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 7 | ASCDONE | W | 0h | Clear ASC done flag in RIS 0h = Interrupt is not pending. 1h = Interrupt is pending. | | 6 | UVIFG | W | Oh | Raw interrupt flag for MEMRESx underflow. This bit is reset to 0 by IIDX read or when corresponding bit in ICLR_EX is set to 1. 0h = Interrupt is not pending. 1h = Interrupt is pending. | | 5 | DMADONE | W | Oh | Raw interrupt flag for DMADONE. This bit is reset to 0 by IIDX read or when corresponding bit in ICLR_EX is set to 1. 0h = Interrupt is not pending. 1h = Interrupt is pending. | | 4 | INIFG | W | 0h | Mask INIFG in MIS_EX register. 0h = Interrupt is not pending. 1h = Interrupt is pending. | | 3 | LOWIFG | W | Oh | Raw interrupt flag for the MEMRESx result register being below than the WCLOWx threshold of the window comparator. This bit is reset to 0 by IIDX read or when corresponding bit in ICLR_EX is set to 1. 0h = Interrupt is not pending. 1h = Interrupt is pending. | | 2 | HIGHIFG | W | Oh | Raw interrupt flag for the MEMRESx result register being higher than the WCHIGHx threshold of the window comparator. This bit is reset to 0 by IIDX read or when corresponding bit in ICLR_EX is set to 1. 0h = Interrupt is not pending. 1h = Interrupt is pending. | | 1 | TOVIFG | W | Oh | Raw interrupt flag for sequence conversion timeout overflow. This bit is reset to 0 by IIDX read or when corresponding bit in ICLR_EX is set to 1. 0h = Interrupt is not pending. 1h = Interrupt is pending. | | 0 | OVIFG | W | Oh | Raw interrupt flag for MEMRESx overflow. This bit is reset to 0 by IIDX read or when corresponding bit in ICLR_EX is set to 1. 0h = Interrupt is not pending. 1h = Interrupt is pending. | ### 9.3.13 IIDX (Offset = 1050h) [Reset = 00000000h] IIDX is shown in Figure 9-18 and described in Table 9-24. Return to the Summary Table. This register provides the highest priority enabled interrupt index. 0x0 means no event pending. Interrupt 1 is the highest priority, 2 next highest, 4, 8, ... $2^{31}$ is the least priority. That is, the least bit position that is set to 1 denotes the highest priority pending interrupt. The priority order is fixed. However, users can implement their own prioritization schemes using other registers that expose the full set of interrupts that have occurred. On each read, only one interrupt is indicated. On a read, the current interrupt (highest priority) is automatically cleared by the hardware and the corresponding interrupt flag in the RIS and MIS are cleared as well. After a read from the CPU (not from the debug interface), the register must be updated with the next highest priority interrupt, if none are pending, then it should display 0x0. #### Figure 9-18. IIDX #### Table 9-24. IIDX Field Descriptions | Bit | Field | Туре | Reset | Description | | | |-------|----------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | 31-10 | RESERVED | R | 0h | | | | | 9-0 | STAT | R | 0h | Interrupt index status 00h = No bit is set means there is no pending interrupt request 03h = High threshold compare interrupt 04h = Low threshold compare interrupt 05h = Primary Sequence In range comparator interrupt 9h = MEMRES0 data loaded interrupt | | | ### 9.3.14 IMASK (Offset = 1058h) [Reset = 00000000h] IMASK is shown in Figure 9-19 and described in Table 9-25. Return to the Summary Table. Interrupt Mask. If a bit is set, then corresponding interrupt is un-masked. Un-masking the interrupt causes the raw interrupt to be visible in IIDX, as well as MIS. Figure 9-19. IMASK **Table 9-25. IMASK Field Descriptions** | Bit | Field | Туре | Reset | Description | |------|------------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-9 | RESERVED | R/W | 0h | | | 8 | MEMRESIFG0 | R/W | 0h | Raw interrupt status for MEMRES0. This bit is set to 1 when MEMRES0 is loaded with a new conversion result. Reading MEMRES0 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 7-5 | RESERVED | R/W | 0h | | | 4 | INIFG | R/W | Oh | Mask INIFG in MIS_EX register. 0h = Interrupt is not pending. 1h = Interrupt is pending. | | 3 | LOWIFG | R/W | 0h | Raw interrupt flag for the MEMRESx result register being below than the WCLOWx threshold of the window comparator. This bit is reset to 0 by IIDX read or when corresponding bit in ICLR_EX is set to 1. 0h = Interrupt is not pending. 1h = Interrupt is pending. | | 2 | HIGHIFG | R/W | 0h | Raw interrupt flag for the MEMRESx result register being higher than the WCHIGHx threshold of the window comparator. This bit is reset to 0 by IIDX read or when corresponding bit in ICLR_EX is set to 1. 0h = Interrupt is not pending. 1h = Interrupt is pending. | | 1-0 | RESERVED | R/W | 0h | | ### 9.3.15 RIS (Offset = 1060h) [Reset = 00000000h] RIS is shown in Figure 9-20 and described in Table 9-26. Return to the Summary Table. Raw interrupt status. Reflects all pending interrupts, regardless of masking. The RIS register allows the user to implement a poll scheme. A flag set in this register can be cleared by writing 1 to the ICLR register bit even if the corresponding IMASK bit is not enabled. Figure 9-20. RIS #### Table 9-26. RIS Field Descriptions | Bit | Field | Туре | Reset | Description | |------|------------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-9 | RESERVED | R | 0h | | | 8 | MEMRESIFG0 | R | 0h | Raw interrupt status for MEMRES0. This bit is set to 1 when MEMRES0 is loaded with a new conversion result. Reading MEMRES0 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 7-5 | RESERVED | R | 0h | | | 4 | INIFG | R | Oh | Mask INIFG in MIS_EX register. 0h = Interrupt is not pending. 1h = Interrupt is pending. | | 3 | LOWIFG | R | 0h | Raw interrupt flag for the MEMRESx result register being below than the WCLOWx threshold of the window comparator. This bit is reset to 0 by IIDX read or when corresponding bit in ICLR_EX is set to 1. 0h = Interrupt is not pending. 1h = Interrupt is pending. | | 2 | HIGHIFG | R | 0h | Raw interrupt flag for the MEMRESx result register being higher than the WCHIGHx threshold of the window comparator. This bit is reset to 0 by IIDX read or when corresponding bit in ICLR_EX is set to 1. 0h = Interrupt is not pending. 1h = Interrupt is pending. | | 1-0 | RESERVED | R | 0h | | ## 9.3.16 MIS (Offset = 1068h) [Reset = 00000000h] MIS is shown in Figure 9-21 and described in Table 9-27. Return to the Summary Table. Masked interrupt status. This is an AND of the IMASK and RIS registers. ### Figure 9-21. MIS | i igaio o z ii iiiio | | | | | | | | | |----------------------------------------|------|----|----------|------|------|------|------------|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | | RESE | RVED | | | | | | | R-0h | | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | | RESE | RVED | | | | | | | R-0h | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | RESERVED | | | | MEMRESIFG0 | | | | | | R-0h | | | | R-0h | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | RESERVED INIFG LOWIFG HIGHIFG RESERVED | | | | | | RVED | | | | | R-0h | | R-0h | R-0h | R-0h | R- | ·0h | | ### **Table 9-27. MIS Field Descriptions** | Bit | Field | Туре | Reset | Description | |------|------------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-9 | RESERVED | R | 0h | | | 8 | MEMRESIFG0 | R | 0h | Raw interrupt status for MEMRES0. This bit is set to 1 when MEMRES0 is loaded with a new conversion result. Reading MEMRES0 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 7-5 | RESERVED | R | 0h | | | 4 | INIFG | R | Oh | Mask INIFG in MIS_EX register. 0h = Interrupt is not pending. 1h = Interrupt is pending. | | 3 | LOWIFG | R | 0h | Raw interrupt flag for the MEMRESx result register being below than the WCLOWx threshold of the window comparator. This bit is reset to 0 by IIDX read or when corresponding bit in ICLR_EX is set to 1. 0h = Interrupt is not pending. 1h = Interrupt is pending. | | 2 | HIGHIFG | R | 0h | Raw interrupt flag for the MEMRESx result register being higher than the WCHIGHx threshold of the window comparator. This bit is reset to 0 by IIDX read or when corresponding bit in ICLR_EX is set to 1. 0h = Interrupt is not pending. 1h = Interrupt is pending. | | 1-0 | RESERVED | R | 0h | | ### 9.3.17 ISET (Offset = 1070h) [Reset = 00000000h] ISET is shown in Figure 9-22 and described in Table 9-28. Return to the Summary Table. Interrupt set. Allows interrupts to be set by software (useful in diagnostics and safety checks). Writing a 1 to a bit in ISET will set the event and therefore the related RIS bit also gets set. If the interrupt is enabled through the mask, then the corresponding MIS bit is also set. Figure 9-22. ISET #### Table 9-28. ISET Field Descriptions | Bit | Field | Туре | Reset | Description | |------|------------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-9 | RESERVED | W | 0h | | | 8 | MEMRESIFG0 | W | 0h | Raw interrupt status for MEMRES0. This bit is set to 1 when MEMRES0 is loaded with a new conversion result. Reading MEMRES0 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 7-5 | RESERVED | W | 0h | | | 4 | INIFG | W | Oh | Mask INIFG in MIS_EX register. 0h = Interrupt is not pending. 1h = Interrupt is pending. | | 3 | LOWIFG | W | 0h | Raw interrupt flag for the MEMRESx result register being below than the WCLOWx threshold of the window comparator. This bit is reset to 0 by IIDX read or when corresponding bit in ICLR_EX is set to 1. 0h = Interrupt is not pending. 1h = Interrupt is pending. | | 2 | HIGHIFG | W | 0h | Raw interrupt flag for the MEMRESx result register being higher than the WCHIGHx threshold of the window comparator. This bit is reset to 0 by IIDX read or when corresponding bit in ICLR_EX is set to 1. 0h = Interrupt is not pending. 1h = Interrupt is pending. | | 1-0 | RESERVED | W | 0h | | ## 9.3.18 ICLR (Offset = 1078h) [Reset = 00000000h] ICLR is shown in Figure 9-23 and described in Table 9-29. Return to the Summary Table. Interrupt clear. Write a 1 to clear corresponding Interrupt. ### Figure 9-23. ICLR | | | | 9 | | | | | | | | |----|----------------------------------------|----|----------|------|------|----|------------|--|--|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | | RESERVED | | | | | | | | | | | | W-0h | | | | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | | RESERVED | | | | | | | | | | | | W-0h | | | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | | | RESERVED | | | | MEMRESIFG0 | | | | | | | | W-0h | | | | W-0h | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | RESERVED INIFG LOWIFG HIGHIFG RESERVED | | | | | | | | | | | | W-0h | | W-0h | W-0h | W-0h | W | -0h | | | | #### Table 9-29. ICLR Field Descriptions | | Table 5-23. IOER Field Descriptions | | | | | | | |------|-------------------------------------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | 31-9 | RESERVED | W | 0h | | | | | | 8 | MEMRESIFG0 | W | 0h | Raw interrupt status for MEMRES0. This bit is set to 1 when MEMRES0 is loaded with a new conversion result. Reading MEMRES0 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | | 7-5 | RESERVED | W | 0h | | | | | | 4 | INIFG | W | Oh | Mask INIFG in MIS_EX register. 0h = Interrupt is not pending. 1h = Interrupt is pending. | | | | | 3 | LOWIFG | W | 0h | Raw interrupt flag for the MEMRESx result register being below than the WCLOWx threshold of the window comparator. This bit is reset to 0 by IIDX read or when corresponding bit in ICLR_EX is set to 1. 0h = Interrupt is not pending. 1h = Interrupt is pending. | | | | | 2 | HIGHIFG | W | 0h | Raw interrupt flag for the MEMRESx result register being higher than the WCHIGHx threshold of the window comparator. This bit is reset to 0 by IIDX read or when corresponding bit in ICLR_EX is set to 1. 0h = Interrupt is not pending. 1h = Interrupt is pending. | | | | | 1-0 | RESERVED | W | 0h | | | | | ### 9.3.19 IIDX (Offset = 1080h) [Reset = 00000000h] IIDX is shown in Figure 9-24 and described in Table 9-30. Return to the Summary Table. This register provides the highest priority enabled interrupt index. 0x0 means no event pending. Interrupt 1 is the highest priority, 2 next highest, 4, 8, ... $2^{31}$ is the least priority. That is, the least bit position that is set to 1 denotes the highest priority pending interrupt. The priority order is fixed. However, users can implement their own prioritization schemes using other registers that expose the full set of interrupts that have occurred. On each read, only one interrupt is indicated. On a read, the current interrupt (highest priority) is automatically cleared by the hardware and the corresponding interrupt flag in the RIS and MIS are cleared as well. After a read from the CPU (not from the debug interface), the register must be updated with the next highest priority interrupt, if none are pending, then it should display 0x0. #### Figure 9-24. IIDX #### Table 9-30. IIDX Field Descriptions | Bit Field Type Reset Description | | | | | | |----------------------------------|------|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Field | туре | Reset | Description | | | | RESERVED | R | 0h | | | | | STAT | R | Oh | Interrupt index status 00h = No bit is set means there is no pending interrupt request 9h = MEMRES0 data loaded interrupt Ah = MEMRES1 data loaded interrupt Bh = MEMRES2 data loaded interrupt Ch = MEMRES3 data loaded interrupt Dh = MEMRES4 data loaded interrupt Eh = MEMRES5 data loaded interrupt Fh = MEMRES6 data loaded interrupt 10h = MEMRES7 data loaded interrupt 11h = MEMRES8 data loaded interrupt 12h = MEMRES9 data loaded interrupt 13h = MEMRES9 data loaded interrupt 14h = MEMRES10 data loaded interrupt 15h = MEMRES11 data loaded interrupt 15h = MEMRES12 data loaded interrupt 16h = MEMRES13 data loaded interrupt 17h = MEMRES14 data loaded interrupt 18h = MEMRES15 data loaded interrupt 19h = MEMRES16 data loaded interrupt 18h = MEMRES17 data loaded interrupt 18h = MEMRES18 data loaded interrupt 18h = MEMRES19 data loaded interrupt 18h = MEMRES19 data loaded interrupt 18h = MEMRES20 data loaded interrupt 18h = MEMRES21 data loaded interrupt 18h = MEMRES20 data loaded interrupt 18h = MEMRES21 data loaded interrupt 18h = MEMRES22 data loaded interrupt 18h = MEMRES22 data loaded interrupt 18h = MEMRES22 data loaded interrupt 18h = MEMRES23 data loaded interrupt 18h = MEMRES23 data loaded interrupt 18h = MEMRES23 data loaded interrupt | | | | F | | Field Type RESERVED R | Field Type Reset RESERVED R 0h | | | ### 9.3.20 IMASK (Offset = 1088h) [Reset = 00000000h] IMASK is shown in Figure 9-25 and described in Table 9-31. Return to the Summary Table. Interrupt Mask. If a bit is set, then corresponding interrupt is un-masked. Un-masking the interrupt causes the raw interrupt to be visible in IIDX, as well as MIS. Figure 9-25. IMASK | | Figure 9-25. IMASK | | | | | | | | |-------------|--------------------|-------------|-------------|-------------|-------------|-------------|-------------|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | MEMRESIFG23 | MEMRESIFG22 | MEMRESIFG21 | MEMRESIFG20 | MEMRESIFG19 | MEMRESIFG18 | MEMRESIFG17 | MEMRESIFG16 | | | R/W-0h | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | MEMRESIFG15 | MEMRESIFG14 | MEMRESIFG13 | MEMRESIFG12 | MEMRESIFG11 | MEMRESIFG10 | MEMRESIFG9 | MEMRESIFG8 | | | R/W-0h | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | MEMRESIFG7 | MEMRESIFG6 | MEMRESIFG5 | MEMRESIFG4 | MEMRESIFG3 | MEMRESIFG2 | MEMRESIFG1 | MEMRESIFG0 | | | R/W-0h | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | RESERVED | | | | | | | | | | R/W-0h | | | | | | | | ### **Table 9-31. IMASK Field Descriptions** | Bit | Field | Туре | Reset | Description | |-----|-------------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 | MEMRESIFG23 | R/W | Oh | Raw interrupt status for MEMRES23. This bit is set to 1 when MEMRES23 is loaded with a new conversion result. Reading MEMRES23 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 30 | MEMRESIFG22 | R/W | Oh | Raw interrupt status for MEMRES22. This bit is set to 1 when MEMRES22 is loaded with a new conversion result. Reading MEMRES22 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 29 | MEMRESIFG21 | R/W | Oh | Raw interrupt status for MEMRES21. This bit is set to 1 when MEMRES21 is loaded with a new conversion result. Reading MEMRES21 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 28 | MEMRESIFG20 | R/W | Oh | Raw interrupt status for MEMRES20. This bit is set to 1 when MEMRES20 is loaded with a new conversion result. Reading MEMRES20 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | ## **Table 9-31. IMASK Field Descriptions (continued)** | | | | | Descriptions (continued) | | |-----|-------------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | Bit | Field | Туре | Reset | Description | | | 27 | MEMRESIFG19 | R/W | 0h | Raw interrupt status for MEMRES19. This bit is set to 1 when MEMRES19 is loaded with a new conversion result. Reading MEMRES19 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | 26 | MEMRESIFG18 | R/W | 0h | Raw interrupt status for MEMRES18. This bit is set to 1 when MEMRES18 is loaded with a new conversion result. Reading MEMRES18 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | 25 | MEMRESIFG17 | R/W | Oh | Raw interrupt status for MEMRES17. This bit is set to 1 when MEMRES17 is loaded with a new conversion result. Reading MEMRES17 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | 24 | MEMRESIFG16 | R/W | Oh | Raw interrupt status for MEMRES16. This bit is set to 1 when MEMRES16 is loaded with a new conversion result. Reading MEMRES16 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | 23 | MEMRESIFG15 | R/W | 0h | Raw interrupt status for MEMRES15. This bit is set to 1 when MEMRES15 is loaded with a new conversion result. Reading MEMRES15 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | 22 | MEMRESIFG14 | R/W | Oh | Raw interrupt status for MEMRES14. This bit is set to 1 when MEMRES14 is loaded with a new conversion result. Reading MEMRES14 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | 21 | MEMRESIFG13 | R/W | Oh | Raw interrupt status for MEMRES13. This bit is set to 1 when MEMRES13 is loaded with a new conversion result. Reading MEMRES13 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | 20 | MEMRESIFG12 | R/W | Oh | Raw interrupt status for MEMRES12. This bit is set to 1 when MEMRES12 is loaded with a new conversion result. Reading MEMRES12 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | # **Table 9-31. IMASK Field Descriptions (continued)** | Bit | Field | Туре | Reset | Description Description | |-----|-------------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 19 | MEMRESIFG11 | R/W | 0h | Raw interrupt status for MEMRES11. This bit is set to 1 when MEMRES11 is loaded with a new conversion result. Reading MEMRES11 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 18 | MEMRESIFG10 | R/W | 0h | Raw interrupt status for MEMRES10. This bit is set to 1 when MEMRES10 is loaded with a new conversion result. Reading MEMRES10 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 17 | MEMRESIFG9 | R/W | 0h | Raw interrupt status for MEMRES9. This bit is set to 1 when MEMRES9 is loaded with a new conversion result. Reading MEMRES9 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 16 | MEMRESIFG8 | R/W | 0h | Raw interrupt status for MEMRES8. This bit is set to 1 when MEMRES8 is loaded with a new conversion result. Reading MEMRES8 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 15 | MEMRESIFG7 | R/W | 0h | Raw interrupt status for MEMRES7. This bit is set to 1 when MEMRES7 is loaded with a new conversion result. Reading MEMRES7 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 14 | MEMRESIFG6 | R/W | 0h | Raw interrupt status for MEMRES6. This bit is set to 1 when MEMRES6 is loaded with a new conversion result. Reading MEMRES6 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 13 | MEMRESIFG5 | R/W | 0h | Raw interrupt status for MEMRES5. This bit is set to 1 when MEMRES5 is loaded with a new conversion result. Reading MEMRES5 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 12 | MEMRESIFG4 | R/W | 0h | Raw interrupt status for MEMRES4. This bit is set to 1 when MEMRES4 is loaded with a new conversion result. Reading MEMRES4 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | ## **Table 9-31. IMASK Field Descriptions (continued)** | | Table 9-31. IMASK Field Descriptions (Continued) | | | | | | | | |-----|--------------------------------------------------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | | 11 | MEMRESIFG3 | R/W | Oh | Raw interrupt status for MEMRES3. This bit is set to 1 when MEMRES3 is loaded with a new conversion result. Reading MEMRES3 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | | | 10 | MEMRESIFG2 | R/W | Oh | Raw interrupt status for MEMRES2. This bit is set to 1 when MEMRES2 is loaded with a new conversion result. Reading MEMRES2 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | | | 9 | MEMRESIFG1 | R/W | Oh | Raw interrupt status for MEMRES1. This bit is set to 1 when MEMRES1 is loaded with a new conversion result. Reading MEMRES1 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | | | 8 | MEMRESIFG0 | R/W | 0h | Raw interrupt status for MEMRES0. This bit is set to 1 when MEMRES0 is loaded with a new conversion result. Reading MEMRES0 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | | | 7-0 | RESERVED | R/W | 0h | | | | | | ### 9.3.21 RIS (Offset = 1090h) [Reset = 00000000h] RIS is shown in Figure 9-26 and described in Table 9-32. Return to the Summary Table. Raw interrupt status. Reflects all pending interrupts, regardless of masking. The RIS register allows the user to implement a poll scheme. A flag set in this register can be cleared by writing 1 to the ICLR register bit even if the corresponding IMASK bit is not enabled. Figure 9-26. RIS | | 1 iguie 3-20. Nio | | | | | | | | |-------------|-------------------|-------------|-------------|-------------|-------------|-------------|-------------|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | MEMRESIFG23 | MEMRESIFG22 | MEMRESIFG21 | MEMRESIFG20 | MEMRESIFG19 | MEMRESIFG18 | MEMRESIFG17 | MEMRESIFG16 | | | R-0h | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | MEMRESIFG15 | MEMRESIFG14 | MEMRESIFG13 | MEMRESIFG12 | MEMRESIFG11 | MEMRESIFG10 | MEMRESIFG9 | MEMRESIFG8 | | | R-0h | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | MEMRESIFG7 | MEMRESIFG6 | MEMRESIFG5 | MEMRESIFG4 | MEMRESIFG3 | MEMRESIFG2 | MEMRESIFG1 | MEMRESIFG0 | | | R-0h | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | RESERVED | | | | | | | | | | R-0h | | | | | | | | | I | | | | | | | | | ### Table 9-32. RIS Field Descriptions | Bit | Field | Туре | Reset | Description | |-----|-------------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 | MEMRESIFG23 | R | Oh | Raw interrupt status for MEMRES23. This bit is set to 1 when MEMRES23 is loaded with a new conversion result. Reading MEMRES23 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 30 | MEMRESIFG22 | R | Oh | Raw interrupt status for MEMRES22. This bit is set to 1 when MEMRES22 is loaded with a new conversion result. Reading MEMRES22 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 29 | MEMRESIFG21 | R | Oh | Raw interrupt status for MEMRES21. This bit is set to 1 when MEMRES21 is loaded with a new conversion result. Reading MEMRES21 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 28 | MEMRESIFG20 | R | Oh | Raw interrupt status for MEMRES20. This bit is set to 1 when MEMRES20 is loaded with a new conversion result. Reading MEMRES20 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | ## **Table 9-32. RIS Field Descriptions (continued)** | Bit | Bit Field Type Reset Description | | | | | | |-----|----------------------------------|---|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | 27 | MEMRESIFG19 | R | 0h | Raw interrupt status for MEMRES19. | | | | 21 | INILIMITESII 919 | K | OII | This bit is set to 1 when MEMRES19 is loaded with a new conversion result. Reading MEMRES19 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | 26 | MEMRESIFG18 | R | 0h | Raw interrupt status for MEMRES18. This bit is set to 1 when MEMRES18 is loaded with a new conversion result. Reading MEMRES18 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | 25 | MEMRESIFG17 | R | Oh | Raw interrupt status for MEMRES17. This bit is set to 1 when MEMRES17 is loaded with a new conversion result. Reading MEMRES17 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | 24 | MEMRESIFG16 | R | 0h | Raw interrupt status for MEMRES16. This bit is set to 1 when MEMRES16 is loaded with a new conversion result. Reading MEMRES16 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | 23 | MEMRESIFG15 | R | 0h | Raw interrupt status for MEMRES15. This bit is set to 1 when MEMRES15 is loaded with a new conversion result. Reading MEMRES15 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | 22 | MEMRESIFG14 | R | 0h | Raw interrupt status for MEMRES14. This bit is set to 1 when MEMRES14 is loaded with a new conversion result. Reading MEMRES14 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | 21 | MEMRESIFG13 | R | Oh | Raw interrupt status for MEMRES13. This bit is set to 1 when MEMRES13 is loaded with a new conversion result. Reading MEMRES13 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | 20 | MEMRESIFG12 | R | Oh | Raw interrupt status for MEMRES12. This bit is set to 1 when MEMRES12 is loaded with a new conversion result. Reading MEMRES12 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | # **Table 9-32. RIS Field Descriptions (continued)** | Bit | Field | Туре | Reset | Descriptions (continued) | |-----|-------------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 19 | MEMRESIFG11 | R | 0h | Raw interrupt status for MEMRES11. This bit is set to 1 when MEMRES11 is loaded with a new conversion result. Reading MEMRES11 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 18 | MEMRESIFG10 | R | 0h | Raw interrupt status for MEMRES10. This bit is set to 1 when MEMRES10 is loaded with a new conversion result. Reading MEMRES10 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 17 | MEMRESIFG9 | R | Oh | Raw interrupt status for MEMRES9. This bit is set to 1 when MEMRES9 is loaded with a new conversion result. Reading MEMRES9 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 16 | MEMRESIFG8 | R | Oh | Raw interrupt status for MEMRES8. This bit is set to 1 when MEMRES8 is loaded with a new conversion result. Reading MEMRES8 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 15 | MEMRESIFG7 | R | 0h | Raw interrupt status for MEMRES7. This bit is set to 1 when MEMRES7 is loaded with a new conversion result. Reading MEMRES7 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 14 | MEMRESIFG6 | R | 0h | Raw interrupt status for MEMRES6. This bit is set to 1 when MEMRES6 is loaded with a new conversion result. Reading MEMRES6 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 13 | MEMRESIFG5 | R | 0h | Raw interrupt status for MEMRES5. This bit is set to 1 when MEMRES5 is loaded with a new conversion result. Reading MEMRES5 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 12 | MEMRESIFG4 | R | Oh | Raw interrupt status for MEMRES4. This bit is set to 1 when MEMRES4 is loaded with a new conversion result. Reading MEMRES4 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | ## **Table 9-32. RIS Field Descriptions (continued)** | | Table 3-32. No Field Descriptions (Continued) | | | | | | | | |-----|-----------------------------------------------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | | 11 | MEMRESIFG3 | R | 0h | Raw interrupt status for MEMRES3. This bit is set to 1 when MEMRES3 is loaded with a new conversion result. Reading MEMRES3 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | | | 10 | MEMRESIFG2 | R | 0h | Raw interrupt status for MEMRES2. This bit is set to 1 when MEMRES2 is loaded with a new conversion result. Reading MEMRES2 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | | | 9 | MEMRESIFG1 | R | 0h | Raw interrupt status for MEMRES1. This bit is set to 1 when MEMRES1 is loaded with a new conversion result. Reading MEMRES1 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | | | 8 | MEMRESIFG0 | R | 0h | Raw interrupt status for MEMRES0. This bit is set to 1 when MEMRES0 is loaded with a new conversion result. Reading MEMRES0 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | | | 7-0 | RESERVED | R | 0h | | | | | | ## 9.3.22 MIS (Offset = 1098h) [Reset = 00000000h] MIS is shown in Figure 9-27 and described in Table 9-33. Return to the Summary Table. Extension of Masked interrupt status. This is an AND of the IMASK and RIS registers. ### Figure 9-27. MIS | | | | 1 19410 0 | | | | | | |-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | MEMRESIFG23 | MEMRESIFG22 | MEMRESIFG21 | MEMRESIFG20 | MEMRESIFG19 | MEMRESIFG18 | MEMRESIFG17 | MEMRESIFG16 | | | R-0h | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | MEMRESIFG15 | MEMRESIFG14 | MEMRESIFG13 | MEMRESIFG12 | MEMRESIFG11 | MEMRESIFG10 | MEMRESIFG9 | MEMRESIFG8 | | | R-0h | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | MEMRESIFG7 | MEMRESIFG6 | MEMRESIFG5 | MEMRESIFG4 | MEMRESIFG3 | MEMRESIFG2 | MEMRESIFG1 | MEMRESIFG0 | | | R-0h | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | RESERVED | | | | | | | | | | R-0h | | | | | | | | ### **Table 9-33. MIS Field Descriptions** | Bit | Field | Туре | Reset | Description | |-----|-------------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 | MEMRESIFG23 | R | Oh | Raw interrupt status for MEMRES23. This bit is set to 1 when MEMRES23 is loaded with a new conversion result. Reading MEMRES23 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 30 | MEMRESIFG22 | R | Oh | Raw interrupt status for MEMRES22. This bit is set to 1 when MEMRES22 is loaded with a new conversion result. Reading MEMRES22 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 29 | MEMRESIFG21 | R | Oh | Raw interrupt status for MEMRES21. This bit is set to 1 when MEMRES21 is loaded with a new conversion result. Reading MEMRES21 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 28 | MEMRESIFG20 | R | Oh | Raw interrupt status for MEMRES20. This bit is set to 1 when MEMRES20 is loaded with a new conversion result. Reading MEMRES20 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 27 | MEMRESIFG19 | R | 0h | Raw interrupt status for MEMRES19. This bit is set to 1 when MEMRES19 is loaded with a new conversion result. Reading MEMRES19 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | ## **Table 9-33. MIS Field Descriptions (continued)** | Bit | Field | Type | Reset | Description (continued) | |-----|--------------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 26 | MEMRESIFG18 | R | 0h | Raw interrupt status for MEMRES18. | | 20 | WEWIXESH 910 | K | OII | This bit is set to 1 when MEMRES18 is loaded with a new conversion result. Reading MEMRES18 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 25 | MEMRESIFG17 | R | 0h | Raw interrupt status for MEMRES17. This bit is set to 1 when MEMRES17 is loaded with a new conversion result. Reading MEMRES17 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 24 | MEMRESIFG16 | R | Oh | Raw interrupt status for MEMRES16. This bit is set to 1 when MEMRES16 is loaded with a new conversion result. Reading MEMRES16 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 23 | MEMRESIFG15 | R | 0h | Raw interrupt status for MEMRES15. This bit is set to 1 when MEMRES15 is loaded with a new conversion result. Reading MEMRES15 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 22 | MEMRESIFG14 | R | Oh | Raw interrupt status for MEMRES14. This bit is set to 1 when MEMRES14 is loaded with a new conversion result. Reading MEMRES14 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 21 | MEMRESIFG13 | R | 0h | Raw interrupt status for MEMRES13. This bit is set to 1 when MEMRES13 is loaded with a new conversion result. Reading MEMRES13 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 20 | MEMRESIFG12 | R | Oh | Raw interrupt status for MEMRES12. This bit is set to 1 when MEMRES12 is loaded with a new conversion result. Reading MEMRES12 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 19 | MEMRESIFG11 | R | Oh | Raw interrupt status for MEMRES11. This bit is set to 1 when MEMRES11 is loaded with a new conversion result. Reading MEMRES11 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | ## **Table 9-33. MIS Field Descriptions (continued)** | Bit | Field | Type | Reset | Descriptions (continued) Description | |-----|-------------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 18 | MEMRESIFG10 | R | 0h | Raw interrupt status for MEMRES10. This bit is set to 1 when MEMRES10 is loaded with a new conversion result. Reading MEMRES10 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 17 | MEMRESIFG9 | R | 0h | Raw interrupt status for MEMRES9. This bit is set to 1 when MEMRES9 is loaded with a new conversion result. Reading MEMRES9 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 16 | MEMRESIFG8 | R | Oh | Raw interrupt status for MEMRES8. This bit is set to 1 when MEMRES8 is loaded with a new conversion result. Reading MEMRES8 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 15 | MEMRESIFG7 | R | Oh | Raw interrupt status for MEMRES7. This bit is set to 1 when MEMRES7 is loaded with a new conversion result. Reading MEMRES7 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 14 | MEMRESIFG6 | R | Oh | Raw interrupt status for MEMRES6. This bit is set to 1 when MEMRES6 is loaded with a new conversion result. Reading MEMRES6 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 13 | MEMRESIFG5 | R | Oh | Raw interrupt status for MEMRES5. This bit is set to 1 when MEMRES5 is loaded with a new conversion result. Reading MEMRES5 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 12 | MEMRESIFG4 | R | 0h | Raw interrupt status for MEMRES4. This bit is set to 1 when MEMRES4 is loaded with a new conversion result. Reading MEMRES4 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 11 | MEMRESIFG3 | R | 0h | Raw interrupt status for MEMRES3. This bit is set to 1 when MEMRES3 is loaded with a new conversion result. Reading MEMRES3 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | ## **Table 9-33. MIS Field Descriptions (continued)** | | Table 3-30. MIO Field Descriptions (continued) | | | | | | | |-----|------------------------------------------------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | 10 | MEMRESIFG2 | R | Oh | Raw interrupt status for MEMRES2. This bit is set to 1 when MEMRES2 is loaded with a new conversion result. Reading MEMRES2 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | | 9 | MEMRESIFG1 | R | Oh | Raw interrupt status for MEMRES1. This bit is set to 1 when MEMRES1 is loaded with a new conversion result. Reading MEMRES1 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | | 8 | MEMRESIFG0 | R | Oh | Raw interrupt status for MEMRES0. This bit is set to 1 when MEMRES0 is loaded with a new conversion result. Reading MEMRES0 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | | 7-0 | RESERVED | R | 0h | | | | | ### 9.3.23 ISET (Offset = 10A0h) [Reset = 00000000h] ISET is shown in Figure 9-28 and described in Table 9-34. Return to the Summary Table. Interrupt set. Allows interrupts to be set by software (useful in diagnostics and safety checks). Writing a 1 to a bit in ISET will set the event and therefore the related RIS bit also gets set. If the interrupt is enabled through the mask, then the corresponding MIS bit is also set. Figure 9-28. ISET | | | | 1 194100 | -20. IOL I | | | | | |-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | MEMRESIFG23 | MEMRESIFG22 | MEMRESIFG21 | MEMRESIFG20 | MEMRESIFG19 | MEMRESIFG18 | MEMRESIFG17 | MEMRESIFG16 | | | W-0h | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | MEMRESIFG15 | MEMRESIFG14 | MEMRESIFG13 | MEMRESIFG12 | MEMRESIFG11 | MEMRESIFG10 | MEMRESIFG9 | MEMRESIFG8 | | | W-0h | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | MEMRESIFG7 | MEMRESIFG6 | MEMRESIFG5 | MEMRESIFG4 | MEMRESIFG3 | MEMRESIFG2 | MEMRESIFG1 | MEMRESIFG0 | | | W-0h | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | RESERVED | | | | | | | | | | W-0h | | | | | | | | | I | | | | | | | | | ### **Table 9-34. ISET Field Descriptions** | Bit | Field | Туре | Reset | Description | |-----|-------------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 | MEMRESIFG23 | W | 0h | Raw interrupt status for MEMRES23. This bit is set to 1 when MEMRES23 is loaded with a new conversion result. Reading MEMRES23 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 30 | MEMRESIFG22 | W | Oh | Raw interrupt status for MEMRES22. This bit is set to 1 when MEMRES22 is loaded with a new conversion result. Reading MEMRES22 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 29 | MEMRESIFG21 | W | Oh | Raw interrupt status for MEMRES21. This bit is set to 1 when MEMRES21 is loaded with a new conversion result. Reading MEMRES21 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 28 | MEMRESIFG20 | W | 0h | Raw interrupt status for MEMRES20. This bit is set to 1 when MEMRES20 is loaded with a new conversion result. Reading MEMRES20 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | ## **Table 9-34. ISET Field Descriptions (continued)** | Bit | Field | Type | Reset | Description (continued) | |-----|----------------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 27 | MEMRESIFG19 | W | 0h | Raw interrupt status for MEMRES19. | | 21 | IMEMIKESIFG 19 | V | OII | This bit is set to 1 when MEMRES19 is loaded with a new conversion result. Reading MEMRES19 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 26 | MEMRESIFG18 | W | 0h | Raw interrupt status for MEMRES18. This bit is set to 1 when MEMRES18 is loaded with a new conversion result. Reading MEMRES18 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 25 | MEMRESIFG17 | W | 0h | Raw interrupt status for MEMRES17. This bit is set to 1 when MEMRES17 is loaded with a new conversion result. Reading MEMRES17 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 24 | MEMRESIFG16 | W | 0h | Raw interrupt status for MEMRES16. This bit is set to 1 when MEMRES16 is loaded with a new conversion result. Reading MEMRES16 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 23 | MEMRESIFG15 | W | 0h | Raw interrupt status for MEMRES15. This bit is set to 1 when MEMRES15 is loaded with a new conversion result. Reading MEMRES15 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 22 | MEMRESIFG14 | W | Oh | Raw interrupt status for MEMRES14. This bit is set to 1 when MEMRES14 is loaded with a new conversion result. Reading MEMRES14 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 21 | MEMRESIFG13 | W | Oh | Raw interrupt status for MEMRES13. This bit is set to 1 when MEMRES13 is loaded with a new conversion result. Reading MEMRES13 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 20 | MEMRESIFG12 | W | Oh | Raw interrupt status for MEMRES12. This bit is set to 1 when MEMRES12 is loaded with a new conversion result. Reading MEMRES12 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | # Table 9-34. ISET Field Descriptions (continued) | Bit | Field | Туре | Reset | Description Description | |-----|-------------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 19 | MEMRESIFG11 | W | Oh | Raw interrupt status for MEMRES11. This bit is set to 1 when MEMRES11 is loaded with a new conversion result. Reading MEMRES11 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 18 | MEMRESIFG10 | W | 0h | Raw interrupt status for MEMRES10. This bit is set to 1 when MEMRES10 is loaded with a new conversion result. Reading MEMRES10 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 17 | MEMRESIFG9 | W | 0h | Raw interrupt status for MEMRES9. This bit is set to 1 when MEMRES9 is loaded with a new conversion result. Reading MEMRES9 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 16 | MEMRESIFG8 | W | 0h | Raw interrupt status for MEMRES8. This bit is set to 1 when MEMRES8 is loaded with a new conversion result. Reading MEMRES8 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 15 | MEMRESIFG7 | W | 0h | Raw interrupt status for MEMRES7. This bit is set to 1 when MEMRES7 is loaded with a new conversion result. Reading MEMRES7 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 14 | MEMRESIFG6 | W | 0h | Raw interrupt status for MEMRES6. This bit is set to 1 when MEMRES6 is loaded with a new conversion result. Reading MEMRES6 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 13 | MEMRESIFG5 | W | 0h | Raw interrupt status for MEMRES5. This bit is set to 1 when MEMRES5 is loaded with a new conversion result. Reading MEMRES5 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 12 | MEMRESIFG4 | W | Oh | Raw interrupt status for MEMRES4. This bit is set to 1 when MEMRES4 is loaded with a new conversion result. Reading MEMRES4 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | ## **Table 9-34. ISET Field Descriptions (continued)** | Bit | Field | Туре | Reset | Description | |-----|------------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 11 | MEMRESIFG3 | W | 0h | Raw interrupt status for MEMRES3. This bit is set to 1 when MEMRES3 is loaded with a new conversion result. Reading MEMRES3 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 10 | MEMRESIFG2 | W | 0h | Raw interrupt status for MEMRES2. This bit is set to 1 when MEMRES2 is loaded with a new conversion result. Reading MEMRES2 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 9 | MEMRESIFG1 | W | 0h | Raw interrupt status for MEMRES1. This bit is set to 1 when MEMRES1 is loaded with a new conversion result. Reading MEMRES1 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 8 | MEMRESIFG0 | W | 0h | Raw interrupt status for MEMRES0. This bit is set to 1 when MEMRES0 is loaded with a new conversion result. Reading MEMRES0 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 7-0 | RESERVED | W | 0h | | ## 9.3.24 ICLR (Offset = 10A8h) [Reset = 00000000h] ICLR is shown in Figure 9-29 and described in Table 9-35. Return to the Summary Table. Interrupt clear. Write a 1 to clear corresponding Interrupt. ### Figure 9-29. ICLR | | | | 1 194100 | | | | | | |-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | MEMRESIFG23 | MEMRESIFG22 | MEMRESIFG21 | MEMRESIFG20 | MEMRESIFG19 | MEMRESIFG18 | MEMRESIFG17 | MEMRESIFG16 | | | W-0h | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | MEMRESIFG15 | MEMRESIFG14 | MEMRESIFG13 | MEMRESIFG12 | MEMRESIFG11 | MEMRESIFG10 | MEMRESIFG9 | MEMRESIFG8 | | | W-0h | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | MEMRESIFG7 | MEMRESIFG6 | MEMRESIFG5 | MEMRESIFG4 | MEMRESIFG3 | MEMRESIFG2 | MEMRESIFG1 | MEMRESIFG0 | | | W-0h | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | RESERVED | | | | | | | | | W-0h | | | | | | | | | ### Table 9-35. ICLR Field Descriptions | Bit | Field | Туре | Reset | Description | |-----|-------------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 | MEMRESIFG23 | W | Oh | Raw interrupt status for MEMRES23. This bit is set to 1 when MEMRES23 is loaded with a new conversion result. Reading MEMRES23 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 30 | MEMRESIFG22 | W | Oh | Raw interrupt status for MEMRES22. This bit is set to 1 when MEMRES22 is loaded with a new conversion result. Reading MEMRES22 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 29 | MEMRESIFG21 | W | Oh | Raw interrupt status for MEMRES21. This bit is set to 1 when MEMRES21 is loaded with a new conversion result. Reading MEMRES21 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 28 | MEMRESIFG20 | W | 0h | Raw interrupt status for MEMRES20. This bit is set to 1 when MEMRES20 is loaded with a new conversion result. Reading MEMRES20 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 27 | MEMRESIFG19 | W | Oh | Raw interrupt status for MEMRES19. This bit is set to 1 when MEMRES19 is loaded with a new conversion result. Reading MEMRES19 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | ## **Table 9-35. ICLR Field Descriptions (continued)** | Bit | Field | Type | Reset | Descriptions (continued) | |-----|-------------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 26 | MEMRESIFG18 | W | Oh | Raw interrupt status for MEMRES18. This bit is set to 1 when MEMRES18 is loaded with a new conversion result. Reading MEMRES18 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 25 | MEMRESIFG17 | W | Oh | Raw interrupt status for MEMRES17. This bit is set to 1 when MEMRES17 is loaded with a new conversion result. Reading MEMRES17 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 24 | MEMRESIFG16 | W | Oh | Raw interrupt status for MEMRES16. This bit is set to 1 when MEMRES16 is loaded with a new conversion result. Reading MEMRES16 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 23 | MEMRESIFG15 | W | Oh | Raw interrupt status for MEMRES15. This bit is set to 1 when MEMRES15 is loaded with a new conversion result. Reading MEMRES15 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 22 | MEMRESIFG14 | W | Oh | Raw interrupt status for MEMRES14. This bit is set to 1 when MEMRES14 is loaded with a new conversion result. Reading MEMRES14 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 21 | MEMRESIFG13 | W | Oh | Raw interrupt status for MEMRES13. This bit is set to 1 when MEMRES13 is loaded with a new conversion result. Reading MEMRES13 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 20 | MEMRESIFG12 | W | 0h | Raw interrupt status for MEMRES12. This bit is set to 1 when MEMRES12 is loaded with a new conversion result. Reading MEMRES12 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 19 | MEMRESIFG11 | W | Oh | Raw interrupt status for MEMRES11. This bit is set to 1 when MEMRES11 is loaded with a new conversion result. Reading MEMRES11 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | ## Table 9-35. ICLR Field Descriptions (continued) | Bit | Field | Type | Reset | Descriptions (continued) | |-----|-------------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 18 | MEMRESIFG10 | W | 0h | Raw interrupt status for MEMRES10. This bit is set to 1 when MEMRES10 is loaded with a new conversion result. Reading MEMRES10 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 17 | MEMRESIFG9 | W | Oh | Raw interrupt status for MEMRES9. This bit is set to 1 when MEMRES9 is loaded with a new conversion result. Reading MEMRES9 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 16 | MEMRESIFG8 | W | Oh | Raw interrupt status for MEMRES8. This bit is set to 1 when MEMRES8 is loaded with a new conversion result. Reading MEMRES8 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 15 | MEMRESIFG7 | W | Oh | Raw interrupt status for MEMRES7. This bit is set to 1 when MEMRES7 is loaded with a new conversion result. Reading MEMRES7 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 14 | MEMRESIFG6 | W | Oh | Raw interrupt status for MEMRES6. This bit is set to 1 when MEMRES6 is loaded with a new conversion result. Reading MEMRES6 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 13 | MEMRESIFG5 | W | 0h | Raw interrupt status for MEMRES5. This bit is set to 1 when MEMRES5 is loaded with a new conversion result. Reading MEMRES5 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 12 | MEMRESIFG4 | W | 0h | Raw interrupt status for MEMRES4. This bit is set to 1 when MEMRES4 is loaded with a new conversion result. Reading MEMRES4 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | 11 | MEMRESIFG3 | W | Oh | Raw interrupt status for MEMRES3. This bit is set to 1 when MEMRES3 is loaded with a new conversion result. Reading MEMRES3 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | ## Table 9-35. ICLR Field Descriptions (continued) | | Table 3-30: IOER Tield Descriptions (continued) | | | | | | | | |-----|-------------------------------------------------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | | 10 | MEMRESIFG2 | W | 0h | Raw interrupt status for MEMRES2. This bit is set to 1 when MEMRES2 is loaded with a new conversion result. Reading MEMRES2 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | | | 9 | MEMRESIFG1 | W | 0h | Raw interrupt status for MEMRES1. This bit is set to 1 when MEMRES1 is loaded with a new conversion result. Reading MEMRES1 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | | | 8 | MEMRESIFG0 | W | Oh | Raw interrupt status for MEMRES0. This bit is set to 1 when MEMRES0 is loaded with a new conversion result. Reading MEMRES0 register will clear this bit, or when the corresponding bit in ICLR is set to 1 0h = No new data ready. 1h = A new data is ready to be read. | | | | | | 7-0 | RESERVED | W | 0h | | | | | | ## 9.3.25 EVT\_MODE (Offset = 10E0h) [Reset = 00000009h] EVT\_MODE is shown in Figure 9-30 and described in Table 9-36. Return to the Summary Table. Event mode register. It is used to select whether each line is disabled, in software mode (software clears the RIS) or in hardware mode (hardware clears the RIS) Figure 9-30. EVT\_MODE # Table 9-36. EVT\_MODE Field Descriptions | iable e del Evi_mebe i lota becomptione | | | | | | | | | |-----------------------------------------|----------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | | 31-4 | RESERVED | R | 0h | | | | | | | 3-2 | EVT1_CFG | R | 2h | Event line mode select for event corresponding to GEN_EVENT 0h = The interrupt or event line is disabled. 1h = The interrupt or event line is in software mode. Software must clear the RIS. 2h = The interrupt or event line is in hardware mode. The hardware (another module) clears automatically the associated RIS flag. | | | | | | 1-0 | INT0_CFG | R | 1h | Event line mode select for event corresponding to CPU_INT 0h = The interrupt or event line is disabled. 1h = The interrupt or event line is in software mode. Software must clear the RIS. 2h = The interrupt or event line is in hardware mode. The hardware (another module) clears automatically the associated RIS flag. | | | | | ## 9.3.26 DESC (Offset = 10FCh) [Reset = 26110010h] DESC is shown in Figure 9-31 and described in Table 9-37. Return to the Summary Table. This register identifies the peripheral and its exact version. #### Figure 9-31. DESC ### Table 9-37. DESC Field Descriptions | Table 3-07. DEGG Tield Descriptions | | | | | | | | |-------------------------------------|------------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | 31-16 | MODULEID | R | 2611h | Module identification contains a unique peripheral identification number. The assignments are maintained in a central database for all of the platform modules to ensure uniqueness. 0h = Smallest value FFFFh = Highest possible value | | | | | 15-12 | FEATUREVER | R | 0h | Feature Set for the module *instance* 0h = Smallest value Fh = Highest possible value | | | | | 11-8 | INSTNUM | R | 0h | Instance Number within the device. This will be a parameter to the RTL for modules that can have multiple instances | | | | | 7-4 | MAJREV | R | 1h | Major rev of the IP 0h = Smallest value Fh = Highest possible value | | | | | 3-0 | MINREV | R | 0h | Minor rev of the IP 0h = Smallest value Fh = Highest possible value | | | | ## 9.3.27 CTL0 (Offset = 1100h) [Reset = 00000000h] CTL0 is shown in Figure 9-32 and described in Table 9-38. Return to the Summary Table. Control Register 0 ### Figure 9-32. CTL0 | | | | 9 | | | | | | |--------|----------|----------|----|---------|--------|----|----|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | RESERVED | | SCLKDIV | | | | | | | | R/W-0h | | R/W-0h | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | RESERVED | | | | | | | | | | | | | | R/W-0h | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | RESERVED | | | | | | | | | | R/W-0h | | | | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | RESERVED | | | | | | | | | R/W-0h | | | | | | | | | ### Table 9-38. CTL0 Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-27 | RESERVED | R/W | 0h | | | 26-24 | SCLKDIV | R/W | Oh | Sample clock divider 0h = Do not divide clock source 1h = Divide clock source by 2 2h = Divide clock source by 4 3h = Divide clock source by 8 4h = Divide clock source by 16 5h = Divide clock source by 24 6h = Divide clock source by 32 7h = Divide clock source by 48 | | 23-17 | RESERVED | R/W | 0h | | | 16 | PWRDN | R/W | 0h | Power down policy 0h = ADC is powered down on completion of a conversion if there is no pending trigger 1h = ADC remains powered on as long as it is enabled through software. | | 15-1 | RESERVED | R/W | 0h | | | 0 | ENC | RH/W | Oh | Enable conversion Oh = Conversion disabled. ENC change from ON to OFF will abort single or repeat sequence on a MEMCTLx boundary. The current conversion will finish and result stored in corresponding MEMRESx. 1h = Conversion enabled. ADC sequencer waits for valid trigger (software or hardware). | # 9.3.28 CTL1 (Offset = 1104h) [Reset = 00000000h] CTL1 is shown in Figure 9-33 and described in Table 9-39. Return to the Summary Table. Control Register 1 ## Figure 9-33. CTL1 | | | | i iguic 3- | 00. O I E I | | | | |----------|----------|--------|------------|-------------|------|--------|---------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | RESERVED | | AVGD | | RESERVED | | AVGN | | | R/W-0h | | R/W-0h | | R/W-0h | | R/W-0h | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | RESERVED | | SAMPMODE | RESE | RVED | CON | SEQ | | | R/W-0h | | R/W-0h | R/W | /-0h | R/W | /-0h | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | RESERVED | | | | SC | | | | | R/W-0h | | | | RH/W-0h | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | RESERVED | | | | TRIGSRC | | | | | R/W-0h | | | | R/W-0h | ## Table 9-39. CTL1 Field Descriptions | Bit Field Type Reset Description 31 RESERVED R/W 0h Hardware averager denominator. The number to divide the accumulated value by (this is a shift). Note result register is maximum of 16-bits long so if not shifted appropriately result will be truncated. Oh (R/W) = No shift 1h (R/W) = 1 bit shift 2h (R/W) = 2 bit shift 3h (R/W) = 3 bit shift 3h (R/W) = 3 bit shift 5h (R/W) = 5 bit shift 5h (R/W) = 5 bit shift 7h (R/W) = 7 3 | I GOIO O OU. O I E I I | | | | Ticia Descriptions | | | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|----------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | AVGD R/W Oh Hardware averager denominator. The number to divide the accumulated value by (this is a shift). Note result register is maximum of 16-bits long so if not shifted appropriately result will be truncated. Oh (R/W) = No shift 1h (R/W) = 1 bit shift 2h (R/W) = 2 bit shift 3h (R/W) = 3 bit shift 4h (R/W) = 4 bit shift 5h (R/W) = 5 bit shift 6h (R/W) = 5 bit shift 7h (R/W) = 7 bit shift 27 RESERVED R/W Oh Hardware averager numerator. Selects number of conversions to accumulate for current MEMCTLx and then it is divided by AVGD. Result will be stored in MEMRESx. Oh (R/W) = Disables averager 1h (R/W) = Averages 2 conversions before storing in MEMRESx register 2h (R/W) = Averages 4 conversions before storing in MEMRESx register 3h (R/W) = Averages 8 conversions before storing in MEMRESx register 4h (R/W) = Averages 16 conversions before storing in MEMRESx register 5h (R/W) = Averages 32 conversions before storing in MEMRESx register 6h (R/W) = Averages 64 conversions before storing in MEMRESx register 7h (R/W) = Averages 64 conversions before storing in MEMRESx register 7h (R/W) = Averages 64 conversions before storing in MEMRESx register 7h (R/W) = Averages 128 conversions before storing in MEMRESx register 7h (R/W) = Averages 128 conversions before storing in MEMRESx register | Bit | Field | Туре | Reset | Description | | | | accumulated value by (this is a shift). Note result register is maximum of 16-bits long so if not shifted appropriately result will be truncated. Oh (R/W) = No shift 1h (R/W) = 1 bit shift 2h (R/W) = 2 bit shift 3h (R/W) = 3 bit shift 4h (R/W) = 4 bit shift 5h (R/W) = 6 bit shift 7h (R/W) = 7 bit shift 4h (R/W) = 7 bit shift 7h | 31 | RESERVED | R/W | 0h | | | | | AVGN R/W Oh Hardware averager numerator. Selects number of conversions to accumulate for current MEMCTLx and then it is divided by AVGD. Result will be stored in MEMRESx. Oh (R/W) = Disables averager 1h (R/W) = Averages 2 conversions before storing in MEMRESx register 2h (R/W) = Averages 4 conversions before storing in MEMRESx register 3h (R/W) = Averages 8 conversions before storing in MEMRESx register 4h (R/W) = Averages 16 conversions before storing in MEMRESx register 5h (R/W) = Averages 32 conversions before storing in MEMRESx register 6h (R/W) = Averages 64 conversions before storing in MEMRESx register 7h (R/W) = Averages 128 conversions before storing in MEMRESx register 7h (R/W) = Averages 128 conversions before storing in MEMRESx register | 30-28 | AVGD | R/W | Oh | accumulated value by (this is a shift). Note result register is maximum of 16-bits long so if not shifted appropriately result will be truncated. 0h (R/W) = No shift 1h (R/W) = 1 bit shift 2h (R/W) = 2 bit shift 3h (R/W) = 3 bit shift 4h (R/W) = 4 bit shift 5h (R/W) = 5 bit shift 6h (R/W) = 6 bit shift | | | | accumulate for current MEMCTLx and then it is divided by AVGD. Result will be stored in MEMRESx. 0h (R/W) = Disables averager 1h (R/W) = Averages 2 conversions before storing in MEMRESx register 2h (R/W) = Averages 4 conversions before storing in MEMRESx register 3h (R/W) = Averages 8 conversions before storing in MEMRESx register 4h (R/W) = Averages 16 conversions before storing in MEMRESx register 5h (R/W) = Averages 32 conversions before storing in MEMRESx register 6h (R/W) = Averages 64 conversions before storing in MEMRESx register 7h (R/W) = Averages 128 conversions before storing in MEMRESx register | 27 | RESERVED | R/W | 0h | | | | | 23-21 RESERVED R/W 0h | 26-24 | AVGN | R/W | Oh | accumulate for current MEMCTLx and then it is divided by AVGD. Result will be stored in MEMRESx. 0h (R/W) = Disables averager 1h (R/W) = Averages 2 conversions before storing in MEMRESx register 2h (R/W) = Averages 4 conversions before storing in MEMRESx register 3h (R/W) = Averages 8 conversions before storing in MEMRESx register 4h (R/W) = Averages 16 conversions before storing in MEMRESx register 4h (R/W) = Averages 16 conversions before storing in MEMRESx register 5h (R/W) = Averages 32 conversions before storing in MEMRESx register 6h (R/W) = Averages 64 conversions before storing in MEMRESx register 7h (R/W) = Averages 128 conversions before storing in MEMRESx | | | | | 23-21 | RESERVED | R/W | 0h | | | | # Table 9-39. CTL1 Field Descriptions (continued) | Bit | Field | Туре | Reset | Description Description | |-------|----------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 20 | SAMPMODE | R/W | 0h | Sample mode. This bit selects the source of the sampling signal. MANUAL option is not valid when TRIGSRC is selected as hardware event trigger. Oh = Sample timer high phase is used as sample signal 1h = Software trigger is used as sample signal | | 19-18 | RESERVED | R/W | 0h | | | 17-16 | CONSEQ | R/W | 0h | Conversion sequence mode 0h = ADC channel in MEMCTLx pointed by STARTADD will be converted once 1h = ADC channel sequence pointed by STARTADD and ENDADD will be converted once 2h = ADC channel in MEMCTLx pointed by STARTADD will be converted repeatedly 3h = ADC channel sequence pointed by STARTADD and ENDADD will be converted repeatedly | | 15-9 | RESERVED | R/W | 0h | | | 8 | sc | RH/W | 0h | Start of conversion Oh = When SAMPMODE is set to MANUAL, clearing this bit will end the sample phase and the conversion phase will start. When SAMPMODE is set to AUTO, writing 0 has no effect. 1h = When SAMPMODE is set to MANUAL, setting this bit will start the sample phase. Sample phase will last as long as this bit is set. When SAMPMODE is set to AUTO, setting this bit will trigger the timer based sample time. | | 7-1 | RESERVED | R/W | 0h | | | 0 | TRIGSRC | R/W | 0h | Sample trigger source 0h = Software trigger 1h = Hardware event trigger | ## 9.3.29 CTL2 (Offset = 1108h) [Reset = 00000000h] CTL2 is shown in Figure 9-34 and described in Table 9-40. Return to the Summary Table. Control Register 2 ## Figure 9-34. CTL2 ## Table 9-40. CTL2 Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-29 | RESERVED | R/W | 0h | | | 28-24 | ENDADD | R/W | Oh | Sequence end address. These bits select which MEMCTLx is the last one for the sequence mode. The value of ENDADD is 0x00 to 0x17, corresponding to MEMRES0 to MEMRES23. 00h = MEMCTL0 is selected as end address of sequence. 01h = MEMCTL1 is selected as end address of sequence. 02h = MEMCTL2 is selected as end address of sequence. 03h = MEMCTL3 is selected as end address of sequence. 04h = MEMCTL4 is selected as end address of sequence. 05h = MEMCTL5 is selected as end address of sequence. 06h = MEMCTL6 is selected as end address of sequence. 07h = MEMCTL7 is selected as end address of sequence. 08h = MEMCTL8 is selected as end address of sequence. 09h = MEMCTL9 is selected as end address of sequence. 09h = MEMCTL10 is selected as end address of sequence. 00h = MEMCTL11 is selected as end address of sequence. 00h = MEMCTL13 is selected as end address of sequence. 00h = MEMCTL14 is selected as end address of sequence. 00h = MEMCTL15 is selected as end address of sequence. 01h = MEMCTL15 is selected as end address of sequence. 01h = MEMCTL15 is selected as end address of sequence. 11h = MEMCTL15 is selected as end address of sequence. 11h = MEMCTL16 is selected as end address of sequence. 11h = MEMCTL18 is selected as end address of sequence. 12h = MEMCTL18 is selected as end address of sequence. 13h = MEMCTL19 is selected as end address of sequence. 15h = MEMCTL20 is selected as end address of sequence. 16h = MEMCTL21 is selected as end address of sequence. 17h = MEMCTL23 is selected as end address of sequence. | | 23-21 | RESERVED | R/W | 0h | | # **Table 9-40. CTL2 Field Descriptions (continued)** | Bit | Field | | Reset | Descriptions (continued) | |-------|----------|----------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 20-16 | | Type R/W | | Description Sequencer start address. These bits select which MEMCTLx is used for single conversion or as first MEMCTL for sequence mode. The value of STARTADD is 0x00 to 0x17, corresponding to MEMRESQ to MEMRESQ3. 00h = MEMCTL0 is selected as start address of a sequence or for a single conversion. 01h = MEMCTL1 is selected as start address of a sequence or for a single conversion. 02h = MEMCTL2 is selected as start address of a sequence or for a single conversion. 03h = MEMCTL3 is selected as start address of a sequence or for a single conversion. 03h = MEMCTL3 is selected as start address of a sequence or for a single conversion. 04h = MEMCTL4 is selected as start address of a sequence or for a single conversion. 05h = MEMCTL5 is selected as start address of a sequence or for a single conversion. 06h = MEMCTL6 is selected as start address of a sequence or for a single conversion. 07h = MEMCTL7 is selected as start address of a sequence or for a single conversion. 08h = MEMCTL8 is selected as start address of a sequence or for a single conversion. 09h = MEMCTL9 is selected as start address of a sequence or for a single conversion. 09h = MEMCTL11 is selected as start address of a sequence or for a single conversion. 00h = MEMCTL11 is selected as start address of a sequence or for a single conversion. 00h = MEMCTL11 is selected as start address of a sequence or for a single conversion. 00h = MEMCTL11 is selected as start address of a sequence or for a single conversion. 00h = MEMCTL11 is selected as start address of a sequence or for a single conversion. 00h = MEMCTL15 is selected as start address of a sequence or for a single conversion. 00h = MEMCTL16 is selected as start address of a sequence or for a single conversion. 01h = MEMCTL16 is selected as start address of a sequence or for a single conversion. 01h = MEMCTL16 is selected as start address of a sequence or for a single conversion. | | | | | | a single conversion. 0Fh = MEMCTL15 is selected as start address of a sequence or for a single conversion. 10h = MEMCTL16 is selected as start address of a sequence or for a single conversion. 11h = MEMCTL17 is selected as start address of a sequence or for a | | 15-11 | SAMPCNT | R/W | 0h | Number of ADC converted samples to be transferred on a DMA trigger Oh = Minimum value 18h = Maximum value | | 10 | FIFOEN | R/W | Oh | Enable FIFO based operation 0h = Disable 1h = Enable | | 9 | RESERVED | R/W | 0h | | # **Table 9-40. CTL2 Field Descriptions (continued)** | Bit | Field | Туре | Reset | Description | |-----|----------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 8 | DMAEN | RH/W | Oh | Enable DMA trigger for data transfer. Note: DMAEN bit is cleared by hardware based on DMA done signal at the end of data transfer. Software has to re-enable DMAEN bit for ADC to generate DMA triggers. Oh (R/W) = DMA trigger not enabled 1h (R/W) = DMA trigger enabled | | 7-3 | RESERVED | R/W | 0h | | | 2-1 | RES | R/W | Oh | Resolution. These bits define the resolution of ADC conversion result. Note: A value of 3 defaults to 12-bits resolution. 0h = 12-bits resolution 1h = 10-bits resolution 2h = 8-bits resolution | | 0 | DF | R/W | 0h | Data read-back format. Data is always stored in binary unsigned format. 0h = Digital result reads as Binary Unsigned. 1h = Digital result reads Signed Binary. (2s complement), left aligned. | # 9.3.30 CTL3 (Offset = 110Ch) [Reset = 00000000h] CTL3 is shown in Figure 9-35 and described in Table 9-41. Return to the Summary Table. Control Register 3. This register is used to configure ADC for ad-hoc single conversion. ## Figure 9-35. CTL3 | | | | i iguie 3- | 00. O I E0 | | | | | |------|----------|-------|------------|------------|----------|----|----------|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | | RESE | RVED | | | | | | | R/W-0h | | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | RESERVED | | | | | | | | | | | | R/W | /-0h | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | RESE | RVED | ASCVF | RSEL | | RESERVED | | ASCSTIME | | | R/W | V-0h | R/W- | -0h | | R/W-0h | | R/W-0h | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | RESERVED | | ASCCHSEL | | | | | | | | R/W-0h | | | | R/W-0h | | | | #### Table 9-41. CTL3 Field Descriptions | | Tuble 0 41. 01201 Icia Besonptions | | | | | | | |-------|------------------------------------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | 31-14 | RESERVED | R/W | 0h | | | | | | 13-12 | ASCVRSEL | R/W | 0h | Selects voltage reference for ASC operation. VEREFM must be connected to on-board ground when external reference option is selected. Note: Writing value 0x3 defaults to INTREF. 0h = VDDA reference. 1h = EXTREF pin reference. 2h = Internal reference. | | | | | 11-9 | RESERVED | R/W | 0h | | | | | | 8 | ASCSTIME | R/W | 0h | ASC sample time compare value select. This is used to select between SCOMP0 and SCOMP1 registers for ASC operation. 0h = Select SCOMP0 1h = Select SCOMP1 | | | | | 7-5 | RESERVED | R/W | 0h | | | | | # **Table 9-41. CTL3 Field Descriptions (continued)** | Dit | | | | Descriptions (continued) | |-----|----------|------|-------|--------------------------| | Bit | Field | Туре | Reset | Description | | 4-0 | ASCCHSEL | R/W | 0h | ASC channel select | | | | | | 00h = Selects channel 0 | | | | | | 01h = Selects channel 1 | | | | | | 02h = Selects channel 2 | | | | | | 03h = Selects channel 3 | | | | | | 04h = Selects channel 4 | | | | | | 05h = Selects channel 5 | | | | | | 06h = Selects channel 6 | | | | | | 07h = Selects channel 7 | | | | | | 08h = Selects channel 8 | | | | | | 09h = Selects channel 9 | | | | | | 0Ah = Selects channel 10 | | | | | | 0Bh = Selects channel 11 | | | | | | 0Ch = Selects channel 12 | | | | | | 0Dh = Selects channel 13 | | | | | | 0Eh = Selects channel 14 | | | | | | 0Fh = Selects channel 15 | | | | | | 10h = Selects channel 16 | | | | | | 11h = Selects channel 17 | | | | | | 12h = Selects channel 18 | | | | | | 13h = Selects channel 19 | | | | | | 14h = Selects channel 20 | | | | | | 15h = Selects channel 21 | | | | | | 16h = Selects channel 22 | | | | | | 17h = Selects channel 23 | | | | | | 18h = Selects channel 24 | | | | | | 19h = Selects channel 25 | | | | | | 1Ah = Selects channel 26 | | | | | | 1Bh = Selects channel 27 | | | | | | 1Ch = Selects channel 28 | | | | | | 1Dh = Selects channel 29 | | | | | | 1Eh = Selects channel 30 | | | | | | 1Fh = Selects channel 31 | # 9.3.31 CLKFREQ (Offset = 1110h) [Reset = 00000000h] CLKFREQ is shown in Figure 9-36 and described in Table 9-42. Return to the Summary Table. Sampling clock frequency range register. ## Figure 9-36. CLKFREQ Table 9-42. CLKFREQ Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-3 | RESERVED | R/W | 0h | | | 2-0 | FRANGE | R/W | Oh | Frequency Range. 0h = 1 to 4 MHz 1h = >4 to 8 MHz 2h = >8 to 16 MHz 3h = >16 to 20 MHz 4h = >20 to 24 MHz 5h = >24 to 32 MHz 6h = >32 to 40 MHz 7h = >40 to 48 MHz | ## 9.3.32 SCOMP0 (Offset = 1114h) [Reset = 00000000h] SCOMP0 is shown in Figure 9-37 and described in Table 9-43. Return to the Summary Table. Sample time compare 0 register. Specifies the sample time, in number of ADC sample clock cycles. CTL0.ENC must be 0 to write to this register. ## Figure 9-37. SCOMP0 ## Table 9-43. SCOMP0 Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-10 | RESERVED | R/W | 0h | | | 9-0 | VAL | R/W | Oh | Specifies the number of sample clocks. When VAL = 0 or 1, number of sample clocks = Sample clock divide value. When VAL > 1, number of sample clocks = VAL x Sample clock divide value. Note: Sample clock divide value is not the value written to SCLKDIV but the actual divide value (SCLKDIV = 2 implies divide value is 4). Example: VAL = 4, SCLKDIV = 3 implies 32 sample clock cycles. | ## 9.3.33 SCOMP1 (Offset = 1118h) [Reset = 00000000h] SCOMP1 is shown in Figure 9-38 and described in Table 9-44. Return to the Summary Table. Sample time compare 1 register. Specifies the sample time, in number of ADC sample clock cycles. CTL0.ENC must be 0 to write to this register. ## Figure 9-38. SCOMP1 ## Table 9-44. SCOMP1 Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-10 | RESERVED | R/W | 0h | | | 9-0 | VAL | R/W | 0h | Specifies the number of sample clocks. When VAL = 0 or 1, number of sample clocks = Sample clock divide value. When VAL > 1, number of sample clocks = VAL x Sample clock divide value. Note: Sample clock divide value is not the value written to SCLKDIV but the actual divide value (SCLKDIV = 2 implies divide value is 4). Example: VAL = 4, SCLKDIV = 3 implies 32 sample clock cycles. | # 9.3.34 REFCFG (Offset = 111Ch) [Reset = 00000000h] REFCFG is shown in Figure 9-39 and described in Table 9-45. Return to the Summary Table. Reference buffer configuration register ## Figure 9-39. REFCFG ## **Table 9-45. REFCFG Field Descriptions** | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------| | 31-5 | RESERVED | R/W | 0h | | | 4-3 | IBPROG | R/W | 0h | Configures reference buffer bias current output value 0h = 1uA 1h = 0.5uA 2h = 2uA 3h = 0.67uA | | 2 | RESERVED | R/W | 0h | | | 1 | REFVSEL | R/W | Oh | Configures reference buffer output voltage 0h = Reference buffer generates 2.5 V output 1h = Reference buffer generates 1.4 V output | | 0 | REFEN | R/W | Oh | Reference buffer enable 0h = Disable 1h = Enable | ## 9.3.35 WCLOW (Offset = 1148h) [Reset = 00000000h] WCLOW is shown in Figure 9-40 and described in Table 9-46. Return to the Summary Table. Window Comparator Low Threshold Register. The data format that is used to write and read WCLOW depends on the value of DF bit in CTL2 register. CTL0.ENC must be 0 to write to this register. Note: Change in ADC data format or resolution does not reset WCLOW. #### Figure 9-40. WCLOW ## Table 9-46. WCLOW Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-16 | RESERVED | R/W | 0h | | | 15-0 | DATA | R/W | Oh | If DF = 0, unsigned binary format has to be used. The value based on the resolution has to be right aligned with the MSB on the left. For 10-bits and 8-bits resolution, unused bits have to be 0s. If DF = 1, 2s-complement format has to be used. The value based on the resolution has to be left aligned with the LSB on the right. For 10-bits and 8-bits resolution, unused bits have to be 0s. | ## 9.3.36 WCHIGH (Offset = 1150h) [Reset = 00000000h] WCHIGH is shown in Figure 9-41 and described in Table 9-47. Return to the Summary Table. Window Comparator High Threshold Register. The data format that is used to write and read WCHIGH depends on the value of DF bit in CTL2 register. CTL0.ENC must be 0 to write to this register. Note: Change in ADC data format or resolution does not reset WCHIGH. #### Figure 9-41. WCHIGH #### **Table 9-47. WCHIGH Field Descriptions** | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-16 | RESERVED | R/W | 0h | | | 15-0 | DATA | R/W | Oh | If DF = 0, unsigned binary format has to be used. The threshold value has to be right aligned, with the MSB on the left. For 10-bits and 8-bits resolution, unused bit have to be 0s. If DF = 1, 2s-complement format has to be used. The value based on the resolution has to be left aligned with the LSB on the right. For 10-bits and 8-bits resolution, unused bit have to be 0s. | ## 9.3.37 FIFODATA (Offset = 1160h) [Reset = 00000000h] FIFODATA is shown in Figure 9-42 and described in Table 9-48. Return to the Summary Table. FIFO data register. This is a virtual register used to do read from FIFO. ## Figure 9-42. FIFODATA ## **Table 9-48. FIFODATA Field Descriptions** | Bit | Field | Туре | Reset | Description | |------|-------|------|-------|-------------------------------------------------------------| | 31-0 | DATA | R | 0h | Read from this data field returns the ADC sample from FIFO. | # 9.3.38 ASCRES (Offset = 1170h) [Reset = 00000000h] ASCRES is shown in Figure 9-43 and described in Table 9-49. Return to the Summary Table. ASC result register ## Figure 9-43. ASCRES ## Table 9-49. ASCRES Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-16 | RESERVED | R | 0h | | | 15-0 | DATA | R | 0h | Result of ADC ad-hoc single conversion. If DF = 0, unsigned binary: The conversion result is right aligned. In 10 and 8 bit modes, the unused MSB bits are forced to 0. If DF = 1, 2s-complement format: The conversion result is left aligned. In 10 and 8 bit modes, the unused LSB bits are forced to 0. The data is stored in the right-justified format and is converted to the left-justified 2s-complement format during read back. | # 9.3.39 MEMCTL[y] (Offset = 1180h + formula) [Reset = 00000000h] MEMCTL[y] is shown in Figure 9-44 and described in Table 9-50. Return to the Summary Table. Conversion Memory Control Register. CTL0.ENC must be 0 to write to this register. Offset = 1180h + (y \* 4h); where y = 0h to 17h Figure 9-44. MEMCTL[v] | | Figure 9-44. MEMICTE[y] | | | | | | | | |----|-------------------------|----|---------|------|----------|----|--------|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | RESERVED | | WINCOMP | | RESERVED | | TRIG | | | | R/W-0h | | R/W-0h | | R/W-0h | | R/W-0h | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | RESERVED | | BCSEN | | RESERVED | | AVGEN | | | | R/W-0h | | R/W-0h | | R/W-0h | | R/W-0h | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | RESERVED | | STIME | RESE | ERVED | VF | RSEL | | | | R/W-0h | | R/W-0h | R/\ | N-0h | R/ | W-0h | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | RESERVED | | | | CHANSEL | | | | | | R/W-0h | | | | R/W-0h | | | | Table 9-50. MEMCTL[y] Field Descriptions | | Table 0 Co. Maint 12[3] Field Bescriptions | | | | | | | | |-------|--------------------------------------------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | | 31-29 | RESERVED | R/W | 0h | | | | | | | 28 | WINCOMP | R/W | 0h | Enable window comparator. 0h = Disable 1h = Enable | | | | | | 27-25 | RESERVED | R/W | 0h | | | | | | | 24 | TRIG | R/W | 0h | Trigger policy. Indicates if a trigger will be needed to step to the next MEMCTL in the sequence or to perform next conversion in the case of repeat single channel conversions. Oh = Next conversion is automatic 1h = Next conversion requires a trigger | | | | | | 23-21 | RESERVED | R/W | 0h | | | | | | | 20 | BCSEN | R/W | 0h | Enable burn out current source. 0h = Disable 1h = Enable | | | | | | 19-17 | RESERVED | R/W | 0h | | | | | | | 16 | AVGEN | R/W | Oh | Enable hardware averaging. 0h (R/W) = Averaging disabled. 1h = Averaging enabled. | | | | | | 15-13 | RESERVED | R/W | 0h | | | | | | | 12 | STIME | R/W | Oh | Selects the source of sample timer period between SCOMP0 and SCOMP1. 0h = Select SCOMP0 1h = Select SCOMP1 | | | | | | 11-10 | RESERVED | R/W | 0h | | | | | | # Table 9-50. MEMCTL[y] Field Descriptions (continued) | | Table 9-50. MEMCT L[y] Field Descriptions (continued) | | | | | | | |-----|-------------------------------------------------------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | 9-8 | VRSEL | R/W | 0h | Voltage reference selection. VEREFM must be connected to on-<br>board ground when external reference option is selected.<br>Note: Writing value 0x3 defaults to INTREF.<br>0h = VDDA reference<br>1h = External reference from pin<br>2h = Internal reference | | | | | 7-5 | RESERVED | R/W | 0h | | | | | | 4-0 | CHANSEL | R/W | Oh | Input channel select. 00h = Selects channel 0 01h = Selects channel 1 02h = Selects channel 2 03h = Selects channel 3 04h = Selects channel 4 05h = Selects channel 5 06h = Selects channel 6 07h = Selects channel 7 08h = Selects channel 8 09h = Selects channel 9 0Ah = Selects channel 10 0Bh = Selects channel 11 0Ch = Selects channel 12 0Dh = Selects channel 13 0Eh = Selects channel 14 0Fh = Selects channel 15 10h = Selects channel 16 11h = Selects channel 17 12h = Selects channel 18 13h = Selects channel 19 14h = Selects channel 20 15h = Selects channel 21 16h = Selects channel 22 17h = Selects channel 23 18h = Selects channel 24 19h = Selects channel 27 1Ch = Selects channel 28 1Dh = Selects channel 28 1Dh = Selects channel 29 1Eh = Selects channel 29 1Eh = Selects channel 29 | | | | | | | | | 1Fh = Selects channel 31 | | | | ## 9.3.40 MEMRES[y] (Offset = 1280h + formula) [Reset = 00000000h] MEMRES[y] is shown in Figure 9-45 and described in Table 9-51. Return to the Summary Table. Memory Result Register Offset = 1280h + (y \* 4h); where y = 0h to 17h #### Figure 9-45. MEMRES[y] Table 9-51. MEMRES[y] Field Descriptions | В | it | Field | Туре | Reset | Description | |-----|----|----------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31- | 16 | RESERVED | R | 0h | | | 15 | -0 | DATA | R | Oh | MEMRES result register. If DF = 0, unsigned binary: The conversion results are right aligned. In 10 and 8 bit modes, the unused MSB bits are forced to 0. If DF = 1, 2s-complement format: The conversion results are left aligned. In 10 and 8 bit modes, the unused LSB bits are forced to 0. The data is stored in the right-justified format and is converted to the left-justified 2s-complement format during read back. | # 9.3.41 STATUS (Offset = 1340h) [Reset = 00000000h] STATUS is shown in Figure 9-46 and described in Table 9-52. Return to the Summary Table. Status Register ## Figure 9-46. STATUS #### **Table 9-52. STATUS Field Descriptions** | Bit | Field | Туре | Reset | Description | |------|-----------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-3 | RESERVED | R | 0h | | | 2 | ASCACT | R | Oh | ASC active 0h = Idle or done 1h = ASC active | | 1 | REFBUFRDY | R | Oh | Indicates reference buffer is powered up and ready. 0h = Not ready 1h = Ready | | 0 | BUSY | R | 0h | Busy. This bit indicates that an active ADC sample or conversion operation is in progress. 0h = No ADC sampling or conversion in progress. 1h = ADC sampling or conversion is in progress. | This page intentionally left blank. # Chapter 10 COMP The comparator module (COMP) is an analog voltage comparator with general comparator functionality. This chapter describes the operation of the comparator module. | 10.1 Comparator Overview | 598 | |---------------------------|-----| | 10.2 Comparator Operation | | | 10.3 COMP Registers | | | 10.0 COM: Registers | | #### 10.1 Comparator Overview The comparator module can be useful for supply voltage supervision and monitoring of external analog signals. Features of comparator include: - · Fast and ultra-low-power modes of operation - · Inverting and non-inverting terminal input multiplexer - · Inverting and non-inverting terminal short and exchange capabilities - Software-selectable analog filter for the comparator output - · Programmable hysteresis - Reference voltage from VDD or from external reference pin - · Configurable reference voltage generator from integrated 8-bit DAC with two input codes - · Output connected to event system - Interrupt driven measurement system for low-power operation Figure 10-1 shows the comparator block diagram. Figure 10-1. Comparator Block Diagram www.ti.com COMP #### 10.2 Comparator Operation The comparator module is configured by user software. The setup and operation of comparator is discussed in the following sections. #### 10.2.1 Comparator Configuration The comparator compares the analog voltages at the positive (+) and negative (–) input terminals. If the + terminal is more positive than the – terminal, the comparator output is high. The polarity of the comparator output can be configured by using the OUTPOL bit in COMPx.CTL1 register. The comparator can be switched on or off using ENABLE bit in COMPx.CTL1 register. The comparator should be switched off when not in use to reduce current consumption. When the comparator is off, OUT is low when OUTPOL bit is set to 0, and OUT is high when OUTPOL bit is set to 1. The comparator can be configured in fast or ultra-low-power mode using MODE bit in COMPx.CTL1 register. The default value of MODE bit is 0 which configures the comparator in fast mode. When MODE bit is set to 1 the comparator is configured in ultra-low-power mode. In the fast mode the comparator consumes higher current but the response time is faster. In the ultra-low power mode the comparator consumes very low current but response time is slower. To optimize current consumption for the application, the power mode that meets the comparator speed requirements should be selected (please see the device-specific data sheet for the comparator propagation delay). The clock control for comparator is managed by System Controller (SYSCTL), SYSCTL knows if comparator module is enabled and it also knows if it is in ultra-low-power mode or fast mode. User needs to ensure the proper bus clock is selected for different comparator operation mode: - For ultra-low-power mode comparator, bus clock can be LFCLK or any of the high speed clocks. - For fast mode comparator, bus clock cannot be LFCLK, system will generate a clock error interrupt in SYSCTL if you enable a comparator in fast mode and the bus clock is LFCLK. #### 10.2.2 Comparator Channels Selection The comparator channels on positive terminal is selected through IPSEL bits and enabled through IPEN bit in the register COMPx.CTL0. Similarly the comparator channels on negative terminal is selected through IMSEL bits and enabled through IMEN bit. The IPSEL and IMSEL bits can be used to select the comparator channel inputs from device pins or from internal analog modules. The switches in the comparator input channels multiplexer on positive and negative terminals are implemented using break-before-make arrangement to minimize the cross talk when the channel selection changes. The IPSEL and IMSEL bits allow: - Connection of an external signal to the positive and negative terminals of the comparator - Connection of an internal analog signal (like OPA) to the positive and negative terminals of the comparator - Connection of one comparator positive terminal signal to another comparator positive terminal in window compare mode The EXCH bit in COMPx.CTL1 register controls the input multiplexer, exchange the input signals of the comparator positive and negative terminals. Additionally, when the comparator terminals are exchanged, the output signal from the comparator is inverted too. This allows the user to determine or compensate for the comparator input offset voltage. #### **Note** #### **Comparator Input Connection** Please see the device data sheet COMP section for the input channel selection configuration. When the comparator is on, the input terminals should be connected to a signal, power, or ground. Otherwise, floating levels can cause unexpected interrupts and increased current consumption. #### **Comparator Configuration** The configuration of the comparator must not change while it is in operation except for changes in IPSEL, IMSEL and EXCH settings in the register COMPx.CTL0. To change the configuration of the comparator it must be first disabled, reconfigured as needed and then re-enabled. #### 10.2.3 Comparator Output The comparator output is readable from the OUT bit in COMPx.CTL1 register. The output is also brought out on device pin. For successful connection of comparator output with the device pin, it is necessary for the software to configure the corresponding device pin in IOMUX module. The comparator output also goes to the Event Interface to generate CPU interrupt event and generic publisher event for internal connects with other modules. #### 10.2.4 Output Filter The output of the comparator can be used with or without internal filtering. Output filtering can only be enabled while Comparator is in fast mode (COMPx.CTL1.MODE = 0). When FLTEN bit in COMPx.CTL1 register is set, the output is filtered with an on-chip analog filter. The delay of the filter can be adjusted in four different steps using the FLTDLY bits in COMPx.CTL1 register (see Table 10-1). Table 10-1. Typical Output Filter Delay Settings | FLTDLY bit in COMPx.CTL1 | Typical filter delay | |--------------------------|----------------------| | 0 | 70ns | | 1 | 500ns | | 2 | 1200ns | | 3 | 2700ns | Filter delay settings are an addition to propagation delay outlined in device specific data sheet. The comparator output oscillates if the voltage difference across the input terminals is small (see Figure 10-2). Internal and external parasitic effects and cross coupling on and between signal lines, power supply lines, and other parts of the system result in this behavior. The comparator output oscillation reduces the accuracy and resolution of the comparison result. Selecting the output filter can reduce errors associated with comparator oscillation. Figure 10-2. Analog Filter Response at the Output of the Comparator www.ti.com COMP #### 10.2.5 Sampled Output Mode Sampled mode is a method of operation for the comparator, which compares input signals at discrete time intervals or samples, producing output signals that change only at the sampling points. The SAMPMODE bit in the register CTL2 enables or disables the sampled mode. To define the sampling window, two events, EVT0 and EVT1, are generated from the timer. The sampling window can be aligned to less noisy phases with the use of these events. EVT0 sets the sampling window, while EVT1 clears it. In sampled mode, the output of the comparator is captured only when the sampling window is high, and the output is not captured at other times. The captured output is used for interrupt and event generation. By using sampled mode, the comparator can reduce the effects of noise in the input signals, resulting in more accurate and reliable comparisons. The use of EVT0 and EVT1 to define the sampling window allows for greater flexibility in aligning the window to the least noisy phases of the input signals, further improving the accuracy of the comparisons. #### 10.2.6 Blanking Mode Due to the noise or other interference, the input signal may fluctuate around the threshold voltage, causing the output to switch rapidly and erratically. This can lead to false triggering. Comparator blanking mode introduces a brief delay between the time the input signal crosses the threshold voltage and the time the output changes state. During this delay period, the comparator ignores any further changes in the input signal and maintains its current output state, this is mainly used in some uses cases like PWM waves indicated by a timer in motor drive, power control and so on. The control bits BLANKSRC in the register CTL2 can be used to configure disable or which source should be working on blanking mode. There are 3 sources can be as the inputs of blanking mode: TIMG0.CC1, TIMG1.CC1 and TIMG2.CC1. #### Note The timer is used as the source of comparator blanking mode, there will typically be a one TIMCLK cycle delay between the timer output and the comparator's output. ## 10.2.7 Reference Voltage Generator Figure 10-3 shows the block diagram of the comparator reference voltage generator. The comparator reference voltage generator consists of a 8-bit DAC along with some configuration options. The REFSRC bits in COMPx.CTL2 register are used to select the reference source for the comparator. - When REFSRC = 0, the reference voltage generator is disabled and the reference voltage generator cannot be used for comparator operation. - When REFSRC = 1, the analog supply VDDA is selected as the reference input for the DAC and the DAC output is used as reference voltage for the comparator. - When REFSRC = 2, the external reference is selected as the reference input for the DAC and the DAC output is used as reference voltage for the comparator. - When REFSRC = 3, the external reference is used directly as reference voltage for the comparator and the DAC is switched off. The reference voltage generator output can be applied to either the positive terminal or negative terminal of the comparator using the REFSEL bit COMPx.CTL2 register. If external signals are applied to both comparator input terminals, turn off the internal reference voltage generator to reduce current consumption. When the reference voltage generator output is applied on a comparator terminal using REFSEL bit COMPx.CTL2 register and the comparator channel (from device pins or from internal analog modules) is also selected on the same terminal using IPSEL/IPEN or IMSEL/IMEN bits in COMPx.CTL0 register then the comparator channel selection takes precedence. DAC8 output is also connected to the internal analog OPA module through OPAx (see Figure 11-1). Figure 10-3. Reference Voltage Generator Block Diagram #### **Integrated 8-bit DAC** The 8-bit DAC input code can be provided through DACCODE0 or DACCODE1 bits in COMPx.CTL3 register. The DACCTL bit in COMPx.CTL2 register determines if the comparator output or a software control bit DACSW in COMPx.CTL2 register selects DACCODE0 or DACCODE1 bits as input to DAC. - When DACCTL is 0 the comparator output value selects DACCODE0 or DACCODE1. If the comparator output value is 0, DACCODE0 will be the input to DAC. And DACCODE1 will be the input to DAC if the comparator output value is 1. - When DACCTL is 1 the DACSW bit value that is programmed by software selects DACCODE0 or DACCODE1. If DACSW is 0, DACCODE0 will be the input to DAC. And DACCODE1 will be the input to DAC if DACSW is 1. With this provision it is possible to generate desired hysteresis levels for the comparator without using external components. - The REFMODE bit in COMPx.CTL2 register determines if the comparator requests for internal VREF operation in fast or ultra-low-power and also the mode of operation of the 8-bit DAC. When REFMODE bit is 0, the internal VREF is requested for operation in fast mode and the 8-bit DAC in comparator is configured in fast mode as well. When REFMODE bit is 1, the internal VREF is requested for operation in ultra-low-power and the 8-bit DAC in comparator in comparator is configured in ultra-low-power. Operation in fast mode offers higher accuracy but consumes higher current while the ultra-low-power operation consumes lower current but with relaxed reference voltage accuracy. Refer to comparator electrical specifications in device-specific data sheet for details. #### 10.2.8 Comparator Hysteresis The comparator supports programmable hysteresis voltages for fast and ultra-low-power modes to avoid spurious output transitions in case of noisy input signals. When HYST bits in COMPx.CTL1 register are 0, the comparator generates no hysteresis. 10 mV, 20 mV, and 30 mV typical hysteresis voltages are generated by the comparator for HYST bits values 1, 2, and 3 respectively. The hysteresis can also be implemented by using the internal 8-bit DAC. The input of the reference generator 8-bit DAC can be provided by two values DACCODE0 and DACCODE1 in COMPx.CTL3 register. User can configure the DACCTL bit in COMPx.CTL2 register to 1 and the comparator output value will select the DAC input between DACCODE0 and DACCODE1 values. With this provision it is possible to generate desired www.ti.com COMP hysteresis levels for the comparator without using external components. For more information about this configuration please refer to Integrated 8-bit DAC section. #### 10.2.9 Input SHORT Switch The SHORT bit shorts the comparator inputs. This can be used to build a simple sample-and-hold for the comparator (see Figure 10-4) Figure 10-4. Comparator Short Switch The required sampling time is proportional to the size of the sampling capacitor (CS), the resistance of the input switches in series with the short switch (RI) and the resistance of the external source (RS). The sampling capacitor CS should be greater than 100 pF. The time constant, Tau, to charge the sampling capacitor CS can be calculated with Equation 10. $$T_{\alpha\mu} = (R_I + R_S) \times C_S \tag{10}$$ Depending on the required accuracy, use 3 to 10 Tau as the sampling time. With 3 Tau the sampling capacitor is charged to approximately 95% of the input signals voltage level, with 5 Tau it is charged to more than 99%, and with 10 Tau the sampled voltage is sufficient for 12-bit accuracy. ## 10.2.10 Interrupt and Events Support The comparator module contains two event publishers and two event subscribers. One event publisher (CPU\_INT) manages comparator interrupt requests (IRQs) to the CPU subsystem through a static event route. The second event publisher (GEN\_EVENT) is used to setup the generic event publisher through Generic route. The two event subscribers are used to define the start and stop points in sampled output mode. The comparator events are summarized in Table 10-2. #### **Table 10-2. Comparator Events** | Event | Туре | Source Destination | | Route | Configuration | Functionality | |-----------------------------|------------|--------------------|-------------------|---------------|-------------------------------|------------------------------------------------------------------------------------------------| | CPU interrupt | Publisher | Comparator | CPU Subsystem | Static route | CPU_INT registers | Fixed interrupt<br>route from<br>comparator<br>to CPU | | Generic publisher event | Publisher | Comparator | Other peripherals | Generic route | GEN_EVENT FPUB_1 registers | Configurable route from comparator to other peripherals | | Generic<br>subscriber event | Subscriber | Other peripherals | Comparator | Generic route | GEN_EVENT<br>FSUB_0 registers | Configurable route<br>from other<br>peripherals to the<br>comparator start<br>of sample window | | Generic<br>subscriber event | Subscriber | Other peripherals | Comparator | Generic route | GEN_EVENT<br>FSUB_1 registers | Configurable route<br>from other<br>peripherals to the<br>comparator stop<br>sampling window | #### 10.2.10.1 CPU Interrupt Event Publisher (CPU\_INT) The comparator module provides 3 interrupt sources which can be configured to source a CPU interrupt event. In order of decreasing interrupt priority, the CPU interrupt events from the comparator are: Table 10-3. Comparator CPU Interrupt Event Conditions (CPU INT) | idade to the comparator of a microapi arom commission (c. c_mt) | | | | | | | | |-----------------------------------------------------------------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | IIDX STAT | Name | Description | | | | | | | 0x01 | COMPIFG | The interrupt flags COMPIFG and COMPINVIFG are set either on the rising or falling edge of the comparator output, selected by the IES bit. When IES bit is 0, rising edge of the comparator output sets the COMPIFG and falling edge sets the COMPINVIFG. When IES bit is 1, falling edge of the comparator output sets the COMPIFG and rising edge sets the COMPINVIFG. | | | | | | | 0x02 | COMPINVIFG | The interrupt flags COMPIFG and COMPINVIFG are set either on the rising or falling edge of the comparator output, selected by the IES bit. When IES bit is 0, rising edge of the comparator output sets the COMPIFG and falling edge sets the COMPINVIFG. When IES bit is 1, falling edge of the comparator output sets the COMPIFG and rising edge sets the COMPINVIFG. | | | | | | | 0x03 | OUTRDYIFG | Comparator output ready interrupt. This bit is set when the comparator output is valid. | | | | | | The CPU interrupt event configuration is managed with the CPU\_INT event management registers. See Section 6.2.5 for guidance on configuring the Event registers for CPU interrupts. #### 10.2.10.2 Generic Event Publisher (GEN\_EVENT) A generic route is a route in which the comparator peripheral publishing the event is configured to use one of several available generic route channels to publish its event to another entity (or entities, in the case of a splitter route), where an entity can be another peripheral, a generic DMA trigger event, or a generic CPU event. The GEN\_EVENT register is used to select a peripheral condition (Table 10-4) to use for publishing an event. FPUB\_1 is the publisher port register and it is used to configure which generic route channel to use to broadcast the event. A second peripheral, the DMA, or the CPU can subscribe to this event by configuring its subscriber port to listen on the same generic route channel which the publishing peripheral is connected to. www.ti.com COMP For example, through the use of a generic event channel, it is possible to directly trigger a timer capture from a comparator event, by connecting a comparator FPUB\_1 and TIM FSUB\_x to the same generic event channel. Refer to Section 6.1.3.3 and Section 6.2.3 for how generic event route works. Table 10-4. Comparator Generic Event Conditions (GEN\_EVENT) | IIDX STAT | Name | Description | |-----------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0x01 | COMPIFG | The interrupt flags COMPIFG and COMPINVIFG are set either on the rising or falling edge of the comparator output, selected by the IES bit. When IES bit is 0, rising edge of the comparator output sets the COMPIFG and falling edge sets the COMPINVIFG. When IES bit is 1, falling edge of the comparator output sets the COMPIFG and rising edge sets the COMPINVIFG. | | 0x02 | COMPINVIFG | The interrupt flags COMPIFG and COMPINVIFG are set either on the rising or falling edge of the comparator output, selected by the IES bit. When IES bit is 0, rising edge of the comparator output sets the COMPIFG and falling edge sets the COMPINVIFG. When IES bit is 1, falling edge of the comparator output sets the COMPIFG and rising edge sets the COMPINVIFG. | | 0x03 | OUTRDYIFG | Comparator output ready interrupt. This bit is set when the comparator output is valid. | See Section 6.2.5 for guidance on configuring the Event registers. #### 10.2.10.3 Generic Event Subscribers The two event subscribers are used to establish the sampling start and stop times when the comparator is used in the sampled output mode. - FSUB\_0 selects the generic event route at the device level on which the start of sampling window event is sent - FSUB\_1 selects the generic event route at the device level on which the stop of sampling window event is sent. As the sampling window is driven from generic event routes, any peripheral module with generic publisher capabilities can set the comparator's sampling window, including timers and GPIO. # 10.3 COMP Registers Table 10-5 lists the memory-mapped registers for the COMP registers. All register offset addresses not listed in Table 10-5 should be considered as reserved locations and the register contents should not be modified. #### **Table 10-5. COMP Registers** | Offset | Acronym | Register Name | Group | Section | | | |--------|----------|-----------------------------------------|--------------|---------|--|--| | 400h | FSUB_0 | Subscriber Port 0 | | Go | | | | 404h | FSUB_1 | Subscriber Port 1 | Go | | | | | 444h | FPUB_1 | Publisher port 1 | | Go | | | | 800h | PWREN | Power enable | | Go | | | | 804h | RSTCTL | Reset Control | | Go | | | | 808h | CLKCFG | Peripheral Clock Configuration Register | | Go | | | | 814h | STAT | Status Register | | Go | | | | 1020h | IIDX | Interrupt index | CPU_INT | Go | | | | 1028h | IMASK | Interrupt mask | CPU_INT | Go | | | | 1030h | RIS | Raw interrupt status | CPU_INT | Go | | | | 1038h | MIS | Masked interrupt status | CPU_INT | Go | | | | 1040h | ISET | Interrupt set | CPU_INT | Go | | | | 1048h | ICLR | Interrupt clear | Go | | | | | 1050h | IIDX | Interrupt index | Go | | | | | 1058h | IMASK | Interrupt mask | Go | | | | | 1060h | RIS | Raw interrupt status | Go | | | | | 1068h | MIS | Masked interrupt status | GEN_EVENT | Go | | | | 1070h | ISET | Interrupt set | GEN_EVENT | Go | | | | 1078h | ICLR | Interrupt clear | GEN_EVENT | Go | | | | 10E0h | EVT_MODE | Event Mode | | Go | | | | 10FCh | DESC | Module Description | | Go | | | | 1100h | CTL0 | Control 0 | Control 0 Go | | | | | 1104h | CTL1 | Control 1 Go | | | | | | 1108h | CTL2 | Control 2 Go | | | | | | 110Ch | CTL3 | Control 3 | | Go | | | | 1120h | STAT | Status | | Go | | | Complex bit access types are encoded to fit into small table cells. Table 10-6 shows the codes that are used for access types in this section. Table 10-6. COMP Access Type Codes | Access Type | Code | Description | | | | | | |------------------------|--------|----------------------------------------|--|--|--|--|--| | Read Type | | | | | | | | | R | R | Read | | | | | | | Write Type | | | | | | | | | K | К | Write protected by a key | | | | | | | W | W | Write | | | | | | | WK | W<br>K | Write<br>Write protected by a key | | | | | | | Reset or Default Value | | | | | | | | | -n | | Value after reset or the default value | | | | | | www.ti.com COMP # 10.3.1 FSUB\_0 (Offset = 400h) [Reset = 00000000h] FSUB\_0 is shown in Figure 10-5 and described in Table 10-7. Return to the Summary Table. Subscriber port ## Figure 10-5. FSUB\_0 # Table 10-7. FSUB\_0 Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-4 | RESERVED | R/W | 0h | | | 3-0 | CHANID | R/W | | 0 = disconnected. 1-15 = connected to channelID = CHANID. 0h = A value of 0 specifies that the event is not connected Fh = Consult your device data sheet as the actual allowed maximum may be less than 15. | # 10.3.2 FSUB\_1 (Offset = 404h) [Reset = 00000000h] FSUB\_1 is shown in Figure 10-6 and described in Table 10-8. Return to the Summary Table. Subscriber port ## Figure 10-6. FSUB\_1 Table 10-8. FSUB\_1 Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-4 | RESERVED | R/W | 0h | | | 3-0 | CHANID | R/W | | 0 = disconnected. 1-15 = connected to channelID = CHANID. 0h = A value of 0 specifies that the event is not connected Fh = Consult your device data sheet as the actual allowed maximum may be less than 15. | www.ti.com COMP # 10.3.3 FPUB\_1 (Offset = 444h) [Reset = 00000000h] FPUB\_1 is shown in Figure 10-7 and described in Table 10-9. Return to the Summary Table. Publisher port ## Figure 10-7. FPUB\_1 Table 10-9. FPUB\_1 Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-4 | RESERVED | R/W | 0h | | | 3-0 | CHANID | R/W | | 0 = disconnected. 1-15 = connected to channelID = CHANID. 0h = A value of 0 specifies that the event is not connected Fh = Consult your device data sheet as the actual allowed maximum may be less than 15. | # 10.3.4 PWREN (Offset = 800h) [Reset = 00000000h] PWREN is shown in Figure 10-8 and described in Table 10-10. Return to the Summary Table. Register to control the power state ## Figure 10-8. PWREN ## **Table 10-10. PWREN Field Descriptions** | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|----------------------------------------------------------------------------------------------------| | 31-24 | KEY | W | 0h | KEY to allow Power State Change<br>26h = KEY to allow write access to this register | | 23-1 | RESERVED | R/W | 0h | | | 0 | ENABLE | К | 0h | Enable the power KEY must be set to 26h to write to this bit. 0h = Disable Power 1h = Enable Power | www.ti.com COMP # 10.3.5 RSTCTL (Offset = 804h) [Reset = 00000000h] RSTCTL is shown in Figure 10-9 and described in Table 10-11. Return to the Summary Table. Register to control reset assertion and de-assertion ## Figure 10-9. RSTCTL ## Table 10-11. RSTCTL Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|--------------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------| | 31-24 | KEY | W | 0h | Unlock key B1h = KEY to allow write access to this register | | 23-2 | RESERVED | W | 0h | | | 1 | RESETSTKYCLR | WK | 0h | Clear the RESETSTKY bit in the STAT register KEY must be set to B1h to write to this bit. 0h = Writing 0 has no effect 1h = Clear reset sticky bit | | 0 | RESETASSERT | WK | 0h | Assert reset to the peripheral KEY must be set to B1h to write to this bit. Oh = Writing 0 has no effect 1h = Assert reset | # 10.3.6 CLKCFG (Offset = 808h) [Reset = 00000000h] CLKCFG is shown in Figure 10-10 and described in Table 10-12. Return to the Summary Table. Peripheral Clock Configuration Register ## Figure 10-10. CLKCFG #### Table 10-12. CLKCFG Field Descriptions | | | | | • | |-------|------------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Field | Туре | Reset | Description | | 31-24 | KEY | W | 0h | KEY to Allow State Change 0xA9 A9h = Key value to be used in writing to this register for the write to take effect. | | 23-9 | RESERVED | R/W | 0h | | | 8 | BLOCKASYNC | R/W | 0h | Async Clock Request is blocked from starting SYSOSC or forcing bus clock to 32MHz 0h = disable COMP to request SYSOSC 1h = enable COMP to request SYSOSC | | 7-0 | RESERVED | R/W | 0h | | # 10.3.7 STAT (Offset = 814h) [Reset = 00000000h] STAT is shown in Figure 10-11 and described in Table 10-13. Return to the Summary Table. peripheral enable and reset status # Figure 10-11. STAT # **Table 10-13. STAT Field Descriptions** | Bit | Field | Туре | Reset | Description | |-------|-----------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-17 | RESERVED | R | 0h | | | 16 | RESETSTKY | R | 0h | This bit indicates, if the peripheral was reset, since this bit was cleared by RESETSTKYCLR in the RSTCTL register 0h = The peripheral has not been reset since this bit was last cleared by RESETSTKYCLR in the RSTCTL register 1h = The peripheral was reset since the last bit clear | | 15-0 | RESERVED | R | 0h | | # 10.3.8 IIDX (Offset = 1020h) [Reset = 00000000h] IIDX is shown in Figure 10-12 and described in Table 10-14. Return to the Summary Table. Interrupt index register. This read-only register provides the interrupt index of the pending interrupt with the highest priority. It also indicates if no interrupt is pending. The priority order is fixed: lower index equals higher priority. Alternatively to the use of IIDX, users can implement their own prioritization schemes using other registers that expose the full set of interrupts that have occurred. On each read, only one interrupt is indicated. On a read, the current interrupt (highest priority) is automatically cleared by the hardware and the corresponding interrupt flags in the RIS and MIS are cleared as well. After a read from the CPU (not from the debug interface), the register must be updated with the next highest priority interrupt or indicate that no interrupt is pending. Only interrupts which are selected via IMASK are indicated. Figure 10-12. IIDX **Table 10-14. IIDX Field Descriptions** | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-2 | RESERVED | R | 0h | | | 1-0 | STAT | R | 0h | Interrupt index status 0h = No pending interrupt 2h = Comparator output interrupt 3h = Comparator output inverted interrupt 4h = Comparator output ready interrupt | # 10.3.9 IMASK (Offset = 1028h) [Reset = 00000000h] IMASK is shown in Figure 10-13 and described in Table 10-15. Return to the Summary Table. Interrupt Mask. If a bit is set, then corresponding interrupt is unmasked. Unmasking the interrupt causes the raw interrupt to be visible in IIDX, as well as MIS." Figure 10-13. IMASK ## **Table 10-15. IMASK Field Descriptions** | Bit | Field | Туре | Reset | Description | | | |------|------------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | 31-4 | RESERVED | R/W | 0h | | | | | 3 | OUTRDYIFG | R/W | Oh | Masks OUTRDYIFG 0h = Interrupt is masked out 1h = Interrupt will request an interrupt service routine and corresponding bit in MIS will be set | | | | 2 | COMPINVIFG | R/W | Oh | Masks COMPINVIFG 0h = Interrupt is masked out 1h = Interrupt will request an interrupt service routine and corresponding bit in MIS will be set | | | | 1 | COMPIFG | R/W | Oh | Masks COMPIFG 0h = Interrupt is masked out 1h = Interrupt will request an interrupt service routine and corresponding bit in MIS will be set | | | | 0 | RESERVED | R/W | 0h | | | | # 10.3.10 RIS (Offset = 1030h) [Reset = 00000000h] RIS is shown in Figure 10-14 and described in Table 10-16. Return to the Summary Table. Raw interrupt status. Reflects all pending interrupts, regardless of masking. The RIS register allows the user to implement a poll scheme. A flag set in this register can be cleared by writing 1 to the ICLR register bit even if the corresponding IMASK bit is not enabled. Figure 10-14. RIS ## **Table 10-16. RIS Field Descriptions** | Bit | Field | Туре | Reset | Description | |------|------------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-4 | RESERVED | R | 0h | | | 3 | OUTRDYIFG | R | 0h | Raw interrupt status for comparator output ready interrupt flag. This bit is set when the comparator output is valid. 0h = No interrupt pending 1h = Interrupt pending | | 2 | COMPINVIFG | R | 0h | Raw interrupt status for comparator output inverted interrupt flag. The IES bit defines the transition of the comparator output setting this bit. 0h = No interrupt pending 1h = Interrupt pending | | 1 | COMPIFG | R | 0h | Raw interrupt status for comparator output interrupt flag. The IES bit defines the transition of the comparator output setting this bit. 0h = No interrupt pending 1h = Interrupt pending | | 0 | RESERVED | R | 0h | | # 10.3.11 MIS (Offset = 1038h) [Reset = 00000000h] MIS is shown in Figure 10-15 and described in Table 10-17. Return to the Summary Table. Masked interrupt status. This is an AND of the IMASK and RIS registers. # Figure 10-15. MIS | | | | 9 | • . • • | | | | | | |------|----------|------|------|-----------|------------|---------|----------|--|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | RESERVED | | | | | | | | | | R-0h | | | | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | RESERVED | | | | | | | | | | R-0h | | | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | | RESE | RVED | | | | | | | | | | R- | ·0h | | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | RESE | RVED | | OUTRDYIFG | COMPINVIFG | COMPIFG | RESERVED | | | | | R-0 | Oh | | R-0h | R-0h | R-0h | R-0h | | | # Table 10-17. MIS Field Descriptions | Bit | Field | Туре | Reset | Description | |------|------------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-4 | RESERVED | R | 0h | | | 3 | OUTRDYIFG | R | 0h | Masked interrupt status for OUTRDYIFG 0h = OUTRDYIFG does not request an interrupt service routine 1h = OUTRDYIFG requests an interrupt service routine | | 2 | COMPINVIFG | R | Oh | Masked interrupt status for COMPINVIFG 0h = COMPINVIFG does not request an interrupt service routine 1h = COMPINVIFG requests an interrupt service routine | | 1 | COMPIFG | R | Oh | Masked interrupt status for COMPIFG 0h = COMPIFG does not request an interrupt service routine 1h = COMPIFG requests an interrupt service routine | | 0 | RESERVED | R | 0h | | # 10.3.12 ISET (Offset = 1040h) [Reset = 00000000h] ISET is shown in Figure 10-16 and described in Table 10-18. Return to the Summary Table. Interrupt set. Allows interrupts to be set by software (useful in diagnostics and safety checks). Writing a 1 to a bit in ISET will set the event and therefore the related RIS bit also gets set. If the interrupt is enabled through the mask, then the corresponding MIS bit is also set. Figure 10-16. ISET ## Table 10-18. ISET Field Descriptions | Bit | Field | Туре | Reset | Description | |------|------------|------|-------|----------------------------------------------------------------------------------------------------------------| | 31-4 | RESERVED | W | 0h | | | 3 | OUTRDYIFG | W | 0h | Sets OUTRDYIFG in RIS register 0h = Writing a 0 has no effect 1h = RIS bit corresponding to OUTRDYIFG is set | | 2 | COMPINVIFG | W | 0h | Sets COMPINVIFG in RIS register 0h = Writing a 0 has no effect 1h = RIS bit corresponding to COMPINVIFG is set | | 1 | COMPIFG | W | 0h | Sets COMPIFG in RIS register 0h = Writing a 0 has no effect 1h = RIS bit corresponding to COMPIFG is set | | 0 | RESERVED | W | 0h | | # 10.3.13 ICLR (Offset = 1048h) [Reset = 00000000h] ICLR is shown in Figure 10-17 and described in Table 10-19. Return to the Summary Table. Interrupt clear. Write a 1 to clear corresponding Interrupt. # Figure 10-17. ICLR # Table 10-19. ICLR Field Descriptions | Bit | Field | Туре | Reset | Description | |------|------------|------|-------|----------------------------------------------------------------------------------------------------------------------| | 31-4 | RESERVED | W | 0h | | | 3 | OUTRDYIFG | W | Oh | Clears OUTRDYIFG in RIS register 0h = Writing a 0 has no effect 1h = RIS bit corresponding to OUTRDYIFG is cleared | | 2 | COMPINVIFG | W | Oh | Clears COMPINVIFG in RIS register 0h = Writing a 0 has no effect 1h = RIS bit corresponding to COMPINVIFG is cleared | | 1 | COMPIFG | W | Oh | Clears COMPIFG in RIS register 0h = Writing a 0 has no effect 1h = RIS bit corresponding to COMPIFG is cleared | | 0 | RESERVED | W | 0h | | # 10.3.14 IIDX (Offset = 1050h) [Reset = 00000000h] IIDX is shown in Figure 10-18 and described in Table 10-20. Return to the Summary Table. Interrupt index register. This read-only register provides the interrupt index of the pending interrupt with the highest priority. It also indicates if no interrupt is pending. The priority order is fixed: lower index equals higher priority. Alternatively to the use of IIDX, users can implement their own prioritization schemes using other registers that expose the full set of interrupts that have occurred. On each read, only one interrupt is indicated. On a read, the current interrupt (highest priority) is automatically cleared by the hardware and the corresponding interrupt flags in the RIS and MIS are cleared as well. After a read from the CPU (not from the debug interface), the register must be updated with the next highest priority interrupt or indicate that no interrupt is pending. Only interrupts which are selected via IMASK are indicated. Figure 10-18. IIDX Table 10-20. IIDX Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-2 | RESERVED | R | 0h | | | 1-0 | STAT | R | 0h | Interrupt index status 0h = No pending interrupt 2h = Comparator output interrupt 3h = Comparator output inverted interrupt 4h = Comparator output ready interrupt | # 10.3.15 IMASK (Offset = 1058h) [Reset = 00000000h] IMASK is shown in Figure 10-19 and described in Table 10-21. Return to the Summary Table. Interrupt Mask. If a bit is set, then corresponding interrupt is unmasked. Unmasking the interrupt causes the raw interrupt to be visible in IIDX, as well as MIS." Figure 10-19. IMASK ## **Table 10-21. IMASK Field Descriptions** | | iable to 211 his text i lota becomptione | | | | | | | |------|------------------------------------------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | 31-4 | RESERVED | R/W | 0h | | | | | | 3 | OUTRDYIFG | R/W | 0h | Masks OUTRDYIFG 0h = Interrupt is masked out 1h = Interrupt will request an interrupt service routine and corresponding bit in MIS will be set | | | | | 2 | COMPINVIFG | R/W | 0h | Masks COMPINVIFG 0h = Interrupt is masked out 1h = Interrupt will request an interrupt service routine and corresponding bit in MIS will be set | | | | | 1 | COMPIFG | R/W | 0h | Masks COMPIFG 0h = Interrupt is masked out 1h = Interrupt will request an interrupt service routine and corresponding bit in MIS will be set | | | | | 0 | RESERVED | R/W | 0h | | | | | # 10.3.16 RIS (Offset = 1060h) [Reset = 00000000h] RIS is shown in Figure 10-20 and described in Table 10-22. Return to the Summary Table. Raw interrupt status. Reflects all pending interrupts, regardless of masking. The RIS register allows the user to implement a poll scheme. A flag set in this register can be cleared by writing 1 to the ICLR register bit even if the corresponding IMASK bit is not enabled. Figure 10-20. RIS # **Table 10-22. RIS Field Descriptions** | Bit | Field | Туре | Reset | Description | |------|------------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-4 | RESERVED | R | 0h | | | 3 | OUTRDYIFG | R | 0h | Raw interrupt status for comparator output ready interrupt flag. This bit is set when the comparator output is valid. 0h = No interrupt pending 1h = Interrupt pending | | 2 | COMPINVIFG | R | 0h | Raw interrupt status for comparator output inverted interrupt flag. The IES bit defines the transition of the comparator output setting this bit. 0h = No interrupt pending 1h = Interrupt pending | | 1 | COMPIFG | R | 0h | Raw interrupt status for comparator output interrupt flag. The IES bit defines the transition of the comparator output setting this bit. 0h = No interrupt pending 1h = Interrupt pending | | 0 | RESERVED | R | 0h | | # 10.3.17 MIS (Offset = 1068h) [Reset = 00000000h] MIS is shown in Figure 10-21 and described in Table 10-23. Return to the Summary Table. Masked interrupt status. This is an AND of the IMASK and RIS registers. # Figure 10-21. MIS # Table 10-23. MIS Field Descriptions | Bit | Field | Туре | Reset | Description | |------|------------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-4 | RESERVED | R | 0h | | | 3 | OUTRDYIFG | R | 0h | Masked interrupt status for OUTRDYIFG 0h = OUTRDYIFG does not request an interrupt service routine 1h = OUTRDYIFG requests an interrupt service routine | | 2 | COMPINVIFG | R | Oh | Masked interrupt status for COMPINVIFG 0h = COMPINVIFG does not request an interrupt service routine 1h = COMPINVIFG requests an interrupt service routine | | 1 | COMPIFG | R | Oh | Masked interrupt status for COMPIFG 0h = COMPIFG does not request an interrupt service routine 1h = COMPIFG requests an interrupt service routine | | 0 | RESERVED | R | 0h | | # 10.3.18 ISET (Offset = 1070h) [Reset = 00000000h] ISET is shown in Figure 10-22 and described in Table 10-24. Return to the Summary Table. Interrupt set. Allows interrupts to be set by software (useful in diagnostics and safety checks). Writing a 1 to a bit in ISET will set the event and therefore the related RIS bit also gets set. If the interrupt is enabled through the mask, then the corresponding MIS bit is also set. Figure 10-22. ISET # Table 10-24. ISET Field Descriptions | Bit | Field | Туре | Reset | Description | |------|------------|------|-------|----------------------------------------------------------------------------------------------------------------| | 31-4 | RESERVED | W | 0h | | | 3 | OUTRDYIFG | W | 0h | Sets OUTRDYIFG in RIS register 0h = Writing a 0 has no effect 1h = RIS bit corresponding to OUTRDYIFG is set | | 2 | COMPINVIFG | W | 0h | Sets COMPINVIFG in RIS register 0h = Writing a 0 has no effect 1h = RIS bit corresponding to COMPINVIFG is set | | 1 | COMPIFG | W | 0h | Sets COMPIFG in RIS register 0h = Writing a 0 has no effect 1h = RIS bit corresponding to COMPIFG is set | | 0 | RESERVED | W | 0h | | # 10.3.19 ICLR (Offset = 1078h) [Reset = 00000000h] ICLR is shown in Figure 10-23 and described in Table 10-25. Return to the Summary Table. Interrupt clear. Write a 1 to clear corresponding Interrupt. # Figure 10-23. ICLR # Table 10-25. ICLR Field Descriptions | Bit | Field | Туре | Reset | Description | |------|------------|------|-------|----------------------------------------------------------------------------------------------------------------------| | 31-4 | RESERVED | W | 0h | | | 3 | OUTRDYIFG | W | 0h | Clears OUTRDYIFG in RIS register 0h = Writing a 0 has no effect 1h = RIS bit corresponding to OUTRDYIFG is cleared | | 2 | COMPINVIFG | W | Oh | Clears COMPINVIFG in RIS register 0h = Writing a 0 has no effect 1h = RIS bit corresponding to COMPINVIFG is cleared | | 1 | COMPIFG | W | Oh | Clears COMPIFG in RIS register 0h = Writing a 0 has no effect 1h = RIS bit corresponding to COMPIFG is cleared | | 0 | RESERVED | W | 0h | | # 10.3.20 EVT\_MODE (Offset = 10E0h) [Reset = 00000009h] EVT\_MODE is shown in Figure 10-24 and described in Table 10-26. Return to the Summary Table. Event mode register. It is used to select whether each line is disabled, in software mode (software clears the RIS) or in hardware mode (hardware clears the RIS) Figure 10-24. EVT\_MODE # Table 10-26. EVT\_MODE Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-4 | RESERVED | R/W | 0h | | | 3-2 | EVT1_CFG | R | 2h | Event line mode select for event corresponding to GEN_EVENT 0h = The interrupt or event line is disabled. 1h = Event handled by software. Software must clear the associated RIS flag. 2h = Event handled by hardware. The hardware (another module) clears automatically the associated RIS flag. | | 1-0 | INT0_CFG | R | 1h | Event line mode select for event corresponding to CPU_INT 0h = The interrupt or event line is disabled. 1h = Event handled by software. Software must clear the associated RIS flag. 2h = Event handled by hardware. The hardware (another module) clears automatically the associated RIS flag. | # 10.3.21 DESC (Offset = 10FCh) [Reset = 06110000h] DESC is shown in Figure 10-25 and described in Table 10-27. Return to the Summary Table. This register identifies the peripheral and its exact version. # Figure 10-25. DESC # **Table 10-27. DESC Field Descriptions** | Bit | Field | Туре | Reset | Description | | |-------|------------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | 31-16 | MODULEID | R | 611h | Module identification contains a unique peripheral identification number. The assignments are maintained in a central database for all of the platform modules to ensure uniqueness. | | | 15-12 | FEATUREVER | R | 0h | Feature Set for the module *instance* | | | 11-8 | RESERVED | R | 0h | | | | 7-4 | MAJREV | R | 0h | Major rev of the IP | | | 3-0 | MINREV | R | 0h | Minor rev of the IP | | # 10.3.22 CTL0 (Offset = 1100h) [Reset = 00000000h] CTL0 is shown in Figure 10-26 and described in Table 10-28. Return to the Summary Table. Control 0 register. # Figure 10-26. CTL0 | | | | i igaic it | 7-20. O I LU | | | | | |--------|----------------|----------|------------|--------------|--------|-------|----|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | IMEN | | | | RESERVED | | | | | | R/W-0h | | R/W-0h | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | RESERVED IMSEL | | | | | | | | | R/W-0h | | | | | R/W-0h | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | IPEN | | | | RESERVED | | | | | | R/W-0h | | | | R/W-0h | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | RESERVED | | | | IPSEL | | | | | R/W-0h R/W-0h | | | | | | | | # Table 10-28. CTL0 Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 | IMEN | R/W | Oh | Channel input enable for the negative terminal of the comparator. 0h = Selected analog input channel for negative terminal is disabled 1h = Selected analog input channel for negative terminal is enabled | | 30-19 | RESERVED | R/W | 0h | | | 18-16 | IMSEL | R/W | Oh | Channel input selected for the negative terminal of the comparator if IMEN is set to 1. Oh = Channel 0 selected 1h = Channel 1 selected 2h = Channel 2 selected 3h = Channel 3 selected 4h = Channel 4 selected 5h = Channel 5 selected 6h = Channel 6 selected 7h = Channel 7 selected | | 15 | IPEN | R/W | Oh | Channel input enable for the positive terminal of the comparator. 0h = Selected analog input channel for positive terminal is disabled 1h = Selected analog input channel for positive terminal is enabled | | 14-3 | RESERVED | R/W | 0h | | | 2-0 | IPSEL | R/W | Oh | Channel input selected for the positive terminal of the comparator if IPEN is set to 1. Oh = Channel 0 selected 1h = Channel 1 selected 2h = Channel 2 selected 3h = Channel 3 selected 4h = Channel 4 selected 5h = Channel 5 selected 6h = Channel 6 selected 7h = Channel 7 selected | # 10.3.23 CTL1 (Offset = 1104h) [Reset = 00000000h] CTL1 is shown in Figure 10-27 and described in Table 10-29. Return to the Summary Table. Control 1 register. Figure 10-27. CTL1 Table 10-29. CTL1 Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|-----------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-13 | RESERVED | R/W | 0h | | | 12 | WINCOMPEN | R/W | 0h | This bit enables window comparator operation of comparator. Oh = window comparator is disable 1h = window comparator is enable | | 11 | RESERVED | R/W | 0h | | | 10-9 | FLTDLY | R/W | Oh | These bits select the comparator output filter delay. See the device-specific data sheet for specific values on comparator propagation delay for different filter delay settings. Oh = Typical filter delay of 70 ns 1h = Typical filter delay of 500 ns 2h = Typical filter delay of 1200 ns 3h = Typical filter delay of 2700 ns | | 8 | FLTEN | R/W | 0h | This bit enables the analog filter at comparator output. Oh = Comparator output filter is disabled 1h = Comparator output filter is enabled | | 7 | OUTPOL | R/W | Oh | This bit selects the comparator output polarity. 0h = Comparator output is non-inverted 1h = Comparator output is inverted | | 6-5 | HYST | R/W | 0h | These bits select the hysteresis setting of the comparator. 0h = No hysteresis 1h = Low hysteresis, typical 10mV 2h = Medium hysteresis, typical 20mV 3h = High hysteresis, typical 30mV | | 4 | IES | R/W | Oh | This bit selected the interrupt edge for COMPIFG and COMPINVIFG. 0h = Rising edge sets COMPIFG and falling edge sets COMPINVIFG 1h = Falling edge sets COMPIFG and rising edge sets COMPINVIFG | | 3 | SHORT | R/W | 0h | This bit shorts the positive and negative input terminals of the comparator. Oh = Comparator positive and negative input terminals are not shorted 1h = Comparator positive and negative input terminals are shorted | # Table 10-29. CTL1 Field Descriptions (continued) | Bit | Field | Туре | Reset | Description | |-----|--------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 2 | EXCH | R/W | 0h | This bit exchanges the comparator inputs and inverts the comparator output. 0h = Comparator inputs not exchanged and output not inverted 1h = Comparator inputs exchanged and output inverted | | 1 | MODE | R/W | Oh | This bit selects the comparator operating mode. 0h = Comparator is in fast mode 1h = Comparator is in ultra-low power mode | | 0 | ENABLE | R/W | 0h | This bit turns on the comparator. When the comparator is turned off it consumes no power. 0h = Comparator is off 1h = Comparator is on | # 10.3.24 CTL2 (Offset = 1108h) [Reset = 00000000h] CTL2 is shown in Figure 10-28 and described in Table 10-30. Return to the Summary Table. Control 2 register. # Figure 10-28. CTL2 # Table 10-30. CTL2 Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-25 | RESERVED | R/W | 0h | | | 24 | SAMPMODE | R/W | Oh | Enable sampled mode of comparator. 0h = Sampled mode disabled 1h = Sampled mode enabled | | 23-18 | RESERVED | R/W | 0h | | | 17 | DACSW | R/W | 0h | This bit selects between DACCODE0 and DACCODE1 to 8-bit DAC when DACCTL bit is 1. 0h = DACCODE0 selected for 8-bit DAC 1h = DACCODE1 selected for 8-bit DAC | | 16 | DACCTL | R/W | 0h | This bit determines if the comparator output or DACSW bit controls the selection between DACCODE0 and DACCODE1. Oh = Comparator output controls selection between DACCODE0 and DACCODE1 The DACSW bit controls selection between DACCODE0 and DACCODE1 | | 15-11 | RESERVED | R/W | 0h | | | 10-8 | BLANKSRC | R/W | 0h | These bits select the blanking source for the comparator. 0h = Blanking source disabled 1h = Select Blanking Source 1 2h = Select Blanking Source 2 3h = Select Blanking Source 3 4h = Select Blanking Source 4 5h = Select Blanking Source 5 6h = Select Blanking Source 6 | # Table 10-30. CTL2 Field Descriptions (continued) | Bit | Field | Туре | Reset | Description | |-----|----------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | REFSEL | R/W | Oh | This bit selects if the selected reference voltage is applied to positive or negative terminal of the comparator. Oh = If EXCH bit is 0, the selected reference is applied to positive terminal. If EXCH bit is 1, the selected reference is applied to negative terminal. 1h = If EXCH bit is 0, the selected reference is applied to negative terminal. If EXCH bit is 1, the selected reference is applied to positive terminal. | | 6 | RESERVED | R/W | 0h | | | 5-3 | REFSRC | R/W | Oh | These bits select the reference source for the comparator. 0h = Reference voltage generator is disabled (local reference buffer as well as DAC). 1h = VDDA selected as the reference source to DAC and DAC output applied as reference to comparator. 2h = VREF selected as reference to DAC and DAC output applied as reference to comparator. 3h = In devices where internal VREF is buffered and connected to external VREF pin, VREF applied as reference to comparator. DAC is switched off. Note: In LEGO_A3, DAC is turned off in this selection, in other devices DAC is kept on. 5h = VDDA is used as comparator reference. Note: In LEGO_A3, DAC is turned off in this selection, in other devices DAC is kept on. 6h = Internal reference selected as the reference source to DAC and DAC output applied as reference to comparator. 7h = Internal VREF is used as the source of comparator. Not all devices will have this option. | | 2-1 | RESERVED | R/W | 0h | | | 0 | REFMODE | R/W | Oh | This bit requests ULP_REF bandgap operation in fast mode(static) or low power mode (sampled). The local reference buffer and 8-bit DAC inside comparator module are also configured accordingly. Fast mode operation offers higher accuracy but consumes higher current. Low power operation consumes lower current but with relaxed reference voltage accuracy. Comparator requests for reference voltage from ULP_REF only when REFLVL > 0. 0h = ULP_REF bandgap, local reference buffer and 8-bit DAC inside comparator operate in static mode. 1h = ULP_REF bandgap, local reference buffer and 8-bit DAC inside comparator operate in sampled mode. | # 10.3.25 CTL3 (Offset = 110Ch) [Reset = 00000000h] CTL3 is shown in Figure 10-29 and described in Table 10-31. Return to the Summary Table. Control 3 register. # Figure 10-29. CTL3 # Table 10-31. CTL3 Field Descriptions | Table 10 01: 0120 Field Descriptions | | | | | | | |--------------------------------------|----------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Bit | Field | Туре | Reset | Description | | | | 31-24 | RESERVED | R/W | 0h | | | | | 23-16 | DACCODE1 | R/W | 0h | This is the second 8-bit DAC code. When the DAC code is 0x0 the DAC output will be 0 V. When the DAC code is 0xFF the DAC output will be selected reference voltage x 255/256. 0h = Minimum DAC code value FFh = Minimum DAC code value | | | | 15-8 | RESERVED | R/W | 0h | | | | | 7-0 | DACCODE0 | R/W | 0h | This is the first 8-bit DAC code. When the DAC code is 0x0 the DAC output will be 0 V. When the DAC code is 0xFF the DAC output will be selected reference voltage x 255/256. 0h = Minimum DAC code value FFh = Minimum DAC code value | | | # 10.3.26 STAT (Offset = 1120h) [Reset = 00000000h] STAT is shown in Figure 10-30 and described in Table 10-32. Return to the Summary Table. Status register. # Figure 10-30. STAT **Table 10-32. STAT Field Descriptions** | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-1 | RESERVED | R | 0h | | | 0 | OUT | R | | This bit reflects the value of the comparator output. Writing to this bit has no effect on the comparator output. 0h = Comparator output is low 1h = Comparator output is high | # Chapter 11 **OPA** The OPA is a zero-drift chopper stabilized operational amplifier with a programmable gain stage. This chapter describes the features and operation of the OPA peripheral. | 11.1 OPA Overview | 636 | |--------------------|-----| | 11.2 OPA Operation | | | 11.3 OA Registers | | | The OA Regiotore | | OPA www.ti.com #### 11.1 OPA Overview The purpose of the OPA peripheral integrated into the MSPM0xx MCU platform is to provide a way to buffer or amplify analog signals in a system without the need of discrete op-amps. The OPA is based off of a high-performance factory trimmed amplifier core accompanied with a programmable gain stage feedback loop, configurable input muxes, and a burnout current source used to monitor sensor health. #### OPA features include: - Software selectable zero-drift chopper stabilization - Factory trimming to remove offset error - Rail-to-rail input & output - · Operation supported in full-scale supply voltage range - · Dual power modes for added flexibility - Programmable gain amplifier (PGA) up to 32x - Configurable amplifier modes include General Purpose Mode, Buffer Mode, Inverting/Non-inverting PGA Mode, Difference Amplifier Mode and Cascade Amplifier Mode - · Rich selection of external/internal op-amp terminal input options - · Burnout current source (BCS) integrated to monitor sensor health - Operates in RUN, SLEEP, and STOP modes #### Note Most devices integrate more than one OPA peripheral. If more than one OPA is present on a device, they all operate identically. Throughout this chapter, nomenclature appears such as OPAx and OPA[x-1] to describe different instances of the OPA peripheral. Figure 11-1 shows the functional block diagram of the OPA peripheral. - (A) Available on select devices. See the device-specific data sheet for availability. - (B) From VREF module - (C) From ADC MMR Figure 11-1. OPA Block Diagram www.ti.com OPA # 11.2 OPA Operation The OPA is configured with application software. The following sections describe the setup and operation of the OPA peripheral. #### 11.2.1 Analog Core The OPA integrates a high-performance chopper stabilized low-power rail-to-rail input/output operational amplifier. It can be reconfigured in real-time to meet the performance requirements of a specific application. The following table depicts all of the op-amp analog core features and parameters that are configurable: **Table 11-1. OPA Configurable Parameters** | Parameter | Configuration Options | |------------------------------|------------------------------------------| | Rail-to-Rail Input (RRI) | Enabled / Disabled | | Gain Bandwidth Product (GBW) | 6MHz (STD Mode) / 1MHz (LP Mode) | | Chopping (CHOP) | Disabled/Standard Chop/ADC-assisted Chop | In some basic signal conditioning applications, rail-to-rail input is not required and thus can be disabled to reduce overall power consumption. Rail-to-rail input can be disabled by clearing the RRI bit in the CFGBASE register. The same concept applies to the gain bandwidth product for general purpose applications which require <1MHz GBW. The OPA can be configured to the low power operating mode (LP mode) by clearing the GBW bit in the CFGBASE register. In some analog sensing applications, high accuracy and low offset drift is a requirement. For these use-cases, chopping can be enabled to significantly improve offset voltage and offset drift performance. Please refer to Section 11.2.6 for more details on how to properly configure and leverage the chopping feature of the OPA. # 11.2.2 Power Up Behavior The ENABLE bit in the PWREN register connects the OPA peripheral to the bus and the clock system. The ENABLE bit in the CTL register activates the OPA analog and digital core. There is a ready bit (RDY) in the STAT register which is set when the OPA is ready for use. Please see the device-specific data sheet for the enable time of the OPA peripheral. #### Note PWREN.ENABLE must be set before writing to CTL.ENABLE or any other OPA memory mapped registers (MMRs). #### 11.2.3 Inputs The OPA uses input muxes P-MUX and N-MUX to provide a selection of input channels for the non-inverting and inverting terminals of the amplifier. These inputs are configurable using the PSEL and NSEL control bits. A generalized depiction of the input channel mapping is included in Table 11-2 below. Please refer to the device-specific data sheet for a more detailed depiction of the available OPAx inputs. Table 11-2. General OPAx Input Channels | PSEL | OPAx Non-inverting Channels | NSEL | OPAx Inverting Input Channels | |------|-----------------------------|------|-------------------------------| | 0x0 | Open | 0x0 | Open | | 0x1 | OPAx_IN0+ | 0x1 | OPAx_IN0- | | 0x2 | OPAx_IN1+ | 0x2 | OPAx_IN1- | | 0x3 | DAC_OUT | 0x3 | OPA[x-1]_RBOT | | 0x4 | DAC8.x_OUT | 0x4 | RTAP | | 0x5 | VREF | 0x5 | RTOP | | 0x6 | OPA[x-1]_RTOP | | | OPA www.ti.com ## Table 11-2. General OPAx Input Channels (continued) | PSEL | OPAx Non-inverting Channels | NSEL | OPAx Inverting Input Channels | |------|-----------------------------|------|-------------------------------| | 0x7 | GPAMP Output | | | | 0x8 | VSS | | | #### Note OPAx and OPA[x-1] refer to instances where there are 2 OPA peripherals in a device. In these cases, the peripherals are paired and the input/outputs are shared as shown in Table 11-2. DAC8.x refers to the paired COMP reference DAC which can be routed to the non-inverting input of OPAx. ## 11.2.4 Output The OPA output is connected to a network of complementary switches to allow the amplifier output to be a purely internal signal or allow the signal to be accessed through a device pin. If OUTPIN = 0, the output is internally connected to the programmable gain stage and capable of being routed to other analog peripherals. If OUTPIN = 1, the output goes to the device pin while still maintaining connection to the programmable gain stage and other analog peripherals. Having access to the amplifier output at the device pin allows for external filtering circuitry. # 11.2.5 Clock Requirements The OPA requires SYSOSC to be active for proper operation to support features such as chopping and rail-to-rail input. There are no provisions in place for the OPA to automatically request the SYSOSC from SYSCTL so the user must ensure that SYSOSC is enabled to use the OPA. The minimum requirements for the input clock depend on the OPA configuration as shown in the table below. Table 11-3. | RRI | Supported SYSOSC Frequencies | |-----|------------------------------| | 0 | 4/16/24/32 MHz | | 1 | 32 MHz | #### Note Application software needs to ensure that SYSOSC is programmed to an appropriate frequency for rail-to-rail input. # 11.2.6 Chopping The OPA peripheral implements chopper stabilization to reduce offset, drift, and 1/f noise. CFG.CHOP can be set to 0x1 for standard chopping mode which requires an external filter. Note that the OPA automatically scales the chopping frequency based on CFG.GAIN which is used to select the OPA PGA gain but is also needed with external filter when the standard chopping is used as shown in Table 11-4. Table 11-4. Standard Chopping Frequency for OPA | GAIN | Inverting / Non-inverting Gain | Chopping Frequency (Hz) | Resistor(kΩ) | Capacitor(nF) | |------|--------------------------------|-------------------------|--------------|---------------| | 0x0 | 1x | 125k | 1 | 10 | | 0x1 | -1x / 2x | 62.5k | 1 | 30 | | 0x2 | -3x / 4x | 31.25k | 1 | 90 | | 0x3 | -7x / 8x | 15.6k | 1 | 270 | | 0x4 | -15x / 16x | 7.8k | 1 | 810 | | 0x5 | -31x / 32x | 3.9k | 1 | 2400 | www.ti.com OPA #### 11.2.7 OPA Amplifier Modes The OPA uses an input mux, M-MUX, connected to the programmable gain stage resistor ladder to allow the user to program the OPA for various analog signal chain configurations. These configurations include unity gain buffer, inverting/non-inverting amplification, PGA, cascade amplification, and more. A generalized depiction of the input channel mapping for M-MUX is included in Table 11-5 below. Please refer to the device-specific data sheet for a mode detailed depiction of the available M-MUX inputs. Table 11-5. General OPA M-MUX Channel Mapping | MSEL | OPAx M-MUX Input Channels | |------|---------------------------| | 0x0 | Open | | 0x1 | OPAx_IN1- | | 0x2 | GND | | 0x3 | DAC_OUT | | 0x4 | OPA[x-1]_RTOP | The following sections provide examples of how P-MUX, N-MUX, and M-MUX can be configured for various amplifier modes. #### 11.2.7.1 General-Purpose Mode The OPA internal muxes support GP mode which allows all input and output terminals to be accessed from device pins. Using this mode with external components enables the amplifier to realize any analog signal chain circuitry that a discrete op-amp can. Dual differential inputs IN0+/- and IN1+/- allow for two different input networks to be connected to the same OPA peripheral. Figure 11-2 shows the block diagram of the OPA in GP mode. <sup>(</sup>A) Available on select devices. See the device-specific data sheet for availability. (C) From ADC MMR Figure 11-2. OPA in General Purpose (GP) Mode <sup>(</sup>B) From VREF module OPA www.ti.com #### 11.2.7.2 Buffer Mode The internal feedback loop can be programmed to a unity gain configuration to support OPA buffer mode. The non-inverting input can be sourced from a variety of signals such as the external OPAx\_INx or the on-board DAC and VREF peripherals. The OPA can output to an external pin by setting OUTPIN = 0x1 or be internally routed to on-board analog peripherals such as the ADC, COMP, and/or paired OPA by setting OUTPIN = 0x0. Figure 11-3 shows the block diagram of the OPA in buffer mode with external OPAx\_IN0+ as the noninverting input and the output internally routed to the ADC. Figure 11-3. OPA in ADC Buffer Configuration - (A) Available on select devices. See the device-specific data sheet for availability. - (B) From VREF module - (C) From ADC MMR Figure 11-4 shows the block diagram of the OPA in buffer mode with DAC8.x\_OUT as the noninverting input and the output routed out to a device pin. This mode enables the user to use the OPA peripheral as an output buffer for the comparator's onboard reference DAC. Figure 11-4. OPA in DAC Output Buffer Configuration www.ti.com OPA - (A) Available on select devices. See the device-specific data sheet for availability. - (B) From VREF module - (C) From ADC MMR # 11.2.7.3 OPA PGA Mode The OPA integrates a programmable gain stage in the feedback loop to configure the OPA as a PGA (programmable gain amplifier). The gain stage is a feedback resistance ladder and it supports up to 32x amplification. Table 11-6 lists the OPA PGA mode gain settings. Table 11-6. PGA Mode and Gain Settings | PGA Mode Configuration | GAIN | Gain Value from PGA (Internal Gain) | |------------------------|------|-------------------------------------| | | 0x0 | Not Valid | | | 0x1 | -1x | | Inverting PGA Mode | 0x2 | -3x | | inverting PGA Mode | 0x3 | -7x | | | 0x4 | -15x | | | 0x5 | -31x | | | 0x0 | Not<br>valid | | | 0x1 | 2x | | Non-inverting PGA Mode | 0x2 | 4x | | | 0x3 | 8x | | | 0x4 | 16x | | | 0x5 | 32x | | Buffer Mode | 0x0 | 1x | OPA www.ti.com The programmable gain stage works with P-MUX, N-MUX, and M-MUX to support various internal amplifier configurations which are detailed in the following sections. #### 11.2.7.3.1 Inverting PGA Mode In this mode, the inverting input is sourced from the external OPAx\_IN1- crossing the resistor ladder of the PGA. The MSEL bits select OPAx\_IN1- as the source (MSEL = 0x1) and the NSEL bits must select the RTAP as the inverting input for the amplifier (NSEL = 0x4). Because the OPA is a single supply amplifier, the non-inverting input needs to be biased up to ensure that the output stays within the linear range. The non-inverting input can be sourced from the external OPAx\_INx+ input or from a DAC input. Figure 11-5 shows an example of the OPA inverting PGA mode with the 8-bit reference DAC as bias cancellation. Figure 11-5. OPA in Inverting PGA Configuration - (A) Available on select devices. See the device-specific data sheet for availability. - (B) From VREF module - (C) From ADC MMR #### 11.2.7.3.2 Non-inverting PGA Mode In this mode, the non-inverting input is sourced from the external OPAx\_INx+ input (PSEL = 0x1 or 0x2). The NSEL bits must select RTAP as the inverting input for the amplifier (NSEL = 0x4) and from the MSEL bits a bias is chosen from either ground or the 12-bit buffered DAC (DAC OUT). Figure 11-6 shows an example of the OPA in non-inverting PGA mode. Figure 11-6. OPA in Non-inverting PGA Configuration www.ti.com OPA - (A) Available on select devices. See the device-specific data sheet for availability. - (B) From VREF module - (C) From ADC MMR ## 11.2.7.4 Difference Amplifier Mode When two or more OPAs are available on a device, two can be combined to form a difference amplifier. The output equation for the difference amplifier is given by the Vdiff equation in Figure 11-7. The internally connected configuration for two OPAs with the output being sampled by the ADC is shown in Figure 11-8. Figure 11-7. Two OPA Difference Amplifier Block Diagram and Equation OPA www.ti.com Figure 11-8. Two OPAs in Difference Amplifier Configuration # 11.2.7.5 Cascade Amplifier Mode When two or more OPAs are available on a device, two can be combined to form a multistage or cascaded amplifier. Using the programmable input muxes, all combinations of inverting and non-inverting multistage amplifiers can be implemented. The output equation for the non-inverting to non-inverting cascaded amplifier is given by the V<sub>out</sub> equation in Figure 11-9. The internally connected configuration for two OPAs is shown in Figure 11-10. Figure 11-9. Two OPA Non-inverting to Non-inverting Cascade Amplifier Block Diagram and Equation Figure 11-10. Two OPAs in Non-inverting to Non-inverting Cascade Amplifier Configuration ## 11.2.8 OPA Configuration Selection The OPA peripheral allows customers to dynamically change the OPA gain without disabling OPA functionality by using the register CFG.GAIN control bits. When using the control bits CFG.GAIN to select between different www.ti.com OPA gain values, the user must ensure that the additional CFG control bits remain unchanged, and that the CFG.GAIN control bits do not get cleared to 0x0. To ensure proper operation of the OPA, the configuration settings except the CFG.GAIN bits governed by the CFG register can only be changed when the OPA is disabled. This means that in order to change OPA inputs or mode within an application, a user must perform the following: - Clear CTL.ENABLE bit - Update CFG.MSEL or CFG.NSEL or CFG.PSEL bits - Set CTL.ENABLE bit #### Note Applications must take into account OPA enable time when performing this procedure. Please see OPA Specification within the device-specific data sheet for details. #### Note This procedure must also be followed if changing the CFG.GAIN bits to or from a value of 0x0. ### 11.2.9 Burnout Current Source The OPA has a burnout current source (BCS) that can be used when requested by the ADC. The ADC will provide a burnout current source enable signal to the OPA peripheral when it is selected as the ADC input channel and the BCSEN bit is set in the ADC MEMCTL register. When enabled, the burnout current source will inject current into the positive input of the OPA. The ADC should then be used to measure the voltage across the sensor or resistive Wheatstone bridge with the input signal going through the OPA configured in buffer mode (or whichever OPA configuration is normally used). An ADC reading with the burnout current source enabled can then detect if the sensor is open (that is, a broken wire resulting in full range signal) or shorted (0 V). The user can periodically enable the burnout current source to check if the sensor is operating properly. It should be turned off during measurements. OPA www.ti.com # 11.3 OA Registers Table 11-7 lists the memory-mapped registers for the OA registers. All register offset addresses not listed in Table 11-7 should be considered as reserved locations and the register contents should not be modified. Table 11-7. OA Registers | Offset | Acronym | Register Name | Group | Section | | | |--------|---------|---------------------------|-----------------|---------|--|--| | 800h | PWREN | Power enable | Power enable Go | | | | | 804h | RSTCTL | Reset Control | eset Control Go | | | | | 814h | STAT | tatus Register Go | | | | | | 1010h | CLKOVR | Clock Override Go | | | | | | 101Ch | PWRCTL | Power Control Go | | | | | | 1100h | CTL | Control Register Go | | | | | | 1108h | CFG | Configuration Register Go | | | | | | 1118h | STAT | Status Register Go | | | | | Complex bit access types are encoded to fit into small table cells. Table 11-8 shows the codes that are used for access types in this section. Table 11-8. OA Access Type Codes | Access Type | Code | Description | | | |------------------------|-----------|----------------------------------------|--|--| | Read Type | Read Type | | | | | R | R | Read | | | | Write Type | | | | | | W | W | Write | | | | WK | W<br>K | Write<br>Write protected by a key | | | | Reset or Default Value | | | | | | -n | | Value after reset or the default value | | | www.ti.com OPA # 11.3.1 PWREN (Offset = 800h) [Reset = 00000000h] PWREN is shown in Figure 11-11 and described in Table 11-9. Return to the Summary Table. Register to control the power state # Figure 11-11. PWREN # Table 11-9. PWREN Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|-------------------------------------------------------------------------------------------------------| | 31-24 | KEY | W | 0h | KEY to allow Power State Change<br>26h = KEY to allow write access to this register | | 23-1 | RESERVED | R/W | 0h | | | 0 | ENABLE | R/WK | | Enable the power KEY must be set to 26h to write to this bit. 0h = Disable Power 1h = Enable Power | OPA www.ti.com # 11.3.2 RSTCTL (Offset = 804h) [Reset = 00000000h] RSTCTL is shown in Figure 11-12 and described in Table 11-10. Return to the Summary Table. Register to control reset assertion and de-assertion # Figure 11-12. RSTCTL # **Table 11-10. RSTCTL Field Descriptions** | Bit | Field | Туре | Reset | Description | |-------|--------------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------| | 31-24 | KEY | W | 0h | Unlock key B1h = KEY to allow write access to this register | | 23-2 | RESERVED | W | 0h | | | 1 | RESETSTKYCLR | WK | 0h | Clear the RESETSTKY bit in the STAT register KEY must be set to B1h to write to this bit. 0h = Writing 0 has no effect 1h = Clear reset sticky bit | | 0 | RESETASSERT | WK | 0h | Assert reset to the peripheral KEY must be set to B1h to write to this bit. 0h = Writing 0 has no effect 1h = Assert reset | www.ti.com OPA # 11.3.3 STAT (Offset = 814h) [Reset = 00000000h] STAT is shown in Figure 11-13 and described in Table 11-11. Return to the Summary Table. peripheral enable and reset status # Figure 11-13. STAT # **Table 11-11. STAT Field Descriptions** | Bit | Field | Туре | Reset | Description | |-------|---------------------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-17 | 31-17 RESERVED R 0h | | | | | 16 | RESETSTKY | R | 0h | This bit indicates, if the peripheral was reset, since this bit was cleared by RESETSTKYCLR in the RSTCTL register 0h = The peripheral has not been reset since this bit was last cleared by RESETSTKYCLR in the RSTCTL register 1h = The peripheral was reset since the last bit clear | | 15-0 | RESERVED | R | 0h | | OPA www.ti.com # 11.3.4 CLKOVR (Offset = 1010h) [Reset = 00000000h] CLKOVR is shown in Figure 11-14 and described in Table 11-12. Return to the Summary Table. This register overrides the functional clock request by this peripheral to the system # Figure 11-14. CLKOVR # Table 11-12. CLKOVR Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------------------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-2 | 31-2 RESERVED R/W 0h | | 0h | | | 1 | RUN_STOP | R/W | 0h | If OVERRIDE is enabled, this register is used to manually control the peripheral's clock request to the system 0h = Run/ungate functional clock 1h = Stop/gate functional clock | | 0 | OVERRIDE | R/W | 0h | Unlocks the functionality of RUN_STOP to override the automatic peripheral clock request 0h = Override disabled 1h = Override enabled | www.ti.com OPA # 11.3.5 PWRCTL (Offset = 101Ch) [Reset = 00000001h] PWRCTL is shown in Figure 11-15 and described in Table 11-13. Return to the Summary Table. This register controls if a peripheral is disabled if it is in idle state. # Figure 11-15. PWRCTL | | rigate 11-10.1 Wito 12 | | | | | | | | | | | |------|------------------------|----|------|------|----|----|--------|--|--|--|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | | | RESERVED | | | | | | | | | | | | R/W- | | | | | | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | | | | | RESE | RVED | | | | | | | | | R/W- | | | | | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | | | | RESE | RVED | | | | | | | | | | R/W- | | | | | | | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | RESERVED | | | | | | | | | | | | | | | R/W- | | | | R/W-1h | | | | | # Table 11-13. PWRCTL Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-1 | RESERVED | R/W | 0h | | | 0 | AUTO_OFF | R/W | 1h | When set the peripheral will remove its local IP "request for enable" so that it can be disabled if no other entities in the system are requesting it to be enabled. 0h = Disable automatic power off function 1h = Enable automatic power off function | OPA www.ti.com # 11.3.6 CTL (Offset = 1100h) [Reset = X] CTL is shown in Figure 11-16 and described in Table 11-14. Return to the Summary Table. # Control Register # Figure 11-16. CTL | | | | 9 | | | | | | | | |--------|----------|----|----------|------|----|----|--------|--|--|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | | RESERVED | | | | | | | | | | | R/W-0h | | | | | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | | RESERVED | | | | | | | | | | | | R/W-0h | | | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | | | RESE | RVED | | | | | | | | | R/W-0h | | | | | | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | RESERVED | | | | ENABLE | | | | | | | | R/W-0h | | | | R/W-0h | | | | # **Table 11-14. CTL Field Descriptions** | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|-----------------------------------------------------| | 31-1 | RESERVED | R/W | 0h | | | 0 | ENABLE | R/W | * | OAxn Enable. 0h (R/W) = OAxn OFF 1h (R/W) = OAxn ON | www.ti.com OPA # 11.3.7 CFG (Offset = 1108h) [Reset = 00000000h] CFG is shown in Figure 11-17 and described in Table 11-15. Return to the Summary Table. Configuration Register # Figure 11-17. CFG # Table 11-15. CFG Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-16 | RESERVED | R/W | 0h | | | 15-13 | GAIN | R/W | 0h | Gain setting. Refer to TRM for enumeration information. 0h = Minmum gain value 7h = Maximum gain value. | | 12-10 | MSEL | R/W | Oh | MSEL Mux selection. Please refer to the device specific data sheet for exact channels available. 0h (R/W) = no connect 1h (R/W) = external pin OAn-1 2h (R/W) = VSS 3h (R/W) = DAC12 Output 4h (R/W) = OA[n-1]Rtop | | 9-7 | NSEL | R/W | Oh | Negative OA input selection. Please refer to the device specific data sheet for exact channels available. 0h (R/W) = no connect 1h (R/W) = external pin OAn-0 2h (R/W) = external pin OAn-1 3h (R/W) = OA[n+1]Rbot 4h (R/W) = OA[n]Rtap 5h (R/W) = OA[n]Rtop 6h (R/W) = Spare input | | 6-3 | PSEL | R/W | Oh | Positive OA input selection. Please refer to the device specific data sheet for exact channels available. 0h (R/W) = No connect 1h (R/W) = external pin OA+0 2h (R/W) = external pin OAn+1 3h (R/W) = DAC12OUT 4h (R/W) = DAC8OUT 5h (R/W) = VREF Channel 6h (R/W) = OA[n-1]Rtop 7h (R/W) = GPAMP_OUT_INT Input 8h = Internal Grouund Connection | OPA www.ti.com # **Table 11-15. CFG Field Descriptions (continued)** | Bit | Field | Туре | Reset | Description | |-----|--------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 2 | OUTPIN | R/W | 0h | Enable output pin 0h (R/W) = Output pin disabled 1h (R/W) = Output pin enabled | | 1-0 | СНОР | R/W | | Chopping enable. 0h (R/W) = Chopping disable. 1h (R/W) = Standard chopping enable. 2h (R/W) = Chop with post average on. Requires output to be connect to ADC in average mode. | www.ti.com OPA # 11.3.8 STAT (Offset = 1118h) [Reset = X] STAT is shown in Figure 11-18 and described in Table 11-16. Return to the Summary Table. Status Register # Figure 11-18. STAT # **Table 11-16. STAT Field Descriptions** | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|----------------------------------------------------------------------| | 31-1 | RESERVED | R | 0h | | | 0 | RDY | R | | OA ready status. 0h (R) = OAxn is not ready. 1h (R) = OAxn is ready. | OPA www.ti.com This page intentionally left blank. # Chapter 12 **GPAMP** The GPAMP is a chopper stabilized general purpose operational amplifier with rail-to-rail input and output. This chapter describes the features and operation of the GPAMP peripheral. | 12.1 GPAMP Overview | |----------------------| | | | | | 12.2 GPAMP Operation | | | | 12.3 GPAMP Registers | GPAMP www.ti.com #### 12.1 GPAMP Overview The purpose of the GPAMP peripheral integrated into the MSPM0xx MCU platform is to provide a way to buffer or amplify analog signals in a system without the need of discrete op-amps. The GPAMP is based off of a factory trimmed amplifier core accompanied with a configurable inverting input mux which allows for various analog signal chain configurations. #### GPAMP features include: - · Software selectable chopper stabilization - Rail-to-rail input & output - · Operation supported in full-scale supply voltage range - · Programmable internal unity gain feedback loop - · Operates in RUN, SLEEP, and STOP modes Figure 12-1 show the functional block diagram of the GPAMP peripheral. Figure 12-1. GPAMP Block Diagram #### 12.2 GPAMP Operation The GPAMP peripheral is configured with user software using the PMUOPAMP register which is located in the PMCU region of memory mapped registers. For bit field definitions, you can refer to the end of this chapter or the register section of PMCU. The setup and operation of GPAMP is discussed in the following sections. #### 12.2.1 Analog Core The GPAMP integrates a chopper stabilized low-power rail-to-rail input/output operational amplifier. It can be reconfigured in real-time to meet the performance requirements of various applications. The following table depicts all of the amplifier analog core features and parameters that are configurable: **Table 12-1. GPAMP Configurable Parameters** | Parameter | Configuration Options | | |--------------------------|---------------------------------------------|--| | Rail-to-Rail Input (RRI) | Mode 0 / Mode 1 / Mode 2 | | | Chopping (CHOPCLKMODE) | Standard Chop / Disabled /ADC Assisted Chop | | Note ADC Assisted Chop mode is not supported in PG1.0. It will be supported in PG2.0. www.ti.com GPAMP In some basic signal conditioning applications, rail-to-rail input is not required and thus can be disabled to reduce overall power consumption. Rail-to-rail input can be disabled by programming the RRI bit field to 0x0 (Mode 0). Refer to the GPAMP specifications in the device specific data sheet for supported common-mode input ranges in the various RRI modes. In some analog sensing applications, high accuracy and low offset drift is a requirement. For these use-cases, chopping can be enabled to significantly improve offset voltage and offset drift performance. Please refer to Section 12.2.6 for more details on how to properly configure and leverage the chopping feature of the GPAMP. #### 12.2.2 Power Up Behavior The ENABLE bit in the PMUOPAMP register activates the GPAMP analog and digital core. The GPAMP requires the VBOOST circuit in the PMU to be stabilized before use. Refer to Section 2.2.6 for more details on what the VBOOST circuit is and why it is needed for proper GPAMP operation. Please see the device-specific data sheet for the enable time of the GPAMP peripheral. #### 12.2.3 Inputs The GPAMP uses an input mux, N-MUX, to provide a selection of input channels for the inverting terminal of the amplifier. These inputs are configurable using the NSEL control bits. The non-inverting terminal of the amplifier is enabled using the PCHENABLE control bit and allows the input to be driven from the GPAMP\_IN+ signal on a device pin. A depiction of the input channel mapping is included in Table 12-2 below. | PCHENABLE | GPAMP Non-inverting Input | NSEL | GPAMP Inverting Input Channels | | | | | | | |-----------|---------------------------|------|---------------------------------|--|--|--|--|--|--| | 0x0 | Open | 0x0 | GPAMP output pad<br>(GPAMP_OUT) | | | | | | | | 0x1 | GPAMP_IN+ | 0x1 | GPAMP_IN- | | | | | | | | | | 0x2 | GPAMP internal amplifier output | | | | | | | | | | 0x3 | Open | | | | | | | Table 12-2. GPAMP Input Channels #### 12.2.4 Output The GPAMP output is connected to a switch to allow the amplifier output to be a purely internal signal or allow the signal to be accessed through a device pin. If OUTENABLE = 1, the amplifier output goes to the device pin while still maintaining connection to the inverting input mux and other analog peripherals. If OUTENABLE = 0, the amplifier output is disconnected from the device pin but is still internally connected to the inverting input mux and other analog peripherals on-board. Having access to the amplifier output at the device pin allows for external filtering circuitry. Refer to the GPAMP Block Diagram for a detailed schematic of the GPAMP output circuitry. #### 12.2.5 GPAMP Amplifier Modes The GPAMP uses N-MUX and an internal unity gain feedback loop to allow the user to program the GPAMP for various analog signal chain configurations. These configurations include general purpose mode, ADC buffer, and unity gain mode. The following sections provide examples of how GPAMP can be configured for these various amplifier modes. #### 12.2.5.1 General-Purpose Mode The GPAMP supports general-purpose (GP) mode which allows all input and output terminals to be accessed from device pins. To realize this GP mode NSEL, PCHENABLE, and OUTENABLE must all be set to 0x1. Using this mode requires external components and an appropriate feedback loop to build the circuit desired. Figure 12-2 shows the block diagram of the GPAMP in GP mode. GPAMP www.ti.com Figure 12-2. GPAMP in General Purpose (GP) Mode #### 12.2.5.2 ADC Buffer Mode The GPAMP can be used to internally buffer an analog signal into an on-board ADC. To realize this ADC buffer mode, NSEL must be set to 0x2, PCHENABLE must be set to 0x1, and OUTENABLE must be set to 0x0. Figure 12-3 shows the block diagram of the GPAMP in ADC buffer mode with GPAMP\_IN+ as the noninverting input and the output internally routed to the ADC. Figure 12-3. GPAMP in ADC Buffer Configuration #### 12.2.5.3 Unity Gain Mode The internal feedback loop of the GPAMP can be used to implement a unity gain amplifier which can buffer an analog signal to other devices in a system. To realize this unity gain mode, NSEL must be set to 0x0, PCHENABLE must be set to 0x1, and OUTENABLE must be set to 0x1. Figure 12-4 shows the block diagram of the GPAMP in unity gain mode. www.ti.com GPAMP Figure 12-4. GPAMP in Unity Gain Configuration #### 12.2.6 Chopping The GPAMP peripheral implements chopper stabilization to reduce offset, drift, and 1/f noise. CHOPCLKMODE can be set to 0x1 for standard chopping mode which requires an external filter. See device-specific data sheet for recommended values. The chopping frequency, which is set by CHOPCLKFREQ, needs to scale down as the gain increases. Refer to Table 12-3 for info on what chopping frequency is required for a given gain. Table 12-3. Standard Chopping Frequency for GPAMP | CHOPCLKFREQ | Supported External Gain Configuration | Chopping Frequency (Hz) | |-------------|---------------------------------------|-------------------------| | 0x0 | -1x / 2x | 16k | | 0x1 | -3x / 4x | 8k | | 0x2 | -7x / 8x | 4k | | 0x3 | -15x / 16x | 2k | # 12.3 GPAMP Registers The GPAMP control register (PMUOPAMP) is in the SYSCTL registers. See PMUOPAMP Register for details. GPAMP www.ti.com This page intentionally left blank. # Chapter 13 **VREF** The VREF module contains a configurable voltage reference buffer which allows users to supply a stable internal reference to on-board analog peripherals. It also supports bringing in an external reference for applications where higher accuracy is required. This chapter describes the features and operation of the VREF module. | 13.1 VREF Overview | 664 | |---------------------|-----| | 13.2 VREF Operation | 664 | | 13.3 VREF Registers | | | | | VREF www.ti.com #### 13.1 VREF Overview The VREF module for the MSPM0Lxx family is a voltage reference module dedicated for the on-board ADC. VREF allows users to choose between using an internally generated reference voltage or using an externally provided reference voltage from outside the MCU. The VREF module features include: - 1.4V and 2.5V user-selectable internal references - Support for receiving external reference on VREF+/- device pins - Sample and hold mode supports VREF operation down to STANDBY operating mode - Internal reference supports ADC operation up to 200ksps Figure 13-1 shows the block diagram of the VREF module. Figure 13-1. VREF Block Diagram #### 13.2 VREF Operation The VREF module is configured with user software. The setup and operation of VREF is discussed in the following sections. #### 13.2.1 Internal Reference Generation To use VREF to generate an internal voltage reference, the user must first enable the power to the module using the ENABLE control bit in the PWREN register and then enable the reference buffer using the ENABLE control bit in the CTL0 register. The VREF module generates voltage references based on the factory trimmed bandgap coming from the PMU. The bandgap reference is buffered through a non-inverting amplifier to generate one of two internal reference voltages (1.4V or 2.5V). Only one voltage can be selected at a time using the BUFCONFIG control bit in CTL0. After it is enabled and settled, the internal reference can be used as an accurate and stable voltage reference for the on-board ADC. Refer to Section 13.2.3 for more info on how the ADC can leverage this reference voltage. The VREF provides a READY indication bit in the CTL1 register. The first time the VREF is enabled, the READY bit will remain cleared until the VREF is started and settled, after which the READY bit will be set by hardware. If the VREF is disabled, the READY bit will be cleared back to zero by hardware. If the VREF is re-enabled later, the READY bit will not be set, and application software must manage the VREF startup time. www.ti.com VREF #### 13.2.2 External Reference Input For circumstances where accuracy is a key requirement, an external reference can be brought in to the MCU from the VREF+ and VREF- device pins. When supplying the MCU with an external reference, it is recommended to connect a decoupling capacitor on the reference pins with a value based on the voltage source. #### 13.2.3 Analog Peripheral Interface #### **VREF to ADC** The ADC peripheral can leverage the internal configurable reference or an external reference using the VRSEL control bits in the ADC MEMCTL register. When using an internal reference as the ADC voltage reference ( $V_{R+}$ ) the user must ensure that the VREF reference buffer has settled before triggering an ADC conversion. Refer to the device-specific data sheet for VREF settling times and refer to Section 9.2.2 for more details on all of the reference options available for the ADC peripheral. #### **VREF to COMP** The Comparator peripheral can leverage the external reference using the REFSRC control bits in the CTL2 register. Refer to Section 10.2.7 for more details on all of the reference options available for the Comparator peripheral. #### **VREF to OPA** The OPA peripheral can leverage the external reference for setting a voltage bias on the non-inverting input terminal of the amplifier using the PSEL control bits in the CFG register. Refer to Section 11.2.3 for more details on all of the channels available for the non-inverting amplifier input terminal of the amplifier. VREF www.ti.com # 13.3 VREF Registers Table 13-1 lists the memory-mapped registers for the VREF registers. All register offset addresses not listed in Table 13-1 should be considered as reserved locations and the register contents should not be modified. Table 13-1. VREF Registers | Offset | Acronym | Register Name | Group | Section | | |--------|---------|--------------------|-------|---------|--| | 800h | PWREN | Power enable | | Go | | | 804h | RSTCTL | Reset Control Go | | | | | 814h | STAT | Status Register Go | | | | | 1000h | CLKDIV | Clock Divider | | Go | | | 1008h | CLKSEL | Clock Selection | | Go | | | 1100h | CTL0 | Control 0 | | Go | | | 1104h | CTL1 | Control 1 | | Go | | | 1108h | CTL2 | Control 2 | | Go | | Complex bit access types are encoded to fit into small table cells. Table 13-2 shows the codes that are used for access types in this section. Table 13-2. VREF Access Type Codes | Access Type | Code | Description | | | | | |------------------------|--------|----------------------------------------|--|--|--|--| | Read Type | | | | | | | | R | R | Read | | | | | | Write Type | | | | | | | | K | К | Write protected by a key | | | | | | W | W | Write | | | | | | WK | W<br>K | Write<br>Write protected by a key | | | | | | Reset or Default Value | | | | | | | | -n | | Value after reset or the default value | | | | | www.ti.com VREF # 13.3.1 PWREN (Offset = 800h) [Reset = 00000000h] PWREN is shown in Figure 13-2 and described in Table 13-3. Return to the Summary Table. Register to control the power state # Figure 13-2. PWREN #### Table 13-3. PWREN Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|----------------------------------------------------------------------------------------------------| | 31-24 | KEY | W | 0h | KEY to allow Power State Change<br>26h = KEY to allow write access to this register | | 23-1 | RESERVED | R/W | 0h | | | 0 | ENABLE | К | | Enable the power KEY must be set to 26h to write to this bit. 0h = Disable Power 1h = Enable Power | VREF www.ti.com # 13.3.2 RSTCTL (Offset = 804h) [Reset = 00000000h] RSTCTL is shown in Figure 13-3 and described in Table 13-4. Return to the Summary Table. Register to control reset assertion and de-assertion # Figure 13-3. RSTCTL # **Table 13-4. RSTCTL Field Descriptions** | Bit | Field | Туре | Reset | Description | |-------|--------------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------| | 31-24 | KEY | W | 0h | Unlock key B1h = KEY to allow write access to this register | | 23-2 | RESERVED | W | 0h | | | 1 | RESETSTKYCLR | WK | 0h | Clear the RESETSTKY bit in the STAT register KEY must be set to B1h to write to this bit. 0h = Writing 0 has no effect 1h = Clear reset sticky bit | | 0 | RESETASSERT | WK | 0h | Assert reset to the peripheral KEY must be set to B1h to write to this bit. 0h = Writing 0 has no effect 1h = Assert reset | www.ti.com VREF # 13.3.3 STAT (Offset = 814h) [Reset = 00000000h] STAT is shown in Figure 13-4 and described in Table 13-5. Return to the Summary Table. peripheral enable and reset status # Figure 13-4. STAT ### **Table 13-5. STAT Field Descriptions** | Bit | Field | Туре | Reset | Description | |-------|-----------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-17 | RESERVED | R | 0h | | | 16 | RESETSTKY | R | 0h | This bit indicates, if the peripheral was reset, since this bit was cleared by RESETSTKYCLR in the RSTCTL register 0h = The peripheral has not been reset since this bit was last cleared by RESETSTKYCLR in the RSTCTL register 1h = The peripheral was reset since the last bit clear | | 15-0 | RESERVED | R | 0h | | VREF www.ti.com # 13.3.4 CLKDIV (Offset = 1000h) [Reset = 00000000h] CLKDIV is shown in Figure 13-5 and described in Table 13-6. Return to the Summary Table. Clock Divider # Figure 13-5. CLKDIV **Table 13-6. CLKDIV Field Descriptions** | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|--------------------------------------------------------------------------| | 31-3 | RESERVED | R/W | 0h | | | 2-0 | RATIO | R/W | 0h | Selects divide ratio of module clock to be used in sample and hold logic | www.ti.com VREF # 13.3.5 CLKSEL (Offset = 1008h) [Reset = 00000000h] CLKSEL is shown in Figure 13-6 and described in Table 13-7. Return to the Summary Table. **Clock Selection** Figure 13-6. CLKSEL # Table 13-7. CLKSEL Field Descriptions | Bit | Field | Туре | Reset | Description | |------|------------|------|-------|-------------------------------------------| | 31-4 | RESERVED | R/W | 0h | | | 3 | BUSCLK_SEL | R/W | 0h | Selects BUSCLK as clock source if enabled | | 2 | MFCLK_SEL | R/W | 0h | Selects MFCLK as clock source if enabled | | 1 | LFCLK_SEL | R/W | 0h | Selects LFCLK as clock source if enabled | | 0 | RESERVED | R/W | 0h | | VREF www.ti.com # 13.3.6 CTL0 (Offset = 1100h) [Reset = 00000000h] CTL0 is shown in Figure 13-7 and described in Table 13-8. Return to the Summary Table. Control 0 register. Figure 13-7. CTL0 Table 13-8. CTL0 Field Descriptions | _ | Table 10-0. Of E0 Field Descriptions | | | | | | | | |---|--------------------------------------|------------------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | | Bit | Field | Туре | Reset | Description | | | | | | 31-9 | RESERVED | R/W | 0h | | | | | | | 8 | SHMODE | R/W | 0h | This bit enable sample and hold mode 0h = Sample and hold mode is disable 1h = Sample and hold mode is enable | | | | | | 7 | BUFCONFIG | R/W | 0h | These bits configure output buffer. 0h = output 2p5v : Configure Output Buffer to 2.5v 1h = output 1p4v : Configure Output Buffer to 1.4v | | | | | | 6-2 | RESERVED | R/W | 0h | | | | | | | 1 | COMP_VREF_ENABLE | R/W | 0h | Comparator Vref Enable 0h = COMP VREF is disabled 1h = COMP VREF is enabled | | | | | | 0 | ENABLE | R/W | 0h | This bit enables the VREF module. 0h = VREF is disabled 1h = VREF is enabled | | | | www.ti.com VREF # 13.3.7 CTL1 (Offset = 1104h) [Reset = 00000000h] CTL1 is shown in Figure 13-8 and described in Table 13-9. Return to the Summary Table. Control 1 register. # Figure 13-8. CTL1 # Table 13-9. CTL1 Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|---------------------------------------------------------------------------------------------| | 31-2 | RESERVED | R/W | 0h | | | 0 | READY | R | | These bits defines status of VREF 0h = VREF output is not ready 1h = VREF output is ready | VREF www.ti.com # 13.3.8 CTL2 (Offset = 1108h) [Reset = 00000000h] CTL2 is shown in Figure 13-9 and described in Table 13-10. Return to the Summary Table. Control 2 register. # Figure 13-9. CTL2 # Table 13-10. CTL2 Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|---------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-16 | HCYCLE | R/W | Oh | Hold cycle count Total cycles of module clock for hold phase when VREF is working in sample and hold mode in STANDBY to save power. Please refer VREF section of data sheet for recommended values of sample and hold times. 0h = smallest hold cycle FFFFh = largest hold cycle | | 15-0 | SHCYCLE | R/W | Oh | Sample and Hold cycle count Total cycles of module clock for sample and hold phase when VREF is working in sample and hold mode in STANDBY to save power. This field should be greater than HCYCLE field. The difference between this field and HCYCLE gives the number of cycles of sample phase. Please refer VREF section of data sheet for recommended values of sample and hold times. Oh = smallest sample and hold cycle count FFFFh = largest sample and hold cycle | # Chapter 14 **UART** The universal asynchronous receiver-transmitter (UART) module provides an interface for serial communication protocols. | 14.1 UART Overview | 676 | |---------------------|-----| | 14.2 UART Operation | 677 | | 14.3 UART Registers | | | | | UART www.ti.com #### 14.1 UART Overview #### 14.1.1 Purpose of the Peripheral This interface can be used transfer data between a MSPM0 device and another device with an asynchronous serial communication protocol like LIN (local interconnection network), ISO7816 (Smart card protocol), IrDA (infrared data association), hardware flow control (CTS/RTS) and multiprocessor communications are supported. #### 14.1.2 Features The UART controller includes the following features: - Fully programmable serial interface - 5, 6, 7 or 8 data bits - Even, odd, stick, or no-parity bit generation and detection - 1 or 2 stop bit generation - LSB-first or MSB-first data transmit and receive - Line-break detection - Glitch filter on the input signals - Programmable baud-rate generation with oversampling by 16, 8 or 3 - · Separated transmit and receive 4 depth FIFOs reduce CPU interrupt service loading - · Supports DMA data transfer - · Standard FIFO-level and End-of-Transmission interrupts - · Active in all low-power mode including stop and standby mode - Support for waking up SYSOSC via an asynchronous fast clock request upon start bit detection when operating in low power modes (supports up to 19200B rates when using SYSOSC in FCL mode (1% accuracy) - Support loopback mode operation - · Support hardware flow control - Support 9-bit multi-drop configuration - Protocols supported: - Local Interconnect Network (LIN) support - DALI - IrDA - ISO7816 Smart card - RS485 - Manchester coding - Idle-Line Multiprocessor #### Note This is a general overview, UART extend and UART main differences can be seen in Table 14-1 below. Please refer to device data sheet for the specific UART configuration on UART extend and UART main. Table 14-1, UART Extend and Main Features<sup>(1)</sup> | Features | UART Extend | UART Main | |-------------------------------------|--------------------|--------------------| | Hardware flow control | Yes | Yes | | Oversampling options | 3, 8, 16 | 3, 8, 16 | | Separate transmit and receive FIFOs | Yes | Yes | | Active in all low-power modes | Yes <sup>(2)</sup> | Yes <sup>(2)</sup> | | Wake-up with start bit | Yes <sup>(3)</sup> | Yes <sup>(3)</sup> | | Digital Glitch filter | Yes | No | | Analog Glitch filter | Yes | Yes | | 9-bit multi-drop configuration | Yes | Yes | | Idle-Line Multiprocessor | Yes | Yes | | RS-485 | Yes | Yes | www.ti.com UART | <b>Table 14-1. UART</b> | Extend and Main | Features <sup>(1)</sup> | (continued) | |-------------------------|-----------------|-------------------------|-------------| |-------------------------|-----------------|-------------------------|-------------| | Features | UART Extend | UART Main | |----------------------------|-------------|-----------| | Support LIN mode | Yes | - | | Support DALI | Yes | - | | Support IrDA | Yes | - | | Support ISO7816 Smart card | Yes | - | | Support Manchester code | Yes | - | - (1) Refer to the device-specific data sheet for the device-specific configuration of UART extend and UART main modules and their power domains. - (2) UART can be active in all low-power modes including stop and standby unless the UART instance is in power domain 1 (PD1). - (3) Only for UART instance in power domain 0 (PD0). # 14.1.3 Functional Block Diagram <sup>\*</sup>CLKDIV2 is for IrDA mode only Figure 14-1. UART Functional Block Diagram # 14.2 UART Operation This section describes the operation of the UART peripheral. UART www.ti.com #### 14.2.1 Clock Control The UART internal functional clock is selected and divided from the functional clock of the IP. - Use UARTx.CLKSEL register to select the source of the UART functional clock. - BUSSCLK: the current bus clock is selected as the source for UART. The current bus clock depends on power domain. If the UART instance is in power domain 1 (PD1) refer to MCLK, if the UART instance is in power domain 0 (PD0) refer to ULPCLK. - MFCLK: MFCLK is selected as the source for UART, refer to MFCLK. - LFCLK: LFCLK is selected as the source for UART, refer to LFCLK - Use UARTx.CLKDIV register to select the divide ratio of the UART function clock,options are from divide by 1 to 8. For UART Extend, there is a CLKDIV2 register to further divide the UART function clock to support the IrDA mode. When using IrDA mode, CLKDIV2.RATIO must be set to 1h for proper IrDA clocking. The selected source clock is always available and the frequency depends on the power mode, for more information, see the Clock Module (CKM) section. After enabling the UART module by setting the ENABLE bit, the module will be ready to start receiving and transmitting data. #### 14.2.2 Signal Descriptions UART communications require two pins: Receive Data (RX) and Transmit Data (TX): - RX (Receive Data): RX is the serial data input. Glitch filter and oversampling techniques are used on the receive signal to ensure accurate incoming data. - TX (Transmit Data): TX is the serial data output. When the transmitter is enabled and no data needs to be transmitted, the TX pin will be held high. In some bidirectional protocols like ISO7816 Smart card, this pin is also used to receive data. In hardware flow control mode, the following pins are also used: - CTS (Clear To Send): when driven high by external signal, this signal blocks the data transmission at the end of the current transfer. - RTS (Request To Send): when low, this signal indicates that the UART is ready to receive data. #### 14.2.3 General Architecture and Protocol UART transmits and receives characters at a bit rate that is asynchronous to another device. Timing for each character is based on the selected baud-rate. The transmit and receive functions use the same baud-rate frequency. In general, control registers should only be programmed when the UART is disabled (ENABLE bit in the UARTx.CTL0 register is cleared). If the UART is operating and gets disabled during transmit or receive operation, the current transaction gets completed before the UART stops. The baud-rate divisor registers (UARTx.IBRD and UARTx.FBRD) can be modified without disabling the UART. #### 14.2.3.1 Transmit Receive Logic The transmit logic performs parallel-to-serial conversion on the data read from the transmit FIFO. The control logic outputs the serial bit stream beginning with a start bit and followed by the data bits (LSB first), parity bit, and the stop bits according to the programmed configuration. The receive logic performs serial-to-parallel conversion on the received bit stream after a valid start pulse has been detected. Overrun, parity, frame error checking, and line-break detection are also performed, and their status accompanies the data that is written to the receive FIFO, this is the reason for 12-bit receive FIFO. UARTx.CTL0.ENABLE bit is used to enable and disable the UART module, UARTx.CTL0.TXE and RXE bits are used to enable the transmit and receive mode, UARTx.LCRH.WLEN bit is used to configure the number of data bits transmitted or received in a frame, UARTx.LCRH.PEN is used to enable parity and UARTx.LCRH.STP2 is used to send two stop bits. www.ti.com UART Figure 14-2. UART Character Frame #### 14.2.3.2 Bit Sampling By default, UARTx.CTL0.HSE is set to 0 and 16 oversampling is selected and receiving bits are expected to have the length of 16 UART clock UARTclk cycles and is sampled on the 8th UARTclk cycle. Setting the UARTx.CTL0.HSE bit to 1 selects the 8 oversampling where the receiving bits are expected to have the length of 8 UART clock UARTclk cycles and is sampled on the 4th UARTclk cycle. Setting the UARTx.CTL0.HSE bit to 2 selects the 3 oversampling, the receiving bits are expected to have the length of 3 UART clock UARTclk cycles and are sampled on the 1st UARTclk cycle. Depending on the application: - Select oversampling by 3 or 8 to achieve higher speed with UARTclk/8 or UARTclk/3. In this case the receiver tolerance to clock deviation is reduced. - Select oversampling by 16 to increase the tolerance of the receiver to clock deviations. The maximum speed is limited to UARTclk/16. UART www.ti.com 16x oversampling mode (HSE = 0) 8x oversampling mode (HSE = 1) 3x oversampling mode (HSE = 2) Figure 14-3. UART Oversampling mode #### 14.2.3.3 Baud Rate Generation The baud-rate divisor is a 22-bit number consisting of a 16-bit integer and a 6-bit fractional part. The number formed by these two values is used by the baud-rate generator to determine the bit sample period. Having a fractional baud-rate divisor allows the UART to generate all of the standard baud-rates very accurately The 16-bit integer is loaded through the UART Integer Baud-Rate Divisor UARTx.IBRD register and the 6-bit fractional part is loaded with the UART Fractional Baud-Rate Divisor UARTx.FBRD register. The baud-rate divisor can be calculated by using the following formula: UART clock is the clock output of the UART clock control logic, configured by CLKSEL and CLKDIV. Oversampling is selected by the HSE bit in the UARTx.CTL0 register and it can be 16, 8 or 3. - UARTx.IBRD = INT(BRD), integer part of the BRD - UARTx.FBRD = BRD % 64 , fractional part The integer part of BRD is loaded into UARTx.IBRD register. The 6-bit fractional number must be loaded into the UARTx.FBRD register. #### Note When IBRD = 0, FBRD is ignored and no data gets transferred by the UART. Similarly, when IBRD = 65535 (that is 0xFFFF), then FBRD must not be greater than zero. If this is exceeded it results in an aborted transmission or reception. The following example shows a simple method to calculate IBRD.DIVINT and FBRD.DIVFRAC for a baud rate of 19200 bit/s: www.ti.com UART Note: The adder '+0.5' ensures rounding to the closest integer value to keep the rounding error as small as possible Figure 14-4. Baud Rate Configuration When updating the baud-rate divisor (UARTx.IBRD or UARTx.IFRD), the UART.LCRH register must also be written, so any changes to the baud-rate divisor must be followed by a write to the LCRH register for the changes to take effect. The contents of the UART.IBRD and UART.FBRD registers are not updated until transmission or reception of the current character is complete. #### 14.2.3.4 Data Transmission Data received or transmitted is stored in two FIFOs, though the receive FIFO has an extra four bits per character for status information. #### Transmit data: For transmission, data is written into the transmit FIFO. If the UART is enabled, it causes a data frame to start transmitting with the parameters indicated in the UARTx.LCRH register. Data continues to be transmitted until there is no data left in the transmit FIFO. The BUSY bit in the UARTx.STAT register is asserted as soon as data is written to the transmit FIFO (that is, if the FIFO is non-empty) and remains asserted while data is being transmitted. The BUSY bit is negated only when the transmit FIFO is empty, and the last character has been transmitted to the shift register, including the stop bits. The UART can indicate that it is busy even though the UART can no longer be enabled. BUSY also is set during the generation of a BREAK signal. #### Receive data: When the receiver is idle (the RX signal is continuously 1), and the data input goes low (a start bit has been received), the receive counter begins running and data is sampled on the different cycle based on the oversampling setting of the HSE bit in UARTx.CTL0 register .The start bit is valid and recognized if the RX signal is still low after certain number for cycles based on the oversampling setting. After a valid start bit is detected, successive data bits are sampled according to the programmed length of the data characters. The parity bit is then checked if parity mode is enabled. Data length and parity are defined in the UART.LCRH register. Oversampling is explained in Section 14.2.3.2. Lastly, a valid stop bit is confirmed if the RXD signal is high, otherwise a framing error has occurred. When a full word is received, the data is stored in the receive FIFO along with any error bits associated with that word. ### 14.2.3.5 Error and Status For received data, the data byte and the 4-bit status (break, frame, parity, and overrun) is pushed onto the 12-bit wide receive FIFO. The error and status can be can be retrieved by reading UARTx.RXDATA register as showing in Table 14-2. UART www.ti.com #### **Table 14-2. UART Error and Conditions** | Error Condition <sup>(1)</sup> | Bit Field | Description | |--------------------------------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Framing error | FRMERR | A framing error occurs when a low stop bit is detected. When two stop bits are used, both stop bits are checked for framing error. When a framing error is detected, the FRMERR bit is set. | | Parity error | PARERR | A parity error is a mismatch between the number of 1s in a character and the value of the parity bit. When an address bit is included in the character, it is included in the parity calculation. When a parity error is detected, the PARERR bit is set. | | Receive overrun | OVRERR | An overrun error occurs when a character is loaded into RXDATA/FIFO before the prior character has been read. When an overrun occurs, the OVRERR bit is set. | | Break condition | BRKERR | A break is detected when all received data, parity, and stop bits are 0. When a break condition is detected, the BRKERR bit is set. A break condition can also set the interrupt flag RXINT if the break interrupt enable IMASK.BRKERR bit is set. | <sup>(1)</sup> Framing error and break condition are not set when LIN mode is enabled, this pattern is used to signal a Sync frame for LIN. Break detection is not available for IRDA, Manchester and Dali mode. UART module flag status can also be checked by reading UARTx.STAT register as showing in Table 14-3. #### Table 14-3. UART Flag Status | Bit Field | Description | |-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | BUSY | This bit is set as soon as the transmit FIFO becomes non-empty (regardless of whether UART is enabled) or if a receive data is currently ongoing (after the start edge have been detected until a complete byte, including all stop bits, has been received by the shift register). In IDLE_Line mode the busy signal also stays set during the idle time generation. | | RXFE | This bit is set when receive FIFO is empty. If the FIFO is disabled (FEN is 0), the receive holding register is full. If the FIFO is enabled (FEN is 1), the receive FIFO is full. | | RXFF | This bit is set when receive FIFO is full. If the FIFO is disabled (FEN is 0), the receive holding register is empty. If the FIFO is enabled (FEN is 1), the receive FIFO is empty. | | TXFE | This bit is set when transmit FIFO is empty. If the FIFO is disabled (FEN is 0), the transmit holding register is full. If the FIFO is enabled (FEN is 1), the transmit FIFO is full. | | TXFF | This bit is set when receive FIFO is full. If the FIFO is disabled (FEN is 0), the transmit holding register is empty. If the FIFO is enabled (FEN is 1), the transmit FIFO is empty. | | CTS | This bit is set when CTS signal is asserted (low) and cleared when CTS signal is not asserted (high). | | IDLE | IDLE mode has been detected in idle line multiprocessor mode. The IDLE bit is used as an address tag for each block of characters. In idle line multiprocessor format, this bit is set when a received character is an address. | #### 14.2.3.6 Local Interconnect Network (LIN) Support This section is only relevant for UART Extend, which supports LIN mode. Refer to the device data sheet for the device-specific configuration of UART extend and UART main. For supporting local interconnect network (LIN) protocol, the following hardware enhancements are implemented in the UART module: - 16 bit up-counter (LINCNT) clocked by the UART clock. - Interrupt capability on counter overflow (CPU INT.IMASK.LINOVF). - 16 bit capture register (LINC0) with two configurable modes - Capture of LINCNT value on RXD falling edge. Interrupt capability on capture. - Compare of LINCNT with interrupt capability on match. - 16 bit capture register (LINC1) can be configured: - Capture LINCNT value on RXD rising edge. Interrupt capability on capture. #### LIN transmission Sending the break signal can be done by setting the BRK bit in UARTx.LCRH register. This bit needs to be set before the data is written into the FIFO or transmit data register TXDATA. www.ti.com UART To generate LIN responder signals such as wake signals, the TX pin can be configured by TXD\_OUT and TXD\_CTL\_EN bits in register UARTx.CTL0 to be software controlled. By setting TXD\_CTL\_EN bit to 1, the TX output pin can be controlled by the TXD\_OUT bit if the UART transmit is disabled (CTL0.TXE is cleared). #### LIN reception LIN commander issues a break field and sync field at the start of every frame. Hardware must be added such that the LIN responder software driver can reasonably detect BREAK-SYNC and measure the necessary timing parameters to adjust the baud rate or determine an error. For LIN reception, break field detection and compare mode are needed. To configure these features: - 1. Initialize LIN counter to 0 (UARTx.LINCNT = 0) - 2. Enable counter compare match mode (UARTx.LINCTL.LINC0 MATCH = 1) - Load UARTx.LINC0 (counter capture 0 register) with counter value corresponding to 9.5 x T<sub>bit</sub> (refer to LIN Specification for details on this timing). - 4. Enable LINC0 match interrupt (CPU INT.IMASK.LINC0 = 1) - 5. Setup LIN count control (UARTx.LINCTL): - Enable count while low signal on RXD (LINCTL.CNTRXLOW = 1) - Enable LIN counter clearing on RXD falling edge (LINCTL.ZERONE = 1) - Enable LIN counter (LINCTL.CTRENA = 1) #### Optional: - User can enable the rising edge on UART TX signal interrupt (CPU\_INT.IMASK.RXPE = 1), when the RXPE interrupt fires, the software can read the LINCTR directly to see the BREAK field timing. - User can enable the LIN counter overflow interrupt (CPU\_INT.IMASK.LINOVF = 1) to detect the BREAK field is too long and overflows 16bit counter. The timeout can be calculated as t<sub>Timeout</sub> = 2<sup>16</sup>/ UART clock. Figure 14-5. LIN Break Field Detection Sync field validation is required to ensure accuracy of this LIN header part and to calculate the commander baud rate. The synch field consists of the data 0x55 inside a byte field (see Figure 14-6). After software detects a valid BREAK, it can then set the counter to measure the SYNC field. Both capture registers in LIN counter are used so that software sees fewer interrupts. Figure 14-6 shows the SYNC byte format. The LINCTR should be set to 0 on the start bit falling edge and count continuously. The LINC0 capture or RX falling edge interrupts fire at the falling edges of the RX line. During the interrupt processing, software can measure the individual HIGH-LOW times of the bits themselves using the values in the LINC0 and LINC1 registers to make sure all of the timings are valid. The following flow describes a possible LIN sync field validation procedure: - 1. Initialize LIN counter to 0 (UARTx.LINCNT = 0) after detecting a valid break field. - 2. Enable interrupt on RX falling edge (CPU\_INT.IMASK.RXNE = 1) - 3. Setup LIN count control (LINCTL): - Enable LIN counter capture on raising RX edge (LINCTL.LINC1CAP = 1) - Enable LIN counter capture on falling RX edge (LINCTL.LINC0CAP = 1) - Enable LIN counter clearing on RX falling edge (LINCTL.ZERONE = 1) - Enable LIN counter (LINCTL.CTRENA = 1) UART www.ti.com Figure 14-6. LIN SYNC Field Detection Actions at each falling edge of the RX line for the sync field as showing below: - 1. LIN counter is set to 0 and start counting on the falling RX edge. (LINCTL.ZERONE = 1) - 2. RX falling edge interrupt trigger (RXNE): - · Read capture register LINC0 (falling edge) and LINC1 (rising edge) values - · Verify bit times - 3. RX falling edge interrupt trigger (RXNE): - · Read capture register LINC0 (falling edge) and LINC1 (rising edge) values - · Verify bit times - 4. RX falling edge interrupt trigger (RXNE): - · Read capture register LINC0 (falling edge) and LINC1 (rising edge) values - · Verify bit times - 5. RX falling edge interrupt trigger (RXNE): - Read capture register LINC0 (falling edge) and LINC1 (rising edge) values - · Verify bit times - Calculate the proper baud rate to set. Software must set the baud rate before the start bit of the PID field after sync field. On each interrupt occurrence, the capture registers must be read and the bit times need to be validated by the application software. In case of a bit time verification error, the sync field analysis process must be aborted and the application software must switch back to break detection. In case of errors like a breaking commander communication during sync field detection, a timeout interrupt can be generated by enabling the LIN counter overflow (IMASK.LINOVF = 1). When the counter overflows, the interrupt handler can abort the sync field analysis and switch back to break detection. The time the counter overflow interrupt occurs can be calculated as $t_{Timeout} = 2^{16}$ / UART clock. #### Note The sync field is automatically stored in the RX FIFO and can be misread as the PID. Therefore, flush the RX FIFO after the sync field is received and before the PID is received. #### 14.2.3.7 Flow Control Flow control can be accomplished by hardware and the following sections describe the implementation method. In UART mode (CTL0.MODE set to 0), hardware flow control between two devices is accomplished by connecting the RTS output to the CTS input on the receiving device, and connecting the RTS output on the receiving device to the CTS input. The RTS output signal is low active, the CTS input expects a low signal on a send request as shown in Figure 14-7. Figure 14-7. Flow Control The CTS input controls the transmitter, the Device 0 and Device 1 transmitter can only transmit data when their CTS input is asserted low. When RTS flow control is enabled, the RTS output signal indicates the state of the receive FIFO. For example, the CTS of the Device 1 remains asserted low until the preprogrammed RX FIFO level of Device 0 is reached, indicating that the receive FIFO of Device 0 has no space to store additional characters. The CTSEN and RTSEN bits in the UART.CTL0 register specify the flow control mode as shown in Table 14-4. | | Tubic 14 4.1 10W Control Endbic | | | | | |-------|---------------------------------|----------------------------------------|--|--|--| | CTSEN | RTSEN | Description | | | | | 1 | 1 | RTS and CTS flow control enabled | | | | | 1 | 0 | Only CTS flow control enabled | | | | | 0 | 1 | Only RTS flow control enabled | | | | | 0 | 0 | Both RTS and CTS flow control disabled | | | | **Table 14-4. Flow Control Enable** When RTSEN is set to 1, the value of the CTL0.RTS bit is ignored and the RTS output signal is generated by the hardware trigger levels as described below. When RTSEN bit is cleared, the RTS signal output is controlled by the CTL0.RTS bit for SW control. #### RTS flow control: The RTS flow control logic is linked to the programmable receive FIFO watermark levels, it can be configured using UARTx.IFLS register. When RTS flow control is enabled, the RTS is asserted (low) until the receive FIFO is filled up to the watermark level. When the receive FIFO watermark level is reached, the RTS signal is de-asserted (high), indicating that there is no more room to receive any more data. The transmission of data is expected to cease after the current character has been transmitted. The RTS signal is reasserted (low) when data has been read out of the receive FIFO so that it is filled to less than the watermark level. If RTS flow control is disabled and the UART is still enabled, then data is received until the receive FIFO is full, or no more data is transmitted to it. As the RTS signal is de-asserted when the FIFO watermark level is reached by putting the last received character into the FIFO. This means on a back to back transmit another character transfer could already been started by the sender. Therefore, in such cases the watermark level should be set to one level lower to ensure all data can be received and put into the FIFO. #### CTS flow control: If CTS flow control is enabled, then the transmitter checks the CTS signal before transmitting the next byte. If the CTS signal is asserted (low), it transmits the byte otherwise transmission does not occur. The data continues to be transmitted while CTS is asserted (low), and the transmit FIFO is not empty. If the transmit FIFO is empty and the CTS signal is asserted (low) no data is transmitted. If the CTS signal is de-asserted (high) and CTS flow control is enabled, then the current character transmission is completed before stopping. If CTS flow control is disabled and the UART is enabled, then the data continues to be transmitted until the transmit FIFO is empty. #### 14.2.3.8 Idle-Line Multiprocessor When IDLELINE is set in the CTL0.MODE register bits, the idle-line multiprocessor format is selected. Blocks of data are separated by an idle time on the transmit or receive lines (Figure 14-8). An idle receive line is detected when ten or more continuous ones (marks) are received after the one or two stop bits of a character. The baud-rate generator is switched off after reception of an idle line until the next start edge is detected. When an idle line is detected, the IDLE bit in UARTx.STAT is set. In Idle-Line mode the UART receiver operates in no parity mode and the UART word length (UARTx.LCRH.WLEN) must be set to 8bit. Figure 14-8. Idle-Line Multiprocessor The first character received after an idle period is an address character. The IDLE bit in UARTx.STAT register is used as an address tag for each block of characters. In idle-line multiprocessor format, this bit is set when a received character is an address. If an address character is received it is compared against the ADDR register with the AMASK applied. If the received character matches, the address character and all following received characters are transferred into the RXDATA buffer and interrupts/flags are generated until the next address without a match is received. The IDLE bit in UARTx.STAT register is automatically cleared when the address does match; otherwise the IDLE bit is set until the address is matched. When the SENDIDLE bit in UARTx.LCRH register is set the UART inserts an idle period of 11 bit times on the bus, an ongoing transfer is finished first. The next transfer will be delayed till this idle period has finished. Then the next transfer can start with an address character. The following procedure sends out an idle frame to indicate an address character followed by associated data: - Set SENDIDLE then write the address character to TXDATA. TXDATA must be ready for new data (TXINT interrupt must be 1). This generates an idle period of exactly 11 bits followed by the address character. SENDIDLE is reset automatically when the address character has been transferred (all bits are sent out of shift register). - 2. Write desired data characters to TXDATA. TXDATA must be ready for new data (TXINT interrupt must be 1). The data written to TXDATA is transferred to the shift register and transmitted as soon as the shift register is ready for new data. The idle-line time must not be exceeded between address and data transmission or between data transmissions. Otherwise, the transmitted data is misinterpreted as an address. # BUSY bit in IDLELINE mode: - TX: BUSY is set during the generation of an IDLELINE signal and while the address and data bytes are sent - RX: The BUSY signal set during the receive of data and till first 10 idle bits are received. #### 14.2.3.9 9-Bit UART Mode 9-bit mode is enabled by setting MODE bit to ADDR9BIT in the UARTx.CTL0 register. This feature is useful in a multi-drop configuration of the UART where a single controller connected to multiple peripherals can communicate with a particular peripheral through its address or set of addresses along with a qualifier for an address byte. In 9-bit UART mode, the parity enable/mode bits are ignored and the UART word length (UARTx.LCRH.WLEN) must be set to 8 bit. #### **Receive Transaction:** In 9-bit mode, a peripheral checks for the address qualifier at the location of the parity bit. If set, the received byte is compared with the preprogrammed address in UARTx.ADDR register: - If the address matches, a 9-bit mode address match interrupt (ADDR\_MATCH) is generated, if enabled and further data get received. - If the address does not match, the address byte and the subsequent data bytes get dropped. The address can be predefined in the UART.ADDR register to match with the received byte. The matching can be extended to a set of addresses using the address mask in the UART.AMASK register. By default, the UART.AMASK is 0xFF, meaning that only the specified address must match #### **Transmit Transaction:** All the send transactions in 9-bit UART mode are interpreted as: - · Address bytes, if the 9th bit is set - · Data bytes, if the 9th bit is cleared In 9-bit mode, the 9th bit can be controlled by software. The EPS bit setting of the LCRH register reflects the 9th bit for transmit transactions. To indicate an address byte, the software must set the EPS bit before the byte transmission. For data byte transmissions, the EPS bit must be cleared before the byte transmission. For a complete transmit transaction, the address byte must be transmitted as a single byte transaction with EPS bit set, followed by a data byte burst with EPS bit cleared. # 9th bit handling: Table 14-5. 9th Bit Handling | PEN | EPS | 9 <sup>th</sup> Bit (Transmitted or Verified) | | |-----|-----|-----------------------------------------------|--| | 0 | X | Not transmitted or verified | | | 1 | 0 | 0 (= Data) | | | 1 | 1 | 1 (= Address) | | ### 14.2.3.10 RS485 Support RS485 is a standard used in serial communications systems. This standard can be used effectively over long distances and in electrically noisy environments. Multiple receivers can be connected to such a network. These characteristics make RS-485 useful in industrial control systems and similar applications. With the RS485 direction signal an external RS485 PHY can be controlled. The RTS I/O is used in this mode for the direction signal. The signal is set automatically to high once a data transmit is started. It will stay set between bytes if they are sent back to back. If a data receive is ongoing a new transmit should be delayed till this data has been received and the direction signal has been set to transmit. Data exchange sequence as show in Figure 14-9: - Wait till an ongoing receive has been finished. - Activate direction signal to transmit on RTS Pin - · Send data (one or more Bytes) - Wait till an ongoing receive has been finished. - · Deactivate direction signal to transmit on RTS Pin Figure 14-9. RS485 Data Exchange Two bit fields to the LCRH register define the setup and hold time of the external driver direction control: - EXTDIR\_SETUP bits defines the number of UART clock ticks the signal to control the external driver for the RS485 will be set before the START bit is send. The generated setup time will be between EXDIR\_SETUP value and EXDIR\_SETUP + one baud rate cycle - EXTDIR\_HOLD bits defines the number of UART clock ticks the signal to control the external driver for the RS485 will be reset after the beginning of the stop bit. (If 2 STOP bits are enabled the beginning of the 2nd STOP bit.) Figure 14-10. RS485 External Control #### 14.2.3.11 DALI Protocol DALI stands for Digital Addressable Lighting Interface. It is an International Standard (IEC 62386) lighting control system, providing a single interface for all electronic control gear (light sources) and electronic control devices (lighting controllers). The UART module supports the low level DALI Protocol sending and receiving the bit streams for forward and backward frames. The timing between any forward and backward frame sequence needs to be handled and checked by software. # Transmitting a forward or backward frame: When transmitting a forward frame user needs to ensure to write second byte to buffer before first byte has been shifted out. The hardware will then send the two bytes without inserting the stop bits in-between. Otherwise the stop bits will be sent and the data will be handled like a backward frame. #### Receiving data: The UART module in DALI mode will check the 9th bit after the start bit to detect a Forward frame or backward frame. If this bit does have a change of the phase (= no stop bit) a forward frame is detected and: - Address compare is done in software or hardware depending on MASK - Address and data are always transferred into the RX Buffer Otherwise a backward frame is detected and the data is transferred into the RX Buffer without setting the ADDR\_MATCH interrupt. The AMASK register can be used as group assignment used during multicast operation with the MSB to indicate if the device is part of a DALI group. To enable the UART in DALI mode to respond on all ADDRESS the AMASK register needs to be cleared. #### **BI-PHASE LEVELS** Figure 14-11. DALI Protocol The limits for the times T shall be: $334 \,\mu s < T < 500 \,\mu s$ according to standard IEC 62386-102. DALI mode requires Manchester encoding to be enabled. When using DALI mode (CTL0.MODE set to DALI), the CTL0 and LCRH register must be set to: - 8-bit word length (WLEN bit) - No parity / 2 Stop Bit - Manchester encoding enabled - Baud-rate configuration set to match 2T = 833.33us - DALI mode requires the FIFO to be enabled ### 14.2.3.12 Manchester Encoding and Decoding UART provides option to receive and transmit Manchester encoded data. The function is enabled by the MENC bit in CTL0 register to generate the IEEE 802.3 compliant waveform. With the invert function in GPIO control module the output signals can be inverted to generate the G. E. Thomas compliant waveform. The output signal is generated by XORing the data with UART clock signal. The UART clock needs to be double the speed of the baud-rate. So for the data transmit there is an edge at the beginning and the middle of each data bit. For the receive signal the edge in the middle of the bit is detected to decode the RX data. (More information will be added in next revision) ## 14.2.3.13 IrDA Encoding and Decoding When IREN bit in UARTx.IRCTL register is set, the IrDA encoder and decoder are enabled and provide hardware bit shaping for IrDA communication. IrDA en/decoding should only be used with UART mode (UARTx.CTL0.MODE is 0) ### IrDA Encoding The encoder sends a pulse for every zero bit in the transmit bit stream coming from the UART (see Figure 14-12). The pulse duration is defined by IRTXPL bits specifying the number of one-half clock periods of the clock selected by IRTXCLK bit. Figure 14-12. IrDA Protocol (more information will be added in next revision) ### IrDA Decoding The decoder detects high pulses when IRRXPL = 0. Otherwise, it detects low pulses. A programmable digital filter stage can be enabled by setting UARTx.GFCTL.DGFSEL > 0. When IRCTL.IREN is set, also the digital glitch filter should be set so that only pulses longer than the programmed filter length are passed and shorter pulses are discarded. (See the Glitch Suppression chapter on how to set the filter.) ### 14.2.3.14 ISO7816 Smart Card Support The UART offers basic support to allow communication with an ISO7816 smart card. When configuring the MODE bits to smart card (0x4) of the UARTx.CTL0 register, the TXD signal is used as a bit clock, and the RXD signal is used as the half-duplex communication line connected to the smart card. Further smart card signals are not supported by the UART. The clock rate of the UART clock in ISO7816 mode must be in the range of 1 MHz to 5 MHz when using ISO7816 mode, the UARTx.LCRH register must be set to: - 8-bit word length (WLEN bits configured to 0x3) - Even parity (PEN set and EPS set) - No stick parity (SPS cleared) In ISO7816 mode, the UART automatically uses 2 stop bits; therefore the STP2 bit of the LCRH register is ignored. If a parity error is detected during a transmission, RXD is pulled low during the second stop bit. In this case, the UART aborts the transmission, it flushes the transmit FIFO and discards any data it contains. Additionally it raises a parity error interrupt, allowing the software to detect the problem and initiate retransmission of the affected data, as the UART does not support automatic retransmission in this case. The UART does not support automatic retransmission on parity errors. If a parity error is detected on transmission, all further transmit operations are aborted and software must handle retransmission of the affected byte or message. In Smartcard Mode, the receiver in case of parity error will drive the line low and a parity interrupt flag is asserted. The transmitter responds based on the value of this bit. #### 14.2.3.15 Address Detection The UARTx.ADDR register is used to set the specific address that should be matched with receiving address byte. This register is used in conjunction with UARTx.AMASK register to form a match for address-byte received. Only bits where the AMASK is set to '1' are considered. So for full address the AMASK register is set to 0xFF. This feature is used in DALI, UART 9-Bit or Idle-Line mode. **Table 14-6. Address Detection** | Condition | DALI Mode | Idle Line Mode | 9-Bit Mode | |------------------|-------------------------------------|-------------------------------------|-------------------------------------| | Address match | Address and Data is moved to RXDATA | Address and Data is moved to RXDATA | Address and Data is moved to RXDATA | | Address mismatch | Address and Data will be dropped | Address and Data will be dropped | Address and Data will be dropped | ### 14.2.3.16 FIFO Operation The UART has two FIFOs with a depth of 4 entries, one for transmit and one for receive. The FIFOs are accessed through the UART Data (TXDATA/RXDATA) registers. Read operations of the RXDATA register return a 12-bit value consisting of 8 data bits and 4 error flags. Write operations to TXDATA place 8-bit data in the transmit FIFO. Out of reset, both FIFOs are disabled and act as 1-byte-deep holding registers. The FIFOs are enabled by setting the FEN bit in UARTx.CTL0. FIFO status can be monitored through the UARTx.STAT register and the interrupt events. ### Hardware monitors empty, full and overrun conditions The UARTx.STAT register contains empty and full flags (TXFE, TXFF, RXFE, and RXFF bits), and the CPU\_INT.RIS register shows overrun status of the receive FIFO through the OVRERR bit. There is no indicator for a transmit FIFO overrun. A write is just lost, in case it overruns the transmit FIFO. If the FIFOs are disabled, the empty and full flags are set according to the status of the 1-byte-deep holding registers. When receiving more data than the FIFO can capture the oldest data will be overwritten with the received data. The trigger point at which the FIFOs generate interrupts is controlled through the UARTx.IFLS register. Both FIFOs can be individually configured to trigger interrupts at different levels. Available configurations for transmit FIFO include 3/4, 1/2, 1/4 and empty, for receive FIFO 1/4, 1/2, 3/4 and full. For example, if the 3/4 option is selected for the receive FIFO, the UART generates a receive interrupt after 3 data bytes are received. Out of reset, both FIFOs are configured to trigger an interrupt at the 1/2 mark. The FIFO integrity is not guaranteed under the following conditions: - After a UART Send Break has been initiated (LCRH.BRK = 1) - If the software disables the UART in the middle of a transmission with data in the FIFO, and then re-enables it. #### 14.2.3.17 Loopback Operation The UART can be placed into an internal loopback mode for diagnostic or debug work by setting the LBE bit in the UART.CTL0 register. In loopback mode, data transmitted on the TXD output is received on the RXD input. Data received on the RXD IO pin will be ignored when loopback is enabled. #### 14.2.3.18 Glitch Suppression #### Digital filter Digital filter is based on the UART functional clock. The DGFSEL bits in the UARTx.GFCTL register can be programmed to provide glitch suppression on the RX line and assure proper signal values. The glitch suppression value is in terms of functional clocks. All signals are delayed internally when glitch suppression is nonzero. For example, if DGFSEL is set to 0x5, 5 clocks should be added onto the calculation for the expected transaction time. The DGFSEL need to be configured for the glitch suppression pulse width to be shorter than 1/3 of a normal data pulse, to avoid a normal pulse is filtered unexpectedly. #### Analog filter The analog glitch suppression on the RX line is based on the analog glitch filter and it can be selected with the AGFSEL bits in the UARTx.GFCTL register. See data sheet for the select-able glitch filter values. The analog glitch filter is enabled with the AGFEN, if not set the input signals will be passed through to the UART module without filtering. #### 14.2.4 Low Power Operation (More information will be added in next revision) ### 14.2.5 Reset Considerations # **Software Reset Considerations** A Software reset can be executed with setting the RESETASSERT together with the KEY in the RSTCTL register. An ongoing transfer will be terminated immediately and can leave the software in an undefined state. Therefore, before requesting a reset an ongoing transfer should be terminated. #### **Hardware Reset Considerations** A hardware reset also initializes the IO configuration. This sets the IOs to a high impedance state and the data lines can float. If this is critical for the application or connected devices on the UART interface external pull up or down resistors might be required. #### 14.2.6 Initialization Before the UART is setup or configuration changes, the ENABLE bit should be cleared to avoid unpredictable behavior during the updates or for the first data receive or transmitted afterward. To enable and initialize the UART, use the following steps: - 1. Configure RX and TX pin functions by using the IOMUX registers. - 2. Reset the peripheral using UARTx.RSTCTL register - 3. Enable the power to UART peripheral using the UARTx.PWREN register - Select the UART function clock source and divide options using UART.CLKSEL and UART.CLKDIV registers. - 5. Disable the UART by clearing the UART.CTL0.ENABLE bit. - 6. Use the baud-rate equation in Section 14.2.3.3 to calculate the UARTx.IBRD and UARTx.FBRD registers. - 7. Write the integer portion of the BRD to the UART.IBRD register. - 8. Write the fractional portion of the BRD to the UART.FBRD register. - 9. Write the desired oversampling and FIFO configuration to the UART.CTL0 register - 10. Write the desired serial parameters to the UART.LCRH register. - 11. Enable the UART by setting the UART.CTL0.ENABLE bit. ### 14.2.7 Interrupt and Events Support The UART module contains three event publishers and no event subscribers. One event publisher (CPU\_INT) manages UART interrupt requests (IRQs) to the CPU subsystem through a static event route. The second and third event publishers (DMA\_TRIG\_RX, DMA\_TRIG\_TX) are used to setup the trigger signaling for the DMA through DMA event route. The UART events are summarized in Table 14-7. ### **Table 14-7. UART Events** | Event | Туре | Source | Destination | Route | Configuration | Functionality | |---------------|-----------|--------|---------------|-----------------|-----------------------|----------------------------------------| | CPU interrupt | Publisher | UART | CPU Subsystem | Static route | CPU_INT registers | Fixed interrupt route from UART to CPU | | DMA trigger | Publisher | UART | DMA | DMA event route | DMA_TRIG_RX registers | Fixed interrupt route from UART to DMA | | DMA trigger | Publisher | UART | DMA | DMA event route | DMA_TRIG_TX registers | Fixed interrupt route from UART to DMA | ### 14.2.7.1 CPU Interrupt Event Publisher (CPU INT) The UART module provides 18 interrupt sources which can be configured to source a CPU interrupt event. In order of decreasing interrupt priority, the CPU interrupt events from the UART are: ### Table 14-8. UART CPU Interrupt Event Conditions (CPU\_INT) | IIDX STAT | Name | Description | |-----------|-----------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0x01 | RTOUT | UART receive timeout interrupt, This interrupt is asserted when the receive FIFO is not empty, and no further data is received specified time in the UARTx.IFLS.RXTOSEL bits. More information provided below. | | 0x02 | FRMERR | UART framing error interrupt, see Section 14.2.3.5 for more information. | | 0x03 | PARERR | UART parity error interrupt, see Section 14.2.3.5 for more information. | | 0x04 | BRKERR | UART break error interrupt, see Section 14.2.3.5 for more information. | | 0x05 | OVRERR | UART receive overrun error interrupt, see Section 14.2.3.5 for more information. | | 0x06 | RXNE | Falling edge on RX interrupt, this interrupt triggers when there is a falling edge on RX line. | | 0x07 | RXPE | Raising edge on RX interrupt, this interrupt triggers when there is a raising edge on RX line. | | 0x08 | LINC0 | LIN capture 0 match interrupt, this interrupt triggers when the defined capture 0 value is reached in LIN counter. | | 0x09 | LINC1 | LIN capture 1 match interrupt, this interrupt triggers when the defined capture 1 value is reached in LIN counter. | | 0x0A | LINOVF LIN counter overflow interrupt, this interrupt triggers when the 16bit LIN counter overflows | | | 0x0B | RXINT | UART receive interrupt. More information provided below. | | 0x0C | TXINT | UART transmit interrupt. More information provided below. | | | | UART end of transmission interrupt, it indicates that the last bit of all transmitted data and status has left the serializer and without any further data in the TX FIFO. | | 0x0E | ADDR_MATCH Address match interrupt, used in protocols with address to indicate address match happen | | | 0x0F | CTS | UART clear to send interrupt, indicate the CTS signal status. | | 0x10 | DMA_DONE_RX | This interrupt is set if the RX DMA channel sends the DONE signal. | | 0x11 | DMA_DONE_TX | This interrupt is set if the TX DMA channel sends the DONE signal. | The CPU interrupt event configuration is managed with the CPU\_INT event management registers. See Section 6.2.5 for guidance on configuring the Event registers for CPU interrupts. The receive timeout interrupt is asserted when the receive FIFO is not empty, and no further data is received specified time in the IFLS.RXTOSEL bits. The receive timeout interrupt is cleared either when the FIFO becomes empty through reading all the data (or by reading the holding register), by reading the interrupt index from IIDX or when a 1 is written to the corresponding bit in the ICLR register. The receive interrupt (RXINT, 0x0B) changes state when one of the following events occurs: - If the FIFOs are enabled and the receive FIFO reaches the programmed trigger level, the RXINT bit is set. The receive interrupt is cleared by reading data from the receive FIFO until it becomes less than the trigger level, by reading the interrupt index from IIDX or by writing a 1 to the RXINT bit in ICLR. - If the FIFOs are disabled (have a depth of one location) and data is received thereby filling the location, the RXINT bit is set. The receive interrupt is cleared by performing a single read of the receive FIFO, by reading the interrupt index from IIDX or by writing a 1 to the RXINT bit in ICLR. The transmit interrupt (TXINT, 0x0C) changes state when one of the following events occurs: - If the FIFOs are enabled and the transmit FIFO progresses through the programmed trigger level, the TXINT bit is set. The transmit interrupt is based on a transition through level, therefore the FIFO must be written past the programmed trigger level otherwise no further transmit interrupts will be generated. The transmit interrupt is cleared by writing data to the transmit FIFO until it becomes greater than the trigger level, by reading the interrupt index from IIDX or by writing a 1 to the TXINT bit in ICLR. - If the FIFOs are disabled (have a depth of one location) and there is no data present in the transmitters single location, the TXINT bit is set. It is cleared by performing a single write to the transmit FIFO, by reading the interrupt index from IIDX or by writing a 1 to the TXINT bit in ICLR. 14.2.7.2 DMA Trigger Publisher (DMA\_TRIG\_RX, DMA\_TRIG\_TX) DMA\_TRIG\_RX and DMA\_TRIG\_TX registers are used to setup the trigger signaling for the DMA. This can be setup in a flexible way to trigger the DMA for receive or transmit events with the trigger conditions in Table 14-9and Table 14-10. DMA\_TRIG\_RX is used for triggering the DMA to do a receive data transfer and DMA\_TRIG\_TX is used for triggering the DMA to do a transmit data transfer. | Table 14-9. | . UART DMA | Trigger | Condition | (DMA | TRIG | RX) | | |-------------|------------|---------|-----------|------|------|-----|--| | | | | | | | | | | IIDX STAT | Name | Description | | |-----------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | 0x01 | | UART receive timeout interrupt, This interrupt is asserted when the receive FIFO is not empty, and no further data is received specified time in the UARTx.IFLS.RXTOSEL bits. More information provided below. | | | 0x0B | RXINT | UART receive interrupt. More information provided below. | | The receive timeout interrupt is asserted when the receive FIFO is not empty, and no further data is received specified time in the IFLS.RXTOSEL bits. The receive timeout interrupt is cleared either when the FIFO becomes empty through reading all the data (or by reading the holding register), by reading the interrupt index from IIDX or when a 1 is written to the corresponding bit in the ICLR register. The receive interrupt (RXINT, 0x0B) changes state when one of the following events occurs: - If the FIFOs are enabled and the receive FIFO reaches the programmed trigger level, the RXINT bit is set. The receive interrupt is cleared by reading data from the receive FIFO until it becomes less than the trigger level, by reading the interrupt index from IIDX or by writing a 1 to the RXINT bit in ICLR. - If the FIFOs are disabled (have a depth of one location) and data is received thereby filling the location, the RXINT bit is set. The receive interrupt is cleared by performing a single read of the receive FIFO, by reading the interrupt index from IIDX or by writing a 1 to the RXINT bit in ICLR. Table 14-10. UART DMA Trigger Condition (DMA\_TRIG\_TX) | IIDX STAT | Name | Description | | |-----------|-------|-----------------------------------------------------------|--| | 0x0C | TXINT | UART transmit interrupt. More information provided below. | | The transmit interrupt (TXINT, 0x0C) changes state when one of the following events occurs: - If the FIFOs are enabled and the transmit FIFO progresses through the programmed trigger level, the TXINT bit is set. The transmit interrupt is based on a transition through level, therefore the FIFO must be written past the programmed trigger level otherwise no further transmit interrupts will be generated. The transmit interrupt is cleared by writing data to the transmit FIFO until it becomes greater than the trigger level, by reading the interrupt index from IIDX or by writing a 1 to the TXINT bit in ICLR. - If the FIFOs are disabled (have a depth of one location) and there is no data present in the transmitters single location, the TXINT bit is set. It is cleared by performing a single write to the transmit FIFO, by reading the interrupt index from IIDX or by writing a 1 to the TXINT bit in ICLR. The DMA trigger event configuration is managed with the DMA\_TRIG\_RX and DMA\_TRIG\_TX event management registers. See Section 6.2.5 for guidance on configuring the Event registers and Section 6.1.3.2 for on how DMA trigger event works. ### 14.2.8 Emulation Modes The module behavior while the device is in debug mode is controlled by the FREE and SOFT bits in PDBGCTL register. When the device is in debug mode and set into halt mode below behavior can be configured. Table 14-11. Debug Mode Peripheral Behavior | PDBGCTL.FREE | PDBGCTL.SOFT | Function | | |--------------|--------------|--------------------------------------------------------|--| | 1 | x | Modules continues operation | | | 0 | 0 | Module stops immediately | | | 0 | 1 | Module stops after the next transfer has been finished | | # 14.3 UART Registers Table 14-12 lists the memory-mapped registers for the UART registers. All register offset addresses not listed in Table 14-12 should be considered as reserved locations and the register contents should not be modified. # Table 14-12. UART Registers | | | Table 14-12. OAKT IVE | <u> </u> | | | |--------|----------|----------------------------------------------|----------------------------|---------|--| | Offset | Acronym | Register Name | Group | Section | | | 800h | PWREN | Power enable | Power enable | | | | 804h | RSTCTL | Reset Control | Reset Control | | | | 808h | CLKCFG | Peripheral Clock Configuration Registe | er | Go | | | 814h | STAT | Status Register | | Go | | | 1000h | CLKDIV | Clock Divider | | Go | | | 1008h | CLKSEL | Clock Select for Ultra Low Power peripherals | | Go | | | 1018h | PDBGCTL | Peripheral Debug Control | | Go | | | 1020h | IIDX | Interrupt index | CPU_INT | Go | | | 1028h | IMASK | Interrupt mask | CPU_INT | Go | | | 1030h | RIS | Raw interrupt status | CPU_INT | Go | | | 1038h | MIS | Masked interrupt status | CPU_INT | Go | | | 1040h | ISET | Interrupt set | CPU_INT | Go | | | 1048h | ICLR | Interrupt clear | CPU_INT | Go | | | 1050h | IIDX | Interrupt index | DMA_TRIG_<br>RX | Go | | | 1058h | IMASK | Interrupt mask | DMA_TRIG_<br>RX | Go | | | 1060h | RIS | Raw interrupt status | DMA_TRIG_<br>RX | Go | | | 1068h | MIS | Masked interrupt status | DMA_TRIG_<br>RX | Go | | | 1070h | ISET | Interrupt set | DMA_TRIG_<br>RX | Go | | | 1078h | ICLR | Interrupt clear | DMA_TRIG_<br>RX | Go | | | 1080h | IIDX | Interrupt index | DMA_TRIG_T<br>X | Go | | | 1088h | IMASK | Interrupt mask | DMA_TRIG_T<br>X | Go | | | 1090h | RIS | Raw interrupt status | DMA_TRIG_T<br>X | Go | | | 1098h | MIS | Masked interrupt status | DMA_TRIG_T<br>X | Go | | | 10A0h | ISET | Interrupt set | DMA_TRIG_T<br>X | Go | | | 10A8h | ICLR | Interrupt clear | DMA_TRIG_T<br>X | Go | | | 10E0h | EVT_MODE | Event Mode | | Go | | | 10E4h | INTCTL | Interrupt control register | Interrupt control register | | | | 1100h | CTL0 | UART Control Register 0 | | | | | 1104h | LCRH | UART Line Control Register | | Go | | | 1108h | STAT | UART Status Register | | Go | | | 110Ch | IFLS | UART Interrupt FIFO Level Select<br>Register | | Go | | Table 14-12. UART Registers (continued) | Offset | Acronym | Register Name | Group | Section | | |--------|---------|-----------------------------------------------|-------------------------------|---------|--| | 1110h | IBRD | UART Integer Baud-Rate Divisor Go<br>Register | | | | | 1114h | FBRD | UART Fractional Baud-Rate Divisor Go Register | | | | | 1118h | GFCTL | Glitch Filter Control | | Go | | | 1120h | TXDATA | UART Transmit Data Register | | Go | | | 1124h | RXDATA | UART Receive Data Register | UART Receive Data Register Go | | | | 1130h | LINCNT | UART LIN Mode Counter Register Go | | Go | | | 1134h | LINCTL | UART LIN Mode Control Register Go | | | | | 1138h | LINC0 | UART LIN Mode Capture 0 Register Go | | | | | 113Ch | LINC1 | UART LIN Mode Capture 1 Register Go | | Go | | | 1140h | IRCTL | eUSCI_Ax IrDA Control Word Register Go | | Go | | | 1148h | AMASK | Self Address Mask Register Go | | | | | 114Ch | ADDR | Self Address Register | · | Go | | | 1160h | CLKDIV2 | Clock Divider | | Go | | Complex bit access types are encoded to fit into small table cells. Table 14-13 shows the codes that are used for access types in this section. Table 14-13. UART Access Type Codes | , po | | | | | | | |------------------------|-----------|----------------------------------------|--|--|--|--| | Access Type | Code | Description | | | | | | Read Type | Read Type | | | | | | | R | R | Read | | | | | | Write Type | | | | | | | | W | W | Write | | | | | | WK | W<br>K | Write<br>Write protected by a key | | | | | | Reset or Default Value | | | | | | | | -n | | Value after reset or the default value | | | | | # 14.3.1 PWREN (Offset = 800h) [Reset = 00000000h] PWREN is shown in Figure 14-13 and described in Table 14-14. Return to the Summary Table. Register to control the power state # Figure 14-13. PWREN # **Table 14-14. PWREN Field Descriptions** | Bit | Field | Туре | Reset | Description | | |-------|----------|------|-------|----------------------------------------------------------------------------------------------------|--| | 31-24 | KEY | W | 0h | KEY to allow Power State Change<br>26h = KEY to allow write access to this register | | | 23-1 | RESERVED | R/W | 0h | | | | 0 | ENABLE | R/WK | 0h | Enable the power KEY must be set to 26h to write to this bit. 0h = Disable Power 1h = Enable Power | | # 14.3.2 RSTCTL (Offset = 804h) [Reset = 00000000h] RSTCTL is shown in Figure 14-14 and described in Table 14-15. Return to the Summary Table. Register to control reset assertion and de-assertion # Figure 14-14. RSTCTL **Table 14-15. RSTCTL Field Descriptions** | Bit | Field | Туре | Reset | Description | |-------|--------------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------| | 31-24 | KEY | W | 0h | Unlock key B1h = KEY to allow write access to this register | | 23-2 | RESERVED | W | 0h | | | 1 | RESETSTKYCLR | WK | 0h | Clear the RESETSTKY bit in the STAT register KEY must be set to B1h to write to this bit. 0h = Writing 0 has no effect 1h = Clear reset sticky bit | | 0 | RESETASSERT | WK | 0h | Assert reset to the peripheral KEY must be set to B1h to write to this bit. 0h = Writing 0 has no effect 1h = Assert reset | # 14.3.3 CLKCFG (Offset = 808h) [Reset = 00000000h] CLKCFG is shown in Figure 14-15 and described in Table 14-16. Return to the Summary Table. Peripheral Clock Configuration Register # Figure 14-15. CLKCFG # **Table 14-16. CLKCFG Field Descriptions** | Bit | Field | Туре | Reset | Description | | |-------|------------|------|-------|-------------------------------------------------------------------------------------------------|--| | 31-24 | KEY | W | 0h | KEY to Allow State Change 0xA9<br>A9h = 0xA9 | | | 23-9 | RESERVED | R/W | 0h | | | | 8 | BLOCKASYNC | R/W | 0h | Async Clock Request is blocked from starting SYSOSC or forcing bus clock to 32MHz 0h = 0 1h = 1 | | | 7-0 | RESERVED | R/W | 0h | | | # 14.3.4 STAT (Offset = 814h) [Reset = 00000000h] STAT is shown in Figure 14-16 and described in Table 14-17. Return to the Summary Table. Reset status register Figure 14-16. STAT # **Table 14-17. STAT Field Descriptions** | Bit | Field | Туре | Reset | Description | |-------|-----------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-17 | RESERVED | R | 0h | | | 16 | RESETSTKY | R | 0h | This bit indicates, if the peripheral was reset, since this bit was cleared by RESETSTKYCLR in the RSTCTL register 0h = The peripheral has not been reset since this bit was last cleared by RESETSTKYCLR in the RSTCTL register 1h = The peripheral was reset since the last bit clear | | 15-0 | RESERVED | R | 0h | | # 14.3.5 CLKDIV (Offset = 1000h) [Reset = 00000000h] CLKDIV is shown in Figure 14-17 and described in Table 14-18. Return to the Summary Table. This register is used to specify module-specific divide ratio of the functional clock # Figure 14-17. CLKDIV ### Table 14-18. CLKDIV Field Descriptions | | 1440 1 1 101 0 <u>2 1 2 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 </u> | | | | | | | | |------|--------------------------------------------------------------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | | 31-3 | RESERVED | R/W | 0h | | | | | | | 2-0 | RATIO | R/W | Oh | Selects divide ratio of module clock 0h = Do not divide clock source 1h = Divide clock source by 2 2h = Divide clock source by 3 3h = Divide clock source by 4 4h = Divide clock source by 5 5h = Divide clock source by 6 6h = Divide clock source by 7 7h = Divide clock source by 8 | | | | | # 14.3.6 CLKSEL (Offset = 1008h) [Reset = 00000000h] CLKSEL is shown in Figure 14-18 and described in Table 14-19. Return to the Summary Table. Clock source selection for peripherals # Figure 14-18. CLKSEL # **Table 14-19. CLKSEL Field Descriptions** | Bit | Field | Туре | Reset | Description | |------|------------|------|-------|-----------------------------------------------------------------------------------------------------------------------------| | 31-4 | RESERVED | R/W | 0h | | | 3 | BUSCLK_SEL | R/W | Oh | Selects BUS CLK as clock source if enabled 0h = Does not select this clock as a source 1h = Select this clock as a source | | 2 | MFCLK_SEL | R/W | Oh | Selects MFCLK as clock source if enabled 0h = Does not select this clock as a source 1h = Select this clock as a source | | 1 | LFCLK_SEL | R/W | Oh | Selects LFCLK as clock source if enabled 0h = Does not select this clock as a source 1h = Select this clock as a source | | 0 | RESERVED | R/W | 0h | | # 14.3.7 PDBGCTL (Offset = 1018h) [Reset = 00000003h] PDBGCTL is shown in Figure 14-19 and described in Table 14-20. Return to the Summary Table. This register can be used by the software developer to control the behavior of the peripheral relative to the 'Core Halted' input Figure 14-19. PDBGCTL #### **Table 14-20. PDBGCTL Field Descriptions** | | 140.0 1 1 2011 2200 12 1 1014 2000 1 1 1014 | | | | | | | | |---|---------------------------------------------|----------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | E | 3it | Field | Туре | Reset | Description | | | | | 3 | 1-2 | RESERVED | R/W | 0h | | | | | | | 1 | SOFT | R/W | 1h | Soft halt boundary control. This function is only available, if FREE is set to 'STOP' 0h = The peripheral will halt immediately, even if the resultant state will result in corruption if the system is restarted 1h = The peripheral blocks the debug freeze until it has reached a boundary where it can resume without corruption | | | | | | 0 | FREE | R/W | 1h | Free run control 0h = The peripheral freezes functionality while the Core Halted input is asserted and resumes when it is deasserted. 1h = The peripheral ignores the state of the Core Halted input | | | | # 14.3.8 IIDX (Offset = 1020h) [Reset = 00000000h] IIDX is shown in Figure 14-20 and described in Table 14-21. Return to the Summary Table. This register provides the highest priority enabled interrupt index. Value 0x00 means no event pending. Interrupt 1 is the highest priority, IIDX next highest, 4, 8, ... IIDX^31 is the least priority. That is, the least bit position that is set to 1 denotes the highest priority pending interrupt. The priority order is fixed. However, users can implement their own prioritization schemes using other registers that expose the full set of interrupts that have occurred. On each read, only one interrupt is indicated. On a read, the current interrupt (highest priority) is automatically cleared by the hardware and the corresponding interrupt flag in [RIS] and [MIS] are cleared as well. After a read from the CPU (not from the debug interface), the register is updated with the next highest priority interrupt, if none are pending, then it should display 0x0. ### Figure 14-20. IIDX ### Table 14-21. IIDX Field Descriptions | Table 14-21. IIDA 1 leiu Descriptions | | | | | | | |---------------------------------------|----------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Bit | Field | Туре | Reset | Description | | | | 31-8 | RESERVED | R | 0h | | | | | 7-0 | STAT | R | Oh | UART Module Interrupt Vector Value. This register provides the highest priority interrupt index. A read clears the corresponding interrupt flag in RIS and MIS registers. 15h-1Fh = Reserved 00h = No interrupt pending 01h = UART receive time-out interrupt; Interrupt Flag: RT; Interrupt Priority: Highest 02h = UART framing error interrupt; Interrupt Flag: FE 03h = UART parity error interrupt; Interrupt Flag: PE 04h = UART break error interrupt; Interrupt Flag: BE 05h = UART receive overrun error interrupt; Interrupt Flag: OE 06h = Negative edge on UARTxRXD interrupt; Interrupt Flag: RXNE 07h = Positive edge on UARTxRXD interrupt; Interrupt Flag: RXPE 08h = LIN capture 0 / match interrupt; Interrupt Flag: LINC0 09h = LIN capture 1 interrupt; Interrupt Flag: LINC1 0Ah = LIN hardware counter overflow interrupt; Interrupt Flag: LINOVF 08h = UART receive interrupt; Interrupt Flag: RX 0Ch = UART transmit interrupt; Interrupt Flag: TX 0Dh = UART end of transmission interrupt (transmit serializer empty); Interrupt Flag: EOT 0Eh = 9-bit mode address match interrupt; Interrupt Flag: MODE_9B Fh = UART Clear to Send Modem interrupt; Interrupt Flag: CTS 10h = DMA DONE on RX 11h = DMA DONE on TX 12h = Noise Error Event | | | # 14.3.9 IMASK (Offset = 1028h) [Reset = 00000000h] IMASK is shown in Figure 14-21 and described in Table 14-22. Return to the Summary Table. Interrupt Mask. If a bit is set, then corresponding interrupt is unmasked. Unmasking the interrupt causes the raw interrupt to be visible in IIDX, as well as MIS. Figure 14-21. IMASK | rigate 14-21. IMAON | | | | | | | | | | | |---------------------|----------|------------|--------|--------|--------|--------|--------|--|--|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | | RESERVED | | | | | | | | | | | | R/W-0h | | | | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | | RESERVED | | | | | | | | | | | | | R/W | ′-0h | | | R/W-0h | R/W-0h | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | DMA_DONE_R<br>X | CTS | ADDR_MATCH | EOT | TXINT | RXINT | LINOVF | LINC1 | | | | | R/W-0h | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | LINC0 | RXPE | RXNE | OVRERR | BRKERR | PARERR | FRMERR | RTOUT | | | | | R/W-0h | | | # **Table 14-22. IMASK Field Descriptions** | Bit | Field | Туре | Reset | Description | | | | |-------|-------------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | 31-18 | RESERVED | R/W | 0h | | | | | | 17 | NERR | R/W | 0h | Noise Error on triple voting. Asserted when the 3 samples of majorit voting are not equal 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | | | 16 | DMA_DONE_TX | R/W | 0h | Enable DMA Done on TX Event Channel Interrupt 0h = Interrupt disabled 1h = Set Interrupt Mask | | | | | 15 | DMA_DONE_RX | R/W | 0h | Enable DMA Done on RX Event Channel Interrupt 0h = Interrupt disabled 1h = Set Interrupt Mask | | | | | 14 | CTS | R/W | 0h | Enable UART Clear to Send Modem Interrupt. Oh = Interrupt disabled 1h = Set Interrupt Mask | | | | | 13 | ADDR_MATCH | R/W | 0h | Enable Address Match Interrupt. 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | | | 12 | ЕОТ | R/W | Oh | Enable UART End of Transmission Interrupt Indicates that the last bit of all transmitted data and flags has left the serializer and without any further Data in the TX FIFO or Buffer. 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | | | 11 | TXINT | R/W | 0h | Enable UART Transmit Interrupt. 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | | | 10 | RXINT | R/W | 0h | Enable UART Receive Interrupt. 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | | # **Table 14-22. IMASK Field Descriptions (continued)** | Bit | Field | Type | Reset | Description (continued) | |-----|--------|------|-------|-----------------------------------------------------------------------------------------------------| | 9 | LINOVF | R/W | Oh | Enable LIN Hardware Counter Overflow Interrupt. Oh = Clear Interrupt Mask 1h = Set Interrupt Mask | | 8 | LINC1 | R/W | Oh | Enable LIN Capture 1 Interrupt. 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | 7 | LINC0 | R/W | 0h | Enable LIN Capture 0 / Match Interrupt . 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | 6 | RXPE | R/W | Oh | Enable Positive Edge on UARTxRXD Interrupt. 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | 5 | RXNE | R/W | Oh | Enable Negative Edge on UARTxRXD Interrupt. 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | 4 | OVRERR | R/W | 0h | Enable UART Receive Overrun Error Interrupt. 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | 3 | BRKERR | R/W | Oh | Enable UART Break Error Interrupt. 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | 2 | PARERR | R/W | Oh | Enable UART Parity Error Interrupt. 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | 1 | FRMERR | R/W | Oh | Enable UART Framing Error Interrupt. 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | 0 | RTOUT | R/W | Oh | Enable UARTOUT Receive Time-Out Interrupt. 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | # 14.3.10 RIS (Offset = 1030h) [Reset = 00000000h] RIS is shown in Figure 14-22 and described in Table 14-23. Return to the Summary Table. Raw interrupt status. Reflects all pending interrupts, regardless of masking. The RIS register allows the user to implement a poll scheme. A flag set in this register can be cleared by writing 1 to the ICLR register bit even if the corresponding IMASK bit is not enabled. Figure 14-22. RIS | 1 19410 14 22.1110 | | | | | | | | | | | | |--------------------|----------|------------|----------|-----------------|--------|--------|-------|--|--|--|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | | | RESERVED | | | | | | | | | | | | | R- | | | | | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | | | | | NERR | DMA_DONE_T<br>X | | | | | | | | | | | R | <u>-</u> | | | R-0h | R-0h | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | DMA_DONE_R<br>X | CTS | ADDR_MATCH | EOT | TXINT | RXINT | LINOVF | LINC1 | | | | | | R-0h | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | LINC0 | RXPE | RXNE | OVRERR | BRKERR | PARERR | FRMERR | RTOUT | | | | | | R-0h | | | | ### Table 14-23. RIS Field Descriptions | Table 14-23. No Tield Descriptions | | | | | | | | |------------------------------------|-------------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | 31-18 | RESERVED | R | 0h | | | | | | 17 | NERR | R | Oh | Noise Error on triple voting. Asserted when the 3 samples of majority voting are not equal 0h = Interrupt did not occur 1h = Interrupt occurred | | | | | 16 | DMA_DONE_TX | R | 0h | DMA Done on TX Event Channel Interrupt Oh = Interrupt disabled 1h = Interrupt occurred | | | | | 15 | DMA_DONE_RX | R | 0h | DMA Done on RX Event Channel Interrupt 0h = Interrupt disabled 1h = Interrupt occurred | | | | | 14 | CTS | R | 0h | UART Clear to Send Modem Interrupt. 0h = Interrupt disabled 1h = Interrupt occurred | | | | | 13 | ADDR_MATCH | R | 0h | Address Match Interrupt. Oh = Interrupt did not occur 1h = Interrupt occurred | | | | | 12 | ЕОТ | R | 0h | UART End of Transmission Interrupt Indicates that the last bit of all transmitted data and flags has left the serializer and without any further Data in the TX FIFO or Buffer. Oh = Interrupt did not occur 1h = Interrupt occurred | | | | | 11 | TXINT | R | 0h | UART Transmit Interrupt. 0h = Interrupt did not occur 1h = Interrupt occurred | | | | | 10 | RXINT | R | 0h | UART Receive Interrupt. 0h = Interrupt did not occur 1h = Interrupt occurred | | | | # **Table 14-23. RIS Field Descriptions (continued)** | Bit | Field | | Reset | Description Description | |-----|--------|------|-------|-------------------------------------------------------------------------------------------------| | | | Туре | | · | | 9 | LINOVF | R | Oh | LIN Hardware Counter Overflow Interrupt. 0h = Interrupt did not occur 1h = Interrupt occurred | | 8 | LINC1 | R | 0h | LIN Capture 1 Interrupt. 0h = Interrupt did not occur 1h = Interrupt occurred | | 7 | LINC0 | R | Oh | LIN Capture 0 / Match Interrupt . 0h = Interrupt did not occur 1h = Interrupt occurred | | 6 | RXPE | R | 0h | Positive Edge on UARTxRXD Interrupt. 0h = Interrupt did not occur 1h = Interrupt occurred | | 5 | RXNE | R | 0h | Negative Edge on UARTxRXD Interrupt. 0h = Interrupt did not occur 1h = Interrupt occurred | | 4 | OVRERR | R | 0h | UART Receive Overrun Error Interrupt. 0h = Interrupt did not occur 1h = Interrupt occurred | | 3 | BRKERR | R | 0h | UART Break Error Interrupt. 0h = Interrupt did not occur 1h = Interrupt occurred | | 2 | PARERR | R | 0h | UART Parity Error Interrupt. 0h = Interrupt did not occur 1h = Interrupt occurred | | 1 | FRMERR | R | Oh | UART Framing Error Interrupt. 0h = Interrupt did not occur 1h = Interrupt occurred | | 0 | RTOUT | R | Oh | UARTOUT Receive Time-Out Interrupt. 0h = Interrupt did not occur 1h = Interrupt occurred | # 14.3.11 MIS (Offset = 1038h) [Reset = 00000000h] MIS is shown in Figure 14-23 and described in Table 14-24. Return to the Summary Table. Masked interrupt status. This is an AND of the IMASK and RIS registers. # Figure 14-23. MIS | | | | rigule i | 4-23. IVIIS | | | | | | |-----------------|--------------------------|------------|----------|-------------|--------|--------|-------|--|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | RESERVED | | | | | | | | | | | R-0h | | | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | RESERVED NERR DMA_DONE_X | | | | | | | | | | R-0h R-0h | | | | | | R-0h | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | DMA_DONE_R<br>X | CTS | ADDR_MATCH | EOT | TXINT | RXINT | LINOVF | LINC1 | | | | R-0h | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | LINC0 | RXPE | RXNE | OVRERR | BRKERR | PARERR | FRMERR | RTOUT | | | | R-0h | | ### **Table 14-24. MIS Field Descriptions** | | | | 0 1 1 2 11 11110 | i leid Descriptions | | | |-------|-------------|------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Bit | Field | Туре | Reset | Description | | | | 31-18 | RESERVED | R | 0h | | | | | 17 | NERR | R | Oh | Noise Error on triple voting. Asserted when the 3 samples of majority voting are not equal 0h = Interrupt did not occur 1h = Interrupt occurred | | | | 16 | DMA_DONE_TX | R | 0h | Masked DMA Done on TX Event Channel Interrupt 0h = Interrupt did not occur 1h = Interrupt occurred | | | | 15 | DMA_DONE_RX | R | 0h | Masked DMA Done on RX Event Channel Interrupt 0h = Interrupt did not occur 1h = Interrupt occurred | | | | 14 | CTS | R | 0h | Masked UART Clear to Send Modem Interrupt. 0h = Interrupt did not occur 1h = Interrupt occurred | | | | 13 | ADDR_MATCH | R | Oh | Masked Address Match Interrupt. 0h = Interrupt did not occur 1h = Interrupt occurred | | | | 12 | EOT | R | Oh | UART End of Transmission Interrupt Indicates that the last bit of all transmitted data and flags has left the serializer and without any further Data in the TX FIFO or Buffer. 0h = Interrupt did not occur 1h = Interrupt occurred | | | | 11 | TXINT | R | 0h | Masked UART Transmit Interrupt. 0h = Interrupt did not occur 1h = Interrupt occurred | | | | 10 | RXINT | R | 0h | Masked UART Receive Interrupt. 0h = Interrupt did not occur 1h = Interrupt occurred | | | | 9 | LINOVF | R | Oh | Masked LIN Hardware Counter Overflow Interrupt. 0h = Interrupt did not occur 1h = Interrupt occurred | | | # **Table 14-24. MIS Field Descriptions (continued)** | | Table 14-24. MIS Fleid Descriptions (Continued) | | | | | | | | | |-----|-------------------------------------------------|------|-------|-----------------------------------------------------------------------------------------------------|--|--|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | | | 8 | LINC1 | R | 0h | Masked LIN Capture 1 Interrupt. Oh = Interrupt did not occur 1h = Interrupt occurred | | | | | | | 7 | LINC0 | R | 0h | Masked LIN Capture 0 / Match Interrupt . 0h = Interrupt did not occur 1h = Interrupt occurred | | | | | | | 6 | RXPE | R | 0h | Masked Positive Edge on UARTxRXD Interrupt. Oh = Interrupt did not occur 1h = Interrupt occurred | | | | | | | 5 | RXNE | R | 0h | Masked Negative Edge on UARTxRXD Interrupt. Oh = Interrupt did not occur 1h = Interrupt occurred | | | | | | | 4 | OVRERR | R | 0h | Masked UART Receive Overrun Error Interrupt. 0h = Interrupt did not occur 1h = Interrupt occurred | | | | | | | 3 | BRKERR | R | 0h | Masked UART Break Error Interrupt. Oh = Interrupt did not occur 1h = Interrupt occurred | | | | | | | 2 | PARERR | R | 0h | Masked UART Parity Error Interrupt. Oh = Interrupt did not occur 1h = Interrupt occurred | | | | | | | 1 | FRMERR | R | 0h | Masked UART Framing Error Interrupt. Oh = Interrupt did not occur 1h = Interrupt occurred | | | | | | | 0 | RTOUT | R | 0h | Masked UARTOUT Receive Time-Out Interrupt. 0h = Interrupt did not occur 1h = Interrupt occurred | | | | | | # 14.3.12 ISET (Offset = 1040h) [Reset = 00000000h] ISET is shown in Figure 14-24 and described in Table 14-25. Return to the Summary Table. Interrupt set. Allows interrupts to be set by software (useful in diagnostics and safety checks). Writing a 1 to a bit in ISET will set the event and therefore the related RIS bit also gets set. If the interrupt is enabled through the mask, then the corresponding MIS bit is also set. Figure 14-24. ISET | | | | i igaic i | | | | | | | |-----------------|--------------------------|------------|-----------|--------|--------|--------|-------|--|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | RESERVED | | | | | | | | | | | W-0h | | | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | RESERVED NERR DMA_DONE_X | | | | | | | | | | | W-0h | | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | DMA_DONE_R<br>X | CTS | ADDR_MATCH | EOT | TXINT | RXINT | LINOVF | LINC1 | | | | W-0h | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | LINC0 | RXPE | RXNE | OVRERR | BRKERR | PARERR | FRMERR | RTOUT | | | | W-0h | | # Table 14-25. ISET Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|-------------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-18 | RESERVED | W | 0h | | | 17 | NERR | W | 0h | Noise Error on triple voting. Asserted when the 3 samples of majority voting are not equal 0h = Writing this has no effect 1h = Set the interrupt | | 16 | DMA_DONE_TX | W | Oh | Set DMA Done on TX Event Channel Interrupt 0h = Interrupt disabled 1h = Set Interrupt | | 15 | DMA_DONE_RX | W | 0h | Set DMA Done on RX Event Channel Interrupt 0h = Interrupt disabled 1h = Set Interrupt | | 14 | CTS | W | 0h | Set UART Clear to Send Modem Interrupt. 0h = Writing 0 has no effect 1h = Set Interrupt | | 13 | ADDR_MATCH | W | Oh | Set Address Match Interrupt. 0h = Writing 0 has no effect 1h = Set Interrupt | | 12 | ЕОТ | W | Oh | Set UART End of Transmission Interrupt Indicates that the last bit of all transmitted data and flags has left the serializer and without any further Data in the TX FIFO or Buffer. 0h = Writing 0 has no effect 1h = Set Interrupt | | 11 | TXINT | W | Oh | Set UART Transmit Interrupt. 0h = Writing 0 has no effect 1h = Set Interrupt | | 10 | RXINT | W | 0h | Set UART Receive Interrupt. 0h = Writing 0 has no effect 1h = Set Interrupt | # **Table 14-25. ISET Field Descriptions (continued)** | Table 14-25. ISET Field Descriptions (Continued) | | | | | | | | | |--------------------------------------------------|--------|------|-------|------------------------------------------------------------------------------------------------|--|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | | 9 | LINOVF | W | 0h | Set LIN Hardware Counter Overflow Interrupt. 0h = Writing 0 has no effect 1h = Set Interrupt | | | | | | 8 | LINC1 | W | 0h | Set LIN Capture 1 Interrupt. 0h = Writing 0 has no effect 1h = Set Interrupt | | | | | | 7 | LINC0 | W | 0h | Set LIN Capture 0 / Match Interrupt . 0h = Writing 0 has no effect 1h = Set Interrupt | | | | | | 6 | RXPE | W | 0h | Set Positive Edge on UARTxRXD Interrupt. 0h = Writing 0 has no effect 1h = Set Interrupt | | | | | | 5 | RXNE | W | 0h | Set Negative Edge on UARTxRXD Interrupt. 0h = Writing 0 has no effect 1h = Set Interrupt | | | | | | 4 | OVRERR | W | 0h | Set UART Receive Overrun Error Interrupt. 0h = Writing 0 has no effect 1h = Set Interrupt | | | | | | 3 | BRKERR | W | Oh | Set UART Break Error Interrupt. 0h = Writing 0 has no effect 1h = Set Interrupt | | | | | | 2 | PARERR | W | 0h | Set UART Parity Error Interrupt. 0h = Writing 0 has no effect 1h = Set Interrupt | | | | | | 1 | FRMERR | W | Oh | Set UART Framing Error Interrupt. 0h = Writing 0 has no effect 1h = Set Interrupt | | | | | | 0 | RTOUT | W | 0h | Set UARTOUT Receive Time-Out Interrupt. 0h = Writing 0 has no effect 1h = Set Interrupt | | | | | # 14.3.13 ICLR (Offset = 1048h) [Reset = 00000000h] ICLR is shown in Figure 14-25 and described in Table 14-26. Return to the Summary Table. Interrupt clear. Write a 1 to clear corresponding Interrupt. # Figure 14-25. ICLR | | | | 9 a. o | LO. IOLIX | | | | | | |-----------------|----------|------------|------------|-----------|--------|--------|-------|--|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | RESERVED | | | | | | | | | | | W-0h | | | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | | NERR | DMA_DONE_T | | | | | | | | | | W-( | Oh | | | W-0h | W-0h | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | DMA_DONE_R<br>X | CTS | ADDR_MATCH | EOT | TXINT | RXINT | LINOVF | LINC1 | | | | W-0h | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | LINC0 | RXPE | RXNE | OVRERR | BRKERR | PARERR | FRMERR | RTOUT | | | | W-0h | | # **Table 14-26. ICLR Field Descriptions** | Bit Field Type Reset [ | | | | · · · · · · · · · · · · · · · · · · · | | | |------------------------|-------------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Віт | Field | Type | Reset | Description | | | | 31-18 | RESERVED | W | 0h | | | | | 17 | NERR | W | 0h | Noise Error on triple voting. Asserted when the 3 samples of majority voting are not equal 0h = Writing 0 has no effect 1h = Clear Interrupt | | | | 16 | DMA_DONE_TX | W | 0h | Clear DMA Done on TX Event Channel Interrupt 0h = Interrupt disabled 1h = Clear Interrupt | | | | 15 | DMA_DONE_RX | W | 0h | Clear DMA Done on RX Event Channel Interrupt 0h = Interrupt disabled 1h = Clear Interrupt | | | | 14 | CTS | W | 0h | Clear UART Clear to Send Modem Interrupt. 0h = Writing 0 has no effect 1h = Clear Interrupt | | | | 13 | ADDR_MATCH | W | 0h | Clear Address Match Interrupt. 0h = Writing 0 has no effect 1h = Clear Interrupt | | | | 12 | EOT | W | Oh | Clear UART End of Transmission Interrupt Indicates that the last bit of all transmitted data and flags has left the serializer and without any further Data in the TX FIFO or Buffer. Oh = Writing 0 has no effect 1h = Clear Interrupt | | | | 11 | TXINT | W | 0h | Clear UART Transmit Interrupt. 0h = Writing 0 has no effect 1h = Clear Interrupt | | | | 10 | RXINT | W | 0h | Clear UART Receive Interrupt. 0h = Writing 0 has no effect 1h = Clear Interrupt | | | | 9 | LINOVF | W | 0h | Clear LIN Hardware Counter Overflow Interrupt. 0h = Writing 0 has no effect 1h = Clear Interrupt | | | # **Table 14-26. ICLR Field Descriptions (continued)** | Table 14-20. IOLN Field Descriptions (Continued) | | | | | | | | |--------------------------------------------------|--------|------|-------|-----------------------------------------------------------------------------------------------|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | 8 | LINC1 | W | 0h | Clear LIN Capture 1 Interrupt. 0h = Writing 0 has no effect 1h = Clear Interrupt | | | | | 7 | LINC0 | W | 0h | Clear LIN Capture 0 / Match Interrupt . 0h = Writing 0 has no effect 1h = Clear Interrupt | | | | | 6 | RXPE | W | 0h | Clear Positive Edge on UARTxRXD Interrupt. 0h = Writing 0 has no effect 1h = Clear Interrupt | | | | | 5 | RXNE | W | 0h | Clear Negative Edge on UARTxRXD Interrupt. 0h = Writing 0 has no effect 1h = Clear Interrupt | | | | | 4 | OVRERR | W | 0h | Clear UART Receive Overrun Error Interrupt. 0h = Writing 0 has no effect 1h = Clear Interrupt | | | | | 3 | BRKERR | W | 0h | Clear UART Break Error Interrupt. 0h = Writing 0 has no effect 1h = Clear Interrupt | | | | | 2 | PARERR | W | 0h | Clear UART Parity Error Interrupt. 0h = Writing 0 has no effect 1h = Clear Interrupt | | | | | 1 | FRMERR | W | 0h | Clear UART Framing Error Interrupt. 0h = Writing 0 has no effect 1h = Clear Interrupt | | | | | 0 | RTOUT | W | 0h | Clear UARTOUT Receive Time-Out Interrupt. 0h = Writing 0 has no effect 1h = Clear Interrupt | | | | # 14.3.14 IIDX (Offset = 1050h) [Reset = 00000000h] IIDX is shown in Figure 14-26 and described in Table 14-27. Return to the Summary Table. This register provides the highest priority enabled interrupt index. Value 0x00 means no event pending. Interrupt 1 is the highest priority, IIDX next highest, 4, 8, ... IIDX^31 is the least priority. That is, the least bit position that is set to 1 denotes the highest priority pending interrupt. The priority order is fixed. However, users can implement their own prioritization schemes using other registers that expose the full set of interrupts that have occurred. On each read, only one interrupt is indicated. On a read, the current interrupt (highest priority) is automatically cleared by the hardware and the corresponding interrupt flag in [RIS] and [MIS] are cleared as well. After a read from the CPU (not from the debug interface), the register is updated with the next highest priority interrupt, if none are pending, then it should display 0x0. ### Figure 14-26. IIDX ### Table 14-27. IIDX Field Descriptions | Bit | Field | Туре | Reset | Description | | | |------|----------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | 31-8 | RESERVED | R | 0h | | | | | 7-0 | STAT | R | 0h | UART Module Interrupt Vector Value. This register provides the highest priority interrupt index. A read clears the corresponding interrupt flag in UARTRIS and UARTMISC. 15h-1Fh = Reserved 00h = No interrupt pending 01h = UART receive time-out interrupt; Interrupt Flag: RT; Interrupt Priority: Highest 08h = UART receive interrupt; Interrupt Flag: RX | | | # 14.3.15 IMASK (Offset = 1058h) [Reset = 00000000h] IMASK is shown in Figure 14-27 and described in Table 14-28. Return to the Summary Table. Interrupt Mask. If a bit is set, then corresponding interrupt is unmasked. Unmasking the interrupt causes the raw interrupt to be visible in IIDX, as well as MIS. Figure 14-27. IMASK # Table 14-28. IMASK Field Descriptions | Tubic 14 20: IIIIAGIT I Icia Besoniptions | | | | | | | | | |-------------------------------------------|----------|------|-------|------------------------------------------------------------------------------------------------|--|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | | 31-11 | RESERVED | R/W | 0h | | | | | | | 10 | RXINT | R/W | 0h | Enable UART Receive Interrupt. 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | | | | 9-1 | RESERVED | R/W | 0h | | | | | | | 0 | RTOUT | R/W | 0h | Enable UARTOUT Receive Time-Out Interrupt. Oh = Clear Interrupt Mask 1h = Set Interrupt Mask | | | | | # 14.3.16 RIS (Offset = 1060h) [Reset = 00000000h] RIS is shown in Figure 14-28 and described in Table 14-29. Return to the Summary Table. Raw interrupt status. Reflects all pending interrupts, regardless of masking. The RIS register allows the user to implement a poll scheme. A flag set in this register can be cleared by writing 1 to the ICLR register bit even if the corresponding IMASK bit is not enabled. Figure 14-28. RIS #### Table 14-29. RIS Field Descriptions | | <b>-</b> | | | | | | |-------|----------|------|-------|------------------------------------------------------------------------------------------|--|--| | Bit | Field | Туре | Reset | Description | | | | 31-11 | RESERVED | R | 0h | | | | | 10 | RXINT | R | Oh | UART Receive Interrupt. 0h = Interrupt did not occur 1h = Interrupt occurred | | | | 9-1 | RESERVED | R | 0h | | | | | 0 | RTOUT | R | Oh | UARTOUT Receive Time-Out Interrupt. 0h = Interrupt did not occur 1h = Interrupt occurred | | | # 14.3.17 MIS (Offset = 1068h) [Reset = 00000000h] MIS is shown in Figure 14-29 and described in Table 14-30. Return to the Summary Table. Masked interrupt status. This is an AND of the IMASK and RIS registers. # Figure 14-29. MIS | | | | ga.o . | | | | | | |-------------------------|----------|----|--------|------|----|------|-------|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | RESERVED | | | | | | | | | R-0h | | | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | | RESE | RVED | | | | | | R-0h | | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | RESERVED RXINT RESERVED | | | | | | | RVED | | | R-0h R- | | | | | | R-0 | )h | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | RESERVED | | | | | | | RTOUT | | | R-0h | | | | | | R-0h | | | # **Table 14-30. MIS Field Descriptions** | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|-------------------------------------------------------------------------------------------------| | 31-11 | RESERVED | R | 0h | | | 10 | RXINT | R | Oh | Masked UART Receive Interrupt. 0h = Interrupt did not occur 1h = Interrupt occurred | | 9-1 | RESERVED | R | 0h | | | 0 | RTOUT | R | Oh | Masked UARTOUT Receive Time-Out Interrupt. 0h = Interrupt did not occur 1h = Interrupt occurred | # 14.3.18 ISET (Offset = 1070h) [Reset = 00000000h] ISET is shown in Figure 14-30 and described in Table 14-31. Return to the Summary Table. Interrupt set. Allows interrupts to be set by software (useful in diagnostics and safety checks). Writing a 1 to a bit in ISET will set the event and therefore the related RIS bit also gets set. If the interrupt is enabled through the mask, then the corresponding MIS bit is also set. Figure 14-30. ISET ### Table 14-31. ISET Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|-----------------------------------------------------------------------------------------| | 31-11 | RESERVED | W | 0h | | | 10 | RXINT | W | 0h | Set UART Receive Interrupt. 0h = Writing 0 has no effect 1h = Set Interrupt | | 9-1 | RESERVED | W | 0h | | | 0 | RTOUT | W | 0h | Set UARTOUT Receive Time-Out Interrupt. 0h = Writing 0 has no effect 1h = Set Interrupt | # 14.3.19 ICLR (Offset = 1078h) [Reset = 00000000h] ICLR is shown in Figure 14-31 and described in Table 14-32. Return to the Summary Table. Interrupt clear. Write a 1 to clear corresponding Interrupt. # Figure 14-31. ICLR | | | | 9 | • | | | | | |----------------------|----------|------|------|------|----|------|-------|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | RESERVED | | | | | | | | | W-0h | | | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | | RESE | RVED | | | | | | | W-0h | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | RESERVED RXINT RESER | | | | | | RVED | | | | | | W-0h | W-0h | VV-( | Oh | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | RESERVED | | | | | | | RTOUT | | | W-0h | | | | | | W-0h | | | # **Table 14-32. ICLR Field Descriptions** | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|----------------------------------------------------------------------------------------------| | 31-11 | RESERVED | W | 0h | | | 10 | RXINT | W | 0h | Clear UART Receive Interrupt. 0h = Writing 0 has no effect 1h = Clear Interrupt | | 9-1 | RESERVED | W | 0h | | | 0 | RTOUT | W | 0h | Clear UARTOUT Receive Time-Out Interrupt. 0h = Writing 0 has no effect 1h = Clear Interrupt | # 14.3.20 IIDX (Offset = 1080h) [Reset = 00000000h] IIDX is shown in Figure 14-32 and described in Table 14-33. Return to the Summary Table. This register provides the highest priority enabled interrupt index. Value 0x00 means no event pending. Interrupt 1 is the highest priority, IIDX next highest, 4, 8, ... IIDX^31 is the least priority. That is, the least bit position that is set to 1 denotes the highest priority pending interrupt. The priority order is fixed. However, users can implement their own prioritization schemes using other registers that expose the full set of interrupts that have occurred. On each read, only one interrupt is indicated. On a read, the current interrupt (highest priority) is automatically cleared by the hardware and the corresponding interrupt flag in [RIS] and [MIS] are cleared as well. After a read from the CPU (not from the debug interface), the register is updated with the next highest priority interrupt, if none are pending, then it should display 0x0. #### Figure 14-32. IIDX #### Table 14-33. IIDX Field Descriptions | Bit | Field | Туре | Reset | Description | | | | | |------|----------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | 31-8 | RESERVED | R | 0h | | | | | | | 7-0 | STAT | R | | UART Module Interrupt Vector Value. This register provides the highest priority interrupt index. A read clears the corresponding interrupt flag in UARTRIS and UARTMISC. 15h-1Fh = Reserved 00h = No interrupt pending 0Ch = UART transmit interrupt; Interrupt Flag: TX | | | | | # 14.3.21 IMASK (Offset = 1088h) [Reset = 00000000h] IMASK is shown in Figure 14-33 and described in Table 14-34. Return to the Summary Table. Interrupt Mask. If a bit is set, then corresponding interrupt is unmasked. Unmasking the interrupt causes the raw interrupt to be visible in IIDX, as well as MIS. Figure 14-33. IMASK #### **Table 14-34. IMASK Field Descriptions** | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|-------------------------------------------------------------------------------------| | 31-12 | RESERVED | R/W | 0h | | | 11 | TXINT | R/W | Oh | Enable UART Transmit Interrupt. 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | 10-0 | RESERVED | R/W | 0h | | # 14.3.22 RIS (Offset = 1090h) [Reset = 00000000h] RIS is shown in Figure 14-34 and described in Table 14-35. Return to the Summary Table. Raw interrupt status. Reflects all pending interrupts, regardless of masking. The RIS register allows the user to implement a poll scheme. A flag set in this register can be cleared by writing 1 to the ICLR register bit even if the corresponding IMASK bit is not enabled. Figure 14-34. RIS #### **Table 14-35. RIS Field Descriptions** | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|-------------------------------------------------------------------------------| | 31-12 | RESERVED | R | 0h | | | 11 | TXINT | R | 0h | UART Transmit Interrupt. 0h = Interrupt did not occur 1h = Interrupt occurred | | 10-0 | RESERVED | R | 0h | | # 14.3.23 MIS (Offset = 1098h) [Reset = 00000000h] MIS is shown in Figure 14-35 and described in Table 14-36. Return to the Summary Table. Masked interrupt status. This is an AND of the IMASK and RIS registers. # Figure 14-35. MIS | | | | 9 | | | | | | |----|----------|------|------|-------|----|----------|----|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | | RESE | RVED | | | | | | | R-0h | | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | | RESE | RVED | | | | | | | R-0h | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | RESE | RVED | | TXINT | | RESERVED | | | | | R- | 0h | | R-0h | | R-0h | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | RESERVED | | | | | | | | | | | | R- | 0h | | | | | | | | | | | | | | | # Table 14-36. MIS Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|----------------------------------------------------------------------------------------| | 31-12 | RESERVED | R | 0h | | | 11 | TXINT | R | 0h | Masked UART Transmit Interrupt. 0h = Interrupt did not occur 1h = Interrupt occurred | | 10-0 | RESERVED | R | 0h | | # 14.3.24 ISET (Offset = 10A0h) [Reset = 00000000h] ISET is shown in Figure 14-36 and described in Table 14-37. Return to the Summary Table. Interrupt set. Allows interrupts to be set by software (useful in diagnostics and safety checks). Writing a 1 to a bit in ISET will set the event and therefore the related RIS bit also gets set. If the interrupt is enabled through the mask, then the corresponding MIS bit is also set. Figure 14-36. ISET #### Table 14-37. ISET Field Descriptions | | Bit | Field | Туре | Reset | Description | |---|-------|----------|------|-------|------------------------------------------------------------------------------| | | 31-12 | RESERVED | W | 0h | | | | 11 | TXINT | W | | Set UART Transmit Interrupt. 0h = Writing 0 has no effect 1h = Set Interrupt | | Ī | 10-0 | RESERVED | W | 0h | | # 14.3.25 ICLR (Offset = 10A8h) [Reset = 00000000h] ICLR is shown in Figure 14-37 and described in Table 14-38. Return to the Summary Table. Interrupt clear. Write a 1 to clear corresponding Interrupt. # Figure 14-37. ICLR | | | | 9 | - | | | | |----|----------|------|------|-------|----|----------|----| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | RESE | RVED | | | | | | W-0h | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | RESE | RVED | | | | | | W-0h | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | RESE | RVED | | TXINT | | RESERVED | | | | W- | -0h | | W-0h | | W-0h | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | RESERVED | | | | | | | | | W-0h | | | | | | | | | | | | | | | | # Table 14-38. ICLR Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|----------------------------------------------------------------------------------| | 31-12 | RESERVED | W | 0h | | | 11 | TXINT | W | 0h | Clear UART Transmit Interrupt. 0h = Writing 0 has no effect 1h = Clear Interrupt | | 10-0 | RESERVED | W | 0h | | # 14.3.26 EVT\_MODE (Offset = 10E0h) [Reset = 00000029h] EVT\_MODE is shown in Figure 14-38 and described in Table 14-39. Return to the Summary Table. Event mode register. It is used to select whether each line is disabled, in software mode (software clears the RIS) or in hardware mode (hardware clears the RIS) Figure 14-38. EVT\_MODE # Table 14-39. EVT\_MODE Field Descriptions | Table 14 doi: Et 1_ineb_1 fold bedefiguette | | | | | | | | | |---------------------------------------------|----------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | | 31-6 | RESERVED | R/W | 0h | | | | | | | 5-4 | INT2_CFG | R | 2h | Event line mode select for event corresponding to none.INT_EVENT2 0h = The interrupt or event line is disabled. 1h = The interrupt or event line is in software mode. Software must clear the RIS. 2h = The interrupt or event line is in hardware mode. The hardware (another module) clears automatically the associated RIS flag. | | | | | | 3-2 | INT1_CFG | R | 2h | Event line mode select for event corresponding to none.INT_EVENT1 Oh = The interrupt or event line is disabled. 1h = The interrupt or event line is in software mode. Software must clear the RIS. 2h = The interrupt or event line is in hardware mode. The hardware (another module) clears automatically the associated RIS flag. | | | | | | 1-0 | INTO_CFG | R | 1h | Event line mode select for event corresponding to none.INT_EVENT0 0h = The interrupt or event line is disabled. 1h = The interrupt or event line is in software mode. Software must clear the RIS. 2h = The interrupt or event line is in hardware mode. The hardware (another module) clears automatically the associated RIS flag. | | | | | # 14.3.27 INTCTL (Offset = 10E4h) [Reset = 00000000h] INTCTL is shown in Figure 14-39 and described in Table 14-40. Return to the Summary Table. Interrupt control register # Figure 14-39. INTCTL # **Table 14-40. INTCTL Field Descriptions** | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-1 | RESERVED | R/W | 0h | | | 0 | INTEVAL | W | 0h | Writing a 1 to this field re-evaluates the interrupt sources. 0h = The interrupt or event line is disabled. 1h = The interrupt or event line is in software mode. Software must clear the RIS. | # 14.3.28 CTL0 (Offset = 1100h) [Reset = 00000038h] CTL0 is shown in Figure 14-40 and described in Table 14-41. Return to the Summary Table. #### **UART Control Register** The CTL0 register is the control register. All the bits are cleared on reset except for the Transmit Enable (TXE) and Receive Enable (RXE) bits, which are set. To enable the UART module, the UARTEN bit must be set. If software requires a configuration change in the module, the UARTEN bit must be cleared before the configuration changes are written. If the UART is disabled during a transmit or receive operation, the current transaction is completed prior to the UART stopping. NOTE: The CTL0 register should not be changed while the UART is enabled or else the results are unpredictable. The following sequence is recommended for making changes to the CTL0 register. - 1. Disable the UART. - 2. Wait for the end of transmission or reception of the current character. - 3. Flush the transmit FIFO by clearing bit FEN in the UART control register CTL0. - 4. Reprogram the control register. - 5. Enable the UART. Figure 14-40, CTL0 | rigure 14-40. OTEO | | | | | | | | | |--------------------|---------|------------|--------|----------|---------|----------|--------|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | | RESE | RVED | | | | | | | R/W-0h | | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | RESE | RVED | | MSBFIRST | MAJVOTE | FEN | HSE | | | | R/V | V-0h | | R/W-0h | R/W-0h | R/W-0h | R/W-0h | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | HSE | CTSEN | RTSEN | RTS | RESERVED | | MODE | | | | R/W-0h | R/W-0h | R/W-0h | R/W-0h | R/W-0h | | R/W-0h | | | | 7 6 5 4 | | | | 3 | 2 | 1 | 0 | | | MENC | TXD_OUT | TXD_OUT_EN | TXE | RXE | LBE | RESERVED | ENABLE | | | R/W-0h | R/W-0h | R/W-1h | R/W-1h | R/W-1h | R/W-0h | R/W-0h | R/W-0h | | #### Table 14-41. CTL0 Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-20 | RESERVED | R/W | 0h | | | 19 | MSBFIRST | R/W | Oh | Most Significant Bit First This bit has effect both on the way protocol byte is transmitted and received. Notes: User needs to match the protocol to the correct value of this bit to send MSb or LSb first. The hardware engine will send the byte entirely based on this bit. 0h = Least significant bit is sent first in the protocol packet 1h = Most significant bit is sent first in the protocol packet | | 18 | MAJVOTE | R/W | Oh | Majority Vote Enable When Majority Voting is enabled, the three center bits are used to determine received sample value. In case of error (all 3 bits are not the same), noise error is detected and bits RIS.NERR and register RXDATA.NERR are set. Oversampling of 16: bits 7, 8, 9 are used Oversampling of 8: bits 3, 4, 5 are used Disabled: Single sample value (center value) used 0h = Majority voting is disabled 1h = Majority voting is enabled | # Table 14-41. CTL0 Field Descriptions (continued) | Bit | Field | Type | Reset | Descriptions (continued) Description | | | |-------|------------|-------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | 17 | FEN | R/W | 0h | UART Enable FIFOs | | | | 17 | FEN | TV VV | OII | Oh = The FIFOs are disabled (Character mode). The FIFOs become 1-byte-deep holding registers. 1h = The transmit and receive FIFO buffers are enabled (FIFO mode). | | | | 16-15 | HSE | R/W | Oh | High-Speed Bit Oversampling Enable <b>NOTE</b> : The bit oversampling influences the UART baud-rate configuration. The state of this bit has no effect on clock generation in ISO7816 smart card mode (the SMART bit is set). 0h = 16x oversampling. 1h = 8x oversampling. 2h = 3x oversampling. IrDA, Manchester and DALI not supported when 3x oversampling is enabled. | | | | 14 | CTSEN | R/W | 0h | Enable Clear To Send 0h = CTS hardware flow control is disabled. 1h = CTS hardware flow control is enabled. Data is only transmitted when the UARTxCTS signal is asserted. | | | | 13 | RTSEN | R/W | Oh | Enable hardware controlled Request to Send 0h = RTS hardware flow control is disabled. 1h = RTS hardware flow control is enabled. Data is only requested (by asserting UARTxRTS) when the receive FIFO has available entries. | | | | 12 | RTS | R/W | 0h | Request to Send If RTSEN is set the RTS output signals is controlled by the hardware logic using the FIFO fill level or TXDATA buffer. If RTSEN is cleared the RTS output is controlled by the RTS bit. The bit is the complement of the UART request to send, RTS modem status output. 0h = Signal not RTS 1h = Signal RTS | | | | 11 | RESERVED | R/W | 0h | | | | | 10-8 | MODE | R/W | Oh | Set the communication mode and protocol used. (Not defined settings uses the default setting: 0) 0h = Normal operation 1h = RS485 mode: UART needs to be IDLE with receiving data for the in EXTDIR_HOLD set time. EXTDIR_SETUP defines the time the RTS line is set to high before sending. When the buffer is empty the RTS line is set low again. A transmit will be delayed as long the UART is receiving data. 2h = The UART operates in IDLE Line Mode 3h = The UART operates in 9 Bit Address mode 4h = ISO7816 Smart Card Support The application must ensure that it sets 8-bit word length (WLEN set to 3h) and even parity (PEN set to 1, EPS set to 1, SPS set to 0) in UARTLCRH when using ISO7816 mode. The value of the STP2 bit in UARTLCRH is ignored and the number of stop bits is forced to 2. 5h = DALI Mode: | | | | 7 | MENC | R/W | Oh | Manchester Encode enable 0h = Disable Manchester Encoding 1h = Enable Manchester Encoding | | | | 6 | TXD_OUT | R/W | 0h | TXD Pin Control Controls the TXD pin when TXD_OUT_EN = 1 and TXE = 0. 0h = TXD pin is low 1h = TXD pin is high | | | | 5 | TXD_OUT_EN | R/W | 1h | TXD Pin Control Enable. When the transmit section of the UART is disabled (TXE = 0), the TXD pin can be controlled by the TXD_OUT bit. 0h = TXD pin can not be controlled by TXD_OUT 1h = TXD pin can be controlled by TXD_OUT | | | # **Table 14-41. CTL0 Field Descriptions (continued)** | Bit | Field | Туре | Reset | Description | |-----|----------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 4 | TXE | R/W | 1h | UART Transmit Enable If the UART is disabled in the middle of a transmission, it completes the current character before stopping. NOTE: To enable transmission, the UARTEN bit must be set. 0h = The transmit section of the UART is disabled. The UARTXTXD pin of the UART can be controlled by the TXD_CTL bit when enabled. 1h = The transmit section of the UART is enabled. | | 3 | RXE | R/W | 1h | UART Receive Enable If the UART is disabled in the middle of a receive, it completes the current character before stopping. NOTE: To enable reception, the UARTEN bit must be set. 0h = The receive section of the UART is disabled. 1h = The receive section of the UART is enabled. | | 2 | LBE | R/W | 0h | UART Loop Back Enable 0h = Normal operation. 1h = The UARTxTX path is fed through the UARTxRX path internally. | | 1 | RESERVED | R/W | 0h | | | 0 | ENABLE | R/W | Oh | UART Module Enable. If the UART is disabled in the middle of transmission or reception, it completes the current character before stopping. If the ENABLE bit is not set, all registers can still be accessed and updated. It is recommended to setup and change the UART operation mode with having the ENABLE bit cleared to avoid unpredictable behavior during the setup or update. If disabled the UART module will not send or receive any data and the logic is held in reset state. Oh = Disable Module 1h = Enable module | # 14.3.29 LCRH (Offset = 1104h) [Reset = 00000000h] LCRH is shown in Figure 14-41 and described in Table 14-42. Return to the Summary Table. UART Line Control Register The LCRH register is the line control register. Serial parameters such as data length, parity, and stop bit selection are implemented in this register. When updating the baud-rate divisor (UARTIBRD or UARTIFRD), the LCRH register must also be written. The write strobe for the baud-rate divisor registers is tied to the LCRH register. Figure 14-41, LCRH | | | | ga.o . | 7 TI. EOIVII | | | | | | |----------|--------------------------|--------|-------------|--------------|--------|--------|--------|--|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | | EXTDIF | EXTDIR_HOLD | | | | | | | | | R/W-0h | | | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | EXTDIR_HOLD EXTDIR_SETUP | | | | | | | | | | | R/W-0h R/W-0h | | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | | RES | ERVED | | | | | | | | R/W-0h | | | | | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | SENDIDLE | SPS | WLEN | | STP2 | EPS | PEN | BRK | | | | R/W-0h | R/W-0h | R/W | /-0h | R/W-0h | R/W-0h | R/W-0h | R/W-0h | | | #### **Table 14-42. LCRH Field Descriptions** | Bit | Field | | Reset | Description | | | |-------|--------------|-----------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | | 1 1010 | Туре | | Description | | | | 31-26 | RESERVED | R/W | 0h | | | | | 25-21 | EXTDIR_HOLD | DIR_HOLD R/W 0h | | Defines the number of UARTclk ticks the signal to control the external driver for the RS485 will be reset after the beginning of the stop bit. (If 2 STOP bits are enabled the beginning of the 2nd STOP bit.) Oh = Smallest value 1Fh = Highest possible value | | | | 20-16 | EXTDIR_SETUP | R/W | Oh | Defines the number of UARTclk ticks the signal to control the external driver for the RS485 will be set before the START bit is send 0h = Smallest value 1Fh = Highest possible value | | | | 15-8 | RESERVED | R/W | 0h | | | | | 7 | SENDIDLE | R/W | 0h | UART send IDLE pattern. When this bit is set an SENDIDLE period of 11 bit times will be sent on the TX line. The bit is cleared by hardware afterward. 0h = Disable Send Idle Pattern 1h = Enable Send Idle Pattern | | | | 6 | SPS | R/W | Oh | UART Stick Parity Select The Stick Parity Select (SPS) bit is used to set either a permanent '1' or a permanent '0' as parity when transmitting or receiving data. Its purpose is to typically indicate the first byte of a package or to mark an address byte, for example in a multidrop RS-485 network. When bits PEN, EPS, and SPS of UARTLCRH are set, the parity bit is transmitted and checked as a 0. When bits PEN and SPS are set and EPS is cleared, the parity bit is transmitted and checked as a 1. Oh = Disable Stick Parity 1 | | | # **Table 14-42. LCRH Field Descriptions (continued)** | | | | | la Descriptions (continuea) | |-----|-------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Field | Туре | Reset | Description | | 5-4 | WLEN | R/W | Oh | UART Word Length The bits indicate the number of data bits transmitted or received in a frame as follows: 0h = 5 bits (default) 1h = 6 bits 2h = 7 bits 3h = 8 bits | | 3 | STP2 | R/W | Oh | UART Two Stop Bits Select When in 7816 smart card mode (the SMART bit is set in the UARTCTL register), the number of stop bits is forced to 2. Oh = One stop bit is transmitted at the end of a frame. The Two stop bits are transmitted at the end of a frame. The receive logic checks for two stop bits being received and provide Frame Error if either is invalid. | | 2 | EPS | R/W | Oh | UART Even Parity Select This bit has no effect when parity is disabled by the PEN bit. For 9-Bit UART Mode transmissions, this bit controls the address byte and data byte indication (9th bit). 0 = The transferred byte is a data byte 1 = The transferred byte is an address byte Oh = Odd parity is performed, which checks for an odd number of 1s. 1h = Even parity generation and checking is performed during transmission and reception, which checks for an even number of 1s in data and parity bits. | | 1 | PEN | R/W | Oh | UART Parity Enable 0h = Parity is disabled and no parity bit is added to the data frame. 1h = Parity checking and generation is enabled. | | 0 | BRK | R/W | Oh | UART Send Break (for LIN Protocol) 0h = Normal use. 1h = A low level is continually output on the UARTxTXD signal, after completing transmission of the current character. For the proper execution of the break command, software must set this bit for at least two frames (character periods). | # 14.3.30 STAT (Offset = 1108h) [Reset = 00000144h] STAT is shown in Figure 14-42 and described in Table 14-43. Return to the Summary Table. **UART Status Register** Figure 14-42. STAT **Table 14-43. STAT Field Descriptions** | Bit | Field | Туре | Reset | Description | |-------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-10 | RESERVED | R | 0h | | | 9 | IDLE | The IDLE bit is used as an addr<br>In idle-line multiprocessor forma<br>character is an address.<br>Oh = IDLE has not been detecte<br>(In idle-line multiprocessor mod<br>1h = IDLE has been detected be | | IDLE mode has been detected in Idleline-Multiprocessor-Mode. The IDLE bit is used as an address tag for each block of characters. In idle-line multiprocessor format, this bit is set when a received character is an address. Oh = IDLE has not been detected before last received character. (In idle-line multiprocessor mode). 1h = IDLE has been detected before last received character. (In idle-line multiprocessor mode). | | 8 | стѕ | R | 1h | Clear To Send 0h = The CTS signal is not asserted (high). 1h = The CTS signal is asserted (low). | | 7 | TXFF | R | Oh | UART Transmit FIFO Full The meaning of this bit depends on the state of the FEN bit in the CTL0 register. 0h = The transmitter is not full. 1h = If the FIFO is disabled (FEN is 0), the transmit holding register is full. If the FIFO is enabled (FEN is 1), the transmit FIFO is full. | | 6 | TXFE | R | 1h | UART Transmit FIFO Empty The meaning of this bit depends on the state of the FEN bit in the CTL0 register. 0h = The transmitter has data to transmit. 1h = If the FIFO is disabled (FEN is 0), the transmit holding register is empty. If the FIFO is enabled (FEN is 1), the transmit FIFO is empty. | | 5-4 | RESERVED | R | 0h | | | 3 | RXFF | F R Oh | | UART Receive FIFO Full The meaning of this bit depends on the state of the FEN bit in the CTL0 register. 0h = The receiver can receive data. 1h = If the FIFO is disabled (FEN is 0), the receive holding register is full. If the FIFO is enabled (FEN is 1), the receive FIFO is full. | # **Table 14-43. STAT Field Descriptions (continued)** | Bit | Field | Туре | Reset | Description | |-----|----------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 2 | RXFE | R | 1h | UART Receive FIFO Empty The meaning of this bit depends on the state of the FEN bit in the CTL0 register. 0h = The receiver is not empty. 1h = If the FIFO is disabled (FEN is 0), the receive holding register is empty. If the FIFO is enabled (FEN is 1), the receive FIFO is empty. | | 1 | RESERVED | R | 0h | | | 0 | BUSY | R | Oh | UART Busy This bit is set as soon as the transmit FIFO or TXDATA register becomes non-empty (regardless of whether UART is enabled) or if a receive data is currently ongoing (after the start edge have been detected until a complete byte, including all stop bits, has been received by the shift register). In IDLE_Line mode the Busy signal also stays set during the idle time generation. Oh = The UART is not busy. 1h = The UART is busy transmitting data. This bit remains set until the complete byte, including all stop bits, has been sent/received from/into the shift register. | # 14.3.31 IFLS (Offset = 110Ch) [Reset = 00000022h] IFLS is shown in Figure 14-43 and described in Table 14-44. Return to the Summary Table. The IFLS register is the interrupt FIFO level select register. You can use this register to define the levels at which the TX, RX and timeout interrupt flags are triggered. The interrupts are generated based on a transition through a level rather than being based on the level. That is, the interrupts are generated when the fill level progresses through the trigger level. For example, if the receive trigger level is set to the half-way mark, the interrupt is triggered when the receive FIFO is filled with two or more characters. Out of reset, the TXIFLSEL and RXIFLSEL bits are configured so that the FIFOs trigger an interrupt at the half-way mark. Figure 14-43. IFLS #### Table 14-44. IFLS Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-12 | RESERVED | R/W | 0h | | | 11-8 | RXTOSEL | R/W | Oh | UART Receive Interrupt Timeout Select. When receiving no start edge for an additional character within the set bit times a RX interrupt is set even if the FIFO level is not reached. A value of 0 disables this function. 0h = Smallest value Fh = Highest possible value | | 7 | RESERVED | R/W | 0h | | | 6-4 | RXIFLSEL | R/W | 2h | UART Receive Interrupt FIFO Level Select The trigger points for the receive interrupt are as follows: Note: In ULP domain the trigger levels are used for: 0: LVL_1_4 4: LVL_FULL For undefined settings the default configuration is used. 0h = RX FIFO >= 1/4 full Note: For ULP Domain 1h = RX FIFO >= 1/4 full 2h = RX FIFO >= 1/2 full (default) 3h = RX FIFO >= 3/4 full 4h = RX FIFO is full Note: For ULP Domain 5h = RX FIFO >= 1 entry available Note: esp. required for DMA Trigger | | 3 | RESERVED | R/W | 0h | | # Table 14-44. IFLS Field Descriptions (continued) | Bit | Field | Туре | Reset | Description | |-----|----------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 2-0 | TXIFLSEL | R/W | 2h | UART Transmit Interrupt FIFO Level Select The trigger points for the transmit interrupt are as follows: Note: for undefined settings the default configuration is used. 1h = TX FIFO <= 3/4 empty 2h = TX FIFO <= 1/2 empty (default) 3h = TX FIFO <= 1/4 empty 5h = TX FIFO is empty 7h = TX FIFO >= 1 entry free Note: esp. required for DMA Trigger | # 14.3.32 IBRD (Offset = 1110h) [Reset = 00000000h] IBRD is shown in Figure 14-44 and described in Table 14-45. Return to the Summary Table. When changing the IBRD register, the new value does not take effect until transmission/reception of the current character is complete. Any changes to the baud-rate divisor must be followed by a write to the UARTLCRH register. See Baud-Rate Generation chapter for configuration details. # Figure 14-44. IBRD #### Table 14-45. IBRD Field Descriptions | Bit | Field | Type Reset | | Description | | | |-------|----------|------------|----|------------------------------------------------------------------------------|--|--| | 31-16 | RESERVED | R/W | 0h | | | | | 15-0 | DIVINT | R/W | | Integer Baud-Rate Divisor 0h = Smallest value FFFFh = Highest possible value | | | # 14.3.33 FBRD (Offset = 1114h) [Reset = 00000000h] FBRD is shown in Figure 14-45 and described in Table 14-46. Return to the Summary Table. UART Fractional Baud-Rate Divisor Register The FBRD register is the fractional part of the baud-rate divisor value. All the bits are cleared on reset. When changing the FBRD register, the new value does not take effect until transmission/reception of the current character is complete. Any changes to the baud-rate divisor must be followed by a write to the UARTLCRH register. See Baud-Rate Generation chapter for configuration details. Figure 14-45. FBRD #### Table 14-46. FBRD Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|---------------------------------------------------------------------------------| | 31-6 | RESERVED | R/W | 0h | | | 5-0 | DIVFRAC | R/W | | Fractional Baud-Rate Divisor 0h = Smallest value 3Fh = Highest possible value | # 14.3.34 GFCTL (Offset = 1118h) [Reset = X] GFCTL is shown in Figure 14-46 and described in Table 14-47. Return to the Summary Table. This register control the glitch filter on the RX input. # Figure 14-46. GFCTL | g | | | | | | | | | | | | |----------|----------|------|------|--------|--------|----|--------|--|--|--|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | | | RESERVED | | | | | | | | | | | | | R/W-0h | | | | | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | | | | | RESE | RVED | | | | | | | | | | R/W-0h | | | | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | | RESE | RVED | | CHAIN | AGFSEL | | AGFEN | | | | | | | R/W-0h | | | R/W-0h | R/W-0h | | R/W-0h | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | RESERVED | | | | DGF | SEL | | | | | | | | R/W-0h | | | | R/W | ′-0h | | | | | | | # **Table 14-47. GFCTL Field Descriptions** | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-12 | RESERVED | R/W | 0h | | | 11 | CHAIN | R/W | 0h | Analog and digital noise filters chaining enable. 0 DISABLE: When 0, chaining is disabled and only digital filter output is available to IP logic for sampling 1 ENABLE: When 1, analog and digital glitch filters are chained and the output of the combination is made available to IP logic for sampling 0h = Disabled 1h = Enabled | | 10-9 | AGFSEL | R/W | Oh | Analog Glitch Suppression Pulse Width This field controls the pulse width select for the analog glitch suppression on the RX line. See device data sheet for exact values. Oh = Pulses shorter then 5ns length are filtered. 1h = Pulses shorter then 10ns length are filtered. 2h = Pulses shorter then 25ns length are filtered. 3h = Pulses shorter then 50ns length are filtered. | | 8 | AGFEN | R/W | 0h | Analog Glitch Suppression Enable 0h = Analog Glitch Filter disable 1h = Analog Glitch Filter enable | | 7-6 | RESERVED | R/W | 0h | | | 5-0 | DGFSEL | R/W | Oh | Glitch Suppression Pulse Width This field controls the pulse width select for glitch suppression on the RX line. The value programmed in this field gives the number of cycles of functional clock up to which the glitch has to be suppressed on the RX line. In IRDA mode: The minimum pulse length for receive is given by: t(MIN) = (DGFSEL) / f(IRTXCLK) 0h = Bypass GF 3Fh = Highest Possible Value | # 14.3.35 TXDATA (Offset = 1120h) [Reset = 00000000h] TXDATA is shown in Figure 14-47 and described in Table 14-48. Return to the Summary Table. UART Transmit Data Register. This register is the transmit data register (the interface to the FIFOs). For transmitted data, if the FIFO is enabled, data written to this location is pushed onto the transmit FIFO. If the FIFO is disabled, data is stored in the transmitter holding register (the bottom word of the transmit FIFO). A write to this register initiates a transmission from the UART. # Figure 14-47. TXDATA #### Table 14-48. TXDATA Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-8 | RESERVED | R/W | 0h | | | 7-0 | DATA | R/W | 0h | Data Transmitted or Received Data that is to be transmitted via the UART is written to this field. When read, this field contains the data that was received by the UART. 0h = Smallest value FFh = Highest possible value | # 14.3.36 RXDATA (Offset = 1124h) [Reset = 00000000h] RXDATA is shown in Figure 14-48 and described in Table 14-49. Return to the Summary Table. UART Receive Data Register. This register is the data receive register (the interface to the FIFOs). For received data, if the FIFO is enabled, the data byte and the 4-bit status (break, frame, parity, and overrun) is pushed onto the 12-bit wide receive FIFO. If the FIFO is disabled, the data byte and status are stored in the receiving holding register (the bottom word of the receive FIFO). The received data can be retrieved by reading this register. Figure 14-48. RXDATA | | | | i iguic i <del>-</del> - | O. IXDAIA | | | | | | |----|----------|----|--------------------------|-----------|--------|--------|--------|--|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | RESERVED | | | | | | | | | | | R-0h | | | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | RESERVED | | | | | | | | | | | R-0h | | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | RESERVED | | NERR | OVRERR | BRKERR | PARERR | FRMERR | | | | | R-0h | | R-0h | R-0h | R-0h | R-0h | R-0h | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | DATA | | | | | | | | | | | | | R- | -0h | | | | | | | | | | | | | | | | | #### Table 14-49. RXDATA Field Descriptions | Bit | Field | | Reset | Description | |-------|----------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | 111111 | Туре | 1 | Description | | 31-13 | RESERVED | R | 0h | | | 12 | NERR | R | Oh | Noise Error. Writing to this bit has no effect. The flag is cleared by writing 1 to the NERR bit in the UART EVENT ICLR register. Oh = No noise error occurred 1h = Noise error occurred during majority voting | | 11 | OVRERR | R | 0h | UART Receive Overrun Error Writing to this bit has no effect. The flag is cleared by writing 1 to the OVRERR bit in the UART EVENT ICLR register. In case of a receive FIFO overflow, the FIFO contents remain valid because no further data is written when the FIFO is full. Only the contents of the shift register are overwritten. The CPU must read the data in order to empty the FIFO. Oh = No data has been lost due to a receive overrun. 1h = New data was received but could not be stored, because the previous data was not read (resulting in data loss). | | 10 | BRKERR | R | Oh | UART Break Error Writing to this bit has no effect. The flag is cleared by writing 1 to the BRKERR bit in the UART EVENT ICLR register. This error is associated with the character at the top of the FIFO. When a break occurs, only one 0 character is loaded into the FIFO. The next character is only enabled after the receive data input goes to a 1 (marking state) and the next valid start bit is received. Oh = No break condition has occurred 1h = A break condition has been detected, indicating that the receive data input was held low for longer than a full-word transmission time (defined as start, data, parity, and stop bits). | | 9 | PARERR | R | 0h | UART Parity Error Writing to this bit has no effect. The flag is cleared by writing 1 to the PARERR bit in the UART EVENT ICLR register. Oh = No parity error has occurred 1h = The parity of the received data character does not match the parity defined by bits 2 and 7 of the UARTLCRH register. | # **Table 14-49. RXDATA Field Descriptions (continued)** | Bit | Field | Туре | Reset | Description | |-----|--------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 8 | FRMERR | R | 0h | UART Framing Error Writing to this bit has no effect. The flag is cleared by writing 1 to the FRMERR bit in the UART EVENT ICLR register. This error is associated with the character at the top of the FIFO. 0h = No framing error has occurred 1h = The received character does not have a valid stop bit sequence, which is one or two stop bits depending on the UARTLCRH.STP2 setting (a valid stop bit is 1). | | 7-0 | DATA | R | 0h | Received Data. When read, this field contains the data that was received by the UART. 0h = Smallest value FFh = Highest possible value | # 14.3.37 LINCNT (Offset = 1130h) [Reset = 00000000h] LINCNT is shown in Figure 14-49 and described in Table 14-50. Return to the Summary Table. **UART LIN Mode Counter Register** # Figure 14-49. LINCNT # **Table 14-50. LINCNT Field Descriptions** | | Bit | Field | Туре | Reset | Description | |---|-------|----------|------|-------|-------------------------------------------------------------------------------------------------------------------| | Γ | 31-16 | RESERVED | R/W | 0h | | | | 15-0 | VALUE | R/W | | 16 bit up counter clocked by the functional clock of the UART. 0h = Smallest value FFFFh = Highest possible value | # 14.3.38 LINCTL (Offset = 1134h) [Reset = 00000000h] LINCTL is shown in Figure 14-50 and described in Table 14-51. Return to the Summary Table. **UART LIN Mode Control Register** # Figure 14-50. LINCTL #### **Table 14-51. LINCTL Field Descriptions** | Bit | Field | Туре | Reset | Description | |------|-------------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-7 | RESERVED | R/W | 0h | | | 6 | LINC0_MATCH | R/W | Oh | Counter Compare Match Mode When this bit is set to 1 a counter compare match with LINC0 register triggers an LINC0 interrupt when enabled. Oh = Counter compare match mode disabled (capture mode enabled) 1h = Counter compare match enabled (capture mode disabled) | | 5 | LINC1CAP | R/W | Oh | Capture Counter on positive RXD Edge. When enabled the counter value is captured to LINC1 register on each positive RXD edge. A LINC1 interrupt is triggered when enabled. Oh = Capture counter on positive UARTxRXD edge disabled 1h = Capture counter on positive UARTxRXD edge enabled | | 4 | LINC0CAP | R/W | Oh | Capture Counter on negative RXD Edge. When enabled the counter value is captured to LINC0 register on each negative RXD edge. A LINC0 interrupt is triggered when enabled. Oh = Capture counter on negative UARTxRXD edge disabled 1h = Capture counter on negative UARTxRXD edge enabled | | 3 | RESERVED | R/W | 0h | | | 2 | CNTRXLOW | R/W | 0h | Count while low Signal on RXD When counter is enabled and the signal on RXD is low, the counter increments. 0h = Count while low Signal on UARTxRXD disabled 1h = Count while low Signal on UARTxRXD enabled | | 1 | ZERONE | R/W | 0h | Zero on negative Edge of RXD. When enabled the counter is set to 0 and starts counting on a negative edge of RXD 0h = Zero on negative edge disabled 1h = Zero on negative edge enabled | | 0 | CTRENA | R/W | 0h | LIN Counter Enable. LIN counter will only count when enabled. 0h = Counter disabled 1h = Counter enabled | # 14.3.39 LINC0 (Offset = 1138h) [Reset = 00000000h] LINC0 is shown in Figure 14-51 and described in Table 14-52. Return to the Summary Table. UART LIN Mode Capture 0 Register # Figure 14-51. LINC0 # Table 14-52. LINC0 Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-16 | RESERVED | R/W | 0h | | | 15-0 | DATA | R/W | 0h | 16 Bit Capture / Compare Register Captures current LINCTR value on RXD falling edge and can generate a LINC0 interrupt when capture is enabled (LINC0CAP = 1). If compare mode is enabled (LINC0_MATCH = 1), a counter match can generate a LINC0 interrupt. 0h = Smallest value FFFFh = Highest possible value | # 14.3.40 LINC1 (Offset = 113Ch) [Reset = 00000000h] LINC1 is shown in Figure 14-52 and described in Table 14-53. Return to the Summary Table. **UART LIN Mode Capture 1 Register** # Figure 14-52. LINC1 # Table 14-53. LINC1 Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-16 | RESERVED | R/W | 0h | | | 15-0 | DATA | R/W | 0h | 16 Bit Capture / Compare Register Captures current LINCTR value on RXD rising edge and can generate a LINC1 interrupt when capture is enabled (LINC1CAP = 1) 0h = Smallest value FFFFh = Highest possible value | # 14.3.41 IRCTL (Offset = 1140h) [Reset = X] IRCTL is shown in Figure 14-53 and described in Table 14-54. Return to the Summary Table. IrDA Control Register Figure 14-53. IRCTL **Table 14-54. IRCTL Field Descriptions** | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-10 | RESERVED | R/W | 0h | | | 9 | IRRXPL | R/W | 0h | IrDA receive input UCAxRXD polarity 0h = HIGH : IrDA transceiver delivers a high pulse when a light pulse is seen 1h = LOW : IrDA transceiver delivers a low pulse when a light pulse is seen | | 8 | RESERVED | R/W | 0h | | | 7-2 | IRTXPL | R/W | 0h | Transmit pulse length. Pulse length t(PULSE) = (IRTXPLx + 1) / [2 * f(IRTXCLK)] (IRTXCLK = functional clock of the UART) 0h = Smallest value 3Fh = Highest possible value | | 1 | IRTXCLK | R/W | 0h | IrDA transmit pulse clock select 0h (R/W) = IrDA encode data is based on the functional clock. 1h (R/W) = IrDA encode data is based on the Baud Rate clock< when select 8x oversampling, the IRTXPL cycle should less 8; when select 16x oversampling, the IRTXPL cycle should less 16. | | 0 | IREN | R/W | 0h | IrDA encoder/decoder enable 0h (R/W) = IrDA encoder/decoder disabled 1h (R/W) = IrDA encoder/decoder enabled | # 14.3.42 AMASK (Offset = 1148h) [Reset = 000000FFh] AMASK is shown in Figure 14-54 and described in Table 14-55. Return to the Summary Table. Self Address Mask Register The AMASK register is used to enable the address mask for 9-bit or Idle-Line mode. The address bits are masked to create a set of addresses to be matched with the received address byte. Used in DALI, UART 9-Bit or Idle-Line mode. #### Figure 14-54. AMASK #### Table 14-55. AMASK Field Descriptions | Bit | Field | Туре | Reset | Description | | | | |------|----------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | 31-8 | RESERVED | R/W | 0h | | | | | | 7-0 | VALUE | R/W | FFh | Self Address Mask for 9-Bit Mode This field contains the address mask that creates a set of addresses that should be matched. A 0 bit in the MSK bit field configures, that the corresponding bit in the ADDR bit field of the UARTxADDR register is don't care. A 1 bit in the MSK bit field configures, that the corresponding bit in the ADDR bit field of the UARTxADDR register must match. 0h = Smallest value FFh = Highest possible value | | | | # 14.3.43 ADDR (Offset = 114Ch) [Reset = 00000000h] ADDR is shown in Figure 14-55 and described in Table 14-56. Return to the Summary Table. Self Address Register The ADDR register is used to write the specific address that should be matched with the receiving byte when the Address Mask (AMASK) is set to FFh. This register is used in conjunction with AMASK to form a match for address-byte received. Used in DALI, UART 9-Bit or Idle-Line mode. #### Figure 14-55. ADDR # Table 14-56. ADDR Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-8 | RESERVED | R/W | 0h | | | 7-0 | VALUE | R/W | 0h | Self Address for 9-Bit Mode This field contains the address that should be matched when UARTxAMASK is FFh. 0h = Smallest value FFh = Highest possible value | # 14.3.44 CLKDIV2 (Offset = 1160h) [Reset = 00000000h] CLKDIV2 is shown in Figure 14-56 and described in Table 14-57. Return to the Summary Table. This register is used to specify module-specific divide ratio of the functional clock. (Only in UART extended) #### Figure 14-56. CLKDIV2 # Table 14-57. CLKDIV2 Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-3 | RESERVED | R/W | 0h | | | 2-0 | RATIO | R/W | Oh | Selects divide ratio of module clock 0h = Do not divide clock source 1h = Divide clock source by 2 2h = Divide clock source by 3 3h = Divide clock source by 4 4h = Divide clock source by 5 5h = Divide clock source by 6 6h = Divide clock source by 7 7h = Divide clock source by 8 | This page intentionally left blank. # Chapter 15 **SPI** The serial peripheral interface (SPI) module provides a standardized serial interface to transfer data between MSPM0 devices and other external devices with SPI interface. | 15.1 SPI Overview | 754 | |---------------------|-----| | 15.2 SPI Operation | | | 15.3 SPI Registers | | | 10.0 01 1 (Cg)3(013 | | SPI www.ti.com #### 15.1 SPI Overview The SPI module provides a standardized serial interface to transfer data between MSPM0 devices and other external devices (such as a Sensors, Memory, ADCs, or DACs) using SPI protocols #### 15.1.1 Purpose of the Peripheral The SPI module acts as a controller or peripheral interface for synchronous serial communication with peripheral devices and other controllers. The transmit and receive paths are buffered with internal, independent FIFO memories allowing up to 4 entries with 16-bit width. A DMA interface is also provided to allow the data exchange with the transmit and receive FIFOs. #### 15.1.2 Features The SPI modules have the following features: - · Configurable as a controller or a peripheral - · Programmable clock bit rate and prescaler - Separate transmit (TX) and receive (RX) first-in first-out buffers (FIFOs) - Programmable data frame size from 4-bits to 16-bits (Controller Mode) - Programmable data frame size from 7-bits to 16-bits (Peripheral Mode) - Supports PACKEN feature that allows the packing of 2 16 bit FIFO entries into a 32-bit value to improve CPU performance. However, not all devices support packing. Please check device specific data sheet. - Interrupts for transmit and receive FIFOs, overrun and timeout interrupts, and DMA done - · Programmable SPI mode support Motorola SPI, MICROWIRE, or Texas Instruments format - Single bit parity will be supported in both transmit and receive paths using the CTL1.PTEN and CTL1.PREN bits - Direct memory access controller interface (DMA): - Separate channels for transmit and receive - Transfer complete interrupt www.ti.com SPI # 15.1.3 Functional Block Diagram Figure 15-1. SPI Functional Block Diagram # 15.1.4 External Connections and Signal Descriptions Figure 15-2 and Table 15-1 show an overview of the pin functions for different operation modes of the SPI module. SPI www.ti.com # Controller SCLK POCI PICO PICO PICO Pripheral SCLK POCI PICO #### 4 Wire Connection with CD # 4 Wire Connection with 4 Peripherals Figure 15-2. External Connections for Different SPI Configurations **Table 15-1. Pin Function Overview** | Standard SPI | Feature | |--------------|------------------------------------| | | SPI clock | | SCLK | Controller mode: SCLK is an output | | | Peripheral mode: SCLK is an input | **Table 15-1. Pin Function Overview (continued)** | Standard SPI | Feature | |--------------|-----------------------------------------------------| | | Controller out, peripheral in | | PICO | Controller mode: PICO is the data output line | | | Peripheral mode: PICO is the data input line | | | Controller in, peripheral out | | POCI | Controller mode: POCI is the data input line | | | Peripheral mode: POCI is the data output line | | CS0 | Chip select signal 0, used in 4-pin mode | | CS1 | Chip select signal 1, used in 4-pin mode | | CS2 | Chip select signal 2, used in 4-pin mode | | CS3/CD | Chip select signal 3 or Command, used in 4-pin mode | ## 15.2 SPI Operation #### 15.2.1 Clock Control The SPI internal functional clock is selected and divided from the clock sourced to this module. - Use SPIx.CLKSEL register to select the source of the SPI functional clock. - BUSSCLK: the current bus clock is selected as the source for SPI. The current bus clock depends on power domain. If the SPI instance is in power domain 1 (PD1) please refer to MCLK, if the SPI instance is in power domain 0 (PD0) refer to ULPCLK. - MFCLK: MFCLK is selected as the source for SPI, refer to MFCLK. - LFCLK: LFCLK is selected as the source for SPI, refer to LFCLK - Use SPIx.CLKDIV register to select the divide ratio of the SPI function clock. Options are from divide by 1 to 8. The SPI module must be enabled before being configured for use by using the ENABLE bit in SPIx.PWREN register (see peripheral power enable). When the SPI will be setup or the configuration should be changed the ENABLE bit should be cleared to avoid unpredictable behavior during the updates or for the first data receive or transmitted afterward. The maximum SPI frequency supported with controller and peripheral mode depends on the device clock option and IO option. Please refer to specific device data sheet spec for more information. ## 15.2.2 General Architecture ## 15.2.2.1 Chip Select and Command Handling #### 15.2.2.1.1 Chip Select Control One can configure the SPI to be controller mode by setting the CTL1.MS bit to 1, and in peripheral mode by clearing the CTL1.MS bit. The CTL0.CSSEL bit selects which connected peripheral is addressed by the up to 4 CS signals. The bits are controlled by the SPI module in controller or target/peripheral mode. The selected signal is controlled during the transfers. The chip select signal needs to be provided by the controller in four-wire mode and the chip select polarity can be inverted by configuring the PINCM.CSx.INV register. In peripheral mode, the clock is provided by the controller and used by the peripheral to capture the data. The peripheral has the option to operate in 3-wire or 4-wire mode. 4-wire mode only accepts data transfers if the CS is activated. When the CTL0.CSCLR bit is set, the transmit/receive shift register counter is cleared automatically when the CS goes to the inactive state. When using the Motorola 4-wire or National Microwire mode, follow these constraints: - The CS disable period must be longer than 2 functional clock cycles before the CS pin is re-asserted - The CS lead time (CS active to the first bit clock edge) must be at least 2 SPI functional clock cycles Following these constraints helps the peripheral to synchronize again on the controller in case of a disturbance or glitch on the clock line or during initialization. This bit is relevant only in the peripheral mode. - CTL0.CSCLR = 0: The transmit/receive bit counter state is retained when the CS signal disables the peripheral. - CTL0.CSCLR = 1: The transmit/receive bit counter is cleared when the CS signal disables the peripheral. #### Note The CSCLR function requires the CS disable pulse to be longer than 2 SPI function clock cycles to proper detect and clear the bit counter in the SPI. The CS lead time (CS active to the first bit clock edge) also needs to be at least 2 SPI function clock cycles. #### 15.2.2.1.2 Command Data Control When using the Motorola frame format, the CDMODE bit can be set to use the CS3/CD line as signal to distinguish between Command and Data information. This is often used for LCD or data storage devices. - CD level low: command function - · CD level high: data function The CTL1.CDMODE can be written with a value of 1-14 to specify the number of bytes and the CD line will go low for the given numbers of bytes which are sent by the SPI, starting with the next value to be transmitted. After the number of bytes are transmitted the CD will go high automatically. If a value of 0xF is set the C/D stays low permanently, a value of 0 set the CD line to high immediately after the current character has been transmitted. This option is only available in controller mode. CTL1.CDENABLE can only be updated when the SPI module is disabled, CTL1.CDMODE can be updated between the different data packages. The counter will be reset with CDENABLE or SPI ENABLE set to disabled. Before setting a new value in CTL1.CDMODE the status of the FIFO should be checked to be empty and the SPI should be in Idle mode. When writing a new value into CTL1.CDMODE, the internal counter will be reset and the new value will be used for counting. If the counter did count down to 0 and another command package should be sent the CDMODE needs to be set first again, otherwise the next data is send as data with the CD pin signaling data mode. #### 15.2.2.2 Data Format The control bit CTL1.MSB defines the direction of the data input and output with most-significant-bit (MSB) or least-significant-bit (LSB) first. If the parity is enabled the parity bits is always received as last bit. With the control register bits CTL0.DSS the bit length per transfer will be defined between 4-16 bits for Controller mode and 7-16 bits for Peripheral mode. A transfer will be triggered with writing to the TX buffer register. The data write needs to have at least the number of bits of the transfer. For example, if only a byte is written to the TX buffer but the length of the transfer is > 8 the missing bits will be filled with 0s. On the receive path the received data will be moved to the RXFIFO or RX buffer after the number of bit defined in CTL0.DSS register have been received. The RX and TX buffer shall be accessed with at least the bits covering one transfer. - 4-8 bits : byte access (Peripheral mode: 7-8 Bits) - 9-16 bits: 16 bit access Clock polarity (CTL0.SPO) is used to control the clock polarity when data is not being transferred and it is only used in the Motorola SPI frame mode. - 0h = peripheral produces a steady state LOW value on the CLKOUT pin when data is not being transferred. - 1h = peripheral produces a steady state HIGH value on the CLKOUT pin when data is not being transferred. Clock phase (CTL0.SPH) bit selects the clock edge that captures data and enables it to change state. It has the most impact on the first bit transmitted by either permitting or not permitting a clock transition before the first data capture edge. Please refer to Motorola SPI frame mode section to check the diagrams. - 0h = Data is captured on the first clock edge transition. - 1h = Data is captured on the second clock edge transition. The SPI can be configured to work in Peripheral mode with CTL1.MS bit = 0. In Peripheral mode the clock is provided by the controller and available for the peripheral on the CLK pins which needs to be configured for input. The Clock Select and divider control bits are not used. The CS input signal is used to select/enable the data receive path of the peripheral in 4 wire mode. The SPI can be configured to work as Controller with CTL1.MS bit = 1. In Controller mode the clock needs to be generated by selecting the available clock sources with the clock select bits. It also needs to control the CS signal depending on the selected protocol. When setting the CTL1.PEN bit the last bit will be used as parity to evaluate the integrity of the previous bits. The CTL1.PES bit selects the parity mode as even or odd. When detecting a fault, the interrupt flag RIS.PER is set to mark the data as invalid. Parity checking is a feature to improve the robustness of the communication. ### 15.2.2.3 Delayed data sampling In circumstances when the input data arrives at the POCI pin with some delay due to runtime conditions and the following input data sampling stage, the previous data would be sampled at the sampling clock edge. To compensate for such condition, a delayed sampling can be set with the CLKCTL.DSAMPLE bits. The delayed sampling is only available in controller mode. The delay can be adjusted in steps of SPI input clock steps with setting the control register bits CLKCTL.DSAMPLE. The maximum allowed delay should not exceed the length of one data frame. #### 15.2.2.4 Clock Generation The SPI includes a programmable bit rate clock divider and prescaler to generate the serial output clock (SCLK). Bit rates supported are up to, the input clocks divided by 2. The input clock selection depends on the specific device, refer to the device data sheet and Clock Control section. The SPI functionality can work with any of these selected inputs: SYSCLK, MFCLK and LFCLK "SPI Clock" is the output after clock division performed according to ratio selected by the CLKDIV register. SPI clock = Selected input clock / (1 + CLKDIV) SPI Sampling Clock (SCLK) is the output after dividing the SPI Clock by the Prescalar value. SCLK = SPI Clock / ((1 + SCR)\*2) If the factor of two (\*2) is set by CLKDIV the input clock must be at least 2 times faster than SPI clock. ### 15.2.2.5 FIFO Operation ### **Transmit FIFO** The TX FIFO is a 32-bit-wide, 4-location-deep, first-in first-out memory buffer. The CPU writes data to the FIFO by writing the SPI Data Register TXDATA.DATA, and data is stored in the FIFO until it is read out by the transmission logic. When configured as a controller or a peripheral, parallel data is written into the TX FIFO before serial conversion and transmission to the attached peripheral or controller, respectively, through the PICO or POCI pin. In peripheral mode, the SPI transmits data each time the controller initiates a transaction. If the TX FIFO is empty and the controller initiates a transfer, the peripheral transmits the most-recent value written to the transmit FIFO. User or software is responsible to make valid data available to the FIFO as needed. The SPI can be configured to generate an interrupt or a DMA request when the FIFO is empty. The transmit FIFO has a TXFIFO\_UNF interrupt to indicate a FIFO underflow condition. ### **Receive FIFO** The RX FIFO is a 32-bit-wide, 4-location-deep, first-in-first-out memory buffer. Received data from the serial interface is stored in the buffer until read out by the CPU or DMA, which accesses the read FIFO by reading the SPIx.RXDATA register. When configured as a controller or peripheral, serial data is received through the POCI or PICO pin. As the access pointer for the FIFO will be updated with each access, the data needs to be accessed by single transfers. With the FIFO fill level trigger signals located in the STAT register (TFE, TNF, RFE, RNF) the FIFO buffer allows an application to continuously stream serial data in one buffer while the application moves or process the data from the other buffer. If the FIFO is full and new data is written into the FIFO without reading data the RXFIFO overflow event is set. The receive FIFO has a RXFULL interrupt to indicate a FIFO full condition. #### 15.2.2.6 DMA Operation The SPI provides an interface to the DMA controller with separate channels for transmit and receive. The DMA operation of the SPI is enabled through the SPI Event and DMA register. When DMA operation is enabled, the SPI asserts a DMA request on the receive or transmit channel when the associated FIFO can transfer data. For the receive channel a transfer request is asserted whenever the amount of data in the receive FIFO is at or above the FIFO trigger level configured using the RXIFLSEL bit in IFLS register or the receive timeout has triggered, in this case the amount of data received so far will be transmitted. For the transmit channel a transfer request is asserted whenever the transmit FIFO contains fewer characters than the FIFO trigger level configured using the TXIFLSEL bit in IFLS register. The DMA transfer requests are handled automatically by the DMA controller depending on how the DMA channel is configured. The DMA transfers can be configured and aligned between the data width of the SPI transfers and the bus accesses width of 8/16 bits to make an efficient usage of the bus. The trigger and transfers are independent for receive and transmit. See more information about the interrupt and event in Section 15.2.6.2 section. ## 15.2.2.7 Repeat Transfer mode With the CTL1.REPEATTX bits the last character transmit will be repeated as defined by the register bits. A value of 0 in CTL1.REPEATTX bits will disable this mode and this function is only available in Controller mode. The transfer will be started with writing a data into the TX Buffer. Then the data will be repeatedly sent with the given value. The behavior is identical as if the data would be written into the TX Buffer that many times as defined by the value here. It can be used to clean a transfer or to pull a certain amount of data from a peripheral. When REPEATTX is used it needs to be aligned with the data in the FIFO. So the below shown sequence should be used: - · Wait and check till FIFO is empty - Setup REPEATTX - Write to TXDATA / FIFO - Wait till requested data has been received #### 15.2.2.8 Low Power Mode The SPI module is located in power domain 1 (PD1) and as such is only active in RUN and SLEEP modes. If the SPI module is enabled by application software, an entry into STOP or STANDBY low-power mode forces the SPI module to be temporarily disabled while the device is in STOP or STANDBY mode. #### 15.2.3 Protocol Descriptions The protocol format mode can be selected by using CTL0.FRF register. The supported options include Motorola 3 wire, Motorola 4 wire, Texas Instruments Synchronous and MICROWIRE. ### 15.2.3.1 Motorola SPI Frame Format The Motorola SPI interface is a 4-wire interface where the CS signal behaves as a peripheral select. In the 3-wire mode the CS signals is not required and the module behaves as if always selected. The main feature of the Motorola SPI format is that the inactive state and phase of the SCLK signal can be programmed through the SPO and SPH bits in the SPIx.CTL0 control register. ### **SPO Clock Polarity Bit** If the CTL0.SPO clock polarity control bit is clear, the bit produces a steady-state low value on the SCLK pin when data is not being transferred. If the CTL0.SPO bit is set, the bit places a steady-state high value on the SCLK pin when data is not being transferred. #### **SPH Phase-Control Bit** The CTL0.SPH phase-control bit selects the clock edge that captures data, and allows it to change state. The state of this bit has the most impact on the first bit transmitted, by either allowing or not allowing a clock transition before the first data capture edge. If the CTL0.SPH phase-control bit is clear, data is captured on the first clock edge transition. If the SPH bit is set, data is captured on the second clock edge transition. #### Motorola SPI Frame Format with SPO = 0 and SPH = 0 Figure 15-3shows signal sequences for Motorola SPI format with SPO = 0 and SPH = 0. Q is undefined Figure 15-3. Motorola SPI Format With SPO = 0 and SPH = 0 In this configuration, the following occurs during idle periods: - SCLK is forced low - · CS is forced high - The transmit data line PICO is forced low - · When the SPI is configured as a controller, it enables the SCLK pin - · When the SPI is configured as a peripheral, it disables the SCLK pin If the SPI is enabled and valid data is in the TX FIFO, the CS controller signal is driven low at the start of transmission which causes enabling of peripheral data onto the POCI input line of the controller. The controller PICO output pin is enabled. One-half SCLK period later, valid controller data is transferred to the PICO pin. Once both the controller and peripheral data are set, the SCLK controller clock pin goes high after an additional one-half SCLK period. The data is now captured on the rising edges and propagated on the falling edges of the SCLK signal. For a single-word transmission after all bits of the data word are transferred, the CS line is returned to its IDLE high state one SCLK period after the last bit is captured. For continuous back-to-back transmissions, the CS signal must pulse high between each data word transfer because the peripheral-select pin freezes the data in its serial peripheral register and does not allow altering of the data if the SPH bit is clear. The controller device must raise the CS pin of the peripheral device between each data transfer to enable the serial peripheral data write. When the continuous transfer completes, the CS pin is returned to its IDLE state one SCLK period after the last bit is captured. #### Motorola SPI Frame Format with SPO = 0 and SPH = 1 Figure 15-4 shows the signal sequence for Motorola SPI format with SPO = 0 and SPH = 1. Q is undefined Figure 15-4. Motorola SPI Frame Format With SPO = 0 and SPH = 1 If the SPI is enabled and valid data is in the TX FIFO, the CS controller signal goes low at the start of transmission. The controller PICO output is enabled. After an additional one-half SCLK period, both controller and peripheral valid data are enabled onto their respective transmission lines. At the same time, SCLK is enabled with a rising-edge transition. Data is then captured on the falling edges and propagated on the rising edges of the SCLK signal. For a single-word transfer, after all bits are transferred, the CS line is returned to its IDLE high state one SCLK period after the last bit is captured. For continuous back-to-back transfers, the CS pin is held low between successive data words and terminates like a single-word transfer. ### Motorola SPI Frame Format with SPO = 1 and SPH = 0 Figure 15-5 shows signal sequences for Motorola SPI format with SPO = 1 and SPH = 0. Q is undefined Figure 15-5. Motorola SPI Frame Format With SPO = 1 and SPH = 0 In this configuration, the following occurs during idle periods: - SCLK is forced high - · CS is forced high - The transmit data line PICO is arbitrarily forced low - When the SPI is configured as a controller, it enables the SCLK pin - When the SPI is configured as a peripheral, it disables the SCLK pin If the SPI is enabled and valid data is in the TX FIFO, the SPI CS controller signal goes low at the start of transmission and transfers peripheral data onto the POCI line of the controller immediately. The controller PICO output pin is enabled. One-half SCLK period later, valid controller data is transferred to the PICO line. When both the controller and peripheral data have been set, the SCLK controller clock pin becomes low after one additional half SCLK period. Data is captured on the falling edges and propagated on the rising edges of the SCLK signal. For a single-word transmission after all bits of the data word are transferred, the CS line is returned to its IDLE high state one SCLK period after the last bit is captured. For continuous back-to-back transmissions, the CS signal must pulse high between each data word transfer as the peripheral-select pin freezes the data in its serial peripheral register and keeps it from being altered if the SPH bit is clear. The controller device must raise the CS pin of the peripheral device between each data transfer to enable the serial peripheral data write. When the continuous transfer completes, the CS pin returns to its IDLE state one SCLK period after the last bit is captured. #### Motorola SPI Frame Format with SPO = 1 and SPH = 1 Figure 15-6shows the signal sequence for Motorola SPI format with SPO = 1 and SPH = 1. Figure 15-6. Motorola SPI Frame Format With SPO = 1 and SPH = 1 In this configuration, the following occurs during idle periods: - SCLK is forced high - CS is forced high - · The transmit data line PICO is arbitrarily forced low - When the SPI is configured as a controller, it enables the SCLK pin - When the SPI is configured as a peripheral, it disables the SCLK pin If the SPI is enabled and valid data is in the TX FIFO, the start of transmission is signified by the CS controller signal going low. The controller PICO output pin is enabled. After an additional one-half SCLK period, both controller and peripheral data are enabled onto their respective transmission lines. At the same time, SCLK is enabled with a falling-edge transition. Data is then captured on the rising edges and propagated on the falling edges of the SCLK signal. For a single word transmission, after all bits are transferred, the CS line returns to its IDLE high state one SCLK period after the last bit is captured. For continuous back-to-back transmissions, the CS pin remains in its active low state until the final bit of the last word is captured and then returns to its IDLE state. For continuous back-to-back transfers, the CS pin is held low between successive data words and terminates like a single-word transfer. The serial clock (SCLK) is held inactive while the SPI is idle and SCLK transitions at the programmed frequency only during active transmission or reception of data. The IDLE state of SCLK provides a receive timeout indication that occurs when the RX FIFO still contains data after a timeout period. ### 15.2.3.2 Texas Instruments Synchronous Serial Frame Format The SPI peripheral is compatible with Texas Instruments Synchronous Serial frame format. Figure 15-7 shows the TI synchronous serial frame format for a single and continuous transmitted frame. **Single Transmission Signal Sequences** **Continuous Transmission Signal Sequences** Figure 15-7. TI Synchronous Serial Frame Format SCLK and CS are forced low and the transmit data line PICO is put in tristate whenever the SPI is idle. When the bottom entry of the TX FIFO contains data, CS is pulsed high for one SCLK period. The transmitted value is also transferred from the TX FIFO to the serial shift register of the transmit logic. On the next rising edge of SCLK, the MSB of the 4- to 16-bit data frame is shifted out on the PICO pin. Likewise, the MSB of the received data is shifted onto the POCI pin by the off-chip serial peripheral device. Both the SPI and the off-chip serial peripheral device then clock each data bit into their serial shifter on each falling edge of SCLK. The received data is transferred from the serial shifter to the RX FIFO on the first rising edge of SCLK after the least significant bit (LSB) is latched. The serial clock (SCLK) is held inactive while the SPI is idle and SCLK transitions at the programmed frequency only during active transmission or reception of data. The IDLE state of SCLK provides a receive time-out indication that occurs when the RX FIFO still contains data after a time-out period. #### 15.2.4 Reset Considerations #### **Software Reset Considerations** A Software reset can be executed with setting the RESETASSERT together with the KEY in the RSTCTL register. An ongoing transfer will be terminated immediately and can leave the software in an undefined state. Therefore, before requesting a Reset an ongoing Transfer should be terminated. #### **Hardware Reset Considerations** A hardware reset also initializes the IO configuration. This sets the IOs to a high impedance state and the data lines can float. If this is critical for the application or connected devices on the SPI interface external pull up or down resistors might be required. #### 15.2.5 Initialization To enable and initialize the SPI, the following steps are necessary: 1. Configure the IOMUX with the appropriate GPIO pins for which the SPI signals are multiplexed to #### Note Pull-ups can be used to avoid unnecessary toggles on the SPI pins, which can take the peripheral to a wrong state. In addition, if the SCLK signal is programmed to steady state High through the SPO bit in the CTL0 register, then software must also configure the GPIO port pin corresponding to the SCLK signal as a pull-up. For each of the frame formats, the SPI is configured using the following steps: - 1. Ensure that the ENABLE bit in the CTL1 register is clear before making any configuration changes. - 2. Select and configure the clock prescale divisor by writing the CLKSEL and CLKDIV register. - 3. Select whether the SPI is a controller or peripheral: - For controller operations, set the MS bit in the CTL1 register. - For peripheral mode, clear the MS bit in the CTL1 register. - 4. Configure the clock divisor by writing the CLKCTL register. - 5. Please note that a SPI Software reset ( See section 15.3.4) is required when switching SPI protocol format. - 6. Configure the CTL0 and CTL1 register with based on the desired protocol, data width and other special configurations. - 7. Optionally configure DMA - 8. Enable the SPI by setting the ENABLE bit in the CTL1 register. #### 15.2.6 Interrupt and Events Support The SPI module contains three event publishers and no event subscribers. One event publisher (CPU\_INT) manages SPI interrupt requests (IRQs) to the CPU subsystem through a static event route. The second and third event publishers (DMA\_TRIG\_RX, DMA\_TRIG\_TX) are used to setup the trigger signaling for the DMA through DMA event route. The SPI events are summarized in Table 15-2. #### Table 15-2. SPI Events | Event | Type | Source | Destination | Route | Configuration | Functionality | |---------------|-----------|--------|---------------|-----------------|-----------------------|------------------------------------------------| | CPU interrupt | Publisher | SPI | CPU Subsystem | Static route | CPU_INT registers | Fixed interrupt route from SPI to CPU | | DMA trigger | Publisher | SPI | DMA | DMA event route | DMA_TRIG_RX registers | Fixed interrupt<br>route from SPI RX<br>to DMA | | DMA trigger | Publisher | SPI | DMA | DMA event route | DMA_TRIG_TX registers | Fixed interrupt route from SPI TX to DMA | ### 15.2.6.1 CPU Interrupt Event Publisher (CPU INT) The SPI module provides 9 interrupt sources that can source a CPU interrupt event. Table 15-3 lists the CPU interrupt events from the SPI in order of decreasing priority. Table 15-3. SPI CPU\_INT Trigger Condition | IIDX STAT | Name | Description | | | | |--------------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | 0x01 | RXFIFO_OVF | RXFIFO overflow event. This interrupt is set if an RX FIFO overflow has been detected. | | | | | 0x02 | PER | Parity error event. This bit if a Parity error has been detected. | | | | | | | Peripheral receive timeout event. When in peripheral mode and not receiving data for the CTL1.RXTIMEOUT selected number of functional clock cycles. | | | | | 0x04 | RX | Receive FIFO event. This interrupt is set if the selected receive FIFO level has been reached. | | | | | 0x05 | TX | Transmit FIFO event. This interrupt is set if the selected transmit FIFO level has been reached. | | | | | 0x06 TXEMPTY | | Transmit FIFO empty interrupt. This is set if all data in the transmit FIFO have been shifted out. | | | | | 0x07 IDLE | | SPI Idle. SPI has done finished transfers and changed into IDLE mode. This bit is set when STAT.BUSY bit goes low. | | | | | 0x08 | DMA_DONE1_RX | This interrupt is set if the RX DMA channel sends the DONE signal. | | | | | 0x09 | DMA_DONE1_TX | This interrupt is set if the TX DMA channel sends the DONE signal. | | | | The CPU interrupt event configuration is managed with the CPU\_INT event management registers. See Section 6.2.5 for guidance on configuring the Event registers. ## 15.2.6.2 DMA Trigger Publisher (DMA\_TRIG\_RX, DMA\_TRIG\_TX) DMA\_TRIG\_RX and DMA\_TRIG\_TX registers are used to setup the trigger signaling for the DMA. This can be setup in a flexible way to trigger the DMA for receive or transmit events with the trigger conditions in Table 15-4 and Table 15-5. DMA\_TRIG\_RX is used for triggering the DMA to do a receive data transfer and DMA\_TRIG\_TX is used for triggering the DMA to do a transmit data transfer. Table 15-4. SPI DMA\_TRIG\_RX DMA Trigger Condition | IIDX STAT | Name | Description | |-----------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------| | 0x03 | | Peripheral receive timeout event. When in peripheral mode and not receiving data for the CTL1.RXTIMEOUT selected number of functional clock cycles. | | 0x04 | RX | Receive FIFO event. This interrupt is set if the selected receive FIFO level has been reached. | Table 15-5. SPI DMA\_TRIG\_TX DMA Trigger Condition | IIDX STAT | Name | Description | |-----------|------|--------------------------------------------------------------------------------------------------| | 0x05 | TX | Transmit FIFO event. This interrupt is set if the selected transmit FIFO level has been reached. | The DMA trigger event configuration is managed with the DMA\_TRIG\_RX and DMA\_TRIG\_TX event management registers. See Section 6.2.5 for guidance on configuring the Event registers and Section 6.1.3.2 for on how DMA trigger event works. ### 15.2.7 Emulation Modes The module behavior while the device is in debug mode is controlled by the FREE and SOFT bits in PDBGCTL register. When the device is in debug mode and set into halt mode below behavior can be configured. # Table 15-6. Debug Mode Peripheral Behavior | PDBGCTL.FREE PDBGCTL.SOFT | | Function | | | |---------------------------|---|--------------------------------------------------------|--|--| | 1 | x | Modules continues operation | | | | 0 | 0 | Module stops immediately | | | | 0 1 | | Module stops after the next transfer has been finished | | | # 15.3 SPI Registers Table 15-7 lists the memory-mapped registers for the SPI registers. All register offset addresses not listed in Table 15-7 should be considered as reserved locations and the register contents should not be modified. Table 15-7. SPI Registers | Offset | Acronym | Register Name | Group | Section | |--------|----------|----------------------------------------------|-----------------|---------| | 800h | PWREN | Power enable | | Go | | 804h | RSTCTL | Reset Control | | Go | | 808h | CLKCFG | Peripheral Clock Configuration Register | | Go | | 814h | STAT | Status Register | | Go | | 1000h | CLKDIV | Clock Divider | | Go | | 1004h | CLKSEL | Clock Select for Ultra Low Power peripherals | | Go | | 1018h | PDBGCTL | Peripheral Debug Control | | Go | | 1020h | IIDX | Interrupt Index Register | CPU_INT | Go | | 1028h | IMASK | Interrupt mask | CPU_INT | Go | | 1030h | RIS | Raw interrupt status | CPU_INT | Go | | 1038h | MIS | Masked interrupt status | CPU_INT | Go | | 1040h | ISET | Interrupt set | CPU_INT | Go | | 1048h | ICLR | Interrupt clear | CPU_INT | Go | | 1050h | IIDX | Interrupt Index Register | DMA_TRIG_<br>RX | Go | | 1058h | IMASK | Interrupt mask | DMA_TRIG_<br>RX | Go | | 1060h | RIS | Raw interrupt status | DMA_TRIG_<br>RX | Go | | 1068h | MIS | Masked interrupt status | DMA_TRIG_<br>RX | Go | | 1070h | ISET | Interrupt set | DMA_TRIG_<br>RX | Go | | 1078h | ICLR | Interrupt clear | DMA_TRIG_<br>RX | Go | | 1080h | IIDX | Interrupt Index Register | DMA_TRIG_T<br>X | Go | | 1088h | IMASK | Interrupt mask | DMA_TRIG_T<br>X | Go | | 1090h | RIS | Raw interrupt status | DMA_TRIG_T<br>X | Go | | 1098h | MIS | Masked interrupt status | DMA_TRIG_T<br>X | Go | | 10A0h | ISET | Interrupt set | DMA_TRIG_T<br>X | Go | | 10A8h | ICLR | Interrupt clear | DMA_TRIG_T<br>X | Go | | 10E0h | EVT_MODE | Event Mode | | Go | | 10E4h | INTCTL | Interrupt control register | | Go | | 1100h | CTL0 | SPI control register 0 | | Go | | 1104h | CTL1 | SPI control register 1 | | Go | | 1108h | CLKCTL | Clock prescaler and divider register. | | Go | | 110Ch | IFLS | Interrupt FIFO Level Select Register | | Go | | 1110h | STAT | Status Register | | Go | | | | | | | Table 15-7. SPI Registers (continued) | Offse | Acronym | Register Name | Group | Section | |-------|---------|-----------------|-------|---------| | 1130h | RXDATA | RXDATA Register | | Go | | 1140h | TXDATA | TXDATA Register | | Go | Complex bit access types are encoded to fit into small table cells. Table 15-8 shows the codes that are used for access types in this section. Table 15-8. SPI Access Type Codes | Access Type | Code | Description | |------------------------|--------|----------------------------------------| | Read Type | | | | R | R | Read | | Write Type | | | | W | W | Write | | WK | W<br>K | Write<br>Write protected by a key | | Reset or Default Value | | | | -n | | Value after reset or the default value | # 15.3.1 PWREN (Offset = 800h) [Reset = 00000000h] PWREN is shown in Figure 15-8 and described in Table 15-9. Return to the Summary Table. Register to control the power state # Figure 15-8. PWREN # Table 15-9. PWREN Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|----------------------------------------------------------------------------------------------------| | 31-24 | KEY | W | 0h | KEY to allow Power State Change<br>26h = KEY to allow write access to this register | | 23-1 | RESERVED | R/W | 0h | | | 0 | ENABLE | R/WK | | Enable the power KEY must be set to 26h to write to this bit. 0h = Disable Power 1h = Enable Power | # 15.3.2 RSTCTL (Offset = 804h) [Reset = 00000000h] RSTCTL is shown in Figure 15-9 and described in Table 15-10. Return to the Summary Table. Register to control reset assertion and de-assertion # Figure 15-9. RSTCTL ### Table 15-10. RSTCTL Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|--------------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------| | 31-24 | KEY | W | 0h | Unlock key B1h = KEY to allow write access to this register | | 23-2 | RESERVED | W | 0h | | | 1 | RESETSTKYCLR | WK | 0h | Clear the RESETSTKY bit in the STAT register KEY must be set to B1h to write to this bit. 0h = Writing 0 has no effect 1h = Clear reset sticky bit | | 0 | RESETASSERT | WK | 0h | Assert reset to the peripheral KEY must be set to B1h to write to this bit. 0h = Writing 0 has no effect 1h = Assert reset | # 15.3.3 CLKCFG (Offset = 808h) [Reset = 00000000h] CLKCFG is shown in Figure 15-10 and described in Table 15-11. Return to the Summary Table. Peripheral Clock Configuration Register # Figure 15-10. CLKCFG | | | | ga.o .o . | | | | | | | | | |----|----------|----|-----------|------|----|----|------------|--|--|--|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | | | KEY | | | | | | | | | | | | | W-0h | | | | | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | | | | | RESE | RVED | | | | | | | | | | | | R/V | V-0h | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | | | | RESERVED | | | | BLOCKASYNC | | | | | | | | | R/W-0h | | | | R/W-0h | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | RESERVED | | | | | | | | | | | | | R/W-0h | | | | | | | | | | | | | | | | | | | | | | | | # **Table 15-11. CLKCFG Field Descriptions** | Bit | Field | Туре | Reset | Description | |-------|------------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------| | 31-24 | KEY | W | 0h | KEY to Allow State Change 0xA9<br>A9h = key value to allow change field of GPRCM | | 23-9 | RESERVED | R/W | 0h | | | 8 | BLOCKASYNC | R/W | 0h | Async Clock Request is blocked from starting SYSOSC or forcing bus clock to 32MHz 0h = Not block async clock request 1h = Block async clock request | | 7-0 | RESERVED | R/W | 0h | | # 15.3.4 STAT (Offset = 814h) [Reset = 00000000h] STAT is shown in Figure 15-11 and described in Table 15-12. Return to the Summary Table. peripheral enable and reset status Figure 15-11. STAT ## **Table 15-12. STAT Field Descriptions** | Bit | Field | Туре | Reset | Description | | | | | |-------|-----------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | 31-17 | RESERVED | R | 0h | | | | | | | 16 | RESETSTKY | R | 0h | This bit indicates, if the peripheral was reset, since this bit was cleared by RESETSTKYCLR in the RSTCTL register 0h = The peripheral has not been reset since this bit was last cleared by RESETSTKYCLR in the RSTCTL register 1h = The peripheral was reset since the last bit clear | | | | | | 15-0 | RESERVED | R | 0h | | | | | | # 15.3.5 CLKDIV (Offset = 1000h) [Reset = 00000000h] CLKDIV is shown in Figure 15-12 and described in Table 15-13. Return to the Summary Table. This register is used to specify module-specific divide ratio of the functional clock # Figure 15-12. CLKDIV # **Table 15-13. CLKDIV Field Descriptions** | Table 10 101 021(B) V 1 lota Bocomptions | | | | | | | | |------------------------------------------|----------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | 31-3 | RESERVED | R/W | 0h | | | | | | 2-0 | RATIO | R/W | Oh | Selects divide ratio of module clock 0h = Do not divide clock source 1h = Divide clock source by 2 2h = Divide clock source by 3 3h = Divide clock source by 4 4h = Divide clock source by 5 5h = Divide clock source by 6 6h = Divide clock source by 7 7h = Divide clock source by 8 | | | | # 15.3.6 CLKSEL (Offset = 1004h) [Reset = 00000000h] CLKSEL is shown in Figure 15-13 and described in Table 15-14. Return to the Summary Table. Clock source selection for peripherals # Figure 15-13. CLKSEL ### Table 15-14. CLKSEL Field Descriptions | Bit | Field | Туре | Reset | Description | |------|------------|------|-------|----------------------------------------------------------------------------------------------------------------------------| | 31-4 | RESERVED | R/W | 0h | | | 3 | SYSCLK_SEL | R/W | Oh | Selects SYSCLK as clock source if enabled 0h = Does not select this clock as a source 1h = Select this clock as a source | | 2 | MFCLK_SEL | R/W | Oh | Selects MFCLK as clock source if enabled 0h = Does not select this clock as a source 1h = Select this clock as a source | | 1 | LFCLK_SEL | R/W | Oh | Selects LFCLK as clock source if enabled 0h = Does not select this clock as a source 1h = Select this clock as a source | | 0 | RESERVED | R/W | 0h | | # 15.3.7 PDBGCTL (Offset = 1018h) [Reset = 00000003h] PDBGCTL is shown in Figure 15-14 and described in Table 15-15. Return to the Summary Table. This register can be used by the software developer to control the behavior of the peripheral relative to the 'Core Halted' input Figure 15-14. PDBGCTL # Table 15-15. PDBGCTL Field Descriptions | Table to 10.1 BBGG1E1 leid BGGG1ptions | | | | | | | | |----------------------------------------|----------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | 31-2 | RESERVED | R/W | 0h | | | | | | 1 | SOFT | R/W | 1h | Soft halt boundary control. This function is only available, if FREE is set to 'STOP' Oh = The peripheral will halt immediately, even if the resultant state will result in corruption if the system is restarted 1h = The peripheral blocks the debug freeze until it has reached a boundary where it can resume without corruption | | | | | 0 | FREE | R/W | 1h | Free run control 0h = The peripheral freezes functionality while the Core Halted input is asserted and resumes when it is deasserted. 1h = The peripheral ignores the state of the Core Halted input | | | | # 15.3.8 IIDX (Offset = 1020h) [Reset = 00000000h] IIDX is shown in Figure 15-15 and described in Table 15-16. Return to the Summary Table. This register provides the highest priority enabled interrupt index. Value 0x00 means no event pending. Interrupt 1 is the highest priority, IIDX next highest, 4, 8, ... IIDX^31 is the least priority. That is, the least bit position that is set to 1 denotes the highest priority pending interrupt. The priority order is fixed. However, users can implement their own prioritization schemes using other registers that expose the full set of interrupts that have occurred. On each read, only one interrupt is indicated. On a read, the current interrupt (highest priority) is automatically cleared by the hardware and the corresponding interrupt flag in [RIS] and [MIS] are cleared as well. After a read from the CPU (not from the debug interface), the register is updated with the next highest priority interrupt, if none are pending, then it should display 0x0. ### Figure 15-15. IIDX ## Table 15-16. IIDX Field Descriptions | Reset | Description | |-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0h | | | Oh | Interrupt index status 00h = No interrupt pending 1h = RX FIFO Overflow Event/interrupt pending 2h = Transmit Parity Event/interrupt pending 3h = SPI receive time-out interrupt 4h = Receive Event/interrupt pending 5h = Transmit Event/interrupt pending 6h = Transmit Buffer Empty Event/interrupt pending 7h = End of Transmit Event/interrupt pending 8h = DMA Done for Receive Event/interrupt pending 9h = DMA Done for Transmit Event/interrupt pending Ah = TX FIFO underflow interrupt Bh = RX FIFO Full Interrupt | | | 0h | # 15.3.9 IMASK (Offset = 1028h) [Reset = 00000000h] IMASK is shown in Figure 15-16 and described in Table 15-17. Return to the Summary Table. Interrupt Mask. If a bit is set, then corresponding interrupt is un-masked. Un-masking the interrupt causes the raw interrupt to be visible in IIDX, as well as MIS. Figure 15-16. IMASK | | | | i igaic io | TO. INIAOIX | | | | | |-----------------|---------------------------------------|---------|------------|-------------|--------|--------|------------|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | | RESE | RVED | | | | | | | R/W-0h | | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | RESERVED | | | | | | | | | R/W-0h | | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | RESERVED RXFULL TXFIFO_UNF DMA_DONE X | | | | | | | | | | | R/W-0h | | | R/W-0h | R/W-0h | R/W-0h | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | DMA_DONE_R<br>X | IDLE | TXEMPTY | TX | RX | RTOUT | PER | RXFIFO_OVF | | | R/W-0h | # **Table 15-17. IMASK Field Descriptions** | Bit | Field | Туре | Reset | Description | |-------|-------------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------| | 31-11 | RESERVED | R/W | 0h | | | 10 | RXFULL | R/W | 0h | RX FIFO Full Interrupt Mask 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | 9 | TXFIFO_UNF | R/W | Oh | TX FIFO underflow interrupt mask 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | 8 | DMA_DONE_TX | R/W | Oh | DMA Done 1 event for TX event mask. 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | 7 | DMA_DONE_RX | R/W | 0h | DMA Done 1 event for RX event mask. 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | 6 | IDLE | R/W | 0h | SPI Idle event mask. 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | 5 | TXEMPTY | R/W | 0h | Transmit FIFO Empty event mask. 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | 4 | TX | R/W | 0h | Transmit FIFO event mask. 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | 3 | RX | R/W | Oh | Receive FIFO event. This interrupt is set if the selected Receive FIFO level has been reached 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | 2 | RTOUT | R/W | 0h | Enable SPI Receive Time-Out event mask. 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | # **Table 15-17. IMASK Field Descriptions (continued)** | Bit | Field | Туре | Reset | Description | |-----|------------|------|-------|---------------------------------------------------------------------------------| | 1 | PER | R/W | 0h | Parity error event mask. 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | 0 | RXFIFO_OVF | R/W | 0h | RXFIFO overflow event mask. 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | # 15.3.10 RIS (Offset = 1030h) [Reset = 00000000h] RIS is shown in Figure 15-17 and described in Table 15-18. Return to the Summary Table. Raw interrupt status. Reflects all pending interrupts, regardless of masking. The RIS register allows the user to implement a poll scheme. A flag set in this register can be cleared by writing 1 to the ICLR register bit even if the corresponding IMASK bit is not enabled. Figure 15-17. RIS | rigate to 17. No | | | | | | | | |------------------|----------|---------|------------|------------|-------|------|------------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | RESE | RVED | | | | | | R-0h | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | RESE | RVED | | | | | | R-0h | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | RESERVED | RXFULL | TXFIFO_UNF | DMA_DONE_T | | | | | | | R-0h | | | R-0h | R-0h | R-0h | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | DMA_DONE_R<br>X | IDLE | TXEMPTY | TX | RX | RTOUT | PER | RXFIFO_OVF | | R-0h # Table 15-18. RIS Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|-------------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-11 | RESERVED | R | 0h | | | 10 | RXFULL | R | Oh | RX FIFO Full Interrupt 0h = Interrupt did not occur 1h = Interrupt occurred | | 9 | TXFIFO_UNF | R | 0h | TX FIFO Underflow Interrupt 0h = Interrupt did not occur 1h = Interrupt occurred | | 8 | DMA_DONE_TX | R | Oh | DMA Done 1 event for TX. This interrupt is set if the TX DMA channel sends the DONE signal. This allows the handling of the DMA event inside the mapped peripheral. Oh = Interrupt did not occur Th = Interrupt occurred | | 7 | DMA_DONE_RX | R | 0h | DMA Done 1 event for RX. This interrupt is set if the RX DMA channel sends the DONE signal. This allows the handling of the DMA event inside the mapped peripheral. Oh = Interrupt did not occur Th = Interrupt occurred | | 6 | IDLE | R | Oh | SPI has done finished transfers and changed into IDLE mode. This bit is set when BUSY goes low. 0h = Interrupt did not occur 1h = Interrupt occurred | | 5 | TXEMPTY | R | Oh | Transmit FIFO Empty interrupt mask. This interrupt is set if all data in the Transmit FIFO have been move to the shift register. 0h = Interrupt did not occur 1h = Interrupt occurred | | 4 | TX | R | Oh | Transmit FIFO eventThis interrupt is set if the selected Transmit FIFO level has been reached. 0h = Interrupt did not occur 1h = Interrupt occurred | # Table 15-18. RIS Field Descriptions (continued) | Bit | Field | Туре | Reset | Description | |-----|------------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------| | 3 | RX | R | 0h | Receive FIFO event. This interrupt is set if the selected Receive FIFO level has been reached 0h = Interrupt did not occur 1h = Interrupt occurred | | 2 | RTOUT | R | 0h | SPI Receive Time-Out event. 0h = Interrupt did not occur 1h = Interrupt occurred | | 1 | PER | R | 0h | Parity error event: this bit is set if a Parity error has been detected 0h = Interrupt did not occur 1h = Interrupt occurred | | 0 | RXFIFO_OVF | R | 0h | RXFIFO overflow event. This interrupt is set if an RX FIFO overflow has been detected. 0h = Interrupt did not occur 1h = Interrupt occurred | # 15.3.11 MIS (Offset = 1038h) [Reset = 00000000h] MIS is shown in Figure 15-18 and described in Table 15-19. Return to the Summary Table. Masked interrupt status. This is an AND of the IMASK and RIS registers. # Figure 15-18. MIS | | | | i igaic i | 0 10. 11110 | | | | | | |-----------------|----------------|----------|-----------|-------------|--------|------------|------------|--|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | RESERVED | | | | | | | | | | | R-0h | | | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | | | RESE | RVED | | | | | | | | R-0h | | | | | | | | | | 15 | 15 14 13 12 11 | | | | 10 | 9 | 8 | | | | | | RESERVED | | | RXFULL | TXFIFO_UNF | DMA_DONE_T | | | | | | R-0h | | | R-0h | R-0h | R-0h | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | DMA_DONE_R<br>X | IDLE | TXEMPTY | TX | RX | RTOUT | PER | RXFIFO_OVF | | | | R-0h | | # Table 15-19. MIS Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|-------------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-11 | RESERVED | R | 0h | | | 10 | RXFULL | R | Oh | RX FIFO Full Interrupt 0h = Interrupt did not occur 1h = Interrupt occurred | | 9 | TXFIFO_UNF | R | Oh | TX FIFO underflow interrupt 0h = Interrupt did not occur 1h = Interrupt occurred | | 8 | DMA_DONE_TX | R | Oh | Masked DMA Done 1 event for TX. 0h = Interrupt did not occur 1h = Interrupt occurred | | 7 | DMA_DONE_RX | R | Oh | Masked DMA Done 1 event for RX. 0h = Interrupt did not occur 1h = Interrupt occurred | | 6 | IDLE | R | Oh | Masked SPI IDLE mode event. 0h = Interrupt did not occur 1h = Interrupt occurred | | 5 | TXEMPTY | R | Oh | Masked Transmit FIFO Empty event. 0h = Interrupt did not occur 1h = Interrupt occurred | | 4 | TX | R | 0h | Masked Transmit FIFO event. This interrupt is set if the selected Transmit FIFO level has been reached. 0h = Interrupt did not occur 1h = Interrupt occurred | | 3 | RX | R | 0h | Masked receive FIFO event. This interrupt is set if the selected Receive FIFO level has been reached 0h = Interrupt did not occur 1h = Interrupt occurred | | 2 | RTOUT | R | Oh | Masked SPI Receive Time-Out Interrupt. 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | # **Table 15-19. MIS Field Descriptions (continued)** | E | 3it | Field | Туре | Reset | Description | |---|-----|------------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------| | | 1 | PER | R | 0h | Masked Parity error event: this bit if a Parity error has been detected 0h = Interrupt did not occur 1h = Interrupt occurred | | | 0 | RXFIFO_OVF | R | 0h | Masked RXFIFO overflow event. This interrupt is set if an RX FIFO overflow has been detected. 0h = Interrupt did not occur 1h = Interrupt occurred | # 15.3.12 ISET (Offset = 1040h) [Reset = 00000000h] ISET is shown in Figure 15-19 and described in Table 15-20. Return to the Summary Table. Interrupt set. Allows interrupts to be set by software (useful in diagnostics and safety checks). Writing a 1 to a bit in ISET will set the event and therefore the related RIS bit also gets set. If the interrupt is enabled through the mask, then the corresponding MIS bit is also set. Figure 15-19. ISET | | | | rigule is | )-19.13L1 | | | | |-----------------|-------------|----------|-----------|-----------|--------|------------|--------------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | RESE | RVED | | | | | | | | W | -0h | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | RESE | RVED | | | | | | W-0h | | | | | | | | 15 | 14 13 12 11 | | | | 10 | 9 | 8 | | | | RESERVED | | | RXFULL | TXFIFO_UNF | DMA_DONE_T X | | | | W-0h | | | W-0h | W-0h | W-0h | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | DMA_DONE_R<br>X | IDLE | TXEMPTY | TX | RX | RTOUT | PER | RXFIFO_OVF | | W-0h # Table 15-20. ISET Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|-------------|------|-------|--------------------------------------------------------------------------------------| | 31-11 | RESERVED | W | 0h | | | 10 | RXFULL | W | 0h | Set RX FIFO Full Event 0h = Writing has no effect 1h = Set Interrupt | | 9 | TXFIFO_UNF | W | 0h | Set TX FIFO Underflow Event 0h = Writing has no effect 1h = Set interrupt | | 8 | DMA_DONE_TX | W | 0h | Set DMA Done 1 event for TX. 0h = Writing 0 has no effect 1h = Set Interrupt | | 7 | DMA_DONE_RX | W | 0h | Set DMA Done 1 event for RX. 0h = Writing 0 has no effect 1h = Set Interrupt | | 6 | IDLE | W | 0h | Set SPI IDLE mode event. 0h = Writing 0 has no effect 1h = Set Interrupt | | 5 | TXEMPTY | W | 0h | Set Transmit FIFO Empty event. 0h = Writing 0 has no effect 1h = Set Interrupt | | 4 | TX | W | 0h | Set Transmit FIFO event. 0h = Writing 0 has no effect 1h = Set Interrupt | | 3 | RX | W | 0h | Set Receive FIFO event. 0h = Writing 0 has no effect 1h = Set Interrupt | | 2 | RTOUT | W | 0h | Set SPI Receive Time-Out Event. 0h = Writing 0 has no effect 1h = Set Interrupt Mask | # **Table 15-20. ISET Field Descriptions (continued)** | Bit | Field | Туре | Reset | Description | |-----|------------|------|-------|-----------------------------------------------------------------------------| | 1 | PER | W | 0h | Set Parity error event. 0h = Writing 0 has no effect 1h = Set Interrupt | | 0 | RXFIFO_OVF | W | Oh | Set RXFIFO overflow event. 0h = Writing 0 has no effect 1h = Set Interrupt | # 15.3.13 ICLR (Offset = 1048h) [Reset = 00000000h] ICLR is shown in Figure 15-20 and described in Table 15-21. Return to the Summary Table. Interrupt clear. Write a 1 to clear corresponding Interrupt. # Figure 15-20. ICLR | | | | i igaic is | 7-20. IOLIX | | | | | | |-----------------|-------------|----------|------------|-------------|--------|------------|-----------------|--|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | RESERVED | | | | | | | | | | | W-0h | | | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | RESERVED | | | | | | | | | | | W-0h | | | | | | | | | | 15 | 14 13 12 11 | | | | 10 | 9 | 8 | | | | | | RESERVED | | | RXFULL | TXFIFO_UNF | DMA_DONE_T<br>X | | | | | | W-0h | | | W-0h | W-0h | W-0h | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | DMA_DONE_R<br>X | IDLE | TXEMPTY | TX | RX | RTOUT | PER | RXFIFO_OVF | | | | W-0h | | # **Table 15-21. ICLR Field Descriptions** | Bit | Field | Туре | Reset | Description | |-------|-------------|------|-------|----------------------------------------------------------------------------------------| | 31-11 | RESERVED | W | 0h | | | 10 | RXFULL | W | Oh | Clear RX FIFO underflow event 0h = Writing has no effect 1h = Clear interrupt | | 9 | TXFIFO_UNF | W | Oh | Clear TXFIFO underflow event 0h = Writing has no effect 1h = Clear interrupt | | 8 | DMA_DONE_TX | W | Oh | Clear DMA Done 1 event for TX. 0h = Writing 0 has no effect 1h = Clear Interrupt | | 7 | DMA_DONE_RX | W | Oh | Clear DMA Done 1 event for RX. 0h = Writing 0 has no effect 1h = Clear Interrupt | | 6 | IDLE | W | Oh | Clear SPI IDLE mode event. 0h = Writing 0 has no effect 1h = Clear Interrupt | | 5 | TXEMPTY | W | Oh | Clear Transmit FIFO Empty event. 0h = Writing 0 has no effect 1h = Clear Interrupt | | 4 | TX | W | 0h | Clear Transmit FIFO event. 0h = Writing 0 has no effect 1h = Clear Interrupt | | 3 | RX | W | Oh | Clear Receive FIFO event. 0h = Writing 0 has no effect 1h = Clear Interrupt | | 2 | RTOUT | W | 0h | Clear SPI Receive Time-Out Event. 0h = Writing 0 has no effect 1h = Set Interrupt Mask | # **Table 15-21. ICLR Field Descriptions (continued)** | Bit | Field | Туре | Reset | Description | |-----|------------|------|-------|--------------------------------------------------------------------------------| | 1 | PER | W | 0h | Clear Parity error event. 0h = Writing 0 has no effect 1h = Clear Interrupt | | 0 | RXFIFO_OVF | W | 0h | Clear RXFIFO overflow event. 0h = Writing 0 has no effect 1h = Clear Interrupt | # 15.3.14 IIDX (Offset = 1050h) [Reset = 00000000h] IIDX is shown in Figure 15-21 and described in Table 15-22. Return to the Summary Table. This register provides the highest priority enabled interrupt index. Value 0x00 means no event pending. Interrupt 1 is the highest priority, IIDX next highest, 4, 8, ... IIDX^31 is the least priority. That is, the least bit position that is set to 1 denotes the highest priority pending interrupt. The priority order is fixed. However, users can implement their own prioritization schemes using other registers that expose the full set of interrupts that have occurred. On each read, only one interrupt is indicated. On a read, the current interrupt (highest priority) is automatically cleared by the hardware and the corresponding interrupt flag in [RIS] and [MIS] are cleared as well. After a read from the CPU (not from the debug interface), the register is updated with the next highest priority interrupt, if none are pending, then it should display 0x0. ### Figure 15-21. IIDX ### Table 15-22. IIDX Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|-------------------------------------------------------------------------------------------------------------------------------| | 31-8 | RESERVED | R | 0h | | | 7-0 | STAT | R | | Interrupt index status 00h = No interrupt pending 3h = SPI receive time-out interrupt 4h = Receive Event/interrupt pending | # 15.3.15 IMASK (Offset = 1058h) [Reset = 00000000h] IMASK is shown in Figure 15-22 and described in Table 15-23. Return to the Summary Table. Interrupt Mask. If a bit is set, then corresponding interrupt is un-masked. Un-masking the interrupt causes the raw interrupt to be visible in IIDX, as well as MIS. Figure 15-22. IMASK # Table 15-23. IMASK Field Descriptions | | Table 10 201 min text 1 lota 2 coon priorite | | | | | | | | |------|----------------------------------------------|------|-------|--------------------------------------------------------------------------------------|--|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | | 31-4 | RESERVED | R/W | 0h | | | | | | | 3 | RX | R/W | Oh | Receive FIFO event mask. 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | | | | 2 | RTOUT | R/W | Oh | SPI Receive Time-Out event mask. 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | | | | 1-0 | RESERVED | R/W | 0h | | | | | | # 15.3.16 RIS (Offset = 1060h) [Reset = 00000000h] RIS is shown in Figure 15-23 and described in Table 15-24. Return to the Summary Table. Raw interrupt status. Reflects all pending interrupts, regardless of masking. The RIS register allows the user to implement a poll scheme. A flag set in this register can be cleared by writing 1 to the ICLR register bit even if the corresponding IMASK bit is not enabled. Figure 15-23. RIS ## **Table 15-24. RIS Field Descriptions** | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------| | 31-4 | RESERVED | R | 0h | | | 3 | RX | R | 0h | Receive FIFO event. This interrupt is set if the selected Receive FIFO level has been reached 0h = Interrupt did not occur 1h = Interrupt occurred | | 2 | RTOUT | R | Oh | SPI Receive Time-Out Event. 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | 1-0 | RESERVED | R | 0h | | # 15.3.17 MIS (Offset = 1068h) [Reset = 00000000h] MIS is shown in Figure 15-24 and described in Table 15-25. Return to the Summary Table. Masked interrupt status. This is an AND of the IMASK and RIS registers. # Figure 15-24. MIS | | | | 9 | | | | | | |----------|----|----|----|------|-------|------|------|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | RESERVED | | | | | | | | | | R-0h | | | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | RESERVED | | | | | | | | | | R-0h | | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | RESERVED | | | | | | | | | | R-0h | | | | | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | RESERVED | | | | RX | RTOUT | RESE | RVED | | | R-0h | | | | R-0h | R-0h | R- | ·0h | | # **Table 15-25. MIS Field Descriptions** | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|--------------------------------------------------------------------------------------| | 31-4 | RESERVED | R | 0h | | | 3 | RX | R | 0h | Receive FIFO event mask. 0h = Interrupt did not occur 1h = Interrupt occurred | | 2 | RTOUT | R | Oh | SPI Receive Time-Out event mask. 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | 1-0 | RESERVED | R | 0h | | # 15.3.18 ISET (Offset = 1070h) [Reset = 00000000h] ISET is shown in Figure 15-25 and described in Table 15-26. Return to the Summary Table. Interrupt set. Allows interrupts to be set by software (useful in diagnostics and safety checks). Writing a 1 to a bit in ISET will set the event and therefore the related RIS bit also gets set. If the interrupt is enabled through the mask, then the corresponding MIS bit is also set. Figure 15-25. ISET #### Table 15-26. ISET Field Descriptions | | the state of s | | | | |------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|--------------------------------------------------------------------------------------| | Bit | Field | Туре | Reset | Description | | 31-4 | RESERVED | W | 0h | | | 3 | RX | W | 0h | Set Receive FIFO event. 0h = Writing 0 has no effect 1h = Set Interrupt | | 2 | RTOUT | W | 0h | Set SPI Receive Time-Out event. 0h = Writing 0 has no effect 1h = Set Interrupt Mask | | 1-0 | RESERVED | W | 0h | | # 15.3.19 ICLR (Offset = 1078h) [Reset = 00000000h] ICLR is shown in Figure 15-26 and described in Table 15-27. Return to the Summary Table. Interrupt clear. Write a 1 to clear corresponding Interrupt. # Figure 15-26. ICLR # Table 15-27. ICLR Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|----------------------------------------------------------------------------------------| | 31-4 | RESERVED | W | 0h | | | 3 | RX | W | 0h | Clear Receive FIFO event. 0h = Writing 0 has no effect 1h = Clear Interrupt | | 2 | RTOUT | W | 0h | Clear SPI Receive Time-Out event. 0h = Writing 0 has no effect 1h = Set Interrupt Mask | | 1-0 | RESERVED | W | 0h | | # 15.3.20 IIDX (Offset = 1080h) [Reset = 00000000h] IIDX is shown in Figure 15-27 and described in Table 15-28. Return to the Summary Table. This register provides the highest priority enabled interrupt index. Value 0x00 means no event pending. Interrupt 1 is the highest priority, IIDX next highest, 4, 8, ... IIDX^31 is the least priority. That is, the least bit position that is set to 1 denotes the highest priority pending interrupt. The priority order is fixed. However, users can implement their own prioritization schemes using other registers that expose the full set of interrupts that have occurred. On each read, only one interrupt is indicated. On a read, the current interrupt (highest priority) is automatically cleared by the hardware and the corresponding interrupt flag in [RIS] and [MIS] are cleared as well. After a read from the CPU (not from the debug interface), the register is updated with the next highest priority interrupt, if none are pending, then it should display 0x0. ## Figure 15-27. IIDX ## Table 15-28. IIDX Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|-------------------------------------------------------------------------------------------| | 31-8 | RESERVED | R | 0h | | | 7-0 | STAT | R | | Interrupt index status 00h = No interrupt pending 5h = Transmit Event/interrupt pending | # 15.3.21 IMASK (Offset = 1088h) [Reset = 00000000h] IMASK is shown in Figure 15-28 and described in Table 15-29. Return to the Summary Table. Interrupt Mask. If a bit is set, then corresponding interrupt is un-masked. Un-masking the interrupt causes the raw interrupt to be visible in IIDX, as well as MIS. Figure 15-28. IMASK # **Table 15-29. IMASK Field Descriptions** | | Bit | Field | Туре | Reset | Description | |---|------|----------|------|-------|-------------------------------------------------------------------------------| | | 31-5 | RESERVED | R/W | 0h | | | | 4 | TX | R/W | 0h | Transmit FIFO event mask. 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | Ī | 3-0 | RESERVED | R/W | 0h | | # 15.3.22 RIS (Offset = 1090h) [Reset = 00000000h] RIS is shown in Figure 15-29 and described in Table 15-30. Return to the Summary Table. Raw interrupt status. Reflects all pending interrupts, regardless of masking. The RIS register allows the user to implement a poll scheme. A flag set in this register can be cleared by writing 1 to the ICLR register bit even if the corresponding IMASK bit is not enabled. Figure 15-29. RIS Table 15-30. RIS Field Descriptions | 14400 10 001 140 1 1014 2000 1 1410 1 | | | | | | | | | |---------------------------------------|----------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | | 31-5 | RESERVED | R | 0h | | | | | | | 4 | TX | R | Oh | Transmit FIFO event: A read returns the current mask for transmit FIFO interrupt. On a write of 1, the mask for transmit FIFO interrupt is set which means the interrupt state will be reflected in MIS.TXMIS. A write of 0 clears the mask which means MIS.TXMIS will not reflect the interrupt. Oh = Interrupt did not occur 1h = Interrupt occurred | | | | | | 3-0 | RESERVED | R | 0h | | | | | | # 15.3.23 MIS (Offset = 1098h) [Reset = 00000000h] MIS is shown in Figure 15-30 and described in Table 15-31. Return to the Summary Table. Masked interrupt status. This is an AND of the IMASK and RIS registers. # Figure 15-30. MIS # Table 15-31. MIS Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|---------------------------------------------------------------------------------| | 31-5 | RESERVED | R | 0h | | | 4 | TX | R 0h | | Masked Transmit FIFO event 0h = Interrupt did not occur 1h = Interrupt occurred | | 3-0 | RESERVED | R | 0h | | # 15.3.24 ISET (Offset = 10A0h) [Reset = 00000000h] ISET is shown in Figure 15-31 and described in Table 15-32. Return to the Summary Table. Interrupt set. Allows interrupts to be set by software (useful in diagnostics and safety checks). Writing a 1 to a bit in ISET will set the event and therefore the related RIS bit also gets set. If the interrupt is enabled through the mask, then the corresponding MIS bit is also set. Figure 15-31. ISET Table 15-32. ISET Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|--------------------------------------------------------------------------| | 31-5 | RESERVED | W | 0h | | | 4 | TX | W | | Set Transmit FIFO event. 0h = Writing 0 has no effect 1h = Set Interrupt | | 3-0 | RESERVED | W | 0h | | # 15.3.25 ICLR (Offset = 10A8h) [Reset = 00000000h] ICLR is shown in Figure 15-32 and described in Table 15-33. Return to the Summary Table. Interrupt clear. Write a 1 to clear corresponding Interrupt. # Figure 15-32. ICLR # **Table 15-33. ICLR Field Descriptions** | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|--------------------------------------------------------------------------------| | 31-5 | RESERVED | W | 0h | | | 4 | TX | W | Oh | Clear Transmit FIFO event. 0h = Writing 0 has no effect 1h = Clear Interrupt | | 3-0 | RESERVED | W | 0h | | # 15.3.26 EVT\_MODE (Offset = 10E0h) [Reset = 00000029h] EVT\_MODE is shown in Figure 15-33 and described in Table 15-34. Return to the Summary Table. Event mode register. It is used to select whether each line is disabled, in software mode (software clears the RIS) or in hardware mode (hardware clears the RIS) Figure 15-33. EVT\_MODE # Table 15-34. EVT\_MODE Field Descriptions | Tubic to the Ext_inebE field becompliant | | | | | | | | |------------------------------------------|----------|-------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | 31-6 | RESERVED | /ED R/W 0h | | | | | | | 5-4 | INT2_CFG | T2_CFG R 2h | | Event line mode select for event corresponding to none.INT_EVENT2 Oh = The interrupt or event line is disabled. 1h = The interrupt or event line is in software mode. Software must clear the RIS. 2h = The interrupt or event line is in hardware mode. The hardware (another module) clears automatically the associated RIS flag. | | | | | 3-2 | INT1_CFG | R | 2h | Event line mode select for event corresponding to none.INT_EVENT1 Oh = The interrupt or event line is disabled. 1h = The interrupt or event line is in software mode. Software must clear the RIS. 2h = The interrupt or event line is in hardware mode. The hardware (another module) clears automatically the associated RIS flag. | | | | | 1-0 | INT0_CFG | R | 1h | Event line mode select for event corresponding to none.INT_EVENT0 0h = The interrupt or event line is disabled. 1h = The interrupt or event line is in software mode. Software must clear the RIS. 2h = The interrupt or event line is in hardware mode. The hardware (another module) clears automatically the associated RIS flag. | | | | # 15.3.27 INTCTL (Offset = 10E4h) [Reset = 00000000h] INTCTL is shown in Figure 15-34 and described in Table 15-35. Return to the Summary Table. Interrupt control register # Figure 15-34. INTCTL # **Table 15-35. INTCTL Field Descriptions** | Bit | Field | Туре | Reset | Description | | | |------|----------|--------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | 31-1 | RESERVED | R/W 0h | | | | | | 0 | INTEVAL | W | | Writing a 1 to this field re-evaluates the interrupt sources. 0h = The interrupt or event line is disabled. 1h = The interrupt or event line is in software mode. Software must clear the RIS. | | | # 15.3.28 CTL0 (Offset = 1100h) [Reset = 00000000h] CTL0 is shown in Figure 15-35 and described in Table 15-36. Return to the Summary Table. SPI control register 0 Figure 15-35. CTL0 # Table 15-36. CTL0 Field Descriptions | Bit | Field | Туре | Reset | Description | | | |-------|----------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | 31-15 | RESERVED | R/W | 0h | | | | | 14 | CSCLR | R/W | Oh | Clear shift register counter on CS inactive This bit is relevant only in the peripheral, CTL1.CP=0. 0h = Disable automatic clear of shift register when CS goes to disable. 1h = Enable automatic clear of shift register when CS goes to disable. | | | | 13-12 | CSSEL | R/W | Oh | Select the CS line to control on data transfer This bit is applicable for both controller/target mode 0h (R/W) = CS line select: 0 1h (R/W) = CS line select: 1 2h (R/W) = CS line select: 2 3h (R/W) = CS line select: 3 | | | | 11-10 | RESERVED | R/W | 0h | | | | | 9 | SPH | R/W | Oh | CLKOUT phase (Motorola SPI frame format only) This bit selects the clock edge that captures data and enables it to change state. It has the most impact on the first bit transmitted by either permitting or not permitting a clock transition before the first data capture edge. Oh = Data is captured on the first clock edge transition. 1h = Data is captured on the second clock edge transition. | | | | 8 | SPO | R/W | 0h | CLKOUT polarity (Motorola SPI frame format only) 0h = SPI produces a steady state LOW value on the CLKOUT 1h = SPI produces a steady state HIGH value on the CLKOUT | | | | 7 | PACKEN | R/W | 0h | Packing Enable. When 1, packing feature is enabled inside the IP When 0, packing feature is disabled inside the IP 0h = Packing feature disabled 1h = Packing feature enabled | | | # Table 15-36. CTL0 Field Descriptions (continued) | Bit | Field | Туре | Reset | Description (continued) | |-----|-------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 6-5 | FRF | R/W | Oh | Frame format Select 0h = Motorola SPI frame format (3 wire mode) 1h = Motorola SPI frame format (4 wire mode) 2h = TI synchronous serial frame format 3h = National Microwire frame format | | 4-0 | DSS | R/W | Oh | Data Size Select. Values 0 - 2 are reserved and shall not be used. 3h = 4_BIT : 4-bit data SPI allows only values up to 16 Bit 3h (R/W) = Data Size Select bits: 4 4h (R/W) = Data Size Select bits: 5 5h (R/W) = Data Size Select bits: 6 6h (R/W) = Data Size Select bits: 7 7h (R/W) = Data Size Select bits: 8 8h (R/W) = Data Size Select bits: 9 9h (R/W) = Data Size Select bits: 10 Ah (R/W) = Data Size Select bits: 11 Bh (R/W) = Data Size Select bits: 12 Ch (R/W) = Data Size Select bits: 13 Dh (R/W) = Data Size Select bits: 14 Eh (R/W) = Data Size Select bits: 15 Fh (R/W) = Data Size Select bits: 15 | # 15.3.29 CTL1 (Offset = 1104h) [Reset = 00000004h] CTL1 is shown in Figure 15-36 and described in Table 15-37. Return to the Summary Table. SPI control register 1 # Figure 15-36. CTL1 | 1 19416 10-00: 0121 | | | | | | | | | | |---------------------|--------|--------|--------|----------|----------|--------|--------|--|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | RESE | RVED | | | RXTIM | IEOUT | | | | | | R/W | '-0h | | | R/W-0h | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | | | REPE | ATTX | | | | | | | | R/W-0h | | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | CDN | MODE | | CDENABLE | RESERVED | | PTEN | | | | | R/\ | V-0h | | R/W-0h | R/W-0h | | R/W-0h | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | RESERVED | PES | PREN | MSB | POD | СР | LBM | ENABLE | | | | R/W-0h | R/W-0h | R/W-0h | R/W-0h | R/W-0h | R/W-1h | R/W-0h | R/W-0h | | | # Table 15-37. CTL1 Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|-----------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-30 | RESERVED | R/W | 0h | | | 29-24 | RXTIMEOUT | R/W | Oh | Receive Timeout (only for Peripheral mode) Defines the number of Clock Cycles before after which the Receive Timeout flag RTOUT is set. The time is calculated using the control register for the clock selection and divider in the Controller mode configuration. A value of 0 disables this function. 0h = Smallest value 3Fh = Highest possible value | | 23-16 | REPEATTX | R/W | Oh Counter to repeat last transfer 0: repeat last transfer is disal repeat the last transfer with the given number. The transfer started with writing a data into the TX Buffer. Sending the data be repeated with the given value, so the data will be transfe times in total. The behavior is identical as if the data would linto the TX Buffer that many times as defined by the value h can be used to clean a transfer or to pull a certain amount of a peripheral. Oh = Smallest value FFh = Highest possible value | | | 15-12 | CDMODE | R/W | Oh | Command/Data Mode Value When CTL1.CDENABLE is 1, CS3 line is used as C/D signal to distinguish between Command (C/D low) and Data (C/D high) information. When a value is written into the CTL1.CDMODE bits, the C/D (CS3) line will go low for the given numbers of byte which are sent by the SPI, starting with the next value to be transmitted after which, C/D line will go high automatically 0: Manual mode with C/D signal as High 1-14: C/D is low while this number of bytes are being sent after which, this field sets to 0 and C/D goes high. Reading this field at any time returns the remaining number of command bytes. 15: Manual mode with C/D signal as Low. 0h = Manual mode: Data 0h = Smallest value Fh = Manual mode: Command | # Table 15-37. CTL1 Field Descriptions (continued) | Bit | Field | Туре | Reset | Description | | |------|----------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | 11 | CDENABLE | R/W | 0h | Command/Data Mode enable 0h = CS3 is used for Chip Select 1h = CS3 is used as CD signal | | | 10-9 | RESERVED | R/W | 0h | | | | 8 | PTEN | R/W | Oh Parity transmit enable If enabled, parity transmission will be done for both control peripheral modes. Oh = Parity transmission is disabled 1h = Parity transmission is enabled | | | | 7 | RESERVED | R/W | 0h | | | | 6 | PES | R/W | Oh | Even Parity Select 0h = Odd Parity mode 1h = Even Parity mode | | | 5 | PREN | R/W | 0h | Parity receive enable If enabled, parity reception check will be done for both controller and peripheral modes In case of a parity miss-match the parity error flag RIS.PER will be set. Oh = Disable Parity receive function 1h = Enable Parity receive function | | | 4 | MSB | R/W | 0h | MSB first select. Controls the direction of the receive and transmit shift register. 0h = LSB first 1h = MSB first | | | 3 | POD | R/W | Oh Peripheral-mode: Data output disabled This bit is relevant only in Peripheral mode. In multiple-pe system topologies, SPI controller can broadcast a messa peripherals, while only one peripheral drives the line. POD can be used by the SPI peripheral to disable driving line. Oh = SPI can drive the MISO output in peripheral mode. 1h = SPI cannot drive the MISO output in peripheral mode. | | | | 2 | СР | R/W | 1h | Controller or peripheral mode select. This bit can be modified only when SPI is disabled, CTL1.ENABLE=0. 0h = Select Peripheral mode 1h = Select Controller Mode | | | 1 | LBM | R/W | 0h | Loop back mode 0h = Disable loopback mode 1h = Enable loopback mode | | | 0 | ENABLE | R/W | 0h | SPI enable 0h = Disable module function 1h = Enable module function | | # 15.3.30 CLKCTL (Offset = 1108h) [Reset = 00000000h] CLKCTL is shown in Figure 15-37 and described in Table 15-38. Return to the Summary Table. Clock prescaler and divider register. This register contains the settings for the Clock prescaler and divider settings. # Figure 15-37. CLKCTL | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----|--------|-------------|------|----|----|--------|----|----|------|------|----|----|----|----|----| | | DSAM | <b>JPLE</b> | | | | | | | RESE | RVED | | | | | | | | R/W | /-0h | | | | | | | R/W | /-0h | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | RESE | RVED | | | | | | | S | CR | | | | | | | R/W-0h | | | | | R/W-0h | | | | | | | | | | # **Table 15-38. CLKCTL Field Descriptions** | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-28 | DSAMPLE | R/W | Oh | Delayed sampling value. In controller mode the data on the input pin will be delayed sampled by the defined clock cycles of internal functional clock hence relaxing the setup time of input data. This setting is useful in systems where the board delays and external peripheral delays are more than the input setup time of the controller. Please refer to the data sheet for values of controller input setup time and assess what DSAMPLE value meets the requirement of the system. Note: High values of DSAMPLE can cause HOLD time violations and must be factored in the calculations. 0h = Smallest value Fh = Highest possible value | | 27-10 | RESERVED | R/W | 0h | | | 9-0 | SCR | R/W | 0h | Serial clock divider: This is used to generate the transmit and receive bit rate of the SPI. The SPI bit rate is (SPI's functional clock frequency)/((SCR+1)*2). SCR is a value from 0-1023. 0h = Smallest value 3FFh = Highest possible value | # 15.3.31 IFLS (Offset = 110Ch) [Reset = 00000012h] IFLS is shown in Figure 15-38 and described in Table 15-39. Return to the Summary Table. The IFLS register is the interrupt FIFO level select register. You can use this register to define the levels at which the TX, RX and timeout interrupt flags are triggered. The interrupts are generated based on a transition through a level rather than being based on the level. That is, the interrupts are generated when the fill level progresses through the trigger level. For example, if the receive trigger level is set to the half-way mark, the interrupt is triggered when the receive FIFO is filled with two or more characters. Out of reset, the TXIFLSEL and RXIFLSEL bits are configured so that the FIFOs trigger an interrupt at the half-way mark. Figure 15-38. IFLS Table 15-39. IFLS Field Descriptions | | Tuble 10 00: II E0 1 leid De3cription3 | | | | | | | |------|----------------------------------------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | 31-6 | RESERVED | R/W | 0h | | | | | | 5-3 | RXIFLSEL | R/W | 2h | SPI Receive Interrupt FIFO Level Select The trigger points for the receive interrupt are as follows: 0h = Reserved 1h = RX FIFO >= 1/4 full 2h = RX FIFO >= 1/2 full (default) 3h = RX FIFO >= 3/4 full 4h = Reserved 5h = RX FIFO is full 6h = Reserved 7h = Trigger when RX FIFO contains >= 1 frame | | | | | 2-0 | TXIFLSEL | R/W | 2h | SPI Transmit Interrupt FIFO Level Select The trigger points for the transmit interrupt are as follows: 0h = Reserved 1h = TX FIFO <= 3/4 empty 2h = TX FIFO <= 1/2 empty (default) 3h = TX FIFO <= 1/4 empty 4h = Reserved 5h = TX FIFO is empty 6h = Reserved 7h = Trigger when TX FIFO has >= 1 frame free Should be used with DMA | | | | # 15.3.32 STAT (Offset = 1110h) [Reset = 0000000Fh] STAT is shown in Figure 15-39 and described in Table 15-40. Return to the Summary Table. Status Register Figure 15-39. STAT # **Table 15-40. STAT Field Descriptions** | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|-------------------------------------------------------------------------------------------------------------------------| | 31-5 | RESERVED | R | 0h | | | 4 | BUSY | R | 0h | Busy 0h = SPI is in idle mode. 1h = SPI is currently transmitting and/or receiving data, or transmit FIFO is not empty. | | 3 | RNF | R | 1h | Receive FIFO not full 0h = Receive FIFO is full. 1h = Receive FIFO is not full. | | 2 | RFE | R | 1h | Receive FIFO empty. 0h = Receive FIFO is not empty. 1h = Receive FIFO is empty. | | 1 | TNF | R | 1h | Transmit FIFO not full 0h = Transmit FIFO is full. 1h = Transmit FIFO is not full. | | 0 | TFE | R | 1h | Transmit FIFO empty. 0h = Transmit FIFO is not empty. 1h = Transmit FIFO is empty. | # 15.3.33 RXDATA (Offset = 1130h) [Reset = 00000000h] RXDATA is shown in Figure 15-40 and described in Table 15-41. Return to the Summary Table. # **RXDATA Register** Reading this register returns value(s) of FIFO. If the FIFO is empty the last read value is returned. Writing has not effect and is ignored. When PACKEN=1, two entries of the FIFO are returned as a 32-bit value. When PACKEN=0, 1 entry of FIFO is returned as 16-bit value. # Figure 15-40. RXDATA # Table 15-41. RXDATA Field Descriptions | Bit | Field | Туре | Reset | Description | | | | |------|-------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | 31-0 | DATA | R | Oh | Received Data When PACKEN=1,two entries of the FIFO are returned as a 32-bit value. When PACKEN=0, 1 entry of FIFO is returned as 16-bit value. As data values are removed by the receive logic from the incoming data frame, they are placed into the entry in the receive FIFO, pointed to by the current FIFO write pointer. Received data less than 16 bits is automatically right justified in the receive buffer. 0h = Smallest value FFFFFFFF = Highest possible value | | | | # 15.3.34 TXDATA (Offset = 1140h) [Reset = 00000000h] TXDATA is shown in Figure 15-41 and described in Table 15-42. Return to the Summary Table. ## **TXDATA Register** Writing puts the data into the TX FIFO. Reading this register returns the last written value. When PACKEN=0, only the lower 16-bits of data written into the register is transferred to one 16-bits wide TX FIFO entry When PACKEN=1, upper and lower 16-bits of 32-bit write data are transferred to two16-bits wide TX FIFO entry ## Figure 15-41. TXDATA # Table 15-42. TXDATA Field Descriptions | | | | | · | |------|-------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Field | Туре | Reset | Description | | 31-0 | DATA | R/W | Oh | Transmit Data When read, last written value will be returned. If the last write to this field was a 32-bit write (with PACKEN=1), 32-bits will be returned and if the last write was a 16-bit write (PACKEN=0), those 16-bits will be returned. When written, one or two FIFO entries will be written depending on PACKEN value. Data values are removed from the transmit FIFO one value at a time by the transmit logic. It is loaded into the transmit serial shifter, then serially shifted out onto the TXD output pin at the programmed bit rate. When a data size of less than 16 bits is selected, the user must right-justify data written to the transmit FIFO. The transmit logic ignores the unused bits. Oh = Smallest value FFFFFFFh = Highest possible value | # Chapter 16 The $I^2C$ module provides a standardized serial interface to transfer data between MSP devices and other external $I^2C$ devices (such as a sensors, memory, or DACs). | 16.1 I <sup>2</sup> C Overview | 812 | |---------------------------------|-----| | 16.2 I <sup>2</sup> C Operation | | | 16.3 I2C Registers | | $f^2C$ www.ti.com ## 16.1 I<sup>2</sup>C Overview The I<sup>2</sup>C module provides a standardized serial interface to transfer data between MSP devices and other external I<sup>2</sup>C devices (such as a sensors, memory, or DACs). #### 16.1.1 Purpose of the Peripheral The I<sup>2</sup>C peripheral provides bidirectional data transfer through a two-wire serial bus consisting of a data (SDA) and clock (SCL) line. The I<sup>2</sup>C bus is widely used to interface with devices such as battery management ICs, sensors, other MCUs and so on. This I<sup>2</sup>C peripheral provides the ability to both transmit to and receive from other I<sup>2</sup>C devices on the bus. #### 16.1.2 Features The controller includes I<sup>2</sup>C modules with the following features: - Devices on the I<sup>2</sup>C bus can be designated as either a controller or a target with 7-bit addressing. - Support four I<sup>2</sup>C modes - Controller transmit - Controller receive - Target transmit - Target receive - Supported transmission speeds: - Standard-mode (Sm) with a bit rate up to 100 kbps - Fast-mode (Fm) with a bit rate up to 400 kbps - Fast-mode Plus (Fm+) with a bit rate up to 1 Mbps - · Independent 8-byte FIFOs for reception and transmission - Dual target address capability - · Glitch suppression - · Independent controller and target interrupt generation - Controller operation with arbitration, clock synchronization, multiple controller support - Hardware support for SMBus and PMBus - Clock low timeout detection and interrupt - Quick command capability - · Hardware support for DMA with separate channels for transmit and receive ## 16.1.3 Functional Block Diagram Figure 16-1. I2C Functional Block Diagram #### 16.1.4 Environment and External Connections The I<sup>2</sup>C mode supports any target or controller I<sup>2</sup>C-compatible device. Figure 16-2 shows an example of an I<sup>2</sup>C bus. Each I<sup>2</sup>C peripheral instance is comprised of both controller and target functions where the target can be addressed with 2 independent user defined addresses. A device connected to the I<sup>2</sup>C bus can be considered as the controller or the target when performing data transfers. A controller initiates a data transfer and generates the clock signal SCL. Any device addressed by a controller is considered a target. I<sup>2</sup>C data is communicated using the serial data (SDA) pin and the serial clock (SCL) pin. Both SDA and SCL are open-drain bidirectional and must be connected to a positive supply voltage using a pullup resistor. Figure 16-2. Bus Connection Diagram $l^2C$ www.ti.com ## 16.2 I<sup>2</sup>C Operation This section describes the operation of the I<sup>2</sup>C peripheral. #### 16.2.1 Clock Control ## 16.2.1.1 Clock Select and I<sup>2</sup>C Speed Standard, Fast, and Fast Plus modes are selected using a value in the I<sup>2</sup>C Controller Timer Period (I2CMTPR) register that results in a maximum SCL frequency of: - 100 kbps for Standard mode - · 400 kbps for Fast mode - 1 Mbps for Fast mode Plus The $I^2C$ frequency $I2C\_FREQ$ is determined by the $I2C\_CLK$ frequency and bitfields TPR , $SCL\_LP$ , and $SCL\_HP$ where: - I2C\_CLK is the functional clock frequency to the I<sup>2</sup>C module. Note that the I<sup>2</sup>C internal functional clock is first divided from the source clock: - Use I2Cx.CLKSEL register to select the source of the I<sup>2</sup>C functional clock - BUSSCLK: the current bus clock is selected as the source for I<sup>2</sup>C. The current bus clock depends on power domain. If the I<sup>2</sup>C instance is in power domain 1 (PD1) refer to MCLK, if the I<sup>2</sup>C instance is in power domain 0 (PD0) refer to ULPCLK. - MFCLK: MFCLK is selected as the source for I<sup>2</sup>C, refer to MFCLK. - Use I2Cx.CLKDIV register to select divide ratio of I<sup>2</sup>C function clock, options are from divide by 1 to 8. - SCL LP is the low phase of SCL (which must be fixed at 6) - SCL HP is the high phase of SCL (which must be fixed at 4) - TPR is the programmed value of the TPR bits in the I2Cx.MTPR register. This value is determined by replacing the known variables in the equation below and solving for TPR The I<sup>2</sup>C frequency is calculated as follows: $$I2C FREQ = I2C CLK / ((1+TPR) * (SCL LP + SCL HP))$$ (12) For example, if the I<sup>2</sup>C functional clock frequency is 32 MHz and target SCL frequency is 400 kHz: 12C CLK = 32 MHz I2C FREQ = 400 kHz SCL LP = 6, SCL HP = 4 TPR = (I2C CLK / (I2C FREQ \* (4 + 6))) - 1 TPR = 7 (0x07) Table 16-1. Examples of Controller Clock Setting for Typical Clock Configurations | Functional Clock | TPR Bits<br>Standard Mode<br>100-kHz SCL | TPR Bits<br>Fast Mode<br>400-kHz SCL | TPR Bits<br>Fast Mode Plus<br>1000-kHz SCL | | |------------------|------------------------------------------|--------------------------------------|--------------------------------------------|--| | 4 MHz | 0x03 | - | - | | | 8 MHz | 0x07 | 0x01 | - | | | 20 MHz | 0x13 | 0x04 | 0x01 | | | 32 MHz | 0x1F | 0x07 | 0x02 <sup>(1)</sup> | | | 40 MHz | 0x27 | 0x09 | 0x03 | | (1) With 32-MHz functional clock, TPR = 0x01 generates 1.6-MHz SCL frequency, and TPR = 0x02 generates 1.067-MHz SCL frequency. I<sup>2</sup>C functional clock must be greater than or equal to 20 times the SCL frequency, I2C\_CLK ≥ 20 × I2C\_FREQ. The following minimum functional clock frequencies are required when running certain I2C clock speeds: - I2C\_CLK ≥ 2 MHz when working with I<sup>2</sup>C speed 0 to 100 kHz - I2C CLK ≥ 8 MHz when working with I<sup>2</sup>C speed 100 to 400 kHz - I2C CLK ≥ 20 MHz when working with I<sup>2</sup>C speed 400 kHz to 1 MHz ## 16.2.1.2 Clock Startup The selected clock source is always available and the frequency depends on the power mode, for more information refer to the PMU/Clock section. After enabling the I<sup>2</sup>C module by setting the I2C.PWREN.ENABLE bit, the module is ready to start receiving and transmitting data. ## 16.2.2 Signal Descriptions The I<sup>2</sup>C bus consists of a clock signal and a data signal. The clock signal can be generated either internally (during controller operation) or externally (during target operation). | Device Pin | Function | |------------|-------------------------------| | I2Cx_SCL | l <sup>2</sup> C clock signal | | I2Cx_SDA | I <sup>2</sup> C data signal | #### 16.2.3 General Architecture ## 16.2.3.1 I<sup>2</sup>C Bus Functional Overview The I<sup>2</sup>C bus uses only two signals: SDA and SCL. SDA is the bidirectional serial data line and SCL is the bidirectional serial clock line. The bus is considered idle when both lines are in high state and no transfer is ongoing. Every transaction on the I<sup>2</sup>C bus is 9-bits long, consisting of 8 data bits and 1 acknowledge bit. A transfer is defined as the time between a valid START and STOP condition—as described in Figure 16-3. The number of bytes per transfer is unrestricted; however, each data byte must be followed by an acknowledge bit and data must be transferred MSB first. When a receiver cannot receive another complete byte, it can hold the clock line SCL Low and force the transmitter into a wait state, this process is commonly known as clock stretching. The data transfer continues when the receiver releases the clock SCL. Figure 16-3. Module Data Transfer The data on the SDA line must be stable during the high period of the clock, and the data line can only change when SCL is low (see Figure 16-4), otherwise START or STOP conditions are generated. Figure 16-4. Data Change Period I<sup>2</sup>C www.ti.com #### 16.2.3.2 START and STOP Conditions The protocol of the I<sup>2</sup>C bus defines two states to begin and end a transaction: START and STOP. A high-to-low transition on the SDA line while the SCL is high is defined as a START condition, and a low-to-high transition on the SDA line while SCL is high is defined as a STOP condition. START and STOP conditions are always generated by the controller. The bus is considered busy after a START condition and free after a STOP condition. Figure 16-5. START and STOP Conditions The STOP bit determines if the transaction stops at the end of the data cycle or continues on to a repeated START condition. To generate a single transaction, the $I^2C$ controller target address $I^2Cx.MSA.SADDR$ register is written with the desired address, the $I^2Cx.MSA.DIR$ bit should be set to 1 to start a receive operation and 0 to start a transmit operation , and the control register ( $I^2Cx.MCTR$ ) is written with ACK = X (0 or 1), STOP = 1, START = 1, and RUN = 1 to perform the operation and generate a STOP at the end. When the operation is completed (or aborted due an error) the interrupt flags are set. When the $I^2C$ module operates in Controller receiver mode, the ACK bit is normally (in case of no error) set causing the $I^2C$ bus controller to transmit an acknowledge automatically after each byte. This bit must be cleared when the $I^2C$ bus controller requires no further data to be transmitted from the target transmitter. For more information on $I^2C$ controller mode configuration please refer to Section 16.2.4.1 When operating in target mode, the START and STOP bits in the CPU\_INT.RIS register indicate detection of start and stop conditions on the bus and the CPU\_INT.IMASK can be configured to allow START and STOP to be promoted to controller interrupts (when interrupts are enabled). For more information on I<sup>2</sup>C target mode configuration please refer to Section 16.2.4.2 #### **Bus Status Flags:** - BUSBSY is set when a START is detected on the bus and sequentially cleared when a STOP condition is detected on the bus. It is also cleared after a clock timeout I2Cx.MSR.CLKTO is set once both SCL and SDA are pulled to high. - BUSY is also set after a START/RESTART, and cleared after I2Cx.MCTR.MBLEN bytes of data is transferred. It is also cleared after data is NACK 'd or a STOP. - IDLE is set when the Controller I<sup>2</sup>C State machine is in the IDLE state indicating no ongoing transfer. #### 16.2.3.3 Data Format with 7-Bit Address Data transfers follow the format shown in Figure 16-6. After the START condition, a target address is transmitted. This address is 7-bits long followed by an eighth bit, which is a data direction bit (this bit is only as Controller mode, DIR bit in the I2Cx.MSA register). If the I2Cx.MSA.DIR bit is 0, it indicates a transmit operation (send), and if it is set to 1, it indicates a request to receive data (receive). A data transfer is always terminated by a STOP condition generated by the controller; however, a controller can initiate communications with another device on the bus by generating a repeated START condition and addressing another target without first generating a STOP condition, see section Repeated Start. Various combinations of receive/transmit formats are then possible within a single transfer. The ninth bit is the Acknowledge bit, which is described in Section 16.2.3.4. Figure 16-6. Data Format with 7-Bit Address With the I2Cx.SCTR.GENCALL bit the $I^2$ C module can be enabled to respond on a General Call on the $I^2$ C bus. The General Call is identified by address of 0x00 and the R/W bit set to 0. The General Call interrupt can be enabled with the CPU\_INT.IMASK.GENCALL bit. ## 16.2.3.4 Acknowledge All bus transactions have a required acknowledge clock cycle that is generated by the controller. During the acknowledge cycle, the transmitter (which can be the controller or target) releases the SDA line. To acknowledge the transaction, the receiver must pull down SDA during the acknowledge clock cycle. The acknowledge cycle must comply with the data validity requirements. When a target receiver does not acknowledge the target address, SDA must be left high by the target so that the controller can generate a STOP condition and abort the current transfer or generate a repeated START condition to start a new transfer. If the controller device is acting as a receiver during a transfer, it is responsible for acknowledging each transfer made by the target. Because the controller controls the number of bytes in the transfer, it signals the end of data to the target transmitter by not generating an acknowledge on the last data byte. The target transmitter must then release SDA to allow the controller to generate the STOP or a repeated START condition. A target can generate ACK/NACK manually or automatically. When I2Cx.SACKCTL.ACKOEN=0, the target will send automatic ACK. Note that due to the FIFO, the device will receive and ACK all bytes automatically until the RX FIFO is full. Setting SACKCTL.ACKOEN =1 enables manual ACK. Manual ACK override can be used to evaluate each received byte or to slow down the communication when automatic FIFO reception is not desired. When manual ACK override operation is enabled, the I<sup>2</sup>C target module's clock is pulled low after the last data bit until this SACKCTL.ACKOVAL is written with the indicated response. The reception of new data is indicated by the SRXDONE interrupt flag. If the controller receives a NACK while transmitting data the NACK and MTXDONE bit will be set in the RIS registers. If there is still data in the FIFO the TXEMPTY bit will not be set to inform software that a TX FIFO flush may be required. ## 16.2.3.5 Repeated Start The direction of data flow on SDA can be changed by the controller, without first stopping a transfer, by issuing a repeated START condition. This is called a RESTART, see data format in Figure 16-7. After a RESTART is issued, the target address is again sent out with the new data direction specified by the R/W bit. Figure 16-7. Data Format with Repeated Start A repeated start sequence for a Controller transmit is as follows: - 1. When the device is in the idle state, the Controller writes the target address to the I2Cx.MSA register and configures the DIR bit for the desired transfer type. - 2. Data is written to the I2Cx.MTXDATA register. - 3. When the BUSY bit in the MSR register is 0, the BURSTRUN and START bit in the I2Cx.MCTR register need to be set to initiate a transfer. - 4. Wait till the BUSY bit in the I2Cx.MSR register gets 0. I<sup>2</sup>C www.ti.com 5. The Controller does not generate a STOP condition but instead writes another target address to the I2Cx.MSA register and then sets the BURSTRUN and START bit again with a write operation to initiate the repeated START. A repeated start sequence for a Controller receive is similar: - 1. When the device is in idle, the Controller writes the target address to the I2Cx.MSA register and configures the DIR bit for the desired transfer type. - 2. When the BUSY bit in the I2Cx.MSR register is 0, the BURSTRUN and START bit in the I2Cx.MCTR register need to be set to initiate a transfer. - 3. The controller reads data from the I2Cx.MRXDATA register. - 4. Wait till the BUSY bit in the I2Cx.MSR register gets 0. - 5. The Controller does not generate a STOP condition but instead writes another target address to the I2Cx.MSA register and then sets the BURSTRUN and START bit again with a write operation to initiate the repeated START. # 16.2.3.6 Clock Low Timeout (CLKTO) The I<sup>2</sup>C target can extend the transaction by pulling the clock low to slow down communication. The I<sup>2</sup>C module has a 12-bit programmable counter that is used to track how long the clock has been held low. The upper 8 bits of the count value are software programmable through the I<sup>2</sup>C Controller Clock Low Time-out Count I2Cx.MCLKOCNTLOAD register. The CNTL value programmed in the I2Cx.MCLKOCNTLOAD register has to be greater than 0x01 to enable the CLKTO feature. Please note that the low or high timeout configuration needs to be set only during initialization and not during active state. The application can program the eight most significant bits of the counter to reflect the acceptable cumulative low period in a transaction. Each count is equal to a timeout period of (1 + TPR) × 12 of functional clocks FCLK where the TPR is the programmable timer period. The Controller Clock Low Timeout counter counts for the entire time SCL is held Low continuously. When SCL is high, the Controller Clock Low Timeout Counter is reloaded with the value in the I2Cx.MCLKOCNTLOAD register, and begins counting down from this value at the falling edge of SCL. The internal bus clock generated for the timeout counter keeps running at the programmed I<sup>2</sup>C speed even if SCL is held low on the bus. The I<sup>2</sup>C clock low timeout period is calculated as follows: - Cumulative clock low period = Timeout counter \* One timeout period - One timeout period = I2C\_CLK period \* (1 + TPR) \* 12 - Timeout counter = I2Cx.MCLKOCNTLOAD register (this register contains the upper 8-bits of a 12-bit counter value, the lower 4-bits are set to 0) As an example, if the functional clock is 20 MHz and the $I^2C$ module was operating at 100-kHz speed, the TPR would be equal to 19. See Section 16.2.1.1 on how TPR is calculated. One timeout period is equal to (1 / 20 MHz) × (1 + 19) × 12 or 12 $\mu$ s. Programming the I2Cx.MCLKOCNTLOAD register to 0xDA would translate to the value 0xDA0, because the lower 4-bits are set to 0x0. This would translate to a decimal value of 3488 clocks or a cumulative clock low period of 3488 × 12 $\mu$ s, or 41.856 ms at 100 kHz. The CLKTO bit in the I<sup>2</sup>C Controller Raw Interrupt Status I2Cx.CPU\_INT.RIS register is set when the clock timeout period is reached, allowing the controller to start corrective action to resolve the remote target state. In addition, the CLKTO bit in the I<sup>2</sup>C Controller Status I2Cx.MSR register is set. This bit is cleared after I<sup>2</sup>C goes to idle or during the I<sup>2</sup>C controller reset. The status of the raw SDA and SCL signals are readable by software through the SDA and SCL bits in the I<sup>2</sup>C Controller Bus Monitor I2Cx.MBMON register to help determine the state of the remote target. In the event of a CLKTO condition, application software must choose how it intends to attempt bus recovery. If a CLKTO is detected before the end of a transfer (receive or transmit), software should flush the FIFO before initializing the next transfer. The clock low timeout is needed for SMBus and PMBus implementation. #### Note The Controller clock low timeout counter register I2Cx.MCLKOCNT counts for the entire time SCL is held low continuously. When SCL is high, the counter is reloaded with the value in the I2Cx.MCLKOCNTLOAD register, and begins counting down from this value at the falling edge of SCL. ## 16.2.3.7 Clock Stretching In controller mode, the clock stretching can be disabled if no targets on the bus support it, allowing the controller to reach the maximum speed on the bus. Otherwise the clock can be slowed by a target keeping the clock low or due to the clock status detection delay within the I<sup>2</sup>C module. To ensure compliance to the I<sup>2</sup>C specification, clock stretching needs to be enabled. Clock stretching is activated when either the RX FIFO full or TX FIFO empty is set. Clock stretching support can be enabled or disabled by configuring the CLKSTRETCH bit in I2Cx.MCR register. In the target mode, clock stretching is always enabled and it is signaled by the TREQ and RREQ bits of the I<sup>2</sup>C target status register I2Cx.SSR. - When TREQ bit is set, it indicates the I<sup>2</sup>C controller has been addressed as a target transmitter and is using clock stretching to delay the controller until data has been written to the STXDATA FIFO (Target TX FIFO is empty). - When RREQ bit is set, it indicates the I<sup>2</sup>C controller has outstanding receive data from the I2C controller and is using clock stretching to delay the controller until the data has been read from the SRXDATA FIFO (Target RX FIFO is full). #### Note Clock stretching in target mode may be used together with an asynchronous fast clock request to support bringing the device into a suspended low power mode state upon detection of an I2C start bit, enabling the I2C module to support 100kHz (standard mode) or 400kHz (fast mode) operation out of low power modes where the bus clock speed is below the minimum oversampling speed required by the respective mode. Refer to the clock selection and I<sup>2</sup>C speed section for the minimum frequency requirements. When clock stretching is used together with an asynchronous fast clock request, it is possible for the device to wait in STOP or STANDBY mode when the I<sup>2</sup>C is idle, and when an I<sup>2</sup>C bus edge is seen, the fast clock request will requests SYSOSC at base frequency and the bus clock will switch to SYSOSC at base frequency, allowing the I<sup>2</sup>C module to process the bus transaction and wake the processor if an interrupt is generated. ## 16.2.3.8 Dual Address The I<sup>2</sup>C target interface supports dual address capability for the target. An additional programmable I<sup>2</sup>C Target Own Address Register I2CX. SOAR is provided and can be matched if enabled. When dual address disabled (I2Cx.SOAR2.OAR2EN=0), the I<sup>2</sup>C target provides an ACK on the bus if the address matches the OAR field in the I2Cx.SOAR register. In dual address mode (I2Cx.SOAR2.OAR2EN=1), the I<sup>2</sup>C target provides an ACK on the bus if either the OAR field in the I2Cx.SOAR register or the OAR2 field in the I2Cx.SOAR2 register is matched. The OAR2SEL bit in the I2Cx.SSR register indicates if the address that was ACKed is the alternate address or not. When this bit is clear, it indicates either the primary address match or no OAR2 address match. ## 16.2.3.9 Arbitration A controller can start a transfer only if the bus is idle. It's possible for two or more controllers to generate a START condition within minimum hold time of the START condition. In these situations, an arbitration scheme takes place on the SDA line, while SCL is high (see Figure 16-8). The first controller transmitter that generates a logic high is overruled by the opposing controller generating a logic low and the losing controller releases the bus until the bus is idle again. Arbitration can take place over several bits. Its first stage is a comparison of address bits, and if both controllers are trying to address the same device, arbitration continues on to the comparison of data bits. $I^2C$ www.ti.com Figure 16-8. Arbitration Procedure Between Two Controller Transmitters When an arbitration lost is detected the I2Cx.MSR.ARBLST flag is set. It will be reset by the hardware with the next STOP condition detected on the bus. Additionally the ARBLOST flags in CPU INT.RIS registers are set. If arbitration is lost when the I<sup>2</sup>C controller has initiated a transfer, the application should execute the following steps to correctly handle the arbitration loss: - Flush TX FIFO - Clear and mask the TX Empty interrupt by the TXEMPTY bit through the IMASK and ICLR register. - Once the bus is IDLE, the TXFIFO can be filled and enabled, the TXEMPTY bit can be unmasked and a new transaction can be initiated. ## 16.2.3.10 Multiple Controller Mode When operating in a multiple controller system, the I2Cx.MCR.MMST bit must be set. During the arbitration procedure, the clocks from the different controllers must be synchronized. A device that first generates a low period on SCL overrules the other devices, forcing them to start their own low periods. SCL is then held low by the device with the longest low period. The other devices must wait for SCL to be released before starting their high periods In multiple-controller configuration, the clock synchronization (Figure 16-9) during the arbitration is enabled, the SCL high time counts once the SCL line has been detected high. If not enabled the high time counts as soon as the SCL line has been set high by the I<sup>2</sup>C controller which allows the I<sup>2</sup>C to reach the maximum speed by the I<sup>2</sup>Cx.MTPR register specified speed. Figure 16-9. Clock Synchronization ## 16.2.3.11 Glitch Suppression The $I^2C$ module supports glitch suppression on the SCL and SDA lines to meet the 50ns glitch suppression as specified in the $I^2C$ specification. #### **Analog glitch Filter** By default, an analog glitch filter is enabled and configured to suppress spikes with a pulse width up to 50 ns. $I^2C$ spec advises to suppress noise spikes of less than 50ns. The user can disable this filter by clear the I2Cx.GFCTL.AGFEN bit and the suppression pulse width can also be configured by using I2Cx.GFCTL.AGFEN. The analog glitch filter can only be used to wake up the I<sup>2</sup>C in low-power mode. ## **Digital glitch Filter** The DGFSEL bits in the I2Cx.GFCTL register can be programmed to provide glitch suppression on the SCL and SDA lines and assure proper signal values. The glitch suppression value is in terms of the I<sup>2</sup>C functional clocks. All signals are delayed internally when glitch suppression is nonzero. For example, if DGFSEL bit is set to 0x7, 31 clocks should be added onto the calculation for the expected transaction time, for more information please see register description. Digital glitch filter can't be used to wake up the I2C from low-power mode. | Table 1 | 16-3. | Glitch | Suppre | ession | <b>Filter</b> | |---------|-------|--------|--------|--------|---------------| |---------|-------|--------|--------|--------|---------------| | | Analog Glitch Filter | Digital Glitch Filter | |----------------------------------|----------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------| | Default | Default enabled with 50 ns | Default bypassed | | Pulse width of suppressed spikes | Configurable 5 ns, 10 ns, 25 ns, 50 ns | Programmable I <sup>2</sup> C clock cycle 1, 2, 3, 4, 8, 16, 31 | | Benefits | Available without needing clock | Programmable length to provide extra filtering Stable filtering length | | Limitation | Variation with temperature, voltage, process | Does not work in low-power mode wakeup when there is no sufficient clock . Enabled only after 3 clock cycles after start of I <sup>2</sup> C packet | #### Note The glitch filter configuration within the register I2Cx.GFCTL should only be modified while the I<sup>2</sup>C module for controller and target is not enabled. #### 16.2.3.12 FIFO operation The receive data register I2Cx.MRXDATA (for controller mode) and I2Cx.SRXDATA (for target mode) are user accessible and contains the current character to be read from the RX FIFO stack. The last received character from the receive shift register will be push to the end of the FIFO Stack. The transmit data register I2Cx.MTXDATA (for controller mode) and I2Cx.STXDATA (for target mode) are user accessible and holds the data last written data to the TX FIFO. The TX FIFO contains the data waiting to be moved into the transmit shift register and transmitted on SDA. FIFOs are available for the controller and target receive and transmit. Each FIFO entry has a width of 8 bits and should be accessed in byte mode. Each FIFO has a programmable threshold point (configured by RXTRIG and TXTRIG bits in the I2Cx.MFIFOCTL register for controller mode and I2Cx.SFIFOCTL register for target mode) which indicates when the FIFO service interrupt should be generated. Additionally, a FIFO receive full and transmit empty interrupt can be enabled in the interrupt mask (IMASK) registers for the controller and target. The content of the FIFO can be flushed with setting TXFLUSH or RXFLUSH bit to 1 in the I2Cx.FIFOCTL registers. When the I<sup>2</sup>C gets reset the content of the FIFO needs also to be cleared. FIFO clear should only be executed while the I<sup>2</sup>C is in IDLE mode. Before triggering the flush the FIFO interrupts should be disabled and after flush has completed the interrupt flags needs to be checked. #### 16.2.3.12.1 Flushing Stale Tx data in target mode In most use cases, the user does not want to transmit leftover data of the I2C peripheral Tx FIFO from previous frame in the next frame. The device provides a mechanism for the software to choose whether to flush stale data or not A status bit **SSR.STALE\_TXFIFO** represents whether the data present inside I2C peripheral TX FIFO is stale or not. A control bit **SCTR.TXWAIT\_STALE\_TXFIFO** is used to enable modified empty indication to target logic - indicate empty to I2C peripheral FSM when Tx FIFO is empty **OR** stale data present in Tx FIFO. A control bit I<sup>2</sup>C www.ti.com **SCTR.TXEMPTY\_ON\_TREQ** allows RIS.STXEMPTY interrupt to be used for indicating TREQ condition i.e. the condition when SCL is being stretched waiting for transmit data from the I2C peripheral. ## **Recommended Sequence** - 1. When **SCTR.TXWAIT\_STALE\_TXFIFO** is set, on STOP, restart, or timeout, I2C peripheral FSM gets an empty indication even though stale data is present inside I2C peripheral Tx FIFO. - 2. I2C module doesnt immediately generate an TX FIFO empty interrupt/DMA request. Instead, waits till the controller on the I2C bus attempts to read data from I2C peripheral, at which point the I2C peripheral clock stretches. - At this point I2C peripheral issues clock stretch (TREQ) interrupt to CPU when SCTR.TXEMPTY\_ON\_TREQ is set. - 4. Application software in ISR checks for **SSR.STALE\_TXFIFO** flag and flushes the TX FIFO using **SFIFOCTL.TXFLUSH** This also clears the status of **SSR.STALE TXFIFO** ## 16.2.3.13 Loopback mode The I<sup>2</sup>C modules can be placed into an internal loopback mode for diagnostic or debug work by setting the LPBK bit in the I<sup>2</sup>C controller configuration I2Cx.MCR register. In loopback mode, the SDA and SCL signals from the controller part of the I<sup>2</sup>C are tied to the SDA and SCL signals of the target part of the I<sup>2</sup>C module to allow internal testing of the device without having to connect the I/Os. #### 16.2.3.14 Burst Mode A burst mode is provided for the controller module which allows a sequence of data transfers using the DMA or software to handle the data in the FIFO. The burst mode is enabled by setting the MBLEN bits in the controller control register I2Cx.MCTR to a value greater then '1'. This sets the number of bytes transferred by a burst. A copy of this value is automatically written to the MBCNT bits in the I<sup>2</sup>C controller status register I2Cx.MSR to be used as a down-counter during the burst transfer. The bytes written to the I<sup>2</sup>C FIFO are transferred to the RX FIFO or TX FIFO depending on whether a transmit or receive is being executed. If data is NACK'd during a BURST and the STOP bit is set in the I2Cx.MCTR register, the transfer terminates. If the STOP bit is not set, software must issue a STOP or repeated START when a NACK interrupt is asserted. In the case of a NACK, the MBCNT bits in the I2Cx.MSR register can be used to determine the amount of data that was transferred prior to the burst termination. If the address is NACK'd during a transfer, then a STOP is issued. ## 16.2.3.15 DMA Operation The I<sup>2</sup>C provides an interface to the DMA controller with two channels. The DMA operation of the I<sup>2</sup>C is enabled through the I<sup>2</sup>C event register and DMA peripheral registers. When the DMA functionality is enabled, the I<sup>2</sup>C asserts a DMA request on the selected channel when the associated FIFO can transfer or receive data. For more information about I<sup>2</sup>C event and DMA, please refer to Interrupt and Events Support and DMA Trigger Publisher sections. #### Note Per DMA Channel only one event source should be enabled by the IMASK register at the same time. The DMA transaction descriptor needs to match for the selected trigger with a correct setup for either Controller or Target and RX or TX configuration. The DMA trigger should only be changed when no I<sup>2</sup>C transfer is ongoing and a previous triggered DMA transfer has been finished. If this cannot be ensured the I<sup>2</sup>C and DMA channel should be disabled first. ## 16.2.3.16 Low Power Operation I<sup>2</sup>C supports operation in Low Power Modes. Supported power mode for controller mode: - Controller mode with 100kHz speed can operate in RUN, SLEEP, STOP power mode - Controller mode with 400kHz speed can operate in RUN, SLEEP power mode Controller mode with 1MHz speed can operate in RUN, SLEEP power mode In low-power mode, the I<sup>2</sup>C interface automatically request the clock selected in the CLKSEL control register after detecting a start condition. The clock request will be released after detection of the STOP condition. Supported power mode and wakeup mode for target mode: - Target mode with 100kHz speed can operate in RUN, SLEEP, STOP power mode - Target mode with 100kHz speed can't operate in STANDBY mode because the maximum bus clock in STANDBY mode is 32kHz and to support 100kHz speed we need minimum 400kHz clock. However, in STANDBY mode I2C target can still wakeup from the start bit and perform the (Asynchronous Fast Clock Requests) to temporarily get a 32MHz clock to receive the data until the FIFO or address match interrupt wakes up the CPU. - Target mode with 400kHz speed in RUN, SLEEP power mode - Target mode with 1MHz speed in RUN, SLEEP power mode (More information will be added in next revision) ## 16.2.4 Protocol Descriptions #### 16.2.4.1 I<sup>2</sup>C Controller Mode As showing in the function block diagram section, I<sup>2</sup>C peripheral has a set of specific controller registers to configure the operation when the module is configured as an I<sup>2</sup>C target mode. ## 16.2.4.1.1 Controller Configuration The I<sup>2</sup>C Controller Control register I2Cx.MCTR and I<sup>2</sup>C Controller Target Address register I2Cx.MSA are used for controlling controller transmit and receive modes. The following settings can be modified to control the different transactions. - · Length indicates the number of bytes for the transaction and is configured by I2Cx.MCTR.MBLEN bit - Direction (transmit or receive) is configured by I2Cx.MSA.DIR bit - ACK generation is configured by I2Cx.MCTR.MBLEN bit - STOP condition generation is configured by I2Cx.MCTR.STOP bit - START or repeated START condition generation is configured by I2Cx.MCTR.START bit - RUN enable the controller transaction and is configured by I2Cx.MCTR.BURSTRUN bit #### Controller send data transactions ## Table 16-4. Start Transmit From Idle Mode | Length | Direction | ACK | STOP | START | RUN | Format | Comments | |---------|-----------|-----|--------|-------|-----|----------------------------------|-------------------------------------| | n (n>0) | 0 | х | 0 or 1 | 1 | 1 | START+ADDR+R/W+<br>DATA*n+(STOP) | Sending of STOP depends on STOP bit | #### Table 16-5. Continue Transmit When Last Transmission Finished Without stop | Length | Direction | ACK | STOP | START | RUN | Format | Comments | |---------|-----------|-----|--------|-------|-----|-------------------------------|-------------------------------------| | n (n>0) | 0 | х | 0 or 1 | 0 | 1 | DATA*n+ (ACK/NACK)+<br>(STOP) | Sending of STOP depends on STOP bit | If there is a NACK response from the target, the controller will automatically send out a stop to finish the transmit. The Controller will be unable to send a RESTART after ADDR or DATA NACK. $l^2C$ www.ti.com #### Controller receive data transactions #### Table 16-6. Start Receive From Idle Mode | Length | Direction | ACK | STOP | START | RUN | Format | Comments | |---------|-----------|--------|--------|-------|-----|----------------------------------------------------|---------------------------------------------------------------------------------------------------------| | n (n>0) | 1 | 0 or 1 | 0 or 1 | 1 | 1 | START+ADDR +R/<br>W+DATA *n +(ACK/NACK)<br>+(STOP) | The last data ACK or<br>NACK depend on ACK<br>bit; additional sending of<br>STOP depends on STOP<br>bit | #### Table 16-7. Continue Receive When Last Receive Finished Without STOP or NACK | Length | Direction | ACK | STOP | START | RUN | Format | Comments | |---------|-----------|--------|--------|-------|-----|--------------------------------|---------------------------------------------------------------------------------------------------------------------| | n (n>0) | 1 | 0 or 1 | 0 or 1 | 0 | 1 | DATA*n+ (ACK/NACK) +<br>(STOP) | The last data followed by<br>ACK or NACK depend<br>on ACK bit; additional<br>sending of STOP depends<br>on STOP bit | This configuration is not allowed if last transaction ended with NACK, as NACK can only be followed by STOP or RESTART. The ACK and STOP bits should not be set to 1 at the same time, as the target needs to be informed to release bus lines before sending out STOP. ## **Controller repeated start transactions** If last transmit or receive finished without stop, a repeat start can be generated to initiate a new transaction ## Table 16-8. Repeated Start Transmit | Length | Direction | ACK | STOP | START | RUN | Format | Comments | |---------|-----------|--------|--------|-------|-----|--------------------------------------|------------------------------------------------| | n (n>0) | 0 | 0 or 1 | 0 or 1 | 1 | 1 | Restart+ADDR +R/<br>W+DATA*n +(STOP) | Additional sending of STOP depends on STOP bit | If there is a NACK response from the target, the controller will automatically send out a stop to finish the transmit. The Controller will be unable to send a RESTART after ADDR or DATA NACK. Table 16-9. Repeated Start Receive | Length | Direction | ACK | STOP | START | RUN | Format | Comments | |---------|-----------|--------|--------|-------|-----|-----------------------------------------------------|---------------------------------------------------------------------------------------------------------------------| | n (n>0) | 1 | 0 or 1 | 0 or 1 | 1 | 1 | Restart+ADDR +R/<br>W+DATA*n +(ACK/NACK)<br>+(STOP) | The last data followed by<br>ACK or NACK depend<br>on ACK bit; additional<br>sending of STOP depends<br>on STOP bit | The ACK and STOP bits should not be set to 1 at the same time, as the target needs to be informed to release bus lines before sending out STOP. ## **Controller send STOP only transaction** # Table 16-10. Send STOP only | Length | Direction | ACK | STOP | START | RUN | Format | Comments | |---------|-----------|-----|------|-------|-----|--------|--------------| | n (n>0) | Х | X | 1 | 0 | 1 | STOP | STOP command | It is only allowed to send after previous transaction success finished, and STOP can't be sent without a NACK to the target if controller is currently in receive mode #### **Controller Quick Command transaction** The Quick command could only be sent at the transaction beginning, not following other transactions (without stop) or repeat start. Table 16-11. Controller quick command | Length | Direction | ACK | STOP | START | RUN | Format | Comments | |--------|-----------|-----|------|-------|-----|--------------------------|---------------| | 0 | 0/1 | Х | 1 | 1 | 1 | START+ADDR +R/<br>W+STOP | Quick command | #### 16.2.4.1.2 Controller Mode Operation ## I<sup>2</sup>C Controller Initialization - 1. Configure SDA and SCL pin functions and select as input by using the IOMUX registers. - 2. Reset the peripheral using I2Cx.RSTCTL register - 3. Enable the power to peripheral using I2Cx.PWREN register - 4. Select and configure the I<sup>2</sup>C clock using the CLKCTL and CLKDIV registers. - 5. Set the desired SCL clock speed of by writing the TPR bit in I2Cx.MTPR register with the correct value. For more information about how to calculate TPR value refer to Clock Control section. For example, with 20MHz I<sup>2</sup>C clock to achieve 100 kbps SCL clock, TPR value will be 19 (0x13) so we can write the I2Cx.MTPR register with the value of 0x13. - 6. Specify the target address and mode (transmit or receive) for the next operation by writing the I2Cx.MSA register. For example, if the target address is 0x3B (MSA.SADDR[7:1] = 0x3B) and we want to transmit (MSA.DIR[0] = 0x0) data then we can write the I2Cx.MSA register with a value of 0x76. - 7. If controller is transmitting data, user can place data (byte) to be transmitted in the data register by writing the I2Cx.MTXDATA register with the desired data. - 8. Configure the controller transmit or receive mode by writing the I2Cx.MCTR register. For more information on how to configure I2Cx.MCTR register for different mode please see Controller Configuration section above. - 9. Enable desired interrupts and/or DMA event by using CPU INT.IMASK register. ## I<sup>2</sup>C Controller Status User can read the I2Cx.MSR register to check the current state of the I2C controller. Table 16-12. Controller Status Register | Bit Field | Description | |-----------|-------------------------------------------------------------------------------------------------------------------------| | BUSY | I2C controller busy. The BUSY bit is set during an ongoing transaction. | | ERR | I2C error. The error can be from the target address not being acknowledged or the transmit data not being acknowledged. | | ADRACK | Acknowledge address. This bit is set if the transmitted address was not acknowledged. | | DATACK | Acknowledge data. This bit is set if the transmitted data was not acknowledged. | | ARBLST | Arbitration lost. This bit is set if controller lost arbitration. | | IDLE | I2C bus idle. | | BUSBSY | I2C bus busy. The bit changes based on the START and STOP conditions, set it bus is busy. | | CLKTO | Clock timeout error. This bit is set if the clock timeout error has occurred. | | MBCNT | I2C controller transaction count. This field contains the current countdown value of the transaction. | ## I<sup>2</sup>C Controller Receiver Mode For controller to start receive data out of the idle mode, user needs to set the START bit in I2Cx.MCTR register to generate the start condition. Then the controller automatically sends the START condition followed by the target address as soon as it detects that the bus is free. All the process below should be followed. I2Cx.MSA.DIR is set to 1 to enable receive mode, I2Cx.MCTR.START is set to generate start condition, I2Cx.MBLEN can be programmed to indicate the number of bytes (n) for the receive operation. I2Cx.MCTR.ACK and I2Cx.MCTR.STOP bit can be set or clear based on user configuration. I2Cx.MCTR.BURSTRUN is set to $f^2C$ www.ti.com start the operation. The packet format is START+ADDR+R+DATA\*n +(ACK/NACK) + (STOP). The last data ACK/NACK depend on ACK bit, additional sending of STOP depends on STOP bit. After last byte is received, the MRXDONE (0x01) interrupt in CPU\_INT.IIDX register is set to indicate that controller receive transaction is completed. User can use the MRXFIFOTRG (0x03) interrupt in CPU\_INT.IIDX register to read the data from the receive FIFO. This interrupt will trigger when controller RX FIFO contains >= defined bytes, the trigger level can be defined by using RXTRIG bit in I2Cx.MFIFOCTL register. The flow chart of controller receiver mode is shown in Figure 16-10. Figure 16-10. Controller Receiver Mode I<sup>2</sup>C www.ti.com #### I<sup>2</sup>C Controller transmitter Mode For controller, to start transmit data out of the idle mode, user need to set the START bit in I2Cx.MCTR register to generate the start condition. Then the controller automatically sends the START condition followed by the target address as soon as it detects that the bus is free. The data written into the MTXFIFO is transmitted if arbitration is not lost during transmission of the target address. All the process below should be followed. I2Cx.MSA.DIR is cleared to enable transmit mode, I2Cx.MCTR.START is set to generate start condition, I2Cx.MBLEN can be programmed to indicate the number of bytes (n) for the transmit operation. I2Cx.MCTR.STOP bit can be set or clear based on user configuration. I2Cx.MCTR.BURSTRUN is set to start the operation. The packet format is START+ADDR+W+DATA\*n + (STOP), sending of STOP depends on STOP bit. After last byte is transmitted, the MTXDONE (0x02) interrupt in CPU\_INT.IIDX register is set to indicate that controller transmit transaction is completed. User can also set use the MTXEMPTY (0x06) interrupt in CPU\_INT.IIDX register to see if the MTXFIFO is empty and ready to load more data. This interrupt will trigger if all data in the transmit FIFO have been shifted out. The flow chart of controller receiver mode is shown in Figure 16-11. Figure 16-11. Controller Transmitter Mode #### 16.2.4.1.3 Read On TX Empty Typically, in any I2C transaction one would need to first write the target in order to set the register number, then do a repeated start + read to get back the data value. However, the RD\_ON\_EMPTY flag allows one to do two I2C transactions with a single setup of the I2C controller. One can set up both the write and read together; with the limitation being that the "write" phase cannot send more than the data that fits inside the TX FIFO. This is an optimization to minimize interrupt processing requirements. The high level set up is below: - Set MSA to target address with RECEIVE = 1 (RD\_ON\_TXEMPTY must have I2C\_MSR\_DIR\_RECEIVE set) - Set MCTR to initiate the transaction, in this use case write: - MBLEN= size for READ phase - RD\_ON\_TXEMPTY - ACK\_DISABLE(my use case will NACK+STOP after read) - STOP ENABLE - START ENABLE - BURST\_ENABLE The expected behavior with this set up is that the controller will START, transmit all TXFIFO data and when TXFIFO is empty will automatically do a repeated START, read MBLEN bytes, then STOP. #### 16.2.4.2 I<sup>2</sup>C Target Mode #### 16.2.4.2.1 Target Mode Operation #### I<sup>2</sup>C Target Initialization - 1. Configure SDA and SCL pin functions and select as input by using the IOMUX registers. - 2. Reset the peripheral using I2Cx.RSTCTL register - 3. Enable the power to peripheral using I2Cx.PWREN register - 4. Select and configure the I<sup>2</sup>C clock using the CLKCTL and CLKDIV registers. - 5. Configure at least one target address by writing the 7-bit address to I2Cx.SOAR register. The additional target address can be enabled and configured by using I2Cx.SOAR2 register. - 6. Enable desired interrupts and/or DMA event by using CPU\_INT.IMASK register. - 7. The general call response can be enabled by setting the GENCALL bit in I2Cx.SCTR register. - 8. Enable the I<sup>2</sup>C target mode by setting the ACTIVE bit in I2Cx.SCTR register. #### I<sup>2</sup>C Target Status User can read the I2Cx.SSR register to check the current state of the I2C target. #### Bit Field Description This bit is set if the I2C controller has outstanding receive data from the I2C controller and is using clock stretching **RREQ** to delay the controller until the data has been read from the SRXDATA FIFO (Target RX FIFO is full) This bit is set if the I2C controller has been addressed as a target transmitter and is using clock stretching to delay **TREQ** the controller until data has been written to the STXDATA FIFO (Target TX FIFO is empty). OAR2SEL This bit is set if SOAR2.OAR2 address matched and ACKed by the target. Quick command status value. This bit is 0 if the last transaction was a normal transaction or a transaction has not **QCMDST** occurred. This bit is set if the last transaction was a quick command transaction Quick command read / write status. This bit only has meaning when the QCMDST bit is set. This bit is 0 if quick **QCMDRW** command was a write. This bit is set if quick command was a read. Table 16-13. Target Status Register #### I<sup>2</sup>C Target Receiver Mode Target receiver mode is entered when the target address transmitted by the controller matches its own address and a cleared R/W bit is received. In target receiver mode, serial data bits received on SDA are shifted in with the clock pulses that are generated by the controller device. The target device does not generate the clock, but it can hold SCL low if intervention of the CPU is required after a byte has been received. After the a data byte is received, the SRXDONE (0x11) interrupt in CPU\_INT.IIDX register is set to indicate that a byte has been received. The I<sup>2</sup>C module automatically acknowledges the received data or user can choice to manually send acknowledge after each byte received by configuring the I2Cx.SACKCTL register. When the controller generates a START condition, the SSTART (0x17) interrupt in CPU\_INT.IIDX register is set. When the controller generates a STOP condition, the SSTOP (0x18) interrupt in CPU\_INT.IIDX register is set. User can also set use the SRXFIFOTRG (0x13) interrupt in CPU\_INT.IIDX register to read the data from the receive FIFO. This interrupt will trigger when receive FIFO contains >= defined bytes, the trigger level can be defined by using RXTRIG bit in I2Cx.SFIFOCTL register. The SRXDONE approach could be used if target wants to slow down communication to evaluate reception of every byte, while the SRXFIFOTRG approach could be used to maximize throughput and avoid clock stretching. The flow chart of using SRXDONE and SRXFIFOTRG interrupt to read the receive data are shown in Figure 16-12 and Figure 16-13 respectively. <sup>\*</sup> RX buffer is a user defined buffer for received data packet Figure 16-12. Target Receiver Mode using SRXDONE and ACK override <sup>\*</sup> RX buffer is a user defined buffer for received data packet Figure 16-13. Target Receiver Mode using SRXFIFOTRG and automatic ACK #### I<sup>2</sup>C Target Transmitter Mode Target transmitter mode is entered when the target address transmitted by the controller is identical to its own address with a set R/W bit. The target transmitter shifts the serial data out on SDA with the clock pulses that are generated by the controller device. The target device does not generate the clock, but it can hold SCL low if intervention of the CPU is required after a byte has been transmitted. After a data byte is transmitted, the STXDONE (0x12) interrupt in CPU\_INT.IIDX register is set to indicate that a byte has been transmitted. When the controller generates a START condition, the SSTART (0x17) interrupt in CPU\_INT.IIDX register is set. When the controller generates a STOP condition, the SSTOP (0x18) interrupt in CPU\_INT.IIDX register is set. User can also set use the STXFIFOTRG (0x14) interrupt in CPU\_INT.IIDX register to load the data to the transmit FIFO. This interrupt will trigger when transmit FIFO contains <= defined bytes, the trigger level can be defined by using TXTRIG bit in I2Cx.SFIFOCTL register. The STXDONE approach could be used if target wants to slow down communication to evaluate reception of every byte, while the STXFIFOTRG approach could be used to maximize throughput and avoid clock stretching. The flow chat of using STXDONE and STXFIFOTRG interrupt to transmit data are shown in Figure 16-14 and Figure 16-15. <sup>\*</sup> TX buffer is a user defined buffer for transmit data packet Figure 16-14. Target Transmitter Mode using STXDONE <sup>\*</sup> TX buffer is a user defined buffer for received data packet Figure 16-15. Target Transmitter Mode using STXFIFOTRG #### 16.2.5 Reset Considerations #### **Software Reset Considerations** A Software reset can be executed by setting the RESETASSERT bit together with the KEY bit in the I2Cx.RSTCTL register. We recommend issues a reset only after terminating a transaction. #### **Hardware Reset Considerations** A hardware reset also initializes the IO configuration. This sets the IOs to a high-impedance state and with the external pullup resistors for I<sup>2</sup>C the lines pulled high. Table 16-14 shows the behavior of status bits when Controller or Target gets disabled. Table 16-14. Status Bits When Controller is Disabled | Register | Bit | Behavior When<br>Controller<br>Disabled | Behavior When<br>Target Disabled | Behavior After Controller/Target Enabled | |---------------|--------|-----------------------------------------|----------------------------------|--------------------------------------------------------------| | I2Cx.MSR | Busy | Reset State | Don't care | updates Start condition sending | | | ERR | Reset State | Don't care | updates on next event detected | | | ADRACK | Reset State | Don't care | updates on next event detected | | | DATACK | Reset State | Don't care | updates on next event detected | | | ARBLST | Reset State | Don't care | updates on next event detected | | | IDLE | Reset State | Don't care | updates on next event detected | | | BUSBSY | Reset State | Don't care | updates on next Start detected on bus (or SDA or SCL is low) | | | CLKTO | Reset State | Don't care | updates on next event detected | | | MBCNT | Reset State | Don't care | updates on next event detected | | I2Cx.MCLKOCNT | CLKCNT | Reset State | Don't care | updates with Controller enable when SCL is high | #### **Table 16-14. Status Bits When Controller is Disabled (continued)** | Register | Bit | Behavior When<br>Controller<br>Disabled | Behavior When<br>Target Disabled | Behavior After Controller/Target Enabled | |------------|-----|-----------------------------------------|----------------------------------|------------------------------------------| | I2Cx.MBMON | SCL | Reset State | Don't care | updates with Controller enable | | | SDA | Reset State | Don't care | updates with Controller enable | #### Table 16-15. Status Bits When Target is Disabled | Register | Bit | Behavior When<br>Controller<br>Disabled | Behavior When<br>Target Disabled | Behavior After Controller/Target Enabled | |--------------|-----------|-----------------------------------------|----------------------------------|------------------------------------------| | I2Cx.SSR | RREQ | Don't care | Reset State | updates on next event detected | | | TREQ | Don't care | Reset State | updates on next event detected | | | OAR2SEL | Don't care | Reset State | updates on next event detected | | | QCMDST | Don't care | Reset State | updates on next event detected | | | QCMDRW | Don't care | Reset State | updates on next event detected | | I2Cx.SFIFOSR | RXFIFOCNT | Don't care | Unchanged | updates on FIFO access | | | TXFIFOCNT | Don't care | Unchanged | updates on FIFO access | #### 16.2.6 Initialization Please see Section 16.2.4.1.2 for controller initialization and Section 16.2.4.2.1 for target initialization. #### Note The configuration registers of the I2C module (including the clock configuration, mode configuration, and timeout count) must not be modified by application software when an I2C data transfer is in progress. #### 16.2.7 Interrupt and Events Support The I<sup>2</sup>C module contains three event publishers and no event subscribers. One event publisher (CPU\_INT) manages I<sup>2</sup>C interrupt requests (IRQs) to the CPU subsystem through a static event route. The second and third event publishers (DMA\_TRIG1, DMA\_TRIG0) are used to setup the trigger signaling for the DMA through DMA event route. The I<sup>2</sup>C events are summarized in Table 16-16. #### Table 16-16. I2C Events | Event | Type | Source | Destination | Route | Configuration | Functionality | |---------------|-----------|------------------|---------------|-----------------|---------------------|----------------------------------------------------------| | CPU interrupt | Publisher | l <sup>2</sup> C | CPU Subsystem | Static route | CPU_INT registers | Fixed interrupt<br>route from I <sup>2</sup> C<br>to CPU | | DMA trigger | Publisher | l <sup>2</sup> C | DMA | DMA event route | DMA_TRIG1 registers | Fixed interrupt<br>route from I <sup>2</sup> C<br>to DMA | | DMA trigger | Publisher | l <sup>2</sup> C | DMA | DMA event route | DMA_TRIG0 registers | Fixed interrupt<br>route from I <sup>2</sup> C<br>to DMA | #### 16.2.7.1 CPU Interrupt Event Publisher (CPU\_INT) The $I^2C$ module provides 24 interrupt sources which can be configured to source a CPU interrupt event. In order of decreasing interrupt priority, the CPU interrupt events from the $I^2C$ are: #### Table 16-17. I<sup>2</sup>C CPU Interrupt Event Conditions for Controller (CPU INT) | idado lo III. o ol o interrape Event contante los contactios (e. o_itt) | | | | | |-------------------------------------------------------------------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | IIDX STAT | Name | Description | | | | 0x01 | MRXDONE | Controller receive transaction completed interrupt | | | | 0x02 | MTXDONE | Controller transmit transaction completed interrupt | | | | 0x03 | MRXFIFOTRG | Controller receive FIFO trigger. Trigger when RX FIFO contains >= defined bytes | | | | 0x04 | MTXFIFOTRG | Controller transmit FIFO trigger. Trigger when Transmit FIFO contains <= defined bytes | | | | 0x05 | MRXFIFOFULL | Controller RXFIFO full event. This interrupt is set if an RX FIFO is full. | | | | 0x06 | MTXEMPTY | Controller transmit FIFO empty interrupt. This interrupt is set if all data in the Transmit FIFO have been shifted out and the transmit goes into idle mode. | | | | 0x07 | MCLKTO | Controller clock timeout interrupt | | | | 80x0 | MNACK | Address/Data NACK interrupt | | | | 0x09 | MSTART | Controller START detection interrupt | | | | 0x0A | MSTOP | Controller STOP detection interrupt | | | | 0x0B | MARBLOST | Controller arbitration lost interrupt | | | | 0x0C | MDMA_DONE_TX | Controller DMA TX done signal (see next section for more detail) | | | | 0x0D | MDMA_DONE_RX | Controller DMA RX done signal (see next section for more detail) | | | ### Table 16-18. I<sup>2</sup>C CPU Interrupt Event Conditions for Target (CPU\_INT) | IIDX STAT | Name | Description | | | |-----------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | 0x11 | SRXDONE | Target receive transaction completed interrupt | | | | 0x12 | STXDONE | Target transmit transaction completed interrupt | | | | 0x13 | SRXFIFOTRG | Target receive FIFO trigger. It will trigger when receive FIFO contains >= defined bytes | | | | 0x14 | STXFIFOTRG | Target transmit FIFO trigger. It will trigger when transmit FIFO contains <= defined bytes | | | | 0x15 | SXFIFOFULL | Target RXFIFO full event. This interrupt is set if an RX FIFO is full. | | | | 0x16 | STXEMPTY | Target transmit FIFO empty interrupt. This interrupt is set if all data in the Target Transmit FIFO have been shifted out and the transmit goes into idle mode. | | | | 0x17 | SSTART | Target START detection interrupt | | | | 0x18 | SSTOP | Target STOP detection interrupt | | | | 0x19 | SGENCALL | General call interrupt | | | | 0x1A | SDMA_DONE_TX | Target DMA TX done signal (see next section for more detail) | | | | 0x1B | SDMA_DONE_RX | Target DMA RX done signal (see next section for more detail) | | | The CPU interrupt event configuration is managed with the CPU\_INT event management registers. See Section 6.2.5 for guidance on configuring the Event registers for CPU interrupts. ### 16.2.7.2 DMA Trigger Publisher (DMA\_TRIG1, DMA\_TRIG0) DMA\_TRIG1 and DMA\_TRIG0 registers are used to setup the trigger signaling for the DMA. This can be setup in a flexible way to trigger the DMA for Controller or Target and receive or transmit events with the following four trigger conditions: Table 16-19. I<sup>2</sup>C DMA Trigger Condition (DMA\_TRIG1 and DMA\_TRIG0) | IIDX STAT | Name | Description | |-----------|------------|----------------------------------------------------------------------------------------| | 0x01 | MRXFIFOTRG | Controller receive FIFO trigger. Trigger when RX FIFO contains >= defined bytes | | 0x02 | MTXFIFOTRG | Controller transmit FIFO trigger. Trigger when Transmit FIFO contains <= defined bytes | | 0x03 | SRXFIFOTRG | Target receive FIFO trigger. Trigger when RX FIFO contains >= defined bytes | | 0x04 | STXFIFOTRG | Target transmit FIFO trigger. Trigger when Transmit FIFO contains <= defined bytes | The DMA trigger event configuration is managed with the DMA\_TRIG1 and DMA\_TRIG0 event management registers. See Section 6.2.5 for guidance on configuring the Event registers and Section 6.1.3.2 for on how DMA trigger event works. DMA\_TRIG1 and DMA\_TRIG0 are two event management registers that correspond to two DMA channels. As shown in Figure 16-16, each DMA channel can be triggered by any of the conditions listed in Table 16-19 and it can generate either the controller DMA done signal or target DMA done signal. For example, the user can configure the DMA\_TRIG1 trigger using MTXFIFOTRG and the DMA\_TRIG0 trigger using SRXFIFOTRG. When the Channel 1 DMA status changes to done, the MDMA\_DONE\_TX and MDMA\_DONE\_RX interrupts will set, and when the Channel 2 DMA status change to done, the SDMA DONE TX and SDMA DONE RX interrupts will set. Figure 16-16. I<sup>2</sup>C DMA Trigger and Status #### 16.2.8 Emulation Modes The module behavior while the device is in debug mode is controlled by the FREE and SOFT bits in PDBGCTL register. When the device is in debug mode and set into halt mode below behavior can be configured. #### Table 16-20. Debug Mode Peripheral Behavior | PDBGCTL.FREE | PDBGCTL.SOFT | Function | |--------------|--------------|--------------------------------------------------------| | 1 | x | Modules continues operation | | 0 | 0 | Module stops immediately | | 0 | 1 | Module stops after the next transfer has been finished | # 16.3 I2C Registers Table 16-21 lists the memory-mapped registers for the I2C registers. All register offset addresses not listed in Table 16-21 should be considered as reserved locations and the register contents should not be modified. ### Table 16-21. I2C Registers | Offset | Acronym | Register Name | Group | Section | | |--------|-------------|----------------------------------------------|-----------|---------|--| | 800h | PWREN | Power enable | | Go | | | 804h | RSTCTL | Reset Control | Go | | | | 808h | CLKCFG | Peripheral Clock Configuration Register | Go | | | | 814h | STAT | Status Register | Go | | | | 1000h | CLKDIV | Clock Divider | | Go | | | 1004h | CLKSEL | Clock Select for Ultra Low Power peripherals | | Go | | | 1018h | PDBGCTL | Peripheral Debug Control | | Go | | | 1020h | IIDX | Interrupt index | CPU_INT | Go | | | 1028h | IMASK | Interrupt mask | CPU_INT | Go | | | 1030h | RIS | Raw interrupt status | CPU_INT | Go | | | 1038h | MIS | Masked interrupt status | CPU_INT | Go | | | 1040h | ISET | Interrupt set | CPU_INT | Go | | | 1048h | ICLR | Interrupt clear | CPU_INT | Go | | | 1050h | IIDX | Interrupt index | DMA_TRIG1 | Go | | | 1058h | IMASK | Interrupt mask | DMA_TRIG1 | Go | | | 1060h | RIS | Raw interrupt status | DMA_TRIG1 | Go | | | 1068h | MIS | Masked interrupt status DMA_TRIG1 | | Go | | | 1070h | ISET | Interrupt set | DMA_TRIG1 | Go | | | 1078h | ICLR | Interrupt clear | DMA_TRIG1 | Go | | | 1080h | IIDX | Interrupt index | DMA_TRIG0 | Go | | | 1088h | IMASK | Interrupt mask | DMA_TRIG0 | Go | | | 1090h | RIS | Raw interrupt status DMA_TRIG0 | | Go | | | 1098h | MIS | Masked interrupt status | DMA_TRIG0 | Go | | | 10A0h | ISET | Interrupt set | DMA_TRIG0 | Go | | | 10A8h | ICLR | Interrupt clear | DMA_TRIG0 | Go | | | 10E0h | EVT_MODE | Event Mode | | | | | 10E4h | INTCTL | Interrupt control register | | Go | | | 10FCh | DESC | Module Description | | Go | | | 1200h | GFCTL | I2C Glitch Filter Control | | Go | | | 1204h | TIMEOUT_CTL | I2C Timeout Count Control Register | | Go | | | 1208h | TIMEOUT_CNT | I2C Timeout Count Register | | Go | | | 1210h | MSA | I2C Controller Target Address Register | | Go | | | 1214h | MCTR | I2C Controller Control Register | | | | | 1218h | MSR | I2C Controller Status Register | Go | | | | 121Ch | MRXDATA | I2C Controller RX Data | Go | | | | 1220h | MTXDATA | I2C Controller TX Data | | Go | | | 1224h | MTPR | I2C Controller Timer Period | | Go | | | 1228h | MCR | I2C Controller Configuration Go | | | | | 1234h | MBMON | I2C Controller Bus Monitor | | Go | | | 1238h | MFIFOCTL | I2C Controller FIFO Control Go | | | | | 123Ch | MFIFOSR | I2C Controller FIFO Status Register | | Go | | Table 16-21. I2C Registers (continued) | Offset | Acronym | Register Name | Group | Section | |--------|----------------------|-------------------------------------|-------|---------| | 1240h | CONTROLLER_I2CPECCTL | I2C Controller PEC control register | | Go | | 1244h | CONTROLLER_PECSR | I2C Controller PEC status register | | Go | | 1250h | SOAR | I2C Target Own Address | | Go | | 1254h | SOAR2 | I2C Target Own Address 2 | | Go | | 1258h | SCTR | I2C Target Control Register | | Go | | 125Ch | SSR | I2C Target Status Register | | Go | | 1260h | SRXDATA | I2C Target RX Data | | Go | | 1264h | STXDATA | I2C Target TX Data | | Go | | 1268h | SACKCTL | I2C Target ACK Control | | Go | | 126Ch | SFIFOCTL | I2C Target FIFO Control | | Go | | 1270h | SFIFOSR | I2C Target FIFO Status Register | | Go | | 1274h | TARGET_PECCTL | I2C Target PEC control register | | Go | | 1278h | TARGET_PECSR | I2C Target PEC status register | | Go | Complex bit access types are encoded to fit into small table cells. Table 16-22 shows the codes that are used for access types in this section. Table 16-22. I2C Access Type Codes | Access Type | Code | Description | | | | | |------------------------|-----------|----------------------------------------|--|--|--|--| | Read Type | Read Type | | | | | | | R | R | Read | | | | | | Write Type | | | | | | | | W | W | Write | | | | | | WK | W<br>K | Write<br>Write protected by a key | | | | | | Reset or Default Value | | | | | | | | -n | | Value after reset or the default value | | | | | # 16.3.1 PWREN (Offset = 800h) [Reset = 00000000h] PWREN is shown in Figure 16-17 and described in Table 16-23. Return to the Summary Table. Register to control the power state ### Figure 16-17. PWREN ### **Table 16-23. PWREN Field Descriptions** | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|----------------------------------------------------------------------------------------------------| | 31-24 | KEY | W | 0h | KEY to allow Power State Change<br>26h = KEY to allow write access to this register | | 23-1 | RESERVED | R/W | 0h | | | 0 | ENABLE | R/WK | 0h | Enable the power KEY must be set to 26h to write to this bit. 0h = Disable Power 1h = Enable Power | # 16.3.2 RSTCTL (Offset = 804h) [Reset = 00000000h] RSTCTL is shown in Figure 16-18 and described in Table 16-24. Return to the Summary Table. Register to control reset assertion and de-assertion ### Figure 16-18. RSTCTL #### Table 16-24. RSTCTL Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|--------------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------| | 31-24 | KEY | W | 0h | Unlock key B1h = KEY to allow write access to this register | | 23-2 | RESERVED | W | 0h | | | 1 | RESETSTKYCLR | WK | 0h | Clear the RESETSTKY bit in the STAT register KEY must be set to B1h to write to this bit. 0h = Writing 0 has no effect 1h = Clear reset sticky bit | | 0 | RESETASSERT | WK | 0h | Assert reset to the peripheral KEY must be set to B1h to write to this bit. 0h = Writing 0 has no effect 1h = Assert reset | # 16.3.3 CLKCFG (Offset = 808h) [Reset = 00000000h] CLKCFG is shown in Figure 16-19 and described in Table 16-25. Return to the Summary Table. Peripheral Clock Configuration Register ### Figure 16-19. CLKCFG | | | | | U. UL. (U. U | | | | | |--------|--------------------|----|--------|--------------|----|----|--------|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | | KI | ΞY | | | | | | | W-0h | | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | RESERVED | | | | | | | | | R/W-0h | | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | RESERVED BLOCKASYN | | | | | | | | | | | | R/W-0h | | | | R/W-0h | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | RESERVED | | | | | | | | | | | | R/V | V-0h | | | | | | 1 | | | | | | | | | ### Table 16-25. CLKCFG Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|------------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------| | 31-24 | KEY | W | 0h | KEY to Allow State Change 0xA9<br>A9h = key value to allow change field of GPRCM | | 23-9 | RESERVED | R/W | 0h | | | 8 | BLOCKASYNC | R/W | 0h | Async Clock Request is blocked from starting SYSOSC or forcing bus clock to 32MHz 0h = Not block async clock request 1h = Block async clock request | | 7-0 | RESERVED | R/W | 0h | | # 16.3.4 STAT (Offset = 814h) [Reset = 00000000h] STAT is shown in Figure 16-20 and described in Table 16-26. Return to the Summary Table. peripheral enable and reset status ### Figure 16-20. STAT ### **Table 16-26. STAT Field Descriptions** | Bit | Field | Туре | Reset | Description | |-------|-----------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-17 | RESERVED | R | 0h | | | 16 | RESETSTKY | R | 0h | This bit indicates, if the peripheral was reset, since this bit was cleared by RESETSTKYCLR in the RSTCTL register 0h = The peripheral has not been reset since this bit was last cleared by RESETSTKYCLR in the RSTCTL register 1h = The peripheral was reset since the last bit clear | | 15-0 | RESERVED | R | 0h | | # 16.3.5 CLKDIV (Offset = 1000h) [Reset = 00000000h] CLKDIV is shown in Figure 16-21 and described in Table 16-27. Return to the Summary Table. This register is used to specify module-specific divide ratio of the functional clock ### Figure 16-21. CLKDIV ## **Table 16-27. CLKDIV Field Descriptions** | | Table 10 27. GENERAL Flora Becompliance | | | | | | | |------|-----------------------------------------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | 31-3 | RESERVED | R/W | 0h | | | | | | 2-0 | RATIO | R/W | Oh | Selects divide ratio of module clock 0h = Do not divide clock source 1h = Divide clock source by 2 2h = Divide clock source by 3 3h = Divide clock source by 4 4h = Divide clock source by 5 5h = Divide clock source by 6 6h = Divide clock source by 7 7h = Divide clock source by 8 | | | | # 16.3.6 CLKSEL (Offset = 1004h) [Reset = 00000000h] CLKSEL is shown in Figure 16-22 and described in Table 16-28. Return to the Summary Table. Clock source selection. ### Figure 16-22. CLKSEL #### Table 16-28. CLKSEL Field Descriptions | Bit | Field | Туре | Reset | Description | |------|------------|------|-------|--------------------------------------------------------------------------------------------------------------------------| | 31-4 | RESERVED | R/W | 0h | | | 3 | BUSCLK_SEL | R/W | 0h | Selects BUSCLK as clock source if enabled 0h = Does not select this clock as a source 1h = Select this clock as a source | | 2 | MFCLK_SEL | R/W | 0h | Selects MFCLK as clock source if enabled 0h = Does not select this clock as a source 1h = Select this clock as a source | | 1-0 | RESERVED | R/W | 0h | | # 16.3.7 PDBGCTL (Offset = 1018h) [Reset = 00000003h] PDBGCTL is shown in Figure 16-23 and described in Table 16-29. Return to the Summary Table. This register can be used by the software developer to control the behavior of the peripheral relative to the 'Core Halted' input Figure 16-23. PDBGCTL # Table 16-29. PDBGCTL Field Descriptions | | 14510 10 2011 5500 12 1 1014 5000 1ption0 | | | | | | |------|-------------------------------------------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Bit | Field | Туре | Reset | Description | | | | 31-2 | RESERVED | R/W | 0h | | | | | 1 | SOFT | R/W | 1h | Soft halt boundary control. This function is only available, if FREE is set to 'STOP' Oh = The peripheral will halt immediately, even if the resultant state will result in corruption if the system is restarted 1h = The peripheral blocks the debug freeze until it has reached a boundary where it can resume without corruption | | | | 0 | FREE | R/W | 1h | Free run control 0h = The peripheral freezes functionality while the Core Halted input is asserted and resumes when it is deasserted. 1h = The peripheral ignores the state of the Core Halted input | | | ### 16.3.8 IIDX (Offset = 1020h) [Reset = 00000000h] IIDX is shown in Figure 16-24 and described in Table 16-30. Return to the Summary Table. This register provides the highest priority enabled interrupt index. #### Figure 16-24. IIDX # Table 16-30. IIDX Field Descriptions | Table 16-30. IIDX Field Descriptions | | | | | | | |--------------------------------------|----------|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Field | Туре | Reset | Description | | | | | RESERVED | R | 0h | | | | | | STAT | R | Oh | I2C Module Interrupt Vector Value. This register provides the highest priority interrupt index. A read clears the corresponding interrupt flag in RIS and MISC. 15h-1Fh = Reserved 00h = No interrupt pending 01h = Controller data received 02h = Controller data transmitted 03h = Controller receive FIFO Trigger Level 04h = Controller transmit FIFO Trigger level 5h = RX FIFO FULL Event/interrupt pending 6h = Transmit FIFO/Buffer Empty Event/interrupt pending 08h = Address/Data NACK 09h = Start Event 0Ah = Stop Event 0Bh = Arbitration Lost Ch = DMA DONE on Channel TX Dh = DMA DONE on Channel RX Eh = Controller PEC Receive Error Event Fh = Timeout A Event 10h = Timeout B Event 11h = Target Data Event 12h = Target Data Event 13h = Target receive FIFO Trigger Level 14h = Target transmit FIFO Trigger level 15h = RX FIFO FULL Event/interrupt pending 16h = Transmit FIFO/Buffer Empty Event/interrupt pending 17h = Start Event 18h = Stop Event 19h = General Call Event 1Ah = DMA DONE on Channel TX 1Bh = DMA DONE on Channel RX 1Ch = Target PEC receive error event 1Dh = Target TX FIFO underflow 1Eh = Target RX FIFO overflow event 1Fh = Target arbitration lost event 20h = Interrupt overflow event | | | | | | RESERVED | Field Type RESERVED R | Field Type Reset RESERVED R 0h | | | | # 16.3.9 IMASK (Offset = 1028h) [Reset = 00000000h] IMASK is shown in Figure 16-25 and described in Table 16-31. Return to the Summary Table. Interrupt Mask. If a bit is set, then corresponding interrupt is unmasked. Unmasking the interrupt causes the raw interrupt to be visible in IIDX, as well as MIS. Figure 16-25. IMASK | | | | ga.o .o | 20. IIIIAOIX | | | | |-----------|----------|-----------------|------------------|------------------|------------------|------------------|----------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | INTR_OVFL | SARBLOST | SRX_OVFL | STX_UNFL | SPEC_RX_ER<br>R | SDMA_DONE_<br>RX | SDMA_DONE_<br>TX | SGENCALL | | R/W-0h | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | SSTOP | SSTART | STXEMPTY | SRXFIFOFULL | STXFIFOTRG | SRXFIFOTRG | STXDONE | SRXDONE | | R/W-0h | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | TIMEOUTB | TIMEOUTA | MPEC_RX_ER<br>R | MDMA_DONE_<br>RX | MDMA_DONE_<br>TX | MARBLOST | MSTOP | MSTART | | R/W-0h | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | MNACK | RESERVED | MTXEMPTY | MRXFIFOFULL | MTXFIFOTRG | MRXFIFOTRG | MTXDONE | MRXDONE | | R/W-0h #### **Table 16-31. IMASK Field Descriptions** | Bit | Field | Туре | Reset | Description | |-----|--------------|--------|-------|-------------------------------------------------------| | | 1 1 1 1 1 1 | | | • | | 31 | INTR_OVFL | R/W | 0h | Interrupt Overflow Interrupt Mask | | | | | | 0h = Clear Interrupt Mask<br>1h = Set Interrupt Mask | | | OARRI COT | D 0.47 | | · | | 30 | SARBLOST | R/W | 0h | Target Arbitration Lost 0h = Clear Set Interrupt Mask | | | | | | 1h = Set Interrupt Mask | | 29 | CDV OVEL | R/W | 0h | · | | 29 | SRX_OVFL | R/VV | Un | Target RX FIFO overflow 0h = Clear Interrupt Mask | | | | | | 1h = Set Interrupt Mask | | 28 | STX UNFL | R/W | 0h | Target TX FIFO underflow | | 20 | OTX_ONI E | 1000 | 011 | 0h = Clear Interrupt Mask | | | | | | 1h = Set Interrupt Mask | | 27 | SPEC RX ERR | R/W | 0h | Target RX Pec Error Interrupt | | | | 1.4.1. | | 0h = Clear Interrupt Mask | | | | | | 1h = Set Interrupt Mask | | 26 | SDMA_DONE_RX | R/W | 0h | Target DMA Done on Event Channel RX | | | | | | 0h = Clear Interrupt Mask | | | | | | 1h = Set Interrupt Mask | | 25 | SDMA_DONE_TX | R/W | 0h | Target DMA Done on Event Channel TX | | | | | | 0h = Clear Interrupt Mask | | | | | | 1h = Set Interrupt Mask | | 24 | SGENCALL | R/W | 0h | General Call Interrupt | | | | | | 0h = Clear Interrupt Mask | | | | | | 1h = Set Interrupt Mask | | 23 | SSTOP | R/W | 0h | Stop Condition Interrupt | | | | | | 0h = Clear Interrupt Mask | | | | | | 1h = Set Interrupt Mask | # **Table 16-31. IMASK Field Descriptions (continued)** | Table 16-31. IMASK Fleid | | | IIVIASK FIEIU | Descriptions (continued) | | |--------------------------|--------------|------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | Bit | Field | Туре | Reset | Description | | | 22 | SSTART | R/W | 0h | Start Condition Interrupt 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | 21 | STXEMPTY | R/W | Oh | Target Transmit FIFO Empty interrupt mask. This interrupt is set if all data in the Transmit FIFO have been shifted out and the transmit goes into idle mode. 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | 20 | SRXFIFOFULL | R/W | 0h | RXFIFO full event. This interrupt is set if an Target RX FIFO is full. 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | 19 | STXFIFOTRG | R/W | 0h | Target Transmit FIFO Trigger 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | 18 | SRXFIFOTRG | R/W | 0h | Target Receive FIFO Trigger 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | 17 | STXDONE | R/W | 0h | Target Transmit Transaction completed Interrupt 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | 16 | SRXDONE | R/W | Oh | Target Receive Data Interrupt Signals that a byte has been received 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | 15 | TIMEOUTB | R/W | 0h | Timeout B Interrupt 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | 14 | TIMEOUTA | R/W | 0h | Timeout A Interrupt 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | 13 | MPEC_RX_ERR | R/W | 0h | Controller RX Pec Error Interrupt 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | 12 | MDMA_DONE_RX | R/W | 0h | DMA Done on Event Channel RX 0h = Interrupt disabled 1h = Set Interrupt Mask | | | 11 | MDMA_DONE_TX | R/W | 0h | DMA Done on Event Channel TX 0h = Interrupt disabled 1h = Set Interrupt Mask | | | 10 | MARBLOST | R/W | 0h | Arbitration Lost Interrupt 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | 9 | MSTOP | R/W | 0h | STOP Detection Interrupt 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | 8 | MSTART | R/W | 0h | START Detection Interrupt 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | 7 | MNACK | R/W | 0h | Address/Data NACK Interrupt 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | 6 | RESERVED | R/W | 0h | | | | 5 | MTXEMPTY | R/W | Oh | Transmit FIFO Empty interrupt mask. This interrupt is set if all data in the Transmit FIFO have been shifted out and the transmit goes into idle mode. 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | *I*<sup>2</sup>*C* www.ti.com # **Table 16-31. IMASK Field Descriptions (continued)** | Bit | Field | Туре | Reset | Description | |-----|-------------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------| | 4 | MRXFIFOFULL | R/W | Oh | RXFIFO full event. This interrupt is set if an RX FIFO is full. 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | 3 | MTXFIFOTRG | R/W | 0h | Controller Transmit FIFO Trigger Trigger when Transmit FIFO contains <= defined bytes 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | 2 | MRXFIFOTRG | R/W | 0h | Controller Receive FIFO Trigger Trigger when RX FIFO contains >= defined bytes 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | 1 | MTXDONE | R/W | Oh | Controller Transmit Transaction completed Interrupt 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | 0 | MRXDONE | R/W | Oh | Controller Receive Transaction completed Interrupt 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | www.ti.com P<sup>2</sup>C ### 16.3.10 RIS (Offset = 1030h) [Reset = 00000000h] RIS is shown in Figure 16-26 and described in Table 16-32. Return to the Summary Table. Raw interrupt status. Reflects all pending interrupts, regardless of masking. The RIS register allows the user to implement a poll scheme. A flag set in this register can be cleared by writing 1 to the ICLR register bit even if the corresponding IMASK bit is not enabled. #### Figure 16-26. RIS | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-----------|----------|-----------------|------------------|------------------|------------------|------------------|----------| | INTR_OVFL | SARBLOST | SRX_OVFL | STX_UNFL | SPEC_RX_ER<br>R | SDMA_DONE_<br>RX | SDMA_DONE_<br>TX | SGENCALL | | R- | R-0 h | R-0h | R-0h | R-0h | R-0h | R-0h | R-0h | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | SSTOP | SSTART | STXEMPTY | SRXFIFOFULL | STXFIFOTRG | SRXFIFOTRG | STXDONE | SRXDONE | | R-0h | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | TIMEOUTB | TIMEOUTA | MPEC_RX_ER<br>R | MDMA_DONE_<br>RX | MDMA_DONE_<br>TX | MARBLOST | MSTOP | MSTART | | R-0h | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | MNACK | RESERVED | MTXEMPTY | MRXFIFOFULL | MTXFIFOTRG | MRXFIFOTRG | MTXDONE | MRXDONE | | R-0h | R- | R-0h | R-0h | R-0h | R-0h | R-0h | R-0h | ### Table 16-32. RIS Field Descriptions | Bit | Field | Туре | Reset | Description | |-----|--------------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 | INTR_OVFL | R | 0h | Interrupt overflow interrupt It is set when SSTART or SSTOP interrupts overflow i.e. occur twice without being serviced Oh = Interrupt did not occur 1h = Interrupt occured | | 30 | SARBLOST | R | 0 h | Target Arbitration Lost 0h = Interrupt did not occur 1h = Interrupt occured | | 29 | SRX_OVFL | R | 0h | Target RX FIFO overflow 0h = Interrupt did not occur 1h = Interrupt Occured | | 28 | STX_UNFL | R | 0h | Target TX FIFO underflow 0h = Interrupt did not occur 1h = Interrupt occured | | 27 | SPEC_RX_ERR | R | 0h | Target RX Pec Error Interrupt 0h = Interrupt did not occur 1h = Interrupt ocuured | | 26 | SDMA_DONE_RX | R | 0h | DMA Done on Event Channel RX 0h = Clear interrupt 1h = Set interrupt | | 25 | SDMA_DONE_TX | R | Oh | DMA Done on Event Channel TX 0h = Clear interrupt 1h = Set interrupt | | 24 | SGENCALL | R | Oh | General Call Interrupt 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | *I*<sup>2</sup>*C* www.ti.com # Table 16-32. RIS Field Descriptions (continued) | Table 16-32. RIS Field Descriptions (continued) | | | | | | | |-------------------------------------------------|--------------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Bit | Field | Туре | Reset | Description | | | | 23 | SSTOP | R | 0h | Stop Condition Interrupt 0h = Clear Interrupt 1h = Set interrupt | | | | 22 | SSTART | R | 0h | Start Condition Interrupt 0h = Clear interrupt 1h = Set Interrupt | | | | 21 | STXEMPTY | R | Oh | Transmit FIFO Empty interrupt mask. This interrupt is set if all data in the Transmit FIFO have been shifted out and the transmit goes into idle mode. Oh = Interrupt did not occur 1h = Set Interrupt Mask | | | | 20 | SRXFIFOFULL | R | 0h | RXFIFO full event. This interrupt is set if an RX FIFO is full. 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | | 19 | STXFIFOTRG | R | 0h | Target Transmit FIFO Trigger 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | | 18 | SRXFIFOTRG | R | 0h | Target Receive FIFO Trigger 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | | 17 | STXDONE | R | 0h | Target Transmit Transaction completed Interrupt 0h = Interrupt did not occur 1h = Set Interrupt Mask | | | | 16 | SRXDONE | R | 0h | Target Receive Data Interrupt Signals that a byte has been received 0h = Interrupt did not occur 1h = Set Interrupt Mask | | | | 15 | TIMEOUTB | R | 0h | Timeout B Interrupt 0h = Interrupt did not occur 1h = Interrupt occured | | | | 14 | TIMEOUTA | R | 0h | Timeout A Interrupt 0h = Interrupt did not occur 1h = Set Interrupt Mask | | | | 13 | MPEC_RX_ERR | R | 0h | Controller RX Pec Error Interrupt 0h = Interrupt did not occur 1h = Interrupt Occured | | | | 12 | MDMA_DONE_RX | R | 0h | DMA Done on Event Channel RX 0h = Interrupt disabled 1h = Set Interrupt Mask | | | | 11 | MDMA_DONE_TX | R | 0h | DMA Done on Event Channel TX 0h = Interrupt disabled 1h = Set Interrupt Mask | | | | 10 | MARBLOST | R | 0h | Arbitration Lost Interrupt 0h = Interrupt did not occur 1h = Set Interrupt Mask | | | | 9 | MSTOP | R | 0h | STOP Detection Interrupt 0h = Interrupt did not occur 1h = Set Interrupt Mask | | | | 8 | MSTART | R | 0h | START Detection Interrupt 0h = Interrupt did not occur 1h = Set Interrupt Mask | | | | 7 | MNACK | R | 0h | Address/Data NACK Interrupt 0h = Interrupt did not occur 1h = Set Interrupt Mask | | | | 6 | RESERVED | R | 0h | | | | | L | | | | I . | | | # Table 16-32. RIS Field Descriptions (continued) | | I= | | | | |-----|-------------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Field | Туре | Reset | Description | | 5 | MTXEMPTY | R | Oh | Transmit FIFO Empty interrupt mask. This interrupt is set if all data in the Transmit FIFO have been shifted out and the transmit goes into idle mode. Oh = Interrupt did not occur 1h = Set Interrupt Mask | | 4 | MRXFIFOFULL | R | 0h | RXFIFO full event. This interrupt is set if an RX FIFO is full. 0h = Interrupt did not occur 1h = Set Interrupt Mask | | 3 | MTXFIFOTRG | R | Oh | Controller Transmit FIFO Trigger Trigger when Transmit FIFO contains <= defined bytes 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | 2 | MRXFIFOTRG | R | Oh | Controller Receive FIFO Trigger Trigger when RX FIFO contains >= defined bytes 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | 1 | MTXDONE | R | 0h | Controller Transmit Transaction completed Interrupt 0h = Interrupt did not occur 1h = Set Interrupt Mask | | 0 | MRXDONE | R | 0h | Controller Receive Transaction completed Interrupt 0h = Interrupt did not occur 1h = Set Interrupt Mask | # 16.3.11 MIS (Offset = 1038h) [Reset = 00000000h] MIS is shown in Figure 16-27 and described in Table 16-33. Return to the Summary Table. Masked interrupt status. This is an AND of the IMASK and RIS registers. ## Figure 16-27. MIS | | | | 1.194.0 | | | | | |-----------|----------|-----------------|------------------|------------------|------------------|------------------|----------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | INTR_OVFL | SARBLOST | SRX_OVFL | STX_UNFL | SPEC_RX_ER<br>R | SDMA_DONE_<br>RX | SDMA_DONE_<br>TX | SGENCALL | | R-0h | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | SSTOP | SSTART | STXEMPTY | SRXFIFOFULL | STXFIFOTRG | SRXFIFOTRG | STXDONE | SRXDONE | | R-0h | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | TIMEOUTB | TIMEOUTA | MPEC_RX_ER<br>R | MDMA_DONE_<br>RX | MDMA_DONE_<br>TX | MARBLOST | MSTOP | MSTART | | R-0h | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | MNACK | RESERVED | MTXEMPTY | MRXFIFOFULL | MTXFIFOTRG | MRXFIFOTRG | MTXDONE | MRXDONE | | R-0h ### **Table 16-33. MIS Field Descriptions** | Bit | Field | Туре | Reset | Description | |-----|--------------|------|-------|---------------------------------------------------------------------------------| | 31 | INTR_OVFL | R | Oh | Interrupt overflow Oh = Interrupt did not occur 1h = Interrupt occured | | 30 | SARBLOST | R | Oh | Target Arbitration Lost 0h = Clear interrupt mask 1h = Set interrupt mask | | 29 | SRX_OVFL | R | Oh | Target RX FIFO overflow 0h = Clear interrupt mask 1h = Set interrupt mask | | 28 | STX_UNFL | R | Oh | Target TX FIFO underflow 0h = Clear interrupt mask 1h = Set interrupt mask | | 27 | SPEC_RX_ERR | R | Oh | Target RX Pec Error Interrupt 0h = Clear interrupt mask 1h = Set interrupt mask | | 26 | SDMA_DONE_RX | R | Oh | DMA Done on Event Channel RX 0h = Clear MIS 1h = Set MIS | | 25 | SDMA_DONE_TX | R | Oh | DMA Done on Event Channel TX 0h = Clear MIS 1h = Set MIS | | 24 | SGENCALL | R | Oh | General Call Interrupt 0h = Interrupt did not occur 1h = Set Interrupt Mask | | 23 | SSTOP | R | Oh | Target STOP Detection Interrupt 0h = Clear MIS 1h = Set MIS | | 22 | SSTART | R | Oh | Target START Detection Interrupt 0h = Clear MIS 1h = Set MIS | # **Table 16-33. MIS Field Descriptions (continued)** | D:4 | Ciold | | | Descriptions (continued) | |-----|--------------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Field | Туре | Reset | Description | | 21 | STXEMPTY | R | Oh | Transmit FIFO Empty interrupt mask. This interrupt is set if all data in the Transmit FIFO have been shifted out and the transmit goes into idle mode. Oh = Interrupt did not occur 1h = Set Interrupt Mask | | 20 | SRXFIFOFULL | R | Oh | RXFIFO full event. This interrupt is set if an RX FIFO is full. 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | 19 | STXFIFOTRG | R | 0h | Target Transmit FIFO Trigger 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | 18 | SRXFIFOTRG | R | 0h | Target Receive FIFO Trigger 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | 17 | STXDONE | R | 0h | Target Transmit Transaction completed Interrupt Oh = Interrupt did not occur 1h = Set Interrupt Mask | | 16 | SRXDONE | R | Oh | Target Receive Data Interrupt Signals that a byte has been received 0h = Interrupt did not occur 1h = Set Interrupt Mask | | 15 | TIMEOUTB | R | 0h | Timeout B Interrupt 0h = Clear interrupt mask 1h = Set interrupt mask | | 14 | TIMEOUTA | R | 0h | Timeout A Interrupt 0h = Interrupt did not occur 1h = Set Interrupt Mask | | 13 | MPEC_RX_ERR | R | 0h | Controller RX Pec Error Interrupt 0h = Clear interrupt mask 1h = Set interrupt mask | | 12 | MDMA_DONE_RX | R | 0h | DMA Done on Event Channel RX 0h = Interrupt disabled 1h = Set Interrupt Mask | | 11 | MDMA_DONE_TX | R | 0h | DMA Done on Event Channel TX 0h = Interrupt disabled 1h = Set Interrupt Mask | | 10 | MARBLOST | R | Oh | Arbitration Lost Interrupt Oh = Interrupt did not occur 1h = Set Interrupt Mask | | 9 | MSTOP | R | Oh | STOP Detection Interrupt 0h = Interrupt did not occur 1h = Set Interrupt Mask | | 8 | MSTART | R | Oh | START Detection Interrupt 0h = Interrupt did not occur 1h = Set Interrupt Mask | | 7 | MNACK | R | Oh | Address/Data NACK Interrupt 0h = Interrupt did not occur 1h = Set Interrupt Mask | | 6 | RESERVED | R | 0h | | | 5 | MTXEMPTY | R | Oh | Transmit FIFO Empty interrupt mask. This interrupt is set if all data in the Transmit FIFO have been shifted out and the transmit goes into idle mode. Oh = Interrupt did not occur 1h = Set Interrupt Mask | | 4 | MRXFIFOFULL | R | Oh | RXFIFO full event. This interrupt is set if the RX FIFO is full. 0h = Interrupt did not occur 1h = Set Interrupt Mask | *I*<sup>2</sup>*C* www.ti.com # **Table 16-33. MIS Field Descriptions (continued)** | Bit | Field | Туре | Reset | Description | | | | |-----|------------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | 3 | MTXFIFOTRG | R | Oh | Controller Transmit FIFO Trigger Trigger when Transmit FIFO contains <= defined bytes 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | | | 2 | MRXFIFOTRG | R | Oh | Controller Receive FIFO Trigger Trigger when RX FIFO contains >= defined bytes 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | | | 1 | MTXDONE | R | 0h | Controller Transmit Transaction completed Interrupt 0h = Interrupt did not occur 1h = Set Interrupt Mask | | | | | 0 | MRXDONE | R | Oh | Controller Receive Data Interrupt 0h = Interrupt did not occur 1h = Set Interrupt Mask | | | | www.ti.com P<sup>2</sup>C ### 16.3.12 ISET (Offset = 1040h) [Reset = 00000000h] ISET is shown in Figure 16-28 and described in Table 16-34. Return to the Summary Table. Interrupt set. Allows interrupts to be set by software (useful in diagnostics and safety checks). Writing a 1 to a bit in ISET will set the event and therefore the related RIS bit also gets set. If the interrupt is enabled through the mask, then the corresponding MIS bit is also set. Figure 16-28. ISET | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |-----------|----------|-----------------|------------------|------------------|------------------|------------------|----------| | INTR_OVFL | SARBLOST | SRX_OVFL | STX_UNFL | SPEC_RX_ER<br>R | SDMA_DONE_<br>RX | SDMA_DONE_<br>TX | SGENCALL | | W-0h | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | SSTOP | SSTART | STXEMPTY | SRXFIFOFULL | STXFIFOTRG | SRXFIFOTRG | STXDONE | SRXDONE | | W-0h | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | TIMEOUTB | TIMEOUTA | MPEC_RX_ER<br>R | MDMA_DONE_<br>RX | MDMA_DONE_<br>TX | MARBLOST | MSTOP | MSTART | | W-0h | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | MNACK | RESERVED | MTXEMPTY | MRXFIFOFULL | MTXFIFOTRG | MRXFIFOTRG | MTXDONE | MRXDONE | | W-0h ### Table 16-34. ISET Field Descriptions | Bit | Field | Туре | Reset | Description | |-----|--------------|------|-------|-------------------------------------------------------------------------------| | 31 | INTR_OVFL | W | 0h | Interrupt overflow 0h = No effect 1h = Set interrupt | | 30 | SARBLOST | W | 0h | Target Arbitration Lost 0h = Writing 0 has no effect 1h = Set interrupt | | 29 | SRX_OVFL | W | 0h | Target RX FIFO overflow 0h = Writing 0 has no effect 1h = Set interrupt | | 28 | STX_UNFL | W | 0h | Target TX FIFO underflow 0h = Writing 0 has no effect 1h = Set interrupt | | 27 | SPEC_RX_ERR | W | 0h | Target RX Pec Error Interrupt 0h = Writing 0 has no effect 1h = Set interrupt | | 26 | SDMA_DONE_RX | W | 0h | DMA Done on Event Channel RX 0h = Writing 0 has no effect 1h = Set interrupt | | 25 | SDMA_DONE_TX | W | 0h | DMA Done on Event Channel TX 0h = Writing 0 has no effect 1h = Set interrupt | | 24 | SGENCALL | W | Oh | General Call Interrupt 0h = Writing 0 has no effect 1h = Set Interrupt Mask | | 23 | SSTOP | W | 0h | Stop Condition Interrupt 0h = Writing 0 has no effect 1h = Set interrupt | *I*<sup>2</sup>C www.ti.com # Table 16-34. ISET Field Descriptions (continued) | Bit | Field | Type | Reset | Descriptions (continued) | |-----|--------------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 22 | SSTART | W | 0h | Start Condition Interrupt | | | CO IT II Y | | | 0h = Writing 0 has no effect 1h = Set interrupt | | 21 | STXEMPTY | W | Oh | Transmit FIFO Empty interrupt mask. This interrupt is set if all data in the Transmit FIFO have been shifted out and the transmit goes into idle mode. 0h = Writing 0 has no effect 1h = Set Interrupt Mask | | 20 | SRXFIFOFULL | W | 0h | RXFIFO full event. This interrupt is set if an RX FIFO is full. 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | 19 | STXFIFOTRG | W | 0h | Target Transmit FIFO Trigger 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | 18 | SRXFIFOTRG | W | 0h | Target Receive FIFO Trigger 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | 17 | STXDONE | W | 0h | Target Transmit Transaction completed Interrupt 0h = Writing 0 has no effect 1h = Set Interrupt Mask | | 16 | SRXDONE | W | 0h | Target Receive Data Interrupt Signals that a byte has been received 0h = Writing 0 has no effect 1h = Set Interrupt Mask | | 15 | TIMEOUTB | W | 0h | Timeout B Interrupt 0h = Writing 0 has no effect 1h = Set interrupt | | 14 | TIMEOUTA | W | 0h | Timeout A interrupt 0h = Writing 0 has no effect 1h = Set Interrupt Mask | | 13 | MPEC_RX_ERR | W | 0h | Controller RX Pec Error Interrupt 0h = Writing 0 has no effect 1h = Set interrupt | | 12 | MDMA_DONE_RX | W | 0h | DMA Done on Event Channel RX 0h = Interrupt disabled 1h = Set Interrupt Mask | | 11 | MDMA_DONE_TX | W | 0h | DMA Done on Event Channel TX 0h = Interrupt disabled 1h = Set Interrupt Mask | | 10 | MARBLOST | W | 0h | Arbitration Lost Interrupt 0h = Writing 0 has no effect 1h = Set Interrupt Mask | | 9 | MSTOP | W | 0h | STOP Detection Interrupt 0h = Writing 0 has no effect 1h = Set Interrupt Mask | | 8 | MSTART | W | 0h | START Detection Interrupt 0h = Writing 0 has no effect 1h = Set Interrupt Mask | | 7 | MNACK | W | 0h | Address/Data NACK Interrupt 0h = Writing 0 has no effect 1h = Set Interrupt Mask | | 6 | RESERVED | W | 0h | | | 5 | MTXEMPTY | W | Oh | Transmit FIFO Empty interrupt mask. This interrupt is set if all data in the Transmit FIFO have been shifted out and the transmit goes into idle mode. 0h = Writing 0 has no effect 1h = Set Interrupt Mask | # **Table 16-34. ISET Field Descriptions (continued)** | Bit | Field | Туре | Reset | Description | |-----|-------------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------| | 4 | MRXFIFOFULL | W | Oh | RXFIFO full event. 0h = Writing 0 has no effect 1h = Set Interrupt Mask | | 3 | MTXFIFOTRG | W | 0h | Controller Transmit FIFO Trigger Trigger when Transmit FIFO contains <= defined bytes 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | 2 | MRXFIFOTRG | W | 0h | Controller Receive FIFO Trigger Trigger when RX FIFO contains >= defined bytes 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | 1 | MTXDONE | W | 0h | Controller Transmit Transaction completed Interrupt 0h = Writing 0 has no effect 1h = Set Interrupt Mask | | 0 | MRXDONE | W | 0h | Controller Receive Data Interrupt Signals that a byte has been received 0h = Writing 0 has no effect 1h = Set Interrupt Mask | # 16.3.13 ICLR (Offset = 1048h) [Reset = 00000000h] ICLR is shown in Figure 16-29 and described in Table 16-35. Return to the Summary Table. Interrupt clear. Write a 1 to clear corresponding Interrupt. ## Figure 16-29. ICLR | 1.94.0.10.11. | | | | | | | | |---------------|----------|-----------------|------------------|------------------|------------------|------------------|----------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | INTR_OVFL | SARBLOST | SRX_OVFL | STX_UNFL | SPEC_RX_ER<br>R | SDMA_DONE_<br>RX | SDMA_DONE_<br>TX | SGENCALL | | W-0h | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | SSTOP | SSTART | STXEMPTY | SRXFIFOFULL | STXFIFOTRG | SRXFIFOTRG | STXDONE | SRXDONE | | W-0h | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | TIMEOUTB | TIMEOUTA | MPEC_RX_ER<br>R | MDMA_DONE_<br>RX | MDMA_DONE_<br>TX | MARBLOST | MSTOP | MSTART | | W-0h | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | MNACK | RESERVED | MTXEMPTY | MRXFIFOFULL | MTXFIFOTRG | MRXFIFOTRG | MTXDONE | MRXDONE | | W-0h ### **Table 16-35. ICLR Field Descriptions** | Bit | Field | Туре | Reset | Description | |-----|--------------|------|-------|------------------------------------------------------------------------------------| | 31 | INTR_OVFL | W | Oh | Interrupt overflow 0h = No effect 1h = Clear interrupt | | 30 | SARBLOST | W | Oh | Target Arbitration Lost 0h = Writing 0 has no effect 1h = Clear Interrupt | | 29 | SRX_OVFL | W | Oh | Target RX FIFO overflow 0h = Writing 0 has no effect 1h = Clear Interrupt | | 28 | STX_UNFL | W | Oh | Target TX FIFO underflow 0h = Writing 0 has no effect 1h = Clear Interrupt | | 27 | SPEC_RX_ERR | W | Oh | Target RX Pec Error Interrupt 0h = Writing 0 has no effect 1h = Clear Interrupt | | 26 | SDMA_DONE_RX | W | Oh | DMA Done on Event Channel RX 0h = Writing 0 has no effect 1h = Clear interrupt | | 25 | SDMA_DONE_TX | W | Oh | DMA Done on Event Channel TX 0h = Writing 0 has no effect 1h = Clear interrupt | | 24 | SGENCALL | W | Oh | General Call Interrupt 0h = Writing 0 has no effect 1h = Set Interrupt Mask | | 23 | SSTOP | W | Oh | Target STOP Detection Interrupt 0h = Writing 0 has no effect 1h = Clear interrupt | | 22 | SSTART | W | Oh | Target START Detection Interrupt 0h = Writing 0 has no effect 1h = Clear interrupt | # Table 16-35. ICLR Field Descriptions (continued) | Table 16-35. ICLR Field I | | | | | | | |---------------------------|--------------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Bit | Field | Туре | Reset | Description | | | | 21 | STXEMPTY | W | 0h | Transmit FIFO Empty interrupt mask. This interrupt is set if all data in the Transmit FIFO have been shifted out and the transmit goes into idle mode. 0h = Writing 0 has no effect 1h = Set Interrupt Mask | | | | 20 | SRXFIFOFULL | W | Oh | RXFIFO full event. This interrupt is set if an RX FIFO is full. 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | | 19 | STXFIFOTRG | W | 0h | Target Transmit FIFO Trigger 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | | 18 | SRXFIFOTRG | W | 0h | Target Receive FIFO Trigger 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | | 17 | STXDONE | W | 0h | Target Transmit Transaction completed Interrupt 0h = Writing 0 has no effect 1h = Set Interrupt Mask | | | | 16 | SRXDONE | W | Oh | Target Receive Data Interrupt Signals that a byte has been received 0h = Writing 0 has no effect 1h = Set Interrupt Mask | | | | 15 | TIMEOUTB | W | 0h | Timeout B Interrupt 0h = Writing 0 has no effect 1h = Clear Interrupt | | | | 14 | TIMEOUTA | W | 0h | Timeout A interrupt 0h = Writing 0 has no effect 1h = Set Interrupt Mask | | | | 13 | MPEC_RX_ERR | W | 0h | Controller RX Pec Error Interrupt 0h = Writing 0 has no effect 1h = Clear Interrupt | | | | 12 | MDMA_DONE_RX | W | 0h | DMA Done on Event Channel RX 0h = Interrupt disabled 1h = Set Interrupt Mask | | | | 11 | MDMA_DONE_TX | W | 0h | DMA Done on Event Channel TX 0h = Interrupt disabled 1h = Set Interrupt Mask | | | | 10 | MARBLOST | W | 0h | Arbitration Lost Interrupt 0h = Writing 0 has no effect 1h = Set Interrupt Mask | | | | 9 | MSTOP | W | 0h | STOP Detection Interrupt 0h = Writing 0 has no effect 1h = Set Interrupt Mask | | | | 8 | MSTART | W | 0h | START Detection Interrupt 0h = Writing 0 has no effect 1h = Set Interrupt Mask | | | | 7 | MNACK | W | 0h | Address/Data NACK Interrupt 0h = Writing 0 has no effect 1h = Set Interrupt Mask | | | | 6 | RESERVED | W | 0h | | | | | 5 | MTXEMPTY | W | Oh | Transmit FIFO Empty interrupt mask. This interrupt is set if all data in the Transmit FIFO have been shifted out and the transmit goes into idle mode. 0h = Writing 0 has no effect 1h = Set Interrupt Mask | | | | 4 | MRXFIFOFULL | W | Oh | RXFIFO full event. 0h = Writing 0 has no effect 1h = Set Interrupt Mask | | | *I*<sup>2</sup>*C* www.ti.com # **Table 16-35. ICLR Field Descriptions (continued)** | Bit | Field | Туре | Reset | Description | |-----|------------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------| | 3 | MTXFIFOTRG | W | 0h | Controller Transmit FIFO Trigger Trigger when Transmit FIFO contains <= defined bytes 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | 2 | MRXFIFOTRG | W | 0h | Controller Receive FIFO Trigger Trigger when RX FIFO contains >= defined bytes 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | 1 | MTXDONE | W | Oh | Controller Transmit Transaction completed Interrupt 0h = Writing 0 has no effect 1h = Set Interrupt Mask | | 0 | MRXDONE | W | 0h | Controller Receive Data Interrupt Signals that a byte has been received 0h = Writing 0 has no effect 1h = Set Interrupt Mask | ### 16.3.14 IIDX (Offset = 1050h) [Reset = 00000000h] IIDX is shown in Figure 16-30 and described in Table 16-36. Return to the Summary Table. This register provides the highest priority enabled interrupt index. #### Figure 16-30. IIDX # **Table 16-36. IIDX Field Descriptions** | Table 10-00. IIDA I leid Descriptions | | | | | | |---------------------------------------|----------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | Bit | Field | Туре | Reset | Description | | | 31-8 | RESERVED | R | 0h | | | | 7-0 | STAT | R | Oh | I2C Module Interrupt Vector Value. This register provides the highes priority interrupt index. A read clears the corresponding interrupt flag in RIS and MISC. 15h-1Fh = Reserved 00h = No interrupt pending 01h = Controller receive FIFO Trigger Level 02h = Controller transmit FIFO Trigger level 03h = Target receive FIFO Trigger Level 04h = Target transmit FIFO Trigger level | | # 16.3.15 IMASK (Offset = 1058h) [Reset = 00000000h] IMASK is shown in Figure 16-31 and described in Table 16-37. Return to the Summary Table. Interrupt Mask. If a bit is set, then corresponding interrupt is un-masked. Un-masking the interrupt causes the raw interrupt to be visible in IIDX, as well as MIS. Figure 16-31. IMASK #### **Table 16-37. IMASK Field Descriptions** | Bit | Field | Туре | Reset | Description | |------|------------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------| | 31-4 | RESERVED | R/W | 0h | | | 3 | STXFIFOTRG | R/W | Oh | Target Transmit FIFO Trigger 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | 2 | SRXFIFOTRG | R/W | Oh | Target Receive FIFO Trigger 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | 1 | MTXFIFOTRG | R/W | 0h | Controller Transmit FIFO Trigger Trigger when Transmit FIFO contains <= defined bytes 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | 0 | MRXFIFOTRG | R/W | 0h | Controller Receive FIFO Trigger Trigger when RX FIFO contains >= defined bytes 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | ### 16.3.16 RIS (Offset = 1060h) [Reset = 00000000h] RIS is shown in Figure 16-32 and described in Table 16-38. Return to the Summary Table. Raw interrupt status. Reflects all pending interrupts, regardless of masking. The RIS register allows the user to implement a poll scheme. A flag set in this register can be cleared by writing 1 to the ICLR register bit even if the corresponding IMASK bit is not enabled. Figure 16-32. RIS #### Table 16-38. RIS Field Descriptions | Bit | Field | Туре | Reset | Description | |------|------------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------| | 31-4 | RESERVED | R | 0h | | | 3 | STXFIFOTRG | R | 0h | Target Transmit FIFO Trigger 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | 2 | SRXFIFOTRG | R | 0h | Target Receive FIFO Trigger 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | 1 | MTXFIFOTRG | R | Oh | Controller Transmit FIFO Trigger Trigger when Transmit FIFO contains <= defined bytes 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | 0 | MRXFIFOTRG | R | Oh | Controller Receive FIFO Trigger Trigger when RX FIFO contains >= defined bytes 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | ## 16.3.17 MIS (Offset = 1068h) [Reset = 00000000h] MIS is shown in Figure 16-33 and described in Table 16-39. Return to the Summary Table. Masked interrupt status. This is an AND of the IMASK and RIS registers. ### Figure 16-33. MIS | | | | i iguie i | 0-33. IVII3 | | | | | | | |----|----------|------|-----------|-------------|------------|------------|------------|--|--|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | | RESERVED | | | | | | | | | | | | R-0h | | | | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | | RESERVED | | | | | | | | | | | | R-0h | | | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | | | RESE | RVED | | | | | | | | | | | R | -0h | | | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | RESE | RVED | | STXFIFOTRG | SRXFIFOTRG | MTXFIFOTRG | MRXFIFOTRG | | | | | | R-0 | 0h | | R-0h | R-0h | R-0h | R-0h | | | | ### **Table 16-39. MIS Field Descriptions** | Bit | Field | Туре | Reset | Description | | | | |------|------------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | 31-4 | RESERVED | R | 0h | | | | | | 3 | STXFIFOTRG | R | 0h | Target Transmit FIFO Trigger 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | | | 2 | SRXFIFOTRG | R | 0h | Target Receive FIFO Trigger 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | | | 1 | MTXFIFOTRG | R | 0h | Controller Transmit FIFO Trigger Trigger when Transmit FIFO contains <= defined bytes 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | | | 0 | MRXFIFOTRG | R | 0h | Controller Receive FIFO Trigger Trigger when RX FIFO contains >= defined bytes 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | | ### 16.3.18 ISET (Offset = 1070h) [Reset = 00000000h] ISET is shown in Figure 16-34 and described in Table 16-40. Return to the Summary Table. Interrupt set. Allows interrupts to be set by software (useful in diagnostics and safety checks). Writing a 1 to a bit in ISET will set the event and therefore the related RIS bit also gets set. If the interrupt is enabled through the mask, then the corresponding MIS bit is also set. Figure 16-34. ISET #### Table 16-40. ISET Field Descriptions | Bit | Field | Туре | Reset | Description | |------|------------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------| | 31-4 | RESERVED | W | 0h | | | 3 | STXFIFOTRG | W | 0h | Target Transmit FIFO Trigger 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | 2 | SRXFIFOTRG | W | 0h | Target Receive FIFO Trigger 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | 1 | MTXFIFOTRG | W | Oh | Controller Transmit FIFO Trigger Trigger when Transmit FIFO contains <= defined bytes 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | 0 | MRXFIFOTRG | W | Oh | Controller Receive FIFO Trigger Trigger when RX FIFO contains >= defined bytes 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | ## 16.3.19 ICLR (Offset = 1078h) [Reset = 00000000h] ICLR is shown in Figure 16-35 and described in Table 16-41. Return to the Summary Table. Interrupt clear. Write a 1 to clear corresponding Interrupt. ### Figure 16-35. ICLR | | | | 9 | | | | | | | |----------|-------|------|------|------------|------------|------------|------------|--|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | | | RESE | RVED | | | | | | | | W-0h | | | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | RESERVED | | | | | | | | | | | W-0h | | | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | | RESE | RVED | | | | | | | | | | W | -0h | | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | RESEF | RVED | | STXFIFOTRG | SRXFIFOTRG | MTXFIFOTRG | MRXFIFOTRG | | | | | W-( | )h | | W-0h | W-0h | W-0h | W-0h | | | #### **Table 16-41. ICLR Field Descriptions** | _ | | | | | | | | |---|------|------------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------|--|--| | | Bit | Field | Туре | Reset | Description | | | | | 31-4 | RESERVED | W | 0h | | | | | | 3 | STXFIFOTRG | W | Oh | Target Transmit FIFO Trigger 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | | | 2 | SRXFIFOTRG | W | Oh | Target Receive FIFO Trigger 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | | | 1 | MTXFIFOTRG | W | 0h | Controller Transmit FIFO Trigger Trigger when Transmit FIFO contains <= defined bytes 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | | | 0 | MRXFIFOTRG | W | 0h | Controller Receive FIFO Trigger Trigger when RX FIFO contains >= defined bytes 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | ### 16.3.20 IIDX (Offset = 1080h) [Reset = 00000000h] IIDX is shown in Figure 16-36 and described in Table 16-42. Return to the Summary Table. This register provides the highest priority enabled interrupt index. #### Figure 16-36. IIDX ## **Table 16-42. IIDX Field Descriptions** | | Table 10 421 IIBX 1 Iola Becomptione | | | | | | | | |------|--------------------------------------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | | 31-8 | RESERVED | R | 0h | | | | | | | 7-0 | STAT | R | Oh | I2C Module Interrupt Vector Value. This register provides the highes priority interrupt index. A read clears the corresponding interrupt flag in RIS and MISC. 15h-1Fh = Reserved 00h = No interrupt pending 01h = Controller receive FIFO Trigger Level 02h = Controller transmit FIFO Trigger level 03h = Target receive FIFO Trigger Level 04h = Target transmit FIFO Trigger level | | | | | # 16.3.21 IMASK (Offset = 1088h) [Reset = 00000000h] IMASK is shown in Figure 16-37 and described in Table 16-43. Return to the Summary Table. Interrupt Mask. If a bit is set, then corresponding interrupt is un-masked. Un-masking the interrupt causes the raw interrupt to be visible in IIDX, as well as MIS. Figure 16-37. IMASK #### **Table 16-43. IMASK Field Descriptions** | Bit | Field | Туре | Reset | Description | | | | |------|------------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | 31-4 | RESERVED | R/W | 0h | | | | | | 3 | STXFIFOTRG | R/W | 0h | Target Transmit FIFO Trigger 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | | | 2 | SRXFIFOTRG | R/W | Oh | Target Receive FIFO Trigger 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | | | 1 | MTXFIFOTRG | R/W | 0h | Controller Transmit FIFO Trigger Trigger when Transmit FIFO contains <= defined bytes 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | | | 0 | MRXFIFOTRG | R/W | 0h | Controller Receive FIFO Trigger Trigger when RX FIFO contains >= defined bytes 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | | ### 16.3.22 RIS (Offset = 1090h) [Reset = 00000000h] RIS is shown in Figure 16-38 and described in Table 16-44. Return to the Summary Table. Raw interrupt status. Reflects all pending interrupts, regardless of masking. The RIS register allows the user to implement a poll scheme. A flag set in this register can be cleared by writing 1 to the ICLR register bit even if the corresponding IMASK bit is not enabled. Figure 16-38. RIS #### **Table 16-44. RIS Field Descriptions** | Bit | Field | Туре | Reset | Description | |------|------------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------| | 31-4 | RESERVED | R | 0h | | | 3 | STXFIFOTRG | R | 0h | Target Transmit FIFO Trigger 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | 2 | SRXFIFOTRG | R | 0h | Target Receive FIFO Trigger 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | 1 | MTXFIFOTRG | R | Oh | Controller Transmit FIFO Trigger Trigger when Transmit FIFO contains <= defined bytes 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | 0 | MRXFIFOTRG | R | Oh | Controller Receive FIFO Trigger Trigger when RX FIFO contains >= defined bytes 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | ## 16.3.23 MIS (Offset = 1098h) [Reset = 00000000h] MIS is shown in Figure 16-39 and described in Table 16-45. Return to the Summary Table. Masked interrupt status. This is an AND of the IMASK and RIS registers. ## Figure 16-39. MIS | | | | J | | | | | | | |------|----------|------|------|------------|------------|------------|------------|--|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | RESERVED | | | | | | | | | | | R-0h | | | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | RESERVED | | | | | | | | | | | R-0h | | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | | RESI | ERVED | | | | | | | | | | R | t-0h | | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | RESEF | RVED | | STXFIFOTRG | SRXFIFOTRG | MTXFIFOTRG | MRXFIFOTRG | | | | R-0h | | | | R-0h | R-0h | R-0h | R-0h | | | #### **Table 16-45. MIS Field Descriptions** | | Table 10 for this Field 2000 phone | | | | | | | | |------|------------------------------------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | | 31-4 | RESERVED | R | 0h | | | | | | | 3 | STXFIFOTRG | R | Oh | Target Transmit FIFO Trigger 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | | | | 2 | SRXFIFOTRG | R | Oh | Target Receive FIFO Trigger 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | | | | 1 | MTXFIFOTRG | R | 0h | Controller Transmit FIFO Trigger Trigger when Transmit FIFO contains <= defined bytes 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | | | | 0 | MRXFIFOTRG | R | 0h | Controller Receive FIFO Trigger Trigger when RX FIFO contains >= defined bytes 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | | | ### 16.3.24 ISET (Offset = 10A0h) [Reset = 00000000h] ISET is shown in Figure 16-40 and described in Table 16-46. Return to the Summary Table. Interrupt set. Allows interrupts to be set by software (useful in diagnostics and safety checks). Writing a 1 to a bit in ISET will set the event and therefore the related RIS bit also gets set. If the interrupt is enabled through the mask, then the corresponding MIS bit is also set. Figure 16-40. ISET #### Table 16-46. ISET Field Descriptions | Bit | Field | Туре | Reset | Description | |------|------------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------| | 31-4 | RESERVED | W | 0h | | | 3 | STXFIFOTRG | W | Oh | Target Transmit FIFO Trigger 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | 2 | SRXFIFOTRG | W | Oh | Target Receive FIFO Trigger 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | 1 | MTXFIFOTRG | W | 0h | Controller Transmit FIFO Trigger Trigger when Transmit FIFO contains <= defined bytes 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | 0 | MRXFIFOTRG | W | 0h | Controller Receive FIFO Trigger Trigger when RX FIFO contains >= defined bytes 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | ## 16.3.25 ICLR (Offset = 10A8h) [Reset = 00000000h] ICLR is shown in Figure 16-41 and described in Table 16-47. Return to the Summary Table. Interrupt clear. Write a 1 to clear corresponding Interrupt. ## Figure 16-41. ICLR | | | | J | | | | | | | | | |----|---------------------------------------------------|----|-------------|-------|------|------|------|--|--|--|--| | 31 | 30 | 29 | 28 27 26 25 | | | | | | | | | | | RESERVED | | | | | | | | | | | | | W-0h | | | | | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | | | | | RES | ERVED | | | | | | | | | | W-0h | | | | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | | | | RES | ERVED | | | | | | | | | | | | V | /-0h | | | | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | RESERVED STXFIFOTRG SRXFIFOTRG MTXFIFOTRG MRXFIFO | | | | | | | | | | | | | W-0 | )h | | W-0h | W-0h | W-0h | W-0h | | | | | #### **Table 16-47. ICLR Field Descriptions** | | | | • | . 1014 2000p.10110 | |------|------------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------| | Bit | Field | Туре | Reset | Description | | 31-4 | RESERVED | W | 0h | | | 3 | STXFIFOTRG | W | Oh | Target Transmit FIFO Trigger 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | 2 | SRXFIFOTRG | W | Oh | Target Receive FIFO Trigger 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | 1 | MTXFIFOTRG | W | 0h | Controller Transmit FIFO Trigger Trigger when Transmit FIFO contains <= defined bytes 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | 0 | MRXFIFOTRG | W | 0h | Controller Receive FIFO Trigger Trigger when RX FIFO contains >= defined bytes 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | ## 16.3.26 EVT\_MODE (Offset = 10E0h) [Reset = 00000029h] EVT\_MODE is shown in Figure 16-42 and described in Table 16-48. Return to the Summary Table. Event mode register. It is used to select whether each line is disabled, in software mode (software clears the RIS) or in hardware mode (hardware clears the RIS) Figure 16-42. EVT\_MODE ### Table 16-48. EVT\_MODE Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-6 | RESERVED | R/W | 0h | | | 5-4 | EVT2_CFG | R | 2h | Event line mode select for event corresponding to none.INT_EVENT2 0h = The interrupt or event line is disabled. 1h = The interrupt or event line is in software mode. Software must clear the RIS. 2h = The interrupt or event line is in hardware mode. The hardware (another module) clears automatically the associated RIS flag. | | 3-2 | INT1_CFG | R | 2h | Event line mode select for event corresponding to none.INT_EVENT1 Oh = The interrupt or event line is disabled. 1h = The interrupt or event line is in software mode. Software must clear the RIS. 2h = The interrupt or event line is in hardware mode. The hardware (another module) clears automatically the associated RIS flag. | | 1-0 | INTO_CFG | R | 1h | Event line mode select for event corresponding to none.INT_EVENT0 0h = The interrupt or event line is disabled. 1h = The interrupt or event line is in software mode. Software must clear the RIS. 2h = The interrupt or event line is in hardware mode. The hardware (another module) clears automatically the associated RIS flag. | ## 16.3.27 INTCTL (Offset = 10E4h) [Reset = 00000000h] INTCTL is shown in Figure 16-43 and described in Table 16-49. Return to the Summary Table. Interrupt control register Figure 16-43. INTCTL ### **Table 16-49. INTCTL Field Descriptions** | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-1 | RESERVED | R/W | 0h | | | 0 | INTEVAL | W | | Writing a 1 to this field re-evaluates the interrupt sources. 0h = The interrupt or event line is disabled. 1h = The interrupt or event line is in software mode. Software must clear the RIS. | ## 16.3.28 DESC (Offset = 10FCh) [Reset = 15110010h] DESC is shown in Figure 16-44 and described in Table 16-50. Return to the Summary Table. This register identifies the peripheral and its exact version. ### Figure 16-44. DESC ### **Table 16-50. DESC Field Descriptions** | Table 10-30. DEGG Field Descriptions | | | | | | | | | | | |--------------------------------------|------------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--| | Bit | Field | Type | Reset | Description | | | | | | | | 31-16 | MODULEID | R | 1511h | Module identification contains a unique peripheral identification number. The assignments are maintained in a central database for all of the platform modules to ensure uniqueness. Oh = Smallest value FFFFh = Highest possible value | | | | | | | | 15-12 | FEATUREVER | R | Oh | Feature Set for the module *instance* 0h = Smallest value Fh = Highest possible value | | | | | | | | 11-8 | INSTNUM | R | 0h | Instance Number within the device. This will be a parameter to the RTL for modules that can have multiple instances 0h = Smallest value Fh = Highest possible value | | | | | | | | 7-4 | MAJREV | R | 1h | Major rev of the IP 0h = Smallest value Fh = Highest possible value | | | | | | | | 3-0 | MINREV | R | Oh | Minor rev of the IP 0h = Smallest value Fh = Highest possible value | | | | | | | ## 16.3.29 GFCTL (Offset = 1200h) [Reset = 00000F00h] GFCTL is shown in Figure 16-45 and described in Table 16-51. Return to the Summary Table. This register controls the glitch filter on the SCL and SDA lines ### Figure 16-45. GFCTL | | | | i iguic io- | 73. OI OIL | | | | | | | | |----|----------|----------|-------------|------------|--------|------|--------|--|--|--|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | | | RESERVED | | | | | | | | | | | | | | | R/ | W- | | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | | | | | RESE | RVED | | | | | | | | | | | | R/ | W- | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | | RESE | RVED | | CHAIN | AGF | SEL | AGFEN | | | | | | | R/ | W- | | R/W-1h | R/W | /-3h | R/W-1h | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | RESERVED | | | DGFSEL | | | | | | | | | | R/W- | | | R/W-0h | | | | | | | ### Table 16-51. GFCTL Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-12 | RESERVED | R/W | 0h | | | 11 | CHAIN | R/W | 1h | Analog and digital noise filters chaining enable. Oh = When 0, chaining is disabled and only digital filter output is available to IP logic for oversampling Th = When 1, analog and digital glitch filters are chained and the output of the combination is made available to IP logic for oversampling | | 10-9 | AGFSEL | R/W | 3h | Analog Glitch Suppression Pulse Width This field controls the pulse width select for the analog glitch suppression on SCL and SDA lines. See device data sheet for exact values. (ULP I2C only) 0h = Pulses shorter then 5ns length are filtered. 1h = Pulses shorter then 10ns length are filtered. 2h = Pulses shorter then 25ns length are filtered. 3h = Pulses shorter then 50ns length are filtered. | | 8 | AGFEN | R/W | 1h | Analog Glitch Suppression Enable 0h = Analog Glitch Filter disable 1h = Analog Glitch Filter enable | | 7-3 | RESERVED | R/W | 0h | | | 2-0 | DGFSEL | R/W | Oh | Glitch Suppression Pulse Width This field controls the pulse width select for glitch suppression on the SCL and SDA lines. The following values are the glitch suppression values in terms of functional clocks. (Core Domain only) 0h = Bypass 1h = 1 clock 2h = 2 clocks 3h = 3 clocks 4h = 4 clocks 5h = 8 clocks 6h = 16 clocks 7h = 31 clocks | ## 16.3.30 TIMEOUT\_CTL (Offset = 1204h) [Reset = 00020002h] TIMEOUT\_CTL is shown in Figure 16-46 and described in Table 16-52. Return to the Summary Table. This register contains controls for Timeout Counters A and B ### Figure 16-46. TIMEOUT CTL | | | - | .94.0 .0 .0. | 000 | | | | | | | | |---------|----|----------|--------------|----------|----|----|----|--|--|--|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | | TCNTBEN | | RESERVED | | | | | | | | | | | R/W-0h | | R/W-0h | | | | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | | | | | TCN | NTLB | | | | | | | | | | | R/W-2h | | | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | TCNTAEN | | | | RESERVED | | | | | | | | | R/W-0h | | | | R/W-0h | | | | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | TCN | ITLA | | | | | | | | | | | | R/V | V-2h | | | | | | | | | 1 | | | | | | | | | | | | ## Table 16-52. TIMEOUT\_CTL Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 | TCNTBEN | R/W | 0h | Timeout Counter B Enable 0h = Disable Timeout Counter B 1h = Enable Timeout Counter B | | 30-24 | RESERVED | R/W | 0h | | | 23-16 | TCNTLB | R/W | 2h | Timeout Count B Load: Counter B is used for SCL High Detection. This field contains the upper 8 bits of a 12-bit pre-load value for the Timeout B count. NOTE: The value of CNTLB must be greater than 1h. Each count is equal to 1* clock period. For example, with 10MHz functional clock one timeout period will be equal to1*100ns. 0h = Smallest possible value FFh = Highest possible value | | 15 | TCNTAEN | R/W | 0h | Timeout Counter A Enable 0h = Disable Timeout Counter B 1h = Enable Timeout Counter B | | 14-8 | RESERVED | R/W | 0h | | | 7-0 | TCNTLA | R/W | 2h | Timeout counter A load value Counter A is used for SCL low detection. This field contains the upper 8 bits of a 12-bit pre-load value for the Timeout A count. NOTE: The value of CNTLA must be greater than 1h. Each count is equal to 520 times the timeout period of functional clock. For example, with 8MHz functional clock and a 100KHz operating I2C clock, one timeout period will be equal to (1 / 8MHz) * 520 or 65 us. 0h = Smallest Value FFh = Highest possible value | ## 16.3.31 TIMEOUT\_CNT (Offset = 1208h) [Reset = 00020002h] TIMEOUT\_CNT is shown in Figure 16-47 and described in Table 16-53. Return to the Summary Table. This register contains the upper 8 bits of a 12-bit current counter values for counter A and B. The lower four bits of the counter are not user visible and are always 0h. ### Figure 16-47. TIMEOUT\_CNT | ( | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|----|----|----|-----|-----|----|----|----|----|----|----|-----|-----|----|----|----|----|----|----|-----|-----|----|---|---|---|---|---|-----|-----|---|---|---| | | | | R | ESE | RVE | D | | | | | | TCN | NTB | | | | | | R | ESE | RVE | D | | | | | | TCI | ATA | | | | | | | | | R- | 0h | | | | | | | R- | 2h | | | | | | | R- | 0h | | | | | | | R- | 2h | | | | ## Table 16-53. TIMEOUT\_CNT Field Descriptions | Bit | Field | Туре | Reset | Description | | | | |-------|----------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | 31-24 | RESERVED | R | 0h | | | | | | 23-16 | TCNTB | R | 2h | Timeout Count B Current Count: This field contains the upper 8 bits of a 12-bit current counter for timeout counter B 0h = Smallest Value FFh = Highest possible value | | | | | 15-8 | RESERVED | R | 0h | | | | | | 7-0 | TCNTA | R | 2h | Timeout Count A Current Count: This field contains the upper 8 bits of a 12-bit current counter for timeout counter A 0h = Smallest Value FFh = Highest possible value | | | | ## 16.3.32 MSA (Offset = 1210h) [Reset = 00000000h] MSA is shown in Figure 16-48 and described in Table 16-54. Return to the Summary Table. I2C Controller Target Address Register ### Figure 16-48. MSA ### Table 16-54. MSA Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-16 | RESERVED | R/W | 0h | | | 15 | MMODE | R/W | 0h | This bit selects the adressing mode to be used in Controller mode When 0, 7-bit addressing is used. When 1, 10-bit addressing is used. 0h = 7-bit addressing mode 1h = 10-bit addressing mode | | 14-11 | RESERVED | R/W | 0h | | | 10-1 | SADDR | R/W | Oh | I2C Target Address This field specifies bits A9 through A0 of the Target address. In 7-bit addressing mode as selected by MSA.MODE bit, the top 3 bits are don't care 0h = Smallest value 3FFh = Highest possible value | | 0 | DIR | R/W | Oh | Receive/Send The DIR bit specifies if the next Controller operation is a Receive (High) or Transmit (Low). Oh = Transmit 1h = Receive Oh = The Controller is in transmit mode. 1h = The Controller is in receive mode. | ### 16.3.33 MCTR (Offset = 1214h) [Reset = 00000000h] MCTR is shown in Figure 16-49 and described in Table 16-55. Return to the Summary Table. This control register configures the I2C controller operation. The START bit generates the START or REPEATED START condition. The STOP bit determines if the cycle stops at the end of the data cycle or continues to the next transfer cycle, which could be a repeated START. To generate a single transmit cycle, the I2C Controller Target Address (MSA) register is written with the desired address, the RS bit is cleared, and this register is written with ACK = X (0 or 1), STOP = 1, START = 1, and RUN = 1 to perform the operation and stop. When the operation is completed (or aborted due an error), an byte transaction completed interrupt becomes active and the data may be read from the MRXDATA register. When the I2C module operates in Controller receiver mode, a set ACK bit causes the I2C bus controller to transmit an acknowledge automatically after each byte. This bit must be cleared when the I2C bus controller requires no further data to be transmitted from the Target transmitter. Figure 16-49, MCTR | | | | 9 | -0. III 0 1 1 C | | | | |--------|---------------------------------|--------|---------|-----------------|--------|--------|----------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | RES | ERVED | | | МВІ | _EN | | | | R/ | W-0h | | • | R/W | /-0h | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | MB | LEN | | | | | R/W-0h | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | RESE | RVED | | | | | | | | R/V | V-0h | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | RES | RESERVED RD_ON_TXEM MACKOEN PTY | | MACKOEN | ACK | STOP | START | BURSTRUN | | R | /W-0h | R/W-0h | R/W-0h | R/W-0h | R/W-0h | R/W-0h | R/W-0h | Table 16-55. MCTR Field Descriptions | | Table 10-00. WOTH Field Descriptions | | | | | | | | |-------|--------------------------------------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | | 31-28 | RESERVED | R/W | 0h | | | | | | | 27-16 | MBLEN | R/W | 0h | I2C transaction length This field contains the programmed length of bytes of the Transaction. 0h = Smallest value FFFh = Highest possible value | | | | | | 15-6 | RESERVED | R/W | 0h | | | | | | | 5 | RD_ON_TXEMPTY | R/W | Oh | Read on TX Empty 0h = No special behavior 1h = When 1 the Controller will transmit all bytes from the TX FIFO before continuing with the programmed Burst Run Read. If the DIR is not set to Read in the MSA then this bit is ignored. The Start must be set in the MCTR for proper I2C protocol. The Controller will first send the Start Condition, I2C Address with R/W bit set to write, before sending the bytes in the TX FIFO. When the TX FIFO is empty, the I2C transaction will continue as programmed in MTCR and MSA without sending a Stop Condition. This is intended to be used to perform simple I2C command based reads transition that will complete after initiating them without having to get an interrupt to turn the bus around. | | | | | ### **Table 16-55. MCTR Field Descriptions (continued)** | | | 1able 16-55 | . MC I K FIE | Descriptions (continued) | | | |-----|----------|-------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Bit | Field | Туре | Reset | Description | | | | 4 | MACKOEN | R/W | Oh | Controller ACK overrride Enable 0h = No special behavior 1h = When 1 and the Controller is receiving data and the number of bytes indicated in MBLEN have been received, the state machine will generate an rxdone interrupt and wait at the start of the ACK for FW to indicate if an ACK or NACK should be sent. The ACK or NACK is selected by writing the MCTR register and setting ACK accordingly. The other fields in this register can also be written at this time to continue on with the transaction. If a NACK is sent the state machine will automatically send a Stop. | | | | 3 | ACK | R/W | Oh | Data Acknowledge Enable. Software needs to configure this bit to send the ACK or NACK. See field decoding in Table: MCTR Field decoding. Oh = The last received data byte of a transaction is not acknowledged automatically by the Controller. The last received data byte of a transaction is acknowledged automatically by the Controller. | | | | 2 | STOP | R/W | 0h | Generate STOP 0h = The controller does not generate the STOP condition. 1h = The controller generates the STOP condition. See field decoding in Table: MCTR Field decoding. | | | | 1 | START | R/W | Oh | Generate START 0h = The controller does not generate the START condition. 1h = The controller generates the START or repeated START condition. See field decoding in Table: MCTR Field decoding. | | | | 0 | BURSTRUN | R/W | Oh | I2C Controller Enable and start transaction 0h = In standard mode, this encoding means the Controller is unable to transmit or receive data. 1h = The Controller is able to transmit or receive data. See field decoding in Table: MCTR Field decoding. | | | ## 16.3.34 MSR (Offset = 1218h) [Reset = 00000020h] MSR is shown in Figure 16-50 and described in Table 16-56. Return to the Summary Table. The status register indicates the state of the I2C bus controller. ### Figure 16-50. MSR | | | | 94.0 .0 | • • • • • • • • • • • • • • • • • • • • | | | | |----------|--------|------|---------|-----------------------------------------|--------|------|------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | RESE | RVED | | | MBC | NT | | | | F | ₹- | | | R-0 | )h | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | MBG | CNT | | | | | R-0h | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | RESE | RVED | | | | | | | | R | <b>!-</b> | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | RESERVED | BUSBSY | IDLE | ARBLST | DATACK | ADRACK | ERR | BUSY | | R- | R-0h | R-1h | R-0h | R-0h | R-0h | R-0h | R-0h | ### Table 16-56. MSR Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-28 | RESERVED | R | 0h | | | 27-16 | MBCNT | R | Oh | I2C Controller Transaction Count This field contains the current count-down value of the transaction. 0h = Smallest value FFFh = Highest possible value | | 15-7 | RESERVED | R | 0h | | | 6 | BUSBSY | R | Oh | I2C Bus is Busy Controller State Machine will wait until this bit is cleared before starting a transaction. When first enabling the Controller in multi Controller environments, FW should wait for one I2C clock period after setting ACTIVE high before writing to the MTCR register to start the transaction so that if SCL goes low it will trigger the BUSBSY. Oh = The I2C bus is idle. 1h = 'This Status bit is set on a START or when SCL goes low. It is cleared on a STOP, or when a SCL high bus busy timeout occurs and SCL and SDA are both high. This status is cleared when the ACTIVE bit is low. Note that the Controller State Machine will wait until this bit is cleared before starting an I2C transaction. When first enabling the Controller in multi Controller environments, FW should wait for one I2C clock period after setting ACTIVE high before writing to the MTCR register to start the transaction so that if SCL goes low it will trigger the BUSBSY. | | 5 | IDLE | R | 1h | I2C Idle 0h = The I2C controller is not idle. 1h = The I2C controller is idle. | | 4 | ARBLST | R | 0h | Arbitration Lost 0h = The I2C controller won arbitration. 1h = The I2C controller lost arbitration. | | 3 | DATACK | R | 0h | Acknowledge Data 0h = The transmitted data was acknowledged 1h = The transmitted data was not acknowledged. | # Table 16-56. MSR Field Descriptions (continued) | Bit | Field | Туре | Reset | Description | |-----|--------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 2 | ADRACK | R | 0h | Acknowledge Address 0h = The transmitted address was acknowledged 1h = The transmitted address was not acknowledged. | | 1 | ERR | R | 0h | Error The error can be from the Target address not being acknowledged or the transmit data not being acknowledged. 0h = No error was detected on the last operation. 1h = An error occurred on the last operation. | | 0 | BUSY | R | Oh | I2C Controller FSM Busy The BUSY bit is set during an ongoing transaction, so is set during the transmit/receive of the amount of data set in MBLEN including START, RESTART, Address and STOP signal generation when required for the current transaction. 0h = The controller is idle. 1h = The controller is busy. | ### 16.3.35 MRXDATA (Offset = 121Ch) [Reset = 00000000h] MRXDATA is shown in Figure 16-51 and described in Table 16-57. Return to the Summary Table. I2C Controller RX FIFO Read Data Byte This field contains the current byte being read in the RX FIFO stack. If the FIFO is disabled, the data byte and status are stored in the receiving holding register (the bottom word of the receive FIFO). The received data can be retrieved by reading this register. ### Figure 16-51. MRXDATA ### **Table 16-57. MRXDATA Field Descriptions** | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|--------------------------------------------------------------------------------------------------------------| | 31-8 | RESERVED | R | 0h | | | 7-0 | VALUE | R | Oh | Received Data. This field contains the last received data. 0h = Smallest value FFh = Highest possible value | ### 16.3.36 MTXDATA (Offset = 1220h) [Reset = 00000000h] MTXDATA is shown in Figure 16-52 and described in Table 16-58. Return to the Summary Table. ### I2C Controller Transmit Data Register. This register is the transmit data register (the interface to the FIFOs). For transmitted data, if the FIFO is enabled, data written to this location is pushed onto the transmit FIFO. If the FIFO is disabled, data is stored in the transmitter holding register (the bottom word of the transmit FIFO). #### Figure 16-52. MTXDATA #### Table 16-58. MTXDATA Field Descriptions | E | Bit | Field | Туре | Reset | Description | |---|-----|----------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------| | 3 | 1-8 | RESERVED | R/W | 0h | | | 7 | 7-0 | VALUE | R/W | | Transmit Data This byte contains the data to be transferred during the next transaction. 0h = Smallest value FFh = Highest possible value | ### 16.3.37 MTPR (Offset = 1224h) [Reset = 00000001h] MTPR is shown in Figure 16-53 and described in Table 16-59. Return to the Summary Table. This register is programmed to set the timer period for the SCL clock and assign the SCL clock to standard mode. #### Figure 16-53. MTPR ## Table 16-59. MTPR Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-7 | RESERVED | R/W | 0h | | | 6-0 | TPR | R/W | 1h | Timer Period This field is used in the equation to configure SCL_PERIOD: SCL_PERIOD = (1 + TPR) × (SCL_LP + SCL_HP) × INT_CLK_PRD where: SCL_PRD is the SCL line period (I2C clock). TPR is the Timer Period register value (range of 1 to 127). SCL_LP is the SCL Low period (fixed at 6). SCL_HP is the SCL High period (fixed at 4). CLK_PRD is the functional clock period in ns. 0h = Smallest value 7Fh = Highest possible value | ### 16.3.38 MCR (Offset = 1228h) [Reset = 00000000h] MCR is shown in Figure 16-54 and described in Table 16-60. Return to the Summary Table. Controller configuration register ### Figure 16-54. MCR ### Table 16-60. MCR Field Descriptions | Bit | Field | Туре | Reset | Description | |------|------------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-9 | RESERVED | R/W | 0h | | | 8 | LPBK | R/W | Oh | I2C Loopback 0h = Normal operation. 1h = The controller in a test mode loopback configuration. | | 7-3 | RESERVED | R/W | 0h | | | 2 | CLKSTRETCH | R/W | Oh | Clock Stretching. This bit controls the support for clock stretching of the I2C bus. Oh = Disables the clock stretching detection. This can be disabled if no Target on the bus does support clock stretching, so that the maximum speed on the bus can be reached. 1h = Enables the clock stretching detection. Enabling the clock stretching ensures compliance to the I2C standard but could limit the speed due the clock stretching. | | 1 | MMST | R/W | Oh | MultiController mode. In MultiController mode the SCL high time counts once the SCL line has been detected high. If this is not enabled the high time counts as soon as the SCL line has been set high by the I2C controller. Oh = Disable MultiController mode. 1h = Enable MultiController mode. | | 0 | ACTIVE | R/W | 0h | Device Active After this bit has been set, it should not be set again unless it has been cleared by writing a 0 or by a reset, otherwise transfer failures may occur. 0h = Disables the I2C Controller operation. 1h = Enables the I2C Controller operation. | ## 16.3.39 MBMON (Offset = 1234h) [Reset = 00000003h] MBMON is shown in Figure 16-55 and described in Table 16-61. Return to the Summary Table. This register is used to determine the SCL and SDA signal status. ### Figure 16-55. MBMON **Table 16-61. MBMON Field Descriptions** | Table 10-01. Mibiliote Field Descriptions | | | | | | | | |-------------------------------------------|----------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | 31-2 | RESERVED | R | 0h | | | | | | 1 | SDA | R | 1h | I2C SDA Status 0h = The I2CSDA signal is low. 1h = The I2CSDA signal is high. Note: During and right after reset, the SDA pin is in GPIO input mode without the internal pull enabled. For proper I2C operation, the user should have the external pull-up resistor in place before starting any I2C operations. | | | | | 0 | SCL | R | 1h | I2C SCL Status 0h = The I2CSCL signal is low. 1h = The I2CSCL signal is high. Note: During and right after reset, the SCL pin is in GPIO input mode without the internal pull enabled. For proper I2C operation, the user should have the external pull-up resistor in place before starting any I2C operations. | | | | ## 16.3.40 MFIFOCTL (Offset = 1238h) [Reset = 00000000h] MFIFOCTL is shown in Figure 16-56 and described in Table 16-62. Return to the Summary Table. **I2C Controller FIFO Control** ### Figure 16-56. MFIFOCTL #### Table 16-62. MFIFOCTL Field Descriptions | | Table 10-02. Will if OCTE Field Descriptions | | | | | | | | |-------|----------------------------------------------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | | 31-16 | RESERVED | R/W | 0h | | | | | | | 15 | RXFLUSH | R/W | Oh | RX FIFO Flush Setting this bit will Flush the RX FIFO. Before clearing this bit to stop Flush the RXFIFOCNT should be checked to be 0 and indicating that the Flush has completed. 0h = Do not Flush FIFO 1h = Flush FIFO | | | | | | 14-11 | RESERVED | R/W | 0h | | | | | | | 10-8 | RXTRIG | R/W | Oh | RX FIFO Trigger Indicates at what fill level in the RX FIFO a trigger will be generated. Note: Programming RXTRIG to 0x0 has no effect since no data is present to transfer out of RX FIFO. 0h = Trigger when RX FIFO contains >= 1 byte 1h = Trigger when RX FIFO contains >= 2 byte 2h = Trigger when RX FIFO contains >= 3 byte 3h = Trigger when RX FIFO contains >= 4 byte 4h = Trigger when RX FIFO contains >= 5 byte 5h = Trigger when RX FIFO contains >= 6 byte 6h = Trigger when RX FIFO contains >= 7 byte 7h = Trigger when RX FIFO contains >= 8 byte | | | | | | 7 | TXFLUSH | R/W | Oh | TX FIFO Flush Setting this bit will Flush the TX FIFO. Before clearing this bit to stop Flush the TXFIFOCNT should be checked to be 8 and indicating that the Flush has completed. 0h = Do not Flush FIFO 1h = Flush FIFO | | | | | | 6-3 | RESERVED | R/W | 0h | | | | | | *I*<sup>2</sup>*C* www.ti.com ## Table 16-62. MFIFOCTL Field Descriptions (continued) | Bit | Field | Туре | Reset | Description | | | |-----|--------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | 2-0 | TXTRIG | R/W | Oh | TX FIFO Trigger Indicates at what fill level in the TX FIFO a trigger will be generated. 0h = Trigger when the TX FIFO is empty. 1h = Trigger when TX FIFO contains ≤ 1 byte 2h = Trigger when TX FIFO contains ≤ 2 byte 3h = Trigger when TX FIFO contains ≤ 3 byte 4h = Trigger when TX FIFO contains ≤ 4 byte 5h = Trigger when TX FIFO contains ≤ 5 byte 6h = Trigger when TX FIFO contains ≤ 6 byte 7h = Trigger when TX FIFO contains ≤ 7 byte | | | ### 16.3.41 MFIFOSR (Offset = 123Ch) [Reset = 00000800h] MFIFOSR is shown in Figure 16-57 and described in Table 16-63. Return to the Summary Table. I2C Controller FIFO Status Register Note: this Register should only be read when BUSY is 0 #### Figure 16-57. MFIFOSR | Figure 10-37. WFIFOSK | | | | | | | | | |-----------------------|--------------------|----------|------|-----------|-----|----|----|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | | RESE | RVED | | | | | | | R-0h | | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | RESERVED | | | | | | | | | | R-0h | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | TXFLUSH | | RESERVED | | TXFIFOCNT | | | | | | R-0h | | R-0h | | | R-8 | 3h | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | RXFLUSH | RESERVED RXFIFOCNT | | | | | | | | | R-0h | R-0h R-0h | | | | | | | | ### **Table 16-63. MFIFOSR Field Descriptions** | Bit | Field | Туре | Reset | Description | |-------|-----------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-16 | RESERVED | R | 0h | | | 15 | TXFLUSH | R | 0h | TX FIFO Flush When this bit is set a Flush operation for the TX FIFO is active. Clear the TXFLUSH bit in the control register to stop. 0h = FIFO Flush not active 1h = FIFO Flush active | | 14-12 | RESERVED | R | 0h | | | 11-8 | TXFIFOCNT | R | 8h | Number of Bytes which could be put into the TX FIFO 0h = Smallest value 8h = Highest possible value | | 7 | RXFLUSH | R | 0h | RX FIFO Flush When this bit is set a Flush operation for the RX FIFO is active. Clear the RXFLUSH bit in the control register to stop. 0h = FIFO Flush not active 1h = FIFO Flush active | | 6-4 | RESERVED | R | 0h | | | 3-0 | RXFIFOCNT | R | 0h | Number of Bytes which could be read from the RX FIFO 0h = Smallest value 8h = Highest possible value | ## 16.3.42 CONTROLLER\_I2CPECCTL (Offset = 1240h) [Reset = 00000000h] CONTROLLER\_I2CPECCTL is shown in Figure 16-58 and described in Table 16-64. Return to the Summary Table. I2C Controller PEC Control Register ## Figure 16-58. CONTROLLER\_I2CPECCTL ### Table 16-64. CONTROLLER\_I2CPECCTL Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-13 | RESERVED | R/W | 0h | | | 12 | PECEN | R/W | Oh | PEC Enable This bit enables the SMB Packet Error Checking (PEC). When enabled the PEC is calculated on all bits accept the Start, Stop, Ack and Nack. The PEC LSFR and the Byte Counter is set to 0 when the State Machine is in the IDLE state, which occur following a Stop or when a timeout occurs. The Counter is also set to 0 after the PEC byte is sent or received. Note that the NACK is automatically send following a PEC byte that results in a PEC error. The PEC Polynomial is x^8 + x^2 + x^1 + 1. 0h = PEC is disabled in Controller mode 1h = PEC is enabled in Controller mode | | 11-9 | RESERVED | R/W | 0h | | ## Table 16-64. CONTROLLER\_I2CPECCTL Field Descriptions (continued) | Table 10-04: CONTROLLEN_IZOT LOCAL Fleid Bescriptions (Continued) | | | | | | | | | |-------------------------------------------------------------------|--------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | | 8-0 | PECCNT | R/W | Oh | PEC Count When this field is non zero, the number of I2C bytes are counted (Note that although the PEC is calculated on the I2C address it is not counted at a byte). When the byte count = PECCNT and the state machine is transmitting, the contents of the LSFR is loaded into the shift register instead of the byte received from the Tx FIFO. When the state machine is receiving, after the last bit of this byte is received the LSFR is checked and if it is non-zero, a PEC RX Error interrupt is generated. The I2C packet must be padded to include the PEC byte for both transmit and receive. In transmit mode the FIFO must be loaded with a dummy PEC byte. In receive mode the PEC byte will be passed to the Rx FIFO. In the normal Controller use case, FW would set PECEN=1 and PECCNT=SMB packet length (Not including Target Address byte, but including the PEC byte). FW would then configure DMA to allow the packet to complete unassisted and write MCTR to initiate the transaction. Note that when the byte count = PEC CNT, the byte count is reset to 0 and multiple PEC calculation can automatically occur within a single I2C transaction. Note that any write to the Controller_I2CPECCTL Register will clear the current PEC Byte Count in the Controller State Machine. 0h = Minimum Value 1FFh = Maximum Value | | | | | ## 16.3.43 CONTROLLER\_PECSR (Offset = 1244h) [Reset = 00000000h] CONTROLLER\_PECSR is shown in Figure 16-59 and described in Table 16-65. Return to the Summary Table. Controller PEC Status Register ### Figure 16-59. CONTROLLER\_PECSR Table 16-65. CONTROLLER\_PECSR Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|--------------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-18 | RESERVED | R | 0h | | | 17 | PECSTS_ERROR | R | 0h | This status bit indicates if a PEC check error occurred in the transaction that occurred before the last Stop. Latched on Stop. 0h = Indicates PEC check error did not occurr in the transaction that occurred before the last Stop 1h = Indicates if a PEC check error occurred in the transaction that occurred before the last Stop | | 16 | PECSTS_CHECK | R | 0h | This status bit indicates if the PEC was checked in the transaction that occurred before the last Stop. Latched on Stop. 0h = Indicates PEC was not checked in the transaction that occurred before the last Stop 1h = Indicates if the PEC was checked in the transaction that occurred before the last Stop | | 15-9 | RESERVED | R | 0h | | | 8-0 | PECBYTECNT | R | 0h | PEC Byte Count This is the current PEC Byte Count of the Controller State Machine. 0h = Minimum Value 1FFh = Maximum Value | ## 16.3.44 SOAR (Offset = 1250h) [Reset = 00004000h] SOAR is shown in Figure 16-60 and described in Table 16-66. Return to the Summary Table. This register consists of seven address bits that identify the I2C device on the I2C bus. ### Figure 16-60. SOAR | rigule 10-00. OOAK | | | | | | | | | | | | |--------------------|----------|----|------|------|----|-----|------|--|--|--|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | | | RESERVED | | | | | | | | | | | | R/W-0h | | | | | | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | | | RESERVED | | | | | | | | | | | | | R/W-0h | | | | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | SMODE | OAREN | | RESE | RVED | | 0 | AR | | | | | | R/W-0h | R/W-1h | | R/W | V-0h | | R/V | V-0h | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | O/ | AR | | | | | | | | | | | | R/W | V-0h | | | | | | | | | | | | | | | | | | | | | ### **Table 16-66. SOAR Field Descriptions** | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-16 | RESERVED | R/W | 0h | | | 15 | SMODE | R/W | 0h | This bit selects the adressing mode to be used in Target mode. When 0, 7-bit addressing is used. When 1, 10-bit addressing is used. 0h = Enable 7-bit addressing 1h = Enable 10-bit addressing | | 14 | OAREN | R/W | 1h | I2C Target Own Address Enable 0h = Disable OAR address 1h = Enable OAR address | | 13-10 | RESERVED | R/W | 0h | | | 9-0 | OAR | R/W | Oh | I2C Target Own Address: This field specifies bits A9 through A0 of the Target address. In 7-bit addressing mode as selected by I2CSOAR.MODE bit, the top 3 bits are don't care 0h = Smallest value 3FFh = Highest possible value | ## 16.3.45 SOAR2 (Offset = 1254h) [Reset = 00000000h] SOAR2 is shown in Figure 16-61 and described in Table 16-67. Return to the Summary Table. This register consists of seven address bits that identify the alternate address for the I2C device on the I2C bus. Figure 16-61. SOAR2 | | | | 1 19410 10 | 0 11 0 07 til t <u>2</u> | | | | | | | |----------|-----------|----|------------|--------------------------|----|----|----|--|--|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | | RESERVED | | | | | | | | | | | | R/W-0h | | | | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | RESERVED | OAR2_MASK | | | | | | | | | | | R/W-0h | R/W-0h | | | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | | | RESE | RVED | | | | | | | | | | | R/V | V-0h | | | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | OAR2EN | | | | OAR2 | | | | | | | | R/W-0h | | | | R/W-0h | | | | | | | Table 16-67. SOAR2 Field Descriptions | | 1400 10 071 007 112 1 1014 2 000 1 pt 010 | | | | | | | | |-------|-------------------------------------------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | | 31-23 | RESERVED | R/W | 0h | | | | | | | 22-16 | OAR2_MASK | R/W | Oh | I2C Target Own Address 2 Mask: This field specifies bits A6 through A0 of the Target address. The bits with value '1' in SOAR2.OAR2_MASK field will make the corresponding incoming address bits to match by default regardless of the value inside SOAR2.OAR2 i.e. corresponding SOAR2.OAR2 bit is a don't care. 0h = Minimum Value 7Fh = Maximum Value | | | | | | 15-8 | RESERVED | R/W | 0h | | | | | | | 7 | OAR2EN | R/W | Oh | I2C Target Own Address 2 Enable 0h = The alternate address is disabled. 1h = Enables the use of the alternate address in the OAR2 field. | | | | | | 6-0 | OAR2 | R/W | Oh | I2C Target Own Address 2 This field specifies the alternate OAR2 address. 0h = Smallest value 7Fh = Highest possible value | | | | | ## 16.3.46 SCTR (Offset = 1258h) [Reset = 00000404h] SCTR is shown in Figure 16-62 and described in Table 16-68. Return to the Summary Table. I2C Target Control Register ### Figure 16-62. SCTR | | 9 | | | | | | | | | | |-------------------|--------------------|-------------------------|-------------------|---------------------|-----------------|------------------|------------------|--|--|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | | RESERVED | | | | | | | | | | | | R/W-0h | | | | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | | RESERVED | | | | | | | | | | | | R/W-0h | | | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | | RESERVED | | | SWUEN | EN_DEFDEVA<br>DR | EN_ALRESPAD<br>R | | | | | | | R/W-0h | | | R/W-1h | R/W-0h | R/W-0h | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | EN_DEFHOST<br>ADR | RXFULL_ON_R<br>REQ | TXWAIT_STAL<br>E_TXFIFO | TXTRIG_TXMO<br>DE | TXEMPTY_ON<br>_TREQ | SCLKSTRETC<br>H | GENCALL | ACTIVE | | | | | R/W-0h | R/W-0h | R/W-0h | R/W-0h | R/W-0h | R/W-1h | R/W-0h | R/W-0h | | | | ### **Table 16-68. SCTR Field Descriptions** | Bit | Field | Туре | Reset | Description | |-------|---------------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-11 | RESERVED | R/W | 0h | | | 10 | SWUEN | R/W | 1h | Target Wakeup Enable 0h = When 0, the Target is not allowed to clock stretch on START detection 1h = When 1, the Target is allowed to clock stretch on START detection and wait for faster clock to be abvailable. This allows clean wake up support for I2C in low power mode use cases | | 9 | EN_DEFDEVADR | R/W | Oh | Enable Deault device address 0h = When this bit is 0, the default device address is not matched. NOTE: it may still be matched if programmed inside SOAR/SOAR2. 1h = When this bit is 1, default device address of 7'h110_0001 is always matched by the Target address match logic. | | 8 | EN_ALRESPADR | R/W | Oh | Enable Alert Response Address 0h = When this bit is 0, the alert response address is not matched. NOTE: it may still be matched if programmed inside SOAR/SOAR2 1h = When this bit is 1, alert response address of 7'h000_1100 is always matched by the Target address match logic. | | 7 | EN_DEFHOSTADR | R/W | 0h | Enable Default Host Address 0h = When this bit is 0, the default host address is not matched NOTE: it may still be matched if programmed inside SOAR/SOAR2 1h = When this bit is 1, default host address of 7'h000_1000 is always matched by the Target address match logic. | *I*<sup>2</sup>C www.ti.com ## **Table 16-68. SCTR Field Descriptions (continued)** | Bit | Field | Type | Reset | Descriptions (continued) | |-----|---------------------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 6 | RXFULL_ON_RREQ | R/W | Oh | Rx full interrupt generated on RREQ condition as indicated in SSR 0h = When 0, RIS:SRXFULL will be set when only the Target RX FIFO is full. This allows the SRXFULL interrupt to be used to indicate that the I2C bus is being clock stretched and that the FW must either read the RX FIFO or ACK/NACK the current Rx byte. 1h = When 1, RIS:SRXFULL will be set when the Target State Machine is in the RX_WAIT or RX_ACK_WAIT states which occurs when the I2C transaction is clock stretched because the RX FIFO is full or the ACKOEN has been set and the state machine is waiting for FW to ACK/NACK the current byte. | | 5 | TXWAIT_STALE_TXFIFO | R/W | Oh | Tx transfer waits when stale data in Tx FIFO. This prevents stale bytes left in the TX FIFO from automatically being sent on the next I2C packet. Note: this should be used with TXEMPTY_ON_TREQ set to prevent the Target State Machine from waiting for TX FIFO data without an interrupt notification when the FIFO data is stale. Oh = When 0, the TX FIFO empty signal to the Target State Machine indicates that the TX FIFO is empty. 1h = When 1, the TX FIFO empty signal to the Target State Machine will indicate that the TX FIFO is empty or that the TX FIFO data is stale. The TX FIFO data is determined to be stale when there is data in the TX FIFO when the Target State Machine leaves the TXMODE as defined in the SSR register. This can occur is a Stop or timeout occur when there are bytes left in the TX FIFO. | | 4 | TXTRIG_TXMODE | R/W | Oh | Tx Trigger when Target FSM is in Tx Mode 0h = No special behavior 1h = When 1, RIS:TXFIFOTRG will be set when the Target TX FIFO has reached the trigger level AND the Target State Machine is in the TXMODE as defined in the SSR register. When cleared RIS:TXFIFOTRG will be set when the Target TX FIFO is at or above the trigger level. This setting can be used to hold off the TX DMA until a transaction starts. This allows the DMA to be configured when the I2C is idle but have it wait till the transaction starts to load the Target TX FIFO, so it can load from a memory buffer that might be changing over time. | | 3 | TXEMPTY_ON_TREQ | R/W | 0h | Tx Empty Interrupt on TREQ 0h = When 0, RIS:STXEMPTY will be set when only the Target TX FIFO is empty. This allows the STXEMPTY interrupt to be used to indicate that the I2C bus is being clock stretched and that Target TX data is required. 1h = When 1, RIS:STXEMPTY will be set when the Target State Machine is in the TX_WAIT state which occurs when the TX FIFO is empty AND the I2C transaction is clock stretched waiting for the FIFO to receive data. | | 2 | SCLKSTRETCH | R/W | 1h | Target Clock Stretch Enable 0h = Target clock stretching is disabled 1h = Target clock stretching is enabled | | 1 | GENCALL | R/W | Oh | General call response enable Modify only when UCSWRST = 1. 0b = Do not respond to a general call 1b = Respond to a general call 0h = Do not respond to a general call 1h = Respond to a general call | | 0 | ACTIVE | R/W | 0h | Device Active. Setting this bit enables the Target functionality. 0h = Disables the I2C Target operation. 1h = Enables the I2C Target operation. | www.ti.com # 16.3.47 SSR (Offset = 125Ch) [Reset = 00000000h] SSR is shown in Figure 16-63 and described in Table 16-69. Return to the Summary Table. This register functions as a control register when written, and a status register when read. # Figure 16-63. SSR | | rigate to concern | | | | | | | | | |-----------|--------------------|--------|-----------|---------|--------|------|--------------|--|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | RESERVED | | | | | | | | | | | R-0h | | | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | RESERVED ADDRMATCH | | | | | | | | | | R-0h R-0h | | | | | | R-0h | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | | ADDRMATCH | | | | STALE_TXFIFO | | | | | | | R-0h | | | | R-0h | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | TXMODE | BUSBSY | QCMDRW | QCMDST | OAR2SEL | RXMODE | TREQ | RREQ | | | | R-0h | | # Table 16-69. SSR Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|--------------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-19 | RESERVED | R | 0h | | | 18-9 | ADDRMATCH | R | Oh | Indicates the address for which Target address match happened 0h = Minimum Value 3FFh = Maximum Value | | 8 | STALE_TXFIFO | R | 0h | Stale Tx FIFO 0h = Tx FIFO is not stale 1h = The TX FIFO is stale. This occurs when the TX FIFO was not emptied during the previous I2C transaction. | | 7 | TXMODE | R | Oh | Target FSM is in TX MODE 0h = The Target State Machine is not in TX_DATA, TX_WAIT, TX_ACK or ADDR_ACK state with the bus direction set to read. 1h = The Target State Machine is in TX_DATA, TX_WAIT, TX_ACK or ADDR_ACK state with the bus direction set to read. | | 6 | BUSBSY | R | Oh | I2C bus is busy 0h = The I2C Bus is not busy 1h = The I2C Bus is busy. This is cleared on a timeout. | | 5 | QCMDRW | R | Oh | Quick Command Read / Write This bit only has meaning when the QCMDST bit is set. Value Description: 0: Quick command was a write 1: Quick command was a read 0h = Quick command was a write 1h = Quick command was a read | | 4 | QCMDST | R | Oh | Quick Command Status Value Description: 0: The last transaction was a normal transaction or a transaction has not occurred. 1: The last transaction was a Quick Command transaction 0h = The last transaction was a normal transaction or a transaction has not occurred. 1h = The last transaction was a Quick Command transaction. | *I*<sup>2</sup>*C* www.ti.com # **Table 16-69. SSR Field Descriptions (continued)** | Bit | Field | Туре | Reset | Description | |-----|---------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 3 | OAR2SEL | R | Oh | OAR2 Address Matched This bit gets reevaluated after every address comparison. 0h = Either the OAR2 address is not matched or the match is in legacy mode. 1h = OAR2 address matched and ACKed by the Target. | | 2 | RXMODE | R | Oh | Target FSM is in Rx MODE 0h = The Target State Machine is not in the RX_DATA, RX_ACK, RX_WAIT, RX_ACK_WAIT or ADDR_ACK state with the bus direction set to write. 1h = The Target State Machine is in the RX_DATA, RX_ACK, RX_WAIT, RX_ACK_WAIT or ADDR_ACK state with the bus direction set to write. | | 1 | TREQ | R | 0h | Transmit Request 0h = No outstanding transmit request. 1h = The I2C controller has been addressed as a Target transmitter and is using clock stretching to delay the Controller until data has been written to the STXDATA FIFO (Target TX FIFO is empty). | | 0 | RREQ | R | Oh | Receive Request 0h = No outstanding receive data. 1h = The I2C controller has outstanding receive data from the I2C Controller and is using clock stretching to delay the Controller until the data has been read from the SRXDATA FIFO (Target RX FIFO is full). | www.ti.com # 16.3.48 SRXDATA (Offset = 1260h) [Reset = 00000000h] SRXDATA is shown in Figure 16-64 and described in Table 16-70. Return to the Summary Table. # I2C Target RX FIFO Read Data Byte This field contains the current byte being read in the RX FIFO stack. If the FIFO is disabled, the data byte and status are stored in the receiving holding register (the bottom word of the receive FIFO). The received data can be retrieved by reading this register. # Figure 16-64. SRXDATA ## Table 16-70. SRXDATA Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|-------------------------------------------------------------------------------------------------------------| | 31-8 | RESERVED | R | 0h | | | 7-0 | VALUE | R | 0h | Received Data. This field contains the last received data. 0h = Smallest value FFh = Highest possible value | $f^2C$ www.ti.com # 16.3.49 STXDATA (Offset = 1264h) [Reset = 00000000h] STXDATA is shown in Figure 16-65 and described in Table 16-71. Return to the Summary Table. I2C Target Transmit Data Register. This register is the transmit data register (the interface to the FIFOs). For transmitted data, if the FIFO is enabled, data written to this location is pushed onto the transmit FIFO. If the FIFO is disabled, data is stored in the transmitter holding register (the bottom word of the transmit FIFO). # Figure 16-65. STXDATA # **Table 16-71. STXDATA Field Descriptions** | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------| | 31-8 | RESERVED | R/W | 0h | | | 7-0 | VALUE | R/W | 0h | Transmit Data This byte contains the data to be transferred during the next transaction. 0h = Smallest value FFh = Highest possible value | www.ti.com # 16.3.50 SACKCTL (Offset = 1268h) [Reset = 00000000h] SACKCTL is shown in Figure 16-66 and described in Table 16-72. Return to the Summary Table. This register enables the I2C Target to Not Acknowledge (NACK) for invalid data or command or Acknowledge (ACK) for valid data or command. The I2C clock is pulled low after the last data bit until this register is written. Figure 16-66. SACKCTL **Table 16-72. SACKCTL Field Descriptions** | Bit | Field | Туре | Reset | Description | |------|-------------------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-5 | RESERVED | R/W | 0h | | | 4 | ACKOEN_ON_PECDONE | R/W | 0h | When set this bit will automatically turn on the Target ACKOEN field following the ACK/NACK of the received PEC byte. 0h = No special behavior 1h = When set this bit will automatically turn on the Target ACKOEN field following the ACK/NACK of the received PEC byte. | | 3 | ACKOEN_ON_PECNEXT | R/W | Oh | When set this bit will automatically turn on the Target ACKOEN field following the ACK/NACK of the byte received just prior to the PEC byte. Note that when ACKOEN is set the PEC byte will not automatically be ACKed/NACKed by the State Machine and FW must perform this function by writing Target_SACKCTL. 0h = No special behavior 1h = When set this bit will automatically turn on the Target ACKOEN field following the ACK/NACK of the byte received just prior to the PEC byte. Note that when ACKOEN is set the PEC byte will not automatically be ACKed/NACKed by the State Machine and FW must perform this function by writing Target_SACKCTL. | | 2 | ACKOEN_ON_START | R/W | 0h | When set this bit will automatically turn on the Target ACKOEN field following a Start Condition. 0h = No special behavior 1h = When set this bit will automatically turn on the Target ACKOEN field following a Start Condition. | | 1 | ACKOVAL | R/W | 0h | I2C Target ACK Override Value Note: for General Call this bit will be ignored if set to NACK and Target continues to receive data. 0h = An ACK is sent indicating valid data or command. 1h = A NACK is sent indicating invalid data or command. | *I*<sup>2</sup>*C* www.ti.com # Table 16-72. SACKCTL Field Descriptions (continued) | Bit | Field | Туре | Reset | Description | |-----|--------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | ACKOEN | R/W | | I2C Target ACK Override Enable 0h = A response in not provided. 1h = An ACK or NACK is sent according to the value written to the ACKOVAL bit. | www.ti.com # 16.3.51 SFIFOCTL (Offset = 126Ch) [Reset = 00000000h] SFIFOCTL is shown in Figure 16-67 and described in Table 16-73. Return to the Summary Table. I2C Target FIFO Control # Figure 16-67. SFIFOCTL # Table 16-73. SFIFOCTL Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-16 | RESERVED | R/W | 0h | | | 15 | RXFLUSH | R/W | Oh | RX FIFO Flush Setting this bit will Flush the RX FIFO. Before clearing this bit to stop Flush the RXFIFOCNT should be checked to be 0 and indicating that the Flush has completed. 0h = Do not Flush FIFO 1h = Flush FIFO | | 14-11 | RESERVED | R/W | 0h | | | 10-8 | RXTRIG | R/W | 0h | RX FIFO Trigger Indicates at what fill level in the RX FIFO a trigger will be generated. Note: Programming RXTRIG to 0x0 has no effect since no data is present to transfer out of RX FIFO. 4h = Trigger when RX FIFO contains >= 5 byte 5h = Trigger when RX FIFO contains >= 6 byte 6h = Trigger when RX FIFO contains >= 7 byte 7h = Trigger when RX FIFO contains >= 8 byte | | 7 | TXFLUSH | R/W | Oh | TX FIFO Flush Setting this bit will Flush the TX FIFO. Before clearing this bit to stop Flush the TXFIFOCNT should be checked to be 8 and indicating that the Flush has completed. 0h = Do not Flush FIFO 1h = Flush FIFO | | 6-3 | RESERVED | R/W | 0h | | | 2-0 | TXTRIG | R/W | Oh | TX FIFO Trigger Indicates at what fill level in the TX FIFO a trigger will be generated. 4h = Trigger when TX FIFO contains ≤ 4 byte 5h = Trigger when TX FIFO contains ≤ 5 byte 6h = Trigger when TX FIFO contains ≤ 6 byte 7h = Trigger when TX FIFO contains ≤ 7 byte | $I^2C$ www.ti.com # 16.3.52 SFIFOSR (Offset = 1270h) [Reset = 00000800h] SFIFOSR is shown in Figure 16-68 and described in Table 16-74. Return to the Summary Table. I2C Target FIFO Status Register Note: this Register should only be read when BUSY is 0 ## Figure 16-68. SFIFOSR | | | | i iguic io-o | o. or it core | | | | | |---------|----------|----------|--------------|---------------|-----|----|----|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | RESERVED | | | | | | | | | | R-0h | | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | RESERVED | | | | | | | | | | R-0h | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | TXFLUSH | | RESERVED | | TXFIFOCNT | | | | | | R-0h | | R-0h | | | R-8 | 3h | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | RXFLUSH | RESERVED | | | RXFIFOCNT | | | | | | R-0h | R-0h | | | | R-0 | Dh | | | ## Table 16-74. SFIFOSR Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|-----------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-16 | RESERVED | R | 0h | | | 15 | TXFLUSH | R | Oh | TX FIFO Flush When this bit is set a Flush operation for the TX FIFO is active. Clear the TXFLUSH bit in the control register to stop. 0h = FIFO Flush not active 1h = FIFO Flush active | | 14-12 | RESERVED | R | 0h | | | 11-8 | TXFIFOCNT | R | 8h | Number of Bytes which could be put into the TX FIFO 0h = Smallest value 8h = Highest possible value | | 7 | RXFLUSH | R | Oh | RX FIFO Flush When this bit is set a Flush operation for the RX FIFO is active. Clear the RXFLUSH bit in the control register to stop. 0h = FIFOFlush not active 1h = FIFO Flush active | | 6-4 | RESERVED | R | 0h | | | 3-0 | RXFIFOCNT | R | 0h | Number of Bytes which could be read from the RX FIFO 0h = Smallest value 8h = Highest possible value | www.ti.com # 16.3.53 TARGET\_PECCTL (Offset = 1274h) [Reset = 00000000h] TARGET\_PECCTL is shown in Figure 16-69 and described in Table 16-75. Return to the Summary Table. **I2C Target PEC Control Register** # Figure 16-69. TARGET PECCTL | | | | ga.o .o oo, | <b>_</b> | | | | | | |----|----------|----|-------------|----------------|--------|----|--------|--|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | RESERVED | | | | | | | | | | | R/W-0h | | | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | RESERVED | | | | | | | | | | | R/W-0h | | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | RESERVED | | PECEN | RESERVED PECCI | | | | | | | | R/W-0h | | R/W-0h | | R/W-0h | | R/W-0h | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | PECCNT | | | | | | | | | | | | | R/W | <b>/-</b> 0h | | | | | | | 1 | | | | | | | i i | | | # Table 16-75. TARGET\_PECCTL Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-13 | RESERVED | R/W | 0h | | | 12 | PECEN | R/W | Oh | PEC Enable This bit enables the SMB Packet Error Checking (PEC). When enabled the PEC is calculated on all bits accept the Start, Stop, Ack and Nack. The PEC LSFR and the Byte Counter is set to 0 when the State Machine is in the IDLE state, which occur following a Stop or when a timeout occurs. The Counter is also set to 0 after the PEC byte is sent or received. Note that the NACK is automatically send following a PEC byte that results in a PEC error. The PEC Polynomial is x^8 + x^2 + x^1 + 1. 0h = PEC transmission and check is disabled 1h = PEC transmission and check is enabled | | 11-9 | RESERVED | R/W | 0h | | | 8-0 | PECCNT | R/W | Oh | When this field is non zero, the number of I2C data bytes are counted. When the byte count = PECCNT and the state machine is transmitting, the contents of the LSFR is loaded into the shift register instead of the byte received from the Tx FIFO. When the state machine is receiving, after the last bit of this byte is received the LSFR is checked and if it is non-zero, a PEC RX Error interrupt is generated. The I2C packet must be padded to include the PEC byte for both transmit and receive. In transmit mode the FIFO must be loaded with a dummy PEC byte. In receive mode the PEC byte will be passed to the Rx FIFO. In the normal Target use case, FW would set PECEN=1 and PECCNT=0 and use the ACKOEN until the remaining SMB packet length is known. FW would then set the PECCNT to the remaining packet length (Including PEC bye). FW would then configure DMA to allow the packet to complete unassisted and exit NoAck mode. Note that when the byte count = PEC CNT, the byte count is reset to 0 and multiple PEC calculation can automatically occur within a single I2C transaction 0h = Minimum Value 1FFh = Maximum Value | $I^2C$ www.ti.com # 16.3.54 TARGET\_PECSR (Offset = 1278h) [Reset = 00000000h] TARGET\_PECSR is shown in Figure 16-70 and described in Table 16-76. Return to the Summary Table. Target PEC Status Register # Figure 16-70. TARGET\_PECSR Table 16-76. TARGET\_PECSR Field Descriptions | Table 10 10. IAROE1_1 E001(11cla Beschiptions | | | | | | | | | | |-----------------------------------------------|--------------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | | | 31-18 | RESERVED | R | 0h | | | | | | | | 17 | PECSTS_ERROR | R | 0h | This status bit indicates if a PEC check error occurred in the transaction that occurred before the last Stop. Latched on Stop. Oh = Indicates PEC check error did not occurr in the transaction that occurred before the last Stop 1h = Indicates PEC check error occurred in the transaction that occurred before the last Stop | | | | | | | 16 | PECSTS_CHECK | R | 0h | This status bit indicates if the PEC was checked in the transaction that occurred before the last Stop. Latched on Stop. 0h = Indicates PEC was not checked in the transaction that occurred before the last Stop 1h = Indicates PEC was checked in the transaction that occurred before the last Stop | | | | | | | 15-9 | RESERVED | R | 0h | | | | | | | | 8-0 | PECBYTECNT | R | Oh | This is the current PEC Byte Count of the Target State Machine. 0h = Minimum Value 1FFh = Maximum Value | | | | | | # Chapter 17 CRC The cyclic redundancy check (CRC) accelerator generates signatures for a given data sequence based on the CRC16-CCITT polynomial or the CRC32-ISO3309 polynomial. | 17.1 CRC Overview | 912 | |--------------------|-----| | | | | 17.2 CRC Operation | | | 17.3 CRC Registers | 915 | | <u> </u> | | #### 17.1 CRC Overview The CRC accelerator produces CRC signatures for given sequences of data. The CRC16-CCITT and CRC32-ISO3309 CRC functions are supported. Identical input data sequences result in identical CRC signatures when the CRC is initialized with a fixed seed value. Different sequences of input data, in general, result in different signatures for a given CRC function. Key features of the CRC accelerator include: - Support for CRC16-CCITT and CRC32-ISO3309 - Fast single-cycle computation of new CRC output for each data input (no wait states) - Support for input/output bit reversal - Support for little or big endian operation - · Byte, half-word, or word input to CRCIN - 512-word CRCIN\_IDX input field in which all addresses are mapped to CRCIN, supporting use of a standard C-style memcpy() routine to load data into the CRC module for data lengths up to 2KB #### 17.1.1 CRC16-CCITT For CRC16-CCITT, the CRC signature is generated based on the polynomial given in the 16-bit CCITT standard, as shown in the equation below. $$f(x) = x^{16} + x^{12} + x^{5} + 1 \tag{13}$$ The CRC16-CCITT digest size is 16 bits (half-word). ## 17.1.2 CRC32-ISO3309 For CRC32-ISO3309, the CRC signature is generated based on the polynomial given in the ISO3309 Ethernet standard, as shown in the equation below. $$f(x) = x^{32} + x^{26} + x^{23} + x^{22} + x^{16} + x^{12} + x^{11} + x^{10} + x^{8} + x^{7} + x^{5} + x^{4} + x^{2} + x + 1$$ (14) The digest size for CRC32-ISO3309 is 32 bits. ## 17.2 CRC Operation The CRC generator is initialized by configuring the desired mode of operation in the CRCCTRL register, followed by writing the seed value to the CRCSEED register. After the seed is loaded to the CRCSEED register, the CRCOUT register will reflect the SEED value loaded to CRCSEED. # Note If the endianness mode is configured to big endian before the seed value is written to CRCSEED, then the byte order of the seed value written to CRCSEED is swapped when the seed value is loaded into the CRC module. Once initialized, data can be input into the CRC generator by writing to the CRCIN register using byte (8-bit), half-word (16-bit), or word (32-bit) writes. The CPU or the DMA can be used to move input data into the CRC accelerator. #### Note Byte writes need not be word aligned; a byte write to any byte location in CRCIN will be interpreted the same way (adding the 8 written bits to the computed CRC). Half-word writes also need not be word aligned, but they must be half-word aligned. For example, a half-word can be written to BIT0-BIT15 or BIT16-BIT32 of CRCIN, but not to BIT8-BIT23. When using the CRC generator to verify a data set, all data to be included in the CRC calculation must be written to the CRCIN register in the same order as was used to calculate the original CRC signature. When using the CRC generator to create a new signature to be used in the future for verification, be sure to load the data the same way and with the same settings when performing verification. www.ti.com CRC The current CRC output can be read at any time by reading the CRCOUT register. ## 17.2.1 CRC Generator Implementation The CRC generator is implemented with a set of XOR trees. After a set of 8, 16, or 32 bits is provided to the CRC accelerator by writing to the CRCIN register, a calculation for the whole set of input bits is performed. When new data is written to CRCIN, the CRC generator updates the CRC output in a single cycle. Bus wait states are not required to load data back-to-back into the CRC generator. # 17.2.2 Configuration The CRC accelerator supports polynomial selection, bit reversal selection, and byte order (endianness) selection. This section describes these configuration aspects. The CRC accelerator must be enabled before being used through the PWREN register (see peripheral power enable). The CRC accelerator is in power domain 1 (PD1), and as such can only be active in RUN or SLEEP mode. If the CRC accelerator is configured to be enabled by application software, and the device enters STOP or STANDBY mode, SYSCTL will force the CRC into a disabled state until the device exists STOP or STANDBY mode. All CRC register contents are retained when the CRC is forced to a disabled state in STOP or STANDBY mode. The CRC module only runs from the PD1 bus clock (MCLK). ## 17.2.2.1 Polynomial Selection The desired polynomial (CRC16-CCITT or CRC32-ISO3309) is selected with the POLYSIZE bit in the CRCCTRL register. The polynomial to be used must be selected before loading the seed value and any data values. When the CRC generator is configured for a 16-bit digest (CRC16-CCITT), the following conditions apply: - The upper half-word (16 bits) of the CRCSEED register are ignored and only the lower half-word is used - The upper half-word (16 bits) of the CRCOUT register read back as zero and only the lower half-word is valid When the CRC generator is configured for CRC32-ISO3309, all 32 bits of CRCSEED and CRCOUT are valid. #### 17.2.2.2 Bit Order The various CRC standards were defined in the era of main frame computers. At that time, BIT0 was treated as the MSB. In modern computing, BIT0 is typically the LSB. The Arm Cortex-M0+ CPU treats BIT0 as the LSB, as is typical in modern CPUs and MCUs. This sometimes causes confusion, because BIT0 has been treated as the LSB in some cases and as the MSB in other cases. Therefore, the CRC accelerator provides a bit order reversal capability to support both conventions. Bit order reversal can be enabled by setting the BITREVERSE bit in the CRCCTRL register, giving the following behavior for input and output data: - **Input data**: The bit order of each input byte written to the CRCIN register is reversed before it is passed to the CRC generator to be used for CRC calculation - Output data: The bit order of the 16-bit or 32-bit CRC result is reversed when read from the CRCOUT register #### **Note** If input data must be provided bit-reversed, but the output is to be read not reversed, the BITREVERSE bit can be set before loading data to CRCIN and then cleared after all data is written to CRCIN but before the resulting signature is read from CRCOUT. Likewise, it is possible to load input data to CRCIN with BITREVERSE cleared (not reversed), and flip the output before reading it (by setting BITREVERSE before reading CRCOUT). ## 17.2.2.3 Byte Swap The bit OUTPUT\_BYTESWAP in the register CRCCTRL can be used to enable/disable CRC Output Byte swap. This bit controls whether the output is byte-swapped upon a read of the CRCOUT register. If CRCOUT is accessed as a half-word, and the OUTPUT\_BYTESWAP is set to to 1, then the two bytes in the 16-bit access are swapped and returned. Using B0, B1, B2 and B3 to identify Byte 0, Byte 1, Byte 2, Byte 3. B1 is returned as B0 and B0 is returned as B1. If CRCOUT is accessed as a word, and the OUTPUT\_BYTESWAP is set to 1, then the four bytes in the 32-bit read are swapped. B3 is returned as B0, B2 is returned as B1, B1 is returned as B2 and B0 is returned as B3. Note that if the CRC POLYSIZE is 16-bit and a 32-bit read of CRCOUT is performed with OUTPUT\_BYTESWAP enabled, then the output is: MSB LSB 0x0 0x0 B0 B1. If the CRC POLYSIZE is 16-bit and a 32-bit read of CRCOUT is performed with OUTPUT BYTESWAP disabled, then the output is: MSB LSB 0x0 0x0 B1 B0. ## 17.2.2.4 Byte Order When working with half-word or word input data, the input byte order can be configured as either little endian or big endian. The default configuration is little endian. To reverse the byte order when using half-word or word inputs, set the INPUT\_ENDIANNESS bit in the CRCCTRL register. Reversing the endianness will cause the following translation for half-word and word writes: # Table 17-1. CRCIN Byte Order Translation | Endianness | Data Written to CRCIN | Data Applied to CRC Logic | | |------------|-----------------------|---------------------------|--| | 0 (little) | 0xAABB | 0xAABB | | | 1 (big) | 0xAABB | 0xBBAA | | | 0 (little) | 0xAABBCCDD | 0xAABBCCDD | | | 1 (big) | 0xAABBCCDD | 0xDDCCBBAA | | #### Note If the ENDIANNESS bit is set before the seed value is written to CRCSEED, then the byte order of the seed value written to CRCSEED is also reversed when it is loaded into the CRC, and the seed value will read back reversed when reading the CRCOUT register after writing to the CRCSEED register. #### 17.2.2.5 CRC C Library Compatibility To simplify loading of data by software into the CRC, the CRC accelerator provides a 512-word (2KB) CRCIN\_IDX region. Within the CRCIN\_IDX region, a write to any word is re-mapped as, and functionally equivalent to, a write to the CRCIN register. This mechanism enables the use of the standard C library *memcpy()* routine to copy data from SRAM or flash into the CRC, provided that the source data is less than 2KB (2,048 bytes). www.ti.com CRC # 17.3 CRC Registers Table 17-2 lists the memory-mapped registers for the CRC registers. All register offset addresses not listed in Table 17-2 should be considered as reserved locations and the register contents should not be modified. Table 17-2. CRC Registers | | and the state of t | | | | | | | | | | | |--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------|-------|---------|--|--|--|--|--|--|--| | Offset | Acronym | Register Name | Group | Section | | | | | | | | | 800h | PWREN | Power enable | | Go | | | | | | | | | 804h | RSTCTL | Reset Control | | Go | | | | | | | | | 814h | STAT | Status Register | | Go | | | | | | | | | 1004h | CLKSEL | Clock Select | | Go | | | | | | | | | 10FCh | DESC | Module Description | | Go | | | | | | | | | 1100h | CRCCTRL | CRC Control Register | | Go | | | | | | | | | 1104h | CRCSEED | CRC Seed Register | | Go | | | | | | | | | 1108h | CRCIN | CRC Input Data Register | | Go | | | | | | | | | 110Ch | CRCOUT | CRC Output Result Register | | Go | | | | | | | | | 1800h +<br>formula | CRCIN_IDX[y] | CRC Input Data Array Register | | Go | | | | | | | | Complex bit access types are encoded to fit into small table cells. Table 17-3 shows the codes that are used for access types in this section. Table 17-3. CRC Access Type Codes | | Table 17-0. ONO Access Type Codes | | | | | | |----------------------|-----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | Access Type | Code | Description | | | | | | Read Type | | · | | | | | | Н | Н | Set or cleared by hardware | | | | | | R | R | Read | | | | | | Write Type | <u>'</u> | | | | | | | W | W | Write | | | | | | WK | W<br>K | Write Write protected by a key | | | | | | Reset or Default Val | ue | | | | | | | -n | | Value after reset or the default value | | | | | | Register Array Varia | bles | | | | | | | i,j,k,l,m,n | | When these variables are used in a register name, an offset, or an address, they refer to the value of a register array where the register is part of a group of repeating registers. The register groups form a hierarchical structure and the array is represented with a formula. | | | | | | У | | When this variable is used in a register name, an offset, or an address it refers to the value of a register array. | | | | | # 17.3.1 PWREN (Offset = 800h) [Reset = 00000000h] PWREN is shown in Figure 17-1 and described in Table 17-4. Return to the Summary Table. Register to control the power state # Figure 17-1. PWREN # **Table 17-4. PWREN Field Descriptions** | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|-------------------------------------------------------------------------------------------------------| | 31-24 | KEY | W | 0h | KEY to allow Power State Change<br>26h = KEY to allow write access to this register | | 23-1 | RESERVED | R/W | 0h | | | 0 | ENABLE | R/WK | | Enable the power KEY must be set to 26h to write to this bit. 0h = Disable Power 1h = Enable Power | www.ti.com CRC # 17.3.2 RSTCTL (Offset = 804h) [Reset = 00000000h] RSTCTL is shown in Figure 17-2 and described in Table 17-5. Return to the Summary Table. Register to control reset assertion and de-assertion # Figure 17-2. RSTCTL # **Table 17-5. RSTCTL Field Descriptions** | Bit | Field | Туре | Reset | Description | |-------|--------------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------| | 31-24 | KEY | W | 0h | Unlock key B1h = KEY to allow write access to this register | | 23-2 | RESERVED | R | 0h | Reserved | | 1 | RESETSTKYCLR | WK | Oh | Clear the RESETSTKY bit in the STAT register KEY must be set to B1h to write to this bit. 0h = Writing 0 has no effect 1h = Clear reset sticky bit | | 0 | RESETASSERT | WK | Oh | Assert reset to the peripheral KEY must be set to B1h to write to this bit. 0h = Writing 0 has no effect 1h = Assert reset | # 17.3.3 STAT (Offset = 814h) [Reset = 00000000h] STAT is shown in Figure 17-3 and described in Table 17-6. Return to the Summary Table. peripheral enable and reset status # Figure 17-3. STAT | | rigaro ir di dire | | | | | | | | | | | |------|-------------------|----|------|------|----|----|----|--|--|--|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | | | RESERVED | | | | | | | | | | | | R-0h | | | | | | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | | | RESERVED | | | | | | | | | | | | R-0h | | | | | | | | | | | | | 15 | 14 13 12 11 10 9 | | | | | | 8 | | | | | | | | | RESE | RVED | | | | | | | | | | R-0h | | | | | | | | | | | | 7 | 7 6 5 4 3 2 1 | | | | | | | | | | | | | RESERVED | | | | | | | | | | | | | | | R- | 0h | | | | | | | | | 1 | | | | | | | | | | | | # **Table 17-6. STAT Field Descriptions** | Bit | Field | Туре | Reset | Description | | | | | | |-------|-----------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | 31-17 | RESERVED | R | 0h | Reserved | | | | | | | 16 | RESETSTKY | R | 0h | This bit indicates, if the peripheral was reset, since this bit was cleared by RESETSTKYCLR in the RSTCTL register 0h = The peripheral has not been reset since this bit was last cleared by RESETSTKYCLR in the RSTCTL register 1h = The peripheral was reset since the last bit clear | | | | | | | 15-0 | RESERVED | R | 0h | Reserved | | | | | | www.ti.com CRC # 17.3.4 CLKSEL (Offset = 1004h) [Reset = 00000001h] CLKSEL is shown in Figure 17-4 and described in Table 17-7. Return to the Summary Table. Clock source selection # Figure 17-4. CLKSEL # Table 17-7. CLKSEL Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|---------------------------------------------------------------------------------------------------------------------| | 31-1 | RESERVED | R | 0h | | | 0 | MCLK_SEL | R | | Selects main clock (MCLK) if enabled 0h = Does not select this clock as a source 1h = Select this clock as a source | # 17.3.5 DESC (Offset = 10FCh) [Reset = 20117010h] DESC is shown in Figure 17-5 and described in Table 17-8. Return to the Summary Table. This register identifies the peripheral and its exact version. # Figure 17-5. DESC # Table 17-8. DESC Field Descriptions | | | | – – - | 1.1014 2.000.16110110 | | | |-------|------------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Bit | Field | Туре | Reset | Description | | | | 31-16 | MODULEID | R | 2011h | Module identification contains a unique peripheral identification number. The assignments are maintained in a central database for all of the platform modules to ensure uniqueness. 0h = Smallest value FFFFh = Highest possible value | | | | 15-12 | FEATUREVER | R | 7h | Feature Set for the module *instance* 0h = Smallest value Fh = Highest possible value | | | | 11-8 | INSTNUM | R | 0h | Instance Number within the device. This will be a parameter to the RTL for modules that can have multiple instances 0h = Smallest value Fh = Highest possible value | | | | 7-4 | MAJREV | R | 1h | Major rev of the IP 0h = Smallest value Fh = Highest possible value | | | | 3-0 | MINREV | R | 0h | Minor rev of the IP 0h = Smallest value Fh = Highest possible value | | | www.ti.com CRC # 17.3.6 CRCCTRL (Offset = 1100h) [Reset = X] CRCCTRL is shown in Figure 17-6 and described in Table 17-9. Return to the Summary Table. CRC Control Register. Configuration control of the CRC. # Figure 17-6. CRCCTRL | rigato ir di ditaditte | | | | | | | | | | | | |------------------------|----------|----|---------------------|----------|----------------------|------------|----------|--|--|--|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | | | RESERVED | | | | | | | | | | | | R-0h | | | | | | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | | | RESERVED | | | | | | | | | | | | | R-0h | | | | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | | | | RESE | RVED | | | | | | | | | | | | R- | 0h | | | | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | RESERVED | | OUTPUT_BYT<br>ESWAP | RESERVED | INPUT_ENDIA<br>NNESS | BITREVERSE | POLYSIZE | | | | | | | R-0h | | R/W-0h | R-0h | R/W-0h | R/W-0h | R/W-0h | | | | | # Table 17-9. CRCCTRL Field Descriptions | Bit | Field | Туре | Reset | Description | | | |------|------------------|--------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | 31-5 | RESERVED | R | 0h | Reserved | | | | 4 | OUTPUT_BYTESWAP | R/W | Oh | CRC Output Byteswap Enable. This bit controls whether the output is byte-swapped upon a read of the CRCOUT register. If CRCOUT is accessed as a half-word, and the OUTPUT_BYTESWAP is set to to 1, then the two bytes in the 16-bit access are swapped and returned. B1 is returned as B0 B0 is returned as B1 If CRCOUT is accessed as a word, and the OUTPUT_BYTESWAP is set to 1, then the four bytes in the 32-bit read are swapped. B3 is returned as B0 B2 is returned as B1 B1 is returned as B2 B0 is returned as B3 Note that if the CRC POLYSIZE is 16-bit and a 32-bit read of CRCOUT is performed with OUTPUT_BYTESWAP enabled, then the output is: MSB LSB 0x0 0x0 B0 B1 If the CRC POLYSIZE is 16-bit and a 32-bit read of CRCOUT is performed with OUTPUT_BYTESWAP disabled, then the output is: MSB LSB 0x0 0x0 B1 B0 0h = Output byteswapping is disabled 1h = Output byteswapping is enabled. | | | | 3 | RESERVED | R | 0h | Reserved | | | | 2 | INPUT_ENDIANNESS | R/W 0h | | CRC Endian. This bit indicates the byte order within a word or ha word of input data. Oh = LSB is lowest memory address and first to be processed. 1h = LSB is highest memory address and last to be processed. | | | # Table 17-9. CRCCTRL Field Descriptions (continued) | Bit | Field | Type Reset | | Description | |-----|------------|------------|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1 | BITREVERSE | R/W | Oh | CRC Bit Input and output Reverse. This bit indicates that the bit order of each input byte used for the CRC calculation is reversed before it is passed to the generator, and that the bit order of the calculated CRC is be reversed when read from CRC_RESULT. 0h = Bit order is not reversed. 1h = Bit order is reversed. | | 0 | POLYSIZE | R/W | Oh | This bit indicates which CRC calculation is performed by the generator. 0h = CRC-32 ISO-3309 calculation is performed 1h = CRC-16 CCITT is performed | www.ti.com CRC # 17.3.7 CRCSEED (Offset = 1104h) [Reset = 00000000h] CRCSEED is shown in Figure 17-7 and described in Table 17-10. Return to the Summary Table. CRC Seed Register. The Data written to this register is used to initialize the CRC result with this SEED value. Note that in 16-bit mode only the lower 16-bits of this value are used. After writing this register the CRC Output Result Register will reflect this value. ## Figure 17-7. CRCSEED ## Table 17-10. CRCSEED Field Descriptions | Bit | Field | Туре | Reset | Description | |------|-------|------|-------|-------------------------------------------------------------| | 31-0 | SEED | W | | Seed Data 0000000h = Minimum value FFFFFFFh = Maximum value | # 17.3.8 CRCIN (Offset = 1108h) [Reset = 00000000h] CRCIN is shown in Figure 17-8 and described in Table 17-11. Return to the Summary Table. CRC Input Data Register. The Data written to this register is used along with the current CRC result to calculate the next CRC result. This is done in a single clock cycle and requires no wait states. This register can by written as a byte, half word or word transfer and the correct number of bits will be used for the next CRC result. This register is also mapped to a range of registers starting at 0xTDB\_X000 and ending at 0xTDB\_XFFF to allow memcpy to be used instead of DMA for CRC calculations that do not exceed the bounds of the memory range of this register. # Figure 17-8. CRCIN # **Table 17-11. CRCIN Field Descriptions** | Bit | Field | Туре | Reset | Description | |------|-------|------|-------|--------------------------------------------------------------| | 31-0 | DATA | W | | Input Data 0000000h = Minimum value FFFFFFFh = Maximum value | www.ti.com CRC # 17.3.9 CRCOUT (Offset = 110Ch) [Reset = 00000000h] CRCOUT is shown in Figure 17-9 and described in Table 17-12. Return to the Summary Table. CRC Output Result Register. This register stores the result of the current CRC calculation. Note when configured for 16-bit mode the upper bits will read back 0. Note that if output inversion is set in the CRC Control register it will be applied. ## Figure 17-9. CRCOUT # Table 17-12. CRCOUT Field Descriptions | Bit | Field | Туре | Reset | Description | |------|--------|------|-------|----------------------------------------------------------| | 31-0 | RESULT | R | | Result 0000000h = Minimum value FFFFFFFh = Maximum value | # 17.3.10 CRCIN\_IDX[y] (Offset = 1800h + formula) [Reset = 00000000h] CRCIN\_IDX[y] is shown in Figure 17-10 and described in Table 17-13. Return to the Summary Table. This register is dual mapped to CRCIN and is intended to allow operation with C memcpy routine. Offset = 1800h + (y \* 4h); where y = 0h to 1FFh ## Figure 17-10. CRCIN\_IDX[y] # Table 17-13. CRCIN\_IDX[y] Field Descriptions | Bit | Field | Type Reset | | Description | |------|-------|------------|--|---------------------------------------------------------------| | 31-0 | DATA | HW | | Input Data 00000000h = Minimum value FFFFFFFh = Maximum value | # Chapter 18 Timers (TIMx) The timer module (TIMx) is a timer counting module with multiple compare/capture blocks. Based on the device, two types of timers are available: general-purpose timers (TIMG) and advanced control timers (TIMA). Both timers include many common features that can be used for a variety of functions such as measuring the input signal edge and period (capture mode) or generating output waveforms (compare mode output) like PWMs. See the device-specific data sheet to determine which timers and timer instances are available. | 49.4 TIMy Overview | 020 | |------------------------------|-----| | 18.1 TIMx Overview | | | 18.2 TIMx Operation | 931 | | 18.3 Timers (TIMx) Registers | | Timers (TIMx) www.ti.com #### 18.1 TIMx Overview The timer module (TIMx) is a timer counting module with multiple compare/capture blocks. Based on the device, two types of timers are available: general-purpose timers (TIMG) and advanced control timers (TIMA). Both timers use a common timer architecture, which allows for easy migration between timer instances with common functionalities. This minimizes the need to write extra software for timer-based applications and allows for easy porting and maintainence between TIMx instances. #### Note See Section 18.1.3 to determine which common features available between TIMG and TIMA instances. #### In this section: - "TIMx" should be understood as a common feature available on TIMG and TIMA - "TIMA" should be understood as a feature available only on TIMA - "TIMG" should be understood as a feature available only on TIMG ## 18.1.1 TIMG Overview The TIMG module consists of 16-bit and 32-bit auto reload counters driven by a programmable prescaler with two capture/compare (CC) blocks for multiple capture/compares, PWM outputs, and interval timing. TIMG also has extensive event generation capabilities, including counter overflow, reload, and capture/compare actions for a variety of use cases. #### 18.1.1.1 TIMG Features Specific features for TIMG include: - 16-bit or 32-bit up, down, or up-down counter, with repeat-reload mode - 8-bit programmable prescaler to divide the counter clock frequency - · Up to two independent channels for - Output compare - Input capture - PWM output (Edge-Aligned and Center-Aligned) - One-shot mode - · Shadow register mode for load register - · Shadow compare mode for CC register - Support quadrature encoder interface (QEI) and 3-input Hall sensor mode for positioning and movement sensing - Support synchronization and cross trigger among different TIMx instances in the same power domain - Support interrupt/DMA trigger generation and cross peripherals (such as ADC, DAC, etc.) trigger capability #### 18.1.1.2 Functional Block Diagram Figure 18-1 shows the TIMG block diagram. www.ti.com Timers (TIMx) Figure 18-1. TIMG Functional Block Diagram ## 18.1.2 TIMA Overview The TIMA module consists of a 16-bit auto reload counter driven by a programmable prescaler with up to four capture/compare (CC) blocks for multiple capture/compares, PWM outputs with deadband insertion, and interval timing. TIMA has extensive event generation capabilities from different counter events such as overflow, reload, and from each of the capture/compare registers. It also has the hardware design to handle the fault signal generated by internal or external circuitry to indicate a fault in the system. ## 18.1.2.1 TIMA Features Specific features for each TIMA instance include: - 16-bit up, down, or up-down counter, with repeat-reload mode - Selectable and configurable clock source - 8-bit programmable prescaler to divide the counter clock frequency - Repeat counter to generate an interrupt or event only after a given number of cycles of the counter - · Up to four independent channels for: - Output compare - Input capture - PWM output (Edge-Aligned and Center-Aligned) - One-shot mode - · Shadow register for load and CC register - · Complementary PWM output with programmable deadband insertion - Asymmetric PWM output - Fault handling mechanisms to ensure the output signals are in a safe user-defined state when a fault condition is encountered Timers (TIMx) www.ti.com - · Support for synchronization and cross-trigger among different TIMx instances in the same power domain - Support for interrupt trigger generation and trigger capability across peripherals (such as ADC or DAC) - Two additional capture/compare channels for internal events ## 18.1.2.2 Functional Block Diagram Figure 18-2 shows the TIMA block diagram. Figure 18-2. TIMA Block Diagram ## 18.1.3 TIMx Instance Configuration Table 18-1 shows the TIMx instance configuration for TIMA and TIMG instances. www.ti.com Timers (TIMx) ## **Table 18-1. TIMx Instance Configuration** | Instance | Power<br>Domain | Counter<br>Resolutio<br>n | Prescaler | Repeat<br>Counter | CCP<br>Channels<br>(External/<br>Internal) | External<br>PWM<br>Channels | Phase<br>Load | Shadow<br>Load | Shadow<br>CCs | Deadband | Fault<br>Handler | QEI / Hall<br>Input<br>Mode | |----------|-----------------|---------------------------|-----------|-------------------|--------------------------------------------|-----------------------------|---------------|----------------|---------------|----------|------------------|-----------------------------| | TIMG0 | PD0 | 16-bit | 8-bit | - | 2 | 2 | - | - | - | - | - | - | | TIMG1 | PD0 | 16-bit | 8-bit | - | 2 | 2 | - | - | - | - | - | - | | TIMG2 | PD0 | 16-bit | 8-bit | - | 2 | 2 | - | - | - | - | - | - | | TIMG3 | PD0 | 16-bit | 8-bit | - | 2 | 2 | - | - | - | - | - | - | | TIMG4 | PD0 | 16-bit | 8-bit | - | 2 | 2 | - | Yes | Yes | - | - | - | | TIMG5 | PD0 | 16-bit | 8-bit | - | 2 | 2 | - | Yes | Yes | - | - | - | | TIMG6 | PD1 | 16-bit | 8-bit | - | 2 | 2 | - | Yes | Yes | - | - | - | | TIMG7 | PD1 | 16-bit | 8-bit | - | 2 | 2 | - | Yes | Yes | - | - | - | | TIMG8 | PD0 | 16-bit | 8-bit | - | 2 | 2 | - | - | - | - | - | Yes | | TIMG9 | PD0 | 16-bit | 8-bit | - | 2 | 2 | - | - | - | - | - | Yes | | TIMG10 | PD1 | 16-bit | 8-bit | - | 2 | 2 | - | - | - | - | - | Yes | | TIMG11 | PD1 | 16-bit | 8-bit | - | 2 | 2 | - | - | - | - | - | Yes | | TIMG12 | PD1 | 32-bit | - | - | 2 | 2 | - | - | Yes | - | - | - | | TIMG13 | PD0 | 32-bit | - | - | 2 | 2 | - | - | Yes | - | - | - | | TIMG14 | PD1 | 16-bit | 8-bit | - | 4 | 4 | - | - | - | - | - | - | | TIMA0 | PD1 | 16-bit | 8-bit | Yes | 4/2 | 8 | Yes | Yes | Yes | Yes | Yes | - | | TIMA1 | PD1 | 16-bit | 8-bit | Yes | 2/2 | 4 | Yes | Yes | Yes | Yes | Yes | - | #### Note On TIMA instances, external PWM channels are pairs of complementary PWM output signals with deadband generation with respect to the CC block instance, such as TIMA0\_C0 and TIMA0\_C0N. For independent PWM output generation, separate non-inverting channels must be used, such as TIMA0\_C0 and TIMA0\_C1. ## Note Internal CC channels 4 and 5 (CC\_45) can be used for internal compare events and are available in TIMA only. ## Note Look at the device-specific data sheet to check which TIMx instances are available on the device. # 18.2 TIMx Operation The TIMx module is configured with user software. The setup and operation of TIMx is discussed in the following sections. ## Note There are register arrays in the timer module to group registers with same bit fields for different capture/compare ports. For example, TIMx.CC\_01[0/1] is a register array that contains the capture/compare registers for both CCP0 and CCP1. Access TIMx.CC\_01[0] to read the CC0 capture/compare value, and access TIMx.CC\_01[1] to read the CC1 capture/compare value. #### Note TIMx supports event subscribers and event publishers through event register arrays. For more information, please see the Events chapter. Timers (TIMx) www.ti.com #### 18.2.1 Timer Counter All TIMx instances have 16-bit counter blocks except for TIMG12 and TIMG13, which have 32-bit counter blocks. The timer counter register (TIMx.CTR) can count down, up-and-down, or up depending on the operation mode. It can also be read or written with software. Each count occurs with each rising edge of the TIMCLK signal or with both edges of external signals. ## **Enabling the TIMx Counter** The counter is clocked by the prescaler output TIMCLK. The counter enable bit TIMx.CTRCTL.EN can be enabled in three ways: - · Set in software manually - This bit can be set by software to enable the counter, and the counter value after enable (CVAE) is set according to the TIMx.CTRCTL.CVAE setting. - After a load condition (LCOND) or zero condition (ZCOND) is met, and the counter value after enable (CVAE) is changed to the load value or zero value, respectively. #### Note The ability to write the counter register while TIMx is running is possible but should be avoided because the user write can collide with a load, zero, or advance event. Depending on the prescaler ratio, the application cannot guarantee the timing of the write which will affect the correct timer period. #### 18.2.1.1 Clock Source Select and Prescaler The TIMx clock (TIMCLK) can be sourced from an internal clock or an external signal trigger to advance the clock. #### 18.2.1.1.1 Internal Clock and Prescaler The TIMx clock (TIMCLK) can be sourced from BUSCLK, MFCLK and LFCLK by setting the TIMx.CLKSEL register. It can also be divided by a ratio by setting the TIMx.CLKDIV register and a prescaler (if present). The selected source clock is always available and the frequency depends on the power mode. For more information, see the Clock Module (CKM) section. The TIMCLK can come from the following sources: - BUSCLK: the current bus clock is selected as the source for TIMx. The current bus clock depends on power domain. - If the TIMx instance is in Power Domain 1 (PD1), refer to MCLK. - If the TIMx instance is in Power Domain 0 (PD0), refer to ULPCLK. - MFCLK: MFCLK is selected as the source for TIMx, refer to MFCLK. - LFCLK: LFCLK is selected as the source for TIMx, refer to LFCLK. The selected clock source can be passed directly to TIMx or divided by the 8-bit prescaler. The prescaler setting can be configured with register TIMx.CPS.PCNT bit. The selected TIMCLK source is divided by a value of (PCNT+1). A PCNT value of 0 divides TIMCLK by 1, effectively bypassing the divider. A PCNT value of greater than 0 divides the TIMCLK source to generate a slower clock. TIMx also has a software mechanism for disabling the timer clock. Set TIMx.CCLKCTL.CLKEN to 0 to put the timer in an IDLE state. ## **TIMCLK Configuration** To configure the clock source, divider, and prescaler: - 1. Select the TIMCLK clock source (BUSCLK, MFCLK, or LFCLK) using the CLKSEL register. - 2. Optionally divide the TIMCLK using CLKDIV.RATIO. - 3. In TIMx instances with prescalers, optionally set a prescaler using CPS.PCNT. - 4. Enable the TIMCLK by setting CCLKCTL.CLKEN = 1. www.ti.com Timers (TIMx) The frequency of TIMCLK is determined using Equation 15. $$f_{TIMCLK} = \frac{f_{CLK\_SOURCE}}{((CLKDIV.RATIO + 1)*(CPS.PCNT + 1))}$$ (15) #### 18.2.1.1.2 External Signal Trigger The counter can also advance (increment or decrement) by using an external signal on the timer input pin or by triggering from an event from other peripherals in the system. This can be configured by using the advance condition setting (TIMx.CCCTL\_xy[0/1].ACOND) to specify what creates the advance event. To specify what event advances the counter, use the TIMx.CTRCTL.CAC setting. The counter can advance using the internal clock TIMCLK, a different edge of an timer external input, or an internal trigger event from other peripherals. # 18.2.1.2 Repeat Counter (TIMA only) In TIMA only, the repeat counter (RC) is an 8-bit counter that provides the mechanism to suppress unnecessary events and generate real events for optimal interrupt generation. Specifically, the repeat counter can suppress Load, Compare, and Zero events in the case where the timer is generating events that repeat for a known number of cycles, such a periodic PWM output waveform. This prevents generating excessive and unnecessary interrupts every timer period. When the timer counter (TIMA.CTR) is advancing, the repeat counter (TIMA.RC) advances once the counter reloads (TIMA.CTR = 0). The user can set the how many timer counter reloads occur until generating the interrupts and events by setting the TIMA.RCLD register. Once TIMA.RC = TIMA.RCLD, the repeat counter is reset back to zero and a Repeat Counter Zero event occurs (REPC) in the Interrupt and Event Status registers. #### Note If the counter is is configured to stop counting in a debug or fault condition, the repeat counter should also be stopped. See Section 18.2.6 and Section 18.2.10 for more details. Additionally, the repeat counter provides the ability to suppress generation of Zero, Load, and Compare events when TIMA.RC does not equal zero. - Zero and Load events are suppressed by setting TIMA.CTRCTL.SLZERCNEZ register bit - Compare events (see Table 18-8) are suppressed by setting the TIMA.CCCTL\_xy[0/1].SCERCNEZ bit Table 18-2 shows the repeat counter behavior with respect to the timer counter and repeat counter load value. **Table 18-2. Repeat Counter Behavior** | TIMA.CTR is advancing (+1) | Counter value | TIMA.RC =<br>TIMA.RCLD | Repeat Counter<br>Behavior | Suppress Load<br>and Zero Events<br>(SLZERCNEZ = 1) | Suppress Compare<br>Events (SCERCNEZ<br>= 1) | |----------------------------|---------------|------------------------|----------------------------|-----------------------------------------------------|----------------------------------------------| | No | - | - | Does not advance | Yes | Yes | | Yes | TIMA.CTR ≠ 0 | - | Does not advance | Yes | Yes | | Yes | TIMA.CTR = 0 | No | Advance (+1) | Yes | Yes | | Yes | TIMA.CTR = 0 | Yes | TIMA.RC = 0 | No | No | ## Repeat counter example As shown in Figure 18-3, the TIMA.CTR is configured for down-counting mode and zero events are generated once TIMA.CTR = 0. To suppress interrupt generation until 4 timer reloads occur, set TIMA.RCLD = 4 and TIMA.CTRCTL.SLZERCNEZ = 1 to suppress zero and load events until RC = 0 (which occurs once TIMA.RCLD). Timers (TIMx) www.ti.com #### Note The use of the repeat counter does not affect the output signal generation. All events are generated regardless of the repeat counter value sent to the signal generator unit. Figure 18-3. Event Suppressed by Repeat Counter with TIMx.RCLD = 4 in Down Counting Mode ## 18.2.2 Counting Mode Control When the device is out of reset, TIMx is disabled. Writing 1 to the TIMx.CTRCTL.EN bit enables the counter. This bit is automatically cleared if TIMx.CTRCTL.REPEAT=0 (do not automatically reload), and the counter value equals zero. TIMx has three counting modes when enabled: down, up/down, and up. The operating mode is selected by TIMx.CTRCTL.CM bit (shown in Table 18-3). After the counter is enabled, the timer will start counting from the count value after enable (TIMx.CTRCTL.CVAE) setting. Table 18-3. TIMx Counting Modes | Table 10-5. This Counting modes | | | | | | | | | | |---------------------------------|-----------|------------------------------------|-----------------------------------------------------------------------------|--|--|--|--|--|--| | CM Bit | Mode | Count Value After<br>Enable (CVAE) | Description | | | | | | | | 0 | Down | CVAE = 0 (Load<br>Value) | TIMx counts from TIMx.LOAD value down to zero | | | | | | | | 4 | 4 Ha/Dana | | TIMx counts from TIMx.LOAD value down to zero and then back up to TIMx.LOAD | | | | | | | | 1 | Up/Down | CVAE = 2<br>(Zero Value) | TIMx counts from zero up to TIMx.LOAD and then back down to zero | | | | | | | | 2 | Up | CVAE = 2 (Zero<br>Value) | TIMx counts from zero up to TIMx.LOAD value | | | | | | | # Note TIMx.CTRCTL.CVAE = 1 has no effect on the count value after enable. www.ti.com Timers (TIMx) ## 18.2.2.1 One-shot and Periodic Modes Figure 18-4 shows TIMx working in both one-shot mode and periodic mode. ## **One-shot Mode** When TIMx.CTRCTL.REPEAT bit is set to 0, TIMx does not advance when: - TIMx.CTR value reaches 0 in either down- or up/down-counting mode - TIMx.CTR value reaches TIMx.LOAD in up-counting mode ## **Periodic Mode (Counter Reload)** When TIMx.CTRCTL.REPEAT is set to 1h, TIMx automatically repeats once a zero event occurs. This happens when: - TIMx.CTR reaches 0 in either down- or up/down-counting mode - In down-counting mode, a zero event is followed by a load event at the next advance condition - In up/down-counting mode, a zero event is followed by an advance event (+1) - TIMx.CTR reaches TIMx.LOAD in up-counting mode - A load event is followed by a zero at the next advance condition TIMx.CTRCTL.REPEAT can also be set to 3h for TIMx to repeat only when not in a debug condition. If there is a debug condition, TIMx will count to the zero event and repeat only once the debug condition is removed. Timers (TIMx) www.ti.com Figure 18-4. One-shot and Periodic Mode Behavior # 18.2.2.2 Down Counting Mode In down counting mode (CM = 0), TIMx counts from the value defined in TIMx.LOAD (CVAE = 0) down to zero. When the TIMx.CTR value equals zero and TIMx.CTRCTL.REPEAT is set to 1, the TIMx.LOAD value is loaded into TIMx.CTR and the timer repeats the down counting pattern as shown in Figure 18-5. A Zero event is generated when TIMx counts to zero. A Load event is generated when TIMx counts from zero to the TIMx.LOAD value. Figure 18-6 shows the event generating cycle. Figure 18-5. Down Counting Mode, CVAE = 0 Figure 18-6. Down Counting Mode Event Generation # 18.2.2.3 Up/Down Counting Mode The Up/Down counting mode can count in an down-up direction or an up-down direction depending on TIMx.CTRCTL.CVAE value. The TIMx.CTRCTL.CVAE bits specify the initialization condition of the counter. Table 18-4. Counter Value after Enable Initialization Conditions | TIMx.CTRCTL.CVAE Value | Counter Value After Enable | |------------------------|----------------------------| | 0x0 | Load Value | | 0x1 | No Change | | 0x2 | Zero | # Counting in down-up direction When TIMx.CTRCTL.CVAE = 0, TIMx.CTR is set to TIMx.LOAD register value and TIMx counts in the down direction. When it reaches zero, a Zero event is generated and TIMx counts back up to TIMx.LOAD value. A Load event is generated when it reaches TIMx.LOAD value. Figure 18-7 shows TIMx counting in the down-up direction when TIMx.CTRCTL.CVAE = 0. Figure 18-7. Down-up Counting Mode and Event Generation, CVAE = 0 # Counting in up-down direction When TIMx.CTRCTL.CVAE = 2, TIMx.CTR is set to zero and TIMx counts in the up direction. When it reaches TIMx.LOAD, a Load event is generated and TIMx counts back down to zero. A Zero event is generated when it reaches zero. Figure 18-8 shows TIMx counting in up-down direction when TIMxCTRCTL.CVAE = 2. Figure 18-8. Up-down Counting Mode and Event Generation, CVAE = 2 # 18.2.2.4 Up Counting Mode In up counting mode, TIMx counts from zero up to the value defined in TIMx.LOAD. When the TIMx.CTR value equals TIMx.LOAD and TIMx.CTRCTL.REPEAT is not equal to 0, the zero is loaded into TIMx.CTR and the timer repeats the up counting pattern as shown in Figure 18-5. A Load event is generated when TIMx counts to TIMx.LOAD. A Zero event is generated when TIMx counts from TIMx.LOAD to the zero value. Figure 18-6 shows the event generating cycle. Figure 18-9. Up Counting Mode, CVAE = 2 Figure 18-10. Up Counting Mode Event Generation #### 18.2.2.5 Phase Load (TIMA only) In TIMA only, the phase load register TIMA.PL provides the capability for TIMA.CTR to count from a value other than zero or TIMA.LOAD in Up/Down counting mode. Phase load is used to generate asymmetric center-aligned PWM output signals with a controlled phase shift between different timer instances. When TIMA.PL is nonzero, phase load is enabled by setting TIMA.CTRCTL.PLEN = 1 and triggered when TIMA.CTTRIG.TRIG = 1. When phase load is triggered while TIMA.CTRCTL.CVAE = 0, the timer counts from the TIMA.PL value in the down direction. When phase load is triggered while TIMA.CTRCTL.CVAE = 0, the TIMx counts from the TIMA.PL value in the up direction. TIMA.PL is latched when the timer starts, and TIMA.PL is synchronized every time when the counter reaches the previously latched TIMA.PL value. Figure 18-11 shows how the phase load register works when the timer is counting in the up-down direction and the phase load value changes to a new value. Figure 18-11. Phase Load Register Synchronization in Up-Down Mode ## 18.2.3 Capture/Compare Module The capture/compare (CC) block is used for capture events or compare events. TIMG has up to 2 identical capture/compare blocks and TIMA has up to 4 identical capture/compare blocks present to support external or internal signals. Additionally, TIMA provides 2 additional CC blocks (CC4 and CC5) for compare events only from internal signals. Any of the TIMx capture/compare blocks may be used to capture timings of an input signal or to generate time intervals. # 18.2.3.1 Capture Mode Capture mode is selected when the TIMx.CCCTL\_xy[0/1].COC bit is set to 1. Capture mode is used to generate capture events and record time intervals, which is useful for speed computation or time measurements. Key registers for configuring capture mode: - **TIMx.LOAD**: the contents of this register are copied to counter (TIMx.CTR) on any operation designated to do a "load". This value is also used to compare with the counter value for generating a "Load Event" which can be used for interrupt, trigger, or signal generation actions. - **TIMx.CC\_xy[0/1]**: this is a register that can be used as either a capture register to acquire or record the next counter value on an event, or a compare register to the current counter to create an event. - **TIMx.CCCTL\_xy[0/1]**: this register controls the operations of the respective CC (capture/compare) blocks. For example, it can configure whether a rising edge or falling edge generates a capture condition. - TIMx.CTRCTL: this register provides control over the counter operation in different conditions. - **TIMx.IFCTL\_xy[0/1]**: this register controls the input filtering (FE, FP, CPV), selection (ISEL), and inversion (INV) for the associated CC block. #### 18.2.3.1.1 Input Selection and Inversion The TIMx.IFCTL register is used for selecting input source, filtering, and final inversion options for the capture/compare block. Figure 18-12 shows the block diagram for the TIMx capture block with two CC channels. Figure 18-12. TIMx Capture Block Diagram ### **CCP Input Edge Synchronization** When using a capture/compare pin (CCP) as an input, configure PINCMx for the TIMx CCP input (such as TIMG0\_C0). The CCP input signal is always passed through a synchronizer, and the input state (high or low) must be greater than one TIMCLK clock period for the synchronizer to detect the edge. CCP input edge detection requires at least one TIMCLK cycle to synchronize the edge input. Timing in the first TIMCLK cycle is uncertain because the edge detection cannot be predicted in the first TIMCLK period. When the capture condition occurs, an additional TIMCLK cycle is required to generate the capture event. #### Input Filtering The input glitch filter can be enabled by setting the TIMx. IFCTL\_01[0/1].FE bit. The filter period is configured by setting the TIMx. IFCTL\_01[0/1].FP bit. A consecutive period or majority voting format selected by the TIMx.IFCTL\_xy[0/1].CPV bit is used to select the criteria for a CCP input signal. - **Consecutive period** The CCP input signal must be at the specified level for the defined number of FP timer clocks for the CCP input to be processed. - **Majority voting** The filter ignores one clock of opposite logic over the filter period. For example, over the number of FP samples of the input, up to 1 sample may be of an opposite logic value (glitch) without affecting the output. The example shown in Figure 18-13 shows the difference between consecutive period and majority voting formats with a digital filter implemented to capture a CCP input signal of 3 TIMCLK periods. Figure 18-13. Consecutive Period and Majority Voting for Input Glitch Filtering using FP = 0 (3 TIMCLK cycles) # Input Selection The input select bits TIMx.IFCTL\_xy[0/1].ISEL select the input source to the filter input as the corresponding CCP input, CCP0 for cross-triggering across CC blocks, an external trigger, XOR (used in Hall input mode), event subscribers, or comparator inputs. #### 18.2.3.1.2 Use Cases Several different use cases can be achieved in capture mode and are discussed in the following sections. #### 18.2.3.1.2.1 Edge Time Capture Edge time capture measures the time (in TIMCLK cycles) from the start of the capture operation to the signal edge. The counter is loaded when TIMx is enabled and counts with each TIMCLK period until the CCP edge is detected, which triggers the capture of the timer value and generates a capture event. The capture edge time is equivalent to the difference between the starting value of the counter and the capture value in TIMx.CC\_xy[0/1] register. #### **Edge Time Capture Configuration** - 1. Set the TIMx.LOAD value. - 2. In the CTRCTL register, set the desired counter control settings for: - a. Counting mode (CM) and counter value after enable (CVAE) (see as described in Section 18.2.2) - b. Zero (CZC), advance (CAC), and load control (CLC) to specify what condition controls zeroing, advancing, or loading the counter - c. Repeat or one-shot mode (REPEAT) - 3. Set TIMx.CCCTL xy[0/1].COC = 1 for capture mode. - 4. Configure CCP as an input for the CC block by setting respective bit in the CCPD registers. For instance, if TIMx Channel 0 is an input, set CCPD.C0CCP0 = 0. - 5. For the corresponding CC block control register (CCCTL\_01[0/1]), set CCOND to the corresponding setting to capture events based off the input signal condition (rising and/or falling edge). Additionally, set ZCOND or LCOND depending on the counting mode used. - 6. Configure input capture settings in the TIMx.IFCTL xy[0/1] register as described in Section 18.2.3.1.1. - 7. Enable the counter by setting EN = 1 or waiting for a capture event to occur from the input edge. # Example using up-counting mode for rising edge capture In up-counting mode starting from zero (CM = 2, CVAE = 2), TIMx can be configured to generate a zero pulse and start the counter from the configured capture event (CCOND) by setting ZCOND to 1. The expected internal timing for a rising or positive edge time capture in up-counting mode is shown in Figure 18-14. Figure 18-14. Edge Time Capture Mode in Up-Counting Mode, CVAE = 2 # 18.2.3.1.2.2 Period Capture Period capture measures the period of a signal on an input CCP in TIMCLK cycles. On each positive (or negative) edge of the CCP input, the TIMx.CTR value is both captured into the TIMx.CC register to generate a capture event. The period capture time is equivalent to the difference between the starting value of the counter generated to the capture event, or time between reoccuring capture events for a periodic input signal. # **Period Capture Configuration** - 1. Set the TIMx.LOAD value. - 2. In the CTRCTL register, set the desired counter control settings for: - a. Counting mode (CM) and counter value after enable (CVAE) (see as described in Section 18.2.2) - b. Zero (CZC), advance (CAC), and load control (CLC) to specify what condition controls zeroing, advancing, or loading the counter - c. Repeat or one-shot mode (REPEAT) - 3. Set TIMx.CCCTL\_xy[0/1].COC = 1 for capture mode. - 4. Configure CCP as an input for the CC block by setting respective bit in the CCPD registers. For instance, if TIMx Channel 0 is an input, set CCPD.C0CCP0 = 0. - 5. For the corresponding CC block control register (CCCTL\_01[0/1]), set CCOND to the corresponding setting to capture events based off the input signal condition (rising and/or falling edge). Additionally, set ZCOND or LCOND depending on the counting mode used. - 6. Configure input capture settings in the TIMx.IFCTL xy[0/1] register as described in Section 18.2.3.1.1. - 7. Enable the counter by setting EN = 1 or waiting for a capture event to occur from the input edge. # Example using up-counting mode for rising-edge period capture In up-counting mode starting from zero (CM = 2, CVAE = 2), TIMx channel 0 can be configured to generate a capture event and zero event from a rising edge input by setting CCOND = ZCOND = 1h. Additionally, set CZC = 0h to zero the counter when a ZCOND event occurs. When a rising edge input is detected, the counter will begin to increment until the next input rising edge. If REPEAT = 1h, the counter will capture the period in TIMx.CC, zero the counter, and repeatedly capture the input period until the counter is disabled. The expected internal timing for a period capture in up-counting mode using two rising edges is shown in Figure 18-14. Figure 18-15. Period Capture Mode in Up-Counting Mode, CVAE = 2 #### 18.2.3.1.2.3 Pulse Width Capture Pulse width capture measures the high-time of a signal on CCP. The high time is the number of TIMCLK periods from rising edge to falling edge of the CCP input, and is useful for applications such as measuring the duty cycle of an PWM input signal. The counter is loaded at the positive edge and captured at the negative edge (capture event is generated). #### **Pulse-Width Capture Configuration** - 1. Set the TIMx.LOAD value. - 2. In the CTRCTL register, set the desired counter control settings for: - a. Counting mode (CM) and counter value after enable (CVAE) (see as described in Section 18.2.2) - b. Zero (CZC), advance (CAC), and load control (CLC) to specify what condition controls zeroing, advancing, or loading the counter - c. Repeat or one-shot mode (REPEAT) - 3. Set TIMx.CCCTL xy[0/1].COC = 1 for capture mode. - 4. Configure CCP as an input for the CC block by setting respective bit in the CCPD registers. For instance, if TIMx Channel 0 is an input, set CCPD.C0CCP0 = 0. - 5. For the corresponding CC block control register (CCCTL\_01[0/1]), set CCOND to the corresponding setting to capture events based off the input signal condition (rising and/or falling edge). Additionally, set ZCOND or LCOND depending on the counting mode used. - 6. Configure input capture settings in the TIMx.IFCTL xy[0/1] register as described in Section 18.2.3.1.1. - 7. Enable the counter by setting EN = 1 or waiting for a capture event to occur from the input edge. ## Example using up-counting mode for pulse width capture In up-counting mode starting from zero (CM = 2, CVAE = 2), TIMx channel 0 can be configured to generate a zero pulse and start the counter from the configured capture event (CCOND) by setting ZCOND to 1. To start the counter, a load condition can be triggered from the CCP rising edge input by setting LCOND = 1. The expected internal timing for a pulse width capture in up-counting mode using a rising and falling edge is shown in Figure 18-14. Figure 18-16. Pulse-Width Capture Mode #### 18.2.3.1.2.4 Combined Pulse Width and Period Time Using two capture registers can combine pulse-width and period capture of a single input waveform. The input signal can be externally connected to CCP channel 0, and the IFCTL\_01[1] register can be configured to have the input connected to CCP channel 1 internally so capture register 0 (TIMx.CC0) captures pulse width and capture register 1 (TIMx.CC1) captures period. The expected internal timing for combined pulse-width and period capture is shown in Figure 18-17. # **Pulse-Width and Period Capture Configuration** - 1. Set the TIMx.LOAD value. - 2. In the CTRCTL register, set the desired counter control settings for: - a. Counting mode (CM) and counter value after enable (CVAE) (see as described in Section 18.2.2) - b. Zero (CZC), advance (CAC), and load control (CLC) to specify what condition controls zeroing, advancing, or loading the counter - c. Repeat or one-shot mode (REPEAT) - 3. Set TIMx.CCCTL xy[0/1].COC = 1 for capture mode for each CC channel. - 4. Configure CCP as an input for each CC block by setting respective bits in the CCPD register. For instance, if TIMx Channel 0 is an input, set CCPD.C0CCP0 = 0. - 5. For each corresponding CC block control register (CCCTL\_01[0/1]), set CCOND to the corresponding setting to capture events based off the input signal condition (rising and/or falling edge). Additionally, set ZCOND or LCOND depending on the counting mode used. - 6. Configure input capture settings in the TIMx.IFCTL\_xy[0/1] register as described in Section 18.2.3.1.1. - 7. Enable the counter by setting EN = 1 or waiting for a capture event to occur from the input edge. # Example using pulse-width and period time capture In up counting mode, TIMx can be configured to generate a zero pulse and start the counter from the configured capture event (CCOND) by setting ZCOND to 1. The expected internal timing for a pulse-width and period capture in up-counting mode using two CC blocks is shown in Figure 18-14. Figure 18-17. Combined Pulse-Width and Period Capture #### 18.2.3.1.3 QEI Mode (TIMG with QEI support only) In TIMGx instances with QEI support, Quadrature Encoder Interface (QEI) mode provides an interface to the output of a quadrature encoder. It decodes the quadrature encoded data to provide the information on the relative positioning and movement of a linear or rotary motion. The QEI consists of two Gray coded quadrature input signals PHA and PHB, and an index input signal IDX. All input signals go to CCP inputs of a single counter, such that PHA and PHB are mapped to CCP0 and CCP1, and IDX is brought in as a separate input. An error detection mechanism can report erroneous transitions to avoid improper signal decodings. #### Note See Section 18.1.3 and the device-specific data sheet for TIMG instances that support QEI / Hall Input Mode. #### 18.2.3.1.3.1 QEI With 2-Signal QEI is used to decode signals from optical position encoders. Optical position encoders typically output 2 signals (PHA/PHB) which are often used to measure rotary or linear movement of physical items with rotating shafts, such as 3-phase motors. The measurement provided by the interface is incremental, which means as movement occurs, the interface provides the ability to capture the relative change from the previous position. When operating in QEI mode, a counter accumulates the incremental updates, deriving current position from initial position and the accumulated change. The initial position can be determined by the signal of the IDX input (3-signal QEI mode) or by other software means (software directly setting the initial position). The capture and compare register can be used to store the position value by defining a capture condition. When a direction change (DC) occurs, a DC interrupt is generated in the RIS register. Figure 18-18 shows the state machine in the QEI interface to detect the directional rotation from the two CCP input signals, PHA and PHB. Figure 18-18. State Machine for 2-signal and 3-signal QEI mode # **QEI 2-Signal Mode Configuration** - 1. Configure PINCMx for TIMGx C0 (PHA) and TIMGx C1 (PHB). - 2. Set TIMG.CCCTL\_01[0].COC = 1 and TIMG.CCCTL\_01[1].COC = 1 for capture mode for both CCP channels 0 and 1 (PHA and PHB). - 3. Configure CCP as an input for each CC block by setting respective bits in the CCPD register. For instance, if TIMx Channel 0 is an input, set CCPD.C0CCP0 = 0. - 4. Set the TIMx.LOAD value. - 5. In the CTRCTL register, set the CAC, CZC, and CLC bits to 4h. - 6. Configure input capture settings as described in Section 18.2.3.1.1, if desired. - 7. Enable the counter to start counting by setting EN = 1. # Example using QEI mode with 2 input signals The behavior of PHA/PHB follows Table 18-5 and Figure 18-19. Table 18-5. PHA/PHB State Table and Counter Actions | Current State (PHA, PHB) | Next State (PHA, PHB) | Direction (DIR) | Counter Action | |--------------------------|-----------------------|-----------------|------------------------------| | 00 | 10 | | | | 10 | 11 | 1 (Up) | +1 (If TIMx.CTR = LOAD, then | | 11 | 01 | ι (Ορ) | CTR = 0) | | 01 | 00 | | | | | | • | , | |--------------------------|-----------------------|-----------------|---------------------------------| | Current State (PHA, PHB) | Next State (PHA, PHB) | Direction (DIR) | Counter Action | | 00 | 01 | | | | 01 | 11 | 0 (Down) | -1 (If TIMx.CTR = 0, then CTR = | | 11 | 10 | O (DOWII) | TIMx.LOAD) | | 10 | 00 | | | Table 18-5. PHA/PHB State Table and Counter Actions (continued) Figure 18-19. 2-Signal QEI Operation # 18.2.3.1.3.2 QEI With Index Input 3-signal QEI mode is similar to the 2-signal mode with additional index input signal IDX. Generally, IDX input pulses once per rotation which can be used to reset the counter. It is used in one of two applications: - One IDX pulse is generated each movement cycle. In this case, the accumulated position represents the fraction of the movement cycle. - An IDX pulse is generated at a specific position in a non-cyclic movement. #### **QEI 3-Signal Mode Configuration** - 1. Configure PINCMx for TIMGx C0 (PHA), TIMGx C1 (PHB), and TIMGx IDX (IDX). - 2. Set TIMG.CCCTL\_01[0].COC = 1 and TIMG.CCCTL\_01[1].COC = 1 for capture mode for both CCP channels 0 and 1 (PHA and PHB). - 3. Configure CCP as an input for each CC block by setting respective bits in the CCPD register. For instance, if TIMx Channel 0 is an input, set CCPD.C0CCP0 = 0. - 4. Set the TIMx.LOAD value. - 5. In the CTRCTL register, set the CAC, CZC, and CLC bits to 5h. - 6. Configure input capture settings as described in Section 18.2.3.1.1, if desired. - 7. Enable the counter to start counting by setting EN = 1. The IDX input is sampled when a rising edge is detected. The IDX signal affects the counter value depending on the direction as shown in Table 18-6 and Table 18-6. Relation of IDX Input and Counter Value | Direction (DIR) | IDX | Counter Action | |-----------------|--------|-------------------------------------| | 1 | Rising | Zero (TIMx.CTR is set to zero) | | 0 | Rising | Load (TIMx.CTR is set to TIMx.LOAD) | Figure 18-20. 2-Signal QEI with Index Input Operation #### 18.2.3.1.3.3 QEI Error Detection The QEI module can detect erroneous transactions or state errors as shown in Figure 18-18. A QEIERR interrupt is generated and the counter or direction signal does not change in the error state. QEIERR can occur if the TIMCLK period is slower than the period of the PHA or PHB signals. #### 18.2.3.1.4 Hall Input Mode (TIMG with QEI support only) In TIMGx instances with QEI support, three digital Hall signals can be input into CCP channel 0 (CCP0). CCP channel input 1 (CCP1), and IDX for position control of 3-phase Hall-sensored motor applications. Hall signals are used to detect real-time motor position in motor control applications and can be used for speed computation measurements, position control, or motor stall status. #### **Note** See Section 18.1.3 and the device-specific data sheet for TIMG instances that support QEI / Hall Input Mode. Table 18-7 shows the signal mapping for Hall signals A (U), B (V), and C (W) to TIMG capture/compare input signals. Table 18-7. Hall Input and TIMx Input Signal Mapping | Hall input signal | TIMx input | |-------------------|------------| | HALL A / HALL U | CCP0 | | HALL B / HALL V | CCP1 | | HALL C / HALL W | IDX | #### Note Hall input signals should be digital inputs from Hall sensor ICs with a pullup to VCC. As shown in Figure 18-21, the input capture module provides a 3-input XOR of synced CCP0, CCP1, and IDX signals to create a frequency generator (FG) signal. The XOR output signal is selected when IFCTL xy[0/1].ISEL is set to 4h. See Figure 18-21 for XOR option in the input capture block diagram. Figure 18-21. Hall 3-input XOR for Frequency Generator (FG) Signal to CC input block The XOR'ed output signal is propagated to the CC block and a period or pulse-width capture can be used to compute the linear motor speed in relation to the calculated period or pulse width in the TIMx.CC register. See Section 18.2.3.1.2.2 and Section 18.2.3.1.2.3 on how to calculate period and pulse-width captures based on the XOR'ed input signal. Figure 18-22 shows the input signal to the CC block which can be used for speed calculations. Figure 18-22. Hall 3-Input XOR Signal used with Pulse Width or Period Capture for Speed Computation # **Hall Input Mode Configuration** - 1. Configure PINCMx for TIMGx\_C0 (HALLA), TIMGx\_C1 (HALLB), and TIMGx\_IDX (HALLC). - 2. Set TIMG.CCCTL\_01[0].COC = 1 and TIMG.CCCTL\_01[1].COC = 1 for capture mode for both CCP channels 0 and 1 (HALLA and HALLB). - 3. Configure CCP as an input for each CC block by setting respective bits in the CCPD register. For instance, if TIMx Channel 0 is an input, set CCPD.C0CCP0 = 0. - 4. Set the TIMx.LOAD value. - 5. Set TIMG.IFCTL\_xy[0/1].ISEL = 4h to select the XOR option for Hall signals. - 6. Enable the counter to start counting by setting EN = 1. # 18.2.3.2 Compare Mode Compare mode is selected when TIMx.CCCTL\_xy[0/1].COC = 0. Compare mode is used to generate event or PWM output signals at specific time intervals. Many types of compare mode events can be generated based on the configuration of the CC action control register CCACT\_xy[0/1]. A compare event occurs for a CC channel when TIMx.CTR counts up (CCU) or down (CCD) to the value in TIMx.CC\_xy[0/1]. Additionally, secondary compare up (CC2U) or down (CC2D) events for a CC channel can be generated from another CC block's CCU or CCD event with respect to its TIMx.CC\_xy[0/1] value in the same timer instance. Compare events can be used to generate a timing base internally or generate a PWM output with specific profiles using active, inactive, or toggle action behaviors. #### Note Secondary compare events in up/down counting mode can be used to generate PWM signals with twice the PWM frequency (but half the PWM resolution). In TIMA only, an additional internal 5th and 6th CC block (TIMA.CC\_45[0/1]) can be used for secondary compare events while continuing to use CC channels with dedicated output pins for external PWM signal generation. Table 18-8 shows the types of compare mode events that can be generated and conditions to generate the events. | <b>Table 18-8.</b> | Compare | <b>Mode Events</b> | |--------------------|---------|--------------------| |--------------------|---------|--------------------| | Event | Name | Event condition | |------------------------|--------------------------------------|--------------------------------------------------------------------| | CCDn (n = CC channel) | Capture/compare down event | When timer is counting down, TIMx.CTR = TIMx.CC_xy[0/1] | | CCUn (n = CC channel) | Capture/compare up event | When timer is counting up, TIMx.CTR = TIMx.CC_xy[0/1] | | CC2Dn (n = CC channel) | Secondary capture/compare down event | Occurs when CC2SELD is configured for the source of the CCDn event | | CC2Un (n = CC channel) | Secondary capture/compare up event | Occurs when CC2SELU is configured for the source of the CCUn event | #### Note Look at the device specific data sheet to check how many CC channels are available in each TIMx instance on the device. # 18.2.3.2.1 Edge Count In addition to event or PWM output generation, compare mode can also be used for input signal edge counting to determine when a number of edges has been detected. In edge count operation, a CCP input edge can advance the counter based on the ACOND condition. The counter register is initialized with the starting value, and the number of detected CCP input edges at any time can increment or decrement depending on the counting mode configuration. The user can count rising edges, falling edges, or both edges by configuring the CCOND value. ### **Edge Count Configuration** - 1. Set TIMx.CCCTL xy[0/1].COC = 0 for compare mode. - 2. Optionally set the corresponding TIMx.CC\_xy[0/1] to a compare value to generate a compare interrupt when the counter reaches this value. - 3. In the CTRCTL register, set the desired counter control settings for: - a. Counting mode (CM) and counter value after enable (CVAE) (see as described in Section 18.2.2) - b. Zero (CZC), advance (CAC), and load control (CLC) to specify what condition controls zeroing, advancing, or loading the counter - c. Repeat or one-shot mode (REPEAT) - 4. Set ACOND to a setting to advance the counter based on the input edge polarity. - 5. Configure input capture settings as described in Section 18.2.3.1.1, if desired. - 6. Enable the counter by setting EN = 1. #### Example using edge count operation using up-counting mode In up-counting mode starting from zero (CM = 2, CVAE = 2), the expected internal timing for rising edge count operation to increment the counter is shown in Figure 18-23. Figure 18-23. Edge Count Operation to Generate Compare Event (TIMx.CC = 2) #### 18.2.4 Shadow Load and Shadow Compare Some timer modules have a shadow load and shadow compare register feature which gives the user the flexibility of holding the update of load and CC values until a certain event occurs. This is useful in timing-critical applications where PWM control signals need to be updated with correct timings, such as duty cycle updates. Refer to the timer features for specific configurations of the TIMx modules. #### Note See Section 18.1.3 and the device-specific data sheet for TIMx instances that support Shadow Load and Shadow Compare. #### 18.2.4.1 Shadow Load The shadow load feature allows holding the update of load values until a zero event occurs. To enable shadow loading, set the TIMx.GCTL.SHDWLDEN bit. If the TIMx module has a shadow load feature, there is an internal shadow register for the load value (TIMx.LOAD). The shadow register will update the load value at a zero event as shown in Figure 18-24. Figure 18-24. Shadow Load Update Load Value When TIMx.GCTL.SHDWLDEN = 1, load values update at zero events for all counting modes. Consult the counting mode operations below to determine if a shadow load is needed: • In down-counting modes, since TIMx.LOAD value is updated when a zero event occurs, a shadow load is not needed in these modes. - In up/down counting mode, TIMx.LOAD is compared with the counter value to determine if the peak is reached and when to start to counting down. A shadow load is necessary to ensure that TIMx counts up to the load value before the zero event, or else the load value can update immediately and cause incorrect timings. - In up-counting mode, the timer counts to TIMx.LOAD. A shadow load is necessary to ensure that TIMx counts up to the load value before the zero event, or else the load value can update immediately and cause incorrect timings. Figure 18-25 shows an example of how shadow load and shadow compare takes effect at the zero event for both the TIMx.LOAD and TIMx.CC value in up/down counting mode. #### 18.2.4.2 Shadow Compare When shadow compare is enabled for updating the capture/compare register (TIMx.CC), the value written to the respective compare register is first stored into a shadow compare register and then transferred to the compare register at different events configured by setting the TIMx.CCCTL\_xy[0/1].CCUPD bits. Additionally, the capture/compare action register (TIMx.CCACT) has the ability to update the action at different events configured by setting the TIMx.CCCTL xy[0/1].CCACTUPD bits. Table 18-9 shows the settings for configuring when shadow compare and actions occur at different events. Table 18-9. Shadow Compare and Action Update Behavior | Bit Field | Value | Description/Comment | | |------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | | 0 | The value written to TIMx.CC register take effect immediately. | | | | 1 | The value written to the TIMx.CC register is stored in a shadow compare register and gets transferred to the TIMx.CC register in the TIMCLK cycle following a zero event (TIMx.CTR value equals 0). | | | | 2 | The value written to the TIMx.CC register is stored in a shadow compare register and gets transferred to the TIMx.CC register in the TIMCLK cycle following a compare (down) event (TIMx.CTR value equals TIMx.CC) | | | | 3 | The value written to the TIMx.CC register is stored in a shadow compare register and gets transferred to the TIMx.CC register in the TIMCLK cycle following a compare (up) event (TIMx.CTR value equals TIMx.CC) | | | CCUPD | 4 | The value written to the TIMx.CC register is stored in a shadow compare register and gets transferred to the | | | / CCACTUPD | | TIMx.CC register in the TIMCLK cycle following a zero or load event (TIMx.CTR value equals 0 or TIMx.CTR | | | | | equals TIMx.LOAD). | | | | | Note: this update mechanism is defined for use only in up/down counting mode. | | | | 5 | The value written to the TIMx.CC register is stored in a shadow compare register and gets transferred to the TIMx.CC register in the TIMCLK cycle following a zero event and the repeat count equaling zero (TIMx.CTR value equals 0 and TIMx.RC equals 0) | | | | 6 | The value written to the TIMx.CC register is stored in a shadow compare register, and gets transferred to the TIMx.CC register in the TIMCLK cycle following a trigger pulse. See Section 18.2.7. | | Figure 18-25 shows an example of how shadow load and shadow compare takes effect at the zero event for both the TIMx.LOAD and TIMx.CC value in up/down counting mode. Figure 18-25. Shadow Load and Shadow Compare Taking Effect at Zero Event in Up/Down Mode # 18.2.5 Output Generator The output signal generation unit can be used with the counter and capture/compare modules to generate desired pulse-width modulation (PWM) output waveforms, event signals, synchronized capture inputs, or the counter direction. Many output waveforms are generated from counter events (load, zero, counter direction) and the capture/compare block (compare match). TIMA and TIMG have many common features in the output generation signal unit. Additionally, TIMA has advanced output generation features such as complimentary output signals, deadband insertion, and fault generation. Figure 18-27 shows the TIMG output block diagram. Figure 18-26. Output Connection for TIMG Figure 18-27 shows the TIMA output block diagram. Figure 18-27. Output Connection for TIMA #### **Signal Generator Actions** Table 18-10 shows the types of signal generator actions capable by the output generator. Signal generator actions are configured in the CCACT xy[0/1] register for zero, load, and compare events. For types of compare events, see Table 18-8. Table 18-10. Signal Generator Actions from Compare Event | Value | Action | | |-------|-----------------------------------------------------------------------|--| | 0h | Event is disabled and a lower priority event is selected if asserting | | | 1h | CCP output value is set high | | | 2h | CCP output value is set low | | | 3h | CCP output value is toggled | | The key registers for generation of output signals are: - **LOAD**: the contents of this register are copied to the counter (TIMx.CTR) on any operation designated to do a "load". This value is also used to compare with the counter value for generating a "Load Event" that can be used for interrupt, trigger, or signal generator actions. - **CCPD:** this register configures the direction of the CCP pins as inputs or outputs. - CC\_xy[0/1]: this is a register used as a compare value to the current counter to create an match event. - **CTRCTL**: this register provides control over the counter operation in different conditions. - CCCTL xy[0/1]: this register controls the operations of the respective CC registers and the counter - OCTL\_xy[0/1]: this register controls the output of the capture-compare portion of the counter. This includes the ability to select the source of what is driven out along with initial condition values and final inversion options. - CCACT\_xy[0/1]: this register controls the actions of the signal generator of the capture-compare portion based on the events created in the counter block, the capture and compare block, and debug events. - **ODIS:** this register disables the output signal selected by OCTL.CCPO (before conditional inversion) to allow software the ability to hold the CCP output low during configuration or shutdown. These are key registers for configuring the compare mode to generate PWM signals: #### 18.2.5.1 Configuration There are five stages to configuring output signal generation in TIMx devices: - Counter and CC Block Event Generation - Output Generation, Selection and Inversion - Software Force Output - Fault Output Generation (TIMA only) - · Counter Initial Value and Enable #### **Counter and CC Block Event Generation** The counter block contains the counter and produces a load event (L), zero event (Z), and direction of counting based on the counting mode used. The CC blocks contain the CC register and can generate two types of output signals: compare match events and capture events. Please see Table 18-8 for the compare events that can be generated. # **Output Generation, Selection and Inversion** The TIMx.CCACT register specifies the waveform generation of a CCP output depending on the counting mode and counter compare actions. TIMx.OCTL\_xy[0/1].CCPO controls the CCP output selection from the output generation unit, output generation unit with deadband (TIMA only), counter events, compare events, capture events, fault events, or signal inputs. The output disable register (ODIS) can optionally disable the CCP output to optionally hold the CCP output low during configuration or shutdown. TIMx.OCTL\_xy[0/1].INV controls final inversion options. On TIMA devices only, CCP complimentary output channels can be generated from the output generation unit (denoted by "N" in the signal name). For instance, TIMA0 channel 2 (TIMA0\_C2) can also produce a complimentary output (TIMA0\_C2N). The CCPO and INV bits also controls the selection and inversion options for the complementary output. Complimentary outputs with deadband insertion are a common use case for inverter-based applications with half-bridge topologies. For more information, please see Section 18.2.5.2.4. #### **Software Force Output** The output of the signal generator can be overwritten in software by setting CCCTL\_xy[0/1].SWFRACT to a nonzero setting. For TIMA devices only, the complementary output of the signal generator can be overwritten by setting CCCTL\_xy[0/1].SWFRACT\_CMPL to a nonzero setting. For more information, see Section 18.2.5.3. # Fault / Debug Output Generation (TIMA only) On TIMA devices, the CCP output can be overwritten after the software force output block if there is a system fault (FAULT), fault condition upon exit (FEXACT), fault condition upon entry (FENACT), an asynchronous fault (FAULT\_ASYNC), or the debugger is halted (DEBUG\_HALT). For more information, see Section 18.2.6 and Section 18.2.10. #### **Counter Compare Initial Value and Enable** To specify an initial value for the CCP output while the counter is disabled, set OCTL\_xy[0/1].CCPIV to 0 for a low value or 1 for a high value. This is useful for applications where CCP outputs need to be in a default state before enabling the counter. To enable the counter, set TIMx.CTRCTL.EN to 1. #### 18.2.5.2 Use Cases Several different use cases can be achieved with the output generator and are discussed in the following sections. #### 18.2.5.2.1 Edge-Aligned PWM To generate edge-aligned PWMs, TIMx can be configured for up- or down-counting mode and the PWM period in TIMCLK cycles is TIMx.LOAD + 1. The waveform uses load, zero, and compare events to drive the CCPx output high or low depending on the configuration settings of the compare/capture block and counter. # **Edge-Aligned PWM Configuration** To generate edge-aligned PWMs using compare match events from the counter: - 1. In the TIMx.CTRCTL register, set the desired counter control settings for: - a. Up-counting (CM = 2) or down-counting mode (CM = 0) and counter value after enable (CVAE) (see as described in Section 18.2.2) - b. Zero (CZC), advance (CAC), and load control (CLC) to specify what condition controls zeroing, advancing, or loading the counter - c. Repeat or one-shot mode (REPEAT) - 2. Set the TIMx.LOAD value to configure the PWM period. - 3. Set the TIMx.CC\_xy[0/1] value to configure the duty cycle. - 4. Set TIMx.CCCTL\_xy[0/1].COC = 1 for compare mode. - 5. Configure CCP as an output for the CC block by setting respective bit in the CCPD registers. For instance, if TIMx Channel 0 is an output, set CCPD.C0CCP0 = 1. - 6. In TIMx.CCACT\_xy[0/1], set the CCP output action settings for compare events, zero events, load events, software force action, or fault events (TIMA only). - 7. In TIMx.OCTL xy[0/1], set CCPO = 0 to select the signal generator output. - 8. Enable the corresponding CCP output by setting ODIS.C0CCPn to 1 for the corresponding counter n. - 9. Configure polarity of the signal using the CCPOINV bit, and configure CCPIV to specify the CCP output state while disabled. - 10. Enable the counter by setting TIMx.CTRCTL.EN = 1. #### Example using edge-aligned PWM in down-counting mode A typical 2-channel edge-aligned PWM generation for down-counting mode is shown in Figure 18-28 with the following edge-aligned PWM output waveforms: - CCP0 output generates: - High pulse-width from TIMx.LOAD to TIMx.CC0 value (LACT = 1h) - Low pulse-width from TIMx.CC0 value to zero (CDACT = 2h) - CCP1 output generates: - High pulse-width from TIMx.LOAD to TIMx.CC1 value (LACT = 1h) - Low pulse-width from TIMx.CC1 value to zero (CDACT = 2h) Figure 18-28. Edge-Aligned PWM Signals in Down-Counting Mode # Example using edge-aligned PWM in up-counting mode A typical 2-channel edge-aligned PWM generation for up-counting mode is shown in Figure 18-28 with the following edge-aligned PWM output waveforms: - CCP0 output generates: - High pulse-width from zero to TIMx.CC0 value (ZACT = 1h) - Low pulse-width from TIMx.CC0 value to TIMx.LOAD (CUACT = 2h) - · CCP1 output generates: - High pulse-width from zero to TIMx.CC1 value (ZACT = 1h) - Low pulse-width from TIMx.CC1 value to TIMx.LOAD (CUACT = 2h) Figure 18-29. Edge-Aligned PWM Signals in Up-Counting Mode #### 18.2.5.2.2 Center-Aligned PWM To generate center-aligned PWMs, TIMx is configured for up/down counting mode and the TIMx.LOAD value contains the half-period. The waveform uses up compare events and down compare events to drive the CCPx output high or low depending on the configuration settings of the compare/capture block and counter. In TIMCLK cycles, the PWM period is (2 \* TIMx.LOAD) and the duty cycle is 1 - (TIMx.CC\_xy[0/1] / TIMx.LOAD). # **Center-Aligned PWM Configuration** To generate center-aligned PWMs using compare match events from the counter: - 1. In the TIMx.CTRCTL register, set the desired counter control settings for: - a. Up/down counting mode (CM = 1) and counter value after enable (CVAE) (see as described in Section 18.2.2) - b. Zero (CZC), advance (CAC), and load control (CLC) to specify what condition controls zeroing, advancing, or loading the counter - c. Repeat or one-shot mode (REPEAT) - 2. Set the TIMx.LOAD value to configure the PWM period. - 3. Set the TIMx.CC xy[0/1] value to configure the duty cycle. - 4. Set TIMx.CCCTL\_xy[0/1].COC = 1 for compare mode. - 5. Configure CCP as an output for the CC block by setting respective bit in the CCPD registers. For instance, if TIMx Channel 0 is an output, set CCPD.C0CCP0 = 1. - 6. In TIMx.CCACT\_xy[0/1], set the CCP output action settings for compare events, zero events, load events, software force action, or fault events (TIMA only). - 7. In TIMx.OCTL xy[0/1], set CCPO = 0 to select the signal generator output. - 8. Enable the corresponding CCP output by setting ODIS.C0CCPn to 1 for the corresponding counter n. - 9. Configure polarity of the signal using the CCPOINV bit, and configure CCPIV to specify the CCP output state while disabled. - 10. Enable the counter by setting TIMx.CTRCTL.EN = 1. #### Example using center-aligned PWM in up/down counting mode A typical 2-channel center-aligned PWM generation using up/down counting mode is shown in Figure 18-30 with the following center-aligned PWM output waveforms: - · CCP0 output generates: - High pulse-width from TIMx.CC0 compare up event to TIMx.CC0 compare down event (CUACT = 1h) - Low pulse-width from TIMx.CC0 compare down event to TIMx.CC0 compare up event (CDACT = 2h) - CCP1 output generates: - High pulse-width from TIMx.CC0 compare up event to TIMx.CC0 compare down event (CUACT = 1h) - Low pulse-width from TIMx.CC0 compare down event to TIMx.CC0 compare up event (CDACT = 2h) Figure 18-30. Center-Aligned PWM # 18.2.5.2.3 Asymmetric PWM (TIMA only) In TIMA only, asymmetric PWMs can be generated by generating two synchronized center-aligned PWM signals with a controlled phase shift. To generate the asymmetric PWM signals, the phase load feature is used as described in Section 18.2.2.5. # **Asymmetric PWM Configuration** To generate asymmetric PWMs using compare match events from the counter: - 1. Synchronize TIMA0 and TIMA1 using a cross trigger as described in Section 18.2.7. - 2. Configure two center-aligned PWMs as described in Section 18.2.5.2.2 using TIMA0 and TIMA1. TIMA0 and TIMA1 should have the same load value (TIMA.LOAD) and compare value (TIMA.CC\_xy[0/1]) to generate the same PWM frequency and duty cycle. - 3. Add a phase shift value for TIMA0 or TIMA1 by configuring the phase load value TIMA.PL as described in Section 18.2.2.5. - 4. Enable the counter by setting TIMA.CTRCTL.EN = 1. Figure 18-31 shows an example of asymmetric PWM configuration using CCP channel 0 of TIMA0 and TIMA1. Figure 18-31. Asymmetric PWM Configuration with Phase Load for CCP channel 0 of TIMA0 and TIMA1 # 18.2.5.2.4 Complementary PWM with Deadband Insertion (TIMA only) TIMA provides the option of generating complimentary PWM outputs with deadband insertion (non-overlapping transitions in complimentary PWM signals) from a signal PWM reference signal. Deadband is useful for applications with half-bridge control to avoid shoot-through conditions, such as motor driver or inverter-based applications. TIMA provides this optional feature on complimentary CCP output channels, such as TIMA0\_C2 and TIMA0\_C2N for a reference PWM signal on TIMA0 CCP output channel 2. The deadband control register (TIMA.DBCTL) is programmed with the deadband mode and timing information. The deadband mode is Mode 0 or Mode 1, which can be selected using the M1\_ENABLE bit, and the timing information to control the deadband width in TIMCLK cycles is selected by the RISEDELAY and FALLDELAY bit fields. See Table 18-11 for the configuration and relationship between deadband mode and deadband width settings. Table 18-11. Deadband Modes and Delay Timing Configuration in DBCTL register | Deadband Mode | Bitfield | Description | Counting Mode | |---------------|---------------|----------------------------------|---------------| | Mode 0 | M1_ENABLE = 0 | RISEDELAY and FALLDELAY | Any | | | | is applied with respect to the | | | | | output generator signal's rising | | | | | and falling edges to generate | | | | | CCP and CCP complimentary | | | | | signal | | Table 18-11. Deadband Modes and Delay Timing Configuration in DBCTL register (continued) | Deadband Mode | Bitfield | Description | Counting Mode | |---------------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------| | Mode 1 | M1_ENABLE = 1 | <ul> <li>CCP signal is the same as<br/>output generator signal</li> <li>RISEDELAY and<br/>FALLDELAY is applied to<br/>CCP complimentary signal</li> </ul> | Up/down counting mode only | #### Deadband timing equation and example The equations for configuring RISEDELAY and FALLDELAY from TIMCLK frequency and deadband timing is shown in Equation 16 and Equation 17. $$RISEDELAY = f_{TIMCLK} \times t_{dead\ rise} \tag{16}$$ $$FALLDELAY = f_{TIMCLK} \times t_{dead\_fall}$$ (17) For example, if 400 ns of deadband is required when using a TIMCLK frequency of 80 MHz, and Mode 1 is used with center-aligned PWMs to generate equal deadband every PWM period, then RISEDELAY = FALLDELAY = (80 MHz) \* (400 ns) = 32. # **Complimentary PWM with Deadband Configuration** - 1. Configure a PWM output for an edge-aligned PWM (Section 18.2.5.2.1) or center-aligned PWM (Section 18.2.5.2.2) for any CCP output channel in TIMA. - 2. Configure TIMA.DBCTL with the specified deadband mode (M1\_ENABLE) and deadband width RISEDELAY and FALLDELAY, depending on the deadband mode. - 3. In TIMx.OCTL xy[0/1], set CCPO = 0xC to select the signal generator with deadband output. - 4. Enable the counter by setting TIMx.CTRCTL.EN = 1. # Example 1 - Complimentary PWM outputs with deadband using edge-aligned PWM in down-counting mode For edge-aligned PWM, Mode 0 can only be used for deadband insertion mode. See Figure 18-32 for inserting configurable deadband using down counting mode, TIMA output channel 0, and edge-aligned PWM. For centeraligned PWM, there are two modes, as shown in and Figure 18-33. Figure 18-32. Deadband Insertion for Edge-Aligned PWM in Down-Counting Mode using TIMA CC output channel 0 (M1\_ENABLE = 0) # Example 2- Complimentary PWM outputs with deadband using center-aligned PWM For center-aligned PWM, Mode 0 or Mode 1 can be used for deadband insertion mode. See Figure 18-33For inserting configurable deadband using up/down counting mode, TIMA output channel 0, and center-aligned PWMs for both Mode 0 and Mode 1. Figure 18-33. Dead Band Insertion for Center-Aligned PWM (Mode 0 and Mode 1) # 18.2.5.3 Forced Output Each output channel signal can be forced to a high or low level directly by software, independently of any comparison between the compare register and the counter. The output of the CCP channel can be forced to high or low by setting the SWFRCACT bit in the TIMx.CCACT\_xy[0/1] register. Additionally, in TIMA only, the complimentary output channel can also be forced to high or low by setting the SWFRCACT CMPL bit in the TIMx.CCACT xy[0/1] register. Table 18-12 shows the software force output action configuration options. **Table 18-12. Force Output Action Configuration** | Table 10 12: 1 orde Output Action Configuration | | | | |-------------------------------------------------|-------|------------------------------------------------------------------------|--| | Bit Field | Value | Description/Comment | | | SWFRCACT / SWFRCACT_CMPL | 0 | No forced output. Output is directly from the signal generation block. | | | | 1 | Force output high | | | | 2 | Force output low | | ## 18.2.6 Fault Handler (TIMA only) In TIMA only, there are internal and external fault inputs which can be used to control the generation of PWM signals. The intended use of these inputs is as a mechanism for internal or external circuitry to indicate a fault in the system. This allows the hardware to react quickly to the external fault while optionally signaling an interrupt for software correction and leaving the output signals in a safe state. It is important to consider the following basic properties of faults in a system, such as: - Fault input selection (fault signal from external IC, internal signal, etc.) - How long a fault condition lasts, or the fault condition duration - How the counter reacts to the entry and exit of a fault condition - How the output signal reacts to the entry and exit of a fault condition Fault conditions are synchronously detected using TIMCLK or asynchronously detected. Synchronous faults have a configurable glitch filter and can generate a latched fault event. Asynchronous faults cannot be latched and do not generate a fault event. The CCP output can be configured for either type of fault upon entry and exit conditions. The fault handler logic diagrams are split into three parts: asynchronous faults, synchronous faults, and fault output generation. Figure 18-34 shows the asynchronous fault handler logic connections. Figure 18-34. Asynchronous Fault Handler Connections Figure 18-35 shows the synchronous fault handler logic connections. Figure 18-35. Synchronous Fault Handler Connections Figure 18-36 shows the fault output generation logic connections. Figure 18-36. Fault Output Generation Connections Key registers for configuring the fault handler are: - TIMA.FCTL: this register controls the fault inputs, fault detection, and error handling behavior. - TIMA.FSCTL: this register controls the fault source selection and enable. - TIMA.FIFCTL: this register controls the input filtering (FILTEN, FP, CPV) for the fault input. - TIMA.CCACT\_xy[0/1]: this register controls the actions of the signal generator of the capture-compare portion based on fault events. # 18.2.6.1 Fault Input Conditioning The comparator and external fault pin fault source input passes through a two TIMCLK synchronization stage and the fault input can be filtered through the glitch filter using the fault input filter (TIMA.FIFCTL) register. The fault input glitch filter can be enabled by setting the TIMA.FIFCTL.FILTEN bit. The filter period is configured by setting the TIMA.FIFCTL.FP bit. A consecutive period or majority voting format selected by the TIMA.FIFCTL.CPV bit is used to select the criteria for a CCP input signal. - Consecutive period The fault input signal must be at the specified level for the defined number of FP timer clocks for the fault input to be processed. - Majority voting The filter ignores one clock of opposite logic over the filter period. For example, over the number of FP samples of the fault input, up to 1 sample may be of an opposite logic value (glitch) without affecting the output. The example shown in Figure 18-13 shows the difference between consecutive period and majority voting formats with a digital filter implemented to capture a fault input of 3 TIMCLK periods. #### 18.2.6.2 Fault Input Sources The fault control (FCTL) and fault source control (FSCTL) registers are used to select the polarity and enable various fault input sources as shown in Table 18-13. To enable the final input for fault detection, set TIMA.FTCL.FIEN = 1. There are four types of fault input sources that are available for synchronous or asynchronous fault detection: # Comparator (COMP) output The comparator output is useful for fault detection when COMPs are used for detecting overcurrent or overvoltage events. To enable the comparator output for fault detection, set the TIMA.FSCTL.FACxEN bit, and configure the polarity to detect the fault using TIMA.FCTL.FSENACx bit (x = 0, 1, or 2 for COMP instance). #### **External Fault Pin** Many IC devices include a fault detection pin (i.e. nFAULT) that an MCU can detect when there is a fault condition in the system. There are 3 fault external signal pins (TIMA\_FLTx) connected to every TIMA module, where x = 0, 1, or 2. Each signal pin can be enabled by setting the TIMA.FSCTL.FEXxEN bit, and the polarity of this signal to trigger a fault condition can be configured by using TIMA.FCTL.FSENEXTx bit (where x = 0, 1, or 2 for each TIMA FLTx pin). #### **System Clock Fault** Any system clock fault can be used to trigger the PWM output(s) to a Hi-Z state. This can be enabled by setting the TIMA.FSCTL.FCEN bit. #### Note When a SYSCLK fault occurs, a device reset is generated. Various TIMA fault entry and exit options are invalid while the device is in reset. #### Trigger A trigger can be configured to generate a fault condition is detected. This is useful for performing diagnostics or creating fault dependencies from other peripherals in the event fabric. For trigger configuration, please see Section 18.2.7. The fault input mask can be enabled by setting the TIMA.FSCTL.TFIM bit. Table 18-13. Fault Input Sources and Configuration | Signal name | Input source | Fault type | Polarity Bit | Enable Bit | |-------------|---------------------|----------------|--------------|------------| | COMP0_OUT | COMP0 output | | FSENAC0 | FAC0EN | | COMP1_OUT | COMP1 output | | FSENAC1 | FAC1EN | | COMP2_OUT | COMP2 output | | FSENAC2 | FAC2EN | | TIMA_FLT0 | External Fault 0 | Synchronous or | FSENEXT0 | FSENEXT0 | | TIMA_FLT1 | External Fault<br>1 | Asynchronous | FSENEXT1 | FSENEXT1 | | TIMA_FLT2 | External Fault<br>2 | | FSENEXT2 | FSENEXT2 | | SYSCLK | System Clock | Synchronous | - | FCEN | | TRIG | Trigger Output | Synthionous | - | TFIM | # 18.2.6.3 Counter Behavior With Fault Conditions There are two settings for specifying the counter behavior in fault conditions: TIMA.CTRCTL.FB (during fault behavior) and TIMA.CTRCTL.FRB (fault resume behavior). The counter should continue to be enabled (TIMA.CTRCTL.EN = 1) during the fault handler behavior. The counter behavior of the fault condition is described in Table 18-14 and Figure 18-37. Table 18-14. Counter Behavior in Fault Condition With TIMA.CTRCTL Register | Bit Fields | | | Counter Behavior | | | |------------|--------------------|---|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | FB | FB FRB CVAE REPEAT | | REPEAT | Counter benayior | | | 0 | X X | | 0 | Ignores fault mode. Counter continues to count during fault and stops when reaches zero. | | | | | | 1/3 | Ignores fault mode. Counter continues to count during fault and repeat. | | | | 0 | Х | 0/1/3 | Reacts immediately to fault mode. The counter stops counting immediately and throughout the fault mode. Upon exit of fault mode, the counter continues counting from where it left off. | | | | 0 | | | Reacts immediately to fault mode. The counter stops counting immediately and throughout the debug mode. Upon exit of fault mode, the counter restarts from LOAD value (restarts a down count). | | | ' | 1 | 1 | x | Reacts immediately to fault mode. The counter stops counting immediately and throughout the debug mode. Upon exit of debug mode, the counter restarts from where it paused at fault entry. | | | | | 2 | | Reacts immediately to fault mode. The counter stops counting immediately and throughout the fault mode. Upon exit of fault mode, it restarts from 0 value (restarts an up/down count). | | Figure 18-37. Counter Behavior in Fault Condition with TIMx.CTRCTL Register ## 18.2.6.4 Output Behavior With Fault Conditions There are two settings for the CCP output channel behavior in a fault condition, TIMA.CCACT\_01[0/1].FEXACT (fault exit behavior) and TIMA.CCACT\_01[0/1].FENACT (fault entry behavior). The output behavior of fault condition is described in Table 18-15. Table 18-15. CCP Output Behavior in Fault Condition With TIMA.CCACT Register | Bit Fields | | Output Behavior | | | |--------------------------------|--------|-------------------------------------------------------|--|--| | FEXACT | FENACT | Output Bellavior | | | | | 0 | The CCP output value is unaffected by the fault event | | | | 1 CCP output value is set high | | CCP output value is set high | | | | 2 CCP output value is set low | | CCP output value is set low | | | | 3 CCP output value toggles | | CCP output value toggles | | | | | 4 | CCP output is tristated (Hi-Z) | | | #### Note Fault entry and exit behavior is not dependent on the counter being enabled. They will always update the output when in fault mode. Enabling the counter through a software write when in fault mode will generate a load event that will be captured in RIS but the counter will not proceed. Load events will not affect the output when in fault mode. Fault events takes the absolute priority and no events can update the output until you are out of fault mode. #### 18.2.7 Synchronization With Cross Trigger When using a main-secondary timer configuration by connecting multiple timers together, the cross-trigger feature can instruct multiple timer modules in the same power domain or across different power domains using the event fabric to start counting simultaneously. Cross-triggers can be enabled using software, compare events from other timer instances, zero or load events, or generic subscriber events. Some applications may require more than one counter block that can be simultaneously started across the same power domain (such as TIMA0 and TIMA1) or different power domains (such as TIMA0 and TIMG0). This configuration uses cross triggers from a main timer module as the input trigger condition for the secondary timers. The timer cross trigger is essentially the combined logic of the hardware and software conditions that control the EN bit in the TIMx.CTRCTL register. The cross triggers that are outputted from the main timer are connected to the external trigger input of other secondary timer modules. As shown in Figure 18-38, TIMGx is the main timer and TIMAx is the secondary timer that will be cross triggered in the configuration example. For power domains of timer instances, refer to the device-specific data sheet. Figure 18-38. Cross Trigger Connections for Main Timer (TIMGx) and Secondary Timer (TIMAx) in Power Domain 1 # 18.2.8 Low Power Operation For detailed information on the low power modes in terms of available clock source and behaviors, refer to Section 2.1.1. Timer modules in power domain PD0 can be active and configured to continue counting in all power modes except SHUTDOWN mode. See Section 2.1.1 for the available clock sources in each low-power mode. The user needs to configure the proper clock to source the timer in low-power mode. Timer modules in power domain PD1 can only be active in RUN and SLEEP modes. When the system goes to STOP or STANDBY mode, the timer modules will be forced to a disabled state and resume when the systems moves back to RUN or SLEEP modes. # 18.2.9 Interrupt and Event Support The TIMx module contains three event publishers and two event subscribers. - One event publisher (CPU\_INT) manages TIMx interrupt requests (IRQs) to the CPU subsystem through a static event route. - The second and third event (GEN\_EVENT0 and GEN\_EVENT1) are used to setup the generic event publishers and subscribers through Generic route. TIMx events are summarized in Table 18-16. Table 18-16. TIMx Events | Event | Type | Source | Destination | Route | Configuration | Functionality | |-----------------------------|------------|-------------------|-------------------|---------------|----------------------------------------|-------------------------------------------------------------| | CPU interrupt | Publisher | TIMx | CPU Subsystem | Static route | CPU_INT registers | Fixed interrupt route from TIMx to CPU | | Generic publisher event | Publisher | TIMx | Other peripherals | Generic route | GEN_EVENT0<br>and FPUB_0<br>registers | Configurable interrupt route from TIMx to other peripherals | | Generic publisher event | Publisher | TIMx | Other peripherals | Generic route | GEN_EVENT 1<br>and FPUB_1<br>registers | Configurable interrupt route from TIMx to other peripherals | | Generic<br>subscriber event | Subscriber | Other peripherals | TIMx | Generic route | FSUB_0 | Configurable interrupt route from other peripherals to TIMx | Table 18-16. TIMx Events (continued) | Event | Туре | Source | Destination | Route | Configuration | Functionality | |-----------------------------|------------|-------------------|-------------|---------------|---------------|-------------------------------------------------------------| | Generic<br>subscriber event | Subscriber | Other peripherals | TIMx | Generic route | FSUB_1 | Configurable interrupt route from other peripherals to TIMx | # 18.2.9.1 CPU Interrupt Event Publisher (CPU\_INT) The TIMx module provides 18 interrupt sources (depending on the specific TIMx module features) which can be configured to source a CPU interrupt event. Table 18-17 lists the CPU interrupt events from the TIMx in order of decreasing interrupt priority. Table 18-17. TIMx CPU Interrupt Event Conditions (CPU\_INT) | IIDX STAT | Name | Description | Timer Module | |-----------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------| | 0x01 | Z | Zero event interrupt. This interrupt is set when there is a zero event. | TIMx | | 0x02 | L | Load event interrupt. This interrupt is set when there is a load event. | TIMx | | 0x05 | CCD0 | Capture or compare 0 down event. This interrupt is set when there is a down compare match event at CC0. | TIMx | | 0x06 | CCD1 | Capture or compare 1 down event. This interrupt is set when there is a down compare match event at CC1. | TIMx | | 0x07 | CCD2 | Capture or compare 2 down event. This interrupt is set when there is a down compare match event at CC2. This interrupt is only available for TIMA0. | TIMx | | 0x08 | CCD3 | Capture or compare 3 down event. This interrupt is set when there is a down compare match event at CC3. This interrupt is only available for TIMA0. | TIMx | | 0x09 | CCU0 | Capture or compare 0 up event. This interrupt is set when there is a up compare match event at CC0. | TIMx | | 0x0A | CCU1 | Capture or compare 1 up event. This interrupt is set when there is a up compare match event at CC1. | TIMx | | 0x0B | CCU2 | Capture or compare 2 up event. This interrupt is set when there is a up compare match event at CC2. | TIMx | | 0x0C | CCU3 | Capture or compare 3 up event. This interrupt is set when there is a up compare match event at CC3. | TIMx | | 0x0D | CCD4 | Capture or compare 4 down event. This interrupt is set when there is a down compare match event at CC4. This interrupt is only available for TIMA modules. | TIMA | | 0x0E | CCD5 | Capture or compare 5 down event. This interrupt is set when there is a down compare match event at CC5. This interrupt is only available for TIMA modules. | TIMA | | 0x0F | CCU4 | Capture or compare 4 up event. This interrupt is set when there is a up compare match event at CC4. This interrupt is only available for TIMA modules. | TIMA | | 0x10 | CCU5 | Capture or compare 5 up event. This interrupt is set when there is a up compare match event at CC5. This interrupt is only available for TIMA modules. | TIMA | | 0x19 | F | Fault event interrupt. This interrupt is set when there is a fault condition event. See Section 18.2.6. This interrupt is only available for TIMA modules with fault handler features. | TIMA | | 0x1A | TOV | Trigger overflow interrupt. This interrupt is set if a trigger event is generated while the associated trigger channel is active. | TIMx | | 0x1B | REPC | Repeat counter zero interrupt. This bit controls the generation of an interrupt if the repeat counter value transitions from a non-zero value to zero. This interrupt is only available for TIMA modules with a repeat counter feature. | TIMA | | 0x1C | DC | Direction change interrupt, used in QEI mode. This interrupt is only available for TIMG modules with QEI features. | TIMG | | 0X1D | QEIERR | Direction change interrupt, used in QEI mode. This interrupt is only available for TIMG modules with QEI features. | TIMG | The CPU interrupt event configuration is managed with the CPU\_INT event management registers. See Section 6.2.5 for guidance on configuring the event registers for CPU interrupts. #### 18.2.9.2 Generic Event Publisher and Subscriber (GEN\_EVENT0 and GEN\_EVENT1) A generic route is a route in which the comparator peripheral publishing the event is configured to use one of several available generic route channels to publish its event to another entity (or entities, in the case of a splitter route), where an entity can be another peripheral, a generic DMA trigger event, or a generic CPU event. The GEN\_EVENT0 and GEN\_EVENT1 registers are used to select a peripheral condition (Table 18-18) to use for publishing or subscribing an event. FPUB\_0 and FPUB\_1 are the publisher port registers and are used to configure which generic route channel to use to broadcast the event. FSUB\_0 and FSUB\_1 are the subscriber port registers and are used to configure which generic route channel to use to subscribe the event. Other peripherals, the DMA, or the CPU can subscribe to this event by configuring its subscriber port to listen on the same generic route channel which the publishing peripheral is connected to. For example, through the use of a generic event channel, it is possible to directly start an ADC conversion from a TIMx event by connecting a TIMx FPUB\_x and ADC FSUB\_0 to the same generic event channel. Refer to Section 6.1.3.3 and Section 6.2.3 for how generic event route works. Table 18-18. TIMx Generic Event Conditions (GEN\_EVENT0 and GEN\_EVENT1) | IIDX STAT | Name | Description | Timer Module | | |-----------|-------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|--| | 0x01 | Z | Zero event interrupt. This interrupt is set when there is a zero event. | TIMx | | | 0x02 | L | Load event interrupt. This interrupt is set when there is a load event. | TIMx | | | 0x05 | CCD0 | Capture or compare 0 down event. This interrupt is set when there is a down compare match event at CC0. | TIMx | | | 0x06 | CCD1 | Capture or compare 1 down event. This interrupt is set when there is a down compare match event at CC1. | TIMx | | | 0x07 | CCD2 | Capture or compare 2 down event. This interrupt is set when there is a down compare match event at CC2. This interrupt is only available for TIMA0. | TIMx | | | 0x08 | CCD3 | Capture or compare 3 down event. This interrupt is set when there is a down compare match event at CC3. This interrupt is only available for TIMA0. | TIMx | | | 0x09 | CCU0 | Capture or compare 0 up event. This interrupt is set when there is a up compare match event at CC0. | TIMx | | | 0x0A | CCU1 | Capture or compare 1 up event. This interrupt is set when there is a up compare match event at CC1. | TIMx | | | 0x0B | CCU2 | Capture or compare 2 up event. This interrupt is set when there is a up compare match event at CC2. | TIMx | | | 0x0C | CCU3 | Capture or compare 3 up event. This interrupt is set when there is a up compare match event at CC3. | TIMx | | | 0x0D | CCD4 | Capture or compare 4 down event. This interrupt is set when there is a down compare match event at CC4. This interrupt is only available for TIMA modules. | TIMA | | | 0x0E | CCD5 | Capture or compare 5 down event. This interrupt is set when there is a down compare match event at CC5. This interrupt is only available for TIMA modules. | TIMA | | | 0x0F | CCU4 | Capture or compare 4 up event. This interrupt is set when there is a up compare match event at CC4. This interrupt is only available for TIMA modules. | TIMA | | | 0x10 | CCU5 | Capture or compare 5 up event. This interrupt is set when there is a up compare match event at CC5. This interrupt is only available for TIMA modules. | TIMA | | | 0x19 | Fault event interrupt. This interrupt is set when there is a fault condition event. | | | | | 0x1A | TOV | Trigger overflow interrupt. This interrupt is set if a trigger event is generated while the associated trigger channel is active. | TIMx | | | 0x1B | REPC | Repeat counter zero interrupt. This bit controls the generation of an interrupt if the repeat counter value transitions from a non-zero value to zero. This interrupt is only available for TIMA modules with a repeat counter feature. | TIMA | | | Table 18-18. TIMx Generic Event Conditions ( | GEN EVENTO and GEN | EVENT1) (continued) | |----------------------------------------------|--------------------|---------------------| | | | | | IIDX STAT | Name | Description | Timer Module | |-----------|--------|--------------------------------------------------------------------------------------------------------------------|--------------| | 0x1C | DC | Direction change interrupt, used in QEI mode. This interrupt is only available for TIMG modules with QEI features. | TIMG | | 0x1D | QEIERR | Direction change interrupt, used in QEI mode. This interrupt is only available for TIMG modules with QEI features. | TIMG | See Section 6.2.5 for guidance on configuring the event registers. #### 18.2.9.3 Generic Subscriber Event Example To use a comparator output event to generate a capture event in the TIMx module, configure each module accordingly. #### TIMx configuration: - 1. Configure the event subscriber port as a trigger source by configuring the TIMx.TSEL.ETSEL = 0x10 for FSUB port 0 or to 0x11 for FSUB port 1. Enable the input trigger function by setting the TIMx.TSEL.TE bit to 1. - 2. Set TIMx.IFCTL xy[0/1].ISEL bit to 3 to select the trigger as input source for the TIMx module. - 3. Use LCOND, ZCOND and CCOND bits in the TIMx.CCCTL\_xy[0/1] register to configure using a trigger to generate a load, zero, advance or capture event. - 4. Configure FSUB\_0 or FSUB\_1 register in the TIMx module to connect to event channel y. Channel y must not be in use by another peripheral. - 5. Configure and enable TIMx. #### Comparator configuration: - 1. Set COMPIFG bit in GEN\_EVENT0 IMASK register to mask the comparator output interrupt. See Section 10.2.10.2. - 2. Configure FPUB 1 register in comparator module to connect to event channel y. - 3. Configure and enable the comparator. #### 18.2.10 Debug Handler (TIMA only) In TIMA only, the timer output and counter behavior in CPU halt debug mode can also be configured by software using the PDBGCTL and CCACT xy[0/1] registers. # 18.3 Timers (TIMx) Registers Table 18-19 lists the memory-mapped registers for the Timers (TIMx) registers. All register offset addresses not listed in Table 18-19 should be considered as reserved locations and the register contents should not be modified. Table 18-19. TIMERS (TIMX) Registers | Officet | Аономуна | Table 18-19. TIMERS (TIM | <del>-</del> | Castion | | | | |---------|----------|----------------------------------------------|-------------------------------------|---------------|--|--|--| | | Acronym | Register Name | Group | Section<br>Go | | | | | 400h | FSUB_0 | | Subsciber Port 0 | | | | | | 404h | FSUB_1 | | Subscriber Port 1 | | | | | | 444h | FPUB_0 | Publisher Port 0 | | Go | | | | | 448h | FPUB_1 | Publisher Port 1 | | Go | | | | | 800h | PWREN | Power enable | | Go | | | | | 804h | RSTCTL | Reset Control | | Go | | | | | 814h | STAT | Status Register | | Go | | | | | 1000h | CLKDIV | Clock Divider | | Go | | | | | 1008h | CLKSEL | Clock Select for Ultra Low Power peripherals | | Go | | | | | 1018h | PDBGCTL | Peripheral Debug Control | | Go | | | | | 1020h | IIDX | Interrupt index | CPU_INT | Go | | | | | 1028h | IMASK | Interrupt mask | CPU_INT | Go | | | | | 1030h | RIS | Raw interrupt status | CPU_INT | Go | | | | | 1038h | MIS | Masked interrupt status | CPU_INT | Go | | | | | 1040h | ISET | Interrupt set | CPU_INT | Go | | | | | 1048h | ICLR | Interrupt clear | Interrupt clear CPU_INT | | | | | | 1050h | IIDX | Interrupt index | GEN_EVENT<br>0 | Go | | | | | 1058h | IMASK | Interrupt mask | GEN_EVENT<br>0 | Go | | | | | 1060h | RIS | Raw interrupt status | GEN_EVENT<br>0 | Go | | | | | 1068h | MIS | Masked interrupt status | GEN_EVENT<br>0 | Go | | | | | 1070h | ISET | Interrupt set | GEN_EVENT<br>0 | Go | | | | | 1078h | ICLR | Interrupt clear | GEN_EVENT<br>0 | Go | | | | | 1080h | IIDX | Interrupt index | GEN_EVENT<br>1 | Go | | | | | 1088h | IMASK | Interrupt mask | GEN_EVENT<br>1 | Go | | | | | 1090h | RIS | Raw interrupt status | GEN_EVENT<br>1 | Go | | | | | 1098h | MIS | Masked interrupt status | Masked interrupt status GEN_EVENT 1 | | | | | | 10A0h | ISET | Interrupt set | Interrupt set GEN_EVENT 1 | | | | | | 10A8h | ICLR | Interrupt clear | Interrupt clear GEN_EVENT Go | | | | | | 10E0h | EVT_MODE | Event Mode | | Go | | | | | 10FCh | DESC | Module Description | | Go | | | | | 1100h | CCPD | CCP Direction | | Go | | | | | 1104h | ODIS | Output Disable | | Go | | | | Table 18-19. TIMERS (TIMX) Registers (continued) | Offset | Acronym | Register Name | Group | Section | | | | |--------------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------|--------------------------------|---------|--|--|--| | 1108h | CCLKCTL | Counter Clock Control Register | Counter Clock Control Register | | | | | | 110Ch | CPS | Clock Prescale Register Go | | | | | | | 1110h | CPSV | Clock prescale count status register Go | | | | | | | 1114h | CTTRIGCTL | Timer Cross Trigger Control Register | | Go | | | | | 111Ch | CTTRIG | Timer Cross Trigger Register | | Go | | | | | 1120h | FSCTL | Fault Source Control | | Go | | | | | 1124h | GCTL | Global control register | | Go | | | | | 1800h | CTR | Counter Register | | Go | | | | | 1804h | CTRCTL | Counter Control Register | | Go | | | | | 1808h | LOAD | Load Register | | Go | | | | | 1810h +<br>formula | CC_01[y] | Capture or Compare Register 0/1 | | Go | | | | | 1818h +<br>formula | CC_23[y] | Capture or Compare Register 0/1 | | Go | | | | | 1820h +<br>formula | CC_45[y] | The CC_45 register are a registers which can be used as compare to the current CTR to create an events CC4U, CC4D, CC5U and CC5D. | | Go | | | | | 1830h +<br>formula | CCCTL_01[y] | Capture or Compare Control Registers | | Go | | | | | 1838h +<br>formula | CCCTL_23[y] | Capture or Compare Control Registers 0/1 | | Go | | | | | 1840h +<br>formula | CCCTL_45[y] | Capture or Compare Control Registers 2/3 | | Go | | | | | 1850h +<br>formula | OCTL_01[y] | CCP Output Control Registers 4/5 | | Go | | | | | 1858h +<br>formula | OCTL_23[y] | CCP Output Control Registers 0/1 | | Go | | | | | 1870h +<br>formula | CCACT_01[y] | Capture or Compare Action Registers 2/3 | | Go | | | | | 1878h +<br>formula | CCACT_23[y] | Capture or Compare Action Registers 0/1 | | Go | | | | | 1880h +<br>formula | IFCTL_01[y] | Input Filter Control Register 0/1 | | Go | | | | | 1888h +<br>formula | IFCTL_23[y] | Input Filter Control Register 2/3 | | Go | | | | | 18A0h | PL | Phase Load Register | | Go | | | | | 18A4h | DBCTL | Dead Band insertion control register | | Go | | | | | 18B0h | TSEL | Trigger Select Register | | Go | | | | | 18B4h | RC | Repeat counter Register | | Go | | | | | 18B8h | RCLD | Repeat counter load Register | | Go | | | | | 18BCh | QDIR | QEI Count Direction Register | | Go | | | | | 18D0h | FCTL | Fault Control Register | | Go | | | | | 18D4h | FIFCTL | Fault input Filter control register | | Go | | | | | | | | | | | | | Complex bit access types are encoded to fit into small table cells. Table 18-20 shows the codes that are used for access types in this section. ## Table 18-20. Timers (TIMx) Access Type Codes | Access Type | Code | Description | |-----------------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Read Type | | | | R | R | Read | | Write Type | · | · | | К | K | Write protected by a key | | W | W | Write | | WK | W<br>K | Write Write protected by a key | | Reset or Default Valu | ie | · | | -n | | Value after reset or the default value | | Register Array Varia | bles | · | | i,j,k,l,m,n | | When these variables are used in a register name, an offset, or an address, they refer to the value of a register array where the register is part of a group of repeating registers. The register groups form a hierarchical structure and the array is represented with a formula. | | У | | When this variable is used in a register name, an offset, or an address it refers to the value of a register array. | ## 18.3.1 FSUB\_0 (Offset = 400h) [Reset = 00000000h] FSUB\_0 is shown in Figure 18-39 and described in Table 18-21. Return to the Summary Table. Subscriber port ### Figure 18-39. FSUB\_0 Table 18-21. FSUB\_0 Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-4 | RESERVED | R/W | 0h | | | 3-0 | CHANID | R/W | | 0 = disconnected. 1-15 = connected to channelID = CHANID. 0h = A value of 0 specifies that the event is not connected Fh = Consult your device data sheet as the actual allowed maximum may be less than 15. | ## 18.3.2 FSUB\_1 (Offset = 404h) [Reset = 00000000h] FSUB\_1 is shown in Figure 18-40 and described in Table 18-22. Return to the Summary Table. Subscriber port ### Figure 18-40. FSUB\_1 ## Table 18-22. FSUB\_1 Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-4 | RESERVED | R/W | 0h | | | 3-0 | CHANID | R/W | | 0 = disconnected. 1-15 = connected to channelID = CHANID. 0h = A value of 0 specifies that the event is not connected Fh = Consult your device data sheet as the actual allowed maximum may be less than 15. | ## 18.3.3 FPUB\_0 (Offset = 444h) [Reset = 00000000h] FPUB\_0 is shown in Figure 18-41 and described in Table 18-23. Return to the Summary Table. Publisher port ### Figure 18-41. FPUB\_0 Table 18-23. FPUB\_0 Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-4 | RESERVED | R/W | 0h | | | 3-0 | CHANID | R/W | | 0 = disconnected. 1-15 = connected to channelID = CHANID. 0h = A value of 0 specifies that the event is not connected Fh = Consult your device data sheet as the actual allowed maximum may be less than 15. | ## 18.3.4 FPUB\_1 (Offset = 448h) [Reset = 00000000h] FPUB\_1 is shown in Figure 18-42 and described in Table 18-24. Return to the Summary Table. Publisher port ### Figure 18-42. FPUB\_1 ## Table 18-24. FPUB\_1 Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-4 | RESERVED | R/W | 0h | | | 3-0 | CHANID | R/W | | 0 = disconnected. 1-15 = connected to channelID = CHANID. 0h = A value of 0 specifies that the event is not connected Fh = Consult your device data sheet as the actual allowed maximum may be less than 15. | ## 18.3.5 PWREN (Offset = 800h) [Reset = 00000000h] PWREN is shown in Figure 18-43 and described in Table 18-25. Return to the Summary Table. Register to control the power state ### Figure 18-43. PWREN ### **Table 18-25. PWREN Field Descriptions** | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|----------------------------------------------------------------------------------------------------| | 31-24 | KEY | W | 0h | KEY to allow Power State Change<br>26h = KEY to allow write access to this register | | 23-1 | RESERVED | R/W | 0h | | | 0 | ENABLE | К | 0h | Enable the power KEY must be set to 26h to write to this bit. 0h = Disable Power 1h = Enable Power | ## 18.3.6 RSTCTL (Offset = 804h) [Reset = 00000000h] RSTCTL is shown in Figure 18-44 and described in Table 18-26. Return to the Summary Table. Register to control reset assertion and de-assertion ### Figure 18-44. RSTCTL ### Table 18-26. RSTCTL Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|--------------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------| | 31-24 | KEY | W | 0h | Unlock key B1h = KEY to allow write access to this register | | 23-2 | RESERVED | W | 0h | | | 1 | RESETSTKYCLR | WK | 0h | Clear the RESETSTKY bit in the STAT register KEY must be set to B1h to write to this bit. 0h = Writing 0 has no effect 1h = Clear reset sticky bit | | 0 | RESETASSERT | WK | 0h | Assert reset to the peripheral KEY must be set to B1h to write to this bit. Oh = Writing 0 has no effect 1h = Assert reset | ## 18.3.7 STAT (Offset = 814h) [Reset = 00000000h] STAT is shown in Figure 18-45 and described in Table 18-27. Return to the Summary Table. peripheral enable and reset status ### Figure 18-45. STAT ### **Table 18-27. STAT Field Descriptions** | Bit | Field | Туре | Reset | Description | |-------|-----------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-17 | RESERVED | R | 0h | | | 16 | RESETSTKY | R | 0h | This bit indicates, if the peripheral was reset, since this bit was cleared by RESETSTKYCLR in the RSTCTL register 0h = The peripheral has not been reset since this bit was last cleared by RESETSTKYCLR in the RSTCTL register 1h = The peripheral was reset since the last bit clear | | 15-0 | RESERVED | R | 0h | | ## 18.3.8 CLKDIV (Offset = 1000h) [Reset = 00000000h] CLKDIV is shown in Figure 18-46 and described in Table 18-28. Return to the Summary Table. This register is used to specify module-specific divide ratio of the functional clock ### Figure 18-46. CLKDIV ### Table 18-28. CLKDIV Field Descriptions | Bit | Field | Туре | Reset | Description | | | | |------|----------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | 31-3 | RESERVED | R/W | 0h | | | | | | 2-0 | RATIO | R/W | Oh | Selects divide ratio of module clock 0h = Do not divide clock source 1h = Divide clock source by 2 2h = Divide clock source by 3 3h = Divide clock source by 4 4h = Divide clock source by 5 5h = Divide clock source by 6 6h = Divide clock source by 7 7h = Divide clock source by 8 | | | | ## 18.3.9 CLKSEL (Offset = 1008h) [Reset = 00000000h] CLKSEL is shown in Figure 18-47 and described in Table 18-29. Return to the Summary Table. Clock Source Select Register ### Figure 18-47. CLKSEL ### Table 18-29. CLKSEL Field Descriptions | Bit | Field | Туре | Reset | Description | |------|------------|------|-------|----------------------------------------------------------------------------------------------------------------------------| | 31-4 | RESERVED | R/W | 0h | | | 3 | BUSCLK_SEL | R/W | Oh | Selects BUSCLK as clock source if enabled 0h = Does not select this clock as a source 1h = Select this clock as a source | | 2 | MFCLK_SEL | R/W | 0h | Selects MFCLK as clock source if enabled 0h = Does not select this clock as a source 1h = Select this clock as a source | | 1 | LFCLK_SEL | R/W | 0h | Selects LFCLK as clock source if enabled 0h = Does not select this clock as a source 1h = Select this clock as a source | | 0 | RESERVED | R/W | 0h | | ### 18.3.10 PDBGCTL (Offset = 1018h) [Reset = 00000003h] PDBGCTL is shown in Figure 18-48 and described in Table 18-30. Return to the Summary Table. This register can be used by the software developer to control the behavior of the peripheral relative to the 'Core Halted' input Figure 18-48. PDBGCTL ### Table 18-30. PDBGCTL Field Descriptions | Table to dot! BBCC121 loid BCCC1ptionic | | | | | | | | | | |-----------------------------------------|------|----------|-------------|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | | Bit | Field | Description | | | | | | | | | 31-2 | RESERVED | R/W | 0h | | | | | | | | 1 | SOFT | R/W | 1h | Soft halt boundary control. This function is only available, if FREE is set to 'STOP' Oh = The peripheral will halt immediately, even if the resultant state will result in corruption if the system is restarted 1h = The peripheral blocks the debug freeze until it has reached a boundary where it can resume without corruption | | | | | | | 0 | FREE | R/W | 1h | Free run control 0h = The peripheral freezes functionality while the Core Halted input is asserted and resumes when it is deasserted. 1h = The peripheral ignores the state of the Core Halted input | | | | | ### 18.3.11 IIDX (Offset = 1020h) [Reset = 00000000h] IIDX is shown in Figure 18-49 and described in Table 18-31. Return to the Summary Table. This register provides the highest priority enabled interrupt index. Value 0x00 means no event pending. Interrupt 1 is the highest priority, IIDX next highest, 4, 8, ... IIDX^31 is the least priority. That is, the least bit position that is set to 1 denotes the highest priority pending interrupt. The priority order is fixed. However, users can implement their own prioritization schemes using other registers that expose the full set of interrupts that have occurred. On each read, only one interrupt is indicated. On a read, the current interrupt (highest priority) is automatically cleared by the hardware and the corresponding interrupt flag in [RIS] and [MIS] are cleared as well. After a read from the CPU (not from the debug interface), the register is updated with the next highest priority interrupt, if none are pending, then it should display 0x0. #### Figure 18-49. IIDX #### Table 18-31. IIDX Field Descriptions | Field | Туре | Reset | Description | |----------|----------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | RESERVED | R | 0h | | | STAT | R | Oh | Interrupt index status 00h = No interrupt pending 01h = Interrupt Source: Zero event (Z) 02h = nterrupt Source: Load event (L) 05h = Interrupt Source: Capture or compare down event (CCD0) 06h = Interrupt Source: Capture or compare down event (CCD1) 07h = Interrupt Source: Capture or compare down event (CCD2) 08h = Interrupt Source: Capture or compare down event (CCD3) 09h = Interrupt Source: Capture or compare up event (CCU0) 0Ah = Interrupt Source: Capture or compare up event (CCU1) 0Bh = Interrupt Source: Capture or compare up event (CCU2) 0Ch = Interrupt Source: Capture or compare up event (CCU3) 0Dh = Interrupt Source: Compare down event (CCD4) 0Eh = Interrupt Source: Compare down event (CCU4) 10h = Interrupt Source: Compare down event (CCU4) 10h = Interrupt Source: Fault Event generated an interrupt. (F) 1Ah = Interrupt Source: Repeat Counter Zero (REPC) 1Ch = Interrupt Source: Direction Change (DC) 1Dh = Interrupt Source: QEI Incorrect state transition error (QEIERR) | | | RESERVED | RESERVED R | RESERVED R 0h | ### 18.3.12 IMASK (Offset = 1028h) [Reset = 00000000h] IMASK is shown in Figure 18-50 and described in Table 18-32. Return to the Summary Table. Interrupt Mask. If a bit is set, then corresponding interrupt is un-masked. Un-masking the interrupt causes the raw interrupt to be visible in IIDX, as well as MIS." Figure 18-50. IMASK | | | | 9 | •••• | | | | |--------|----------------|--------|--------|----------|--------|--------|--------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | RESERVED | | QEIERR | DC | REPC | TOV | F | | | R/W- | | R/W-0h | R/W-0h | R/W-0h | R/W-0h | R/W-0h | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | RESE | RVED | | | | | | | | R/ | W- | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | CCU5 | CCU4 | CCD5 | CCD4 | CCU3 | CCU2 | CCU1 | CCU0 | | R/W-0h | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | CCD3 | CCD3 CCD2 CCD1 | | CCD0 | RESERVED | | L | Z | | R/W-0h | R/W-0h | R/W-0h | R/W-0h | R/ | W- | R/W-0h | R/W-0h | ### **Table 18-32. IMASK Field Descriptions** | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|--------------------------------------------------------------------------------| | 31-29 | RESERVED | R/W | 0h | | | 28 | QEIERR | R/W | 0h | QEIERR Event mask 0h = Disable Event 1h = Enable Event | | 27 | DC | R/W | 0h | Direction Change Event mask 0h = Disable Event 1h = Enable Event | | 26 | REPC | R/W | 0h | Repeat Counter Zero Event mask 0h = Disable Event 1h = Enable Event | | 25 | TOV | R/W | 0h | Trigger Overflow Event mask 0h = Disable Event 1h = Enable Event | | 24 | F | R/W | 0h | Fault Event mask 0h = Disable Event 1h = Enable Event | | 23-16 | RESERVED | R/W | 0h | | | 15 | CCU5 | R/W | 0h | Compare UP event mask CCP5 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | 14 | CCU4 | R/W | 0h | Compare UP event mask CCP4 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | 13 | CCD5 | R/W | 0h | Compare DN event mask CCP5 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | 12 | CCD4 | R/W | 0h | Compare DN event mask CCP4 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | ### **Table 18-32. IMASK Field Descriptions (continued)** | Table 16-32. IMASK Fleid Descriptions (continued) | | | | | | | | | | |---------------------------------------------------|----------|------|-------|-------------------------------------------------------------------------------------------|--|--|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | | | 11 | CCU3 | R/W | 0h | Capture or Compare UP event mask CCP3 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | | | | | 10 | CCU2 | R/W | 0h | Capture or Compare UP event mask CCP2 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | | | | | 9 | CCU1 | R/W | 0h | Capture or Compare UP event mask CCP1 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | | | | | 8 | CCU0 | R/W | 0h | Capture or Compare UP event mask CCP0 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | | | | | 7 | CCD3 | R/W | 0h | Capture or Compare DN event mask CCP3 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | | | | | 6 | CCD2 | R/W | 0h | Capture or Compare DN event mask CCP2 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | | | | | 5 | CCD1 | R/W | 0h | Capture or Compare DN event mask CCP1 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | | | | | 4 | CCD0 | R/W | 0h | Capture or Compare DN event mask CCP0 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | | | | | 3-2 | RESERVED | R/W | 0h | | | | | | | | 1 | L | R/W | 0h | Load Event mask 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | | | | | 0 | Z | R/W | 0h | Zero Event mask 0h = Disable Event 1h = Enable Event | | | | | | ### 18.3.13 RIS (Offset = 1030h) [Reset = 00000000h] RIS is shown in Figure 18-51 and described in Table 18-33. Return to the Summary Table. Raw interrupt status. Reflects all pending interrupts, regardless of masking. The RIS register allows the user to implement a poll scheme. A flag set in this register can be cleared by writing 1 to the ICLR register bit even if the corresponding IMASK bit is not enabled. Figure 18-51. RIS | rigure 10-31. Ki3 | | | | | | | | | | |-------------------|----------|------|--------|----------|------|------|------|--|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | RESERVED | | QEIERR | DC | REPC | TOV | F | | | | | R-0h | | R-0h | R-0h | R-0h | R-0h | R-0h | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | | | RESE | RVED | | | | | | | | | | R- | 0h | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | CCU5 | CCU4 | CCD5 | CCD4 | CCU3 | CCU2 | CCU1 | CCU0 | | | | R-0h | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | CCD3 | CCD2 | CCD1 | CCD0 | RESERVED | | L | Z | | | | R-0h | R-0h | R-0h | R-0h | R- | 0h | R-0h | R-0h | | | ### Table 18-33. RIS Field Descriptions | Bit | Field | Туре | Reset | Description | | | |-------|----------|------|-------|-----------------------------------------------------------------------------------------------------------|--|--| | 31-29 | RESERVED | R | 0h | | | | | 28 | QEIERR | R | 0h | QEIERR, set on an incorrect state transition on the encoder interface. 0h = Event Cleared 1h = Event Set | | | | 27 | DC | R | Oh | Direction Change 0h = Event Cleared 1h = Event Set | | | | 26 | REPC | R | Oh | Repeat Counter Zero 0h = Event Cleared 1h = Event Set | | | | 25 | TOV | R | Oh | Trigger overflow 0h = Event Cleared 1h = Event Set | | | | 24 | F | R | Oh | Fault 0h = Event Cleared 1h = Event Set | | | | 23-16 | RESERVED | R | 0h | | | | | 15 | CCU5 | R | Oh | Compare up event generated an interrupt CCP5 0h = Event Cleared 1h = Event Set | | | | 14 | CCU4 | R | Oh | Compare up event generated an interrupt CCU4 0h = Event Cleared 1h = Event Set | | | | 13 | CCD5 | R | Oh | Compare down event generated an interrupt CCD5 Oh = Event Cleared 1h = Event Set | | | | 12 | CCD4 | R | Oh | Compare down event generated an interrupt CCD4 0h = Event Cleared 1h = Event Set | | | ## **Table 18-33. RIS Field Descriptions (continued)** | rable 10-33. No Field Descriptions (Continued) | | | | | | | | | | |------------------------------------------------|----------|------|-------|-----------------------------------------------------------------------------------------------|--|--|--|--|--| | Bit | Field | Type | Reset | Description | | | | | | | 11 | CCU3 | R | 0h | Capture or compare up event generated an interrupt CCP3 0h = Event Cleared 1h = Event Set | | | | | | | 10 | CCU2 | R | 0h | Capture or compare up event generated an interrupt CCP2 0h = Event Cleared 1h = Event Set | | | | | | | 9 | CCU1 | R | Oh | Capture or compare up event generated an interrupt CCP1 0h = Event Cleared 1h = Event Set | | | | | | | 8 | CCU0 | R | Oh | Capture or compare up event generated an interrupt CCP0 0h = Event Cleared 1h = Event Set | | | | | | | 7 | CCD3 | R | Oh | Capture or compare down event generated an interrupt CCP3 0h = Event Cleared 1h = Event Set | | | | | | | 6 | CCD2 | R | 0h | Capture or compare down event generated an interrupt CCP2 0h = Event Cleared 1h = Event Set | | | | | | | 5 | CCD1 | R | Oh | Capture or compare down event generated an interrupt CCP1 0h = Event Cleared 1h = Event Set | | | | | | | 4 | CCD0 | R | 0h | Capture or compare down event generated an interrupt CCP0 0h = Event Cleared 1h = Event Set | | | | | | | 3-2 | RESERVED | R | 0h | | | | | | | | 1 | L | R | 0h | Load event generated an interrupt. 0h = Event Cleared 1h = Event Set | | | | | | | 0 | Z | R | 0h | Zero event generated an interrupt. 0h = Event Cleared 1h = Event Set | | | | | | ## 18.3.14 MIS (Offset = 1038h) [Reset = 00000000h] MIS is shown in Figure 18-52 and described in Table 18-34. Return to the Summary Table. Masked interrupt status. This is an AND of the IMASK and RIS registers. ### Figure 18-52. MIS | | | | • | | | | | | | |------|----------|------|--------|----------|------|------|------|--|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | RESERVED | | QEIERR | DC | REPC | TOV | F | | | | | R-0h | | R-0h | R-0h | R-0h | R-0h | R-0h | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | | | RESE | RVED | | | | | | | | R-0h | | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | CCU5 | CCU4 | CCD5 | CCD4 | CCU3 | CCU2 | CCU1 | CCU0 | | | | R-0h | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | CCD3 | CCD2 | CCD1 | CCD0 | RESERVED | | L | Z | | | | R-0h | R-0h | R-0h | R-0h | R-0h | | R-0h | R-0h | | | ### Table 18-34. MIS Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|---------------------------------------------------------------------------------------------| | 31-29 | RESERVED | R | 0h | | | 28 | QEIERR | R | 0h | QEIERR 0h = Event Cleared 1h = Event Set | | 27 | DC | R | 0h | Direction Change 0h = Event Cleared 1h = Event Set | | 26 | REPC | R | 0h | Repeat Counter Zero 0h = Event Cleared 1h = Event Set | | 25 | TOV | R | 0h | Trigger overflow 0h = Event Cleared 1h = Event Set | | 24 | F | R | 0h | Fault 0h = Event Cleared 1h = Event Set | | 23-16 | RESERVED | R | 0h | | | 15 | CCU5 | R | 0h | Compare up event generated an interrupt CCP5 0h = Event Cleared 1h = Event Set | | 14 | CCU4 | R | 0h | Compare up event generated an interrupt CCP4 0h = Event Cleared 1h = Event Set | | 13 | CCD5 | R | 0h | Compare down event generated an interrupt CCP5 0h = Event Cleared 1h = Event Set | | 12 | CCD4 | R | 0h | Compare down event generated an interrupt CCP4 0h = Event Cleared 1h = Event Set | | 11 | CCU3 | R | 0h | Capture or compare up event generated an interrupt CCP3 0h = Event Cleared 1h = Event Set | ## Table 18-34. MIS Field Descriptions (continued) | Bit | Field | Туре | Reset | Description | |-----|----------|------|-------|---------------------------------------------------------------------------------------------| | 10 | CCU2 | R | 0h | Capture or compare up event generated an interrupt CCP2 0h = Event Cleared 1h = Event Set | | 9 | CCU1 | R | Oh | Capture or compare up event generated an interrupt CCP1 0h = Event Cleared 1h = Event Set | | 8 | CCU0 | R | Oh | Capture or compare up event generated an interrupt CCP0 0h = Event Cleared 1h = Event Set | | 7 | CCD3 | R | 0h | Capture or compare down event generated an interrupt CCP3 0h = Event Cleared 1h = Event Set | | 6 | CCD2 | R | Oh | Capture or compare down event generated an interrupt CCP2 0h = Event Cleared 1h = Event Set | | 5 | CCD1 | R | 0h | Capture or compare down event generated an interrupt CCP1 0h = Event Cleared 1h = Event Set | | 4 | CCD0 | R | 0h | Capture or compare down event generated an interrupt CCP0 0h = Event Cleared 1h = Event Set | | 3-2 | RESERVED | R | 0h | | | 1 | L | R | Oh | Load event generated an interrupt. 0h = Event Cleared 1h = Event Set | | 0 | Z | R | Oh | Zero event generated an interrupt. 0h = Event Cleared 1h = Event Set | ### 18.3.15 ISET (Offset = 1040h) [Reset = 00000000h] ISET is shown in Figure 18-53 and described in Table 18-35. Return to the Summary Table. Interrupt set. Allows interrupts to be set by software (useful in diagnostics and safety checks). Writing a 1 to a bit in ISET will set the event and therefore the related RIS bit also gets set. If the interrupt is enabled through the mask, then the corresponding MIS bit is also set. Figure 18-53. ISET | | | | i iguic io | , 00. IOL I | | | | | |------|----------|------|------------|-------------|------|------|------|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | RESERVED | | QEIERR | DC | REPC | TOV | F | | | | W-0h | | W-0h | W-0h | W-0h | W-0h | W-0h | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | | RESE | RVED | | | | | | | W-0h | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | CCU5 | CCU4 | CCD5 | CCD4 | CCU3 | CCU2 | CCU1 | CCU0 | | | W-0h | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | CCD3 | CCD2 | CCD1 | CCD0 | RESE | RVED | L | Z | | | W-0h | W-0h | W-0h | W-0h | W- | -0h | W-0h | W-0h | | #### Table 18-35. ISET Field Descriptions | | 14516 10 00:1021 | | | - 1010 = 0001 ption 0 | |-------|------------------|------|-------|----------------------------------------------------------------------------| | Bit | Field | Туре | Reset | Description | | 31-29 | RESERVED | W | 0h | | | 28 | QEIERR | W | 0h | QEIERR event SET 0h = Writing 0 has no effect. 1h = Event Set | | 27 | DC | W | 0h | Direction Change event SET 0h = Writing 0 has no effect. 1h = Event Set | | 26 | REPC | W | 0h | Repeat Counter Zero event SET 0h = Writing 0 has no effect. 1h = Event Set | | 25 | TOV | W | 0h | Trigger Overflow event SET 0h = Writing 0 has no effect. 1h = Event Set | | 24 | F | W | 0h | Fault event SET 0h = Writing 0 has no effect. 1h = Event Set | | 23-16 | RESERVED | W | 0h | | | 15 | CCU5 | W | 0h | Compare up event 5 SET 0h = Writing 0 has no effect. 1h = Event Set | | 14 | CCU4 | W | 0h | Compare up event 4 SET 0h = Writing 0 has no effect. 1h = Event Set | | 13 | CCD5 | W | 0h | Compare down event 5 SET 0h = Writing 0 has no effect. 1h = Event Set | | 12 | CCD4 | W | 0h | Compare down event 4 SET 0h = Writing 0 has no effect. 1h = Event Set | ## **Table 18-35. ISET Field Descriptions (continued)** | Bit | Field | Type | Reset | Description (continued) | |-----|----------|------|--------|------------------------------------------------------------------| | | | | 110000 | • | | 11 | CCU3 | W | 0h | Capture or compare up event SET 0h = Writing 0 has no effect. | | | | | | 1h = Event Set | | 10 | CCU2 | W | 0h | Capture or compare up event SET | | 10 | CC02 | •• | 011 | Oh = Writing 0 has no effect. | | | | | | 1h = Event Set | | 9 | CCU1 | W | 0h | Capture or compare up event SET | | | | | | 0h = Writing 0 has no effect. | | | | | | 1h = Event Set | | 8 | CCU0 | W | 0h | Capture or compare up event SET | | | | | | 0h = Writing 0 has no effect. 1h = Event Set | | | | | | | | 7 | CCD3 | W | 0h | Capture or compare down event SET 0h = Writing 0 has no effect. | | | | | | 1h = Event Set | | 6 | CCD2 | W | 0h | Capture or compare down event SET | | | COBE | ** | 011 | Oh = Writing O has no effect. | | | | | | 1h = Event Set | | 5 | CCD1 | W | 0h | Capture or compare down event SET | | | | | | 0h = Writing 0 has no effect. | | | | | | 1h = Event Set | | 4 | CCD0 | W | 0h | Capture or compare down event SET | | | | | | 0h = Writing 0 has no effect.<br>1h = Event Set | | 0.0 | DECED/ED | 107 | OI: | III - Event Get | | 3-2 | RESERVED | W | 0h | | | 1 | L | W | 0h | Load event SET | | | | | | 0h = Writing 0 has no effect. 1h = Event Set | | 0 | Z | W | 0h | Zero event SET | | | _ | vv | UII | 0h = Writing 0 has no effect. | | | | | | 1h = Event Set | | | | | | | ## 18.3.16 ICLR (Offset = 1048h) [Reset = 00000000h] ICLR is shown in Figure 18-54 and described in Table 18-36. Return to the Summary Table. Interrupt clear. Write a 1 to clear corresponding Interrupt. ## Figure 18-54. ICLR | | | | • | | | | | |------|----------|------|--------|------|------|------|------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | RESERVED | | QEIERR | DC | REPC | TOV | F | | | W-0h | | W-0h | W-0h | W-0h | W-0h | W-0h | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | RESE | RVED | | | | | | W-0h | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | CCU5 | CCU4 | CCD5 | CCD4 | CCU3 | CCU2 | CCU1 | CCU0 | | W-0h | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | CCD3 | CCD2 | CCD1 | CCD0 | RESE | RVED | L | Z | | W-0h | W-0h | W-0h | W-0h | W- | ·0h | W-0h | W-0h | ### Table 18-36. ICLR Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|---------------------------------------------------------------------|------------------------------------------------------------------------------------| | 31-29 | RESERVED | W | 0h | | | 28 | QEIERR | W | Oh | QEIERR event CLEAR 0h = Writing 0 has no effect. 1h = Event Clear | | 27 | DC | W | 0h | Direction Change event CLEAR 0h = Writing 0 has no effect. 1h = Event Clear | | 26 | REPC | W | 0h | Repeat Counter Zero event CLEAR 0h = Writing 0 has no effect. 1h = Event Clear | | 25 | TOV | W | Oh | Trigger Overflow event CLEAR 0h = Writing 0 has no effect. 1h = Event Clear | | 24 | F | W | 0h Fault event CLEAR 0h = Writing 0 has no effect. 1h = Event Clear | | | 23-16 | RESERVED | W | 0h | | | 15 | CCU5 | W | 0h | Compare up event 5 CLEAR 0h = Writing 0 has no effect. 1h = Event Clear | | 14 | CCU4 | W | Oh | Compare up event 4 CLEAR 0h = Writing 0 has no effect. 1h = Event Clear | | 13 | CCD5 | W | 0h | Compare down event 5 CLEAR 0h = Writing 0 has no effect. 1h = Event Clear | | 12 | CCD4 | W | Oh | Compare down event 4 CLEAR 0h = Writing 0 has no effect. 1h = Event Clear | | 11 | ССИЗ | W | 0h | Capture or compare up event CLEAR 0h = Writing 0 has no effect. 1h = Event Clear | ## Table 18-36. ICLR Field Descriptions (continued) | D:4 | First | | te 10-30. ICEN I leid Descriptions (Continued) | | | | |-----|----------|------|------------------------------------------------|--------------------------------------------------------------------------------------|--|--| | Bit | Field | Туре | Reset | Description | | | | 10 | CCU2 | W | Oh | Capture or compare up event CLEAR 0h = Writing 0 has no effect. 1h = Event Clear | | | | 9 | CCU1 | W | Oh | Capture or compare up event CLEAR 0h = Writing 0 has no effect. 1h = Event Clear | | | | 8 | CCU0 | W | 0h | Capture or compare up event CLEAR 0h = Writing 0 has no effect. 1h = Event Clear | | | | 7 | CCD3 | W | 0h | Capture or compare down event CLEAR 0h = Writing 0 has no effect. 1h = Event Clear | | | | 6 | CCD2 | W | 0h | Capture or compare down event CLEAR 0h = Writing 0 has no effect. 1h = Event Clear | | | | 5 | CCD1 | W | Oh | Capture or compare down event CLEAR 0h = Writing 0 has no effect. 1h = Event Clear | | | | 4 | CCD0 | W | Oh | Capture or compare down event CLEAR 0h = Writing 0 has no effect. 1h = Event Clear | | | | 3-2 | RESERVED | W | 0h | | | | | 1 | L | W | Oh | Load event CLEAR 0h = Writing 0 has no effect. 1h = Event Clear | | | | 0 | Z | W | Oh | Zero event CLEAR 0h = Writing 0 has no effect. 1h = Event Clear | | | ### 18.3.17 IIDX (Offset = 1050h) [Reset = 00000000h] IIDX is shown in Figure 18-55 and described in Table 18-37. Return to the Summary Table. This register provides the highest priority enabled interrupt index. Value 0x00 means no event pending. Interrupt 1 is the highest priority, IIDX next highest, 4, 8, ... IIDX^31 is the least priority. That is, the least bit position that is set to 1 denotes the highest priority pending interrupt. The priority order is fixed. However, users can implement their own prioritization schemes using other registers that expose the full set of interrupts that have occurred. On each read, only one interrupt is indicated. On a read, the current interrupt (highest priority) is automatically cleared by the hardware and the corresponding interrupt flag in [RIS] and [MIS] are cleared as well. After a read from the CPU (not from the debug interface), the register is updated with the next highest priority interrupt, if none are pending, then it should display 0x0. #### Figure 18-55. IIDX #### Table 18-37. IIDX Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-8 | RESERVED | R | 0h | | | 7-0 | STAT | R | Oh | Interrupt index status 00h = No interrupt pending 01h = Interrupt Source: Zero event (Z) 02h = nterrupt Source: Load event (L) 05h = Interrupt Source: Capture or compare down event (CCD0) 06h = Interrupt Source: Capture or compare down event (CCD1) 07h = Interrupt Source: Capture or compare down event (CCD2) 08h = Interrupt Source: Capture or compare down event (CCD3) 09h = Interrupt Source: Capture or compare up event (CCU0) 0Ah = Interrupt Source: Capture or compare up event (CCU1) 0Bh = Interrupt Source: Capture or compare up event (CCU2) 0Ch = Interrupt Source: Capture or compare up event (CCU3) 0Dh = Interrupt Source: Capture or compare up event (CCU3) 0Dh = Interrupt Source: Compare down event (CCD4) 0Eh = Interrupt Source: Compare down event (CCU4) 10h = Interrupt Source: Compare down event (CCU4) 10h = Interrupt Source: Fault Event generated an interrupt. (F) 1Ah = Interrupt Source: Repeat Counter Zero (REPC) 1Ch = Interrupt Source: Direction Change (DC) 1Dh = Interrupt Source: QEI Incorrect state transition error (QEIERR) | ### 18.3.18 IMASK (Offset = 1058h) [Reset = 00000000h] IMASK is shown in Figure 18-56 and described in Table 18-38. Return to the Summary Table. Interrupt Mask. If a bit is set, then corresponding interrupt is un-masked. Un-masking the interrupt causes the raw interrupt to be visible in IIDX, as well as MIS." Figure 18-56. IMASK | | | | i igaic io | OU. INIAUIX | | | | |--------|----------|--------|------------|-------------|--------|--------|--------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | RESERVED | | QEIERR | DC | REPC | TOV | F | | | R/W- | | R/W-0h | R/W-0h | R/W-0h | R/W-0h | R/W-0h | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | RESE | RVED | | | | | | R/W- | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | CCU5 | CCU4 | CCD5 | CCD4 | CCU3 | CCU2 | CCU1 | CCU0 | | R/W-0h | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | CCD3 | CCD2 | CCD1 | CCD0 | RESE | RVED | L | Z | | R/W-0h | R/W-0h | R/W-0h | R/W-0h | R/ | W- | R/W-0h | R/W-0h | #### **Table 18-38. IMASK Field Descriptions** | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|--------------------------------------------------------------------------------| | 31-29 | RESERVED | R/W | 0h | | | 28 | QEIERR | R/W | Oh | QEIERR Event mask 0h = Disable Event 1h = Enable Event | | 27 | DC | R/W | Oh | Direction Change Event mask 0h = Disable Event 1h = Enable Event | | 26 | REPC | R/W | Oh | Repeat Counter Zero Event mask 0h = Disable Event 1h = Enable Event | | 25 | TOV | R/W | 0h | Trigger Overflow Event mask 0h = Disable Event 1h = Enable Event | | 24 | F | R/W | 0h | Fault Event mask 0h = Disable Event 1h = Enable Event | | 23-16 | RESERVED | R/W | 0h | | | 15 | CCU5 | R/W | 0h | Compare UP event mask CCP5 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | 14 | CCU4 | R/W | 0h | Compare UP event mask CCP4 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | 13 | CCD5 | R/W | Oh | Compare DN event mask CCP5 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | 12 | CCD4 | R/W | 0h | Compare DN event mask CCP4 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | ### **Table 18-38. IMASK Field Descriptions (continued)** | | Table 18-38. IMASK Field Descriptions (continued) | | | | | | | |-----|---------------------------------------------------|------|-------|-------------------------------------------------------------------------------------------|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | 11 | CCU3 | R/W | 0h | Capture or Compare UP event mask CCP3 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | | | 10 | CCU2 | R/W | 0h | Capture or Compare UP event mask CCP2 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | | | 9 | CCU1 | R/W | 0h | Capture or Compare UP event mask CCP1 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | | | 8 | CCU0 | R/W | Oh | Capture or Compare UP event mask CCP0 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | | | 7 | CCD3 | R/W | 0h | Capture or Compare DN event mask CCP3 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | | | 6 | CCD2 | R/W | 0h | Capture or Compare DN event mask CCP2 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | | | 5 | CCD1 | R/W | 0h | Capture or Compare DN event mask CCP1 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | | | 4 | CCD0 | R/W | Oh | Capture or Compare DN event mask CCP0 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | | | 3-2 | RESERVED | R/W | 0h | | | | | | 1 | L | R/W | Oh | Load Event mask 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | | | 0 | Z | R/W | 0h | Zero Event mask 0h = Disable Event 1h = Enable Event | | | | ### 18.3.19 RIS (Offset = 1060h) [Reset = 00000000h] RIS is shown in Figure 18-57 and described in Table 18-39. Return to the Summary Table. Raw interrupt status. Reflects all pending interrupts, regardless of masking. The RIS register allows the user to implement a poll scheme. A flag set in this register can be cleared by writing 1 to the ICLR register bit even if the corresponding IMASK bit is not enabled. Figure 18-57. RIS | | | | 1 19410 1 | • • • • • • • • | | | | |----------|----------|------|-----------|-----------------|------|------|------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | RESERVED | | QEIERR | DC | REPC | TOV | F | | | R-0h | | R-0h | R-0h | R-0h | R-0h | R-0h | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | RESERVED | | | | | | | | | R-0h | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | CCU5 | CCU4 | CCD5 | CCD4 | CCU3 | CCU2 | CCU1 | CCU0 | | R-0h | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | CCD3 | CCD2 | CCD1 | CCD0 | RESERVED L | | L | Z | | R-0h | R-0h | R-0h | R-0h | R-0h | | R-0h | R-0h | #### Table 18-39. RIS Field Descriptions | Bit | Field | Туре | Reset | Description | | |-------|----------|------|-------|-----------------------------------------------------------------------------------------------------------|--| | 31-29 | RESERVED | R | 0h | | | | 28 | QEIERR | R | 0h | QEIERR, set on an incorrect state transition on the encoder interface. 0h = Event Cleared 1h = Event Set | | | 27 | DC | R | 0h | Direction Change 0h = Event Cleared 1h = Event Set | | | 26 | REPC | R | 0h | Repeat Counter Zero 0h = Event Cleared 1h = Event Set | | | 25 | TOV | R | 0h | Trigger overflow 0h = Event Cleared 1h = Event Set | | | 24 | F | R | 0h | Fault 0h = Event Cleared 1h = Event Set | | | 23-16 | RESERVED | R | 0h | | | | 15 | CCU5 | R | 0h | Compare up event generated an interrupt CCP5 0h = Event Cleared 1h = Event Set | | | 14 | CCU4 | R | 0h | Compare up event generated an interrupt CCU4 0h = Event Cleared 1h = Event Set | | | 13 | CCD5 | R | 0h | Compare down event generated an interrupt CCD5 0h = Event Cleared 1h = Event Set | | | 12 | CCD4 | R | 0h | Compare down event generated an interrupt CCD4 0h = Event Cleared 1h = Event Set | | ## Table 18-39. RIS Field Descriptions (continued) | Bit | Field | Туре | Reset | Description Description | |-----|----------|------|-------|---------------------------------------------------------------------------------------------| | 11 | CCU3 | R | Oh | Capture or compare up event generated an interrupt CCP3 0h = Event Cleared 1h = Event Set | | 10 | CCU2 | R | 0h | Capture or compare up event generated an interrupt CCP2 0h = Event Cleared 1h = Event Set | | 9 | CCU1 | R | Oh | Capture or compare up event generated an interrupt CCP1 0h = Event Cleared 1h = Event Set | | 8 | CCU0 | R | Oh | Capture or compare up event generated an interrupt CCP0 0h = Event Cleared 1h = Event Set | | 7 | CCD3 | R | Oh | Capture or compare down event generated an interrupt CCP3 0h = Event Cleared 1h = Event Set | | 6 | CCD2 | R | 0h | Capture or compare down event generated an interrupt CCP2 0h = Event Cleared 1h = Event Set | | 5 | CCD1 | R | 0h | Capture or compare down event generated an interrupt CCP1 0h = Event Cleared 1h = Event Set | | 4 | CCD0 | R | Oh | Capture or compare down event generated an interrupt CCP0 0h = Event Cleared 1h = Event Set | | 3-2 | RESERVED | R | 0h | | | 1 | L | R | Oh | Load event generated an interrupt. 0h = Event Cleared 1h = Event Set | | 0 | Z | R | 0h | Zero event generated an interrupt. 0h = Event Cleared 1h = Event Set | ### 18.3.20 MIS (Offset = 1068h) [Reset = 00000000h] MIS is shown in Figure 18-58 and described in Table 18-40. Return to the Summary Table. Masked interrupt status. This is an AND of the IMASK and RIS registers. ### Figure 18-58. MIS | | | | J | | | | | |----------|----------|------|------|------|------|------|------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | RESERVED | | | DC | REPC | TOV | F | | | R-0h | | R-0h | R-0h | R-0h | R-0h | R-0h | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | RESERVED | | | | | | | | | R-0h | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | CCU5 | CCU4 | CCD5 | CCD4 | CCU3 | CCU2 | CCU1 | CCU0 | | R-0h | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | CCD3 | CCD2 | CCD1 | CCD0 | RESE | RVED | L | Z | | R-0h | R-0h | R-0h | R-0h | R- | 0h | R-0h | R-0h | ### Table 18-40. MIS Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|-------------------------------------------------------------------------------------------| | 31-29 | RESERVED | R | 0h | | | 28 | QEIERR | R | 0h | QEIERR 0h = Event Cleared 1h = Event Set | | 27 | DC | R | 0h | Direction Change 0h = Event Cleared 1h = Event Set | | 26 | REPC | R | 0h | Repeat Counter Zero 0h = Event Cleared 1h = Event Set | | 25 | TOV | R | 0h | Trigger overflow 0h = Event Cleared 1h = Event Set | | 24 | F | R | 0h | Fault 0h = Event Cleared 1h = Event Set | | 23-16 | RESERVED | R | 0h | | | 15 | CCU5 | R | 0h | Compare up event generated an interrupt CCP5 0h = Event Cleared 1h = Event Set | | 14 | CCU4 | R | 0h | Compare up event generated an interrupt CCP4 0h = Event Cleared 1h = Event Set | | 13 | CCD5 | R | 0h | Compare down event generated an interrupt CCP5 0h = Event Cleared 1h = Event Set | | 12 | CCD4 | R | 0h | Compare down event generated an interrupt CCP4 0h = Event Cleared 1h = Event Set | | 11 | CCU3 | R | 0h | Capture or compare up event generated an interrupt CCP3 0h = Event Cleared 1h = Event Set | ## **Table 18-40. MIS Field Descriptions (continued)** | Bit | Field | Туре | Reset | Description | |-----|----------|------|-------|---------------------------------------------------------------------------------------------| | 10 | CCU2 | R | Oh | Capture or compare up event generated an interrupt CCP2 0h = Event Cleared 1h = Event Set | | 9 | CCU1 | R | 0h | Capture or compare up event generated an interrupt CCP1 0h = Event Cleared 1h = Event Set | | 8 | CCU0 | R | Oh | Capture or compare up event generated an interrupt CCP0 0h = Event Cleared 1h = Event Set | | 7 | CCD3 | R | 0h | Capture or compare down event generated an interrupt CCP3 0h = Event Cleared 1h = Event Set | | 6 | CCD2 | R | Oh | Capture or compare down event generated an interrupt CCP2 0h = Event Cleared 1h = Event Set | | 5 | CCD1 | R | 0h | Capture or compare down event generated an interrupt CCP1 0h = Event Cleared 1h = Event Set | | 4 | CCD0 | R | Oh | Capture or compare down event generated an interrupt CCP0 0h = Event Cleared 1h = Event Set | | 3-2 | RESERVED | R | 0h | | | 1 | L | R | Oh | Load event generated an interrupt. 0h = Event Cleared 1h = Event Set | | 0 | Z | R | Oh | Zero event generated an interrupt. 0h = Event Cleared 1h = Event Set | ### 18.3.21 ISET (Offset = 1070h) [Reset = 00000000h] ISET is shown in Figure 18-59 and described in Table 18-41. Return to the Summary Table. Interrupt set. Allows interrupts to be set by software (useful in diagnostics and safety checks). Writing a 1 to a bit in ISET will set the event and therefore the related RIS bit also gets set. If the interrupt is enabled through the mask, then the corresponding MIS bit is also set. Figure 18-59, ISET | | | | i igaic io | | | | | |----------|----------|------|------------|------|------|------|------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | RESERVED | | QEIERR | DC | REPC | TOV | F | | | W-0h | | W-0h | W-0h | W-0h | W-0h | W-0h | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | RESERVED | | | | | | | | | W-0h | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | CCU5 | CCU4 | CCD5 | CCD4 | CCU3 | CCU2 | CCU1 | CCU0 | | W-0h | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | CCD3 | CCD2 | CCD1 | CCD0 | RESE | RVED | L | Z | | W-0h | W-0h | W-0h | W-0h | W-0h | | W-0h | W-0h | #### Table 18-41. ISET Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|----------------------------------------------------------------------------| | 31-29 | RESERVED | W | 0h | | | 28 | QEIERR | W | Oh | QEIERR event SET 0h = Writing 0 has no effect. 1h = Event Set | | 27 | DC | W | Oh | Direction Change event SET 0h = Writing 0 has no effect. 1h = Event Set | | 26 | REPC | W | Oh | Repeat Counter Zero event SET 0h = Writing 0 has no effect. 1h = Event Set | | 25 | TOV | W | Oh | Trigger Overflow event SET 0h = Writing 0 has no effect. 1h = Event Set | | 24 | F | W | Oh | Fault event SET 0h = Writing 0 has no effect. 1h = Event Set | | 23-16 | RESERVED | W | 0h | | | 15 | CCU5 | W | Oh | Compare up event 5 SET 0h = Writing 0 has no effect. 1h = Event Set | | 14 | CCU4 | W | Oh | Compare up event 4 SET 0h = Writing 0 has no effect. 1h = Event Set | | 13 | CCD5 | W | Oh | Compare down event 5 SET 0h = Writing 0 has no effect. 1h = Event Set | | 12 | CCD4 | W | Oh | Compare down event 4 SET 0h = Writing 0 has no effect. 1h = Event Set | ## **Table 18-41. ISET Field Descriptions (continued)** | | I | | | u Descriptions (continueu) | |-----|----------|------|-------|----------------------------------------------------------------------------------| | Bit | Field | Туре | Reset | Description | | 11 | CCU3 | W | Oh | Capture or compare up event SET 0h = Writing 0 has no effect. 1h = Event Set | | 10 | CCU2 | W | 0h | Capture or compare up event SET 0h = Writing 0 has no effect. 1h = Event Set | | 9 | CCU1 | W | 0h | Capture or compare up event SET 0h = Writing 0 has no effect. 1h = Event Set | | 8 | CCU0 | W | 0h | Capture or compare up event SET 0h = Writing 0 has no effect. 1h = Event Set | | 7 | CCD3 | W | 0h | Capture or compare down event SET 0h = Writing 0 has no effect. 1h = Event Set | | 6 | CCD2 | W | 0h | Capture or compare down event SET 0h = Writing 0 has no effect. 1h = Event Set | | 5 | CCD1 | W | 0h | Capture or compare down event SET 0h = Writing 0 has no effect. 1h = Event Set | | 4 | CCD0 | W | 0h | Capture or compare down event SET 0h = Writing 0 has no effect. 1h = Event Set | | 3-2 | RESERVED | W | 0h | | | 1 | L | W | 0h | Load event SET 0h = Writing 0 has no effect. 1h = Event Set | | 0 | Z | W | 0h | Zero event SET 0h = Writing 0 has no effect. 1h = Event Set | ### 18.3.22 ICLR (Offset = 1078h) [Reset = 00000000h] ICLR is shown in Figure 18-60 and described in Table 18-42. Return to the Summary Table. Interrupt clear. Write a 1 to clear corresponding Interrupt. ## Figure 18-60. ICLR | 31 30 29 28 27 26 25 24 RESERVED W-0h | | | | J | | | | | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|----------|------|--------|------|------|------|------| | W-0h <th< th=""><th>31</th><th>30</th><th>29</th><th>28</th><th>27</th><th>26</th><th>25</th><th>24</th></th<> | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | 23 22 21 20 19 18 17 16 RESERVED W-0h W-0h 15 14 13 12 11 10 9 8 CCU5 CCU4 CCD5 CCD4 CCU3 CCU2 CCU1 CCU0 W-0h W-0h W-0h W-0h W-0h W-0h W-0h 7 6 5 4 3 2 1 0 | | RESERVED | | QEIERR | DC | REPC | TOV | F | | RESERVED W-0h 15 14 13 12 11 10 9 8 CCU5 CCU4 CCU5 CCU1 CCU0 W-0h W-0h W-0h W-0h W-0h W-0h W-0h 7 6 5 4 3 2 1 0 | | W-0h | | W-0h | W-0h | W-0h | W-0h | W-0h | | W-0h 15 14 13 12 11 10 9 8 CCU5 CCU4 CCD5 CCD4 CCU3 CCU2 CCU1 CCU0 W-0h W-0h W-0h W-0h W-0h W-0h W-0h 7 6 5 4 3 2 1 0 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | 15 14 13 12 11 10 9 8 CCU5 CCU4 CCD5 CCD4 CCU3 CCU2 CCU1 CCU0 W-0h W-0h W-0h W-0h W-0h W-0h W-0h W-0h 7 6 5 4 3 2 1 0 | RESERVED | | | | | | | | | CCU5 CCU4 CCD5 CCD4 CCU3 CCU2 CCU1 CCU0 W-0h W- | W-0h | | | | | | | | | W-0h <th< td=""><td>15</td><td>14</td><td>13</td><td>12</td><td>11</td><td>10</td><td>9</td><td>8</td></th<> | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | 7 6 5 4 3 2 1 0 | CCU5 | CCU4 | CCD5 | CCD4 | CCU3 | CCU2 | CCU1 | CCU0 | | | W-0h | CCD3 CCD2 CCD1 CCD0 RESERVED I 7 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | CODS CODS CODS RESERVED | CCD3 | CCD2 | CCD1 | CCD0 | RESE | RVED | L | Z | | W-0h W-0h W-0h W-0h W-0h W-0h | W-0h | W-0h | W-0h | W-0h | W- | ·0h | W-0h | W-0h | ### **Table 18-42. ICLR Field Descriptions** | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|------------------------------------------------------------------------------------| | 31-29 | RESERVED | W | 0h | | | 28 | QEIERR | W | 0h | QEIERR event CLEAR 0h = Writing 0 has no effect. 1h = Event Clear | | 27 | DC | W | 0h | Direction Change event CLEAR 0h = Writing 0 has no effect. 1h = Event Clear | | 26 | REPC | W | 0h | Repeat Counter Zero event CLEAR 0h = Writing 0 has no effect. 1h = Event Clear | | 25 | TOV | W | 0h | Trigger Overflow event CLEAR 0h = Writing 0 has no effect. 1h = Event Clear | | 24 | F | W | 0h | Fault event CLEAR 0h = Writing 0 has no effect. 1h = Event Clear | | 23-16 | RESERVED | W | 0h | | | 15 | CCU5 | W | 0h | Compare up event 5 CLEAR 0h = Writing 0 has no effect. 1h = Event Clear | | 14 | CCU4 | W | 0h | Compare up event 4 CLEAR 0h = Writing 0 has no effect. 1h = Event Clear | | 13 | CCD5 | W | 0h | Compare down event 5 CLEAR 0h = Writing 0 has no effect. 1h = Event Clear | | 12 | CCD4 | W | 0h | Compare down event 4 CLEAR 0h = Writing 0 has no effect. 1h = Event Clear | | 11 | CCU3 | W | 0h | Capture or compare up event CLEAR 0h = Writing 0 has no effect. 1h = Event Clear | # Table 18-42. ICLR Field Descriptions (continued) | | Table 16-42. ICER Fleid Descriptions (Continued) | | | | | | | | | |-----|--------------------------------------------------|------|-------|------------------------------------------------------------------------------------|--|--|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | | | 10 | CCU2 | W | 0h | Capture or compare up event CLEAR 0h = Writing 0 has no effect. 1h = Event Clear | | | | | | | 9 | CCU1 | W | 0h | Capture or compare up event CLEAR 0h = Writing 0 has no effect. 1h = Event Clear | | | | | | | 8 | CCU0 | W | 0h | Capture or compare up event CLEAR 0h = Writing 0 has no effect. 1h = Event Clear | | | | | | | 7 | CCD3 | W | 0h | Capture or compare down event CLEAR 0h = Writing 0 has no effect. 1h = Event Clear | | | | | | | 6 | CCD2 | W | 0h | Capture or compare down event CLEAR 0h = Writing 0 has no effect. 1h = Event Clear | | | | | | | 5 | CCD1 | W | 0h | Capture or compare down event CLEAR 0h = Writing 0 has no effect. 1h = Event Clear | | | | | | | 4 | CCD0 | W | 0h | Capture or compare down event CLEAR 0h = Writing 0 has no effect. 1h = Event Clear | | | | | | | 3-2 | RESERVED | W | 0h | | | | | | | | 1 | L | W | Oh | Load event CLEAR 0h = Writing 0 has no effect. 1h = Event Clear | | | | | | | 0 | Z | W | Oh | Zero event CLEAR 0h = Writing 0 has no effect. 1h = Event Clear | | | | | | ## 18.3.23 IIDX (Offset = 1080h) [Reset = 00000000h] IIDX is shown in Figure 18-61 and described in Table 18-43. Return to the Summary Table. This register provides the highest priority enabled interrupt index. Value 0x00 means no event pending. Interrupt 1 is the highest priority, IIDX next highest, 4, 8, ... IIDX^31 is the least priority. That is, the least bit position that is set to 1 denotes the highest priority pending interrupt. The priority order is fixed. However, users can implement their own prioritization schemes using other registers that expose the full set of interrupts that have occurred. On each read, only one interrupt is indicated. On a read, the current interrupt (highest priority) is automatically cleared by the hardware and the corresponding interrupt flag in [RIS] and [MIS] are cleared as well. After a read from the CPU (not from the debug interface), the register is updated with the next highest priority interrupt, if none are pending, then it should display 0x0. #### Figure 18-61. IIDX #### Table 18-43. IIDX Field Descriptions | Field | Туре | Reset | Description | |----------|----------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | RESERVED | R | 0h | | | STAT | R | Oh<br>Oh | Interrupt index status 00h = No interrupt pending 01h = Interrupt Source: Zero event (Z) 02h = nterrupt Source: Load event (L) 05h = Interrupt Source: Capture or compare down event (CCD0) 06h = Interrupt Source: Capture or compare down event (CCD1) 07h = Interrupt Source: Capture or compare down event (CCD2) 08h = Interrupt Source: Capture or compare down event (CCD3) 09h = Interrupt Source: Capture or compare up event (CCU0) 0Ah = Interrupt Source: Capture or compare up event (CCU1) 0Bh = Interrupt Source: Capture or compare up event (CCU2) 0Ch = Interrupt Source: Capture or compare up event (CCU3) 0Dh = Interrupt Source: Compare down event (CCD4) 0Eh = Interrupt Source: Compare down event (CCD4) 10h = Interrupt Source: Compare down event (CCU4) 10h = Interrupt Source: Fault Event generated an interrupt. (F) 1Ah = Interrupt Source: Repeat Counter Zero (REPC) 1Ch = Interrupt Source: Direction Change (DC) 1Dh = Interrupt Source: QEI Incorrect state transition error (QEIERR) | | | RESERVED | RESERVED R | RESERVED R 0h | ## 18.3.24 IMASK (Offset = 1088h) [Reset = 00000000h] IMASK is shown in Figure 18-62 and described in Table 18-44. Return to the Summary Table. Interrupt Mask. If a bit is set, then corresponding interrupt is un-masked. Un-masking the interrupt causes the raw interrupt to be visible in IIDX, as well as MIS." Figure 18-62, IMASK | | | | i iguic io- | UZ. IIVIAUN | | | | |--------|----------------|--------|-------------|-------------|--------|--------|--------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | RESERVED | | QEIERR | DC | REPC | TOV | F | | | R/W- | | R/W-0h | R/W-0h | R/W-0h | R/W-0h | R/W-0h | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | RESE | RVED | | | | | | | | R/ | W- | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | CCU5 | CCU4 | CCD5 | CCD4 | CCU3 | CCU2 | CCU1 | CCU0 | | R/W-0h | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | CCD3 | CCD3 CCD2 CCD1 | | | RESE | RVED | L | Z | | R/W-0h | R/W-0h | R/W-0h | R/W-0h | R/W- | | R/W-0h | R/W-0h | ## **Table 18-44. IMASK Field Descriptions** | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|--------------------------------------------------------------------------------| | 31-29 | RESERVED | R/W | 0h | | | 28 | QEIERR | R/W | 0h | QEIERR Event mask 0h = Disable Event 1h = Enable Event | | 27 | DC | R/W | 0h | Direction Change Event mask 0h = Disable Event 1h = Enable Event | | 26 | REPC | R/W | 0h | Repeat Counter Zero Event mask 0h = Disable Event 1h = Enable Event | | 25 | TOV | R/W | 0h | Trigger Overflow Event mask 0h = Disable Event 1h = Enable Event | | 24 | F | R/W | 0h | Fault Event mask 0h = Disable Event 1h = Enable Event | | 23-16 | RESERVED | R/W | 0h | | | 15 | CCU5 | R/W | 0h | Compare UP event mask CCP5 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | 14 | CCU4 | R/W | 0h | Compare UP event mask CCP4 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | 13 | CCD5 | R/W | 0h | Compare DN event mask CCP5 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | 12 | CCD4 | R/W | 0h | Compare DN event mask CCP4 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | ## Table 18-44. IMASK Field Descriptions (continued) | | Table 18-44. IMASK Field Descriptions (continued) | | | | | | | | | | |-----|---------------------------------------------------|------|-------|-------------------------------------------------------------------------------------------|--|--|--|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | | | | 11 | CCU3 | R/W | Oh | Capture or Compare UP event mask CCP3 Oh = Clear Interrupt Mask 1h = Set Interrupt Mask | | | | | | | | 10 | CCU2 | R/W | Oh | Capture or Compare UP event mask CCP2 Oh = Clear Interrupt Mask 1h = Set Interrupt Mask | | | | | | | | 9 | CCU1 | R/W | Oh | Capture or Compare UP event mask CCP1 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | | | | | | 8 | CCU0 | R/W | 0h | Capture or Compare UP event mask CCP0 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | | | | | | 7 | CCD3 | R/W | 0h | Capture or Compare DN event mask CCP3 Oh = Clear Interrupt Mask 1h = Set Interrupt Mask | | | | | | | | 6 | CCD2 | R/W | Oh | Capture or Compare DN event mask CCP2 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | | | | | | 5 | CCD1 | R/W | 0h | Capture or Compare DN event mask CCP1 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | | | | | | 4 | CCD0 | R/W | 0h | Capture or Compare DN event mask CCP0 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | | | | | | 3-2 | RESERVED | R/W | 0h | | | | | | | | | 1 | L | R/W | Oh | Load Event mask 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | | | | | | | | 0 | Z | R/W | 0h | Zero Event mask 0h = Disable Event 1h = Enable Event | | | | | | | ## 18.3.25 RIS (Offset = 1090h) [Reset = 00000000h] RIS is shown in Figure 18-63 and described in Table 18-45. Return to the Summary Table. Raw interrupt status. Reflects all pending interrupts, regardless of masking. The RIS register allows the user to implement a poll scheme. A flag set in this register can be cleared by writing 1 to the ICLR register bit even if the corresponding IMASK bit is not enabled. Figure 18-63. RIS | | | | i iguic i | | | | | |------|----------|-----------|-----------|---------------|------|------|------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | RESERVED | | QEIERR | DC | REPC | TOV | F | | | R-0h | | R-0h | R-0h | R-0h | R-0h | R-0h | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | RESE | RVED | | | | | | | | R- | 0h | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | CCU5 | CCU4 | CCD5 | CCD4 | CCU3 | CCU2 | CCU1 | CCU0 | | R-0h | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | CCD3 | CCD2 | CCD2 CCD1 | | CCD0 RESERVED | | L | Z | | R-0h | R-0h | R-0h | R-0h | R- | 0h | R-0h | R-0h | ## Table 18-45. RIS Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|-----------------------------------------------------------------------------------------------------------| | 31-29 | RESERVED | R | 0h | | | 28 | QEIERR | R | 0h | QEIERR, set on an incorrect state transition on the encoder interface. 0h = Event Cleared 1h = Event Set | | 27 | DC | R | Oh | Direction Change 0h = Event Cleared 1h = Event Set | | 26 | REPC | R | Oh | Repeat Counter Zero 0h = Event Cleared 1h = Event Set | | 25 | TOV | R | Oh | Trigger overflow 0h = Event Cleared 1h = Event Set | | 24 | F | R | Oh | Fault 0h = Event Cleared 1h = Event Set | | 23-16 | RESERVED | R | 0h | | | 15 | CCU5 | R | Oh | Compare up event generated an interrupt CCP5 0h = Event Cleared 1h = Event Set | | 14 | CCU4 | R | Oh | Compare up event generated an interrupt CCU4 0h = Event Cleared 1h = Event Set | | 13 | CCD5 | R | Oh | Compare down event generated an interrupt CCD5 0h = Event Cleared 1h = Event Set | | 12 | CCD4 | R | Oh | Compare down event generated an interrupt CCD4 0h = Event Cleared 1h = Event Set | # Table 18-45. RIS Field Descriptions (continued) | | Table 10-45. No Field Descriptions (continued) | | | | | | | | | |-----|------------------------------------------------|------|-------|---------------------------------------------------------------------------------------------|--|--|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | | | 11 | CCU3 | R | 0h | Capture or compare up event generated an interrupt CCP3 0h = Event Cleared 1h = Event Set | | | | | | | 10 | CCU2 | R | 0h | Capture or compare up event generated an interrupt CCP2 0h = Event Cleared 1h = Event Set | | | | | | | 9 | CCU1 | R | 0h | Capture or compare up event generated an interrupt CCP1 0h = Event Cleared 1h = Event Set | | | | | | | 8 | CCU0 | R | 0h | Capture or compare up event generated an interrupt CCP0 0h = Event Cleared 1h = Event Set | | | | | | | 7 | CCD3 | R | 0h | Capture or compare down event generated an interrupt CCP3 0h = Event Cleared 1h = Event Set | | | | | | | 6 | CCD2 | R | 0h | Capture or compare down event generated an interrupt CCP2 0h = Event Cleared 1h = Event Set | | | | | | | 5 | CCD1 | R | 0h | Capture or compare down event generated an interrupt CCP1 0h = Event Cleared 1h = Event Set | | | | | | | 4 | CCD0 | R | 0h | Capture or compare down event generated an interrupt CCP0 0h = Event Cleared 1h = Event Set | | | | | | | 3-2 | RESERVED | R | 0h | | | | | | | | 1 | L | R | Oh | Load event generated an interrupt. 0h = Event Cleared 1h = Event Set | | | | | | | 0 | Z | R | 0h | Zero event generated an interrupt. 0h = Event Cleared 1h = Event Set | | | | | | # 18.3.26 MIS (Offset = 1098h) [Reset = 00000000h] MIS is shown in Figure 18-64 and described in Table 18-46. Return to the Summary Table. Masked interrupt status. This is an AND of the IMASK and RIS registers. ## Figure 18-64. MIS | <b>3</b> | | | | | | | | | | |----------|----------------|------|--------|------|------|------|------|--|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | RESERVED | | QEIERR | DC | REPC | TOV | F | | | | | R-0h | | | R-0h | R-0h | R-0h | R-0h | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | | | RESE | RVED | | | | | | | | | | R- | 0h | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | CCU5 | CCU4 | CCD5 | CCD4 | CCU3 | CCU2 | CCU1 | CCU0 | | | | R-0h | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | CCD3 | CCD3 CCD2 CCD1 | | | RESE | RVED | L | Z | | | | R-0h | R-0h | R-0h | R-0h | R- | 0h | R-0h | R-0h | | | ## **Table 18-46. MIS Field Descriptions** | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|---------------------------------------------------------------------------------------------| | 31-29 | RESERVED | R | 0h | | | 28 | QEIERR | R | Oh | QEIERR 0h = Event Cleared 1h = Event Set | | 27 | DC | R | 0h | Direction Change 0h = Event Cleared 1h = Event Set | | 26 | REPC | R | 0h | Repeat Counter Zero 0h = Event Cleared 1h = Event Set | | 25 | TOV | R | 0h | Trigger overflow 0h = Event Cleared 1h = Event Set | | 24 | F | R | 0h | Fault 0h = Event Cleared 1h = Event Set | | 23-16 | RESERVED | R | 0h | | | 15 | CCU5 | R | 0h | Compare up event generated an interrupt CCP5 0h = Event Cleared 1h = Event Set | | 14 | CCU4 | R | 0h | Compare up event generated an interrupt CCP4 0h = Event Cleared 1h = Event Set | | 13 | CCD5 | R | 0h | Compare down event generated an interrupt CCP5 0h = Event Cleared 1h = Event Set | | 12 | CCD4 | R | 0h | Compare down event generated an interrupt CCP4 0h = Event Cleared 1h = Event Set | | 11 | CCU3 | R | 0h | Capture or compare up event generated an interrupt CCP3 0h = Event Cleared 1h = Event Set | # Table 18-46. MIS Field Descriptions (continued) | Table 10-40. Wild Fleta Descriptions (continued) | | | | | | | | | |--------------------------------------------------|----------|------|-------|-----------------------------------------------------------------------------------------------|--|--|--|--| | Bit | Field | Type | Reset | Description | | | | | | 10 | CCU2 | R | Oh | Capture or compare up event generated an interrupt CCP2 0h = Event Cleared 1h = Event Set | | | | | | 9 | CCU1 | R | Oh | Capture or compare up event generated an interrupt CCP1 0h = Event Cleared 1h = Event Set | | | | | | 8 | CCU0 | R | Oh | Capture or compare up event generated an interrupt CCP0 0h = Event Cleared 1h = Event Set | | | | | | 7 | CCD3 | R | 0h | Capture or compare down event generated an interrupt CCP3 0h = Event Cleared 1h = Event Set | | | | | | 6 | CCD2 | R | 0h | Capture or compare down event generated an interrupt CCP2 0h = Event Cleared 1h = Event Set | | | | | | 5 | CCD1 | R | Oh | Capture or compare down event generated an interrupt CCP1 0h = Event Cleared 1h = Event Set | | | | | | 4 | CCD0 | R | 0h | Capture or compare down event generated an interrupt CCP0 0h = Event Cleared 1h = Event Set | | | | | | 3-2 | RESERVED | R | 0h | | | | | | | 1 | L | R | Oh | Load event generated an interrupt. 0h = Event Cleared 1h = Event Set | | | | | | 0 | Z | R | Oh | Zero event generated an interrupt. 0h = Event Cleared 1h = Event Set | | | | | ## 18.3.27 ISET (Offset = 10A0h) [Reset = 00000000h] ISET is shown in Figure 18-65 and described in Table 18-47. Return to the Summary Table. Interrupt set. Allows interrupts to be set by software (useful in diagnostics and safety checks). Writing a 1 to a bit in ISET will set the event and therefore the related RIS bit also gets set. If the interrupt is enabled through the mask, then the corresponding MIS bit is also set. Figure 18-65. ISET | | | | i igaic io | | | | | |------|----------|------|------------|---------------|------|------|------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | RESERVED | | QEIERR | DC | REPC | TOV | F | | | W-0h | | W-0h | W-0h | W-0h | W-0h | W-0h | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | RESE | RVED | | | | | | | | W- | ·0h | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | CCU5 | CCU4 | CCD5 | CCD4 | CCU3 | CCU2 | CCU1 | CCU0 | | W-0h | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | CCD3 | CCD2 | CCD1 | CCD0 | CCD0 RESERVED | | L | Z | | W-0h | W-0h | W-0h | W-0h | W- | ·0h | W-0h | W-0h | ### Table 18-47. ISET Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|----------------------------------------------------------------------------| | 31-29 | RESERVED | W | 0h | | | 28 | QEIERR | W | Oh | QEIERR event SET 0h = Writing 0 has no effect. 1h = Event Set | | 27 | DC | W | 0h | Direction Change event SET 0h = Writing 0 has no effect. 1h = Event Set | | 26 | REPC | W | 0h | Repeat Counter Zero event SET 0h = Writing 0 has no effect. 1h = Event Set | | 25 | TOV | W | 0h | Trigger Overflow event SET 0h = Writing 0 has no effect. 1h = Event Set | | 24 | F | W | 0h | Fault event SET 0h = Writing 0 has no effect. 1h = Event Set | | 23-16 | RESERVED | W | 0h | | | 15 | CCU5 | W | 0h | Compare up event 5 SET 0h = Writing 0 has no effect. 1h = Event Set | | 14 | CCU4 | W | 0h | Compare up event 4 SET 0h = Writing 0 has no effect. 1h = Event Set | | 13 | CCD5 | W | 0h | Compare down event 5 SET 0h = Writing 0 has no effect. 1h = Event Set | | 12 | CCD4 | W | 0h | Compare down event 4 SET 0h = Writing 0 has no effect. 1h = Event Set | ## **Table 18-47. ISET Field Descriptions (continued)** | | Table 16-47. ISE1 Field Descriptions (continued) | | | | | | | | | | |-----|--------------------------------------------------|------|-------|----------------------------------------------------------------------------------|--|--|--|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | | | | 11 | CCU3 | W | 0h | Capture or compare up event SET 0h = Writing 0 has no effect. 1h = Event Set | | | | | | | | 10 | CCU2 | W | 0h | Capture or compare up event SET 0h = Writing 0 has no effect. 1h = Event Set | | | | | | | | 9 | CCU1 | W | 0h | Capture or compare up event SET 0h = Writing 0 has no effect. 1h = Event Set | | | | | | | | 8 | CCU0 | W | 0h | Capture or compare up event SET 0h = Writing 0 has no effect. 1h = Event Set | | | | | | | | 7 | CCD3 | W | 0h | Capture or compare down event SET 0h = Writing 0 has no effect. 1h = Event Set | | | | | | | | 6 | CCD2 | W | 0h | Capture or compare down event SET 0h = Writing 0 has no effect. 1h = Event Set | | | | | | | | 5 | CCD1 | W | 0h | Capture or compare down event SET 0h = Writing 0 has no effect. 1h = Event Set | | | | | | | | 4 | CCD0 | W | 0h | Capture or compare down event SET 0h = Writing 0 has no effect. 1h = Event Set | | | | | | | | 3-2 | RESERVED | W | 0h | | | | | | | | | 1 | L | W | 0h | Load event SET 0h = Writing 0 has no effect. 1h = Event Set | | | | | | | | 0 | Z | W | 0h | Zero event SET 0h = Writing 0 has no effect. 1h = Event Set | | | | | | | ## 18.3.28 ICLR (Offset = 10A8h) [Reset = 00000000h] ICLR is shown in Figure 18-66 and described in Table 18-48. Return to the Summary Table. Interrupt clear. Write a 1 to clear corresponding Interrupt. # Figure 18-66. ICLR | | | | • | | | | | | |------|----------|------|--------|------|------|------|------|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | RESERVED | | QEIERR | DC | REPC | TOV | F | | | | W-0h | | W-0h | W-0h | W-0h | W-0h | W-0h | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | RESERVED | | | | | | | | | W-0h | | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | CCU5 | CCU4 | CCD5 | CCD4 | CCU3 | CCU2 | CCU1 | CCU0 | | | W-0h | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | CCD3 | CCD2 | CCD1 | CCD0 | RESE | RVED | L | Z | | | W-0h | W-0h | W-0h | W-0h | W- | 0h | W-0h | W-0h | | ## Table 18-48. ICLR Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|----------------------------------------------------------------------------------| | 31-29 | RESERVED | W | 0h | | | 28 | QEIERR | W | 0h | QEIERR event CLEAR 0h = Writing 0 has no effect. 1h = Event Clear | | 27 | DC | W | 0h | Direction Change event CLEAR 0h = Writing 0 has no effect. 1h = Event Clear | | 26 | REPC | W | 0h | Repeat Counter Zero event CLEAR 0h = Writing 0 has no effect. 1h = Event Clear | | 25 | TOV | W | 0h | Trigger Overflow event CLEAR 0h = Writing 0 has no effect. 1h = Event Clear | | 24 | F | W | 0h | Fault event CLEAR 0h = Writing 0 has no effect. 1h = Event Clear | | 23-16 | RESERVED | W | 0h | | | 15 | CCU5 | W | 0h | Compare up event 5 CLEAR 0h = Writing 0 has no effect. 1h = Event Clear | | 14 | CCU4 | W | 0h | Compare up event 4 CLEAR 0h = Writing 0 has no effect. 1h = Event Clear | | 13 | CCD5 | W | 0h | Compare down event 5 CLEAR 0h = Writing 0 has no effect. 1h = Event Clear | | 12 | CCD4 | W | 0h | Compare down event 4 CLEAR 0h = Writing 0 has no effect. 1h = Event Clear | | 11 | CCU3 | W | 0h | Capture or compare up event CLEAR 0h = Writing 0 has no effect. 1h = Event Clear | # Table 18-48. ICLR Field Descriptions (continued) | D:4 | Fi. Li | | | Beautities (continued) | |-----|----------|------|-------|--------------------------------------------------------------------------------------| | Bit | Field | Туре | Reset | Description | | 10 | CCU2 | W | Oh | Capture or compare up event CLEAR 0h = Writing 0 has no effect. 1h = Event Clear | | 9 | CCU1 | W | 0h | Capture or compare up event CLEAR 0h = Writing 0 has no effect. 1h = Event Clear | | 8 | CCU0 | W | 0h | Capture or compare up event CLEAR 0h = Writing 0 has no effect. 1h = Event Clear | | 7 | CCD3 | W | 0h | Capture or compare down event CLEAR 0h = Writing 0 has no effect. 1h = Event Clear | | 6 | CCD2 | W | Oh | Capture or compare down event CLEAR 0h = Writing 0 has no effect. 1h = Event Clear | | 5 | CCD1 | W | Oh | Capture or compare down event CLEAR 0h = Writing 0 has no effect. 1h = Event Clear | | 4 | CCD0 | W | 0h | Capture or compare down event CLEAR 0h = Writing 0 has no effect. 1h = Event Clear | | 3-2 | RESERVED | W | 0h | | | 1 | L | W | Oh | Load event CLEAR 0h = Writing 0 has no effect. 1h = Event Clear | | 0 | Z | W | Oh | Zero event CLEAR 0h = Writing 0 has no effect. 1h = Event Clear | # 18.3.29 EVT\_MODE (Offset = 10E0h) [Reset = 00000029h] EVT\_MODE is shown in Figure 18-67 and described in Table 18-49. Return to the Summary Table. Event mode register. It is used to select whether each line is disabled, in software mode (software clears the RIS) or in hardware mode (hardware clears the RIS) Figure 18-67. EVT\_MODE ## Table 18-49. EVT MODE Field Descriptions | Tuble 10 40. EVI_INOBE I leia besoriptions | | | | | | | | |--------------------------------------------|----------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | 31-6 | RESERVED | R/W | 0h | | | | | | 5-4 | EVT2_CFG | R | 2h | Event line mode select for event corresponding to GEN_EVENT1 0h = The interrupt or event line is disabled. 1h = The interrupt or event line is in software mode. Software must clear the RIS. 2h = The interrupt or event line is in hardware mode. The hardware (another module) clears automatically the associated RIS flag. | | | | | 3-2 | EVT1_CFG | R | 2h | Event line mode select for event corresponding to GEN_EVENTO 0h = The interrupt or event line is disabled. 1h = The interrupt or event line is in software mode. Software must clear the RIS. 2h = The interrupt or event line is in hardware mode. The hardware (another module) clears automatically the associated RIS flag. | | | | | 1-0 | EVT0_CFG | R | 1h | Event line mode select for event corresponding to CPU_INT 0h = The interrupt or event line is disabled. 1h = The interrupt or event line is in software mode. Software must clear the RIS. 2h = The interrupt or event line is in hardware mode. The hardware (another module) clears automatically the associated RIS flag. | | | | # 18.3.30 DESC (Offset = 10FCh) [Reset = 11110000h] DESC is shown in Figure 18-68 and described in Table 18-50. Return to the Summary Table. This register identifies the peripheral and its exact version. ## Figure 18-68. DESC ## **Table 18-50. DESC Field Descriptions** | Bit | Field | Туре | Reset | Description | |-------|------------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | ы | rieiu | Type | Reset | Description | | 31-16 | MODULEID | R | 1111h | Module identification contains a unique peripheral identification number. The assignments are maintained in a central database for all of the platform modules to ensure uniqueness. 0h = Smallest value FFFFh = Highest possible value | | 15-12 | FEATUREVER | R | 0h | Feature Set for the module *instance* 0h = Smallest value Fh = Highest possible value | | 11-8 | INSTNUM | R | 0h | Instance Number within the device. This will be a parameter to the RTL for modules that can have multiple instances 0h = Smallest value Fh = Highest possible value | | 7-4 | MAJREV | R | 0h | Major rev of the IP 0h = Smallest value Fh = Highest possible value | | 3-0 | MINREV | R | Oh | Minor rev of the IP 0h = Smallest value Fh = Highest possible value | # 18.3.31 CCPD (Offset = 1100h) [Reset = 00000000h] CCPD is shown in Figure 18-69 and described in Table 18-51. Return to the Summary Table. CCP Direction. Controls whether CCP is used as an input or an output. ## Figure 18-69. CCPD ## **Table 18-51. CCPD Field Descriptions** | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|---------------------------------------| | 31-4 | RESERVED | R/W | 0h | | | 3 | C0CCP3 | R/W | 0h | CCP3 direction 0h = Input 1h = Output | | 2 | C0CCP2 | R/W | 0h | CCP2 direction 0h = input 1h = Output | | 1 | C0CCP1 | R/W | Oh | CCP1 direction 0h = Input 1h = Output | | 0 | C0CCP0 | R/W | 0h | CCP0 direction 0h = Input 1h = Output | ## 18.3.32 ODIS (Offset = 1104h) [Reset = 00000000h] ODIS is shown in Figure 18-70 and described in Table 18-52. Return to the Summary Table. The ODIS register output is inverted and then ANDed with the output signal selected by the OCTL register CCPO field (before conditional inversion) to allow software the ability to hold the CCP output low during configuration or shutdown. Figure 18-70. ODIS #### Table 18-52. ODIS Field Descriptions | | 14510 10 021 0510 1 1014 500011ptionio | | | | | | | | |------|----------------------------------------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | | 31-4 | RESERVED | R/W | 0h | | | | | | | 3 | C0CCP3 | R/W | 0h | Counter CCP3 Disable Mask Defines whether CCP3 of Counter n is forced low or not 0h = Output function as selected by the OCTL register CCPO field are provided to output inversion block. 1h = CCP output is forced low. | | | | | | 2 | C0CCP2 | R/W | 0h | Counter CCP2 Disable Mask Defines whether CCP2 of Counter n is forced low or not 0h = Output function as selected by the OCTL register CCPO field are provided to output inversion block. 1h = CCP output is forced low. | | | | | | 1 | C0CCP1 | R/W | 0h | Counter CCP1 Disable Mask Defines whether CCP0 of Counter n is forced low or not 0h = Output function as selected by the OCTL register CCPO field are provided to output inversion block. 1h = CCP output is forced low. | | | | | | 0 | C0CCP0 | R/W | 0h | Counter CCP0 Disable Mask Defines whether CCP0 of Counter n is forced low or not 0h = Output function as selected by the OCTL register CCPO field are provided to output inversion block. 1h = CCP output is forced low. | | | | | ## 18.3.33 CCLKCTL (Offset = 1108h) [Reset = 00000000h] CCLKCTL is shown in Figure 18-71 and described in Table 18-53. Return to the Summary Table. The CCLKCTL register provides a SW mechanism for gating the TIMER clock if the module is expected not to be used but the power domain is alive. This effectively puts the IP in an IDLE state Figure 18-71. CCLKCTL ## Table 18-53. CCLKCTL Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-1 | RESERVED | R/W | 0h | | | 0 | CLKEN | R/W | 0h | Clock Enable Disables the clock gating to the module. SW has to explicitly program the value to 0 to gate the clock. 0h = Clock is disabled. 1h = Clock is enabled | # 18.3.34 CPS (Offset = 110Ch) [Reset = 00000000h] CPS is shown in Figure 18-72 and described in Table 18-54. Return to the Summary Table. The CPS register provides the value for the clock pre-scaler. ### Figure 18-72. CPS ## Table 18-54, CPS Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-8 | RESERVED | R/W | 0h | | | 7-0 | PCNT | R/W | Oh | Pre-Scale Count This field specifies the pre-scale count value. The selected TIMCLK source is divided by a value of (PCNT+1). A PCNT value of 0 divides TIMCLK by 1, effectively bypassing the divider. A PCNT value of greater than 0 divides the TIMCLK source generating a slower clock 0h = Minimum value FFh = Maximum Value | ## 18.3.35 CPSV (Offset = 1110h) [Reset = 00000000h] CPSV is shown in Figure 18-73 and described in Table 18-55. Return to the Summary Table. The CPSV register provides the ability to read the current clock prescale count value. ## Figure 18-73. CPSV ## Table 18-55. CPSV Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|---------------------------------------------------------------------| | 31-8 | RESERVED | R | 0h | | | 7-0 | CPSVAL | R | | Current Prescale Count Value 0h = Minimum value FFh = Maximum Value | ## 18.3.36 CTTRIGCTL (Offset = 1114h) [Reset = 00000000h] CTTRIGCTL is shown in Figure 18-74 and described in Table 18-56. Return to the Summary Table. Cross Timer Trigger Control Register This register is used to control the cross trigger connections for enables and faults of different timer instances in the same power domain. Please refer to sections Timer Module Cross Trigger (In/Out) and Fault Cross Triggering for details. Figure 18-74. CTTRIGCTL ## Table 18-56. CTTRIGCTL Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|--------------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-20 | RESERVED | R/W | 0h | | | 19-16 | EVTCTTRIGSEL | R/W | Oh | Used to Select the subscriber port that should be used for input cross trigger. Oh = Use FSUB0 as cross trigger source. 1h = Use FSUB1 as cross trigger source. 2h = Use Zero event as cross trigger source. 3h = Use Load event as cross trigger source. 4h = Use CCD0 event as cross trigger source. 5h = Use CCD1 event as cross trigger source. 6h = Use CCD2 event as cross trigger source. 7h = Use CCD3 event as cross trigger source. 8h = Use CCU0 event as cross trigger source. 9h = Use CCU1 event as cross trigger source. Ah = Use CCU2 event as cross trigger source. Bh = Use CCU3 event as cross trigger source. | | 15-2 | RESERVED | R/W | 0h | | | 1 | EVTCTEN | R/W | Oh | Enable the Input Trigger Conditions to the Timer module as a condition for Cross Triggers. Oh = Cross trigger generation disabled. 1h = Cross trigger generation enabled | | 0 | CTEN | R/W | Oh | Timer Cross trigger enable. This field is used to enable whether the SW or HW logic can generate a timer cross trigger event in the system. These cross triggers are connected to the respective timer trigger in of the other timer IPs in the SOC power domain. The timer cross trigger is essentially the combined logic of the HW and SW conditions controlling EN bit in the CTRCTL register. Oh = Cross trigger generation disabled. 1h = Cross trigger generation enabled | # 18.3.37 CTTRIG (Offset = 111Ch) [Reset = 00000000h] CTTRIG is shown in Figure 18-75 and described in Table 18-57. Return to the Summary Table. Cross Timer Trigger Register This register is used to trigger the timer instances connected and enabled using CTTRIGCTL and CTTRIGMSK registers. Figure 18-75. CTTRIG ### Table 18-57. CTTRIG Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-1 | RESERVED | W | 0h | | | 0 | TRIG | W | 0h | Generate Cross Trigger This bit when programmed will generate a synchronized trigger condition all the cross trigger enabled Timer instances including current timer instance. 0h = Cross trigger generation disabled 1h = Generate Cross trigger pulse | ## 18.3.38 FSCTL (Offset = 1120h) [Reset = 00000000h] FSCTL is shown in Figure 18-76 and described in Table 18-58. Return to the Summary Table. The FSCTL register controls the fault source selection and enable. There are 5 input fault sources either through synchronous path processing or asynchronous path. Figure 18-76. FSCTL ## Table 18-58. FSCTL Field Descriptions | Table 10 00.1 00 12 1 lola 2000 liptions | | | | | | | | |------------------------------------------|----------|------|-------|------------------------------------------------------------------------------------------------------|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | 31-7 | RESERVED | R/W | 0h | | | | | | 6 | FEX2EN | R/W | 0h | This field controls whether the fault is caused by external fault pin 2. 0h = Disable 1h = Enable | | | | | 5 | FEX1EN | R/W | 0h | This field controls whether the fault is caused by external fault pin 1. 0h = Disable 1h = Enable | | | | | 4 | FEX0EN | R/W | 0h | This field controls whether the fault is caused by external fault pin 0. 0h = Disable 1h = Enable | | | | | 3 | FAC2EN | R/W | 0h | This field controls whether the fault is caused by COMP2 output. 0h = Disable 1h = Enable | | | | | 2 | FAC1EN | R/W | 0h | This field controls whether the fault is caused by COMP1 output. 0h = Disable 1h = Enable | | | | | 1 | FAC0EN | R/W | 0h | This field controls whether the fault signal is caused by COMP0 output. 0h = Disable 1h = Enable | | | | | 0 | FCEN | R/W | 0h | This field controls whether the fault is caused by the system clock fault. 0h = Disable 1h = Enable | | | | # 18.3.39 GCTL (Offset = 1124h) [Reset = 00000001h] GCTL is shown in Figure 18-77 and described in Table 18-59. Return to the Summary Table. Global control register ## Figure 18-77. GCTL ## Table 18-59. GCTL Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|-----------------------------------------------------------------------------------------------------| | 31-1 | RESERVED | R/W | 0h | | | 0 | SHDWLDEN | R/W | | Enables shadow to active load of bufferred registers and register fields. 0h = Disable 1h = Enable | ## 18.3.40 CTR (Offset = 1800h) [Reset = 00000000h] CTR is shown in Figure 18-78 and described in Table 18-60. Return to the Summary Table. This is the TIMER counter register. This can be set by SW. However, the writes will be unpredictable if the software tries to set a value while the counter is running. ### Figure 18-78. CTR # Table 18-60. CTR Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|--------------------------------------------------------------------| | 31-16 | RESERVED | R/W | 0h | | | 15-0 | CCTR | R/W | | Current Counter value 0h = Minimum value 00FFFFFFh = Maximum Value | ## 18.3.41 CTRCTL (Offset = 1804h) [Reset = 0000FF80h] CTRCTL is shown in Figure 18-79 and described in Table 18-61. Return to the Summary Table. This register provides control over the counter operation. The configuration can change as well as setting the EN bit in a single write. There is no requirement to change the configuration first and then do an additional write to set the EN bit. Figure 18-79. CTRCTL | rigate to 70. Othor | | | | | | | | |---------------------|----------|----------|------|--------|----------|--------|----------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | RESE | RVED | CV | /AE | | RESERVED | | | | R/M | /-0h | R/V | V-0h | R/W-0h | | | R/W-0h | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | SLZERCNEZ | | RESERVED | | FRB | FB | DRB | RESERVED | | R/W-0h | | R/W-0h | | R/W-0h | R/W-0h | R/W-0h | R/W-0h | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | CZC | | | CAC | | CI | LC | | | R/W-7h | | | R/W-7h | | R/V | V-7h | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | CLC | RESERVED | СМ | | REPEAT | | EN | | | R/W-7h | R/W-0h | R/V | V-0h | R/W-0h | | | R/W-0h | ## Table 18-61. CTRCTL Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|-----------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-30 | RESERVED | R/W | 0h | | | 29-28 | CVAE | R/W | Oh | Counter Value After Enable. This field specifies the initialization condition of the counter when the EN bit is changed from 0 to 1 by a write to the CTRCTL register. Note that an external event can also cause the EN bit to go active. 0h = The counter is set to the LOAD register value 1h = The counter value is unchanged from its current value which could have been initialized by software 2h = The counter is set to zero | | 27-25 | RESERVED | R/W | 0h | | | 24 | PLEN | R/W | Oh | Phase Load Enable. This bit allows the timer to have phase load feature. 0h = Disabled 1h = Enabled | | 23 | SLZERCNEZ | R/W | Oh | Suppress Load and Zero Events if Repeat Counter is Not Equal to Zero. This bit suppresses the generation of the Z (zero) and L (load) events from the counter when the repeat counter (RC) value is not 0. 0h = Disabled. Z and L events are always generated from the counter when their conditions are generated. 1h = Enabled. Z and L events are generated from the counter when their conditions are generated and the RC register value is 0. | | 22-20 | RESERVED | R/W | 0h | | | 19 | FRB | R/W | Oh | Fault Resume Behavior This bit specifies what the device does following the release/exit of fault condition. 0h = Resume counting 1h = Perform the action as specified by the CVAE field. | # **Table 18-61. CTRCTL Field Descriptions (continued)** | Table 18-61. CTRCTL Field Descriptions (continued) | | | | | | |----------------------------------------------------|----------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | Bit | Field | Туре | Reset | Description | | | 18 | FB | R/W | 0h | Fault Behavior This bit specifies whether the counter continues running or suspends during a fault mode. There is a separate control under REPEAT to indicate whether counting is to suspend at next Counter==0 0h = Continues counting 1h = Suspends counting | | | 17 | DRB | R/W | 0h | Debug Resume Behavior This bit specifies what the device does following the release/exit of debug mode. 0h = Resume counting 1h = Perform the action as specified by the CVAE field. | | | 16 | RESERVED | R/W | 0h | | | | 15-13 | CZC | R/W | 7h | Counter Zero Control This field specifies what controls the counter operation with respect to zeroing the counter value. Encodings 1-3 are present based on the CCPC parameter value. Bits 4-5 are present based on the HQEI parameter value. Any encodings not provided are documented as reserved. Oh = CCCTL_0 ZCOND The CCCTL_1 ZCOND This value exists when there are 4 channels. This value exists when there are 4 channels. This value exists when there are 4 channels. This value exists when TIMER support QEI feature. The Controlled by 3-input QEI mode This value exists when TIMER support QEI feature. | | | 12-10 | CAC | R/W | 7h | Counter Advance Control. This field specifies what controls the counter operation with respect to advancing (incrementing or decrementing) the counter value. Encodings 1-3 are present based on the CCPC parameter value. Bits 4-5 are present based on the HQEI parameter value. Any encodings not provided are documented as reserved. 0h = CCCTL_0 ACOND 1h = CCCTL_1 ACOND 2h = CCCTL_2 ACOND This value exists when there are 4 channels. 3h = CCCTL_3 ACOND This value exists when there are 4 channels. 4h = Controlled by 2-input QEI mode This value exists when TIMER support QEI feature. 5h = Controlled by 3-input QEI mode This value exists when TIMER support QEI feature. | | | 9-7 | CLC | R/W | 7h | Counter Load Control. This field specifies what controls the counter operation with respect to setting the counter to the LD register value. Encodings 1-3 are present based on the CCPC parameter value. Bits 4-5 are present based on the HQEI parameter value. Any encodings not provided are documented as reserved. Oh = CCCTL_0 LCOND The CCCTL_1 LCOND This value exists when there are 4 channels. 3h = CCCTL_3 LCOND This value exists when there are 4 channels. 4h = Controlled by 2 input QEI mode. This value exists when TIMER support QEI feature. 5h = Controlled by 3 input QEI mode. This value exists when TIMER support QEI feature. | | | 6 | RESERVED | R/W | 0h | | | # **Table 18-61. CTRCTL Field Descriptions (continued)** | Table 10-01. OT NOTE Field Descriptions (Continued) | | | | | | | | |-----------------------------------------------------|--------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | 5-4 | СМ | R/W | 0h | Count Mode 0h = Down 1h = Up/Down 2h = Counter counts up. | | | | | 3-1 | REPEAT | R/W | Oh | Repeat. The repeat bit controls whether the counter continues to advance following a zero event, or the exiting of a debug or fault condition. If counting down, a zero event is followed by a load at the next advance condition. If counting up-down, a zero event is followed by an advance event (+1). The intent of encoding 3 is that if the debug condition is in effect, the generation of the load pulse is deferred until the debug condition is over. This allows the counter to reach zero before counting is suspended. Oh = Does not automatically advance following a zero event. 1h = Continues to advance following a zero event. 2h = Reserved 3h = Continues to advance following a zero event if the debug mode is not in effect, or following the release of the debug mode. 4h = Reserved | | | | | 0 | EN | R/W | Oh | Counter Enable. This bit allows the timer to advance This bit is automatically cleared if REPEAT=0 (do not automatically reload) and the counter value equals zero. CPU Write: A register write that sets the EN bit, the counter value is set per the CVAE value. Hardware: This bit may also be set as the result of an LCOND or ZCOND condition being met and the counter value changed to the load value or zero value, respectively. 0h = Disabled 1h = Enabled | | | | ## 18.3.42 LOAD (Offset = 1808h) [Reset = 00000000h] LOAD is shown in Figure 18-80 and described in Table 18-62. Return to the Summary Table. The contents of LOAD register are copied to CTR on any operation designated to do a "LOAD". The LOAD is used to compare with the CTR for generating a "Load Event" that can be used for interrupt, trigger, or signal generator actions. #### Figure 18-80. LOAD ## Table 18-62. LOAD Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|---------------------------------------------------------| | 31-16 | RESERVED | R/W | 0h | | | 15-0 | LD | R/W | | Load Value 0h = Minimum value 00FFFFFFh = Maximum Value | ## 18.3.43 CC\_01[y] (Offset = 1810h + formula) [Reset = 00000000h] CC\_01[y] is shown in Figure 18-81 and described in Table 18-63. Return to the Summary Table. The CC\_01 register is a register that can be used as either a capture register, to capture the next CTR value on an event, or a compare to the current CTR to create an event. It cannot operate concurrently as both. There are two Capture-Compare slices of hardware for each counter, hence there are two CC\_01 registers per timer. On a capture event, the next value of the CTR is loaded so that CTR and CC\_01 (which captured) will be equal on the cycle that an interrupt or trigger is created from the capture action. Offset = 1810h + (y \* 4h); where y = 0h to 1h ## Figure 18-81. CC\_01[y] Table 18-63. CC\_01[y] Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|-------------------------------------------------------------------| | 31-16 | RESERVED | R/W | 0h | | | 15-0 | CCVAL | R/W | | Capture or compare value 0h = Minimum value FFFFh = Maximum Value | ## 18.3.44 CC\_23[y] (Offset = 1818h + formula) [Reset = 00000000h] CC\_23[y] is shown in Figure 18-82 and described in Table 18-64. Return to the Summary Table. The CC\_23 register is a register that can be used as either a capture register, to capture the next CTR value on an event, or a compare to the current CTR to create an event. It cannot operate concurrently as both. There are two Capture-Compare slices of hardware for each counter, hence there are two CC\_01 registers per timer. On a capture event, the next value of the CTR is loaded so that CTR and CC\_01 (which captured) will be equal on the cycle that an interrupt or trigger is created from the capture action. Offset = 1818h + (y \* 4h); where y = 0h to 1h ## Figure 18-82. CC\_23[y] Table 18-64. CC\_23[y] Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|-------------------------------------------------------------------| | 31-16 | RESERVED | R/W | 0h | | | 15-0 | CCVAL | R/W | | Capture or compare value 0h = Minimum value FFFFh = Maximum Value | ## 18.3.45 CC\_45[y] (Offset = 1820h + formula) [Reset = 00000000h] CC\_45[y] is shown in Figure 18-83 and described in Table 18-65. Return to the Summary Table. The CC\_45 register are a registers which can be used as compare to the current CTR to create an events CC4U, CC4D, CC5U and CC5D. Offset = 1820h + (y \* 4h); where y = 0h to 1h ## Figure 18-83. CC\_45[y] Table 18-65. CC\_45[y] Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|-------------------------------------------------------------------| | 31-16 | RESERVED | R/W | 0h | | | 15-0 | CCVAL | R/W | | Capture or compare value 0h = Minimum value FFFFh = Maximum Value | # 18.3.46 CCCTL\_01[y] (Offset = 1830h + formula) [Reset = 00000000h] CCCTL\_01[y] is shown in Figure 18-84 and described in Table 18-66. Return to the Summary Table. The CCCTL\_01 registers control the operations of the respective CC registers and the counter. Offset = 1830h + (y \* 4h); where y = 0h to 1h Figure 18-84. CCCTL 01[v] | | | | i iguie io-o | 0000.[5] | 1 | | | |----------|-------------|--------|--------------|----------|----|--------|----------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | CC2SELD | | | CCACTUPD | | | CC2SELU | | | R/W-0h | | | R/W-0h | | | R/W-0h | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | CC2S | CC2SELU RES | | | CCUPD | | COC | RESERVED | | R/M | R/W-0h | | | R/W-0h | | R/W-0h | R/W-0h | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | RESERVED | | ZCOND | | RESERVED | | LCOND | | | R/W-0h | | R/W-0h | | R/W-0h | | R/W-0h | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | RESERVED | | ACOND | | RESERVED | | CCOND | | | R/W-0h | | R/W-0h | | R/W-0h | • | R/W-0h | | # Table 18-66. CCCTL\_01[y] Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|---------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-29 | CC2SELD | R/W | Oh | Selects the source second CCD event. 0h = Selects CCD from CC0. 1h = Selects CCD from CC1. 2h = Selects CCD from CC2. 3h = Selects CCD from CC3. 4h = Selects CCD from CC4. 5h = Selects CCD from CC5. | # Table 18-66. CCCTL\_01[y] Field Descriptions (continued) | Rit | | | | Posserintian | |-----------|----------------|----------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | | | | | Bit 28-26 | Field CCACTUPD | Type R/W | Reset Oh | CCACT shadow register Update Method This field controls how updates to the CCACT shadow register are performed 0h = Value written to the CCACT register has immediate effect. 1h = Following a zero event (CTR=0) Writes to the CCACTx_y register are stored in shadow register and transferred to CCACTx_y in the TIMCLK cycle following CTR equals 0. 2h = Following a CCD event (CTR=CC_xy) Writes to the CCACTx_y register are stored in shadow register and transferred to CCACTx_y in the TIMCLK cycle following CTR equals the CCACTx_y register are stored in shadow register and transferred to CCACTx_y in the TIMCLK cycle following CTR equals the CCx_y register value. 3h = Following a CCU event (CTR=CC_xy) Writes to the CCACTx_y register are stored in shadow register and transferred to CCACTx_y in the TIMCLK cycle following CTR equals the CCx_y register value. 4h = Following a zero event (CTR=0) or load event (CTR = LOAD) Writes to the CCACTx_y register are stored in shadow register and transferred to CCACTx_y in the TIMCLK cycle following CTR equals 0 or CTR. Equals LDn. Note this update mechanism is defined for use only in configurations using up/down counting. This mode is not intended for use in down count configurations. 5h = Following a zero event (CTR=0) with repeat count also zero (RC=0). Writes to the CCACTx_y Writes to the CCACTx_y | | | | | | register are stored in shadow register and transferred to CCACTx_y in the TIMCLK cycle following CTR equals 0 and if RC equal 0. 6h = On a TRIG pulse, the value stored in CCACT_xy shadow register is loaded into CCACT_xy register. | | 25 | SCERCNEZ | R/W | Oh | Suppress Compare Event if Repeat Counter is Not Equal to Zero This bit suppresses the generation of the compare (CCD, CCU and RC) events from the counter when the repeat counter (RC) value is not 0. 0h = CCD, CCU and RC events are always generated from the counter when their conditions are generated. 1h = CCD, CCU and RC events are generated from the counter when their conditions are generated and the RC register value is 0. | # Table 18-66. CCCTL\_01[y] Field Descriptions (continued) | | | | | Field Descriptions (continued) | |----------|----------|------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Field | Туре | Reset | Description | | 24-22 | CC2SELU | R/W | Oh | Selects the source second CCU event. 0h = Selects CCU from CC0. 1h = Selects CCU from CC1. 2h = Selects CCU from CC2. 3h = Selects CCU from CC3. 4h = Selects CCU from CC4. 5h = Selects CCU from CC5. | | 21 | RESERVED | R/W | 0h | | | 21 20-18 | RESERVED | R/W<br>R/W | Oh<br>Oh | Capture and Compare Update Method This field controls how updates to the shadow capture and compare register are performed (when operating in compare mode, COC=0). Oh = Writes to the CCx_y register is written to the register directly and has immediate effect. 1h = Following a zero event (CTR=0) Writes to the CCx_y register are stored in shadow register and transferred to CCx_y in the TIMCLK cycle following CTR equals 0. 2h = Following a CCD event (CTR=CC_xy) Writes to the CCx_y register are stored in shadow register and transferred to CCx_y in the TIMCLK cycle following CTR equals the CCx_y register value. 3h = Following a CCU event (CTR=CC_xy) Writes to the CCx_y register value. 3h = Following a CCU event (CTR=CC_xy) Writes to the CCx_y register value. 4h = Following a CCU event (CTR=0) or load event (CTR=LOAD) Writes to the CCx_y register value. 4h = Following a zero event(CTR=0) or load event (CTR=LOAD) Writes to the CCx_y register value. 5h = Following CTR cycle a zero event (CTR=0) with repeat count also zero (RC=0). Writes to the CCx_y register are stored in shadow register and transferred to CCx_y in the TIMCLK cycle following CTR C | | | | | | shadow register and transferred to CCx_y | # Table 18-66. CCCTL\_01[y] Field Descriptions (continued) | Bit | Field | | Reset | Description (continued) | |-------|----------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | Туре | | • | | 17 | COC | R/W | Oh | Capture or Compare. Specifies whether the corresponding CC register is used as a capture register or a compare register (never both). 0h = Compare 1h = Capture | | 16-15 | RESERVED | R/W | 0h | | | 14-12 | ZCOND | R/W | Oh | Zero Condition. This field specifies the condition that generates a zero pulse. 1h = Rising edge of CCP or trigger assertion edge 2h = Falling edge of CCP or trigger de-assertion edge 3h = Either edge of CCP or trigger change (assertion/de-assertion edge) | | 11 | RESERVED | R/W | 0h | | | 10-8 | LCOND | R/W | 0h | Load Condition. Specifies the condition that generates a load pulse. 1h = Rising edge of CCP or trigger assertion edge 2h = Falling edge of CCP or trigger de-assertion edge 3h = Either edge of CCP or trigger change (assertion/de-assertion edge) | | 7 | RESERVED | R/W | 0h | | | 6-4 | ACOND | R/W | 0h | Advance Condition. Specifies the condition that generates an advance pulse. 0h = Each TIMCLK 1h = Rising edge of CCP or trigger assertion edge 2h = Falling edge of CCP or trigger de-assertion edge 3h = Either edge of CCP or trigger change (assertion/de-assertion edge) 5h = CCP High or Trigger assertion (level) | | 3 | RESERVED | R/W | 0h | | | 2-0 | CCOND | R/W | Oh | Capture Condition. Specifies the condition that generates a capture pulse. 0h = None (never captures) 1h = Rising edge of CCP or trigger assertion edge 2h = Falling edge of CCP or trigger de-assertion edge 3h = Either edge of CCP or trigger change (assertion/de-assertion edge) | ## 18.3.47 CCCTL\_23[y] (Offset = 1838h + formula) [Reset = 00000000h] CCCTL\_23[y] is shown in Figure 18-85 and described in Table 18-67. Return to the Summary Table. The CCCTL registers control the operations of the respective CC registers and the counter. Offset = 1838h + (y \* 4h); where y = 0h to 1h Figure 18-85, CCCTL 23[v] | | | | ga.o .o oo. | | | | | |----------|------------|--------|-------------|----------|----|----------|----------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | CC2SELD | | | CCACTUPD | | SCERCNEZ | CC2SELU | | R/W-0h | | | R/W-0h | | | R/W-0h | R/W-0h | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | CC2S | CC2SELU RI | | | CCUPD | | COC | RESERVED | | R/M | R/W-0h | | | R/W-0h | | R/W-0h | R/W-0h | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | RESERVED | | ZCOND | | RESERVED | | LCOND | | | R/W-0h | | R/W-0h | | R/W-0h | | R/W-0h | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | RESERVED | | ACOND | | RESERVED | | CCOND | | | R/W-0h | • | R/W-0h | | R/W-0h | | R/W-0h | | ## Table 18-67. CCCTL\_23[y] Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|---------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-29 | CC2SELD | R/W | Oh | Selects the source second CCD event. 0h = Selects CCD from CC0. 1h = Selects CCD from CC1. 2h = Selects CCD from CC2. 3h = Selects CCD from CC3. 4h = Selects CCD from CC4. 5h = Selects CCD from CC5. | # Table 18-67. CCCTL\_23[y] Field Descriptions (continued) | Rit | | | | | |-----------|----------------|----------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | | | • | | Bit 28-26 | Field CCACTUPD | Type R/W | Reset Oh | Description CCACT shadow register Update Method This field controls how updates to the CCCACT shadow register are performed 0h = Value written to the CCACTx_y register has immediate effect. 1h = Following a zero event (CTR=0) Writes to the CCACTx_y register are stored in shadow register and transferred to CCACTx_y in the TIMCLK cycle following CTR equals 0. 2h = Following a CCD event (CTR=CC_xy) Writes to the CCACTx_y register are stored in shadow register and transferred to CCACTx_y in the TIMCLK cycle following CTR equals the CCx_y register value. 3h = Following a CCU event (CTR=cc_xy) Writes to the CCACTx_y register are stored in shadow register and transferred to CCACTx_y in the TIMCLK cycle following CTR equals the CCx_y register value. 4h = Following a zero event (CTR=0) or load event (CTR=LOAD) Writes to the CCACTx_y register are stored in shadow register and transferred to CCACTx_y in the TIMCLK cycle following CTR equals the CCx_y register value. 4h = Following a zero event (CTR=0) or load event (CTR=LOAD) Writes to the CCACTx_y register are stored in shadow register and transferred to CCACTx_y in the TIMCLK cycle following CTR equals 0 or CTR. Equals LDn. Note this update mechanism is defined for use only in configurations using up/down counting. This mode is not intended for use in down count configurations. 5h = Following a zero event (CTR=0) with repeat count also zero | | | | | | 1 • | | 25 | SCERCNEZ | R/W | 0h | Suppress Compare Event if Repeat Counter is Not Equal to Zero This bit suppresses the generation of the compare (CCD, CCU and RC) events from the counter when the repeat counter (RCn) value is not 0. 0h = CCD, CCU and RC events are always generated from the counter when their conditions are generated. 1h = CCD, CCU and RC events are generated from the counter when their conditions are generated and the RC register value is 0. | # Table 18-67. CCCTL\_23[y] Field Descriptions (continued) | | | | | Field Descriptions (continued) | |----------|----------|------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Field | Туре | Reset | Description | | 24-22 | CC2SELU | R/W | Oh | Selects the source second CCU event. 0h = Selects CCU from CC0. 1h = Selects CCU from CC1. 2h = Selects CCU from CC2. 3h = Selects CCU from CC3. 4h = Selects CCU from CC4. 5h = Selects CCU from CC5. | | 21 | RESERVED | R/W | 0h | | | 21 20-18 | | R/W<br>R/W | Oh Oh | Capture and Compare Update Method This field controls how updates to the shadow capture and compare register are performed (when operating in compare mode, COC=0). Oh = Writes to the CCx_y register is written to the register directly and has immediate effect. 1h = Following a zero event (CTR=0) Writes to the CCx_y register are stored in shadow register and transferred to CCx_y in the TIMCLK cycle following CTR equals 0. 2h = Following a CCD event (CTR=CC_xy) Writes to the CCx_y register are stored in shadow register and transferred to CCx_y in the TIMCLK cycle following CTR equals the CCx_y register value. 3h = Following a CCU event (CTR=CC_xy) Writes to the CCx_y register value. 3h = Following a CCU event (CTR=CC_xy) Writes to the CCx_y register value. 4h = Following a CCU event (CTR=CC_xy) Writes to the CCx_y register value. 4h = Following a zero or load event Writes to the CCx_y register value. 4h = Following a zero or load event Writes to the CCx_y register value. 5h = Following CTR 6h equals 0 or CTR. Equals 6h cCx_y in the TIMCLK 6h cycle following CTR 6h equals 0 or CTR. Equals 6h cCx_y in the TIMCLK 6h cycle following CTR 6h equals 0 or CTR. Equals 6h configurations c | | | | | | shadow register and transferred to CCx_y #xD; 0. | # Table 18-67. CCCTL\_23[y] Field Descriptions (continued) | | | | | IL_23[y] Field Descriptions (continued) | | | |-------|----------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Bit | Field | Туре | Reset | Description | | | | 17 | coc | R/W | Oh | Capture or Compare. Specifies whether the corresponding CC register is used as a capture register or a compare register (never both). 0h = Compare 1h = Capture | | | | 16-15 | RESERVED | R/W | 0h | | | | | 14-12 | ZCOND | R/W | 0h | Zero Condition. This field specifies the condition that generates a zero pulse. 4h-Fh = Reserved 1h = Rising edge of CCP or trigger assertion edge 2h = Falling edge of CCP or trigger de-assertion edge 3h = Either edge of CCP or trigger change (assertion/de-assertion edge) | | | | 11 | RESERVED | R/W | 0h | | | | | 10-8 | LCOND | R/W | 0h | Load Condition. Specifies the condition that generates a load pulse. 4h-Fh = Reserved 1h = Rising edge of CCP or trigger assertion edge 2h = Falling edge of CCP or trigger de-assertion edge 3h = Either edge of CCP or trigger change (assertion/de-assertion edge) | | | | 7 | RESERVED | R/W | 0h | | | | | 6-4 | ACOND | R/W | Oh | Advance Condition. Specifies the condition that generates an advance pulse. 6h-Fh = Reserved 0h = Each TIMCLK 1h = Rising edge of CCP or trigger assertion edge 2h = Falling edge of CCP or trigger de-assertion edge 3h = Either edge of CCP or trigger change (assertion/de-assertion edge) 5h = CCP High or Trigger assertion (level) | | | | 3 | RESERVED | R/W | 0h | | | | | 2-0 | CCOND | R/W | Oh | Capture Condition. Specifies the condition that generates a capture pulse. 4h-Fh = Reserved 0h = None (never captures) 1h = Rising edge of CCP or trigger assertion edge 2h = Falling edge of CCP or trigger de-assertion edge 3h = Either edge of CCP or trigger change (assertion/de-assertion edge) | | | # 18.3.48 CCCTL\_45[y] (Offset = 1840h + formula) [Reset = 00000000h] CCCTL\_45[y] is shown in Figure 18-86 and described in Table 18-68. Return to the Summary Table. The CCCTL registers control the operations of the respective CC registers and the counter. Offset = 1840h + (y \* 4h); where y = 0h to 1h Figure 18-86. CCCTL 45[v] | | | • | igaic to ou. | - 0001L_+0[y] | | | | |----|-----------------------|------|---------------|---------------|----|----------|----------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | RESE | RVED | | | SCERCNEZ | RESERVED | | | R/W-0h | | | | | | R/W-0h | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | RESERVED CCUPD RESERV | | | | | RVED | | | | R/W-0h | | R/W-0h R/W-0h | | | | /-0h | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | RES | ERVED | | | | | | | | R/\ | V-0h | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | RESE | ERVED | | | | | | | | R/\ | N-0h | | | | | 1 | | | | | | | | #### Table 18-68. CCCTL 45[v] Field Descriptions | | rabio to doi ded i E_4o[J] i loia becompaine | | | | | | | |-------|----------------------------------------------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | 31-26 | RESERVED | R/W | 0h | | | | | | 25 | SCERCNEZ | R/W | Oh | Suppress Compare Event if Repeat Counter is Not Equal to Zero This bit suppresses the generation of the compare (CCD, CCU and RC) events from the counter when the repeat counter (RC) value is not 0. 0h = CCD, CCU and RC events are always generated from the counter when their conditions are generated. 1h = CCD, CCU and RC events are generated from the counter when their conditions are generated and the RC register value is 0. | | | | | 24-21 | RESERVED | R/W | 0h | | | | | # Table 18-68. CCCTL\_45[y] Field Descriptions (continued) | Bit | Field | Туре | Reset | Descriptions (continued) | |-------|----------|------|-------|-------------------------------------------------------------------------------------| | | | | | • | | 20-18 | CCUPD | R/W | 0h | Capture and Compare Update Method | | | | | | This field controls how updates to the shadow | | | | | | capture and compare register are performed (when operating in compare mode, COC=0). | | | | | | Oh = Writes to the CCx_y register is written to the register directly | | | | | | and has immediate effect. | | | | | | 1h = Following a zero event (CTR=0) | | | | | | Writes to the CCx y | | | | | | register are stored in | | | | | | shadow register and transferred to | | | | | | ECCx_y in the TIMCLK | | | | | | cycle following CTR | | | | | | equals 0. | | | | | | 2h = Following a CCD event (CTR=CC_xy) | | | | | | Writes to the CCx_y register are stored in | | | | | | shadow register and transferred to | | | | | | CCx_y in the TIMCLK | | | | | | cycle following CTR equals the CCx y register value. | | | | | | 3h = Following a CCU event (CTR=CC_xy) | | | | | | Writes to the CCx y | | | | | | register are stored in | | | | | | shadow register and transferred to | | | | | | CCx y in the TIMCLK | | | | | | cycle following CTR | | | | | | equals the CCx_y register | | | | | | value. | | | | | | 4h = Following a zero event (CTR=0) or load event (CTR=LOAD) | | | | | | Writes to the CCx_y | | | | | | register are stored in shadow register and transferred to | | | | | | CCx y in the TIMCLK | | | | | | cycle following CTR | | | | | | equals 0 or CTR. Equals | | | | | | LD. | | | | | | Note this update mechanism is | | | | | | defined for use only in | | | | | | configurations using up/down | | | | | | counting. This mode is not intended for use in down count | | | | | | configurations. | | | | | | 5h = Following a zero event (CTR=0) with repeat count also zero (RC=0). | | | | | | Writes to the CCx y | | | | | | register are stored in | | | | | | shadow register and transferred to | | | | | | CCx_y in the TIMCLK | | | | | | cycle following CTR | | | | | | equals 0 and if RC equal | | | | | | 0. | | | | | | 6h = Following a TRIG pulse. | | | | | | Writes to the CCx_y | | | | | | register are stored in | | | | | | shadow register and transferred to CCx_y #xD; 0. | | | | | | OOA_у пл.D, U. | | 17-0 | RESERVED | R/W | 0h | | # 18.3.49 OCTL\_01[y] (Offset = 1850h + formula) [Reset = 00000000h] OCTL\_01[y] is shown in Figure 18-87 and described in Table 18-69. Return to the Summary Table. The OCTL\_01 register controls the CCP output of the Capture-Compare slice of the counter. This includes the ability to select the source of what is driven out along with initial condition values and final inversion options. Offset = 1850h + (y \* 4h); where y = 0h to 1h Figure 18-87. OCTL\_01[y] Table 18-69. OCTL\_01[y] Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-6 | RESERVED | R/W | 0h | | | 5 | CCPIV | R/W | Oh | CCP Initial Value This bit specifies the logical value put on the signal generator state while the counter is disabled (CTRCTL.EN == 0). 0h = Low 1h = High | | 4 | CCPOINV | R/W | Oh | CCP Output Invert The output as selected by CCPO is conditionally inverted. 0h = No inversion 1h = Invert | | 3-0 | ССРО | R/W | Oh | CCP Output Source 0h = Signal generator value (for example, PWM, triggered PWM) 1h = Load event 2h = CCU event or CCD event 4h = Zero event 5h = Capture event 6h = Fault condition 8h = Mirror CCP of first capture and compare register to other capture compare blocks 9h = Mirror CCP of second capture and compare register in other capture compare blocks Ch = Signal generator output after deadband insertion Dh = Counter direction | # 18.3.50 OCTL\_23[y] (Offset = 1858h + formula) [Reset = 00000000h] OCTL\_23[y] is shown in Figure 18-88 and described in Table 18-70. Return to the Summary Table. The OCTL register controls the CCP output of the Capture-Compare slice of the counter. This includes the ability to select the source of what is driven out along with initial condition values and final inversion options. Offset = 1858h + (y \* 4h); where y = 0h to 1h Figure 18-88. OCTL\_23[y] Table 18-70. OCTL\_23[y] Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-6 | RESERVED | R/W | 0h | | | 5 | CCPIV | R/W | 0h | CCP Initial Value This bit specifies the logical value put on the signal generator state while the counter is disabled (CTRCTL.EN == 0). 0h = Low 1h = High | | 4 | CCPOINV | R/W | Oh | CCP Output Invert The output as selected by CCPO is conditionally inverted. 0h = No inversion 1h = Invert | | 3-0 | ССРО | R/W | Oh | CCP Output Source 0h = Signal generator value (for example, PWM, triggered PWM) 1h = Load condition 2h = CCU event or CCD event 4h = Zero event 5h = Capture event 6h = Fault Condition 8h = Mirror CCP of first capture and compare register in other capture compare blocks 9h = Mirror CCP of second capture and compare register in other capture compare blocks /bn,. Ch = Deadband Inserted Output Dh = Counter direction | # 18.3.51 CCACT\_01[y] (Offset = 1870h + formula) [Reset = 00000000h] CCACT\_01[y] is shown in Figure 18-89 and described in Table 18-71. Return to the Summary Table. The CCACT\_01 register controls the actions of the signal generator of the capture-compare slice based on the events created in the counter block, the capture and compare block and debug events. Offset = 1870h + (y \* 4h); where y = 0h to 1h Figure 18-89. CCACT\_01[y] Table 18-71. CCACT\_01[y] Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|---------------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-30 | SWFRCACT_CMPL | R/W | 0h | CCP Complimentary output Action on Software Force Output This field describes the resulting action of software force. This action has a shadow register, which will be updated under specific condition. So that this register cannot take into effect immediately. Oh = This event is disabled and a lower priority event is selected if asserting. The CCP output value is unaffected by the event. 1h = CCP Complimentary output value is set high 2h = CCP Complimentary output value is set low | | 29-28 | SWFRCACT | R/W | Oh | CCP Output Action on Software Force Output This field describes the resulting action of software force. This action has a shadow register, which will be updated under specific condition. So that this register cannot take into effect immediately. Oh = This event is disabled and a lower priority event is selected if asserting. The CCP output value is unaffected by the event. 1h = CCP output value is set high 2h = CCP output value is set low | | 27-25 | FEXACT | R/W | 0h | CCP Output Action on Fault Exit This field describes the resulting action of the signal generator upon exiting the fault condition. Oh = This event is disabled and a lower priority event is selected if asserting. The CCP output value is unaffected by the event. 1h = CCP output value is set high 2h = CCP output value is set low 3h = CCP output value is toggled 4h = CCP output value is tristated | # Table 18-71. CCACT\_01[y] Field Descriptions (continued) | Bit | Field | Type | Reset | Description (continued) | |-------|----------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 24-22 | FENACT | R/W | Oh | CCP Output Action on Fault Entry This field describes the resulting action of the signal generator upon detecting a fault. Oh = This event is disabled and a lower priority event is selected if asserting. The CCP output value is unaffected by the event. 1h = CCP output value is set high 2h = CCP output value is set low 3h = CCP output value is toggled 4h = CCP output value is tristated | | 21-17 | RESERVED | R/W | 0h | | | 16-15 | CC2UACT | R/W | Oh | CCP Output Action on CC2U event. 0h = This event is disabled and a lower priority event is selected if asserting. The CCP output value is unaffected by the event. 1h = CCP output value is set high 2h = CCP output value is set low 3h = CCP output value is toggled | | 14 | RESERVED | R/W | 0h | | | 13-12 | CC2DACT | R/W | Oh | CCP Output Action on CC2D event. 0h = This event is disabled and a lower priority event is selected if asserting. The CCP output value is unaffected by the event. 1h = CCP output value is set high 2h = CCP output value is set low 3h = CCP output value is toggled | | 11 | RESERVED | R/W | 0h | | | 10-9 | CUACT | R/W | Oh | CCP Output Action on Compare (Up) This field describes the resulting action of the signal generator upon detecting a compare event while counting up. Oh = This event is disabled and a lower priority event is selected if asserting. The CCP output value is unaffected by the event. 1h = CCP output value is set high 2h = CCP output value is set low 3h = CCP output value is toggled | | 8 | RESERVED | R/W | 0h | | | 7-6 | CDACT | R/W | Oh | CCP Output Action on Compare (Down) This field describes the resulting action of the signal generator upon detecting a compare event while counting down. Oh = This event is disabled and a lower priority event is selected if asserting. The CCP output value is unaffected by the event. 1h = CCP output value is set high 2h = CCP output value is set low 3h = CCP output value is toggled | | 5 | RESERVED | R/W | 0h | | | 4-3 | LACT | R/W | 0h | CCP Output Action on Load Specifies what changes occur to CCP output as the result of a load event. Oh = This event is disabled and a lower priority event is selected if asserting. The CCP output value is unaffected by the event. 1h = CCP output value is set high 2h = CCP output value is set low 3h = CCP output value is toggled | | 2 | RESERVED | R/W | 0h | | | 1-0 | ZACT | R/W | Oh | CCP Output Action on Zero Specifies what changes occur to CCP output as the result of a zero event. Oh = This event is disabled and a lower priority event is selected if asserting. The CCP output value is unaffected by the event. 1h = CCP output value is set high 2h = CCP output value is set low 3h = CCP output value is toggled | # 18.3.52 CCACT\_23[y] (Offset = 1878h + formula) [Reset = 00000000h] CCACT\_23[y] is shown in Figure 18-90 and described in Table 18-72. Return to the Summary Table. The CCACT register controls the actions of the signal generator of the capture-compare slice based on the events created in the counter block, the capture and compare block and debug events. Offset = 1878h + (y \* 4h); where y = 0h to 1h Figure 18-90. CCACT\_23[y] Table 18-72. CCACT\_23[y] Field Descriptions | | Table 10 72. GOACT_20[y] Title 20001ptions | | | | | | |-------|--------------------------------------------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Bit | Field | Type | Reset | Description | | | | 31-30 | SWFRCACT_CMPL | R/W | Oh | CCP Complimentary Output Action on Software Force Output This field describes the resulting action of software force. This action has a shadow register, which will be updated under specific condition. So that this register cannot take into effect immediately. Oh = This event is disabled and a lower priority event is selected if asserting. The CCP output value is unaffected by the event. 1h = CCP Complimentary output value is set high 2h = CCP Complimentary output value is set low | | | | 29-28 | SWFRCACT | R/W | Oh | CCP Output Action on Software Force Output This field describes the resulting action of software force. This action has a shadow register, which will be updated under specific condition. So that this register cannot take into effect immediately. Oh = This event is disabled and a lower priority event is selected if asserting. The CCP output value is unaffected by the event. 1h = CCP output value is set high 2h = CCP output value is set low | | | | 27-25 | FEXACT | R/W | Oh | CCP Output Action on Fault Exit This field describes the resulting action of the signal generator upon exiting the fault condition. Oh = This event is disabled and a lower priority event is selected if asserting. The CCP output value is unaffected by the event. 1h = CCP output value is set high 2h = CCP output value is set low 3h = CCP output value is toggled 4h = CCP output value is tristated | | | # Table 18-72. CCACT\_23[y] Field Descriptions (continued) | | | | | Field Descriptions (continued) | |-------|----------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Field | Туре | Reset | Description | | 24-22 | FENACT | R/W | 0h | CCP Output Action on Fault Entry This field describes the resulting action of the signal generator upon detecting a fault. Oh = This event is disabled and a lower priority event is selected if asserting. The CCP output value is unaffected by the event. 1h = CCP output value is set high 2h = CCP output value is set low 3h = CCP output value is toggled 4h = CCP output value is tristated | | 21-17 | RESERVED | R/W | 0h | | | 16-15 | CC2UACT | R/W | 0h | CCP Output Action on CC2U event. 0h = This event is disabled and a lower priority event is selected if asserting. The CCP output value is unaffected by the event. 1h = CCP output value is set high 2h = CCP output value is set low 3h = CCP output value is toggled | | 14 | RESERVED | R/W | 0h | | | 13-12 | CC2DACT | R/W | Oh | CCP Output Action on CC2D event. 0h = This event is disabled and a lower priority event is selected if asserting. The CCP output value is unaffected by the event. 1h = CCP output value is set high 2h = CCP output value is set low 3h = CCP output value is toggled | | 11 | RESERVED | R/W | 0h | | | 10-9 | CUACT | R/W | Oh | CCP Output Action on Compare (Up) This field describes the resulting action of the signal generator upon detecting a compare event while counting up. Oh = This event is disabled and a lower priority event is selected if asserting. The CCP output value is unaffected by the event. 1h = CCP output value is set high 2h = CCP output value is set low 3h = CCP output value is toggled | | 8 | RESERVED | R/W | 0h | | | 7-6 | CDACT | R/W | 0h | CCP Output Action on Compare (Down) This field describes the resulting action of the signal generator upon detecting a compare event while counting down. Oh = This event is disabled and a lower priority event is selected if asserting. The CCP output value is unaffected by the event. 1h = CCP output value is set high 2h = CCP output value is set low 3h = CCP output value is toggled | | 5 | RESERVED | R/W | 0h | | | 4-3 | LACT | R/W | 0h | CCP Output Action on Load Specifies what changes occur to CCP output as the result of a load event. Oh = This event is disabled and a lower priority event is selected if asserting. The CCP output value is unaffected by the event. 1h = CCP output value is set high 2h = CCP output value is set low 3h = CCP output value is toggled | | 2 | RESERVED | R/W | 0h | | | 1-0 | ZACT | R/W | Oh | CCP Output Action on Zero Specifies what changes occur to CCP output as the result of a zero event. Oh = This event is disabled and a lower priority event is selected if asserting. The CCP output value is unaffected by the event. 1h = CCP output value is set high 2h = CCP output value is set low 3h = CCP output value is toggled | # 18.3.53 IFCTL\_01[y] (Offset = 1880h + formula) [Reset = 00000000h] IFCTL\_01[y] is shown in Figure 18-91 and described in Table 18-73. Return to the Summary Table. The IFCTL\_01 register controls the input selection and inversion for the associated Capture-Compare slice. Offset = 1880h + (y \* 4h); where y = 0h to 1h Figure 18-91. IFCTL 01[v] | | | | inguie 10-31. | • . – _ • . [9] | | | | | | |--------|----------|----------|---------------|-----------------|----------|-----|------|--|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | RESERVED | | | | | | | | | | | R/W-0h | | | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | | | RESE | RVED | | | | | | | | R/W-0h | | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | RESERVED | | FE | CPV | RESERVED | F | P | | | | | R/W-0h | | R/W-0h | R/W-0h | R/W-0h | R/V | V-0h | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | INV | | RESERVED | | | ISEL | _ | | | | | R/W-0h | | R/W-0h | | | R/W-0 | Dh | | | | Table 18-73. IFCTL\_01[y] Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-13 | RESERVED | R/W | 0h | | | 12 | FE | R/W | 0h | Filter Enable This bit controls whether the input is filtered by the input filter or bypasses to the edge detect. 0h = Bypass. 1h = Filtered. | | 11 | CPV | R/W | Oh | Consecutive Period/Voting Select This bit controls whether the input filter uses a stricter consecutive period count or majority voting. 0h = Consecutive Periods The input must be at a specific logic level for the period defined by FP before it is passed to the filter output. 1h = Voting The filter ignores one clock of opposite logic over the filter period. 1.e. Over FP samples of the input, up to 1 sample may be of an opposite logic value (glitch) without affecting the output. | | 10 | RESERVED | R/W | 0h | | | 9-8 | FP | R/W | 0h | Filter Period. This field specifies the sample period for the input filter. I.e. The input is sampled for FP timer clocks during filtering. 0h = The division factor is 3 1h = The division factor is 5 2h = The division factor is 8 | # Table 18-73. IFCTL\_01[y] Field Descriptions (continued) | Bit | Field | Туре | Reset | Description | |-----|----------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | INV | R/W | Oh | Input Inversion This bit controls whether the selected input is inverted. 0h = Noninverted 1h = Inverted | | 6-4 | RESERVED | R/W | 0h | | | 3-0 | ISEL | R/W | Oh | Input Select (CCP0) This field selects the input source to the filter input. 4h-7h = Reserved Oh = CCP of the corresponding capture compare unit 1h = Input pair CCPX of the capture compare unit. For CCP0 input pair is CCP1 and for CCP1 input pair is CCP0. 2h = CCP0 of the counter 3h = Trigger 4h = XOR of CCP inputs as input source (Used in Hall input mode). 5h = subscriber 0 event as input source. 6h = subscriber 1 event as input source. 7h = Comparator 0 output. 8h = Comparator 2 output. | # 18.3.54 IFCTL\_23[y] (Offset = 1888h + formula) [Reset = 00000000h] IFCTL\_23[y] is shown in Figure 18-92 and described in Table 18-74. Return to the Summary Table. The IFCTL register controls the input selection and inversion for the associated Capture-Compare slice. Offset = 1888h + (y \* 4h); where y = 0h to 1h Figure 18-92. IFCTL 23[v] | | | | ga.o .o o <u>-</u> . | · II O I L_ZO[y] | | | | | | |--------|----------|----------|----------------------|------------------|----------|-----|------|--|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | RESERVED | | | | | | | | | | R/W-0h | | | | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | | | RESE | RVED | | | | | | | R/W-0h | | | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | RESERVED | | FE | CPV | RESERVED | F | P | | | | | R/W-0h | | R/W-0h | R/W-0h | R/W-0h | R/V | V-0h | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | INV | | RESERVED | | | ISE | :L | | | | | R/W-0h | | R/W-0h | | | R/W | -0h | | | | Table 18-74. IFCTL\_23[y] Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-13 | RESERVED | R/W | 0h | | | 12 | FE | R/W | Oh | Filter Enable This bit controls whether the input is filtered by the input filter or bypasses to the edge detect. 0h = Bypass. 1h = Filtered. | | 11 | CPV | R/W | Oh | Consecutive Period/Voting Select This bit controls whether the input filter uses a stricter consecutive period count or majority voting. Oh = Consecutive Periods The input must be at a specific logic level for the period defined by FP before it is passed to the filter output. 1h = Voting The filter ignores one clock of opposite logic over the filter period. 1.e. Over FP samples of the input, up to 1 sample may be of an opposite logic value (glitch) without affecting the output. | | 10 | RESERVED | R/W | 0h | | | 9-8 | FP | R/W | Oh | Filter Period. This field specifies the sample period for the input filter. I.e. The input is sampled for FP timer clocks during filtering. 0h = The division factor is 3 1h = The division factor is 5 2h = The division factor is 8 | # Table 18-74. IFCTL\_23[y] Field Descriptions (continued) | Bit | Field | Туре | Reset | Description | |-----|----------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | INV | R/W | 0h | Input Inversion This bit controls whether the selected input is inverted. 0h = Noninverted 1h = Inverted | | 6-4 | RESERVED | R/W | 0h | | | 3-0 | ISEL | R/W | Oh | Input Select (CCP0) This field selects the input source to the filter input. 4h-7h = Reserved Oh = CCP of the corresponding capture compare unit 1h = Input pair CCPX of the capture compare unit. For CCP0 input pair is CCP1 and for CCP1 input pair is CCP0. 2h = CCP0 of the counter 3h = Trigger 4h = XOR of CCP inputs as input source (Used in Hall input mode). 5h = subscriber 0 event as input source. 6h = subscriber 1 event as input source. 7h = Comparator 0 output. 8h = Comparator 1 output. 9h = Comparator 2 output. | # 18.3.55 PL (Offset = 18A0h) [Reset = 00000000h] PL is shown in Figure 18-93 and described in Table 18-75. Return to the Summary Table. This is the phase load register. # Figure 18-93. PL # **Table 18-75. PL Field Descriptions** | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|--------------------------------------------------------------| | 31-16 | RESERVED | R/W | 0h | | | 15-0 | PHASE | R/W | - | Phase Load value 0h = Minimum value 00FFFFFh = Maximum Value | # 18.3.56 DBCTL (Offset = 18A4h) [Reset = 00000000h] DBCTL is shown in Figure 18-94 and described in Table 18-76. Return to the Summary Table. The DBCTL register controls the dead band insertion of the pulse width modulated output. # Figure 18-94. DBCTL | | | | 9 | | | | | | | |----|-----------|------|-----------|-----------|-------|------|----|--|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | RESER | RVED | | | FALLD | ELAY | | | | | | R/V | V- | | R/W-0h | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | | | FALLE | ELAY | | | | | | | | R/W-0h | | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | RESERVED | | M1_ENABLE | RISEDELAY | | | | | | | | R/W- | | R/W- | | R/W | ′-0h | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | RISEDELAY | | | | | | | | | | | R/W-0h | | | | | | | | | | | | | | | | | | | | #### Table 18-76. DBCTL Field Descriptions | 14515 15 15 15 15 15 15 15 15 15 15 15 15 | | | | | | | | | |-------------------------------------------|-----------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | | 31-28 | RESERVED | R/W | 0h | | | | | | | 27-16 | FALLDELAY | R/W | 0h | Fall Delay The number of TIMCLK periods inserted between the fall edge of CCP signal and the rise edge of CCP complimentary signal. 0h = Minimum value FFFh = Maximum Value | | | | | | 15-13 | RESERVED | R/W | 0h | | | | | | | 12 | M1_ENABLE | R/W | 0h | Dead Band Mode 1 Enable. 0h = Disabled 1h = Enabled | | | | | | 11-0 | RISEDELAY | R/W | 0h | Rise Delay The number of TIMCLK periods inserted between the falling edge of CCP signal and the rising edge of CCP complimentary signal. 0h = Minimum value FFFh = Maximum Value | | | | | # 18.3.57 TSEL (Offset = 18B0h) [Reset = 00000000h] TSEL is shown in Figure 18-95 and described in Table 18-77. Return to the Summary Table. The TSEL register controls the input trigger enable and selection of the trigger source. Trigger sources are generated by other peripherals through their respective publisher ports (subscribed in by the timer's subscriber port). Figure 18-95. TSEL Table 18-77. TSEL Field Descriptions | | | Table I | rieid Descriptions | | | |-------|----------|---------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | Bit | Field | Туре | Reset | Description | | | 31-10 | RESERVED | R/W | 0h | | | | 9 | TE | R/W | Oh | Trigger Enable. This selects whether a trigger is enabled or not for this counter 0x0 = Triggers are not used 0x1 = Triggers are used as selected by the ETSEL field 0h = Triggers are not used. 1h = Triggers are used as selected by the IE, ITSEL and ETSEL fields. | | | 8-5 | RESERVED | R/W | 0h | | | | 4-0 | ETSEL | R/W | Oh | External Trigger Select. This selects which System Event is used if the input filter selects trigger. Triggers 0-15 are used to connect triggers generated by other timer modules. Refer to the SoC data sheet for details related to timer trigger sources. Triggers 16 and 17 are connected to event manager subscriber ports. Event lines 18-31 are reserved for future use. 0h = TRIGx = External trigger input from TIM x. 1h = TRIGx = External trigger input from TIM x. 2h = TRIGx = External trigger input from TIM x. 3h = TRIGx = External trigger input from TIM x. 4h = TRIGx = External trigger input from TIM x. 5h = TRIGx = External trigger input from TIM x. 6h = TRIGx = External trigger input from TIM x. 7h = TRIGx = External trigger input from TIM x. 8h = TRIGx = External trigger input from TIM x. 9h = TRIGx = External trigger input from TIM x. Ah = TRIGx = External trigger input from TIM x. Ch = TRIGx = External trigger input from TIM x. Dh = TRIGx = External trigger input from TIM x. Eh = TRIGx = External trigger input from TIM x. The TRIGx = External trigger input from TIM x. The TRIGx = External trigger input from TIM x. The TRIGx = External trigger input from TIM x. The TRIGx = External trigger input from TIM x. The TRIGx = External trigger input from TIM x. The TRIGx = External trigger input from TIM x. The TRIGx = External trigger input from TIM x. The TRIGx = External trigger input from TIM x. The TRIGx = External trigger input from TIM x. The TRIGx = External trigger input from TIM x. The TRIGx = External trigger input from TIM x. The TRIGx = External trigger input from TIM x. | | # 18.3.58 RC (Offset = 18B4h) [Reset = 00000000h] RC is shown in Figure 18-96 and described in Table 18-78. Return to the Summary Table. Repeat counter is to reduce interrupt overhead. The repeat counter provides the mechanism to suppress un-necessary interrupts; reducing the number of interrupts generated by each event type to 1 for the program number of periods. Specifically, the repeat timer may suppress Load, Compare (up/down, normal/shadow), and Zero events. # Figure 18-96. RC # Table 18-78. RC Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|-------------------------------------------------------------| | 31-8 | RESERVED | R | 0h | | | 7-0 | RC | R | | Repeat Counter Value 0h = Minimum value FFh = Maximum Value | # 18.3.59 RCLD (Offset = 18B8h) [Reset = 00000000h] RCLD is shown in Figure 18-97 and described in Table 18-79. Return to the Summary Table. The load register value is transferred to the counter when the counter load input is asserted. # Figure 18-97. RCLD #### **Table 18-79. RCLD Field Descriptions** | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-8 | RESERVED | R/W | 0h | | | 7-0 | RCLD | R/W | 0h | Repeat Counter Load Value This field provides the value loaded into the repeat counter at a load event following the repeat counter value equaling 0. 0h = Minimum value FFh = Maximum Value | # 18.3.60 QDIR (Offset = 18BCh) [Reset = 00000000h] QDIR is shown in Figure 18-98 and described in Table 18-80. Return to the Summary Table. The QDIR register provides the direction of count which is intended for use when operating the counter in QEI. # Figure 18-98. QDIR # Table 18-80. QDIR Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|----------------------------------------------------------------------------------------| | 31-1 | RESERVED | R | 0h | | | 0 | DIR | R | | Direction of count 0h = Down (Phase B leads Phase A) 1h = Up (Phase A leads Phase B) | # 18.3.61 FCTL (Offset = 18D0h) [Reset = 00000000h] FCTL is shown in Figure 18-99 and described in Table 18-81. Return to the Summary Table. The FCTL register controls the fault inputs, fault detection and error handling behavior. # Figure 18-99. FCTL # Table 18-81. FCTL Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-14 | RESERVED | R/W | 0h | | | 13 | FSENEXT2 | R/W | 0h | Specifies whether the external fault pin2 high/low is treated as fault condition. 0h = Fault Input is active low. 1h = Fault Input is active high. | | 12 | FSENEXT1 | R/W | 0h | Specifies whether the external fault pin1 high/low is treated as fault condition. Oh = Fault Input is active low. 1h = Fault Input is active high. | | 11 | FSENEXT0 | R/W | 0h | Specifies whether the external fault pin0 high/low is treated as fault condition. Oh = Fault Input is active low. 1h = Fault Input is active high. | | 10 | FSENAC2 | R/W | 0h | Specifies whether the COMP2 output high/low is treated as fault condition. Oh = Fault Input is active low. 1h = Fault Input is active high. | | 9 | FSENAC1 | R/W | 0h | Specifies whether the COMP1 output high/low is treated as fault condition. 0h = Fault Input is active low. 1h = Fault Input is active high. | | 8 | FSENAC0 | R/W | 0h | Specifies whether the COMP0 output high/low is treated as fault condition. 0h = Fault Input is active low. 1h = Fault Input is active high. | | 7 | TFIM | R/W | 0h | Trigger Fault Input Mask Specifies whether the selected trigger participates as a fault input. If enabled and the trigger asserts, the trigger is treated as a fault. Oh = Selected trigger does not participate in fault condition generation 1h = Selected trigger participates in fault condition generation | | 6-5 | RESERVED | R/W | 0h | | # Table 18-81. FCTL Field Descriptions (continued) | Bit | Field | Туре | Reset | Description | |-----|----------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 4-3 | FL | R/W | 0h | Fault Latch mode Specifies whether the fault condition is latched and configures the latch clear conditions. 0h = Overall fault condition is not dependent on the F bit in RIS 1h = Overall fault condition is dependent on the F bit in RIS 2h = Fault condition is latched. Fault condition is cleared on a zero event if the fault input is 0. 3h = Fault condition is latched. Fault condition is cleared on a load event if the fault input is 0. | | 2 | FI | R/W | 0h | Fault Input Specifies whether the overall fault condition is dependent on the sensed fault pin. 0h = Overall Fault condition is not dependent on sensed input. 1h = Overall Fault condition is dependent on sensed input. | | 1 | RESERVED | R/W | 0h | | | 0 | FIEN | R/W | Oh | Fault Input Enable This bit enables the input for fault detection. 0h = Fault Input Disabled 1h = Fault Input Enabled | # 18.3.62 FIFCTL (Offset = 18D4h) [Reset = 00000000h] FIFCTL is shown in Figure 18-100 and described in Table 18-82. Return to the Summary Table. The FIFCTL register controls the filtering for the fault input. # Figure 18-100. FIFCTL #### Table 18-82. FIFCTL Field Descriptions | Tubic to 02.111 OTE Ficial Descriptions | | | | | | | | |-----------------------------------------|----------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | 31-5 | RESERVED | R/W | 0h | | | | | | 4 | FILTEN | R/W | Oh | Filter Enable This bit controls whether the input is filtered by the input filter or bypasses to go directly to the optional pre-scale filter and then to the edge detect. 0h = Bypass 1h = Filtered. | | | | | 3 | CPV | R/W | Oh | Consecutive Period/Voting Select This bit controls whether the input filter uses a stricter consecutive period count or majority voting. 0h = Consecutive Periods. The input must be at a specific logic level for the period defined by FP before it is passed to the filter output. 1h = Voting. The filter ignores one clock of opposite logic over the filter period. 1.e. Over FP samples of the input, up to 1 sample may be of an opposite logic value (glitch) without affecting the output | | | | | 2 | RESERVED | R/W | 0h | | | | | | 1-0 | FP | R/W | Oh | Filter Period This field specifies the sample period for the input filter. I.e. The input is sampled for FP timer clocks during filtering. 0h = Filter Period 3 1h = Filter Period 5 2h = Filter Period 8 | | | | # Chapter 19 **WWDT** The window watchdog timer (WWDT) supervises code execution. If the application software does not successfully reset the window watchdog within the programmed open time window, the window watchdog generates a reset. | 19.1 WWDT Overview | 1070 | |------------------------|------| | 19.2 WWDT Operation | 1071 | | 19.3 WWDT Registers | | | 10.0 11.12 1 109.010.0 | | WWDT www.ti.com #### 19.1 WWDT Overview The primary function of the window watchdog timer (WWDT) is to initiate a reset when correct operation of the device has failed due to an unexpected software or system delay. The WWDT can be programmed with a predefined time window within which the application software must restart the timer, indicating that application execution is proceeding normally. If application software fails to restart the timer within the specified window, the WWDT will issue a WWDT violation signal to SYSCTL to generate a reset. If watchdog functionality is not required in an application, the WWDT can also be configured as a basic system interval timer which is capable of generating periodic maskable interrupts to the CPU. Key features of the WWDT include: - · A 25-bit counter with closed and open window - · Counter driven from LFCLK (fixed 32 kHz clock path) with a programmable clock divider - · Eight selectable watchdog timer periods - Optional automatic suspension of counter when operating in low power modes - Support for standard window watchdog mode or interval timer (non-watchdog) mode Devices may have 1 or 2 WWDT instances. A WWDT0 violation generates a BOOTRST, which resets the peripheral and CPU state and also causes the boot configuration routine (BCR) to run. A WWDT1 violation generates a SYSRST, which resets the peripheral and CPU state but does not trigger execution of the BCR. As such, WWDT1 is well suited for recovering from execution stalls that result from software execution, while WWDT0 is well suited for catching larger issues such as a corrupted trim value, at the expense of a longer reset time. #### 19.1.1 Watchdog Mode In watchdog mode, the WWDT is configured to count up to the specified WWDT period. The WWDT counter must be restarted with the configured open window of the WWDT period, or the WWDT will assert a WWDT violation to SYSCTL and a reset will be generated. The window watchdog timer supports detecting both a "too late" response as well as a "too early" response through the use of an optional closed window, as shown in Figure 19-1. The WWDT period consists of a closed window period and an open window period. The closed window period begins first, followed by the open window period. The WWDT can only be restarted during the open window period. An attempt to restart the WWDT during the closed window period results in a violation. Following the closed window, if the WWDT is not restarted before the end of the open window, the WWDT period expires and a violation is also generated. Figure 19-1. WWDT Functionality If the closed window functionality is not desired, it can be disabled (set to 0%), giving traditional watchdog timer functionality where the WWDT can be reset any time before the WWDT period expires. www.ti.com WWDT #### 19.1.2 Interval Timer Mode The WWDT can be used in interval timer mode to generate periodic interrupts to the CPU when not using the watchdog functionality. When used in interval timer mode, a WWDT interrupt is generated when the WWDT period expires, or when an incorrect password is applied to the WWDT control registers. #### 19.2 WWDT Operation The WWDT must be enabled before being configured for use through the PWREN register (see peripheral power enable). The WWDT is configured through the WWDTCTL0 and WWDTCTL1 registers. The registers are password protected. Any register access (read or write) must be a 32-bit access. Write access must also include the corresponding password in the most significant byte (0xC9 for WWDTCTL0, and 0xBE for WWDTCTL1). Attempting a register write without the correct password, or attempting a write with an access other than a 32-bit access generates a WWDT violation to SYSCTL. The password byte always reads as 0x00. The WWDT is disabled and cleared after a SYSRST. The WWDTCTL0 register sets the static configuration of the WWDT, including: the clock divider, the timer period, the two closed window percentages, the timer mode (WWDT or interval), and the stop-in-sleep status. The first write (with a key match) to the WWDTCTL0 register enables the WWDT. Once the WWDT is enabled, the WWDTCTL0 register becomes write protected. Any attempt to write to the WWDTCTL0 register after the WWDT is enabled generates a WWDT violation to SYSCTL. The RUN bit in the WWDTSTAT register indicates that the WWDT is running. Figure 19-2 shows the WWDT functional block diagram. Figure 19-2. WWDT Diagram #### 19.2.1 Mode Selection The WWDT operating mode (watchdog mode or interval timer mode) is selected by the MODE bit in the WWDTCTL0 register. Watchdog mode is the default mode (MODE cleared). Setting the MODE bit configures the WWDT for interval mode. When the WWDT is in watchdog mode, the WWDT counter must be restarted within the open window period by writing the RESTART value (0x000000A7) to the WWDTCNTRST register. After a reset or restart, the WWDT counter will restart from zero. A failure to restart the WWDT within the open window or an attempt to restart the WWDT counter during the closed window will generate a WWDT violation to SYSCTL. Writing any value other than the RESTART value to the WWDTCNTRST register also generates a WWDT violation. When the WWDT is in interval mode, the timer acts as an interval timer, generating WWDT interrupts to the CPU as specified by the WWDT period. As soon as the WWDT is enabled in interval mode, the WWDT interval timer interrupt will be asserted after the expiration of the timer. It is not necessary to restart the WWDT in interval timer mode. WWDT www.ti.com #### 19.2.2 Clock Configuration The WWDT runs from the 32-kHz low-frequency clock (LFCLK). A clock divider supports dividing the input clock from /1 (no divide) to /8 (divide-by-8) using the CLKDIV field in the WWDTCTL0 register. The default CLKDIV setting is 0x03 (32 kHz divided by 4, or 8 kHz). By running from the LFCLK, the WWDT time base is independent of the main clock (MCLK) and CPU clock (CPUCLK) time base, provided that these clocks are not also configured to be running from the LFCLK. While the time base may be considered as independent and derived from a separate oscillator source, LFCLK edges are synchronized to the MCLK before sourcing the WWDT to enable simple access to the memory-mapped registers from application software. A simplified view of the clock scheme is given in Figure 19-3. In Figure 19-3, the internal LFOSC is configured to set the LFCLK rate, and the internal SYSOSC sets the MCLK/CPUCLK rate. Clock selection muxes and dividers are excluded from the figure to simplify the view; the complete clock tree is provided in Section 2.3.3. Figure 19-3. WWDT Simplified Clock Source Tree In the event that the MCLK fails and synchronization of the LFCLK to the MCLK is lost, this failure may be detected by enabling the continuous MCLK monitor. When the MCLK monitor is enabled, a loss of MCLK is always a catastrophic failure which generates a BOOTRST within 12 LFCLK cycles. As a result, a loss of the MCLK tree, and corresponding loss of synchronization, does not prevent a BOOTRST from being generated. #### **Period Selection** The WWDT has a 25-bit counter which is initially stopped after a SYSRST. The WWDT period (total time interval) is set by the PER field in the WWDTCTL0 register. The total WWDT period is calculated as follows: $$T_{WWDT} = (CLKDIV + 1) * PER_{COUNT} / 32768 Hz$$ (18) The total timer count PER<sub>COUNT</sub> is selected to be one of 8 possible period count values, with the encoding given in Table 19-1. **PER** 0x0 0x1 0x2 0x3 0x4 0x5 0x6 0x7 PERCOUNT 225 221 218 215 2<sup>12</sup> 2<sup>10</sup> 26 Table 19-1. WWDT Period Total Timer Count The combination of the period selection (PER) and clock divider (CLKDIV) enable a wide range of WWDT periods, from as short as 1.95 ms to as long as 136.53 minutes. Table 19-2 gives all possible WWDT periods for a given combination of PER and CLKDIV. **Table 19-2. WWDT Period Timing Options** | | PER | | | | | | | | | | |----------|-------|------|------|------|------|-------|------|------|--|--| | CLKDIV | 0x0 | 0x1 | 0x2 | 0x3 | 0x4 | 0x5 | 0x6 | 0x7 | | | | | min | min | s | s | s | ms | ms | ms | | | | 0x0 (/1) | 17.07 | 1.07 | 8.00 | 1.00 | 0.13 | 31.25 | 7.81 | 1.95 | | | www.ti.com WWDT **Table 19-2. WWDT Period Timing Options (continued)** | | PER | | | | | | | | | |----------|--------|------|-------|------|------|--------|-------|-------|--| | CLKDIV | 0x0 | 0x1 | 0x2 | 0x3 | 0x4 | 0x5 | 0x6 | 0x7 | | | | min | min | s | s | s | ms | ms | ms | | | 0x1 (/2) | 34.13 | 2.13 | 16.00 | 2.00 | 0.25 | 62.50 | 15.63 | 3.91 | | | 0x2 (/3) | 51.20 | 3.20 | 24.00 | 3.00 | 0.38 | 93.75 | 23.44 | 5.86 | | | 0x3 (/4) | 68.27 | 4.27 | 32.00 | 4.00 | 0.50 | 125.00 | 32.25 | 7.81 | | | 0x4 (/5) | 85.33 | 5.33 | 40.00 | 5.00 | 0.63 | 156.25 | 39.06 | 9.77 | | | 0x5 (/6) | 102.40 | 6.40 | 48.00 | 6.00 | 0.75 | 187.50 | 46.88 | 11.72 | | | 0x6 (/7) | 119.47 | 7.47 | 56.00 | 7.00 | 0.88 | 218.75 | 54.69 | 13.67 | | | 0x7 (/8) | 136.53 | 8.53 | 64.00 | 8.00 | 1.00 | 250.00 | 62.50 | 15.63 | | #### Synchronization Delay When starting or re-starting the WWDT counter, a maximum synchronization delay of one 32 kHz clock cycle (30.5µs) can occur before the WWDT counter begins counting from zero. The periods given in Table 19-2 do not include this synchronization delay. #### **Closed Window Selection** Configuration of two closed window periods is supported by setting the WINDOW0 and WINDOW1 fields in the WWDTCTL0 register. The WINSEL bit in the WWDTCTL1 register determines the active window (either WINDOW0 or WINDOW1). Either window can be set to one of 8 possible window settings. Table 19-3. WWDT Window Options | WINDOW | 0x0 | 0x1 | 0x2 | 0x3 | 0x4 | 0x5 | 0x6 | 0x7 | |---------------|-----|-------|--------|-----|-----|-----|--------|-------| | Closed window | 0% | 12.5% | 18.75% | 25% | 50% | 75% | 81.25% | 87.5% | Setting a WINDOWx value to 0x0 (0% closed, 100% open) is equivalent to disabling the window function of the WWDT. In this configuration, the WWDT can be restarted at any point during the WWDT period. The active window selection can be changed after the WWDT has been enabled. When the WWDT is restarted by writing to the WWDTCNTRST register, the closed window selection (WINSEL) must not be changed for at least four 32-kHz clock cycles (≈122 µs). #### 19.2.3 Low-Power Mode Behavior The WWDT counter can be configured to continue counting when the device is in a low-power mode (CPU is disabled) or to continue to run when the device is in a low-power mode. The STISM bit in the WWDTCTL0 register controls if the WWDT counter stops counting in sleep mode. By default, the STISM bit is cleared, indicating that the WWDT continues to count in low-power modes. To stop the WWDT from counting in low-power modes, set the STISM bit when loading the WWDTCTL0 configuration to start the WWDT. In this case, when the low-power mode is exited and the CPU returns to operation, the WWDT counter resumes counting from the same value it held before entering the low-power mode. #### 19.2.4 Debug Behavior The WWDT can be configured to stop counting or continue counting when the CPU is halted for debug by the debug subsystem. By default, the WWDT stops counting when the CPU is halted for debug and the device is in a debug state. To allow the WWDT to continue to free run when the CPU is stopped for debug, set the FREE bit in the PDBGCTL register. #### 19.2.5 WWDT Events The WWDT module contains one event publisher and no event subscribers. One event publisher (CPU\_INT) manages WWDT interrupt requests (IRQs) to the CPU subsystem through a static event route. **WWDT** www.ti.com The WWDT events are summarized in Table 19-4. #### Table 19-4. WWDT Events | Event | Туре | Source | Destination | Route | Configuration | Functionality | |---------------|-----------|--------|---------------|--------------|---------------|----------------------------| | CPU Interrupt | Publisher | WWDT | CPU Subsystem | Static route | | Fixed interrupt route from | | Event | | | | | registers | WWDT to CPU | # 19.2.5.1 CPU Interrupt Event Publisher (CPU\_INT) The WWDT module provides one interrupt source which can be configured to source a CPU interrupt event. The WWDT interrupt conditions are given in Table 19-5. Table 19-5. WWDT CPU Interrupt Conditions (CPU\_INT) | Index (IIDX) | Name | Description | |--------------|--------|-----------------------------------------------------------| | 0 | INTTIM | Indicates that the WWDT interval timer period has expired | The CPU interrupt event configuration is managed with the CPU\_INT event management registers. See Section 6.2.5 for guidance on configuring the Event registers for CPU interrupts. www.ti.com WWDT # 19.3 WWDT Registers Table 19-6 lists the memory-mapped registers for the WWDT registers. All register offset addresses not listed in Table 19-6 should be considered as reserved locations and the register contents should not be modified. **Table 19-6. WWDT Registers** | Offset | Acronym | Register Name | Section | |--------|------------|-------------------------------------------------|-----------------| | 800h | PWREN | Power enable | Section 19.3.1 | | 804h | RSTCTL | Reset Control | Section 19.3.2 | | 814h | STAT | Status Register | Section 19.3.3 | | 1018h | PDBGCTL | Peripheral Debug Control | Section 19.3.4 | | 1020h | IIDX | Interrupt index | Section 19.3.5 | | 1028h | IMASK | Interrupt mask | Section 19.3.6 | | 1030h | RIS | Raw interrupt status | Section 19.3.7 | | 1038h | MIS | Masked interrupt status | Section 19.3.8 | | 1040h | ISET | Interrupt set | Section 19.3.9 | | 1048h | ICLR | Interrupt clear | Section 19.3.10 | | 10E0h | EVT_MODE | Event Mode | Section 19.3.11 | | 10FCh | DESC | Module Description | Section 19.3.12 | | 1100h | WWDTCTL0 | Window Watchdog Timer Control Register 0 | Section 19.3.13 | | 1104h | WWDTCTL1 | Window Watchdog Timer Control Register 0 | Section 19.3.14 | | 1108h | WWDTCNTRST | Window Watchdog Timer Counter Reset<br>Register | Section 19.3.15 | | 110Ch | WWDTSTAT | Window Watchdog Timer Status Register | Section 19.3.16 | Complex bit access types are encoded to fit into small table cells. Table 19-7 shows the codes that are used for access types in this section. Table 19-7. WWDT Access Type Codes | 145.0 10 11111217100000 1760 00400 | | | | | | | | |------------------------------------|------------------------|----------------------------------------|--|--|--|--|--| | Access Type | Code | Description | | | | | | | Read Type | Read Type | | | | | | | | R | R | Read | | | | | | | Write Type | | | | | | | | | K | К | Write protected by a key | | | | | | | W | W | Write | | | | | | | WK | W<br>K | Write<br>Write protected by a key | | | | | | | Reset or Defaul | Reset or Default Value | | | | | | | | -n | | Value after reset or the default value | | | | | | WWDT www.ti.com # 19.3.1 PWREN Register (Offset = 800h) [Reset = 00000000h] PWREN is shown in Figure 19-4 and described in Table 19-8. Return to the Summary Table. Register to control the power state # Figure 19-4. PWREN Register # Table 19-8. PWREN Register Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-24 | KEY | W | 0h | KEY to allow Power State Change<br>26h = KEY to allow write access to this register | | 23-1 | RESERVED | R/W | 0h | | | 0 | ENABLE | К | 0h | Enable the power Note: For safety devices the power cannot be disabled once enabled. KEY must be set to 26h to write to this bit. 0h = Disable Power 1h = Enable Power | www.ti.com WWDT # 19.3.2 RSTCTL Register (Offset = 804h) [Reset = 00000000h] RSTCTL is shown in Figure 19-5 and described in Table 19-9. Return to the Summary Table. Register to control reset assertion and de-assertion # Figure 19-5. RSTCTL Register Table 19-9. RSTCTL Register Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|--------------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-24 | KEY | W | 0h | Unlock key B1h = KEY to allow write access to this register | | 23-2 | RESERVED | W | 0h | | | 1 | RESETSTKYCLR | WK | 0h | Clear RESETSTKY KEY must be set to B1h to write to this bit. 0h = Writing 0 has no effect 1h = Clear reset sticky bit | | 0 | RESETASSERT | WK | Oh | Assert reset to the peripheral Note: For safety devices a watchdog reset by software is not possible. KEY must be set to B1h to write to this bit. Oh = Writing 0 has no effect 1h = Assert reset | WWDT www.ti.com # 19.3.3 STAT Register (Offset = 814h) [Reset = 00000000h] STAT is shown in Figure 19-6 and described in Table 19-10. Return to the Summary Table. peripheral enable and reset status # Figure 19-6. STAT Register #### Table 19-10. STAT Register Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|-----------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-17 | RESERVED | R | 0h | | | 16 | RESETSTKY | R | 0h | This bit indicates, if the peripheral was reset, since this bit was cleared by RESETSTKYCLR in the RSTCTL register 0h = The peripheral has not been reset since this bit was last cleared by RESETSTKYCLR in the RSTCTL register 1h = The peripheral was reset since the last bit clear | | 15-0 | RESERVED | R | 0h | | www.ti.com WWDT # 19.3.4 PDBGCTL Register (Offset = 1018h) [Reset = 00000000h] PDBGCTL is shown in Figure 19-7 and described in Table 19-11. Return to the Summary Table. This register can be used by the software developer to control the behavior of the peripheral relative to the 'Core Halted' input Figure 19-7. PDBGCTL Register #### Table 19-11. PDBGCTL Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-1 | RESERVED | R/W | 0h | | | 0 | FREE | R/W | | Free run control 0h = The peripheral freezes functionality while the Core Halted input is asserted and resumes when it is deasserted. 1h = The peripheral ignores the state of the Core Halted input | WWDT www.ti.com # 19.3.5 IIDX Register (Offset = 1020h) [Reset = 00000000h] IIDX is shown in Figure 19-8 and described in Table 19-12. Return to the Summary Table. This register provides the highest priority enabled interrupt index. #### Figure 19-8. IIDX Register #### Table 19-12. IIDX Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-5 | RESERVED | R | 0h | | | 4-0 | STAT | R | Oh | Module Interrupt Vector Value. This register provides the highest priority interrupt index. A read clears the corresponding interrupt flag in RIS and MISC. 0h = No interrupt pending 1h = Interval Timer Interrupt; Interrupt Flag: INTTIM; Interrupt Priority: Highest | www.ti.com WWDT # 19.3.6 IMASK Register (Offset = 1028h) [Reset = 00000000h] IMASK is shown in Figure 19-9 and described in Table 19-13. Return to the Summary Table. Interrupt Mask. If a bit is set, then corresponding interrupt is un-masked. Un-masking the interrupt causes the raw interrupt to be visible in IIDX, as well as MIS." Figure 19-9. IMASK Register ## Table 19-13. IMASK Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|-----------------------------------------------------------------------------| | 31-1 | RESERVED | R/W | 0h | | | 0 | INTTIM | R/W | | Interval Timer Interrupt. 0h = Clear Interrupt Mask 1h = Set Interrupt Mask | WWDT www.ti.com # 19.3.7 RIS Register (Offset = 1030h) [Reset = 00000000h] RIS is shown in Figure 19-10 and described in Table 19-14. Return to the Summary Table. Raw interrupt status. Reflects all pending interrupts, regardless of masking. The RIS register allows the user to implement a poll scheme. A flag set in this register can be cleared by writing 1 to the ICLR register bit even if the corresponding IMASK bit is not enabled. Figure 19-10. RIS Register ### Table 19-14. RIS Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|----------------------------------------------------------------------------------| | 31-1 | RESERVED | R | 0h | | | 0 | INTTIM | R | | Interval Timer Interrupt. 0h = Interrupt did not occur 1h = Interrupt occurred | www.ti.com WWDT # 19.3.8 MIS Register (Offset = 1038h) [Reset = 00000000h] MIS is shown in Figure 19-11 and described in Table 19-15. Return to the Summary Table. Masked interrupt status. This is an AND of the IMASK and RIS registers. # Figure 19-11. MIS Register # **Table 19-15. MIS Register Field Descriptions** | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|--------------------------------------------------------------------------------| | 31-1 | RESERVED | R | 0h | | | 0 | INTTIM | R | | Interval Timer Interrupt. 0h = Interrupt did not occur 1h = Interrupt occurred | WWDT www.ti.com # 19.3.9 ISET Register (Offset = 1040h) [Reset = 00000000h] ISET is shown in Figure 19-12 and described in Table 19-16. Return to the Summary Table. Interrupt set. Allows interrupts to be set by software (useful in diagnostics and safety checks). Writing a 1 to a bit in ISET will set the event and therefore the related RIS bit also gets set. If the interrupt is enabled through the mask, then the corresponding MIS bit is also set. Figure 19-12. ISET Register ## Table 19-16. ISET Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|----------------------------------------------------------------------------| | 31-1 | RESERVED | W | 0h | | | 0 | INTTIM | W | 0h | Interval Timer Interrupt. 0h = Writing 0 has no effect 1h = Set Interrupt | www.ti.com WWDT # 19.3.10 ICLR Register (Offset = 1048h) [Reset = 00000000h] ICLR is shown in Figure 19-13 and described in Table 19-17. Return to the Summary Table. Interrupt clear. Write a 1 to clear corresponding Interrupt. # Figure 19-13. ICLR Register # Table 19-17. ICLR Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|-----------------------------------------------------------------------------| | 31-1 | RESERVED | W | 0h | | | 0 | INTTIM | W | | Interval Timer Interrupt. 0h = Writing 0 has no effect 1h = Clear Interrupt | WWDT www.ti.com # 19.3.11 EVT\_MODE Register (Offset = 10E0h) [Reset = 00000001h] EVT\_MODE is shown in Figure 19-14 and described in Table 19-18. Return to the Summary Table. Event mode register. It is used to select whether each line is disabled, in software mode (software clears the RIS) or in hardware mode (hardware clears the RIS) Figure 19-14. EVT\_MODE Register # Table 19-18. EVT\_MODE Register Field Descriptions | _ | | | | | _ <del></del> | |---|------|----------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | Bit | Field | Туре | Reset | Description | | | 31-2 | RESERVED | R/W | 0h | | | | 1-0 | INT0_CFG | R | 1h | Event line mode select for event corresponding to none.INT_EVENT[0] 0h = The interrupt or event line is disabled. 1h = The interrupt or event line is in software mode. Software must clear the RIS. 2h = The interrupt or event line is in hardware mode. The hardware (another module) clears automatically the associated RIS flag. | www.ti.com WWDT # 19.3.12 DESC Register (Offset = 10FCh) [Reset = 1F117010h] DESC is shown in Figure 19-15 and described in Table 19-19. Return to the Summary Table. This register identifies the peripheral and its exact version. # Figure 19-15. DESC Register # Table 19-19. DESC Register Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|------------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-16 | MODULEID | R | 1F11h | Module identification contains a unique peripheral identification number. The assignments are maintained in a central database for all of the platform modules to ensure uniqueness. 0h = Smallest value FFFFh = Highest possible value | | 15-12 | FEATUREVER | R | 7h | Feature Set for the module *instance* 0h = Smallest value Fh = Highest possible value | | 11-8 | INSTNUM | R | 0h | Instance Number within the device. This will be a parameter to the RTL for modules that can have multiple instances 0h = Smallest value Fh = Highest possible value | | 7-4 | MAJREV | R | 1h | Major rev of the IP 0h = Smallest value Fh = Highest possible value | | 3-0 | MINREV | R | 0h | Minor rev of the IP 0h = Smallest value Fh = Highest possible value | WWDT www.ti.com # 19.3.13 WWDTCTL0 Register (Offset = 1100h) [Reset = 00000043h] WWDTCTL0 is shown in Figure 19-16 and described in Table 19-20. Return to the Summary Table. Window Watchdog Timer Control 0 Register NOTE: Write to this register is enabled after System Reset. The first successful write (key match) enables the Watchdog. When the watchdog is enabled all subsequent writes to this register activate the WWDT error signal to the ESM. Figure 19-16. WWDTCTL0 Register | rigate to te. WWD to Le Register | | | | | | | | | | |----------------------------------|----------------|---------|----|----------|----|---------|--------|--|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | KEY | | | | | | | | | | | W-0h | | | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | RESERVED STISM | | | | | | MODE | | | | | R/W-0h | | | | | R/W-0h | R/W-0h | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | RESERVED | | WINDOW1 | | RESERVED | | WINDOW0 | | | | | R/W-0h | | R/W-0h | | R/W-0h | | R/W-0h | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | RESERVED | | PER | | RESERVED | | CLKDIV | | | | | R/W-0h | | R/W-4h | | R/W-0h | | R/W-3h | | | | ### Table 19-20. WWDTCTL0 Register Field Descriptions | Table 10 20. Title 10 120 Register Flora 2000 Phone | | | | | | | | |-----------------------------------------------------|----------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | 31-24 | KEY | W | 0h | KEY to allow write access to this register. Writing to this register with an incorrect key activates the WWDT error signal to the ESM. Read as 0. C9h (W) = KEY to allow write access to this register | | | | | 23-18 | RESERVED | R/W | 0h | | | | | | 17 | STISM | R/W | Oh | Stop In Sleep Mode. The functionality of this bit requires that POLICY.HWCEN = 0. If POLICY.HWCEN = 1 the WWDT resets during sleep and needs re-configuration. Note: This bit has no effect for the global Window Watchdog as Sleep Mode is not supported. 0h = The WWDT continues to function in Sleep mode. 1h = The WWDT stops in Sleep mode and resumes where it was stopped after wakeup. | | | | | 16 | MODE | R/W | 0h | Window Watchdog Timer Mode 0h = Window Watchdog Timer Mode. The WWDT will generate a error signal to the ESM when following conditions occur: - Timer Expiration (Timeout) - Reset WWDT during the active window closed period - Keyword violation 1h = Interval Timer Mode. The WWDT acts as an interval timer. It generates an interrupt on timeout. | | | | | 15 | RESERVED | R/W | 0h | | | | | WWDT www.ti.com # Table 19-20. WWDTCTL0 Register Field Descriptions (continued) | Bit | Field | Туре | Reset | Description (continued) | |-------|----------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 14-12 | WINDOW1 | R/W | Oh | Closed window period in percentage of the timer interval. WWDTCTL1.WINSEL determines the active window setting (WWDTCTL0.WINDOW0 or WWDTCTL0.WINDOW1). 0h = 0% (No closed Window) 1h = 12.50% of the total timer period is closed window 2h = 18.75% of the total timer period is closed window 3h = 25% of the total timer period is closed window 4h = 50% of the total timer period is closed window 5h = 75% of the total timer period is closed window 6h = 81.25% of the total timer period is closed window 7h = 87.50% of the total timer period is closed window | | 11 | RESERVED | R/W | 0h | | | 10-8 | WINDOW0 | R/W | Oh | Closed window period in percentage of the timer interval. WWDTCTL1.WINSEL determines the active window setting (WWDTCTL0.WINDOW0 or WWDTCTL0.WINDOW1). 0h = 0% (No closed Window) 1h = 12.50% of the total timer period is closed window 2h = 18.75% of the total timer period is closed window 3h = 25% of the total timer period is closed window 4h = 50% of the total timer period is closed window 5h = 75% of the total timer period is closed window 6h = 81.25% of the total timer period is closed window 7h = 87.50% of the total timer period is closed window | | 7 | RESERVED | R/W | 0h | | | 6-4 | PER | R/W | 4h | Timer Period of the WWDT. These bits select the total watchdog timer count. $0h = \text{Total timer count is } 2^{25}$ $1h = \text{Total timer count is } 2^{21}$ $2h = \text{Total timer count is } 2^{18}$ $3h = \text{Total timer count is } 2^{15}$ $4h = \text{Total timer count is } 2^{12} \text{ (default)}$ $5h = \text{Total timer count is } 2^{10}$ $6h = \text{Total timer count is } 2^{8}$ $7h = \text{Total timer count is } 2^{6}$ | | 3 | RESERVED | R/W | 0h | | | 2-0 | CLKDIV | R/W | 3h | Module Clock Divider, Divide the clock source by CLKDIV+1. Divider values from /1 to /8 are possible. The clock divider is currently 4 bits. Bit 4 has no effect and should always be written with 0. 0h = Minimum value 7h = Maximum value | WWDT www.ti.com # 19.3.14 WWDTCTL1 Register (Offset = 1104h) [Reset = 00000000h] WWDTCTL1 is shown in Figure 19-17 and described in Table 19-21. Return to the Summary Table. Window Watchdog Timer Control 1 Register # Figure 19-17. WWDTCTL1 Register # Table 19-21. WWDTCTL1 Register Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-24 | KEY | W | 0h | KEY to allow write access to this register. Writing to this register with an incorrect key activates the WWDT error signal to the ESM. Read as 0. BEh (W) = KEY to allow write access to this register | | 23-1 | RESERVED | R/W | 0h | | | 0 | WINSEL | R/W | 0h | Close Window Select 0h = In window mode field WINDOW0 of WDDTCTL0 defines the closed window size. 1h = In window mode field WINDOW1 of WDDTCTL0 defines the closed window size. | www.ti.com WWDT # 19.3.15 WWDTCNTRST Register (Offset = 1108h) [Reset = 00000000h] WWDTCNTRST is shown in Figure 19-18 and described in Table 19-22. Return to the Summary Table. Window Watchdog Timer Counter Restart Register # Figure 19-18. WWDTCNTRST Register # Table 19-22. WWDTCNTRST Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|---------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-0 | RESTART | R/W | | Window Watchdog Timer Counter Restart Writing 00A7h to this register restarts the WWDT Counter. Writing any other value causes an error generation to the ESM. Read as 0. 0h = Minimum value FFFFFFFFh = Maximum value | WWDT www.ti.com # 19.3.16 WWDTSTAT Register (Offset = 110Ch) [Reset = 00000000h] WWDTSTAT is shown in Figure 19-19 and described in Table 19-23. Return to the Summary Table. Window Watchdog Timer Status Register A write to this register has no effect. # Figure 19-19. WWDTSTAT Register # Table 19-23. WWDTSTAT Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|-------------------------------------------------------------------------------------| | 31-1 | RESERVED | R | 0h | | | 0 | RUN | R | | Watchdog running status flag. 0h = Watchdog counter stopped. 1h = Watchdog running. | # Chapter 20 Debug The debug subsystem (DEBUGSS) is implemented in all MSPM0 devices. The DEBUGSS enables comprehensive debug of application software running on the processor during development by interfacing an external debug probe to the device systems through a serial wire debug (SWD) interface. | 20.1 Overview | 1094 | |----------------------------------|------| | 20.2 Debug Features | 1096 | | 20.3 Behavior in Low Power Modes | | | 20.4 Restricting Debug Access | 1098 | | 20.5 Mailbox (DSSM) | | | | | ### 20.1 Overview The debug subsystem (DEBUGSS) interfaces the serial wire debug (SWD) two-wire physical interface to multiple debug functions within the device. MSPM0 devices support debugging of processor execution, the device state, and the power state (through EnergyTrace technology). The DEBUGSS also provides a mailbox system for communicating with software through SWD. Key features provided by the debug subsystem include: - Two-wire (SWDIO, SWCLK) debug interface, compatible with both TI and 3<sup>rd</sup> party debug probes - On-chip pullup/pulldown resistors for SWDIO and SWCLK, respectively, enabled by default - Support for disabling SWD functions to use SWD pins as general purpose input/output pins - Capability of waking the device from SHUTDOWN mode upon valid SWD activity - · Debug of the processor - Run, halt, and step debug support - 4 hardware breakpoints (BPU) - 2 hardware watchpoints (DWT) - Unlimited software breakpoints - Software-configurable peripheral behavior during processor debug - Ability to free run select peripherals through debug halt - Ability to halt select peripherals on a debug halt - Ability to request reset and mode changes to the PMCU - Monitoring of CPU state through EnergyTrace+ technology - Mailbox (DSSM) for passing data and control signals between the SWD interface and boot ROM (as well as application software) - · Support for various security features, including SWD lockout and password authenticated debugging ### 20.1.1 Debug Interconnect The DEBUGSS architecture is given in Figure 20-1. Figure 20-1. Debug Sub System Block Diagram The SWD physical interface interacts with the Arm serial wire debug port (SW-DP) to gain access to the debug access port bus interconnect (DAPBUSIC) when the SW-DP is enabled. From TI, devices ship with the SW-DP enabled to allow SWD access to the device for development and production programming, but the SW-DP can be configured to be permanently disabled through the boot configuration policy (see Section 20.4). The DAPBUSIC enables a debug probe to access one or more debug access ports. For a debug probe to be able to communicate with an access port, the SW-DP debug port must not be disabled by the device boot configuration policy, and the target access port must also not be disabled by the boot configuration policy. The available access ports are given in Section 20.1.3. The SWD and SW-DP also contain signaling to the PMCU module to support debug-generated resets and operating mode changes (see Section 20.3). ### 20.1.2 Physical Interface Debug connections to the device are supported through an Arm serial wire debug (SWD) compliant interface. The SWD interface requires two connections: - A bidirectional data line (SWDIO) used to send data to, and receive data from, the device - · A unidirectional clock line (SWCLK) driven by the debug probe connecting to the device The SWD interface uses the standard logic levels of the device for SWD communication. See the device-specific data sheet for input and output logic levels for a given supply voltage (VDD). A SWCLK frequency of up to 10MHz is supported by the DEBUGSS. During SWD operation, the SWDIO line can be driven high or driven low by either the target device or the debug probe. As either device can drive the line, when ownership of the shared SWDIO line is switched between the device and the debug probe, undriven time slots are inserted as a part of the SWD protocol. The primary purpose of the pullup resistor on the SWDIO line, and the pulldown resistor on the SWCLK line, is to place the SWD pins into a known state when no debug probe is attached. A minimum resistance of $100k\Omega$ is recommended by Arm. The internal pullup/pulldown resistors fulfill this requirement and external resistors are not required for correct operation of the SWD interface. After a power-on reset (POR), MSPM0 devices configure the SWD pins in SWD mode with an internal pullup resistor enabled on the SWDIO line and an internal pulldown resistor enabled on the SWCLK line. If the device configuration has not permanently disabled all SWD access, then the SWD interface is enabled during the boot process and a debug probe can be connected to the DEBUGSS. In the event that a device was configured by software to enter SHUTDOWN mode, and a debug probe is then connected to the SWD pins with SWCLK active, wakeup logic will trigger an exit from SHUTDOWN mode and cause a BOR. A debug connection can then be established to the DEBUGSS after the BOR completes. Upon physical connection of a debug probe, a configuration sequence must be sent from the debug probe to the target device to initiate a valid SWD connection with the SW-DP. An invalid sequence will not wake the device from SHUTDOWN mode. Once the sequence is applied and the SWD connection is established, communication with enabled debug access points is possible and the application code is alerted through assertion of the DEBUGSS PWRUPIFG interrupt. When the debug probe is disconnected and the SWD connection is lost, the PWRDWNIFG interrupt is asserted. It is possible for application software to disable the SWD interface in SYSCTL, freeing the IO to be used for general purpose IO functionality. Review Section 2.4.1.4 in SYSCTL for using the SWD pins for functionality other than SWD. Once software disables SWD functionality, it is not possible to re-enable it other than by triggering a POR. A POR will automatically re-enable the SWD functionality and put the SWD pins into SWD mode with pullup/pulldown resistors enabled. To re-gain debug access to a device which contains software that disables the SWD pins at startup, it is necessary to hold the device in a reset state with the NRST pin during a POR. This will prevent the application software from starting and will allow the debug probe to gain access to the device, at which point a mass erase DSSM command can be sent from the integrated development environemnt to the device via the debug probe to remove the application software which is disabling the SWD pins. ### Note BOR, BOOTRST, and SYSRST levels do reset the IOMUX logic, which will re-enable the pullup/pulldown resistors on the SWDIO/SWCLK pin. However, the SWD functionality remains disabled until the next POR. Because the device always powers up with the SWDIO pullup and SWCLK pulldown resistors enabled, the hardware design must accommodate this when using the SWD pins for functions other than SWD after startup. After reset, application software may disable the pullup/pulldown resistors in the IOMUX to free the SWD pins for other purposes. ### 20.1.3 Debug Access Ports The debug access ports in the DEBUGSS are given in Table 20-1. | APSEL | AP | Port Description | Purpose | |-------|--------|---------------------------|-----------------------------------------------------------------| | 0x0 | AHB-AP | MCPUSS debug access port | Debug of the processor and peripherals | | 0x1 | CFG-AP | Configuration access port | Access device type information | | 0x2 | SEC-AP | Security access port | Access the debug mailbox (DSSM) | | 0x3 | ET-AP | EnergyTrace™ access port | Read EnergyTrace power state data for power aware debug | | 0x4 | PWR-AP | Power access port | Configure the device power states (interfaces with PMCU/SYSCTL) | The AHB-AP, PWR-AP, and ET-AP provide the complete device debug functionality (processor debug, peripheral and memory bus access, power state control, and processor state). See Section 20.2 for more information. The CFG-AP provides device information to the debug probe so that the debug probe can identify device characteristics, including the device part number and the device revision. The SEC-AP provides access to the mailbox for communicating with software running on the device through SWD. See Section 20.5 for more information. ### 20.2 Debug Features The DEBUGSS supports processor debug, processor trace, peripheral debug, and energy state debug. ### 20.2.1 Processor Debug The Arm Cortex-M0+ processor supports a wide range of features to simplify debugging of application software during development. Key features supported by MSPM0 MCUs include: - Ability to halt the processor through a assertion of a halt signal, a configured debug event (such as a hard fault entry or reset), or a BKPT instruction (for software breakpoints) - Ability to step through instructions (with or without peripheral interrupts enabled) - Ability to run through instructions (with or without peripheral interrupts enabled) - Ability to read and write CPU registers when halted - Ability to read exception information through the Cortex-M0+ system control space (SCS) - Support for 4 hardware breakpoints - Support for 2 hardware watchpoints - Support for accessing the device memory map ### 20.2.1.1 Breakpoint Unit (BPU) The breakpoint unit (BPU) provides 4 comparators which can be used to generate a debug event when the address of an instruction fetch matches the address programmed into the respective BPU comparator. The BPU does not generate a debug event upon an address match for a data read or data write access. Address matching is possible for half-word (16-bit) instructions and word (32-bit) instructions fetched from the CODE region (0x0000.0000 to 0x1FFF.FFFF). If a debug scenario requires more than four breakpoints, software breakpoints can be used together with hardware breakpoints using the BKPT instruction. If debugging of code in the SRAM region is desired, hardware breakpoints are not available and software breakpoints must be inserted by the debug probe instead. ``` // Example of a breakpoint function in C (TI Arm CLANG compiler) __BKPT(0); ``` ### 20.2.1.2 Data Watchpoint and Trace Unit (DWT) The data watchpoint and trace unit (DWT) provides 2 comparators which both support generating an event upon a data address match (watchpoint event) or an instruction address match (PC watchpoint event). The DWT comparators support masking of the address, enabling an event to be generated when the processor attempts to access an address within a specified address range. ### 20.2.2 Peripheral Debug In addition to processor debug, the DEBUGSS can be used to access the device memory map from the perspective of the processor. Thus, a connected debug probe can be used to read and write memory-mapped peripheral registers, the system SRAM, and the flash memory. Certain peripherals support advanced debug configuration options. These options are configured by application software (or optionally, the debug probe) by setting/clearing various debug control bits in the memory map of a given peripheral. In general, the debug behavior of a particular peripheral is specified in the PDBGCTL register of each peripheral. Many peripherals offer the option of halting the functional clock to the peripheral when the processor is halted for debug, thus pausing the peripheral together with the processor (default configuration), or letting the peripheral run even when the processor is halted for debug. For example, the WWDT peripheral supports the FREE bit in the PDBGCTL register. Setting the FREE bit in PDBGCTL for a WWDT causes the WWDT counter to run even if the processor is halted for debug. ### 20.2.3 EnergyTrace The DEBUGSS in MSPM0 devices supports EnergyTrace technology. EnergyTrace technology enables power profiling of MCU devices running application code. This is very useful when developing an application which must be optimized for low-power operation. Development tools from Texas Instruments, including the MSPM0 LaunchPad development tools, support hardware energy measurement of the target MSPM0 over time through EnergyTrace charge counting. This mechanism enables a developer to obtain an energy usage profile for an application, based on real current measurements with a wide dynamic range. To give context to the energy measurements made by the hardware development tools supporting EnergyTrace, MSPM0 MCUs also enable EnergyTrace+. EnergyTrace+ is a component of the DEBUGSS which enables the debug probe to log the state of the processor (RUN, SLEEP) and the current program counter value while the device is running. This state information can be then overlaid with energy measurements to determine if the cause of high current is the processor running, or some other activity on the device. TI's Code Composer Studio integrated development environment provides out-of-the-box support for EnergyTrace energy measurement and EnergyTrace+ processor state logging with MSPM0 devices. ### 20.3 Behavior in Low Power Modes The DEBUGSS supports maintaining a debug connection through SWD in all operating modes except SHUTDOWN. Access to device memory and peripherals is possible in RUN mode and SLEEP mode, in which a debug probe can be actively connected to the AHB-AP access port to interface with the processor. In STOP and STANDBY modes, a debug connection can be established and/or maintained with the DEBUGSS, but not with the CPU debug access port. In SHUTDOWN mode, any active debug connection is terminated as the debug logic is powered down with the device VCORE. While a debug connection to the DEBUGSS is not possible while the device is in SHUTDOWN mode, a debug probe can cause the device to exit SHUTDOWN mode by attempting to communicate with the SWD pins. The device will detect attempted SWD communication even when the device is in SHUTDOWN. If activity is detected, a SHUTDOWN exit is initiated and the device will transition through a BOR state, after which a debug connection can be made to the DEBUGSS through SWD. The DEBUGSS functionality by operating mode is given in Table 20-2. | Table 20-2. DEBUGS | S Functionality by | Operating Mode | |--------------------|--------------------|----------------| |--------------------|--------------------|----------------| | Capability | RUN | SLEEP | STOP | STANDBY | SHUTDOWN | NRST HOLD | |----------------------------|-----|-------|------|---------|----------|-----------| | Processor debug | Y | Y | N | N | N | N | | Memory map access | Y | Y | N | N | N | N | | Debug status through SW-DP | Υ | Y | Y | Y | N | Y | | Debug state maintained | Y | Y | Y | Y | N | N | | Wake from SWD | - | - | - | - | Y | - | ### 20.4 Restricting Debug Access The debug subsystem supports several methods for restricting access to the device through the SWD interface. The debug access policy is determined by the user configuration specified in the NONMAIN flash region. There are 3 levels of access control, given in Table 20-3. By default, products shipped from TI arrive in a "debug enabled" state where the device is fully open. This state is not recommended for production. For production, TI recommends changing the debug configuration to password protected or disabled. Table 20-3. Debug Access Control | Table 20-3. Debug Access Control | | | | | | |----------------------------------|-------------------------|--------------------------------|----------------|--|--| | DEBUGSS Function | Debug Configuration | | | | | | | Debug Enabled (default) | Debug Enabled with<br>Password | Debug Disabled | | | | SW-DP (debug port) | EN | EN | DIS | | | | CFG-AP | EN | EN | DIS | | | | SEC-AP | EN | EN | DIS | | | | ET-AP | EN | EN w/ PW | DIS | | | | AHB-AP (CPU Debug) | EN | EN w/ PW | DIS | | | When debug is enabled with password, the debug access command together with the user-specified debug access password must be provided to the DEBUGSS mailbox by the debug probe, and a BOOTRST must be issued. When debug is disabled, the SW-DP will be disabled during the boot process and any commands previously sent to the mailbox are ignored during boot. Following boot, any attempt to connect to the SW-DP is ignored. It is possible to permanently lock debug access to the device by configuring the NONMAIN flash region to disable debug access while also configuring the NONMAIN flash region as statically write protected (locked). Locking the NONMAIN configuration has the added security of preventing the bootstrap loader (BSL) and application code from changing the debug security policy. ### 20.5 Mailbox (DSSM) The debug subsystem mailbox (DSSM) enables a debug probe to pass messages to the target device through the SWD interface, as well as making it possible for the target device to return data to the debug probe. The DSSM supports the following functions: - Transmission of commands to the device during boot, including authenticating the debug probe for passwordprotected debug, mass erase, and factory reset operations - Communicating with application software running on the target device when no other communication interface is present Two 32-bit word data buffers are provided for TX data (debug probe to target device) and RX data (target device to debug probe). These data buffers are implemented as 32-bit memory-mapped registers in the DEBUGSS. In addition, TXCTL and RXCTL registers are provided for enabling flow control and indicating status of the mailbox. | DSSM<br>Register | Description | Debug Probe | Target Device | Actions | |------------------|-------------------------|-------------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------| | TX_DATA | Data buffer | RW | R | TXCTL.TRANSMIT is set on write by the debug probe, and cleared on a read by the target device; TXIFG is also set on a write by the debug probe | | TXCTL | Flow control and status | RW | R | None | | RX_DATA | Data buffer | R | RW | RXCTL.RECEIVE is set on write by the target device, and cleared on a read by the debug probe; RXIFG is also set on a write by the target device | | RXCTL | Flow control and status | R | RW | None | The TXCTL and RXCTL registers provide TRANSMIT and RECEIVE flags, respectively, in the BIT0 position. The TRANSMIT bit is set in the TXCTL register when a debug probe writes data to the TX\_DATA buffer register. The TRANSMIT flag will then remain set until the target device reads TX\_DATA or a POR occurs. The RECEIVE flag is set in the RXCTL register when the target device writes data to the RX\_DATA buffer register. The RECEIVE flag will then remain set until the debug probe reads the data from RX\_DATA. It is not possible for software running on the target device to write to TX\_DATA, and it is also not possible for target software to clear the TRANSMIT flag other than by reading TX\_DATA. The upper 31 bits of the TXCTL register contain generic flag bits which can be set or cleared by the debug probe to implement a protocol if desired. Only the debug probe can write to the TRANSMIT\_FLAGS field in TXCTL. In a similar way, only the target device software can write to RX\_DATA and RXCTL. The debug probe cannot write to RX\_DATA and it can only clear the RECEIVE flag in RXCTL by reading RX\_DATA. BIT1 through BIT7 (0xFE) of RXCTL contains the RECEIVE\_FLAGS field. Software on the target device can set or clear bits in the RECEIVE\_FLAGS field to implement a protocol if desired. These flags can be read by the debug probe but can not be modified by the debug probe. For a complete listing of DSSM commands which are supported by the boot configuration routine during device startup configuration, see Section 1.4. ### 20.5.1 DSSM Events The DSSM contains one event publisher and no event subscribers. One event publisher (CPU\_INT) manages DSSM interrupt requests (IRQs) to the CPU subsystem through a static event route. The DSSM events are summarized in Table 20-5. #### Table 20-5. DSSM Events | Event | Туре | Source | Destination | Route | Configuration | Functionality | |---------------|-----------|---------|---------------|--------------|---------------|----------------------------| | CPU Interrupt | Publisher | DEBUGSS | CPU Subsystem | Static route | _ | Fixed interrupt route from | | Event | | | | | registers | DEBUGSS to CPU | # 20.5.1.1 CPU Interrupt Event (CPU\_INT) The DSSM provides 4 interrupt sources which can be configured to source a CPU interrupt event. In order of decreasing interrupt priority, the CPU interrupt events from the DSSM are given in Table 20-6. Table 20-6. DSSM CPU Interrupt Event Conditions (CPU INT) | Index (IIDX) | Name | Description | |--------------|-------|------------------------------------------------------------------| | 0 | TXIFG | Indicates that the TX_DATA buffer in the DSSM has received data. | # Table 20-6. DSSM CPU Interrupt Event Conditions (CPU\_INT) (continued) | Index (IIDX) | Name | Description | |--------------|-----------|--------------------------------------------------------------------------------------------| | 1 | RXIFG | Indicates that the data in RX_DATA buffer in the DSSM was read. | | 2 | PWRUPIFG | Indicates that the DEBUGSS was started due to a debug probe attaching to the device. | | 3 | PWRDWNIFG | Indicates that the DEBUGSS was stopped due to a debug probe disconnecting from the device. | The CPU interrupt event configuration is managed with the CPU\_INT event management registers. See Section 6.2.5 for guidance on configuring the Event registers for CPU interrupts. # 20.5.2 DEBUGSS Registers Table 20-7 lists the memory-mapped registers for the DEBUGSS registers. All register offset addresses not listed in Table 20-7 should be considered as reserved locations and the register contents should not be modified. Table 20-7. DEBUGSS Registers | Offset | Acronym | Register Name | Group | Section | | |--------|--------------|-----------------------------------------|---------|---------|--| | 1020h | IIDX | Interrupt index | CPU_INT | Go | | | 1028h | IMASK | Interrupt mask | CPU_INT | Go | | | 1030h | RIS | Raw interrupt status | CPU_INT | Go | | | 1038h | MIS | Masked interrupt status | CPU_INT | Go | | | 1040h | ISET | Interrupt set | CPU_INT | Go | | | 1048h | ICLR | Interrupt clear | CPU_INT | Go | | | 10E0h | EVT_MODE | Event Mode | | Go | | | 10FCh | DESC | Module Description Go | | | | | 1100h | TXD | Transmit data register | | Go | | | 1104h | TXCTL | Transmit control register | | Go | | | 1108h | RXD | Receive data register | | Go | | | 110Ch | RXCTL | Receive control register Go | | | | | 1200h | SPECIAL_AUTH | Special enable authorization register | | Go | | | 1210h | APP_AUTH | Application CPU0 authorization register | | Go | | Complex bit access types are encoded to fit into small table cells. Table 20-8 shows the codes that are used for access types in this section. Table 20-8. DEBUGSS Access Type Codes | Access Type | Code | Description | | | | | | |------------------------|------------------------|----------------------------------------|--|--|--|--|--| | Read Type | Read Type | | | | | | | | R | R | Read | | | | | | | R-0 | R | Read | | | | | | | | -0 | Returns 0s | | | | | | | Write Type | | | | | | | | | W | W | Write | | | | | | | WK | W | Write | | | | | | | | K | Write protected by a key | | | | | | | Reset or Default Value | Reset or Default Value | | | | | | | | -n | | Value after reset or the default value | | | | | | # 20.5.2.1 IIDX (Offset = 1020h) [Reset = 00000000h] IIDX is shown in Figure 20-2 and described in Table 20-9. Return to the Summary Table. This register provides the highest priority enabled interrupt index. 0xFF means no event pending. Interrupt 0x0 is the highest priority, 0x1 next highest, and 0xFE is the least priority. The priority order is fixed. However, users can implement their own prioritization schemes using other registers that expose the full set of interrupts that have occurred. On each read, only one interrupt is indicated. On a read, the current interrupt (highest priority) is automatically cleared by the hardware and the corresponding interrupt flag in the RIS and MIS are cleared as well. After a read from the CPU (not from the debug interface), the register must be updated with the next highest priority interrupt, if none are pending, then it displays 0xFF. ### Figure 20-2. IIDX ### Table 20-9. IIDX Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-8 | RESERVED | R | 0h | | | 7-0 | STAT | R | 0h | Interrupt index status 0h = No pending interrupt request 1h = TX interrupt 2h = RX interrupt 3h = Power-up interrupt. A debug session has started. 4h = Power-up interrupt. A debug session has started. | # 20.5.2.2 IMASK (Offset = 1028h) [Reset = 00000000h] IMASK is shown in Figure 20-3 and described in Table 20-10. Return to the Summary Table. Interrupt Mask. If a bit is set, then corresponding interrupt is un-masked. Un-masking the interrupt causes the raw interrupt to be visible in IIDX, as well as MIS. Figure 20-3. IMASK ### **Table 20-10. IMASK Field Descriptions** | Bit | Field | Туре | Reset | Description | |------|-----------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-4 | RESERVED | R/W | 0h | | | 3 | PWRDWNIFG | R/W | 0h | Masks PWRDWNIFG in MIS register 0h = Interrupt is masked out 1h = Interrupt will request an interrupt service routine and corresponding bit in MIS will be set | | 2 | PWRUPIFG | R/W | 0h | Masks PWRUPIFG in MIS register 0h = Interrupt is masked out 1h = Interrupt will request an interrupt service routine and corresponding bit in MIS will be set | | 1 | RXIFG | R/W | 0h | Masks RXIFG in MIS register 0h = Interrupt is masked out 1h = Interrupt will request an interrupt service routine and corresponding bit in MIS will be set | | 0 | TXIFG | R/W | 0h | Masks TXIFG in MIS register 0h = Interrupt is masked out 1h = Interrupt will request an interrupt service routine and corresponding bit in MIS will be set | # 20.5.2.3 RIS (Offset = 1030h) [Reset = 00000000h] RIS is shown in Figure 20-4 and described in Table 20-11. Return to the Summary Table. Raw interrupt status. Reflects all pending interrupts, regardless of masking. The RIS register allows the user to implement a poll scheme. A flag set in this register can be cleared by writing 1 to the ICLR register bit even if the corresponding IMASK bit is not enabled. Figure 20-4. RIS ### **Table 20-11. RIS Field Descriptions** | Bit | Field | Туре | Reset | Description | |------|-----------|------|-------|-----------------------------------------------------------------------------------------| | 31-4 | RESERVED | R | 0h | | | 3 | PWRDWNIFG | R | 0h | Raw interrupt status for PWRDWNIFG 0h = PWRUPIFG did not occur 1h = PWRUPIFG occurred | | 2 | PWRUPIFG | R | 0h | Raw interrupt status for PWRUPIFG 0h = PWRUPIFG did not occur 1h = PWRUPIFG occurred | | 1 | RXIFG | R | Oh | Raw interrupt status for RXIFG 0h = RXIFG did not occur 1h = RXIFG occurred | | 0 | TXIFG | R | 0h | Raw interrupt status for TXIFG 0h = TXIFG did not occur 1h = TXIFG occurred | # 20.5.2.4 MIS (Offset = 1038h) [Reset = 00000000h] MIS is shown in Figure 20-5 and described in Table 20-12. Return to the Summary Table. Masked interrupt status. This is an AND of the IMASK and RIS registers. # Figure 20-5. MIS | | | | 9 | | | | | |------|----------|------|------|-----------|----------|-------|-------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | RESE | RVED | | | | | | R-0h | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | RESERVED | | | | | | | | R-0h | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | RESE | RVED | | | | | | | | R | -0h | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | RESE | RVED | | PWRDWNIFG | PWRUPIFG | RXIFG | TXIFG | | | R-0 | Oh | | R-0h | R-0h | R-0h | R-0h | # Table 20-12. MIS Field Descriptions | Bit | Field | Туре | Reset | Description | |------|-----------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-4 | RESERVED | R | 0h | | | 3 | PWRDWNIFG | R | 0h | Masked interrupt status for PWRDWNIFG 0h = PWRUPIFG did not request an interrupt service routine 1h = PWRUPIFG requests an interrupt service routine | | 2 | PWRUPIFG | R | 0h | Masked interrupt status for PWRUPIFG 0h = PWRUPIFG did not request an interrupt service routine 1h = PWRUPIFG requests an interrupt service routine | | 1 | RXIFG | R | Oh | Masked interrupt status for RXIFG 0h = RXIFG did not request an interrupt service routine 1h = RXIFG requests an interrupt service routine | | 0 | TXIFG | R | Oh | Masked interrupt status for TXIFG 0h = TXIFG did not request an interrupt service routine 1h = TXIFG requests an interrupt service routine | # 20.5.2.5 ISET (Offset = 1040h) [Reset = 00000000h] ISET is shown in Figure 20-6 and described in Table 20-13. Return to the Summary Table. Interrupt set. Allows interrupts to be set by software (useful in diagnostics and safety checks). Writing a 1 to a bit in ISET will set the event and therefore the related RIS bit also gets set. If the interrupt is enabled through the mask, then the corresponding MIS bit is also set. Figure 20-6. ISET # Table 20-13. ISET Field Descriptions | | | i leid Descriptions | | | |------|-----------|---------------------|-------|-------------------------------------------------------------------------------------------------------------| | Bit | Field | Туре | Reset | Description | | 31-4 | RESERVED | W | 0h | | | 3 | PWRDWNIFG | W | Oh | Sets PWRDWNIFG in RIS register 0h = Writing a 0 has no effect 1h = RIS bit corresponding to PWRUPIFG is set | | 2 | PWRUPIFG | W | Oh | Sets PWRUPIFG in RIS register 0h = Writing a 0 has no effect 1h = RIS bit corresponding to PWRUPIFG is set | | 1 | RXIFG | W | Oh | Sets RXIFG in RIS register 0h = Writing a 0 has no effect 1h = RIS bit corresponding to RXIFG is set | | 0 | TXIFG | W | Oh | Sets TXIFG in RIS register 0h = Writing a 0 has no effect 1h = RIS bit corresponding to TXIFG is set | # 20.5.2.6 ICLR (Offset = 1048h) [Reset = 00000000h] ICLR is shown in Figure 20-7 and described in Table 20-14. Return to the Summary Table. Interrupt clear. Write a 1 to clear corresponding Interrupt. # Figure 20-7. ICLR | | | | 9 | 0 / O E | | | | |------|----------|------|------|-----------|----------|-------|-------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | RESE | RVED | | | | | | W-0h | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | RESERVED | | | | | | | | W-0h | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | RESE | RVED | | | | | | | | W | '-0h | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | RESE | RVED | | PWRDWNIFG | PWRUPIFG | RXIFG | TXIFG | | | W- | 0h | | W-0h | W-0h | W-0h | W-0h | # Table 20-14. ICLR Field Descriptions | Bit | Field | Туре | Reset | Description | |------|-----------|------|-------|-------------------------------------------------------------------------------------------------------------------| | 31-4 | RESERVED | W | 0h | | | 3 | PWRDWNIFG | W | 0h | Clears PWRDWNIFG in RIS register 0h = Writing a 0 has no effect 1h = RIS bit corresponding to PWRUPIFG is cleared | | 2 | PWRUPIFG | W | 0h | Clears PWRUPIFG in RIS register 0h = Writing a 0 has no effect 1h = RIS bit corresponding to PWRUPIFG is cleared | | 1 | RXIFG | W | 0h | Clears RXIFG in RIS register 0h = Writing a 0 has no effect 1h = RIS bit corresponding to RXIFG is cleared | | 0 | TXIFG | W | 0h | Clears TXIFG in RIS register 0h = Writing a 0 has no effect 1h = RIS bit corresponding to TXIFG is cleared | # 20.5.2.7 EVT\_MODE (Offset = 10E0h) [Reset = 00000001h] EVT\_MODE is shown in Figure 20-8 and described in Table 20-15. Return to the Summary Table. Event mode register. It is used to select whether each line is disabled, in software mode (software clears the RIS) or in hardware mode (hardware clears the RIS) Figure 20-8. EVT\_MODE # Table 20-15. EVT\_MODE Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-2 | RESERVED | R | 0h | | | 1-0 | INT0_CFG | R | 1h | Event line mode select for peripheral events 0h = The interrupt or event line is disabled. 1h = The interrupt or event line is in software mode. Software must clear the RIS. 2h = The interrupt or event line is in hardware mode. The hardware (another module) clears automatically the associated RIS flag. | # 20.5.2.8 DESC (Offset = 10FCh) [Reset = 03400000h] DESC is shown in Figure 20-9 and described in Table 20-16. Return to the Summary Table. This register identifies the peripheral and its exact version. # Figure 20-9. DESC # **Table 20-16. DESC Field Descriptions** | 14410 20 101 2 200 1 1014 2 000 1 philosop | | | | | | |--------------------------------------------|------------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | Bit | Field | Туре | Reset | Description | | | 31-16 | MODULEID | R | 340h | Module identification contains a unique peripheral identification number. The assignments are maintained in a central database for all of the platform modules to ensure uniqueness. | | | 15-12 | FEATUREVER | R | 0h | Feature Set for the module *instance* | | | 11-8 | INSTNUM | R | 0h | Instance Number within the device. This will be a parameter to the RTL for modules that can have multiple instances | | | 7-4 | MAJREV | R | 0h | Major rev of the IP | | | 3-0 | MINREV | R | 0h | Minor rev of the IP | | # 20.5.2.9 TXD (Offset = 1100h) [Reset = 00000000h] TXD is shown in Figure 20-10 and described in Table 20-17. Return to the Summary Table. This register is used for data transfers from external debug tools to the DSSM module. The register is written by the debug tool and read by the CPU. # Figure 20-10. TXD ## **Table 20-17. TXD Field Descriptions** | Bit | Field | Туре | Reset | Description | |------|---------|------|-------|---------------------------------------------------------------| | 31-0 | TX_DATA | R | 0h | Contains data written by an external debug tool to the SEC-AP | # 20.5.2.10 TXCTL (Offset = 1104h) [Reset = 00000000h] TXCTL is shown in Figure 20-11 and described in Table 20-18. Return to the Summary Table. Transmit control register # Figure 20-11. TXCTL | | | | 9 | | | | | |----|------|----|--------------|----------|----|----|----------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | TRANSM | IT_FLAGS | | | | | | | | R- | ·0h | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | TRANSM | IT_FLAGS | | | | | | R-0h | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | TRANSM | IT_FLAGS | | | | | | | | R- | ·0h | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | Т | RANSMIT_FLAG | S | | | TRANSMIT | | | | | R-0h | | | | R-0h | # **Table 20-18. TXCTL Field Descriptions** | Bit | Field | Туре | Reset | Description | |------|----------------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-1 | TRANSMIT_FLAGS | R | 0h | Generic TX flags that can be set by external debug tool. Functionality is defined by SW. | | 0 | TRANSMIT | R | Oh | Indicates data request in DSSM.TXD, set on write via Debug AP to DSSM.TXD. A read of the DSSM.TXD register by SW will clear the TX field. The tool can check that TXD is empty by reading this field. 0h = TXD is empty 1h = TXD is full | # 20.5.2.11 RXD (Offset = 1108h) [Reset = 00000000h] RXD is shown in Figure 20-12 and described in Table 20-19. Return to the Summary Table. Receive data register. This register contains the data written by the CPU. This data is read by external debug tool. # Figure 20-12. RXD # **Table 20-19. RXD Field Descriptions** | Bit | Field | Туре | Reset | Description | |------|---------|------|-------|---------------------------------| | 31-0 | RX_DATA | R/W | 0h | Contains data written by SM/OW. | www.ti.com \_\_\_\_\_\_ Debug # 20.5.2.12 RXCTL (Offset = 110Ch) [Reset = 00000000h] RXCTL is shown in Figure 20-13 and described in Table 20-20. Return to the Summary Table. Receive control register Figure 20-13. RXCTL # Table 20-20. RXCTL Field Descriptions | Bit | Field | Туре | Reset | Description | |------|---------------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-8 | RESERVED | R/W | 0h | | | 7-1 | RECEIVE_FLAGS | R/W | 0h | Generic RX flags that can be set by SW and read by external debug tool. Functionality is defined by SW. | | 0 | RECEIVE | R | 0h | Indicates SW write to the DSSM.RXD register. A read of the DSSM.RXD register by SWD Access Port will clear the RX field. 0h = RXD empty 1h = RXD full | # 20.5.2.13 SPECIAL\_AUTH (Offset = 1200h) [Reset = 00000013h] SPECIAL\_AUTH is shown in Figure 20-14 and described in Table 20-21. Return to the Summary Table. This register is used to control ET-AP, DFT-TAP, SWD, CFG-AP and SEC-AP. # Figure 20-14. SPECIAL AUTH | | | • • | gaic 20-17. 0 | ,, | •• | | | | |----------|----------|---------|---------------|--------|---------|-----------|---------|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | RESERVED | | | | | | | | | | R-0h | | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | RESERVED | | | | | | | | | | R-0h | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | RESERVED | | | | | | | | | | R-0h | | | | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | RESERVED | PWRAPEN | AHBAPEN | CFGAPEN | ETAPEN | DFTAPEN | SWDPORTEN | SECAPEN | | | R-0h | R-0h | R-0h | R-1h | R-0h | R-0h | R-1h | R-1h | | # Table 20-21. SPECIAL\_AUTH Field Descriptions | Bit | Field | Туре | Reset | Description | |------|-----------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-7 | RESERVED | R | 0h | | | 6 | PWRAPEN | R | Oh | An active high input. When asserted (and SWD access is also permitted), the debug tools can then access the PWR-AP to power and reset state of the CPU. When deasserted, a DAPBUS firewall will isolate the AP and prevent access. Oh = Disable PWR-AP 1h = Enable PWR-AP | | 5 | AHBAPEN | R | Oh | Disabling / enabling debug access to the M0+ Core via the AHB-AP DAP bus isolation. 0h = Disable AHB-AP 1h = Enable AHB-AP | | 4 | CFGAPEN | R | 1h | An active high input. When asserted (and SWD access is also permitted), the debug tools can use the Config-AP to read device configuration information. When deasserted, a DAPBUS firewall will isolate the AP and prevent access to the Config-AP. 0h = Disable CFG-AP 1h = Enable CFG-AP | | 3 | ETAPEN | R | Oh | An active high input. When asserted (and SWD access is also permitted), the debug tools can then access an ET-AP external to the DebugSS lite. When deasserted, a DAPBUS firewall will isolate the AP and prevent access. Oh = Disable ET+ -AP 1h = Enable ET+ -AP | | 2 | DFTAPEN | R | Oh | An active high input. When asserted (and SWD access is also permitted), the debug tools can then access the DFT-AP external to the DebugSS lite. When deasserted, a DAPBUS firewall will isolate the AP and prevent access. Oh = Disable DFT-TAP 1h = Enable DFT-TAP | | 1 | SWDPORTEN | R | 1h | When asserted, the SW-DP functions normally. When deasserted, the SW-DP effectively disables all external debug access. 0h = Disable SWD port 1h = Enable SWD port | # Table 20-21. SPECIAL\_AUTH Field Descriptions (continued) | Bit | Field | Туре | Reset | Description | |-----|---------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | SECAPEN | R | | An active high input. When asserted (and SWD access is also permitted), the debug tools can use the Security-AP to communicate with security control logic. When deasserted, a DAPBUS firewall will isolate the AP and prevent access to the Security-AP. 0h = Disable SEC-AP 1h = Enable SEC-AP | # 20.5.2.14 APP\_AUTH (Offset = 1210h) [Reset = 00000000h] APP\_AUTH is shown in Figure 20-15 and described in Table 20-22. Return to the Summary Table. This register is used to control DBGEN, NIDEN, SPIDEN, and SPNIDEN of Application CPU0. DBGEN, NIDEN are further processed by DSW based on Active and Debug IPF ID. Figure 20-15. APP\_AUTH # Table 20-22. APP\_AUTH Field Descriptions | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|--------------------------------------------------------------------------------------------------------| | 31-4 | RESERVED | R | 0h | | | 3 | SPNIDEN | R | Oh | Secure non-invasive debug enable. 0h = Invasive debug disabled 1h = Invasive debug enabled | | 2 | SPIDEN | R | Oh | Secure invasive debug enable. 0h = Invasive debug disabled 1h = Invasive debug enabled | | 1 | NIDEN | R | Oh | Controls non-invasive debug enable. 0h = Non-invasive debug disabled 1h = Non-invasive debug enabled | | 0 | DBGEN | R | 0h | Controls invasive debug enable. 0h = Invasive debug disabled 1h = Invasive debug enabled | NOTE: Page numbers for previous revisions may differ from page numbers in the current version. | DATE | REVISION | NOTES | |---------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | May 2023 | C | <ul> <li>Added group names for each event register group (CPU_INT, DMA_TRIGx, GEN_EVENTx) for modules with event generation capabilities and improved clarity of Events chapter</li> <li>Updated SYSOSC FCL description in PMCU chapter</li> <li>Added detailed SYSOSC user trim procedure in PMCU chapter</li> <li>Updated DMA chapter with detailed description of full and basic DMA channel types and capabilities</li> <li>Updated TIMG chapter with documentation improvements</li> <li>Improved description of SPI CSCLR functionality</li> <li>Updated CPU interrupt descriptions</li> <li>Updated architecture chapter diagrams to show DMA configuration registers as being DMA accessible</li> <li>Improved GPIO documentation on input synchronization and glitch filtering with specific examples</li> <li>Added note indicating that the temperature sensor is not available in STANDBY and SHUTDOWN modes</li> <li>Updated flash memory program and erase sequences</li> <li>Updated OPA difference amplifier naming</li> <li>Added note describing ADC aliased address range for MEMRES registers an clarifying ADC conversion control bits</li> <li>Standardized chapter formats for better readability</li> </ul> | | March 2023 | В | <ul> <li>Updated the SYSCTL and NONMAIN register table</li> <li>Updated the chapter Architecture, PMCU, TIMG, SPI, I2C, COMP and DMA</li> <li>Added ADC-assisted chopping, ADC hardware averaging</li> <li>Some notes added for ADC, nRST and OPA</li> <li>Clean up Event Manager routing map</li> </ul> | | November 2022 | Α | Initial Public Release | Revision History www.ti.com This page intentionally left blank. # IMPORTANT NOTICE AND DISCLAIMER TI PROVIDES TECHNICAL AND RELIABILITY DATA (INCLUDING DATA SHEETS), DESIGN RESOURCES (INCLUDING REFERENCE DESIGNS), APPLICATION OR OTHER DESIGN ADVICE, WEB TOOLS, SAFETY INFORMATION, AND OTHER RESOURCES "AS IS" AND WITH ALL FAULTS, AND DISCLAIMS ALL WARRANTIES, EXPRESS AND IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE OR NON-INFRINGEMENT OF THIRD PARTY INTELLECTUAL PROPERTY RIGHTS. These resources are intended for skilled developers designing with TI products. You are solely responsible for (1) selecting the appropriate TI products for your application, (2) designing, validating and testing your application, and (3) ensuring your application meets applicable standards, and any other safety, security, regulatory or other requirements. These resources are subject to change without notice. TI grants you permission to use these resources only for development of an application that uses the TI products described in the resource. Other reproduction and display of these resources is prohibited. No license is granted to any other TI intellectual property right or to any third party intellectual property right. TI disclaims responsibility for, and you will fully indemnify TI and its representatives against, any claims, damages, costs, losses, and liabilities arising out of your use of these resources. TI's products are provided subject to TI's Terms of Sale or other applicable terms available either on ti.com or provided in conjunction with such TI products. TI's provision of these resources does not expand or otherwise alter TI's applicable warranties or warranty disclaimers for TI products. TI objects to and rejects any additional or different terms you may have proposed. Mailing Address: Texas Instruments, Post Office Box 655303, Dallas, Texas 75265 Copyright © 2023, Texas Instruments Incorporated