# MSP430FR4xx and MSP430FR2xx family # **User's Guide** Literature Number: SLAU445I October 2014–Revised March 2019 ## **Contents** | Prefa | ice | | <b>27</b> | |-------|-------|-------------------------------------------------------------------------|------------| | 1 | Syste | em Resets, Interrupts, and Operating Modes, System Control Module (SYS) | 29 | | | 1.1 | System Control Module (SYS) Introduction | 30 | | | 1.2 | System Reset and Initialization | 30 | | | | 1.2.1 Device Initial Conditions After System Reset | 32 | | | 1.3 | Interrupts | 32 | | | | 1.3.1 (Non)Maskable Interrupts (NMIs) | 33 | | | | 1.3.2 SNMI Timing | 33 | | | | 1.3.3 Maskable Interrupts | 33 | | | | 1.3.4 Interrupt Processing | 33 | | | | 1.3.5 Interrupt Nesting | 35 | | | | 1.3.6 Interrupt Vectors | 35 | | | | 1.3.7 SYS Interrupt Vector Generators | 36 | | | 1.4 | Operating Modes | | | | | 1.4.1 Low-Power Modes and Clock Requests | 39 | | | | 1.4.2 Entering and Exiting Low-Power Modes LPM0 Through LPM4 | 40 | | | | 1.4.3 Low-Power Modes LPM3.5 and LPM4.5 (LPMx.5) | 40 | | | | 1.4.4 Extended Time in Low-Power Modes | 42 | | | 1.5 | Principles for Low-Power Applications | 43 | | | 1.6 | Connection of Unused Pins | 43 | | | 1.7 | Reset Pin (RST/NMI) Configuration | 43 | | | 1.8 | Configuring JTAG Pins | 44 | | | 1.9 | Memory Map – Uses and Abilities | 44 | | | | 1.9.1 Memory Map | 44 | | | | 1.9.2 Vacant Memory Space | 45 | | | | 1.9.3 FRAM Write Protection | 45 | | | | 1.9.4 Bootloader (BSL) | 45 | | | 1.10 | JTAG Mailbox (JMB) System | 46 | | | | 1.10.1 JMB Configuration | 46 | | | | 1.10.2 SYSJMBO0 and SYSJMBO1 Outgoing Mailbox | 46 | | | | 1.10.3 SYSJMBI0 and SYSJMBI1 Incoming Mailbox | 46 | | | | 1.10.4 JMB NMI Usage | 46 | | | 1.11 | Device Security | 47 | | | | 1.11.1 JTAG and SBW Lock Mechanism (Electronic Fuse) | 47 | | | | 1.11.2 BSL Security Mechanism | 47 | | | 1.12 | Device-Specific Configurations | 48 | | | | 1.12.1 MSP430FR413x and MSP430FR203x Configurations | 48 | | | | 1.12.2 MSP430FR2433 Configurations | <b>5</b> 0 | | | | 1.12.3 MSP430FR263x and MSP430FR253x Configurations | 51 | | | | 1.12.4 MSP430FR23xx Configurations | 52 | | | | 1.12.5 MSP430FR211x Configurations | 55 | | | 1.13 | Device Descriptor Table | 57 | | | | 1.13.1 Identifying Device Type | 58 | | | | 1.13.2 TLV Descriptors | | | | | 1.13.3 Calibration Values | 59 | | | 1.14 | SFR Re | egisters | 61 | |---|------------|---------|-------------------------------------------------------------|-----| | | | 1.14.1 | SFRIE1 Register (offset = 00h) [reset = 0000h] | 62 | | | | 1.14.2 | SFRIFG1 Register (offset = 02h) [reset = 0082h] | 63 | | | | 1.14.3 | SFRRPCR Register (offset = 04h) [reset = 001Ch] | 64 | | | 1.15 | SYS Re | egisters | 65 | | | | 1.15.1 | SYSCTL Register (offset = 00h) [reset = 0000h] | 66 | | | | 1.15.2 | SYSBSLC Register (offset = 02h) [reset = 0000h] | 67 | | | | 1.15.3 | SYSJMBC Register (offset = 06h) [reset = 000Ch] | 68 | | | | 1.15.4 | SYSJMBI0 Register (offset = 08h) [reset = 0000h] | 69 | | | | 1.15.5 | SYSJMBI1 Register (offset = 0Ah) [reset = 0000h] | 69 | | | | 1.15.6 | SYSJMBO0 Register (offset = 0Ch) [reset = 0000h] | 70 | | | | 1.15.7 | SYSJMBO1 Register (offset = 0Eh) [reset = 0000h] | 70 | | | | 1.15.8 | SYSUNIV Register (offset = 1Ah) [reset = 0000h] | | | | | 1.15.9 | SYSSNIV Register (offset = 1Ch) [reset = 0000h] | | | | | 1.15.10 | SYSRSTIV Register (offset = 1Eh) [reset = 0002h] | | | | 1.16 | | Configuration Registers | | | | | • | Smart Analog Combo Subfamily System Configuration Registers | | | | | 1.16.2 | | | | 2 | Powe | r Mana | gement Module (PMM) and Supply Voltage Supervisor (SVS) | | | _ | 2.1 | | Management Module (PMM) Introduction | | | | 2.2 | | Operation | | | | | | V <sub>CORF</sub> and the Regulator | | | | | | Supply Voltage Supervisor | | | | | | Supply Voltage Supervisor During Power-Up | | | | | | LPM3.5 and LPM4.5 (LPMx.5) | | | | | | Low-Power Reset | | | | | | Brownout Reset (BOR) | | | | | | LPM3.5 Switch | | | | | | Shared Reference Generation and Distribution | | | | | | Temperature Sensor | | | | | | RST/NMI. | | | | | 2.2.11 | PMM Interrupts | | | | | 2.2.12 | Port I/O Control | | | | 2.3 | | registers | | | | | | PMMCTL0 Register (offset = 00h) [reset = 9640h] | | | | | | PMMCTL1 Register (offset = 02h) [reset = 0000h] | | | | | | PMMCTL2 Register (offset = 04h) [reset = 0000h] | | | | | | PMMIE Register (offset = 0Eh) [reset = 0000h] (External) | | | | | | PMMIFG Register (offset = 0Ah) [reset = 0000h] (External) | | | | | | PM5CTL0 Register (offset = 10h) [reset = 0011h] | | | 3 | Clock | | m (CS) | | | 3 | | • | oduction | | | | 3.1<br>3.2 | | | 102 | | | 5.2 | | CS Module Features for Low-Power Applications | | | | | | Internal Very Low-Power Low-Frequency Oscillator (VLO) | | | | | | Internal Trimmed Low-Frequency Reference Oscillator (REFO) | | | | | | | 103 | | | | | | 103 | | | | | | 104 | | | | | | 104 | | | | | Disabling FLL Hardware and Modulator | | | | | | FLL Unlock Detection | | | | | | FLL Onlock Detection FLL Operation From Low-Power Modes | | | | | 3.2.10 | I LL Operation Flori Low-Fower Modes | 100 | | | | 3.2.11 | DCO Factory Trim and Software Trim | 106 | |---|--------|---------|-----------------------------------------------------------------|-----| | | | 3.2.12 | Operation From Low-Power Modes, Requested by Peripheral Modules | 108 | | | | 3.2.13 | Fail-Safe Operation | 109 | | | | 3.2.14 | Synchronization of Clock Signals | 111 | | | | 3.2.15 | Module Oscillator (MODOSC) | 111 | | | 3.3 | CS Re | gisters | 112 | | | | 3.3.1 | CSCTL0 Register | 113 | | | | 3.3.2 | CSCTL1 Register | 114 | | | | 3.3.3 | CSCTL2 Register | 115 | | | | 3.3.4 | CSCTL3 Register | 116 | | | | 3.3.5 | CSCTL4 Register | 117 | | | | 3.3.6 | CSCTL5 Register | | | | | 3.3.7 | CSCTL6 Register | 119 | | | | 3.3.8 | CSCTL7 Register | | | | | 3.3.9 | CSCTL8 Register | 123 | | 4 | CPUX | ζ | | 124 | | | 4.1 | MSP43 | 30X CPU (CPUX) Introduction | 125 | | | 4.2 | | ots | | | | 4.3 | | egisters | | | | | 4.3.1 | Program Counter (PC) | | | | | 4.3.2 | Stack Pointer (SP) | | | | | 4.3.3 | Status Register (SR) | | | | | 4.3.4 | Constant Generator Registers (CG1 and CG2) | | | | | 4.3.5 | General-Purpose Registers (R4 to R15) | | | | 4.4 | Addres | sing Modes | | | | | 4.4.1 | Register Mode | | | | | 4.4.2 | Indexed Mode | | | | | 4.4.3 | Symbolic Mode | 140 | | | | 4.4.4 | Absolute Mode | 145 | | | | 4.4.5 | Indirect Register Mode | 147 | | | | 4.4.6 | Indirect Autoincrement Mode | 148 | | | | 4.4.7 | Immediate Mode | 149 | | | 4.5 | MSP43 | 30 and MSP430X Instructions | 151 | | | | 4.5.1 | MSP430 Instructions | 151 | | | | 4.5.2 | MSP430X Extended Instructions | 156 | | | 4.6 | Instruc | tion Set Description | 167 | | | | 4.6.1 | Extended Instruction Binary Descriptions | 168 | | | | 4.6.2 | MSP430 Instructions | | | | | 4.6.3 | Extended Instructions | | | | | 4.6.4 | Address Instructions | | | 5 | Interr | unt Co | mpare Controller (ICC) | | | J | 5.1 | - | ot Compare Controller (ICC) Introduction | | | | 5.2 | - | peration | | | | 5.2 | 5.2.1 | Nested Interrupt and Non-Nested Interrupt Comparison | | | | | 5.2.2 | Interrupt Priority Levels | | | | | 5.2.3 | Interrupt Priority Level Comparison | | | | | 5.2.4 | Interrupt Compare Mask Update and Virtual Stack | | | | | 5.2.4 | Virtual Stack Push and Pop | | | | | 5.2.6 | Application Operation | | | | 5.3 | | Application Operationegisters | | | | 5.3 | | ICCSC Register (offset = 00h) [reset = 0023h] | | | | | 5.3.1 | • • • • • | | | | | 5.3.2 | ICCMVS Register (offset = 02h) [reset = 00FFh] | | | | | 5.3.3 | ICCILSR0 Register (offset = 04h) [reset = FFFFh] | 234 | | | | 5.3.4 | ICCILSR1 Register (offset = 06h) [reset = FFFFh] | | |---|-------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------| | | | 5.3.5 | ICCILSR2 Register (offset = 08h) [reset = FFFFh] | | | | | 5.3.6 | ICCILSR3 Register (offset = 0Ah) [reset = FFFFh] | | | | | 5.3.7 | ICCILSR4 Register (offset = 0Ch) [reset = FFFFh] | | | | | 5.3.8 | ICCILSR5 Register (offset = 0Eh) [reset = FFFFh] | | | | | 5.3.9 | ICCILSR6 Register (offset = 10h) [reset = FFFFh] | | | | | 5.3.10 | ICCILSR7 Register (offset = 12h) [reset = FFFFh] | 299 | | 6 | FRAM | M Conti | roller (FRCTL) | 300 | | | 6.1 | | Introduction | | | | 6.2 | FRAM | Organization | 301 | | | 6.3 | | _ Module Operation | | | | 6.4 | Progra | ımming FRAM Devices | 302 | | | | 6.4.1 | Programming FRAM Through JTAG or Spy-Bi-Wire | 302 | | | | 6.4.2 | | | | | | 6.4.3 | Programming FRAM Through a Custom Solution | | | | 6.5 | | tate Control | | | | | 6.5.1 | Wait State and Cache Hit | | | | 6.6 | FRAM | ECC | | | | 6.7 | | Write Back | | | | 6.8 | FRAM | Power Control | 303 | | | 6.9 | FRAM | Cache | | | | 6.10 | FRCTI | _ Registers | 305 | | | | | FRCTL0 Register | | | | | 6.10.2 | GCCTL0 Register | 307 | | | | 6.10.3 | GCCTL1 Register | 308 | | 7 | Back | | mory (BAKMEM) | | | • | Duon | ap ivici | 1101 y (DAINIEIII) | 000 | | | 7 1 | Backu | n Memory Introduction | 310 | | | 7.1<br>7.2 | | p Memory Introduction | | | 0 | 7.2 | BAKM | EM Registers | 310 | | 8 | 7.2<br><b>Digit</b> a | BAKM<br>al I/O | EM Registers | 310<br><b>311</b> | | 8 | 7.2<br><b>Digit</b> a<br>8.1 | BAKM<br>al I/O…<br>Digital | EM Registers | 310<br>311<br>312 | | 8 | 7.2<br><b>Digit</b> a | BAKM<br>al I/O<br>Digital<br>Digital | EM Registers I/O Introduction I/O Operation | 310<br>311<br>312<br>313 | | 8 | 7.2<br><b>Digit</b> a<br>8.1 | BAKM<br>al I/O<br>Digital<br>Digital<br>8.2.1 | EM Registers I/O Introduction I/O Operation Input Registers (PxIN) | 310<br>311<br>312<br>313<br>313 | | 8 | 7.2<br><b>Digit</b> a<br>8.1 | BAKM al I/O Digital Digital 8.2.1 8.2.2 | I/O Introduction | 310<br>311<br>312<br>313<br>313<br>313 | | 8 | 7.2<br><b>Digit</b> a<br>8.1 | BAKM<br>al I/O<br>Digital<br>Digital<br>8.2.1<br>8.2.2<br>8.2.3 | I/O Introduction | 310<br>311<br>312<br>313<br>313<br>313<br>313 | | 8 | 7.2<br><b>Digit</b> a<br>8.1 | BAKM al I/O Digital Digital 8.2.1 8.2.2 8.2.3 8.2.4 | I/O Introduction I/O Operation Input Registers (PxIN) Output Registers (PxOUT) Direction Registers (PxDIR) Pullup or Pulldown Resistor Enable Registers (PxREN) | 310<br>311<br>312<br>313<br>313<br>313<br>313 | | 8 | 7.2<br><b>Digit</b> a<br>8.1 | BAKM al I/O Digital Digital 8.2.1 8.2.2 8.2.3 8.2.4 8.2.5 | I/O Introduction I/O Operation Input Registers (PxIN) Output Registers (PxOUT) Direction Registers (PxDIR) Pullup or Pulldown Resistor Enable Registers (PxREN) Function Select Registers (PxSEL0, PxSEL1) | 310<br>311<br>312<br>313<br>313<br>313<br>313<br>314 | | 8 | 7.2<br><b>Digit</b> :<br>8.1<br>8.2 | BAKM al I/O Digital Digital 8.2.1 8.2.2 8.2.3 8.2.4 8.2.5 8.2.6 | I/O Introduction I/O Operation Input Registers (PxIN) Output Registers (PxOUT) Direction Registers (PxDIR) Pullup or Pulldown Resistor Enable Registers (PxREN) Function Select Registers (PxSEL0, PxSEL1) Port Interrupts | 310<br>311<br>312<br>313<br>313<br>313<br>313<br>314<br>314 | | 8 | 7.2<br><b>Digit</b> a<br>8.1 | BAKM Digital Digital 8.2.1 8.2.2 8.2.3 8.2.4 8.2.5 8.2.6 I/O Co | I/O Introduction I/O Operation Input Registers (PxIN) Output Registers (PxOUT) Direction Registers (PxDIR) Pullup or Pulldown Resistor Enable Registers (PxREN) Function Select Registers (PxSEL0, PxSEL1) Port Interrupts nfiguration | 310<br>311<br>312<br>313<br>313<br>313<br>314<br>314<br>314 | | 8 | 7.2<br><b>Digit</b> :<br>8.1<br>8.2 | BAKM Digital Digital 8.2.1 8.2.2 8.2.3 8.2.4 8.2.5 8.2.6 I/O Co 8.3.1 | I/O Introduction I/O Operation Input Registers (PxIN) Output Registers (PxOUT) Direction Registers (PxDIR) Pullup or Pulldown Resistor Enable Registers (PxREN) Function Select Registers (PxSEL0, PxSEL1) Port Interrupts Infiguration Configuration After Reset | 310<br>311<br>312<br>313<br>313<br>313<br>314<br>314<br>316<br>316 | | 8 | 7.2<br><b>Digit</b> :<br>8.1<br>8.2 | BAKM al I/O Digital B.2.1 8.2.2 8.2.3 8.2.4 8.2.5 8.2.6 I/O Co 8.3.1 8.3.2 | I/O Introduction I/O Operation Input Registers (PxIN). Output Registers (PxOUT). Direction Registers (PxDIR) Pullup or Pulldown Resistor Enable Registers (PxREN) Function Select Registers (PxSEL0, PxSEL1). Port Interrupts Infiguration Configuration After Reset Configuration of Unused Port Pins | 310<br>311<br>312<br>313<br>313<br>313<br>314<br>314<br>316<br>316<br>317 | | 8 | 7.2<br><b>Digit</b> :<br>8.1<br>8.2 | BAKM al I/O Digital B.2.1 8.2.2 8.2.3 8.2.4 8.2.5 8.2.6 I/O Co 8.3.1 8.3.2 8.3.3 | I/O Introduction I/O Operation Input Registers (PxIN) Output Registers (PxOUT) Direction Registers (PxDIR) Pullup or Pulldown Resistor Enable Registers (PxREN) Function Select Registers (PxSEL0, PxSEL1) Port Interrupts Infiguration Configuration After Reset Configuration of Unused Port Pins Configuration for LPMx.5 Low-Power Modes | 310<br>311<br>312<br>313<br>313<br>313<br>314<br>314<br>316<br>316<br>317<br>317 | | 8 | 7.2<br><b>Digit</b> :<br>8.1<br>8.2 | BAKM al I/O Digital Digital 8.2.1 8.2.2 8.2.3 8.2.4 8.2.5 8.2.6 I/O Co 8.3.1 8.3.2 8.3.3 Digital | I/O Introduction I/O Operation Input Registers (PxIN) Output Registers (PxOUT) Direction Registers (PxDIR) Pullup or Pulldown Resistor Enable Registers (PxREN) Function Select Registers (PxSEL0, PxSEL1) Port Interrupts Infiguration Configuration After Reset Configuration of Unused Port Pins Configuration for LPMx.5 Low-Power Modes I/O Registers | 310<br>311<br>312<br>313<br>313<br>313<br>314<br>314<br>316<br>316<br>317<br>317<br>317 | | 8 | 7.2<br><b>Digit</b> :<br>8.1<br>8.2 | BAKM al I/O Digital Digital 8.2.1 8.2.2 8.2.3 8.2.4 8.2.5 8.2.6 I/O Co 8.3.1 8.3.2 8.3.3 Digital 8.4.1 | I/O Introduction I/O Operation. Input Registers (PxIN). Output Registers (PxOUT). Direction Registers (PxDIR). Pullup or Pulldown Resistor Enable Registers (PxREN) Function Select Registers (PxSEL0, PxSEL1). Port Interrupts. Infiguration. Configuration After Reset. Configuration of Unused Port Pins Configuration for LPMx.5 Low-Power Modes I/O Registers. | 310<br>311<br>312<br>313<br>313<br>313<br>314<br>314<br>316<br>317<br>317<br>319<br>332 | | 8 | 7.2<br><b>Digit</b> :<br>8.1<br>8.2 | BAKM al I/O Digital B.2.1 8.2.2 8.2.3 8.2.4 8.2.5 8.2.6 I/O Co 8.3.1 8.3.2 8.3.3 Digital 8.4.1 8.4.2 | I/O Introduction I/O Operation Input Registers (PxIN). Output Registers (PxOUT). Direction Registers (PxDIR) Pullup or Pulldown Resistor Enable Registers (PxREN) Function Select Registers (PxSEL0, PxSEL1) Port Interrupts Infiguration Configuration After Reset Configuration of Unused Port Pins Configuration for LPMx.5 Low-Power Modes I/O Registers P1IV Register. P2IV Register. | 310<br>311<br>312<br>313<br>313<br>313<br>314<br>316<br>316<br>317<br>317<br>319<br>332<br>332 | | 8 | 7.2<br><b>Digit</b> :<br>8.1<br>8.2 | BAKM Digital Digital 8.2.1 8.2.2 8.2.3 8.2.4 8.2.5 8.2.6 I/O Co 8.3.1 8.3.2 8.3.3 Digital 8.4.1 8.4.2 8.4.3 | I/O Introduction I/O Operation Input Registers (PxIN) Output Registers (PxOUT) Direction Registers (PxDIR) Pullup or Pulldown Resistor Enable Registers (PxREN) Function Select Registers (PxSEL0, PxSEL1). Port Interrupts Infiguration Configuration After Reset Configuration of Unused Port Pins Configuration for LPMx.5 Low-Power Modes I/O Registers. P1IV Register P2IV Register P3IV Register | 310<br>311<br>312<br>313<br>313<br>313<br>314<br>314<br>316<br>317<br>317<br>319<br>332<br>332<br>333 | | 8 | 7.2<br><b>Digit</b> :<br>8.1<br>8.2 | BAKM al I/O Digital Digital 8.2.1 8.2.2 8.2.3 8.2.4 8.2.5 8.2.6 I/O Co 8.3.1 8.3.2 8.3.3 Digital 8.4.1 8.4.2 8.4.3 8.4.4 | I/O Introduction I/O Operation. Input Registers (PxIN). Output Registers (PxOUT). Direction Registers (PxDIR). Pullup or Pulldown Resistor Enable Registers (PxREN) Function Select Registers (PxSEL0, PxSEL1). Port Interrupts Infiguration. Configuration After Reset. Configuration of Unused Port Pins Configuration for LPMx.5 Low-Power Modes I/O Registers. P1IV Register. P2IV Register. P3IV Register. P3IV Register. | 310<br>311<br>312<br>313<br>313<br>313<br>314<br>314<br>316<br>317<br>317<br>319<br>332<br>333<br>333<br>333 | | 8 | 7.2<br><b>Digit</b> :<br>8.1<br>8.2 | BAKM al I/O Digital Digital 8.2.1 8.2.2 8.2.3 8.2.4 8.2.5 8.2.6 I/O Co 8.3.1 8.3.2 8.3.3 Digital 8.4.1 8.4.2 8.4.3 8.4.4 8.4.5 | I/O Introduction I/O Operation. Input Registers (PxIN). Output Registers (PxOUT). Direction Registers (PxDIR) Pullup or Pulldown Resistor Enable Registers (PxREN) Function Select Registers (PxSEL0, PxSEL1) Port Interrupts Infiguration Configuration After Reset Configuration of Unused Port Pins Configuration for LPMx.5 Low-Power Modes I/O Registers P1IV Register P2IV Register P3IV Register. P3IV Register. P4IV Register. P4IV Register. P4IV Register. | 310<br>311<br>312<br>313<br>313<br>313<br>314<br>314<br>316<br>317<br>317<br>319<br>332<br>333<br>333<br>333<br>334 | | 8 | 7.2<br><b>Digit</b> :<br>8.1<br>8.2 | BAKM al I/O Digital Digital 8.2.1 8.2.2 8.2.3 8.2.4 8.2.5 8.2.6 I/O Co 8.3.1 8.3.2 8.3.3 Digital 8.4.1 8.4.2 8.4.3 8.4.4 8.4.5 8.4.6 | I/O Introduction I/O Operation Input Registers (PxIN) Output Registers (PxOUT) Direction Registers (PxDIR) Pullup or Pulldown Resistor Enable Registers (PxREN) Function Select Registers (PxSEL0, PxSEL1) Port Interrupts Infiguration Configuration After Reset Configuration of Unused Port Pins Configuration for LPMx.5 Low-Power Modes I/O Registers P1IV Register P2IV Register P3IV Register. P4IV Register. P4IV Register. PXIN Register. PXIN Register. PXIN Register. | 310<br>311<br>312<br>313<br>313<br>313<br>314<br>316<br>316<br>317<br>317<br>319<br>332<br>333<br>334<br>334<br>334 | | 8 | 7.2<br><b>Digit</b> :<br>8.1<br>8.2 | BAKM al I/O Digital Digital 8.2.1 8.2.2 8.2.3 8.2.4 8.2.5 8.2.6 I/O Co 8.3.1 8.3.2 8.3.3 Digital 8.4.1 8.4.2 8.4.3 8.4.4 8.4.5 8.4.6 8.4.7 | EM Registers I/O Introduction I/O Operation Input Registers (PxIN). Output Registers (PxOUT). Direction Registers (PxDIR) Pullup or Pulldown Resistor Enable Registers (PxREN) Function Select Registers (PxSEL0, PxSEL1) Port Interrupts Infiguration Configuration After Reset. Configuration of Unused Port Pins Configuration for LPMx.5 Low-Power Modes I/O Registers P1IV Register. P2IV Register. P3IV Register. P4IV Register. PAIN Register. PXIN Register. PXOUT Register. PXDIR Register. PXDIR Register. | 310<br>311<br>312<br>313<br>313<br>313<br>314<br>314<br>316<br>317<br>317<br>319<br>332<br>332<br>333<br>334<br>334<br>334 | | 8 | 7.2<br><b>Digit</b> :<br>8.1<br>8.2 | BAKM al I/O Digital Digital 8.2.1 8.2.2 8.2.3 8.2.4 8.2.5 8.2.6 I/O Co 8.3.1 8.3.2 8.3.3 Digital 8.4.1 8.4.2 8.4.3 8.4.4 8.4.5 8.4.6 8.4.7 8.4.8 | EM Registers I/O Introduction I/O Operation Input Registers (PxIN). Output Registers (PxOUT). Direction Registers (PxDIR) Pullup or Pulldown Resistor Enable Registers (PxREN) Function Select Registers (PxSEL0, PxSEL1). Port Interrupts Infiguration Configuration After Reset. Configuration of Unused Port Pins Configuration for LPMx.5 Low-Power Modes I/O Registers P1IV Register. P2IV Register. P3IV Register. P4IV Register. PAIN Register. PXNI Register. PXDIR Register. PXDIR Register. PXREN Register. PXREN Register. | 310<br>311<br>312<br>313<br>313<br>313<br>314<br>314<br>316<br>317<br>317<br>319<br>332<br>332<br>333<br>334<br>334<br>334<br>334<br>335 | | 8 | 7.2<br><b>Digit</b> :<br>8.1<br>8.2 | BAKM al I/O Digital Digital 8.2.1 8.2.2 8.2.3 8.2.4 8.2.5 8.2.6 I/O Co 8.3.1 8.3.2 8.3.3 Digital 8.4.1 8.4.2 8.4.3 8.4.4 8.4.5 8.4.6 8.4.7 8.4.8 8.4.9 | EM Registers I/O Introduction I/O Operation Input Registers (PxIN) Output Registers (PxOUT) Direction Registers (PxDIR) Pullup or Pulldown Resistor Enable Registers (PxREN) Function Select Registers (PxSEL0, PxSEL1) Port Interrupts Infiguration Configuration After Reset Configuration of Unused Port Pins Configuration for LPMx.5 Low-Power Modes I/O Registers P1IV Register P3IV Register P3IV Register P4IV Register P4IV Register PXIN Register PxOUT Register PxOUT Register PxDIR Register PxREN Register PxREN Register PxSEL0 Register PxSEL0 Register PxSEL0 Register PxSEL0 Register PxSEL0 Register | 310<br>311<br>312<br>313<br>313<br>313<br>314<br>314<br>316<br>317<br>317<br>319<br>332<br>332<br>333<br>334<br>334<br>334<br>335<br>335 | | 8 | 7.2<br><b>Digit</b> :<br>8.1<br>8.2 | BAKM al I/O Digital Digital 8.2.1 8.2.2 8.2.3 8.2.4 8.2.5 8.2.6 I/O Co 8.3.1 8.3.2 8.3.3 Digital 8.4.1 8.4.2 8.4.3 8.4.4 8.4.5 8.4.6 8.4.7 8.4.8 | EM Registers I/O Introduction I/O Operation Input Registers (PxIN). Output Registers (PxOUT). Direction Registers (PxDIR) Pullup or Pulldown Resistor Enable Registers (PxREN) Function Select Registers (PxSEL0, PxSEL1). Port Interrupts Infiguration Configuration After Reset. Configuration of Unused Port Pins Configuration for LPMx.5 Low-Power Modes. I/O Registers. P1IV Register. P2IV Register. P3IV Register. P4IV Register. P4IV Register. PXIN Register. PXDIR Register. PxOUT Register. PxREN Register. PxSEL0 Register. PxSEL0 Register. PxSEL0 Register. PxSEL0 Register. | 310<br>311<br>312<br>313<br>313<br>313<br>314<br>316<br>317<br>317<br>319<br>332<br>333<br>334<br>334<br>335<br>335<br>335<br>335 | | | | | PxIES Register | | |----|------|-----------|----------------------------------------------------|-----| | | | 8.4.13 | PxIE Register | | | | | 8.4.14 | PxIFG Register | 337 | | 9 | Capa | citive To | ouch I/O | 338 | | | 9.1 | Capacit | tive Touch I/O Introduction | 339 | | | 9.2 | Capacit | tive Touch I/O Operation | 340 | | | 9.3 | CapTou | uch Registers | 341 | | | | 9.3.1 | CAPTIOxCTL Register (offset = 0Eh) [reset = 0000h] | 342 | | 10 | CapT | lvate™ | Module | 343 | | | 10.1 | | ate Introduction | | | | 10.2 | - | ate Overview | | | | | 10.2.1 | Declarations | | | | | 10.2.2 | Terms | | | | | | Operation Modes | | | | 10.3 | | ate Registers | | | | | 10.3.1 | CAPIE Register | | | | | 10.3.2 | CAPIFG Register | | | | | | CAPIV Register | | | 11 | CBC | | · · | | | | 11.1 | | Redundancy Check (CRC) Module Introduction | | | | 11.1 | - | tandard and Bit Order | | | | 11.2 | | hecksum Generation | | | | 11.3 | | CRC Implementation | | | | | | Assembler Examples | | | | 11.4 | | egisters | | | | 11.4 | | CRCDI Register | | | | | | CRCDIRB Register | | | | | 11.4.2 | CRCINIRES Register | | | | | _ | CRCRESR Register | | | | | | - | | | 12 | | _ | mer (WDT_A) | | | | 12.1 | _ | \ Introduction | | | | 12.2 | | A Operation | | | | | | Watchdog Timer Counter (WDTCNT) | | | | | 12.2.2 | | | | | | | Interval Timer Mode | | | | | | Watchdog Timer Interrupts | | | | | 12.2.5 | Clock Fail-Safe Feature | | | | | | Operation in Low-Power Modes | | | | 12.3 | | Registers | | | | | 12.3.1 | WDTCTL Register | 366 | | 13 | Time | r_A | | 367 | | | 13.1 | Timer_A | A Introduction | 368 | | | 13.2 | Timer_A | A Operation | 370 | | | | 13.2.1 | 16-Bit Timer Counter | 370 | | | | 13.2.2 | Starting the Timer | 370 | | | | 13.2.3 | Timer Mode Control | 371 | | | | 13.2.4 | | | | | | 13.2.5 | Output Unit | | | | | 13.2.6 | Timer_A Interrupts | | | | | 13.2.7 | Updating Timer_A Configuration | | | | 13.3 | Timer_/ | A Registers | | | | | | TAxCTL Register | | | | | 13.3.2 | TAxR Register | 385 | |----|-------|--------------|----------------------------------------------------|-----| | | | 13.3.3 | TAxCCTLn Register | | | | | 13.3.4 | TAxCCRn Register | 388 | | | | 13.3.5 | TAxIV Register | 388 | | | | 13.3.6 | TAxEX0 Register | | | 14 | Time | | | | | 17 | 14.1 | | B Introduction | | | | 14.1 | | Similarities and Differences From Timer_A | | | | 14.2 | | B Operation | | | | 14.2 | 14.2.1 | 16-Bit Timer Counter | | | | | 14.2.1 | Starting the Timer | | | | | 14.2.3 | Timer Mode Control | | | | | 14.2.4 | Capture/Compare Blocks | | | | | 14.2.5 | Output Unit | | | | | 14.2.5 | · | | | | | 14.2.7 | Timer_B Interrupts Updating Timer_B Configuration | | | | 14.3 | | B Registers | | | | 14.3 | | TBxCTL Register | | | | | 14.3.1 | · · · · · · · · · · · · · · · · · · · | | | | | 14.3.2 | TBxR Register | | | | | 14.3.3 | TBxCCTLn Register | | | | | 14.3.4 | TBxCCRn Register | | | | | 14.3.5 | TBxIV Register | | | | | | TBxEX0 Register | | | 15 | Real- | | lock (RTC) Counter | | | | 15.1 | | ounter Introduction | | | | 15.2 | RTC C | ounter Operation | | | | | 15.2.1 | 16-Bit Timer Counter | | | | | 15.2.2 | Clock Source Select and Divider | | | | | 15.2.3 | Modulo Register (RTCMOD) and Shadow Register | | | | | | RTC Counter Interrupt and External Event/Trigger | | | | 15.3 | RTC C | ounter Registers | | | | | 15.3.1 | RTCCTL Register | | | | | 15.3.2 | RTCIV Register | | | | | 15.3.3 | RTCMOD Register | 422 | | | | 15.3.4 | RTCCNT Register | 422 | | 16 | 32-Bi | t Hardw | vare Multiplier (MPY32) | 423 | | | 16.1 | | Hardware Multiplier (MPY32) Introduction | | | | 16.2 | | 2 Operation | | | | | 16.2.1 | Operand Registers | | | | | 16.2.2 | Result Registers | | | | | 16.2.3 | Software Examples | | | | | | Fractional Numbers | | | | | 16.2.5 | Putting It All Together | | | | | 16.2.6 | Indirect Addressing of Result Registers | | | | | 16.2.7 | Using Interrupts | | | | | 16.2.8 | Using DMA | | | | 16.3 | | Registers | | | | . 5.0 | | MPY32CTL0 Register | 440 | | 47 | 1.00 | | • | | | 17 | | _ | roller | 441 | | | 17.1 | <del>-</del> | Introduction | | | | 17.2 | | Operation | | | | | 17.2.1 | LCD Memory | 444 | | | | 17.2.2<br>17.2.3 | Configuration of Port Pin as LCD Output | | |----|----------|------------------|---------------------------------------------------------|-----| | | | 17.2.4 | LCD Timing Generation | | | | | 17.2.4 | · · | | | | | _ | Blanking the LCD | | | | | 17.2.6 | LCD Blinking | | | | | 17.2.7 | | | | | | 17.2.8 | LCD Operation Modes | | | | | | LCD Interrupts | | | | | 17.2.10 | Static Mode | | | | | 17.2.11 | | | | | | 17.2.12 | 2 3-Mux Mode | 463 | | | | 17.2.13 | 4-Mux Mode | 464 | | | | 17.2.14 | 6-Mux Mode | 465 | | | | 17.2.15 | 8-Mux Mode | 466 | | | 17.3 | LCD_E | Registers | 468 | | | | 17.3.1 | LCDCTL0 Register | 476 | | | | 17.3.2 | LCDCTL1 Register | 477 | | | | 17.3.3 | LCDBLKCTL Register | 478 | | | | 17.3.4 | LCDMEMCTL Register | 479 | | | | | LCDVCTL Register | | | | | | LCDPCTL0 Register | | | | | 17.3.7 | | | | | | 17.3.8 | LCDPCTL2 Register | | | | | | LCDPCTL3 Register | | | | | | LCDCSSEL0 Register | | | | | | LCDCSSEL1 Register | | | | | | LCDCSSEL2 Register | | | | | | LCDCSSEL3 Register | | | | | | LCDM[index] Register – Static, 2-Mux, 3-Mux, 4-Mux Mode | | | | | | LCDM[index] Register – 5-Mux, 6-Mux, 7-Mux, 8-Mux Mode | | | | | | LCDIV Register | | | 40 | <b>-</b> | | - | | | 18 | | | omparator (eCOMP) | | | | 18.1 | | P Introduction | | | | 18.2 | | Operation | | | | | | eCOMP | | | | | | Analog Input Switches | | | | | 18.2.3 | Output Analog Low-Pass Filter | | | | | 18.2.4 | eCOMP Built-in Dual Buffer 6-Bit DAC | 506 | | | 18.3 | eCOMF | Interrupts | 507 | | | 18.4 | eCOMF | P Registers | 508 | | | | 18.4.1 | CPxCTL0 Register (offset = 00h) [reset = 0100h] | 509 | | | | 18.4.2 | CPxCTL1 Register (offset = 02h) [reset = 0000h] | 510 | | | | 18.4.3 | CPxINT Register (offset = 06h) [reset = 0000h] | 511 | | | | 18.4.4 | CPxIV Register (offset = 08h) [reset = 0000h] | 512 | | | | 18.4.5 | CPxDACCTL Register (offset = 10h) [reset = 0002h] | 512 | | | | 18.4.6 | CPxDACDATA Register (offset = 12h) [reset = 0100h] | 513 | | 19 | Trans | simneds | ance Amplifier (TIA) | 514 | | 13 | 19.1 | - | roduction | | | | 19.1 | | eration | | | | 13.2 | | | | | | | | TIA Input and Output | | | | 40.0 | | TIA Input and Output | | | | 19.3 | | gisters | | | | | 19.3.1 | TRICTL Register (offset = 00h) [reset = 0000h] | 51/ | | 20 | Smar | t Analo | g Combo (SAC) | 518 | |----|------|---------|--------------------------------------------------------------------------|-----| | | 20.1 | SAC Int | troduction | 519 | | | 20.2 | SAC Op | peration | 521 | | | | 20.2.1 | SAC OA | 521 | | | | 20.2.2 | SAC OA Configuration | 521 | | | | 20.2.3 | SAC DAC | 528 | | | 20.3 | SAC Co | onfiguration | 530 | | | 20.4 | SAC Re | egisters | 531 | | | | 20.4.1 | SACxOA Register (offset = 00h) [reset = 0000h] | 532 | | | | 20.4.2 | SACxPGA Register (offset = 02h) [reset = 0001h] | 533 | | | | 20.4.3 | SACxDAC Register (offset = 04h) [reset = 0000h] | 534 | | | | 20.4.4 | SACxDAT Register (offset = 06h) [reset = 0000h] | 535 | | | | 20.4.5 | SACxDACSTS Register (offset = 08h) [reset = 0000h] | 536 | | | | | SACxIV Register (offset = 0Ah) [reset = 0000h] | | | 21 | ADC | Module | | 538 | | | 21.1 | | troduction | | | | 21.2 | | peration | | | | | | ADC Core | | | | | | ADC Inputs and Multiplexer | | | | | | Voltage Reference Generator | | | | | | Automatic Power Down | | | | | | Sample and Conversion Timing | | | | | | Conversion Result | | | | | | ADC Conversion Modes | | | | 21.3 | | egisters | | | | | | ADCCTL0 Register | | | | | | ADCCTL1 Register | | | | | | ADCCTL2 Register | | | | | | ADCMEMO Register | | | | | | ADCMEM0 Register, 2s-Complement Format | | | | | | ADCMCTL0 Register | | | | | | ADCHI Register | | | | | | ADCHI Register, 2s-Complement Format | | | | | | ADCLO Register | | | | | | ADCLO Register, 2s-Complement Format | | | | | | ADCIE Register | | | | | | ADCIFG Register | | | | | | ADCIV Register | | | | | | MSP430FR413x SYSCFG2 Register (absolute address = 0164h) [reset = 0000h] | | | 22 | Enha | nced Ur | niversal Serial Communication Interface (eUSCI) – UART Mode | 574 | | | 22.1 | | ed Universal Serial Communication Interface A (eUSCI_A) Overview | | | | 22.2 | | A Introduction – UART Mode | | | | 22.3 | eUSCI_ | _A Operation – UART Mode | 577 | | | | 22.3.1 | eUSCI_A Initialization and Reset | 577 | | | | | Character Format | | | | | | Asynchronous Communication Format | | | | | | Automatic Baud-Rate Detection | | | | | | IrDA Encoding and Decoding | | | | | | Automatic Error Detection | | | | | | eUSCI_A Receive Enable | | | | | | eUSCI_A Transmit Enable | | | | | | UART Baud-Rate Generation | | | | | | | | | | | 22.3.10 Setting a Baud Rate | 586 | |-----|---------|--------------------------------------------------------------------------------|-----| | | | 22.3.11 Transmit Bit Timing - Error calculation | 587 | | | | 22.3.12 Receive Bit Timing – Error Calculation | 587 | | | | 22.3.13 Typical Baud Rates and Errors | 588 | | | | 22.3.14 Using the eUSCI_A Module in UART Mode With Low-Power Modes | 590 | | | | 22.3.15 eUSCI_A Interrupts | | | | 22.4 | eUSCI_A UART Registers | | | | | 22.4.1 UCAxCTLW0 Register | | | | | 22.4.2 UCAxCTLW1 Register | | | | | 22.4.3 UCAxBRW Register | | | | | 22.4.4 UCAxMCTLW Register | | | | | · · · · · · · · · · · · · · · · · · · | | | | | 22.4.5 UCAxSTATW Register | | | | | 22.4.6 UCAxRXBUF Register | | | | | 22.4.7 UCAxTXBUF Register | | | | | 22.4.8 UCAxABCTL Register | | | | | 22.4.9 UCAxIRCTL Register | | | | | 22.4.10 UCAxIE Register | | | | | 22.4.11 UCAxIFG Register | | | | | 22.4.12 UCAxIV Register | 602 | | 23 | Enha | nced Universal Serial Communication Interface (eUSCI) – SPI Mode | 603 | | | 23.1 | Enhanced Universal Serial Communication Interfaces (eUSCI_A, eUSCI_B) Overview | | | | 23.2 | eUSCI Introduction – SPI Mode | | | | 23.3 | eUSCI Operation – SPI Mode | | | | _0.0 | 23.3.1 eUSCI Initialization and Reset | | | | | 23.3.2 Character Format | | | | | 23.3.3 Master Mode | | | | | 23.3.4 Slave Mode | | | | | 23.3.5 SPI Enable | | | | | | | | | | | | | | | | | | | 00.4 | 23.3.8 SPI Interrupts | | | | 23.4 | eUSCI_A SPI Registers | | | | | 23.4.1 UCAxCTLW0 Register | | | | | 23.4.2 UCAxBRW Register | | | | | 23.4.3 UCAxSTATW Register | | | | | 23.4.4 UCAxRXBUF Register | 616 | | | | 23.4.5 UCAxTXBUF Register | 616 | | | | 23.4.6 UCAxIE Register | 617 | | | | 23.4.7 UCAxIFG Register | 617 | | | | 23.4.8 UCAxIV Register | 618 | | | 23.5 | eUSCI_B SPI Registers | 619 | | | | 23.5.1 UCBxCTLW0 Register | 620 | | | | 23.5.2 UCBxBRW Register | 621 | | | | 23.5.3 UCBxSTATW Register | 622 | | | | 23.5.4 UCBxRXBUF Register | | | | | 23.5.5 UCBxTXBUF Register | | | | | 23.5.6 UCBxIE Register | | | | | 23.5.7 UCBxIFG Register | | | | | 23.5.8 UCBxIV Register | | | 0.4 | <b></b> | | | | 24 | | ` , | | | | 24.1 | Enhanced Universal Serial Communication Interface B (eUSCI_B) Overview | | | | 24.2 | eUSCI_B Introduction – I <sup>2</sup> C Mode | | | | 24.3 | eUSCI_B Operation – I <sup>2</sup> C Mode | 629 | | | | 24.3.1 eUSCI_B Initialization and Reset | 629 | |-------|---------|--------------------------------------------------------------------------------|-----| | | | 24.3.2 I <sup>2</sup> C Serial Data | 630 | | | | 24.3.3 I <sup>2</sup> C Addressing Modes | 630 | | | | 24.3.4 I <sup>2</sup> C Quick Setup | 631 | | | | 24.3.5 I <sup>2</sup> C Module Operating Modes | 632 | | | | 24.3.6 Glitch Filtering | 642 | | | | 24.3.7 I <sup>2</sup> C Clock Generation and Synchronization | | | | | 24.3.8 Byte Counter | 643 | | | | 24.3.9 Multiple Slave Addresses | | | | | 24.3.10 Using the eUSCI_B Module in I <sup>2</sup> C Mode With Low-Power Modes | 645 | | | | 24.3.11 eUSCI_B Interrupts in I <sup>2</sup> C Mode | | | | 24.4 | eUSCI_B I2C Registers | 648 | | | | 24.4.1 UCBxCTLW0 Register | 649 | | | | 24.4.2 UCBxCTLW1 Register | | | | | 24.4.3 UCBxBRW Register | 653 | | | | 24.4.4 UCBxSTATW | 653 | | | | 24.4.5 UCBxTBCNT Register | 654 | | | | 24.4.6 UCBxRXBUF Register | 655 | | | | 24.4.7 UCBxTXBUF | 655 | | | | 24.4.8 UCBxI2COA0 Register | 656 | | | | 24.4.9 UCBxI2COA1 Register | 657 | | | | 24.4.10 UCBxl2COA2 Register | 657 | | | | 24.4.11 UCBxl2COA3 Register | 658 | | | | 24.4.12 UCBxADDRX Register | 658 | | | | 24.4.13 UCBxADDMASK Register | 659 | | | | 24.4.14 UCBxl2CSA Register | 659 | | | | 24.4.15 UCBxIE Register | 660 | | | | 24.4.16 UCBxIFG Register | 662 | | | | 24.4.17 UCBxIV Register | 664 | | 25 | Manc | chester Function Module (MFM) | 665 | | | 25.1 | MFM Decoder Introduction | | | | 25.2 | Manchester Codec Operation | | | | 25.3 | Clock Generation | | | | 25.4 | Manchester Coding | | | | 25.5 | Clock Recovery and Regeneration | | | | 25.6 | , , | 668 | | | 20.0 | | 668 | | | | | 668 | | | | | 669 | | | 25.7 | | 669 | | 00 | | | | | 26 | | | 670 | | | 26.1 | | 671 | | | 26.2 | · · · · · · · · · · · · · · · · · · · | 673 | | | | | 673 | | | | | 673 | | | | · · · · · · · · · · · · · · · · · · · | 673 | | | | • | 673 | | | 00.0 | | 674 | | | 26.3 | EEM Configurations | | | David | aian Li | ictory | 675 | ## **List of Figures** | 1-1. | BOR, POR, and PUC Reset Circuit | 31 | |-------|-------------------------------------------|----| | 1-2. | Interrupt Priority | 32 | | 1-3. | Interrupt Processing | 34 | | 1-4. | Return From Interrupt | 35 | | 1-5. | Operation Modes | 38 | | 1-6. | IR Modulation Combinatory Logic | 49 | | 1-7. | 1.2-V Reference Output on A4 | 49 | | 1-8. | IR Modulation Combinatory Logic | 50 | | 1-9. | 1.2-V Reference Output on A4 | 51 | | 1-10. | IR Modulation Combinatory Logic | 52 | | 1-11. | 1.2-V Reference Output on A4 | 52 | | 1-12. | Memory Protection | 53 | | 1-13. | IR Modulation Combinatory Logic | | | 1-14. | 1.2-V Reference Output on A7 | | | 1-15. | IR Modulation Combinatory Logic | | | 1-16. | 1.2-V Reference Output on A7 | 57 | | 1-17. | Devices Descriptor Table | 58 | | 1-18. | SFRIE1 Register | | | 1-19. | SFRIFG1 Register | | | 1-20. | SFRRPCR Register | | | 1-21. | SYSCTL Register | | | 1-22. | SYSBSLC Register | | | 1-23. | SYSJMBC Register | | | 1-24. | SYSJMBI0 Register | | | 1-25. | SYSJMBI1 Register | 69 | | 1-26. | SYSJMBO0 Register | | | 1-27. | SYSJMBO1 Register | 70 | | 1-28. | SYSUNIV Register | 71 | | 1-29. | SYSSNIV Register | 71 | | 1-30. | SYSRSTIV Register | 72 | | 1-31. | SYSCFG0 Register | 75 | | 1-32. | SYSCFG1 Register | 76 | | 1-33. | SYSCFG2 Register | 77 | | 1-34. | SYSCFG3 Register | 78 | | 1-35. | SYSCFG0 Register | 80 | | 1-36. | SYSCFG1 Register | 81 | | 1-37. | SYSCFG2 Register | 82 | | 1-38. | SYSCFG3 Register | 83 | | 2-1. | PMM Block Diagram | 85 | | 2-2. | Voltage Failure and Resulting PMM Actions | 86 | | 2-3. | PMM Action at Device Power-Up | 87 | | 2-4. | PMMCTL0 Register | 91 | | 2-5. | PMMCTL1 Register | 92 | | 2-6. | PMMCTL2 Register | 93 | | 2-7. | PMMIE Register | 95 | | 2-8. | PMMIFG Register | 96 | | 2-9. | PM5CTL0 Register | 97 | | 3-1. | Basic Clock System Block Diagram | 100 | |-------|-------------------------------------------------------|-----| | 3-2. | Enhanced Clock System Block Diagram | 101 | | 3-3. | Modulator Patterns | 105 | | 3-4. | FLL Unlock Detection | 106 | | 3-5. | Module Request Clock System | 108 | | 3-6. | Oscillator Fault Logic | 110 | | 3-7. | Switch MCLK From DCOCLK to XT1CLK | 111 | | 3-8. | CSCTL0 Register | 113 | | 3-9. | CSCTL1 Register | 114 | | 3-10. | CSCTL2 Register | 115 | | 3-11. | CSCTL3 Register | 116 | | 3-12. | CSCTL4 Register | 117 | | 3-13. | CSCTL5 Register | 118 | | 3-14. | CSCTL6 Register | 119 | | 3-15. | CSCTL7 Register | 121 | | 3-16. | CSCTL8 Register | 123 | | 4-1. | MSP430X CPU Block Diagram | 126 | | 4-2. | PC Storage on the Stack for Interrupts | 127 | | 4-3. | Program Counter | 128 | | 4-4. | PC Storage on the Stack for CALLA | 128 | | 4-5. | Stack Pointer | 129 | | 4-6. | Stack Usage | 129 | | 4-7. | PUSHX.A Format on the Stack | 129 | | 4-8. | PUSH SP, POP SP Sequence | 129 | | 4-9. | SR Bits | 130 | | 4-10. | Register-Byte and Byte-Register Operation | 132 | | 4-11. | Register-Word Operation | 132 | | 4-12. | Word-Register Operation | 133 | | 4-13. | Register – Address-Word Operation | 133 | | 4-14. | Address-Word – Register Operation | 134 | | 4-15. | Indexed Mode in Lower 64KB | 136 | | 4-16. | Indexed Mode in Upper Memory | 137 | | 4-17. | Overflow and Underflow for Indexed Mode | 138 | | 4-18. | Example for Indexed Mode | 139 | | 4-19. | Symbolic Mode Running in Lower 64KB | | | 4-20. | Symbolic Mode Running in Upper Memory | | | 4-21. | Overflow and Underflow for Symbolic Mode | 143 | | 4-22. | MSP430 Double-Operand Instruction Format | 151 | | 4-23. | MSP430 Single-Operand Instructions | 152 | | 4-24. | Format of Conditional Jump Instructions | 153 | | 4-25. | Extension Word for Register Modes | 156 | | 4-26. | Extension Word for Non-Register Modes | 156 | | 4-27. | Example for Extended Register or Register Instruction | 157 | | 4-28. | Example for Extended Immediate or Indexed Instruction | 158 | | 4-29. | Extended Format I Instruction Formats | 159 | | 4-30. | 20-Bit Addresses in Memory | 159 | | 4-31. | Extended Format II Instruction Format | 160 | | 4-32. | PUSHM and POPM Instruction Format | 161 | | 4-33. | RRCM, RRAM, RRUM, and RLAM Instruction Format | 161 | | 4-34. | BRA Instruction Format | 161 | |-------|-------------------------------------------------------------|-----| | 4-35. | CALLA Instruction Format | 161 | | 4-36. | Decrement Overlap | 187 | | 4-37. | Stack After a RET Instruction | 206 | | 4-38. | Destination Operand—Arithmetic Shift Left | 208 | | 4-39. | Destination Operand—Carry Left Shift | 209 | | 4-40. | Rotate Right Arithmetically RRA.B and RRA.W | 210 | | 4-41. | Rotate Right Through Carry RRC.B and RRC.W | 211 | | 4-42. | Swap Bytes in Memory | 218 | | 4-43. | Swap Bytes in a Register | 218 | | 4-44. | Rotate Left Arithmetically—RLAM[.W] and RLAM.A | 245 | | 4-45. | Destination Operand-Arithmetic Shift Left | 246 | | 4-46. | Destination Operand-Carry Left Shift | 247 | | 4-47. | Rotate Right Arithmetically RRAM[.W] and RRAM.A | 248 | | 4-48. | Rotate Right Arithmetically RRAX(.B,.A) – Register Mode | 250 | | 4-49. | Rotate Right Arithmetically RRAX(.B,.A) – Non-Register Mode | 250 | | 4-50. | Rotate Right Through Carry RRCM[.W] and RRCM.A | 252 | | 4-51. | Rotate Right Through Carry RRCX(.B,.A) – Register Mode | 254 | | 4-52. | Rotate Right Through Carry RRCX(.B,.A) – Non-Register Mode | 254 | | 4-53. | Rotate Right Unsigned RRUM[.W] and RRUM.A | 255 | | 4-54. | Rotate Right Unsigned RRUX(.B,.A) – Register Mode | 256 | | 4-55. | Swap Bytes SWPBX.A Register Mode | 260 | | 4-56. | Swap Bytes SWPBX.A In Memory | 260 | | 4-57. | Swap Bytes SWPBX[.W] Register Mode | 261 | | 4-58. | Swap Bytes SWPBX[.W] In Memory | 261 | | 4-59. | Sign Extend SXTX.A | 262 | | 4-60. | Sign Extend SXTX[.W] | 262 | | 5-1. | Interrupt Compare Controller Block Diagram | 281 | | 5-2. | Nested and Non-Nested Interrupt Comparison Block Diagram | 283 | | 5-3. | Virtual Stack Push Flow Block Diagram | 285 | | 5-4. | Virtual Stack Pop Flow Block Diagram | 286 | | 5-5. | ISR Recommended Flow Block Diagram | 287 | | 5-6. | Recommended ICC Enable Operation Flow Block Diagram | 289 | | 5-7. | Recommended ICC Disabled Operation Flow Block Diagram | 290 | | 5-8. | ICCSC Register | 293 | | 5-9. | ICCMVS Register | 293 | | 5-10. | ICCILRS0 Register | 294 | | 5-11. | ICCILRS1 Register | 295 | | 5-12. | ICCILRS2 Register | 295 | | 5-13. | ICCILRS3 Register | 296 | | 5-14. | ICCILRS4 Register | 297 | | 5-15. | ICCILRS5 Register | 297 | | 5-16. | ICCILRS6 Register | 298 | | 5-17. | ICCILRS7 Register | 299 | | 6-1. | FRAM Controller Block Diagram | 301 | | 6-2. | FRAM Power Control Diagram | 304 | | 6-3. | FRCTL0 Register | 306 | | 6-4. | GCCTL0 Register (16-MHz Devices) | | | 6-5. | GCCTL0 Register (24-MHz Devices) | 307 | | 6-6. | GCCTL1 Register | 308 | |-----------------------------|---------------------------------------------------------------------------|-----| | 8-1. | P1IV Register | 332 | | 8-2. | P2IV Register | 332 | | 8-3. | P3IV Register | 333 | | 8-4. | P4IV Register | 333 | | 8-5. | PxIN Register | 334 | | 8-6. | PxOUT Register | 334 | | 8-7. | PxDIR Register | 334 | | 8-8. | PxREN Register | 335 | | 8-9. | PxSEL0 Register | 335 | | 8-10. | PxSEL1 Register | 335 | | 8-11. | PxSELC Register | 336 | | 8-12. | PxIES Register | | | 8-13. | PxIE Register | | | 8-14. | PxIFG Register | | | 9-1. | Capacitive Touch I/O Principle | | | 9-2. | Capacitive Touch I/O Block Diagram | | | 9-3. | CAPTIOxCTL Register | | | 10-1. | CapTIvate Declarations | | | 10-2. | Channel Definition | | | 10-3. | Element Definition | | | 10-4. | Self-Capacitance Mode | | | 10-5. | Mutual-Capacitance Mode | | | 10-6. | CAPIE Register | | | 10-7. | CAPIFG Register | | | 10-8. | CAPIV Register | | | 11-1. | LFSR Implementation of CRC-CCITT Standard, Bit 0 is the MSB of the Result | | | 11-2. | Implementation of CRC-CCITT Using the CRCDI and CRCINIRES Registers | | | 11-3. | CRCDI Register | | | | CRCDIRB Register | | | 11-5. | CRCINIRES Register | | | | CRCRESR Register | | | | Watchdog Timer Block Diagram | | | | WDTCTL Register | 366 | | 13-1. | Timer_A Block Diagram | 369 | | 13-2. | Up Mode | 371 | | 13-3. | Up Mode Flag Setting | | | 13-4. | Continuous Mode | 372 | | 13- <del>4</del> .<br>13-5. | Continuous Mode Flag Setting | 372 | | 13-6. | Continuous Mode Time Intervals | 372 | | 13-7. | Up/Down Mode | 373 | | 13-7. | Up/Down Mode Flag Setting | 373 | | | Output Unit in Up/Down Mode | 374 | | | Capture Signal (SCS = 1) | 375 | | | Capture Cycle | | | | Output Example – Timer in Up Mode | 375 | | | Output Example – Timer in Op Mode | 377 | | | Output Example – Timer in Continuous Mode | 378 | | | · | | | 10-10. | Capture/Compare TAxCCR0 Interrupt Flag | 30U | | 13-16. | TAxCTL Register | 384 | |--------|--------------------------------------------------------------------------------|-----| | 13-17. | TAxR Register | 385 | | 13-18. | TAxCCTLn Register | 386 | | 13-19. | TAxCCRn Register | 388 | | 13-20. | TAxIV Register | 388 | | 13-21. | TAxEX0 Register | 389 | | 14-1. | Timer_B Block Diagram | 392 | | 14-2. | Up Mode | 394 | | 14-3. | Up Mode Flag Setting | 394 | | 14-4. | Continuous Mode | 395 | | 14-5. | Continuous Mode Flag Setting | 395 | | 14-6. | Continuous Mode Time Intervals | 395 | | 14-7. | Up/Down Mode | 396 | | 14-8. | Up/Down Mode Flag Setting | | | 14-9. | Output Unit in Up/Down Mode | | | 14-10. | Capture Signal (SCS = 1) | | | | Capture Cycle | | | | Output Example – Timer in Up Mode | | | | Output Example – Timer in Continuous Mode | | | | Output Example – Timer in Up/Down Mode | | | | Capture/Compare TBxCCR0 Interrupt Flag | | | | TBxCTL Register | | | | TBxR Register | | | | TBxCCTLn Register | | | | TBxCCRn Register | | | | TBxIV Register | | | | TBxEX0 Register | | | | RTC Counter Block Diagram | | | 15-2. | Shadow Register Example | 418 | | 15-3. | RTCCTL Register | 420 | | 15-4. | RTCIV Register | 421 | | 15-5. | RTCMOD Register | 422 | | 15-6. | RTCCNT Register | 422 | | 16-1. | MPY32 Block Diagram | 425 | | 16-2. | Q15 Format Representation | 430 | | 16-3. | Q14 Format Representation | 430 | | 16-4. | Saturation Flow Chart | 432 | | 16-5. | Multiplication Flow Chart | 434 | | 16-6. | MPY32CTL0 Register | 440 | | 17-1. | LCD Controller Block Diagram | 443 | | 17-2. | LCD Memory for Static to 4-Mux Mode – Example for 4-Mux Mode With 240 Segments | 445 | | 17-3. | LCD Memory for 5-Mux to 8-Mux Mode – Example for 8-Mux Mode With 96 Segments | 446 | | 17-4. | LCDMx in Static, 2-, 3-, or 4-Mux Mode | 448 | | 17-5. | LCDMx in 5-, 6-, 7-, or 8-Mux Mode | 449 | | 17-6. | Example LCDMx and LCDBMx Configuration in Different Blinking Modes | 453 | | 17-7. | Bias Generation | 455 | | 17-8. | LCD Operation Mode 1 | 457 | | 17-9. | LCD Operation Mode 2 | 457 | | 17-10. | LCD Operation Mode 3 | 458 | | 17-11. | LCD Operation Mode 4 | 459 | |--------|---------------------------------------------------------|-----| | 17-12. | Example Static Waveforms | 461 | | 17-13. | Example 2-Mux Waveforms | 462 | | 17-14. | Example 3-Mux Waveforms | 463 | | 17-15. | Example 4-Mux Waveforms | 464 | | 17-16. | Example 6-Mux Waveforms | 465 | | 17-17. | Example 8-Mux, 1/3 Bias Waveforms (LCDLP = 0) | 466 | | 17-18. | Example 8-Mux, 1/3 Bias Low-Power Waveforms (LCDLP = 1) | 467 | | 17-19. | LCDCTL0 Register | 476 | | 17-20. | LCDCTL1 Register | 477 | | 17-21. | LCDBLKCTL Register | 478 | | 17-22. | LCDMEMCTL Register | 479 | | 17-23. | LCDVCTL Register | 480 | | 17-24. | LCDPCTL0 Register | 482 | | 17-25. | LCDPCTL1 Register | 484 | | 17-26. | LCDPCTL2 Register | 486 | | 17-27. | LCDPCTL3 Register | 488 | | 17-28. | LCDCSSEL0 Register | 490 | | 17-29. | LCDCSSEL1 Register | 492 | | 17-30. | LCDCSSEL2 Register | 494 | | 17-31. | LCDCSSEL3 Register | 496 | | 17-32. | LCDM[index] Register | 498 | | 17-33. | LCDM[index] Register | 500 | | 17-34. | LCDIV Register | 502 | | 18-1. | eCOMP Block Diagram | 504 | | 18-2. | Analog Filter Response at the Output of the eCOMP | 505 | | 18-3. | 6-bit eCOMP Built-in DAC Overview Block Diagram | 506 | | 18-4. | 6-Bit eCOMP Built-in DAC Block Diagram | 507 | | 18-5. | CPxCTL0 Register | 509 | | 18-6. | CPxCTL1 Register | 510 | | 18-7. | CPxINT Register | 511 | | 18-8. | CPxIV Register | 512 | | 18-9. | CPxDACCTL Register | 512 | | 18-10. | CPxDACDATA Register | 513 | | 19-1. | TIA Block Diagram | 515 | | 19-2. | TIA Typical Application Block Diagram | 516 | | 19-3. | TRICTL Register | 517 | | 20-1. | SAC Block Diagram | | | 20-2. | SAC OA in GP Mode | 522 | | 20-3. | SAC OA in Buffer Mode | 524 | | 20-4. | SAC in Inverting PGA Mode With DAC as Bias | 525 | | 20-5. | SAC in Inverting PGA Mode With External Bias | 526 | | 20-6. | SAC in Non-Inverting PGA Mode | 527 | | 20-7. | DAC Block Diagram For Single-Module Devices | 528 | | 20-8. | SACxOA Register | 532 | | 20-9. | SACxPGA Register | | | 20-10. | SACxDAC Register | 534 | | | SACxDAT Register | 535 | | | SACxDACSTS Register | | | | | | | 20-13. | SACxIV Register | 537 | |--------|-------------------------------------------------------------|-----| | 21-1. | ADC Block Diagram | 540 | | 21-2. | Analog Multiplexer | 541 | | 21-3. | Extended Sample Mode in 10-Bit Mode | 543 | | 21-4. | Extended Sample Mode With External Reference in 12-Bit Mode | 543 | | 21-5. | Extended Sample Mode With Internal Reference in 12-Bit Mode | 544 | | 21-6. | Pulse Sample Mode in 10-Bit Mode | 544 | | 21-7. | Pulse Sample Mode With External Reference in 12-Bit Mode | 545 | | 21-8. | Pulse Sample Mode With Internal Reference in 12-Bit Mode | | | 21-9. | Analog Input Equivalent Circuit | 546 | | | Single-Channel Single-Conversion Mode in 10-Bit Mode | | | | Single-Channel Single-Conversion Mode in 12-Bit Mode | | | 21-12. | Sequence-of-Channels Mode in 10-Bit Mode | 549 | | 21-13. | Sequence-of-Channels Mode in 12-Bit Mode | 550 | | 21-14. | Repeat-Single-Channel Mode in 10-Bit Mode | 551 | | | Repeat-Single-Channel Mode in 12-Bit Mode | | | 21-16. | Repeat-Sequence-of-Channels Mode in 10-Bit Mode | 553 | | 21-17. | Repeat-Sequence-of-Channels Mode in 12-Bit Mode | 554 | | | Typical Temperature Sensor Transfer Function for 10-bit ADC | | | | Typical Temperature Sensor Transfer Function for 12-bit ADC | | | | ADC Grounding and Noise Considerations | | | 21-21. | ADCCTL0 Register | 561 | | 21-22. | ADCCTL1 Register | 563 | | 21-23. | ADCCTL2 Register | 565 | | 21-24. | ADCMEM0 Register | 566 | | 21-25. | ADCMEM0 Register | 566 | | 21-26. | ADCMCTL0 Register | 567 | | 21-27. | ADCHI Register | 568 | | 21-28. | ADCHI Register | 568 | | 21-29. | ADCLO Register | 569 | | 21-30. | ADCLO Register | 569 | | 21-31. | ADCIE Register | 570 | | 21-32. | ADCIFG Register | 571 | | 21-33. | ADCIV Register | 572 | | 21-34. | SYSCFG2 Register | 573 | | 22-1. | eUSCI_Ax Block Diagram – UART Mode (UCSYNC = 0) | 576 | | 22-2. | Character Format | 577 | | 22-3. | Idle-Line Format | 578 | | 22-4. | Address-Bit Multiprocessor Format | 579 | | 22-5. | Auto Baud-Rate Detection – Break/Synch Sequence | 580 | | 22-6. | Auto Baud-Rate Detection – Synch Field | 580 | | 22-7. | UART vs IrDA Data Format | 581 | | 22-8. | Glitch Suppression, eUSCI_A Receive Not Started | 583 | | 22-9. | Glitch Suppression, eUSCI_A Activated | 583 | | 22-10. | BITCLK Baud-Rate Timing With UCOS16 = 0 | 584 | | 22-11. | Receive Error | 588 | | | UCAxCTLW0 Register | 593 | | 22-13. | UCAxCTLW1 Register | 594 | | 22-14. | UCAxBRW Register | 595 | | 22-15. | UCAxMCTLW Register | 595 | |--------|-----------------------------------------------------------------------------|-----| | 22-16. | UCAxSTATW Register | 596 | | 22-17. | UCAxRXBUF Register | 597 | | 22-18. | UCAxTXBUF Register | 597 | | 22-19. | UCAxABCTL Register | 598 | | 22-20. | UCAxIRCTL Register | 599 | | 22-21. | UCAxIE Register | 600 | | 22-22. | UCAxIFG Register | 601 | | 22-23. | UCAxIV Register | 602 | | 23-1. | eUSCI Block Diagram – SPI Mode | 605 | | 23-2. | eUSCI Master and External Slave (UCSTEM = 0) | 607 | | 23-3. | eUSCI Slave and External Master | 608 | | 23-4. | eUSCI SPI Timing With UCMSB = 1 | 610 | | 23-5. | UCAxCTLW0 Register | 613 | | 23-6. | UCAxBRW Register | 614 | | 23-7. | UCAxSTATW Register | 615 | | 23-8. | UCAxRXBUF Register | 616 | | 23-9. | UCAxTXBUF Register | 616 | | 23-10. | UCAxIE Register | 617 | | 23-11. | UCAxIFG Register | 617 | | 23-12. | UCAxIV Register | 618 | | 23-13. | UCBxCTLW0 Register | 620 | | 23-14. | UCBxBRW Register | 621 | | 23-15. | UCBxSTATW Register | 622 | | 23-16. | UCBxRXBUF Register | 623 | | 23-17. | UCBxTXBUF Register | 623 | | 23-18. | UCBxIE Register | 624 | | 23-19. | UCBxIFG Register | 624 | | 23-20. | UCBxIV Register | 625 | | 24-1. | eUSCI_B Block Diagram – I <sup>2</sup> C Mode | 628 | | 24-2. | I <sup>2</sup> C Bus Connection Diagram | 629 | | 24-3. | I <sup>2</sup> C Module Data Transfer | 630 | | 24-4. | Bit Transfer on I <sup>2</sup> C Bus | 630 | | 24-5. | I <sup>2</sup> C Module 7-Bit Addressing Format | 630 | | 24-6. | I <sup>2</sup> C Module 10-Bit Addressing Format | 631 | | 24-7. | I <sup>2</sup> C Module Addressing Format With Repeated START Condition | 631 | | 24-8. | I <sup>2</sup> C Time-Line Legend | 633 | | | I <sup>2</sup> C Slave Transmitter Mode | | | 24-10. | I <sup>2</sup> C Slave Receiver Mode | 635 | | 24-11. | I <sup>2</sup> C Slave 10-Bit Addressing Mode | 636 | | 24-12. | I <sup>2</sup> C Master Transmitter Mode | 638 | | 24-13. | I <sup>2</sup> C Master Receiver Mode | 640 | | 24-14. | I <sup>2</sup> C Master 10-Bit Addressing Mode | 641 | | 24-15. | Arbitration Procedure Between Two Master Transmitters | 641 | | | Synchronization of Two I <sup>2</sup> C Clock Generators During Arbitration | | | | UCBxCTLW0 Register | | | | UCBxCTLW1 Register | | | | UCBxBRW Register | | | | UCBxSTATW Register | | | | | | | 24-21. | UCBxTBCNT Register | 654 | |--------|-----------------------------------------------------|-----| | 24-22. | UCBxRXBUF Register | 655 | | 24-23. | UCBxTXBUF Register | 655 | | 24-24. | UCBxI2COA0 Register | 656 | | 24-25. | UCBxI2COA1 Register | 657 | | 24-26. | UCBxI2COA2 Register | 657 | | 24-27. | UCBxI2COA3 Register | 658 | | 24-28. | UCBxADDRX Register | 658 | | 24-29. | UCBxADDMASK Register | 659 | | 24-30. | UCBxI2CSA Register | 659 | | 24-31. | UCBxIE Register | 660 | | 24-32. | UCBxIFG Register | 662 | | | UCBxIV Register | | | 25-1. | MFM Block Diagram | 666 | | 25-2. | Manchester Code Time Sequence | 667 | | 25-3. | Transmit Data Manchester Coding | 667 | | 25-4. | MFM Clock Synchronization | 668 | | 25-5. | Manchester Codec System Integration Diagram Example | 669 | | 26-1 | Large Implementation of FEM | 672 | ## **List of Tables** | 0-1. | Register Bit Accessibility and Initial Condition | 28 | |-------|----------------------------------------------------------------|-----| | 1-1. | Interrupt Sources, Flags, and Vectors | 35 | | 1-2. | Operation Modes | 39 | | 1-3. | Requested vs Actual LPM | 39 | | 1-4. | Connection of Unused Pins | 43 | | 1-5. | BSL and JTAG/SBW Signatures | 47 | | 1-6. | Tag Values | 59 | | 1-7. | SFR Base Address | 61 | | 1-8. | SFR Registers | 61 | | 1-9. | SFRIE1 Register Description | 62 | | 1-10. | SFRIFG1 Register Description | 63 | | 1-11. | SFRRPCR Register Description | 64 | | 1-12. | SYS Registers | 65 | | 1-13. | SYSCTL Register Description | 66 | | 1-14. | SYSBSLC Register Description | 67 | | 1-15. | SYSJMBC Register Description | 68 | | 1-16. | SYSJMBI0 Register Description | 69 | | 1-17. | SYSJMBI1 Register Description | 69 | | 1-18. | SYSJMBO0 Register Description | 70 | | 1-19. | SYSJMBO1 Register Description | 70 | | 1-20. | SYSUNIV Register Description | 71 | | 1-21. | SYSSNIV Register Description | 71 | | 1-22. | SYSRSTIV Register Description | 72 | | 1-23. | Smart Analog Combo Subfamily SYS Configuration Registers | 74 | | 1-24. | SYSCFG0 Register Description | 75 | | 1-25. | SYSCFG1 Register Description | 76 | | 1-26. | SYSCFG2 Register Description | 77 | | 1-27. | SYSCFG3 Register Description | 78 | | 1-28. | Devices Without Smart Analog Combo SYS Configuration Registers | | | 1-29. | SYSCFG0 Register Description | 80 | | 1-30. | SYSCFG1 Register Description | | | 1-31. | SYSCFG2 Register Description | | | 1-32. | SYSCFG3 Register Description | 83 | | 2-1. | PMM Registers | | | 2-2. | PMMCTL0 Register Description | | | 2-3. | PMMCTL1 Register Description | | | 2-4. | PMMCTL2 Register Description | | | 2-5. | PMMIE Register Description | | | 2-6. | PMMIFG Register Description | | | 2-7. | PM5CTL0 Register Description | | | 3-1. | CS Configurations | 98 | | 3-2. | ' | 109 | | 3-3. | 3 | 112 | | 3-4. | | 113 | | 3-5. | | 114 | | 3-6. | | 115 | | 3-7. | CSCTL3 Register Description | 116 | | 3-8. | CSCTL4 Register Description | 117 | |-------|--------------------------------------------------------------------------------|-----| | 3-9. | CSCTL5 Register Description | 118 | | 3-10. | CSCTL6 Register Description | 119 | | 3-11. | CSCTL7 Register Description | 121 | | 3-12. | CSCTL8 Register Description | 123 | | 4-1. | SR Bit Description | 130 | | 4-2. | Values of Constant Generators CG1, CG2 | 131 | | 4-3. | Source and Destination Addressing | | | 4-4. | MSP430 Double-Operand Instructions | | | 4-5. | MSP430 Single-Operand Instructions | | | 4-6. | Conditional Jump Instructions | | | 4-7. | Emulated Instructions | | | 4-8. | Interrupt, Return, and Reset Cycles and Length | 154 | | 4-9. | MSP430 Format II Instruction Cycles and Length | | | 4-10. | MSP430 Format I Instructions Cycles and Length | | | 4-11. | Description of the Extension Word Bits for Register Mode | | | 4-12. | Description of Extension Word Bits for Non-Register Modes | | | 4-13. | Extended Double-Operand Instructions. | | | 4-14. | Extended Single-Operand Instructions | | | 4-15. | Extended Emulated Instructions | | | 4-16. | Address Instructions, Operate on 20-Bit Register Data | | | 4-17. | MSP430X Format II Instruction Cycles and Length | | | 4-18. | MSP430X Format I Instruction Cycles and Length | | | 4-19. | Address Instruction Cycles and Length | 166 | | 4-20. | Instruction Map of MSP430X | 167 | | 5-1. | ICC Registers | 292 | | 5-2. | ICCSC Register Description | | | 5-3. | ICCMVS Register Description | | | 5-4. | ICCILRS0 Register Description | | | 5-5. | ICCILRS1 Register Description | 295 | | 5-6. | ICCILRS2 Register Description | 295 | | 5-7. | ICCILRS3 Register Description | 296 | | 5-8. | ICCILRS4 Register Description | 297 | | 5-9. | ICCILRS5 Register Description | 298 | | 5-10. | ICCILRS6 Register Description | 298 | | 5-11. | ICCILRS7 Register Description | 299 | | 6-1. | FRCTL Registers | 305 | | 6-2. | FRCTL0 Register Description | 306 | | 6-3. | GCCTL0 Register Description | 307 | | 6-4. | GCCTL1 Register Description | 308 | | 7-1. | BAKMEM Registers | 310 | | 8-1. | I/O Configuration | 313 | | 8-2. | I/O Function Selection for Devices With Only One Selection Bit – PxSEL0 | 314 | | 8-3. | I/O Function Selection for Devices With Two Selection Bits – PxSEL0 and PxSEL1 | | | 8-4. | Digital I/O Registers | | | 8-5. | P1IV Register Description | | | 8-6. | P2IV Register Description | | | 8-7. | P3IV Register Description | | | 8-8. | P4IV Register Description | 333 | | 8-9. | PxIN Register Description | 334 | |-----------------------------|-----------------------------------------------|-----| | 8-10. | PxOUT Register Description | 334 | | 8-11. | P1DIR Register Description | 334 | | 8-12. | PxREN Register Description | 335 | | 8-13. | PxSEL0 Register Description | 335 | | 8-14. | PxSEL1 Register Description | 335 | | 8-15. | PxSELC Register Description | | | 8-16. | PxIES Register Description | | | 8-17. | PxIE Register Description | | | 8-18. | PxIFG Register Description | | | 9-1. | CapTouch Registers | | | 9-2. | CAPTIOxCTL Register Description | | | 10-1. | CapTIvate Registers | | | 10-2. | CAPIE Register Description | | | 10-3. | CAPIFG Register Description | | | 10-4. | CAPIV Register Description | | | 11-1. | CRC Registers | | | 11-2. | CRCDI Register Description | | | 11-3. | CRCDIRB Register Description | | | 11-4. | CRCINIRES Register Description | | | 11-5. | CRCRESR Register Description | | | 12-1. | WDT_A Registers | | | 12-2. | WDTCTL Register Description | | | 13-1. | Timer Modes | | | 13-1. | Output Modes | | | 13-3. | Timer_A Registers | | | 13-3.<br>13-4. | TAXCTL Register Description | | | 13- <del>4</del> .<br>13-5. | TAXR Register Description | | | 13-5.<br>13-6. | TAXCCTLn Register Description | | | 13-6.<br>13-7. | TAXCCRn Register Description | | | 13-7.<br>13-8. | TAXIV Register Description | | | 13-6.<br>13-9. | TAXEX0 Register Description | | | 13-9.<br>14-1 | · | | | | Timer Modes | 394 | | 14-2. | TBxCLn Load Events | | | 14-3. | Compare Latch Operating Modes | | | 14-4. | Output Modes | 401 | | 14-5. | Timer_B Registers | 408 | | 14-6. | TBxCTL Register Description | 409 | | 14-7. | TBxR Register Description | 410 | | 14-8. | TBxCCTLn Register Description | 411 | | 14-9. | TBxCCRn Register Description | 413 | | | TBxIV Register Description | 414 | | | TBxEX0 Register Description | 414 | | 15-1. | RTC Counter Registers | 419 | | 15-2. | RTCCTL Register Description | 420 | | 15-3. | RTCIV Register Description | 421 | | 15-4. | RTCMOD Register Description | 422 | | 15-5. | RTCCNT Register Description | 422 | | 16-1. | Result Availability (MPYFRAC = 0, MPYSAT = 0) | 426 | | 16-2. | OP1 Registers | 427 | |--------|-------------------------------------------------------------------|-----| | 16-3. | OP2 Registers | 427 | | 16-4. | SUMEXT and MPYC Contents | 428 | | 16-5. | Result Availability in Fractional Mode (MPYFRAC = 1, MPYSAT = 0) | 431 | | 16-6. | Result Availability in Saturation Mode (MPYSAT = 1) | 432 | | 16-7. | MPY32 Registers | 438 | | 16-8. | Alternative Registers | 439 | | 16-9. | MPY32CTL0 Register Description | 440 | | 17-1. | Differences Between LCD_B, LCD_C, and LCD_E | 442 | | 17-2. | Divider Depending on MUX Mode | 450 | | 17-3. | Example for Possible LCD Frequencies | 451 | | 17-4. | Overview on COM Configuration in Blinking Mode | 452 | | 17-5. | LCD Voltage and Biasing Characteristics | 456 | | 17-6. | LCD_E Registers | 468 | | 17-7. | LCD Memory Registers for Static and 2-Mux to 4-Mux Modes | 469 | | 17-8. | LCD Blinking Memory Registers for Static and 2-Mux to 4-Mux Modes | 471 | | 17-9. | LCD Memory Registers for 5-Mux to 8-Mux Modes | 473 | | 17-10. | LCDCTL0 Register Description | 476 | | 17-11. | LCDCTL1 Register Description | 477 | | 17-12. | LCDBLKCTL Register Description | 478 | | 17-13. | LCDMEMCTL Register Description | 479 | | 17-14. | LCDVCTL Register Description | 480 | | 17-15. | LCDPCTL0 Register Description | 482 | | | LCDPCTL1 Register Description | | | 17-17. | LCDPCTL2 Register Description | 486 | | 17-18. | LCDPCTL3 Register Description | 488 | | 17-19. | LCDCSSEL0 Register Description | 490 | | 17-20. | LCDCSSEL1 Register Description | 492 | | | LCDCSSEL2 Register Description | | | | LCDCSSEL3 Register Description | | | | LCDM[index] Register Description | | | | LCDM[index] Register Description | | | 17-25. | LCDIV Register Description | 502 | | 18-1. | eCOMP Registers | 508 | | 18-2. | CPxCTL0 Register Field Description | 509 | | 18-3. | CPxCTL1 Register Field Description | 510 | | 18-4. | CPxINT Register Field Description | 511 | | 18-5. | CPxIV Register Field Description | 512 | | 18-6. | CPxDACCTL Register Field Description | 512 | | 18-7. | CPxDACDATA Register Field Description | 513 | | 19-1. | TIA Registers | 517 | | 19-2. | TRICTL Register Description | 517 | | 20-1. | SAC Configuration Capability | 521 | | 20-2. | Mode and PGA Gain Setting | 523 | | 20-3. | DAC Full-Scale Range ( $V_{ref} = Ve_{REF+}$ or $V_{REF+}$ ) | 529 | | 20-4. | SAC Configuration | 530 | | 20-5. | SAC Registers | 531 | | 20-6. | SACxOA Register Description | 532 | | 20-7. | SACxPGA Register Description | 533 | | 20-8. | SACxDAC Register Description | 534 | |--------|-----------------------------------------------------------------------------|-----| | 20-9. | SACxDAT Register Description | 535 | | 20-10. | SACxDACSTS Register Description | 536 | | 20-11. | SACxIV Register Description | 537 | | 21-1. | Conversion Mode Summary | 546 | | 21-2. | ADC Registers | 560 | | 21-3. | ADCCTL0 Register Description | 561 | | 21-4. | ADCCTL1 Register Description | 563 | | 21-5. | ADCCTL2 Register Description | 565 | | 21-6. | ADCMEM0 Register Description | 566 | | 21-7. | ADCMEM0 Register Description | 566 | | 21-8. | ADCMCTL0 Register Description | 567 | | 21-9. | ADCHI Register Description | 568 | | 21-10. | ADCHI Register Description | 568 | | 21-11. | ADCLO Register Description | 569 | | 21-12. | ADCLO Register Description | 569 | | 21-13. | ADCIE Register Description | 570 | | 21-14. | ADCIFG Register Description | 571 | | 21-15. | ADCIV Register Description | 572 | | 21-16. | SYSCFG2 Register Description | 573 | | 22-1. | Receive Error Conditions | 582 | | 22-2. | Modulation Pattern Examples | 584 | | 22-3. | BITCLK16 Modulation Pattern | 585 | | 22-4. | UCBRSx Settings for Fractional Portion of N = f <sub>BRCLK</sub> /Baud Rate | 586 | | 22-5. | Recommended Settings for Typical Crystals and Baud Rates | 589 | | 22-6. | UART State Change Interrupt Flags | 591 | | 22-7. | eUSCI_A UART Registers | 592 | | 22-8. | UCAxCTLW0 Register Description | 593 | | 22-9. | UCAxCTLW1 Register Description | 594 | | 22-10. | UCAxBRW Register Description | 595 | | 22-11. | UCAxMCTLW Register Description | 595 | | 22-12. | UCAxSTATW Register Description | 596 | | 22-13. | UCAxRXBUF Register Description | 597 | | 22-14. | UCAxTXBUF Register Description | 597 | | 22-15. | UCAxABCTL Register Description | 598 | | 22-16. | UCAxIRCTL Register Description | 599 | | 22-17. | UCAxIE Register Description | 600 | | 22-18. | UCAxIFG Register Description | 601 | | 22-19. | UCAxIV Register Description | 602 | | 23-1. | UCxSTE Operation | 606 | | 23-2. | eUSCI_A SPI Registers | 612 | | 23-3. | UCAxCTLW0 Register Description | 613 | | 23-4. | UCAxBRW Register Description | 614 | | 23-5. | UCAxSTATW Register Description | 615 | | 23-6. | UCAxRXBUF Register Description | 616 | | 23-7. | UCAxTXBUF Register Description | 616 | | 23-8. | UCAxIE Register Description | 617 | | 23-9. | UCAxIFG Register Description | 617 | | | | | | 23-10. | UCAxIV Register Description | 618 | | 23-11. | eUSCI_B SPI Registers | 619 | |--------|-----------------------------------------------|-----| | 23-12. | UCBxCTLW0 Register Description | 620 | | 23-13. | UCBxBRW Register Description | 621 | | 23-14. | UCBxSTATW Register Description | 622 | | 23-15. | UCBxRXBUF Register Description | 623 | | 23-16. | UCBxTXBUF Register Description | 623 | | 23-17. | UCBxIE Register Description | 624 | | 23-18. | UCBxIFG Register Description | 624 | | 23-19. | UCBxIV Register Description | 625 | | 24-1. | Glitch Filter Length Selection Bits | 642 | | 24-2. | I <sup>2</sup> C State Change Interrupt Flags | 646 | | 24-3. | eUSCI_B Registers | 648 | | 24-4. | UCBxCTLW0 Register Description | 649 | | 24-5. | UCBxCTLW1 Register Description | 651 | | 24-6. | UCBxBRW Register Description | 653 | | 24-7. | UCBxSTATW Register Description | 653 | | 24-8. | UCBxTBCNT Register Description | 654 | | 24-9. | UCBxRXBUF Register Description | 655 | | 24-10. | UCBxTXBUF Register Description | 655 | | 24-11. | UCBxI2COA0 Register Description | 656 | | 24-12. | UCBxI2COA1 Register Description | 657 | | 24-13. | UCBxI2COA2 Register Description | 657 | | 24-14. | UCBxI2COA3 Register Description | 658 | | 24-15. | UCBxADDRX Register Description | 658 | | 24-16. | UCBxADDMASK Register Description | 659 | | 24-17. | UCBxI2CSA Register Description | 659 | | 24-18. | UCBxIE Register Description | 660 | | | UCBxIFG Register Description | | | | UCBxIV Register Description | | | | EEM Configurations | | ## Read This First ### **About This Manual** This manual describes the modules and peripherals of the MSP430FR4xx and MSP430FR2xx family of devices. Each description presents the module or peripheral in a general sense. Not all features and functions of all modules or peripherals may be present on all devices. In addition, modules or peripherals may differ in their exact implementation between device families, or may not be fully implemented on an individual device or device family. Pin functions, internal signal connections, and operational parameters differ from device to device. Consult the device-specific data sheet for these details. #### **Related Documentation From Texas Instruments** For related documentation, see the MSP430 web site: http://www.ti.com/msp430 #### **Notational Conventions** Program examples are shown in a special typeface; for example: MOV #255,R10 XOR @R5,R6 ## **Glossary** | ADC Analog-to-digital converter BOR Brownout reset BSL Bootloader; see www.ti.com/msp430 for application reports CPU Central processing unit DAC Digital-to-analog converter DCO Digitally controlled oscillator dst Destination FLL Frequency locked loop GIE General interrupt enable INT(N/2) Integer portion of N/2 I/O Input/output ISR Interrupt service routine LSB Least-significant bit LSD Least-significant digit LPM Low-power mode; also named PM for power mode MAB Memory address bus MCLK Master clock MDB Memory data bus MSB Most-significant bit MSD Most-significant digit NMI (Non)-Maskable interrupt; also split to UNMI (user NMI) and SNMI (system NMI) PC Program counter PM Power mode | ACLK | Auxiliary clock | |-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|-------------------------------------------------------------------------------| | BSL Bootloader; see www.ti.com/msp430 for application reports CPU Central processing unit DAC Digital-to-analog converter DCO Digitally controlled oscillator dst Destination FLL Frequency locked loop GIE General interrupt enable INT(N/2) Integer portion of N/2 I/O Input/output ISR Interrupt service routine LSB Least-significant bit LSD Least-significant digit LPM Low-power mode; also named PM for power mode MAB Memory address bus MCLK Master clock MDB Memory data bus MSB Most-significant bit MSD Most-significant digit NMI (Non)-Maskable interrupt; also split to UNMI (user NMI) and SNMI (system NMI) PC Program counter | ADC | Analog-to-digital converter | | CPU Central processing unit DAC Digital-to-analog converter DCO Digitally controlled oscillator dst Destination FLL Frequency locked loop GIE General interrupt enable INT(N/2) Integer portion of N/2 I/O Input/output ISR Interrupt service routine LSB Least-significant bit LSD Least-significant digit LPM Low-power mode; also named PM for power mode MAB Memory address bus MCLK Master clock MDB Memory data bus MSB Most-significant bit MSD Most-significant digit NMI (Non)-Maskable interrupt; also split to UNMI (user NMI) and SNMI (system NMI) PC Program counter | BOR | Brownout reset | | DAC Digital-to-analog converter DCO Digitally controlled oscillator dst Destination FLL Frequency locked loop GIE General interrupt enable INT(N/2) Integer portion of N/2 I/O Input/output ISR Interrupt service routine LSB Least-significant bit LSD Least-significant digit LPM Low-power mode; also named PM for power mode MAB Memory address bus MCLK Master clock MDB Memory data bus MSB Most-significant bit MSD Most-significant digit NMI (Non)-Maskable interrupt; also split to UNMI (user NMI) and SNMI (system NMI) PC Program counter | BSL | Bootloader; see www.ti.com/msp430 for application reports | | DCO Digitally controlled oscillator dst Destination FLL Frequency locked loop GIE General interrupt enable INT(N/2) Integer portion of N/2 I/O Input/output ISR Interrupt service routine LSB Least-significant bit LSD Least-significant digit LPM Low-power mode; also named PM for power mode MAB Memory address bus MCLK Master clock MDB Memory data bus MSB Most-significant bit MSD Most-significant digit NMI (Non)-Maskable interrupt; also split to UNMI (user NMI) and SNMI (system NMI) PC Program counter | CPU | Central processing unit | | dst Destination FLL Frequency locked loop GIE General interrupt enable INT(N/2) Integer portion of N/2 I/O Input/output ISR Interrupt service routine LSB Least-significant bit LSD Least-significant digit LPM Low-power mode; also named PM for power mode MAB Memory address bus MCLK Master clock MDB Memory data bus MSB Most-significant bit MSD Most-significant digit NMI (Non)-Maskable interrupt; also split to UNMI (user NMI) and SNMI (system NMI) PC Program counter | DAC | Digital-to-analog converter | | FILL Frequency locked loop GIE General interrupt enable INT(N/2) Integer portion of N/2 I/O Input/output ISR Interrupt service routine LSB Least-significant bit LSD Least-significant digit LPM Low-power mode; also named PM for power mode MAB Memory address bus MCLK Master clock MDB Memory data bus MSB Most-significant bit MSD Most-significant digit NMI (Non)-Maskable interrupt; also split to UNMI (user NMI) and SNMI (system NMI) PC Program counter | DCO | Digitally controlled oscillator | | GIE General interrupt enable INT(N/2) Integer portion of N/2 I/O Input/output ISR Interrupt service routine LSB Least-significant bit LSD Least-significant digit LPM Low-power mode; also named PM for power mode MAB Memory address bus MCLK Master clock MDB Memory data bus MSB Most-significant bit MSD Most-significant digit NMI (Non)-Maskable interrupt; also split to UNMI (user NMI) and SNMI (system NMI) PC Program counter | dst | Destination | | INT(N/2) Integer portion of N/2 I/O Input/output ISR Interrupt service routine LSB Least-significant bit LSD Least-significant digit LPM Low-power mode; also named PM for power mode MAB Memory address bus MCLK Master clock MDB Memory data bus MSB Most-significant bit MSD Most-significant digit NMI (Non)-Maskable interrupt; also split to UNMI (user NMI) and SNMI (system NMI) PC Program counter | FLL | Frequency locked loop | | I/O Input/output ISR Interrupt service routine LSB Least-significant bit LSD Least-significant digit LPM Low-power mode; also named PM for power mode MAB Memory address bus MCLK Master clock MDB Memory data bus MSB Most-significant bit MSD Most-significant digit NMI (Non)-Maskable interrupt; also split to UNMI (user NMI) and SNMI (system NMI) PC Program counter | GIE | General interrupt enable | | ISR Interrupt service routine LSB Least-significant bit LSD Least-significant digit LPM Low-power mode; also named PM for power mode MAB Memory address bus MCLK Master clock MDB Memory data bus MSB Most-significant bit MSD Most-significant digit NMI (Non)-Maskable interrupt; also split to UNMI (user NMI) and SNMI (system NMI) PC Program counter | INT(N/2) | Integer portion of N/2 | | LSB Least-significant bit LSD Least-significant digit LPM Low-power mode; also named PM for power mode MAB Memory address bus MCLK Master clock MDB Memory data bus MSB Most-significant bit MSD Most-significant digit NMI (Non)-Maskable interrupt; also split to UNMI (user NMI) and SNMI (system NMI) PC Program counter | I/O | Input/output | | LSD Least-significant digit LPM Low-power mode; also named PM for power mode MAB Memory address bus MCLK Master clock MDB Memory data bus MSB Most-significant bit MSD Most-significant digit NMI (Non)-Maskable interrupt; also split to UNMI (user NMI) and SNMI (system NMI) PC Program counter | ISR | Interrupt service routine | | LPM Low-power mode; also named PM for power mode MAB Memory address bus MCLK Master clock MDB Memory data bus MSB Most-significant bit MSD Most-significant digit NMI (Non)-Maskable interrupt; also split to UNMI (user NMI) and SNMI (system NMI) PC Program counter | LSB | Least-significant bit | | MAB Memory address bus MCLK Master clock MDB Memory data bus MSB Most-significant bit MSD Most-significant digit NMI (Non)-Maskable interrupt; also split to UNMI (user NMI) and SNMI (system NMI) PC Program counter | LSD | Least-significant digit | | MCLK Master clock MDB Memory data bus MSB Most-significant bit MSD Most-significant digit NMI (Non)-Maskable interrupt; also split to UNMI (user NMI) and SNMI (system NMI) PC Program counter | LPM | Low-power mode; also named PM for power mode | | MDB Memory data bus MSB Most-significant bit MSD Most-significant digit NMI (Non)-Maskable interrupt; also split to UNMI (user NMI) and SNMI (system NMI) PC Program counter | MAB | Memory address bus | | MSB Most-significant bit MSD Most-significant digit NMI (Non)-Maskable interrupt; also split to UNMI (user NMI) and SNMI (system NMI) PC Program counter | MCLK | Master clock | | MSD Most-significant digit NMI (Non)-Maskable interrupt; also split to UNMI (user NMI) and SNMI (system NMI) PC Program counter | MDB | Memory data bus | | NMI (Non)-Maskable interrupt; also split to UNMI (user NMI) and SNMI (system NMI) PC Program counter | MSB | Most-significant bit | | PC Program counter | MSD | Most-significant digit | | • | NMI | (Non)-Maskable interrupt; also split to UNMI (user NMI) and SNMI (system NMI) | | PM Power mode | PC | Program counter | | | PM | Power mode | Register Bit Conventions www.ti.com | POR | Power-on reset | |-------|---------------------------| | PUC | Power-up clear | | RAM | Random access memory | | SCG | System clock generator | | SFR | Special function register | | SMCLK | Subsystem master clock | | SNMI | System NMI | | SP | Stack pointer | | SR | Status register | | src | Source | | TOS | Top of stack | | UNMI | User NMI | | WDT | Watchdog timer | | z16 | 16-bit address space | ## **Register Bit Conventions** Each register is shown with a key indicating the accessibility of the each individual bit and the initial condition: Table 0-1. Register Bit Accessibility and Initial Condition | Key | Bit Accessibility | |-----------|--------------------------------------------------------------------------------------------------| | rw | Read/write | | r | Read only | | r0 | Read as 0 | | r1 | Read as 1 | | W | Write only | | w0 | Write as 0 | | w1 | Write as 1 | | (w) | No register bit implemented; writing a 1 results in a pulse. The register bit always reads as 0. | | h0 | Cleared by hardware | | h1 | Set by hardware | | -0,-1 | Condition after PUC | | -(0),-(1) | Condition after POR | | -[0],-[1] | Condition after BOR | | -{0},-{1} | Condition after brownout | # System Resets, Interrupts, and Operating Modes, System Control Module (SYS) The system control module (SYS) is available on all devices. The basic features of SYS are: - Brownout reset (BOR) and power on reset (POR) handling - Power-up clear (PUC) handling - (Non)maskable interrupt (SNMI and UNMI) event source selection and management - User data-exchange mechanism through the JTAG mailbox (JMB) - · Bootloader (BSL) entry mechanism - Configuration management (device descriptors) - Providing interrupt vector generators for reset and NMIs - FRAM write protection - On-chip module-to-module signaling control **Topic Page** 1.1 1.2 1.3 1.4 1.5 Principles for Low-Power Applications .......43 1.6 Reset Pin (RST/NMI) Configuration 43 1.7 1.8 Configuring JTAG Pins .......44 1.9 Memory Map – Uses and Abilities .......44 1.10 1.11 Device Security 47 1.13 Device Descriptor Table 57 1.14 SFR Registers 61 1.15 SYS Registers 65 1.16 ## 1.1 System Control Module (SYS) Introduction SYS is responsible for the interaction between various modules throughout the system. The functions that SYS provide are not inherent to the peripheral modules themselves. Address decoding, bus arbitration, interrupt event consolidation, and reset generation are some examples of the functions that SYS provides. ## 1.2 System Reset and Initialization Figure 1-1 shows the system reset circuitry, which sources a brownout reset (BOR), a power on reset (POR), and a power up clear (PUC). Different events trigger these reset signals and different initial conditions exist depending on which signal was generated. A BOR is a device reset. A BOR is only generated by the following events: - Powering up the device - Low signal on RST/NMI pin when configured in the reset mode - Wake-up event from LPMx.5 (LPM3.5 or LPM4.5) modes - SVS<sub>H</sub> low condition, when enabled (see the PMM chapter for details) - Software BOR event A POR is always generated when a BOR is generated, but a BOR is not generated by a POR. The following events trigger a POR: - BOR signal - Software POR event A PUC is always generated when a POR is generated, but a POR is not generated by a PUC. The following events trigger a PUC: - POR signal - Watchdog timer expiration when in watchdog mode only (see the WDT\_A chapter for details) - Watchdog timer password violation (see the WDT A chapter for details) - FRAM memory password violation (see the FRAM Controller chapter for details) - Power Management Module password violation (see the PMM chapter for details) - Fetch from peripheral area **NOTE:** The number and type of resets available may vary from device to device. See the device-specific data sheet for all reset sources that are available. Figure 1-1. BOR, POR, and PUC Reset Circuit #### 1.2.1 Device Initial Conditions After System Reset After a BOR, the initial device conditions are: - The RST/NMI pin is configured in the reset mode. See Section 1.7 on configuring the RST/NMI pin. - I/O pins are set to input mode as described in the Digital I/O chapter. - Other peripheral modules and registers are initialized as described in their respective chapters in this manual. - Status register (SR) is reset. - The watchdog timer powers up active in watchdog mode. - Program counter (PC) is loaded with the boot code address and boot code execution begins at that address. Upon completion of the boot code, the PC is loaded with the address contained at the SYSRSTIV reset location (0FFFEh). After a system reset, user software must initialize the device for the application requirements. The following must occur: - Initialize the stack pointer (SP), typically to the top of RAM. - Initialize the watchdog to the requirements of the application. - Configure peripheral modules to the requirements of the application. NOTE: A device that is unprogrammed or blank is defined as having its reset vector value, at memory address FFFEh, equal to FFFFh. Upon system reset of a blank device, the device automatically enters operating mode LPM4. See Section 1.4 for information on operating modes and Section 1.3.6 for details on interrupt vectors. #### 1.3 Interrupts The interrupt priorities are fixed and defined by the arrangement of the modules in the connection chain as shown in Figure 1-2. Interrupt priorities determine which interrupt is acted on when more than one interrupt is pending simultaneously. There are three types of interrupts: - System reset - (Non)maskable - Maskable NOTE: The types of interrupt sources available and their respective priorities can change from device to device. See the device-specific data sheet for all interrupt sources and their priorities. Figure 1-2. Interrupt Priority www.ti.com Interrupts ## 1.3.1 (Non)Maskable Interrupts (NMIs) In general, NMIs are not masked by the general interrupt enable (GIE) bit. The family supports two levels of NMIs: system NMI (SNMI) and user NMI (UNMI). The NMI sources are enabled by individual interrupt enable bits. When an NMI interrupt is accepted, other NMIs of that level are automatically disabled to prevent nesting of consecutive NMIs of the same level. Program execution begins at the address stored in the NMI vector as shown in Table 1-1. To allow software backward compatibility to users of earlier MSP430 families, the software may, but does not need to, reenable NMI sources. A UNMI interrupt can be generated by following sources: - An edge on the RST/NMI pin when configured in NMI mode - An oscillator fault occurs A SNMI interrupt can be generated by following sources: - FRAM errors (see the FRAM Controller chapter for details) - Vacant memory access - JTAG mailbox (JMB) event **NOTE:** The number and types of NMI sources may vary from device to device. See the devicespecific data sheet for all NMI sources available. ## 1.3.2 SNMI Timing Consecutive SNMIs that occur at a higher rate than they can be handled (interrupt storm) allow the main program to execute one instruction after the SNMI handler is finished with a RETI instruction, before the SNMI handler is executed again. Consecutive SNMIs are not interrupted by UNMIs in this case. This avoids a blocking behavior on high SNMI rates. ## 1.3.3 Maskable Interrupts Maskable interrupts are caused by peripherals with interrupt capability. Each maskable interrupt source can be disabled individually by an interrupt enable bit, or all maskable interrupts can be disabled by the general interrupt enable (GIE) bit in the status register (SR). Each individual peripheral interrupt is discussed in its respective module chapter in this manual. ## 1.3.4 Interrupt Processing When an interrupt is requested from a peripheral and the peripheral interrupt enable bit and GIE bit are set, the interrupt service routine is requested. Only the individual enable bit must be set for (non)maskable interrupts (NMI) to be requested. #### 1.3.4.1 Interrupt Acceptance The interrupt latency is six cycles, starting with the acceptance of an interrupt request and lasting until the start of execution of the first instruction of the interrupt service routine, as shown in Figure 1-3. The interrupt logic executes the following: - 1. Any currently executing instruction is completed. - 2. The PC, which points to the next instruction, is pushed onto the stack. - 3. The SR is pushed onto the stack. - 4. The interrupt with the highest priority is selected if multiple interrupts occurred during the last instruction and are pending for service. - 5. The interrupt request flag resets automatically on single-source flags. Multiple source flags remain set for servicing by software. - 6. All bits of SR are cleared except SCG0, thereby terminating any low-power mode. Because the GIE bit is cleared, further interrupts are disabled. - 7. The content of the interrupt vector is loaded into the PC; the program continues with the interrupt Interrupts www.ti.com service routine at that address. Figure 1-3. Interrupt Processing ## NOTE: Enabling and Disable Interrupt Due to the pipelined CPU architecture, the instruction following the enable interrupt instruction (EINT) is always executed, even if an interrupt service request is pending when the interrupts are enabled. If the enable interrupt instruction (EINT) is immediately followed by a disable interrupt instruction (DINT), a pending interrupt might not be serviced. Further instructions after DINT might execute incorrectly and result in unexpected CPU execution. It is recommended to always insert at least one instruction between EINT and DINT. Note that any alternative instruction use that sets and immediately clears the CPU status register GIE bit must be considered in the same fashion. www.ti.com Interrupts ## 1.3.4.2 Return From Interrupt The interrupt handling routine terminates with the instruction: RETI //return from an interrupt service routine The return from the interrupt takes five cycles to execute the following actions and is shown in Figure 1-4. - 1. The SR with all previous settings pops from the stack. All previous settings of GIE, CPUOFF, and the other bits are now in effect, regardless of the settings used during the interrupt service routine. - 2. The PC pops from the stack and begins execution where it was interrupted. Figure 1-4. Return From Interrupt ## 1.3.5 Interrupt Nesting Interrupt nesting is enabled if the GIE bit is set inside an interrupt service routine. When interrupt nesting is enabled, any interrupt occurring during an interrupt service routine interrupts the routine, regardless of the interrupt priorities. ## 1.3.6 Interrupt Vectors The interrupt vectors are in the address range 0FFFFh to 0FF80h, for a maximum of 64 interrupt sources. A vector is programmed by the user and points to the start location of the corresponding interrupt service routine. Table 1-1 is an example of the interrupt vectors that are available. See the device-specific data sheet for the complete interrupt vector list. | Interrupt Source | Interrupt Flag | System Interrupt | Word Address | Priority | |---------------------------------------------------------------|------------------------|------------------------------------|--------------|-------------| | Reset:<br>Power up, external reset,<br>watchdog | <br>WDTIFG<br>KEYV | <br>Reset | <br>0FFFEh | <br>Highest | | System NMI:<br>JTAG mailbox | JMBINIFG,<br>JMBOUTIFG | (Non)maskable | 0FFFCh | | | User NMI: NMI, oscillator fault, FRAM memory access violation | <br>NMIIFG<br>OFIFG | <br>(Non)maskable<br>(Non)maskable | <br>0FFFAh | | | Device specific | | | 0FFF8h | | | | | | | | | Watchdog timer | WDTIFG | Maskable | | | | | | | | | | Device specific | | | | ••• | | Reserved | | Maskable | ••• | Lowest | Table 1-1. Interrupt Sources, Flags, and Vectors Some interrupt enable bits, interrupt flags, and the control bits for the RST/NMI pin are located in the special function registers (SFRs). The SFRs are located in the peripheral address range and are byte and word accessible. See the device-specific data sheet for the SFR configuration. Interrupts www.ti.com ## 1.3.6.1 Alternate Interrupt Vectors On devices that contain RAM, the RAM can be used as an alternate location for the interrupt vector locations. Setting the SYSRIVECT bit in SYSCTL causes the interrupt vectors to be re-mapped to the top of RAM. When the bit is set, any interrupt vectors to the alternate locations now residing in RAM. Because SYSRIVECT is automatically cleared on a BOR, it is critical that the reset vector at location 0FFFEh still be available and handled properly in firmware. ## 1.3.7 SYS Interrupt Vector Generators SYS collects all system NMI (SNMI) sources, user NMI (UNMI) sources, and BOR, POR, PUC (reset) sources of all the other modules. They are combined into three interrupt vectors. The interrupt vector registers SYSRSTIV, SYSSNIV, SYSUNIV are used to determine which flags requested an interrupt or a reset. The interrupt with the highest priority of a group, when enabled, generates a number in the corresponding SYSRSTIV, SYSSNIV, SYSUNIV register. This number can be directly added to the program counter, causing a branch to the appropriate portion of the interrupt service routine. Disabled interrupts do not affect the SYSRSTIV, SYSSNIV, SYSUNIV values. Reading SYSRSTIV, SYSSNIV, SYSUNIV register automatically resets the highest pending interrupt flag of that register. If another interrupt flag is set, another interrupt is immediately generated after servicing the initial interrupt. Writing to the SYSRSTIV, SYSSNIV, SYSUNIV register automatically resets all pending interrupt flags of the group. ## 1.3.7.1 SYSSNIV Software Example The following software example shows the recommended use of SYSSNIV. The SYSSNIV value is added to the PC to automatically jump to the appropriate routine. For SYSRSTIV and SYSUNIV, a similar software approach can be used. The following is an example for a generic device. Vectors can change in priority for a given device. The device-specific data sheet should be referenced for the vector locations. All vectors should be coded symbolically to allow for easy portability of code. ``` &SYSSNIV,PC ; Add offset to jump table SNI_ISR: ADD ; Vector 0: No interrupt RETT ; Vector 10: VMAIFG JMP VMA_ISR JMP JMBI ISR ; Vector 12: JMBINIFG JMBO_ISR: ; Vector 14: JMBOUTIFG ; Task_E starts here ; Return RETI VMA_ISR: ; Vector A ; Task_A starts here . . . ; Return ; Vector C JMBI_ISR: ; Task_C starts here RETI ; Return ``` ### 1.4 Operating Modes The MSP430 family is designed for low-power applications and uses the different operating modes shown in Figure 1-5. The operating modes take into account three different needs: - Low power - Speed and data throughput - Minimizing current consumption of individual peripherals Low-power modes LPM0 through LPM4 are configured with the CPUOFF, OSCOFF, SCG0, and SCG1 bits in the SR. The advantage of including the CPUOFF, OSCOFF, SCG0, and SCG1 mode-control bits in the SR is that the present operating mode is saved onto the stack during an interrupt service routine. Program flow returns to the previous operating mode if the saved SR value is not altered during the interrupt service routine. Program flow can be returned to a different operating mode by manipulating the saved SR value on the stack inside of the interrupt service routine. When setting any of the mode-control bits, the selected operating mode takes effect immediately. Peripherals operating with any disabled clock are disabled until the clock becomes active. Peripherals may also be disabled with their individual control register settings. All I/O port pins, RAM, and registers are unchanged. Wake-up from LPM0 through LPM4 is possible through all enabled interrupts. www.ti.com Operating Modes When LPMx.5 (LPM3.5 or LPM4.5) is entered, the voltage regulator of the Power Management Module (PMM) is disabled. All RAM and register contents are lost. Although the I/O register contents are lost, the I/O pin states are locked upon LPMx.5 entry. See the Digital I/O chapter for further details. Wake-up from LPM4.5 is possible from a power sequence, a RST event, or from specific I/O. Wake-up from LPM3.5 is possible from a power sequence, a RST event, an RTC event, an LF crystal fault, or from specific I/O. NOTE: The TEST/SBWTCK pin is used for interfacing to the development tools through Spy-Bi-Wire. When the TEST/SBWTCK pin is high, wake-up times from LPM2 (device specific), LPM3, and LPM4 may be different compared to when TEST/SBWTCK is low. Pay careful attention to the real-time behavior when exiting from LPM2 (device specific), LPM3, and LPM4 with the device connected to a development tool (for example, MSP-FET430UIF). See the PMM chapter for details. Operating Modes www.ti.com Figure 1-5. Operation Modes www.ti.com Operating Modes ## **Table 1-2. Operation Modes** | SCG1 <sup>(1)</sup> | SCG0 | OSCOFF <sup>(1)</sup> | CPUOFF <sup>(1)</sup> | Mode | CPU and Clocks Status <sup>(2)</sup> | |---------------------|------|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | | | | CPU, MCLK are active. | | | | | | | ACLK is active. SMCLK optionally active (SMCLKOFF = 0). | | 0 | 0 | 0 | 0 | Active | DCO is enabled if sources ACLK, MCLK, or SMCLK (SMCLKOFF = 0). | | Ů | | | , and the second | 710070 | DCO bias is enabled if DCO is enabled or DCO sources MCLK or SMCLK (SMCLKOFF = 0). | | | | | | | FLL is enabled if DCO is enabled. | | | | | | | CPU, MCLK are disabled. | | | | | | | ACLK is active. SMCLK optionally active (SMCLKOFF = 0). | | 0 | 0 | 0 | 1 | LPM0 | DCO is enabled if sources ACLK or SMCLK (SMCLKOFF = 0). | | | | | | LI WO | DCO bias is enabled if DCO is enabled or DCO sources MCLK or SMCLK (SMCLKOFF = 0). | | | | | | | FLL is enabled if DCO is enabled. | | | | | | LPM2 | CPU, MCLK, and FLL are disabled. | | 1 | 0 | 0 | 1 | (device | ACLK is active. SMCLK is disabled. | | | | | | specific) | FLL is disabled. | | | | | | | CPU, MCLK, and FLL are disabled. | | 1 | 1 | 0 | 1 | LPM3 | ACLK is active. SMCLK is disabled. | | | | | | | FLL is disabled. | | 1 | 1 | 1 | 1 | LPM4 | CPU and all clocks are disabled. | | 1 | 1 | 1 | 1 | LPM3.5 | When PMMREGOFF = 1, regulator is disabled. RAM retention in backup memory. In this mode, RTC and LCD operation is possible when configured properly. See the RTC and LCD modules for further details. | | 1 | 1 | 1 | 1 | LPM4.5 | When PMMREGOFF = 1, regulator is disabled. No memory retention. In this mode, all clock sources are disabled; that is, no RTC operation is possible. | <sup>(1)</sup> LPMx.5 modes are entered by following the correct entry sequence as defined in Section 1.4.2. ## 1.4.1 Low-Power Modes and Clock Requests A peripheral module request its clock sources automatically from the clock system (CS) module if it is required for its proper operation, regardless of the current power mode of operation. For details, see Section 3.2.12. Because of the clock request mechanism the system might not reach the low-power modes requested by the bits set in the CPU status register, SR, as listed in Table 1-3. Table 1-3. Requested vs Actual LPM | Requested (SR Bits | Actual LPM | | | | | | | | |------------------------|-----------------------|------------------------|--------------------|--|--|--|--|--| | According to Table 1-2 | If No Clock Requested | If Only ACLK Requested | If SMCLK Requested | | | | | | | LPM0 | LPM0 | LPM0 | LPM0 | | | | | | | LPM2 (device specific) | LPM2 | LPM2 | LPM0 | | | | | | | LPM3 | LPM3 | LPM3 | LPM0 | | | | | | | LPM4 | LPM4 | LPM3 | LPM0 | | | | | | <sup>(2)</sup> The system clocks and the low-power modes can be affected by the clock request system. See the CS chapter for details. Operating Modes www.ti.com ## 1.4.2 Entering and Exiting Low-Power Modes LPM0 Through LPM4 An enabled interrupt event wakes the device from low-power operating modes LPM0 through LPM4. The program flow for exiting LPM0 through LPM4 is: - Enter interrupt service routine - The PC and SR are stored on the stack. - The CPUOFF, SCG1, and OSCOFF bits are automatically reset. - Options for returning from the interrupt service routine - The original SR is popped from the stack, restoring the previous operating mode. - The SR bits stored on the stack can be modified within the interrupt service routine to return to a different operating mode when the RETI instruction is executed. ``` ; Enter LPMO Example #GIE+CPUOFF,SR BTS ; Enter LPM0 ; Program stops here ; Exit LPMO Interrupt Service Routine BIC #CPUOFF, 0(SP) ; Exit LPMO on RETI RETI ; Enter LPM3 Example #GIE+CPUOFF+SCG1+SCG0,SR BIS ; Enter LPM3 . . . ; Program stops here ; Exit LPM3 Interrupt Service Routine BIC #CPUOFF+SCG1+SCG0,0(SP) ; Exit LPM3 on RETI RETI ; Enter LPM4 Example BIS #GIE+CPUOFF+OSCOFF+SCG1+SCG0, SR; Enter LPM4 ; ...; Program stops here ; Exit LPM4 Interrupt Service Routine BIC #CPUOFF+OSCOFF+SCG1+SCG0,0(SP); Exit LPM4 on RETI ``` ### 1.4.3 Low-Power Modes LPM3.5 and LPM4.5 (LPMx.5) The low-power modes LPM3.5 and LPM4.5 (LPMx.5 (1)) give the lowest power consumption on a device. In LPMx.5, the core LDO of the device is switched off. This has the following effects: - · Most of the modules are powered down. - In LPM3.5, only modules powered by the RTC LDO continue to operate. At least an RTC module is connected to the RTC LDO. See the device data sheet for other modules (if any) that are connected to the RTC LDO. - In LPM4.5 the RTC LDO and the connected modules are switched off. - The register content of all modules and the CPU is lost. - The SRAM content is lost. - A wake-up from LPMx.5 causes a complete reset of the core. - The application must initialize the complete device after a wakeup from LPMx.5. The wake-up time from LPMx.5 is much longer than the wake-up time from any other power mode (see the device-specific data sheet). This is because the core domain must power up and the device internal initialization must be done. In addition, the application must be initialized again. Therefore, use LPMx.5 only when the application is in LPMx.5 for a long time. The abbreviation "LPMx.5" is used in this document to indicate both LPM3.5 and LPM4.5. www.ti.com Operating Modes Compute Through Power Loss (CTPL) is a utility API set that leverages FRAM to enable ease of use with LPMx.5 low-power modes and to provide a powerful shutdown mode that allows an application to save and restore critical system components when a power loss is detected. Visit FRAM embedded software utilities for MSP ultra-low-power microcontrollers for details. #### 1.4.3.1 Enter LPMx.5 Follow these steps to enter LPMx.5: - 1. Store any information that must be available after wakeup from LPMx.5 in FRAM. - 2. For LPM4.5 set all ports to general-purpose I/Os (PxSEL0 = 00h and PxSEL1 = 00h). For LPM3.5 if the LF crystal oscillator is used do not change the settings for the I/Os shared with the LF-crystal-oscillator. These pins must be configured as LFXIN and LFXOUT. Set all other port pins to general-purpose I/Os with PxSEL0 and PxSEL1 bits equal to 0. - 3. Set the port pin direction and output bits as necessary for the application. - 4. To enable a wakeup from an I/O do the following: - a. Select the wakeup edge (PxIES) - b. Clear the interrupt flag (PxIFG) - c. Set the interrupt enable bit (PxIE) - 5. For LPM3.5, the modules that stay active must be enabled. For example, the RTC must be enabled if necessary. Only modules connected to the RTC LDO can stay active. - 6. For LPM3.5, enable any interrupt sources from these modules as wakeup sources, if necessary. See the corresponding module chapter. - 7. Disable the watchdog timer WDT if it is enabled and in watchdog mode. If the WDT is enabled and in watchdog mode, the device does not enter LPMx.5. - 8. Clear the GIE bit: ``` BIC #GIE, SR ``` - 9. Do the following steps to set the PMMREGOFF bit in the PMMCTL0 register: - a. Write the correct PMM password to get write access to the PMM control registers. ``` MOV.B #PMMPW_H, &PMMCTLO_H ``` b. Set PMMREGOFF bit in the PMMCTL0 register. ``` BIS.B #PMMREGOFF, &PMMCTLO_L ``` c. To disable the SVS during LPMx.5, clear the SVSHE bit in PMMCTL0. ``` BIC.B #SVSHE, &PMMCTLO_L ``` d. Write an incorrect PMM password to disable the write access to the PMM control registers. ``` MOV.B #000h, &PMMCTLO_H ``` 10. Enter LPMx.5 with the following instruction: ``` BIS #CPUOFF+OSCOFF+SCG0+SCG1, SR ``` The device enters LPM3.5 if any module that is connected to the RTC LDO is enabled. The device enters LPM4.5 if none of the modules that are connected to the RTC LDO are enabled. ## 1.4.3.2 Exit From LPMx.5 The following conditions cause an exit from LPMx.5: - A wake-up event on an I/O, if configured and enabled. The interrupt flag of the corresponding port pin is set (PxIFG). The PMMLPM5IFG bit is set. - A wake-up event from the RTC, if enabled. The corresponding interrupt flag in the RTC is set. The PMMLPM5IFG bit is set. - A wake-up signal from the RST pin. - A power cycle. Either the SVSHIFG or none of the PMMIFGs is set. Operating Modes www.ti.com Any exit from LPMx.5 causes a BOR. The program execution starts at the address the reset vector points to. PMMLPM5IFG = 1 indicates a wakeup from LPMx.5 or the System Reset Vector Word register SYSRSTIV can be used to decode the reset condition (see the device-specific data sheet). After wakeup from LPMx.5, the state of the I/Os and the modules connected to the RTC LDO are locked and remain unchanged until you clear the LOCKLPM5 bit in the PM5CTL0 register. ### 1.4.3.3 Wake up From LPM3.5 Do the following steps after a wakeup from LPM3.5: - 1. Initialize the registers of the modules connected to the RTC LDO exactly the same way as they were configured before the device entered LPM3.5 but do not enable the interrupts. - 2. Initialize the port registers exactly the same way as they were configured before the device entered LPM3.5 but do not enable port interrupts. - 3. If the LF-crystal-oscillator was used in LPM3.5 the corresponding I/Os must be configured as LFXIN and LFXOUT. The LF-crystal-oscillator must be enabled in the clock system (see the clock system CS chapter). - 4. Clear the LOCKLPM5 bit in the PM5CTL0 register. - 5. Enable port interrupts as necessary. - 6. Enable module interrupts. - 7. After enabling the port and module interrupts, the wake-up interrupt is serviced as a normal interrupt. #### 1.4.3.4 Wake up from LPM4.5 Do the following steps after a wakeup from LPM4.5: - 1. Initialize the port registers exactly the same way as they were configured before the device entered LPM4.5 but do not enable port interrupts. - 2. Clear the LOCKLPM5 bit in the PM5CTL0 register. - 3. Enable port interrupts as necessary. - 4. After enabling the port interrupts, the wake-up interrupt is serviced as a normal interrupt. If a crystal oscillator is needed after a wakeup from LPM4.5 then configure the corresponding pins and start the oscillator after you cleared the LOCKLPM5 bit. #### 1.4.4 Extended Time in Low-Power Modes The temperature coefficient of the DCO should be considered when the DCO is disabled for extended low-power mode periods. If the temperature changes significantly, the DCO frequency at wakeup may be significantly different from when the low-power mode was entered and may be out of the specified range. To avoid this, the DCO output can be divided by two before entering the low-power mode for extended periods of time where temperature can change. ## 1.5 Principles for Low-Power Applications Often, the most important factor for reducing power consumption is using the device clock system to maximize the time in LPM3 or LPM4 mode whenever possible. - Use interrupts to wake the processor and control program flow. - Peripherals should be switched on only when needed. - Use low-power integrated peripheral modules in place of software-driven functions. For example, Timer\_A and Timer\_B can automatically generate PWM and capture external timing with no CPU resources. - Calculated branching and fast table look-ups should be used in place of flag polling and long software calculations. - Avoid frequent subroutine and function calls due to overhead. - For longer software routines, single-cycle CPU registers should be used. If the application has low duty cycle and slow response time events, maximizing time in LPMx.5 can further reduce power consumption significantly. ### 1.6 Connection of Unused Pins Table 1-4 lists the correct termination of unused pins. Table 1-4. Connection of Unused Pins<sup>(1)</sup> | Pin | Potential | Comment | |--------------------------|-------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | AVCC | DV <sub>cc</sub> | | | AVSS | DV <sub>SS</sub> | | | Px.0 to Px.7 | Open | Switched to port function, output direction (PxDIR.n = 1) | | RST/NMI | DV <sub>CC</sub> or V <sub>CC</sub> | 47-kΩ pullup or internal pullup selected with 10-nF (1.1 nF) pulldown <sup>(2)</sup> | | TDO<br>TDI<br>TMS<br>TCK | Open | The JTAG pins are shared with general-purpose I/O function. If not being used, these should be switched to port function. When used as JTAG pins, these pins should remain open. | | TEST | Open | This pin always has an internal pulldown enabled. | <sup>(1)</sup> For any unused pin with a secondary function that is shared with general-purpose I/O, follow the Px.0 to Px.7 unused pin connection guidelines. ## 1.7 Reset Pin (RST/NMI) Configuration The reset pin can be configured as a reset function (default) or as an NMI function by the Special Function Register (SFR), SFRRPCR. Setting SYSNMI causes the $\overline{RST}/NMI$ pin to be configured as an external NMI source. The external NMI is edge sensitive and its edge is selectable by SYSNMIIES. Setting the NMIIE enables the interrupt of the external NMI. Upon an external NMI event, the NMIIFG is set. The RST/NMI pin can have either a pullup or pulldown present or not. SYSRSTUP selects either pullup or pulldown and SYSRSTRE causes the pullup or pulldown to be enabled or not. If the RST/NMI pin is unused, it is required to have either the internal pullup selected and enabled or an external resistor connected to the RST/NMI pin as shown in Table 1-4. There is a digital filter that suppresses short pulses on the reset pin to avoid unintended resets of the device. The minimum reset pulse duration is specified in the device-specific data sheet. The filter is active only if the pin is configured in its reset function. It is disabled if the pin is used as external NMI source. <sup>(2)</sup> The pulldown capacitor should not exceed 1.1 nF when using devices with Spy-Bi-Wire interface in Spy-Bi-Wire mode with TI tools like FET interfaces or GANG programmers. Configuring JTAG Pins www.ti.com ## 1.8 Configuring JTAG Pins The JTAG pins are shared with general-purpose I/O pins. There are several ways that the JTAG pins can be selected for 4-wire JTAG mode in software. Normally, upon a BOR, SYSJTAGPIN is cleared. With SYSJTAGPIN cleared, the JTAG are configured as general-purpose I/O. See the Digital I/O chapter for details on controlling the JTAG pins as general-purpose I/O. If SYSJTAG = 1, the JTAG pins are configured to 4-wire JTAG mode and remain in this mode until another BOR condition occurs. Therefore, SYSJTAGPIN is a write only once function. Clearing it by software is not possible, and the device does not change from 4-wire JTAG mode to general-purpose I/O. ## 1.9 Memory Map – Uses and Abilities ## 1.9.1 Memory Map This memory map represents the MSP430FR2xx and MSP430FR4xx devices. Although the address ranges differ from device to device, overall behavior remains the same. | Can generate NMI on read, write, or fetch | | | | | | | | | | |---------------------------------------------------------------------------------------|---------------------------------------|---|------------------|---|------------|---|---|--|--| | Generates PUC on fetch access | | | | | | | | | | | Protectable for read and write accesses | | | | | | | | | | | Always able to access PMM registers from <sup>(1)</sup> ; Mass erase by user possible | | | | | | | | | | | Mass erase by user possible | | | | | | | | | | | Bank erase by user possible | | | | | | | | | | | Segment erase by user pos | ssible | | | | | | | | | | Address Range | Name and Usage | | | | Propertie: | s | | | | | 00000h to 00FFFh | Peripherals with gaps | | | | | | | | | | 00000h to 000FFh | Reserved for system extension | | | | | | | | | | 00100h to 00FEFh | Peripherals | | | | | | х | | | | 00FF0h to 00FF3h | Descriptor type <sup>(2)</sup> | | | | | | х | | | | 00FF4h to 00FF7h | Start address of descriptor structure | | | | | | х | | | | 01800h to 019FFh | Information Memory | Х | х | х | х | х | | | | | 02000h to 03FFFh | RAM 8KB | | | | | | | | | | or | or<br>DAM 41/D | | | | | | | | | | 02000h to 02FFFh<br>or | RAM 4KB | | | | | | | | | | 02000h to 027FFh | RAM 2KB | | | | | | | | | | or | or | | | | | | | | | | 02000h to 023FFh<br>or | RAM 1KB | | | | | | | | | | 02000h to 021FF | RAM 512B | | | | | | | | | | 08000h to 0FFFFh | Program 32KB | Х | x <sup>(3)</sup> | х | х | х | | | | | or | or 1916 | | | | | | | | | | 0C000h to 0FFFFh<br>or | Program 16KB or | | | | | | | | | | 0C400h to 0FFFFh | Program 15KB | | | | | | | | | | or | or | | | | | | | | | | 0E000h to 0FFFFh<br>or | Program 8KB | | | | | | | | | | 0F000h to 0FFFFh | | | | | | | | | | | or | | | | | | | | | | | 0F800h to 0FFFFh | Program 2KB | | | | | | | | | | 0FC00h to 0FFFFh | | | | | | | | | | | or | Program 1KB or | | | | | | | | | | 0FE00h to 0FFFFh | Program 512B | | | | | | | | | | 0FF80h to 0FFFFh | Interrupt Vectors | | | | | | | | | <sup>(1)</sup> Access rights are separately programmable for SYS and PMM. <sup>&</sup>lt;sup>(2)</sup> On vacant memory space, the value 03FFFh is driven on the data bus. <sup>(3)</sup> Fixed ID for all MSP430 devices. See Section 1.13.1 for further details. ## 1.9.2 Vacant Memory Space Vacant memory is nonexistent memory space. Accesses to vacant memory space generate a system (non)maskable interrupt (SNMI), when the interrupt is enabled (VMAIE = 1). Reads from vacant memory result in the value 3FFFh. In the case of a fetch, this is taken as JMP \$. Fetch accesses from vacant peripheral space result in a PUC. After the boot code is executed, the boot code memory space behaves like vacant memory space and also causes an NMI on access. ## 1.9.3 FRAM Write Protection FRAM write protection allows the user to prevent any unwanted write protection to FRAM contents. The SYS module offers two separate write protection. - User program FRAM protection always used to store user main program and constant data protected by the PFWP bit in the SYSCFG0 register - User data FRAM protection always fixed from 1800h to 18FFh or 19FFh (see the device-specific data sheet on info memory) and protected by the DFWP bit in the SYSCFG0 register - Before FRAM access, the write-protect password must be written together with the program or data FRAM protection bit; see the device-specific SYSCFG0 register in Section 1.16 for details. When write protection is enabled, any write access to the protected FRAM causes an invalid write operation but does not generate an interrupt or reset. TI recommends enabling write protection at the beginning of the user initialization routine. To write data to FRAM, write the data as soon as the write protection is disabled, and then immediately enable write protection again when the write is complete. #### **CAUTION** To protect the program stored in FRAM from unintended writes, FRAM write protection must be enabled at all times, except when an intentional write operation is performed. The write operation should be completed within as short a time as possible with interrupts disabled to reduce the risk of an unintended write operation. ### 1.9.4 Bootloader (BSL) The bootloader (BSL) (formerly known as the bootstrap loader) is software that is executed after start-up when a certain BSL entry condition is applied. The BSL lets the user communicate with the embedded memory in the microcontroller during the prototyping phase, final production, and in service. All memory-mapped resources, the programmable memory (FRAM memory), the data memory (RAM), and the peripherals can be modified by the BSL as required. The user can define custom BSL code for FRAM-based devices and protect it against erasure and unintentional or unauthorized access. On devices without USB, a basic BSL program is provided by TI. This supports the commonly used UART protocol with RS232 interfacing, allowing flexible use of both hardware and software. To use the BSL, a specific BSL entry sequence must be applied to specific device pins. The correct entry sequence causes SYSBSLIND to be set. An added sequence of commands initiates the desired function. A boot-loading session can be exited by continuing operation at a defined user program address or by applying the standard reset sequence. Access to the device memory by the BSL is protected against misuse by a user-defined password. Devices with USB have a USB based BSL program provided by TI. For more details, see the MSP430 FRAM Device Bootloader (BSL) User's Guide. The amount of BSL memory that is available is device specific. The BSL memory size is organized into segments. See the device-specific data sheet for the number and size of the segments available. It is possible to assign a small amount of RAM to the allocated BSL memory. Setting SYSBSLR allocates the lowest 16 bytes of RAM for the BSL. When the BSL memory is protected, access to these RAM locations is only possible from within the protected BSL memory segments. It may be desirable in some BSL applications to only allow changing of the Power Management Module settings from the protected BSL segments. This is possible with the SYSPMMPE bit. Normally, this bit is cleared and allows access of the PMM control registers from any memory location. Setting SYSPMMPE allows access to the PMM control registers only from the protected BSL memory. After SYSPMMPE is set, it can only be cleared by a BOR event. ## 1.10 JTAG Mailbox (JMB) System The SYS module provides the capability to exchange user data through the regular JTAG or SBW test/debug interface. The idea behind the JMB is to have a direct interface to the CPU during debugging, programming, and test that is identical for all MSP430 devices of this family and uses only a few or no user application resources. The JTAG interface was chosen because it is available on all MSP430 devices and is a dedicated resource for debugging, programming, and test. Applications of the JMB are: - Providing entry password for device lock or unlock protection - Run-time data exchange (RTDX) ## 1.10.1 JMB Configuration The JMB supports two transfer modes, 16 bit and 32 bit. Set JMBMODE to enable 32-bit transfer mode. Clear JMBMODE to enable 16-bit transfer mode. # 1.10.2 SYSJMBO0 and SYSJMBO1 Outgoing Mailbox Two 16-bit registers are available for outgoing messages to the JTAG/SBW port. SYSJMBO0 is only used when using 16-bit transfer mode (JMBMODE = 0). SYSJMBO1 is used in addition to SYSJMBO0 when using 32-bit transfer mode (JMBMODE = 1). When the application wishes to send a message to the JTAG port, it writes data to SYSJMBO0 for 16-bit mode, or JBOUT0 and JBOUT1 for 32-bit mode. JMBOUT0FG and JMBOUT1FG are read only flags that indicate the status of SYSJMBO0 and SYSJMBO1, respectively. When JMBOUT0FG is set, SYSJMBO0 has been read by the JTAG port and is ready to receive new data. When JMBOUT0FG is reset, the SYSJMBO0 is not ready to receive new data. JMBOUT1FG behaves similarly. #### 1.10.3 SYSJMBIO and SYSJMBI1 Incoming Mailbox Two 16-bit registers are available for incoming messages from the JTAG port. Only SYSJMBI0 is used in 16-bit transfer mode (JMBMODE = 0). SYSJMBI1 is used in addition to SYSJMBI0 in 32-bit transfer mode (JMBMODE = 1). To send a message to the application, the JTAG port writes data to SYSJMBI0 (for 16-bit mode) or to SYSJMBI0 and SYSJMBI1 (for 32-bit mode). JMBIN0FG and JMBIN1FG are flags that indicate the status of SYSJMBI0 and SYSJMBI1, respectively. When JMBIN0FG = 1, SYSJMBI0 has data that is available for reading. When JMBIN0FG = 0, no new data is available in SYSJMBI0. JMBIN1FG behaves similarly. To configure JMBIN0FG and JMBIN1FG to clear automatically, set JMBCLR0OFF = 0 and JMBCLR1OFF = 0, respectively. Otherwise, these flags must be cleared by software. #### 1.10.4 JMB NMI Usage To avoid unnecessary polling, the JMB handshake mechanism can be configured to use interrupts. In 16-bit mode, JMBOUTIFG is set when SYSJMBO0 has been read by the JTAG port and is ready to receive data. In 32-bit mode, JMBOUTIFG is set when both SYSJMBO0 and SYSJMBO1 have been read by the JTAG port and are ready to receive data. If JMBOUTIE is set, these events cause a system NMI. In 16-bit mode, JMBOUTIFG is cleared automatically when data is written to SYSJMBO0. In 32-bit mode, JMBOUTIFG is cleared automatically when data is written to both SYSJMBO0 and SYSJMBO1. In addition, the JMBOUTIFG can be cleared when reading SYSSNIV. Clearing JMBOUTIE disables the NMI interrupt. www.ti.com Device Security In 16-bit mode, JMBINIFG is set when SYSJMBI0 is available for reading. In 32-bit mode, JMBINIFG is set when both SYSJMBI0 and SYSJMBI1 are available for reading. If JMBOUTIE is set, these events cause a system NMI. In 16-bit mode, JMBINIFG is cleared automatically when SYSJMBI0 is read. In 32bit mode, JMBINIFG Is cleared automatically when both SYSJMBI0 and SYSJMBI1 are read. In addition, the JMBINIFG can be cleared when reading SYSSNIV. Clearing JMBINIE disables the NMI interrupt. ### 1.11 Device Security This section describes options for securing the device to prevent unauthorized access from JTAG/SBW or BSL to the device memory. See Table 1-5 for a summary of security options. | Name | Addresses | Value | Device Security | | |-----------------------|----------------|----------------------------------------------|--------------------------------------------------------------------------------------------|--| | BSL Password | FFE0h to FFFFh | User defined +<br>Vector table configuration | This password must be provided by the BSL host before the device is accessible by the BSL. | | | BSL Signature | | 5555_5555h | BSL is disabled. | | | | FF84h to FF87h | AAAA_AAAAh | BSL is password protected. Mass erase on wrong BSL password feature disabled. | | | | | Any other value | BSL is password protected. Mass erase on wrong BSL password feature enabled. | | | 17.4.0.100.11.1 | | FFFF_FFFFh | JTAG/SBW is unlocked. | | | JTAG/SBW<br>Signature | FF80h to FF83h | 0000_0000h | JIAG/SDVV is utiliocked. | | | J.gaturo | | Any other value | JTAG/SBW is locked. | | Table 1-5. BSL and JTAG/SBW Signatures ## 1.11.1 JTAG and SBW Lock Mechanism (Electronic Fuse) A device can be protected from unauthorized access by restricting accessibility of JTAG commands that can be transferred to the device by the JTAG and SBW interface. This is achieved by programming the electronic fuse. When the device is protected, the JTAG and SBW interface remains functional, but JTAG commands that give direct access into the device are completely disabled. Locking the device requires the programming of two signatures in FRAM. JTAG Signature 1 (memory address 0FF80h) and JTAG Signature 2 (memory address 0FF82h) control the behavior of the device locking mechanism. Access is only possible if a BSL is provided with its corresponding key or an unlock mechanism is provided by the customer. A device can be locked by writing any value other than 0000h or FFFFh to both JTAG Signature 1 and JTAG Signature 2. In this case, the JTAG and SBW interfaces grant access to a limited JTAG command set that restricts accessibility into the device. The only way to unlock the device in this case is to use the BSL to overwrite the JTAG signatures with 0000h or FFFFh. Some JTAG commands are still possible when the device is secured, including the BYPASS command (see IEEE Std 1149-2001) and the JMB EXCHANGE command, which allows access to the JTAG Mailbox System (see Section 1.10.4 for details). Signatures that have been entered do not take effect until the next BOR event has occurred, at which time the signatures are checked. ### 1.11.2 BSL Security Mechanism Two BSL signatures, BSL Signature 1 (memory location FF84h) and BSL Signature 2 (memory location FF86h) reside in FRAM and can be used to control the behavior of the BSL. Writing 5555h to BSL Signature 1 and BSL Signature 2 disables the BSL function and any access to the BSL memory space causes a vacant memory access as described in Section 1.9. Most BSL commands require the BSL to be unlocked by a user-defined password. An incorrect password erases the device memory as a security feature. Writing AAAAh to both BSL Signature 1 and BSL Signature 2 disables this security feature. This causes a password error to be returned by the BSL, but the device memory is not erased. In this case, unlimited password attempts are possible. For more details, see MSP430 Programming With the Bootloader (BSL) and the MSP430 FRAM Device Bootloader (BSL) User's Guide. ## 1.12 Device-Specific Configurations The following sections describe the device-specific configurations. | Section 1.12.1 | MSP430FR413x and MSP430FR203x Configurations | |----------------|------------------------------------------------------------| | Section 1.12.2 | MSP430FR2433 Configurations | | Section 1.12.3 | MSP430FR263x and MSP430FR253x Configurations | | Section 1.12.4 | MSP430FR23xx Configurations (Smart Analog Combo Subfamily) | | Section 1.12.5 | MSP430FR211x Configurations | ### 1.12.1 MSP430FR413x and MSP430FR203x Configurations This section describes the configurations that are specific to MSP430FR413x and MSP430FR203x devices. #### 1.12.1.1 FRAM Write Protection The FRAM protection allows users to protect user code and data from accidental write operation. The write operation to main code FRAM and information FRAM are protected by the PFWP and DFWP bits, respectively, in the SYSCFG0 register. After a PUC reset, both bits default to 1 and writes to FRAM are disabled. User code must clear the corresponding bit before write operation. See Section 1.16.2 for register details. #### 1.12.1.2 Infrared Modulation Function The SYS module includes IR modulation logic that the device can use to easily generate accurately modulated IR waveforms, such as RC-5 data format, directly on a external output pin. Figure 1-6 shows the detailed of the circuitry implementation. Set the IREN bit in the SYSCFG1 register to enable the logic. If IREN is cleared, this function is bypassed and the external pin defaults to general-purpose I/O. This function has two different PWM input signals to support either ASK or FSK modulations. In ASK modulation, the first PWM is used for carrier generation and the second generates the envelope. In FSK modulation, the first PWM and the second PWM represent the two different offset frequencies. The IRMSEL bit in SYSCFG1 register specifies the selected mode. Before the modulated data is output to the external pin, the signal can be inverted by setting the IRPSEL bit in SYSCFG1 register for adapting to different external drive circuitry. The IR modulation function can be used with data generated by either hardware or software. In hardware data generation, the data comes from eUSCI\_A and the 8-bit data is automatically serially sent. In software data generation, IRDATA bit in SYSCFG1 register is used to control the logic 0 or 1 to be sent. The IRDSSEL bit in SYSCFG1 registers control the data flow from hardware or firmware. Figure 1-6. IR Modulation Combinatory Logic #### 1.12.1.3 ADC Pin Enable and 1.2-V Reference Settings ADC pins are multiplexed with I/O functions. When the ADC channel is used, the I/O function must be disabled to avoid function conflicts over these pins: A0 to A11. Set the ADCPTCLx bit in the SYSCFG2 register to disable the I/O functions. See Section 1.16.2 for register details. When ADC A4 channel is enabled, the 1.2-V on-chip reference can be output to P1.4 by setting PMM registers (see Figure 1-7 and the PMM Chapter). Figure 1-7. 1.2-V Reference Output on A4 ### 1.12.1.4 LCD Power Pin Enable In MSP430FR413x devices, LCD power pins are multiplexed with I/O functions. When LCD is used, the I/O function must be disabled to avoid function conflicts on these pins: LCDCAP0, LCDCAP1, R13, R23, R33. Set the LCDPCTL bit in SYSCFG2 register to disable the I/O functions and enable the LCD power functions (see Section 1.16.2.3). ## 1.12.2 MSP430FR2433 Configurations This section describes the configurations that are specific to MSP430FR2433 device. #### 1.12.2.1 FRAM Write Protection The FRAM protection allows users to protect user code and data from accidental write operation. The write operation to main code FRAM and information FRAM are protected by the PFWP and DFWP bits, respectively, in the SYSCFG0 register. After a PUC reset, both bits default to 1 and writes to FRAM are disabled. User code must write correct password and clear the corresponding bit before write operation. See Section 1.16.2 for register details. #### 1.12.2.2 Infrared Modulation Function The SYS module includes IR modulation logic that can easily generate accurately modulated IR waveforms, such as RC-5 data format, directly on a external output pin. Figure 1-8 shows the detailed of the circuitry implementation. Set the IREN bit in the SYSCFG1 register to enable the logic. If IREN is cleared, this function is bypassed, and the external pin defaults to general-purpose I/O. This function has two different PWM input signals to support either ASK or FSK modulations. In ASK modulation, the first PWM is used for carrier generation and the second generates the envelope. In FSK modulation, the first PWM and the second PWM represent the two different offset frequencies. The IRMSEL bit in SYSCFG1 register specifies the selected mode. Before the modulated data is output to the external pin, the signal can be inverted by setting the IRPSEL bit in SYSCFG1 register for adapting to different external drive circuitry. The IR modulation function can be used with data generated by either hardware or software. In hardware data generation, the data comes from eUSCI\_A or eUSCI\_B and the 8-bit data is automatically serially sent. In software data generation, IRDATA bit in SYSCFG1 register is used to control the logic 0 or 1 to be sent. The IRDSSEL bit in SYSCFG1 registers control the data flow from hardware or firmware. Figure 1-8. IR Modulation Combinatory Logic ### 1.12.2.3 ADC Pin Enable and 1.2-V Reference Settings ADC pins are multiplexed with I/O functions. When the ADC channel is used, the I/O function must be disabled to avoid function conflicts over these pins: A0 to A11. Set the ADCPTCLx bit in the SYSCFG2 register to disable the I/O functions. See Section 1.16.2 for register details. When the A4 channel of the ADC is enabled, the 1.2-V on-chip reference can be output to P1.4 by setting PMM registers (see Figure 1-9 and the PMM Chapter). Figure 1-9. 1.2-V Reference Output on A4 ## 1.12.3 MSP430FR263x and MSP430FR253x Configurations This section describes the configurations that are specific to MSP430FR263x and FR253x devices. #### 1.12.3.1 FRAM Write Protection The FRAM protection allows users to protect user code and data from accidental write operation. The write operation to main code FRAM and information FRAM are protected by the PFWP and DFWP bits, respectively, in the SYSCFG0 register. After a PUC reset, both bits default to 1 and writes to FRAM are disabled. User code must write correct password and clear the corresponding bit before write operation. See Section 1.16.2 for register details. #### 1.12.3.2 Infrared Modulation Function The SYS module includes IR modulation logic that the device can use to easily generate accurately modulated IR waveforms, such as RC-5 data format, directly on a external output pin. Figure 1-10 shows the detailed of the circuitry implementation. Set the IREN bit in the SYSCFG1 register to enable the logic. If IREN is cleared, this function is bypassed and the external pin defaults to general-purpose I/O. This function has two different PWM input signals to support either ASK or FSK modulations. In ASK modulation, the first PWM is used for carrier generation and the second generates the envelope. In FSK modulation, the first PWM and the second PWM represent the two different offset frequencies. The IRMSEL bit in SYSCFG1 register specifies the selected mode. Before the modulated data is output to the external pin, the signal can be inverted by setting the IRPSEL bit in SYSCFG1 register for adapting to different external drive circuitry. The IR modulation function can be used with data generated by either hardware or software. In hardware data generation, the data comes from eUSCI\_A or eUSCI\_B and the 8-bit data is automatically serially sent. In software data generation, IRDATA bit in SYSCFG1 register is used to control the logic 0 or 1 to be sent. The IRDSSEL bit in SYSCFG1 registers control the data flow from hardware or firmware. Figure 1-10. IR Modulation Combinatory Logic #### 1.12.3.3 ADC Pin Enable and 1.2-V Reference Settings ADC pins are multiplexed with I/O functions. When the ADC channel is used, the I/O function must be disabled to avoid function conflicts over these pins: A0 to A11. Set the ADCPTCLx bit in the SYSCFG2 register to disable the I/O functions. See Section 1.16.2 for register details. When ADC A4 channel is enabled, the 1.2-V on-chip reference can be output to P1.4 by setting PMM registers (see Figure 1-11 and the PMM Chapter). Figure 1-11. 1.2-V Reference Output on A4 ## 1.12.4 MSP430FR23xx Configurations This section describes the configurations that are specific to MSP430FR23xx devices. ## 1.12.4.1 FRAM Write Protection The FRAM protection allows users to protect user code from accidental write operation. The write operation to main code FRAM is protected by the PFWP bit in the SYSCFG0 register. After a PUC reset, this bit defaults to 1, and writes to FRAM are disabled. User code must write the correct password and clear the corresponding bit before write operation. See Section 1.16.1 for register details. In MSP430FR235x devices, the program FRAM can be partially protected by an offset specified by FRWPOA from the starting address of main FRAM memory. When PFWP is set, the main memory after this offset is protected, and the part before this address is unprotected. This unprotected range can be used like RAM for random frequent writes. The 6-bit FRWPOA can specify the offset from 0KB to 63KB with 1KB resolution. After reset, FRWPOA defaults to zero, and the entire program FRAM is under the protection of PFWP. FRWPOA can be modified in parallel when FRWPPW is correctly written. Figure 1-12 shows how the data and program FRAM are protected in these devices. Figure 1-12. Memory Protection #### 1.12.4.2 Infrared Modulation Function The SYS module includes IR modulation logic that the application can use to generate accurately modulated IR waveforms, such as RC-5 data format, directly on a external output pin. Figure 1-13 shows the circuitry. Set the IREN bit in the SYSCFG1 register to enable the logic. If IREN is cleared, this function is bypassed, and the external pin defaults to general-purpose I/O. The IR modulation function has two different PWM input signals to support either ASK or FSK modulations. In ASK modulation, the first PWM is used for carrier generation, and the second PWM generates the envelope. In FSK modulation, the first PWM and the second PWM represent the two different offset frequencies. The IRMSEL bit in SYSCFG1 register specifies the selected mode. Before the modulated data is output to the external pin, the signal can be inverted by setting the IRPSEL bit in the SYSCFG1 register for adapting to different external drive circuitry. The IR modulation function can be used with data generated by either hardware or software. In hardware data generation, the data comes from eUSCI\_A or eUSCI\_B, and the 8-bit data is automatically serially sent. In software data generation, IRDATA bit in SYSCFG1 register is used to control the logic 0 or 1 to be sent. The IRDSSEL bit in SYSCFG1 registers control the data flow from hardware or firmware. Figure 1-13. IR Modulation Combinatory Logic # 1.12.4.3 ADC Pin Enable and 1.2-V Reference Settings ADC pins are multiplexed with I/O functions. When the ADC channel is used, the I/O function must be disabled to avoid function conflicts over these pins: A0 to A11. Set the PxSEL bit in the port register to disable the I/O functions. See the MSP430FR23xx device-specific data sheet for details. When ADC A7 channel is enabled, the 1.2-V on-chip reference can be output to P1.7 by setting PMM registers (see Figure 1-11 and the PMM Chapter). Figure 1-14. 1.2-V Reference Output on A7 ## 1.12.5 MSP430FR211x Configurations This section describes the configurations that are specific to MSP430FR211x devices. #### 1.12.5.1 FRAM Write Protection The FRAM protection allows users to protect user code from accidental write operation. The write operation to main code FRAM is protected by the PFWP, respectively, in the SYSCFG0 register. After a PUC reset, this bit is default to 1 and writes to FRAM is disabled. User code must write correct password and clear the corresponding bit before write operation. See Section 1.16.1 for register details. #### 1.12.5.2 Infrared Modulation Function The SYS module includes IR modulation logic that the device can use to easily generate accurately modulated IR waveforms directly on a external output pin. Default output is on P1.7/UCA0TXD/UCA0SIMO, or the output can be changed to P1.3/UCA0TXD/UCA0SIMO by enabling the USCIARMP bit in the SYSCFG3 register. Figure 1-13 shows the details of the circuitry implementation. Set the IREN bit in the SYSCFG1 register to enable the logic. If IREN is cleared, this function is bypassed and the external pin defaults to general-purpose I/O. This function has two different PWM input signals to support either ASK or part of FSK modulations. In ASK modulation, the first PWM is used for carrier generation and the second generates the envelope. In FSK modulation, the first PWM and the second PWM represent the two different offset frequencies. The IRMSEL bit in SYSCFG1 register specifies the selected mode. Before the modulated data is output to the external pin, the signal can be inverted by setting the IRPSEL bit in SYSCFG1 register for adapting to different external drive circuitry. The IR modulation function can be used with data generated by either hardware or software. In hardware data generation, the data comes from eUSCI\_A or eUSCI\_B and the 8-bit data is automatically serially sent. In software data generation, IRDATA bit in SYSCFG1 register is used to control the logic 0 or 1 to be sent. The IRDSSEL bit in SYSCFG1 registers control the data flow from hardware or firmware. Figure 1-15. IR Modulation Combinatory Logic www.ti.com Device Descriptor Table ## 1.12.5.3 ADC Pin Enable and 1.2-V Reference Settings ADC pins are multiplexed with I/O functions. When the ADC channel is used, the I/O function must be disabled to avoid function conflicts over these pins: A0 to A11. Set the PxSEL bit in the Port register to disable the I/O functions. See MSP430FR231x devices specific for details. When ADC A7 channel is enabled, the 1.2-V on-chip reference can be output to P1.7 by setting PMM registers (see Figure 1-11 and the PMM Chapter). Figure 1-16. 1.2-V Reference Output on A7 ## 1.13 Device Descriptor Table Each device provides a data structure in memory that allows an unambiguous identification of the device as well as a description of the available modules on a given device. SYS provides this information and can be used by device-adaptive software tools and libraries to clearly identify a particular device and all of its modules and capabilities. The validity of the device descriptor can be verified by cyclic redundancy check (CRC). The CRC checksum covers a device-specific TLV range. See the TLV table in the device-specific data sheet for the definitions. Figure 1-17 shows the logical order and structure of the device descriptor table. The complete device descriptor table and its contents can be found in the device-specific data sheet. Device Descriptor Table www.ti.com Figure 1-17. Devices Descriptor Table ## 1.13.1 Identifying Device Type The value at address location 00FF0h identifies the family branch of the device. All values starting with 80h indicate a hierarchical structure that consists of the information block and a tag-length-value (TLV) structure with the various descriptors. Any value other than 80h at address location 00FF0h indicates that the device is of an older family and contains a flat descriptor beginning at location 0FF0h. The information block, shown in Figure 1-17 contains the device ID, die revisions, firmware revisions, and other manufacturer and tool related information. The descriptors contains information about the available peripherals and their subtypes and addresses and provides the information required to build adaptive hardware drivers for operating systems. The length of the descriptors is represented by Info\_length and is computed as shown in Equation 1. Length = $2^{lnfo\_length}$ in 32-bit words (1) For example, if Info\_length = 5, then the length of the descriptors equals 128 bytes. #### 1.13.2 TLV Descriptors The TLV descriptors follow the information block. Because the information block is always a fixed length, the start location of the TLV descriptors is fixed for a given device family. See the device-specific data sheet for the complete TLV structure and what descriptors are available. The TLV descriptors are unique to their respective TLV block and are always followed by the descriptor block length. www.ti.com Device Descriptor Table Each TLV descriptor contains a tag field that identifies the descriptor type. Table 1-6 lists the currently supported tags. | Short Name | Value | Description | |------------|------------|---------------------------------| | LDTAG | 01h | Legacy descriptor | | PDTAG | 02h | Peripheral discovery descriptor | | Reserved | 03h | Future use | | Reserved | 04h | Future use | | BLANK | 05h | Blank descriptor | | Reserved | 06h | Future use | | ADCCAL | 11h | ADC calibration | | REFCAL | 12h | REF calibration | | Reserved | 13h to FDh | Future use | | TAGEXT | FEh | Tag extender | Table 1-6. Tag Values Each tag field is unique to its respective descriptor and is always followed by a length field. The length field is one byte if the tag value is 01h through 0FDh and represents the length of the descriptor in bytes. If the tag value equals 0FEh (TAGEXT), the next byte extends the tag values, and the following two bytes represent the length of the descriptor in bytes. In this way, a user can search through the TLV descriptor table for a particular tag value using a routine similar to the following, which is written in pseudo code: ``` // Identify the descriptor ID (d_ID_value) for the TLV descriptor of interest: descriptor_address = TLV_START address; while ( value at descriptor_address != d_ID_value && descriptor_address != TLV_TAGEND && descriptor_address < TLV_END) { // Point to next descriptor descriptor_address = descriptor_address + (length of the current TLV block) + 2; } if (value at descriptor_address == d_ID_value) { // Appropriate TLV descriptor has been found! Return length of descriptor & descriptor_address as the location of the TLV descriptor } } else { // No TLV descriptor found with a matching d_ID_value Return a failing condition }</pre> ``` #### 1.13.3 Calibration Values The TLV structure contains calibration values that can be used to improve the measurement capability of various functions. The calibration values available on a given device are shown in the TLV structure of the device-specific data sheet. ### 1.13.3.1 1.5-V Reference Calibration The calibration data consists a word for reference voltage available (1.5 V). The reference voltages are measured at room temperature. The measured values are normalized by 1.5 V before being stored into the TLV structure: $$Factor_{gain\_1.5Vref} = \frac{V_{REF+}}{1.5V} \times 2^{15}$$ (2) In this way, a conversion result is corrected by multiplying it with the $Factor_{gain\_1.5Vref}$ and dividing the result by $2^{15}$ as shown for each of the respective reference voltages: $$ADC_{calibrated} = ADC_{raw} \times Factor_{gain\_1.5 Vref} \times \frac{1}{2^{15}}$$ (3) Device Descriptor Table www.ti.com In the following example, the integrated 1.5-V reference voltage is used during a conversion. - Conversion result: 0x0100 = 256 decimal - Reference voltage calibration factor (Factor<sub>gain 1.5Vref</sub>): 0x7BBB The following steps show how the ADC conversion result can be corrected: - Multiply the conversion result by 2 (this step simplifies the final division): 0x0100 x 0x0002 = 0x0200 - Multiply the result by Factor<sub>gain\_1.5Vref</sub>: 0x200 x 0x7BBB = 0x00F7\_7600 - Divide the result by 2<sup>16</sup>: 0x00F7\_7600 / 0x0001\_0000 = 0x0000\_00F7 = 247 decimal #### 1.13.3.2 ADC Offset and Gain Calibration The offset of the ADC is determined and stored as a twos-complement number in the TLV structure. The offset error correction is done by adding the $ADC_{offset}$ to the conversion result. $$ADC_{offset\_calibrated} = ADC_{raw} + ADC_{offset}$$ (4) The gain factor of the ADC is calculated by Equation 5: $$Factor_{gain} = \frac{1}{Gain} \times 2^{15}$$ (5) The conversion result is gain corrected by multiplying it with the Factor<sub>gain</sub> and dividing the result by 2<sup>15</sup>: $$ADC_{gain\_calibrated} = ADC_{raw} \times Factor_{gain} \times \frac{1}{2^{15}}$$ (6) If both gain and offset are corrected, the gain correction is done first: $$ADC_{calibrated} = ADC_{raw} \times Factor_{gain} \times \frac{1}{2^{15}} + ADC_{offset}$$ (7) #### 1.13.3.3 Temperature Sensor Calibration The temperature sensor is calibrated using the internal voltage references. The 1.5-V reference voltage contains a measured value for two temperatures, room temperature (typically, the value is 30°C) and high temperature (85°C or 105°C; see the device-specific data sheet for details), which are stored in the TLV structure. The characteristic equation of the temperature sensor voltage, in mV is: $$V_{\text{sense}} = TC_{\text{sensor}} \times Temperature + V_{\text{sensor}}$$ (8) The temperature coefficient, $TC_{SENSOR}$ , in mV/°C, represents the slope of the equation. $V_{SENSOR}$ , in mV, represents the y-intercept of the equation. Temp, in °C, is the temperature of interest. The temperature (*Temp*, °C) can be computed as follows for each of the reference voltages used in the ADC measurement: Temperature = $$(ADC_{raw} - ADC_{30^{\circ}C_{1.5Vref}}) \times \left(\frac{55^{\circ}C}{ADC_{85^{\circ}C_{1.5Vref}} - ADC_{30^{\circ}C_{1.5Vref}}}\right) + 30^{\circ}C$$ (9) $$Temperature = (ADC_{raw} - ADC_{30^{\circ}C\_1.5Vref}) \times \left(\frac{75^{\circ}C}{ADC_{105^{\circ}C\_1.5Vref} - ADC_{30^{\circ}C\_1.5Vref}}\right) + 30^{\circ}C$$ $$(10)$$ #### 1.13.3.4 DCO Calibration The DCO calibration is stored for a quick setting to maximum DCO frequency (for example, 16 MHz) at room temperature. Loading this value to the CSCTL0 register significantly reduces the FLL lock time when the MCU reboot or exits from a low-power mode. If a possible frequency overshoot caused by temperature drift is expected after exit from an LPM, TI recommends dividing the DCO frequency before use. For more details, see Section 1.4.4. SFR Registers www.ti.com ## 1.14 SFR Registers The SFRs are listed in Table 1-8. The base address for the SFRs is listed in Table 1-7. Many of the bits in the SFRs are described in other chapters throughout this user's guide. These bits are marked with a note and a reference. See the module-specific chapter for details. NOTE: All registers have word or byte register access. For a generic register ANYREG, the suffix "\_L" (ANYREG\_L) refers to the lower byte of the register (bits 0 through 7). The suffix "\_H" (ANYREG\_H) refers to the upper byte of the register (bits 8 through 15). Table 1-7. SFR Base Address | Module | Base Address | |--------|--------------| | SFR | 00100h | Table 1-8. SFR Registers | Offset | Acronym | Register Name | Туре | Access | Reset | Section | |--------|------------------|-------------------|------------|--------|-------|----------------| | 00h | SFRIE1 | Interrupt Enable | Read/write | Word | 0000h | Section 1.14.1 | | 00h | SFRIE1_L (IE1) | | Read/write | Byte | 00h | | | 01h | SFRIE1_H (IE2) | | Read/write | Byte | 00h | | | 02h | SFRIFG1 | Interrupt Flag | Read/write | Word | 0082h | Section 1.14.2 | | 02h | SFRIFG1_L (IFG1) | | Read/write | Byte | 82h | | | 03h | SFRIFG1_H (IFG2) | | Read/write | Byte | 00h | | | 04h | SFRRPCR | Reset Pin Control | Read/write | Word | 001Ch | Section 1.14.3 | | 04h | SFRRPCR_L | | Read/write | Byte | 1Ch | | | 05h | SFRRPCR_H | | Read/write | Byte | 00h | | SFR Registers www.ti.com # 1.14.1 SFRIE1 Register (offset = 00h) [reset = 0000h] Interrupt Enable Register ## Figure 1-18. SFRIE1 Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------|---------|----------|-------|-------|----------|---------------------|-------| | | | | Rese | erved | | | | | r0 | rO | rO | rO | r0 | rO | rO | r0 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | JMBOUTIE | JMBINIE | Reserved | NMIIE | VMAIE | Reserved | OFIE <sup>(1)</sup> | WDTIE | | rw-0 | rw-0 | r0 | rw-0 | rw-0 | rw-0 | rw-0 | rw-0 | <sup>(1)</sup> See the CS chapter for details. # Table 1-9. SFRIE1 Register Description | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-8 | Reserved | R | 0h | Reserved. Always reads as 0. | | 7 | JMBOUTIE | RW | 0h | JTAG mailbox output interrupt enable flag 0b = Interrupts disabled 1b = Interrupts enabled | | 6 | JMBINIE | RW | 0h | JTAG mailbox input interrupt enable flag 0b = Interrupts disabled 1b = Interrupts enabled | | 5 | Reserved | RW | 0h | Reserved. | | 4 | NMIIE | RW | 0h | NMI pin interrupt enable flag 0b = Interrupts disabled 1b = Interrupts enabled | | 3 | VMAIE | RW | 0h | Vacant memory access interrupt enable flag 0b = Interrupts disabled 1b = Interrupts enabled | | 2 | Reserved | R | 0h | Reserved. Always reads as 0. | | 1 | OFIE | RW | 0h | Oscillator fault interrupt enable flag 0b = Interrupts disabled 1b = Interrupts enabled | | 0 | WDTIE | RW | 0h | Watchdog timer interrupt enable. This bit enables the WDTIFG interrupt for interval timer mode. It is not necessary to set this bit for watchdog mode. Because other bits in SFRIE1 may be used for other modules, it is recommended to set or clear this bit using BIS.B or BIC.B instructions, rather than MOV.B or CLR.B instruction. Ob = Interrupts disabled 1b = Interrupts enabled | www.ti.com SFR Registers # 1.14.2 SFRIFG1 Register (offset = 02h) [reset = 0082h] Interrupt Flag Register ## Figure 1-19. SFRIFG1 Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |-----------|----------|----------|--------|--------|----------|----------------------|--------|--|--| | Reserved | | | | | | | | | | | r0 | rO | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | JMBOUTIFG | JMBINIFG | Reserved | NMIIFG | VMAIFG | Reserved | OFIFG <sup>(1)</sup> | WDTIFG | | | | rw-(1) | rw-(0) | r0 | rw-0 | rw-0 | r0 | rw-(1) | rw-0 | | | <sup>(1)</sup> See the Clock System chapter for details. # Table 1-10. SFRIFG1 Register Description | Bit | Field | Туре | Reset | Description | | | |------|-----------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | 15-8 | Reserved | R | 0h | Reserved. Always reads as 0. | | | | 7 | JMBOUTIFG | RW | 1h | JTAG mailbox output interrupt flag 0b = No interrupt pending. When in 16-bit mode (JMBMODE = 0), this bit is cleared automatically when SYSJMBO0 has been written with a new message to the JTAG module by the CPU. When in 32-bit mode (JMBMODE = 1), this bit is cleared automatically when both SYSJMBO0 and SYSJMBO1 have been written with new messages to the JTAG module by the CPU. This bit is also cleared when the associated vector in SYSUNIV has been read. 1b = Interrupt pending, SYSJMBOx registers are ready for new messages. In 16-bit mode (JMBMODE = 0), SYSJMBO0 has been received by the JTAG module and is ready for a new message from the CPU. In 32-bit mode (JMBMODE = 1), SYSJMBO0 and SYSJMBO1 have been received by the JTAG module and are ready for new messages from the CPU. | | | | 6 | JMBINIFG | RW | Oh | JTAG mailbox input interrupt flag 0b = No interrupt pending. When in 16-bit mode (JMBMODE = 0), this bit is cleared automatically when JMBI0 is read by the CPU. When in 32-bit mode (JMBMODE = 1), this bit is cleared automatically when both JMBI0 and JMI have been read by the CPU. This bit is also cleared when the associated verin SYSUNIV has been read 1b = Interrupt pending, a message is waiting in the SYSJMBIx registers. In mode (JMBMODE = 0) when JMBI0 has been written by the JTAG module. 32-bit mode (JMBMODE = 1) when JMBI0 and JMBI1 have been written by JTAG module. | | | | 5 | Reserved | R | 0h | Reserved. Always reads as 0. | | | | 4 | NMIIFG | RW | 0h | NMI pin interrupt flag 0b = No interrupt pending 1b = Interrupt pending | | | | 3 | VMAIFG | RW | Oh | Vacant memory access interrupt flag 0b = No interrupt pending 1b = Interrupt pending | | | | 2 | Reserved | R | 0h | Reserved. Always reads as 0. | | | | 1 | OFIFG | RW | 1h | Oscillator fault interrupt flag 0b = No interrupt pending 1b = Interrupt pending | | | | 0 | WDTIFG | RW | Oh | Watchdog timer interrupt flag. In watchdog mode, WDTIFG self clears upon a watchdog timeout event. The SYSRSTIV can be read to determine if the reset was caused by a watchdog timeout event. In interval mode, WDTIFG is reset automatically by servicing the interrupt, or can be reset by software. Because other bits in SFRIFG1 may be used for other modules, it is recommended to set or clear WDTIFG by using BIS.B or BIC.B instructions, rather than MOV.B or CLR.B instructions. 0b = No interrupt pending 1b = Interrupt pending | | | SFR Registers www.ti.com # 1.14.3 SFRRPCR Register (offset = 04h) [reset = 001Ch] Reset Pin Control Register ## Figure 1-20. SFRRPCR Register ## Table 1-11. SFRRPCR Register Description | Bit | Field | Туре | Reset | Description | |------|-----------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-5 | Reserved | R | 0h | Reserved. Always reads as 0. | | 4 | SYSFLTE | RW | 1h | Reset pin filter enable | | | | | | 0b = Digital filter on reset pin is disabled | | | | | | 1b = Digital filter on reset pin is enabled | | 3 | SYSRSTRE | RW | 1h | Reset pin resistor enable | | | | | | Ob = Pullup or pulldown resistor at the $\overline{RST}/NMI$ pin is disabled | | | | | | 1b = Pullup or pulldown resistor at the RST/NMI pin is enabled | | 2 | SYSRSTUP | RW | 1h | Reset resistor pin pullup/pulldown | | | | | | 0b = Pulldown is selected | | | | | | 1b = Pullup is selected | | 1 | SYSNMIIES | RW | 0h | NMI edge select. This bit selects the interrupt edge for the NMI when SYSNMI = 1. Modifying this bit can trigger an NMI. Modify this bit when SYSNMI = 0 to avoid triggering an accidental NMI. | | | | | | 0b = NMI on rising edge | | | | | | 1b = NMI on falling edge | | 0 | SYSNMI | RW | 0h | NMI select. This bit selects the function for the RST/NMI pin. | | | | | | 0b = Reset function | | | | | | 1b = NMI function | SYS Registers www.ti.com ## 1.15 SYS Registers The SYS registers are listed in Table 1-12. A detailed description of each register and its bits is provided in the following sections. Each register starts at a word boundary. Either word or byte data can be written to the SYS configuration registers. NOTE: All registers have word or byte register access. For a generic register ANYREG, the suffix "\_L" (ANYREG\_L) refers to the lower byte of the register (bits 0 through 7). The suffix "\_H" (ANYREG\_H) refers to the upper byte of the register (bits 8 through 15). Table 1-12. SYS Registers | Offset | Acronym | Register Name | Туре | Access | Reset | Section | |--------|------------|-----------------------------|------------|--------|-------|-----------------| | 00h | SYSCTL | System Control | Read/write | Word | 0000h | Section 1.15.1 | | 00h | SYSCTL_L | | Read/write | Byte | 00h | | | 01h | SYSCTL_H | | Read/write | Byte | 00h | | | 02h | SYSBSLC | Bootloader Configuration | Read/write | Word | 0000h | Section 1.15.2 | | 02h | SYSBSLC_L | | Read/write | Byte | 00h | | | 03h | SYSBSLC_H | | Read/write | Byte | 00h | | | 06h | SYSJMBC | JTAG Mailbox Control | Read/write | Word | 000Ch | Section 1.15.3 | | 06h | SYSJMBC_L | | Read/write | Byte | 0Ch | | | 07h | SYSJMBC_H | | Read/write | Byte | 00h | | | 08h | SYSJMBI0 | JTAG Mailbox Input 0 | Read/write | Word | 0000h | Section 1.15.4 | | 08h | SYSJMBI0_L | | Read/write | Byte | 00h | | | 09h | SYSJMBI0_H | | Read/write | Byte | 00h | | | 0Ah | SYSJMBI1 | JTAG Mailbox Input 1 | Read/write | Word | 0000h | Section 1.15.5 | | 0Ah | SYSJMBI1_L | | Read/write | Byte | 00h | | | 0Bh | SYSJMBI1_H | | Read/write | Byte | 00h | | | 0Ch | SYSJMBO0 | JTAG Mailbox Output 0 | Read/write | Word | 0000h | Section 1.15.6 | | 0Ch | SYSJMBO0_L | | Read/write | Byte | 00h | | | 0Dh | SYSJMBO0_H | | Read/write | Byte | 00h | | | 0Eh | SYSJMBO1 | JTAG Mailbox Output 1 | Read/write | Word | 0000h | Section 1.15.7 | | 0Eh | SYSJMBO1_L | | Read/write | Byte | 00h | | | 0Fh | SYSJMBO1_H | | Read/write | Byte | 00h | | | 1Ah | SYSUNIV | User NMI Vector Generator | Read | Word | 0000h | Section 1.15.8 | | 1Ch | SYSSNIV | System NMI Vector Generator | Read | Word | 0000h | Section 1.15.9 | | 1Eh | SYSRSTIV | Reset Vector Generator | Read | Word | 0002h | Section 1.15.10 | SYS Registers www.ti.com # 1.15.1 SYSCTL Register (offset = 00h) [reset = 0000h] SYS Control Register ## Figure 1-21. SYSCTL Register ## Table 1-13. SYSCTL Register Description | Bit | Field | Туре | Reset | Description | | | | | |------|------------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | 15-8 | Reserved | R | 0h | Reserved. Always reads as 0. | | | | | | 7-6 | Reserved | R | 0h | Reserved. Always reads as 0. Dedicated JTAG pins enable. Setting this bit disables the shared digital functionality of the JTAG pins and permanently enables the JTAG function. To bit can only be set once. After the bit is set, it remains set until a BOR occurs ob = Shared JTAG pins (JTAG mode selectable by JTAG/SBW sequence) 1b = Dedicated JTAG pins (explicit 4-wire JTAG mode selection) | | | | | | 5 | SYSJTAGPIN | RW | 0h | functionality of the JTAG pins and permanently enables the JTAG function. This bit can only be set once. After the bit is set, it remains set until a BOR occurs. Ob = Shared JTAG pins (JTAG mode selectable by JTAG/SBW sequence) | | | | | | 4 | SYSBSLIND | RW | 0h | BSL entry indication. This bit indicates a BSL entry sequence detected on the Spy-Bi-Wire pins. 0b = No BSL entry sequence detected 1b = BSL entry sequence detected | | | | | | 3 | Reserved | R | 0h | Reserved. Always reads as 0. | | | | | | 2 | SYSPMMPE | RW | Oh | PMM access protect. This controls the accessibility of the PMM control registers. After the bit is set to 1, it only can be cleared by a BOR. Ob = Access from anywhere in memory 1b = Access only from the protected BSL segments | | | | | | 1 | Reserved | R | 0h | Reserved. Always reads as 0. | | | | | | 0 | SYSRIVECT | RW | Oh | RAM-based interrupt vectors 0b = Interrupt vectors generated with end address TOP of lower 64KB of FRAM FFFFh 1b = Interrupt vectors generated with end address TOP of RAM | | | | | www.ti.com SYS Registers # 1.15.2 SYSBSLC Register (offset = 02h) [reset = 0000h] Bootloader Configuration Register # Figure 1-22. SYSBSLC Register ## Table 1-14. SYSBSLC Register Description | Bit | Field | Туре | Reset | Description | | |------|-----------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | 15 | SYSBSLPE | RW | Oh | Bootloader memory protection enable. By default, this bit is cleared by hardwith a BOR event (as indicated above); however, the boot code that checks an available BSL may set this bit in software to protect the BSL. Because devices normally come with a TI BSL preprogrammed and protected, the boo code sets this bit. | | | | | | | 0b = Area not protected. Read, program, and erase of BSL memory is possible. 1b = Area protected | | | 14 | SYSBSLOFF | RW | 0h | Bootloader memory disable | | | | | | | 0b = BSL memory is addressed when this area is read. | | | | | | | 1b = BSL memory behaves like vacant memory. Reads cause 3FFFh to be read. Fetches cause JMP \$ to be executed. | | | 13-3 | Reserved | R | 0h | Reserved. Always reads as 0. | | | 2 | SYSBSLR | RW | 0h | RAM assigned to BSL | | | | | | | 0b = No RAM assigned to BSL area | | | | | | | 1b = Lowest 16 bytes of RAM assigned to BSL | | | 1-0 | Reserved | R | 0h | Reserved. Always reads as 0. | | SYS Registers www.ti.com # 1.15.3 SYSJMBC Register (offset = 06h) [reset = 000Ch] JTAG Mailbox Control Register ## Figure 1-23. SYSJMBC Register ## Table 1-15. SYSJMBC Register Description | Bit | Field | Туре | Reset | Description | | | | |------|------------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | 15-8 | Reserved | R | 0h | Reserved. Always reads as 0. | | | | | 7 | JMBCLR1OFF | RW | Oh | Incoming JTAG Mailbox 1 flag auto-clear disable 0b = JMBIN1FG cleared on read of SYSJMBI1 register 1b = JMBIN1FG cleared by software | | | | | 6 | JMBCLR0OFF | RW | 0h | Incoming JTAG Mailbox 0 flag auto-clear disable 0b = JMBIN0FG cleared on read of SYSJMBI0 register 1b = JMBIN0FG cleared by software | | | | | 5 | Reserved | R | 0h | Reserved. Always reads as 0. | | | | | 4 | JMBMODE | RW | 0h | This bit defines the operation mode of JMB for SYSJMBI0, SYSJMBI1, SYSJMBO0, and SYSJMBO1. Before changing this bit, pad and flush out any partial content to avoid data drops. 0b = 16-bit transfers using SYSJMBO0 and SYSJMBI0 only 1b = 32-bit transfers using SYSJMBI0, SYSJMBI1, SYSJMBO0, and SYSJMBO1 | | | | | 3 | JMBOUT1FG | RW | 1h | Outgoing JTAG Mailbox 1 flag. This bit is cleared automatically when a message is written to the upper byte SYSJMBO1 or as word access (by the CPU or other source) and is set after message is read by JTAG. Ob = SYSJMBO1 is not ready to receive new data. 1b = SYSJMBO1 is ready to receive new data. | | | | | 2 | JMBOUT0FG | RW | 1h | Outgoing JTAG Mailbox 0 flag. This bit is cleared automatically when a message is written to the upper byte of SYSJMBO0 or as word access (by the CPU or other source) and is set after the message is read by JTAG. 0b = SYSJMBO0 is not ready to receive new data. 1b = SYSJMBO0 is ready to receive new data. | | | | | 1 | JMBIN1FG | RW | Oh | Incoming JTAG Mailbox 1 flag. This bit is set when a new message (provided by JTAG) is available in SYSJMBI1. This flag is cleared automatically on read of SYSJMBI1 when JMBCLR1OFF = 0 (auto clear mode). If JMBCLR1OFF = 1, JMBIN1FG must be cleared by software. 0b = SYSJMBI1 has no new data 1b = SYSJMBI1 has new data available | | | | | 0 | JMBIN0FG | RW | Oh | Incoming JTAG Mailbox 0 flag. This bit is set when a new message (provided by JTAG) is available in SYSJMBI0. This flag is cleared automatically on read of SYSJMBI0 when JMBCLR0OFF = 0 (auto clear mode). If JMBCLR0OFF = 1, JMBIN0FG must be cleared by software. 0b = SYSJMBI1 has no new data 1b = SYSJMBI1 has new data available | | | | www.ti.com SYS Registers # 1.15.4 SYSJMBIO Register (offset = 08h) [reset = 0000h] JTAG Mailbox Input 0 Register ## Figure 1-24. SYSJMBI0 Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | |-----|-------|-----|-----|-----|-----|-----|-----|--|--|--|--|--| | | MSGHI | | | | | | | | | | | | | r-0 | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | MSGLO | | | | | | | | | | | | | r-0 | | | | | ## Table 1-16. SYSJMBI0 Register Description | Bit | Field | Туре | Reset | Description | | | |------|-------|------|-------|-----------------------------------------|--|--| | 15-8 | MSGHI | R | 0h | JTAG mailbox incoming message high byte | | | | 7-0 | MSGLO | R | 0h | JTAG mailbox incoming message low byte | | | # 1.15.5 SYSJMBI1 Register (offset = 0Ah) [reset = 0000h] JTAG Mailbox Input 1 Register ## Figure 1-25. SYSJMBI1 Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | |-------|-----|-----|-----|-----|-----|-----|-----|--|--|--|--| | MSGHI | | | | | | | | | | | | | r-0 | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | MSGLO | | | | | | | | | | | | | r-0 | | | | # Table 1-17. SYSJMBI1 Register Description | Bit | Field | Туре | Reset | Description | | |------|-------|------|-------|-----------------------------------------|--| | 15-8 | MSGHI | R | 0h | JTAG mailbox incoming message high byte | | | 7-0 | MSGLO | R | 0h | JTAG mailbox incoming message low byte | | SYS Registers www.ti.com # 1.15.6 SYSJMBO0 Register (offset = 0Ch) [reset = 0000h] JTAG Mailbox Output 0 Register ## Figure 1-26. SYSJMBO0 Register ## Table 1-18. SYSJMBO0 Register Description | Bit | Field | Туре | Reset | Description | | | |------|-------|------|-------|-----------------------------------------|--|--| | 15-8 | MSGHI | RW | 0h | JTAG mailbox outgoing message high byte | | | | 7-0 | MSGLO | RW | 0h | JTAG mailbox outgoing message low byte | | | # 1.15.7 SYSJMBO1 Register (offset = 0Eh) [reset = 0000h] JTAG Mailbox Output 1 Register ## Figure 1-27. SYSJMBO1 Register | | | | | | • | | | | | | | | |------|-------|------|------|------|------|------|------|--|--|--|--|--| | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | | | MSGHI | | | | | | | | | | | | | rw-0 | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | MSGLO | | | | | | | | | | | | | rw-0 | | | | | ## Table 1-19. SYSJMBO1 Register Description | Bit | Field | Туре | Reset | Description | |------|-------|------|-------|-----------------------------------------| | 15-8 | MSGHI | RW | 0h | JTAG mailbox outgoing message high byte | | 7-0 | MSGLO | RW | 0h | JTAG mailbox outgoing message low byte | SYS Registers www.ti.com # 1.15.8 SYSUNIV Register (offset = 1Ah) [reset = 0000h] User NMI Vector Register NOTE: Additional events for more complex devices will be appended to this table; sources that are removed reduce the length of this table. The vectors are expected to be accessed symbolic only with the corresponding include file of the device in use. ## Figure 1-28. SYSUNIV Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----|----|----|-----|------|-----|-----|----| | | | | SYS | UNIV | | | | | r0 | rO | rO | rO | rO | rO | r0 | rO | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | SYS | UNIV | | | | | r0 | r0 | r0 | r-0 | r-0 | r-0 | r-0 | r0 | ## Table 1-20. SYSUNIV Register Description | Bit | Field | Туре | Reset | Description | |------|---------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-0 | SYSUNIV | R | | User NMI vector. Generates a value that can be used as address offset for fast interrupt service routine handling. Writing to this register clears all pending user NMI flags. See the device-specific data sheet for a list of values. | ## 1.15.9 SYSSNIV Register (offset = 1Ch) [reset = 0000h] System NMI Vector Register NOTE: Additional events for more complex devices will be appended to this table; sources that are removed reduce the length of this table. The vectors are expected to be accessed symbolic only with the corresponding include file of the device in use. #### Figure 1-29. SYSSNIV Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----|----|----|-----|------|-----|-----|----| | | | | SYS | SNIV | | | | | r0 | r0 | r0 | rO | rO | r0 | r0 | rO | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | SYS | SNIV | | | | | rO | r0 | r0 | r-0 | r-0 | r-0 | r-0 | r0 | ## Table 1-21. SYSSNIV Register Description | Bit | Field | Туре | Reset | Description | |------|---------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-0 | SYSSNIV | R | | System NMI vector. Generates a value that can be used as address offset for fast interrupt service routine handling. Writing to this register clears all pending system NMI flags. See the device-specific data sheet for a list of values. | SYS Registers www.ti.com # 1.15.10 SYSRSTIV Register (offset = 1Eh) [reset = 0002h] Reset Interrupt Vector Register NOTE: Additional events for more complex devices will be appended to this table; sources that are removed reduce the length of this table. The vectors are expected to be accessed symbolic only with the corresponding include file of the device in use. ## Figure 1-30. SYSRSTIV Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----|----|-----|------|-------|-----|-----|----| | | | | SYSF | RSTIV | | | | | r0 | rO | rO | rO | rO | r0 | rO | rO | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | SYSF | RSTIV | | | | | r0 | r0 | r-0 | r-0 | r-0 | r-0 | r-1 | r0 | # Table 1-22. SYSRSTIV Register Description | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-0 | SYSRSTIV | R | Oh | Reset interrupt vector. Generates a value that can be used as address offset for fast interrupt service routine handling to identify the last cause of a reset (BOR, POR, or PUC). Writing to this register clears all pending reset source flags. See the device-specific data sheet for a list of values. | # 1.16 System Configuration Registers The system configuration registers are device specific and are only applicable to the specific device family. Each register starts at a word boundary. Either word or byte data can be written to the SYS configuration registers. For the system configuration registers for devices with Smart Analog Combo (SAC), see Section 1.16.1. These devices are MSP430FR2000, MSP430FR21xx, MSP430FR23xx. For the system configuration registers for devices without Smart Analog Combo (SAC), see Section 1.16.2. These devices are MSP430FR203x, MSP430FR24xx, MSP430FR25xx, MSP430FR25xx, MSP430FR41xx. # 1.16.1 Smart Analog Combo Subfamily System Configuration Registers Table 1-23 lists the system configuration registers that are specific to the Smart Analog Combo Subfamily MCUs. These devices are MSP430FR2000, MSP430FR21xx, MSP430FR23xx. The following sections provide a detailed description of each register and its bits. Table 1-23. Smart Analog Combo Subfamily SYS Configuration Registers | Offset | Acronym | Register Name | Туре | Access | Reset | Section | |--------|-----------|------------------------|------------|--------|-------|------------------| | 20h | SYSCFG0 | System Configuration 0 | Read/write | Word | 9601h | Section 1.16.1.1 | | 20h | SYSCFG0_L | | Read/write | Byte | 96h | | | 21h | SYSCFG0_H | | Read/write | Byte | 01h | | | 22h | SYSCFG1 | System Configuration 1 | Read/write | Word | 0000h | Section 1.16.1.2 | | 22h | SYSCFG1_L | | Read/write | Byte | 00h | | | 23h | SYSCFG1_H | | Read/write | Byte | 00h | | | 24h | SYSCFG2 | System Configuration 2 | Read/write | Word | 0000h | Section 1.16.1.3 | | 24h | SYSCFG2_L | | Read/write | Byte | 00h | | | 25h | SYSCFG2_H | | Read/write | Byte | 00h | | | 26h | SYSCFG3 | System Configuration 3 | Read/write | Word | 0000h | Section 1.16.1.4 | | 26h | SYSCFG3_L | | Read/write | Byte | 00h | | | 27h | SYSCFG3_H | | Read/write | Byte | 00h | | # 1.16.1.1 Smart Analog Combo Subfamily SYSCFG0 Register (offset = 00h) [reset = 9601h] System Configuration Register 0 # Figure 1-31. SYSCFG0 Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |------|------|------|--------------------|--------------------|------|------|------| | | | | FRWF | PPW <sup>(1)</sup> | | | | | rw-1 | rw-0 | rw-0 | rw-1 | rw-0 | rw-1 | rw-1 | rw-0 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | FRWI | POA <sup>(2)</sup> | | | DFWP | PFWP | | rw-0 | rw-0 | rw-0 | rw-0 | rw-0 | rw-0 | rw-1 | rw-1 | The password must be written with the FRAM protection bits in a word in a single operation. # Table 1-24. SYSCFG0 Register Description | Bit | Field | Туре | Reset | Description | |------|-----------------------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-8 | FRWPPW <sup>(1)</sup> | RW | 96h | FRAM protection password | | | | | | FRAM protection password. Write with 0A5h to unlock the FRAM protection registers. Always reads as 096h | | 7-2 | FRWPOA <sup>(2)</sup> | RW | 0h | Program FRAM write protection offset address from the beginning of Program FRAM. The offset increases by 1KB resolution. | | | | | | 000000b = The write protection starting from the beginning of Program FRAM; the entire Program FRAM under PFWP protection | | | | | | 000001b = The FRAM program memory is unprotected (read/write) between the beginning of program FRAM and the beginning of program FRAM + 1024 B. The remainder of the program FRAM is protected by the PFWP protection. | | | | | | 000010b = The FRAM program memory is unprotected (read/write) between the beginning of program FRAM and the beginning of program FRAM + 2048 B. The remainder of the program FRAM is protected by the PFWP protection. | | | | | | 000011b = The FRAM program memory is unprotected (read/write) between the beginning of program FRAM and the beginning of program FRAM + 3072 B. The remainder of the program FRAM is protected by the PFWP protection. | | | | | | 000100b = The FRAM program memory is unprotected (read/write) between the beginning of program FRAM and the beginning of program FRAM + 4096 B. The remainder of the program FRAM is protected by the PFWP protection. | | | | | | : | | | | | | 111111b = The FRAM program memory is unprotected (read/write) between the beginning of program FRAM and the beginning of program FRAM + 64512 B. The remainder of the program FRAM is protected by the PFWP protection. | | 1 | DFWP | RW | 1h | Data (Information) FRAM write protection | | | | | | 0b = Data (Information) FRAM write enable | | | | | | 1b = Data (Information) FRAM write protected (not writable) | | 0 | PFWP | RW | 1h | Program (Main) FRAM write protection | | | | | | 0b = Program (Main) FRAM write enable | | | | | | 1b = Program (Main) FRAM write protected (not writable) | <sup>(1)</sup> The password must be written with the FRAM protection bits in a word in a single operation. <sup>(2)</sup> These bits are valid only in the MSP430FR235x and MSP430FR215x devices. <sup>(2)</sup> These bits are valid only in the MSP430FR235x and MSP430FR215x devices. # 1.16.1.2 Smart Analog Combo Subfamily SYSCFG1 Register (offset = 02h) [reset = 0000h] System Configuration Register 1 # Figure 1-32. SYSCFG1 Register # Table 1-25. SYSCFG1 Register Description | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|-------------------------------------------------------------------------------------------------------------| | 15-5 | Reserved | R | 0h | Reserved. Always read as 0. | | 4 | IRDATA | RW | Oh | Infrared data 0b = Infrared data logic 0 1b = Infrared data logic 1 | | 3 | IRDSSEL | RW | 0h | Infrared data source select 0b = From hardware peripherals upon device configuration 1b = From IRDATA bit | | 2 | IRMSEL | RW | 0h | Infrared mode select 0b = ASK mode 1b = FSK mode | | 1 | IRPSEL | RW | 0h | Infrared polarity select 0b = Normal polarity 1b = Inverted polarity | | 0 | IREN | RW | Oh | Infrared enable 0b = Infrared function disabled 1b = Infrared function enabled | # 1.16.1.3 Smart Analog Combo Subfamily SYSCFG2 Register (offset = 04h) [reset = 0000h] System Configuration Register 2 # Figure 1-33. SYSCFG2 Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |--------------|--------------|--------------|--------------|-------------|-------------|------|-------|--|--| | TB0TRGSEL(1) | TB1TRGSEL(1) | TB2TRGSEL(1) | TB3TRGSEL(1) | USCIBRMP(1) | RTCCKSEL(1) | Rese | erved | | | | rw-0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | Reserved | | | | | | | | | | rw-0 | | <sup>(1)</sup> To determine if this bit is supported in a particular MCU, see the device-specific data sheet. # Table 1-26. SYSCFG2 Register Description | Bit | Field | Туре | Reset | Description | |-----|--------------------------|------|-------|------------------------------------------------------------------------------------| | 15 | TB0TRGSEL <sup>(1)</sup> | RW | 0h | TB0OUTH trigger source selection | | | | | | 0b = Internal source selected | | | | | | 1b = External source selected | | 14 | TB1TRGSEL <sup>(1)</sup> | RW | 0h | TB1OUTH trigger source selection | | | | | | 0b = Internal source selected | | | | | | 1b = External source selected | | 13 | TB2TRGSEL <sup>(1)</sup> | RW | 0h | TB2OUTH trigger source selection | | | | | | 0b = Internal source selected | | | | | | 1b = External source selected | | 12 | TB3TRGSEL(1) | RW | 0h | TB3OUTH trigger source selection | | | | | | 0b = Internal source selected | | | | | | 1b = External source selected | | 11 | USCIBRMP <sup>(1)</sup> | RW | 0h | eUSCIB Remapping source selection, see the device-specific data sheet for details. | | | | | | 0b = P1.x is selected | | | | | | 1b = Other port is selected | | 10 | RTCCKSEL <sup>(1)</sup> | RW | 0h | RTC clock selection | | | | | | 0b = SMCLK is selected | | | | | | 1b = ACLK is selected | | 9-0 | Reserved | RW | 0h | Reserved. Always read as 0. | <sup>(1)</sup> To determine if this bit is supported in a particular MCU, see the device-specific data sheet. # 1.16.1.4 Smart Analog Combo Subfamily SYSCFG3 Register (offset = 06h) [reset = 0000h] System Configuration Register 3 # Figure 1-34. SYSCFG3 Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |-----|----------|-----|------|-------|-----|------|------| | | | | Rese | erved | | | | | r-0 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | Reserved | | | | | | | | r-0 | r-0 | r-0 | r-0 | r-0 | r-0 | rw-0 | rw-0 | To determine if this bit is supported in a particular MCU, see the device-specific data sheet. # Table 1-27. SYSCFG3 Register Description | Bit | Field | Туре | Reset | Description | |------|-------------------------|------|-------|------------------------------------------------------------------------------------------------------------------------------------| | 15-2 | Reserved | R | 0h | Reserved. Always read as 0. | | 1 | TBRMP <sup>(1)</sup> | RW | 0h | Timer_B re-mapping source selection (see the device-specific data sheet for details) | | | | | | 0b = P1.x is selected (P1.6 and P1.7 are selected in MSP430FR2111, MSP430FR2110, MSP430FR2100, MSP430FR2000 <sup>(2)</sup> ) | | | | | | 1b = Other port is selected (P2.0 and P2.1 are selected in MSP430FR2111, MSP430FR2110, MSP430FR2100, MSP430FR2000 <sup>(2)</sup> ) | | 0 | USCIARMP <sup>(1)</sup> | RW | 0h | eUSCIA re-mapping source selection (see the device-specific data sheet for details) | | | | | | 0b = P1.x is selected (P1.4 to P1.7 are selected in MSP430FR2111, MSP430FR2110, MSP430FR2100, MSP430FR2000) | | | | | | 1b = Other port is selected (P1.0 to P1.3 are selected in MSP430FR2111, MSP430FR2110, MSP430FR2100, MSP430FR2000) | <sup>(1)</sup> To determine if this bit is supported in a particular MCU, see the device-specific data sheet. <sup>(2)</sup> Only one selected port is valid at the same time when TB0 acts as capture input functionality. The PWM from TB0 is output regardless of the setting on this re-map bit. See the device-specific data sheet for deails. # 1.16.2 System Configuration Registers for Devices Without Smart Analog Combo (SAC) Table 1-28 lists the system configuration registers that are specific to the devices without the SAC module. These devices are MSP430FR203x, MSP430FR24xx, MSP430FR25xx, MSP430FR26xx, MSP430FR41xx. The following sections provide a detailed description of each register and its bits. Table 1-28. Devices Without Smart Analog Combo SYS Configuration Registers | Offset | Acronym | Register Name | Type | Access | Reset | Section | |--------|-----------|------------------------|------------|--------|-------|------------------| | 20h | SYSCFG0 | System Configuration 0 | Read/write | Word | 9603h | Section 1.16.2.1 | | 20h | SYSCFG0_L | | Read/write | Byte | 96h | | | 21h | SYSCFG0_H | | Read/write | Byte | 03h | | | 22h | SYSCFG1 | System Configuration 1 | Read/write | Word | 0000h | Section 1.16.2.2 | | 22h | SYSCFG1_L | | Read/write | Byte | 00h | | | 23h | SYSCFG1_H | | Read/write | Byte | 00h | | | 24h | SYSCFG2 | System Configuration 2 | Read/write | Word | 0000h | Section 1.16.2.3 | | 24h | SYSCFG2_L | | Read/write | Byte | 00h | | | 25h | SYSCFG2_H | | Read/write | Byte | 00h | | | 26h | SYSCFG3 | System Configuration 3 | Read/write | Word | 0000h | Section 1.16.2.4 | | 26h | SYSCFG3_L | | Read/write | Byte | 00h | | | 27h | SYSCFG3_H | | Read/write | Byte | 00h | | # 1.16.2.1 Devices Without Smart Analog Combo SYSCFG0 Register (offset = 00h) [reset = 9603h] System Configuration Register 0 # Figure 1-35. SYSCFG0 Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |------|------|------|--------------------|--------------------|------|------|------| | | | | FRWF | PPW <sup>(1)</sup> | | | | | rw-1 | rw-0 | rw-0 | rw-1 | rw-0 | rw-1 | rw-1 | rw-0 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | FRWI | POA <sup>(2)</sup> | | | DFWP | PFWP | | rw-0 | rw-0 | rw-0 | rw-0 | rw-0 | rw-0 | rw-1 | rw-1 | These bits have no affect on MSP430FR413x, MSP430FR203x devices. # Table 1-29. SYSCFG0 Register Description | Bit | Field | Туре | Reset | Description | |------|-----------------------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-8 | FRWPPW <sup>(1)</sup> | RW | 96h | FRAM protection password (2) | | | | | | FRAM protection password. Write with 0A5h to unlock the FRAM protection registers. Always reads as 096h | | 7-2 | FRWPOA <sup>(3)</sup> | RW | 0h | Program FRAM write protection offset address from the beginning of Program FRAM. The offset increases by 1KB resolution | | | | | | 000000b = The write protection starting from the beginning of Program FRAM; the entire Program FRAM under PFWP protection | | | | | | 000001b = The FRAM program memory is unprotected (read/write) between the beginning of program FRAM and the beginning of program FRAM + 1024 B. The remainder of the program FRAM is protected by the PFWP protection. | | | | | | 000010b = The FRAM program memory is unprotected (read/write) between the beginning of program FRAM and the beginning of program FRAM + 2048 B. The remainder of the program FRAM is protected by the PFWP protection. | | | | | | 000011b = The FRAM program memory is unprotected (read/write) between the beginning of program FRAM and the beginning of program FRAM + 3072 B. The remainder of the program FRAM is protected by the PFWP protection. | | | | | | 000100b = The FRAM program memory is unprotected (read/write) between the beginning of program FRAM and the beginning of program FRAM + 4096 B. The remainder of the program FRAM is protected by the PFWP protection. | | | | | | : | | | | | | 111111b = The FRAM program memory is unprotected (read/write) between the beginning of program FRAM and the beginning of program FRAM + 64512 B. The remainder of the program FRAM is protected by the PFWP protection. | | 1 | DFWP | RW | 1h | Data (Information) FRAM write protection | | | | | | 0b = Data (Information) FRAM write enable | | | | | | 1b = Data (Information) FRAM write protected (not writable) | | 0 | PFWP | RW | 1h | Program (Main) FRAM write protection | | | | | | 0b = Program (Main) FRAM write enable | | | | | | 1b = Program (Main) FRAM write protected (not writable) | <sup>&</sup>lt;sup>(1)</sup> These bits have no affect on MSP430FR413x, MSP430FR203x devices. <sup>(2)</sup> These bits are valid in MSP430FR2522 and MSP430FR2422 devices. <sup>(2)</sup> The password must be written with the FRAM protection bits in a word in a single operation. <sup>(3)</sup> These bits are valid in MSP430FR2522 and MSP430FR2422 devices. # 1.16.2.2 Devices Without Smart Analog Combo SYSCFG1 Register (offset = 02h) [reset = 0000h] System Configuration Register 1 # Figure 1-36. SYSCFG1 Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |------------------------|------|----------|--------|---------|--------|--------|------| | | | | erved | | | | | | r0 | r0 | r0 | rO | rO | r0 | r0 | rO | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | SYNCSEL <sup>(1)</sup> | | Reserved | IRDATA | IRDSSEL | IRMSEL | IRPSEL | IREN | | rw-0 | rw-0 | r0 | rw-0 | rw-0 | rw-0 | rw-0 | rw-0 | <sup>&</sup>lt;sup>(1)</sup> This bit is valid only on devices that support CapTlvate functionality. # Table 1-30. SYSCFG1 Register Description | Bit | Field | Туре | Reset | Description | |------|------------------------|------|-------|----------------------------------------------------------| | 15-8 | Reserved | R | 0h | Reserved. Always read as 0. | | 7-6 | SYNCSEL <sup>(1)</sup> | RW | 0h | Captivate conversion triggered source selection | | | | | | 00b = External source is selected | | | | | | 01b = ADC as the source is selected | | | | | | 10b = internal source is selected | | | | | | 11b = Reserved | | 5 | Reserved | R | 0h | Reserved. Always read as 0. | | 4 | IRDATA | RW | 0h | Infrared data | | | | | | 0b = Infrared data logic 0 | | | | | | 1b = Infrared data logic 1 | | 3 | IRDSSEL | RW | 0h | Infrared data source select | | | | | | 0b = From hardware peripherals upon device configuration | | | | | | 1b = From IRDATA bit | | 2 | IRMSEL | RW | 0h | Infrared mode select | | | | | | 0b = ASK mode | | | | | | 1b = FSK mode | | 1 | IRPSEL | RW | 0h | Infrared polarity select | | | | | | 0b = Normal polarity | | | | | | 1b = Inverted polarity | | 0 | IREN | RW | 0h | Infrared enable | | | | | | 0b = Infrared function disabled | | | | | | 1b = Infrared function enabled | <sup>&</sup>lt;sup>(1)</sup> This bit is valid only on devices that support CapTIvate functionality. # 1.16.2.3 Devices Without Smart Analog Combo SYSCFG2 Register (offset = 04h) [reset = 0000h] System Configuration Register 2 # Figure 1-37. SYSCFG2 Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |-----------|----------|----------|------------------------|--------------|-------------|----------|----------| | TB0TRGSEL | Rese | erved | LCDPCTL <sup>(1)</sup> | USCIB0RMP(1) | RTCCKSEL(1) | Rese | erved | | rw-0 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | ADCPCTL7 | ADCPCTL6 | ADCPCTL5 | ADCPCTL4 | ADCPCTL3 | ADCPCTL2 | ADCPCTL1 | ADCPCTL0 | | rw-0 <sup>(1)</sup> To determine if this bit is supported in a particular MCU, see the device-specific data sheet. # Table 1-31. SYSCFG2 Register Description | Bit | Field | Туре | Reset | Description | |-------|--------------------------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15 | TB0TRGSEL <sup>(1)</sup> | RW | 0h | TB0OUTH trigger source selection 0b = Internal source selected | | 44.40 | Deserved | DW | Oh | 1b = External source selected | | 14-13 | Reserved | RW | 0h | Reserved. | | 12 | LCDPCTL <sup>(1)</sup> | RW | Oh | LCD power pins (LCDCAP0, LCDCAP1, R13, R23, R33) control 0b = LCD power pin disabled 1b = LCD power pin enabled | | 11 | USCIB0RMP <sup>(1)</sup> | RW | Oh | eUSCIB0 Remapping source selection, see the device-specific data sheet for details 0b = Default function is selected (for example, P1.x is selected) 1b = Re-mapped function is selected | | 10 | RTCCKSEL <sup>(1)</sup> | RW | 0h | RTC clock selection 0b = SMCLK is selected 1b = ACLK is selected | | 9-8 | Reserved | RW | 0h | Reserved. | | 7 | ADCPCTL7 <sup>(1)</sup> | RW | 0h | ADC input A7 pin select 0b = ADC input A7 disabled 1b = ADC input A7 enabled | | 6 | ADCPCTL6 <sup>(1)</sup> | RW | 0h | ADC input A6 pin select 0b = ADC input A6 disabled 1b = ADC input A6 enabled | | 5 | ADCPCTL5 <sup>(1)</sup> | RW | 0h | ADC input A5 pin select 0b = ADC input A5 disabled 1b = ADC input A5 enabled | | 4 | ADCPCTL4 <sup>(1)</sup> | RW | 0h | ADC input A4 pin select 0b = ADC input A4 disabled 1b = ADC input A4 enabled | | 3 | ADCPCTL3 <sup>(1)</sup> | RW | Oh | ADC input A3 pin select 0b = ADC input A3 disabled 1b = ADC input A3 enabled | | 2 | ADCPCTL2 <sup>(1)</sup> | RW | Oh | ADC input A2 pin select 0b = ADC input A2 disabled 1b = ADC input A2 enabled | | 1 | ADCPCTL1 <sup>(1)</sup> | RW | Oh | ADC input A1 pin select 0b = ADC input A1 disabled 1b = ADC input A1 enabled | | 0 | ADCPCTL0 <sup>(1)</sup> | RW | Oh | ADC input A0 pin select 0b = ADC input A0 disabled 1b = ADC input A0 enabled | <sup>(1)</sup> To determine if this bit is supported in a particular MCU, see the device-specific data sheet. # 1.16.2.4 Devices Without Smart Analog Combo SYSCFG3 Register (offset = 06h) [reset = 0000h] System Configuration Register 3 # Figure 1-38. SYSCFG3 Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------|----------|-----|-----------|--------|--------|----------|--------------| | Reserved | | | | | | | | | r-0 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | Reserved | | USCIB1RMP | TA3RMP | TA2RMP | Reserved | USCIA0RMP(1) | | r-0 | r-0 | r-0 | rw-0 | rw-0 | rw-0 | rw-0 | rw-0 | <sup>(1)</sup> To determine if this bit is supported in a particular MCU, see the device-specific data sheet. # Table 1-32. SYSCFG3 Register Description | Bit | Field | Туре | Reset | Description | |------|--------------------------|------|-------|---------------------------------------| | 15-5 | Reserved | R | 0h | Reserved. Always read as 0. | | 4 | USCIB1RMP <sup>(1)</sup> | | | USCIB1RMP re-mapping source selection | | | | | | 0b = Default function is selected | | | | | | 1b = Re-mapped function is selected | | 3 | TA3RMP <sup>(1)</sup> | | | Timer3_A3 re-mapping source selection | | | | | | 0b = Default function is selected | | | | | | 1b = Re-mapped function is selected | | 2 | TA2RMP <sup>(1)</sup> | | | Timer2_A3 re-mapping source selection | | | | | | 0b = Default function is selected | | | | | | 1b = Re-mapped function is selected | | 1 | Reserved | R | 0h | Reserved. Always read as 0. | | 0 | USCIA0RMP <sup>(1)</sup> | RW | 0h | eUSCIA0 re-mapping source selection | | | | | | 0b = Default function is selected | | | | | | 1b = Re-mapped function is selected | <sup>(1)</sup> To determine if this bit is supported in a particular MCU, see the device-specific data sheet. # Power Management Module (PMM) and Supply Voltage Supervisor (SVS) This chapter describes the operation of the Power Management Module (PMM) and Supply Voltage Supervisor (SVS). Topic Page | 2.1 | Power Management Module (PMM) Introduction | 85 | |-----|--------------------------------------------|----| | 2.2 | PMM Operation | 86 | | 2.3 | PMM Registers | 90 | | | _ | | # 2.1 Power Management Module (PMM) Introduction PMM features include: - Wide supply voltage (DV<sub>CC</sub>) range: 1.8 V to 3.6 V - Generation of voltage for the device core (V<sub>CORE</sub>) - Supply voltage supervisor (SVS) for DV<sub>CC</sub> - Brownout reset (BOR) - · Software accessible power-fail indicators - I/O protection during power-fail condition - · Reference voltage output on external pin - Shared reference systems (device specific) - Basic shared reference systems: 1.5-V on-chip reference - Enhanced shared reference systems: 1.5-V, 2.0-V, or 2.5-V on-chip reference The PMM manages all functions related to the power supply and its supervision for the device. Its primary functions are, first, to generate a supply voltage for the core logic and, second, to provide several mechanisms for the supervision of the voltage applied to the device (DV<sub>CC</sub>). The PMM uses an integrated low-dropout voltage regulator (LDO) to produce a secondary core voltage ( $V_{CORE}$ ) from the primary one applied to the device ( $DV_{CC}$ ). In general, $V_{CORE}$ supplies the CPU, memories, and the digital modules, while $DV_{CC}$ supplies the I/Os and analog modules. The $V_{CORE}$ output is maintained using a dedicated voltage reference. The input or primary side of the regulator is referred to in this chapter as its low side. The block diagram of the PMM is shown in Figure 2-1. Figure 2-1. PMM Block Diagram PMM Operation www.ti.com # 2.2 PMM Operation # 2.2.1 $V_{CORE}$ and the Regulator $DV_{CC}$ can be powered from a wide input voltage range, but the core logic of the device must be kept at a voltage lower than what this range allows. For this reason, a regulator (LDO) has been integrated into the PMM. The regulator derives the necessary core voltage ( $V_{CORE}$ ) from $DV_{CC}$ . The regulator supports different load settings to optimize power. The hardware controls the load settings automatically, according to the following criteria: - · Selected and active power modes - Selected and active clocks - Clock frequencies according to Clock System (CS) settings - JTAG or SBW is active In addition to the main LDO, an ultra-low-power regulator (RTC LDO) provides a regulated voltage to the real-time clock module (including the 32-kHz crystal oscillator) and other ultra-low-power modules that remain active during LPM3.5 when the main LDO is switched off. # 2.2.2 Supply Voltage Supervisor The high-side supervisor (SVSH) oversees DV<sub>CC</sub>. It is active in all power modes by default. In LPM3, LPM4, LPM3.5, and LPM4.5, it can be disabled by setting SVSHE = 0. #### 2.2.2.1 SVS Thresholds As Figure 2-2 shows, there is hysteresis built into the supervision thresholds, so that which threshold is in force depends on whether the voltage rail is rising or falling. The behavior of the SVS according to these thresholds is best portrayed graphically. Figure 2-2 shows how the supervisors respond to various supply failure conditions. Figure 2-2. Voltage Failure and Resulting PMM Actions www.ti.com PMM Operation # 2.2.3 Supply Voltage Supervisor During Power-Up When the device is powering up, the SVSH function is enabled by default. Initially, $DV_{CC}$ is low, and therefore the PMM holds the device in BOR reset. When the SVSH level is met, the reset is released. Figure 2-3 shows this process. Figure 2-3. PMM Action at Device Power-Up # 2.2.4 LPM3.5 and LPM4.5 (LPMx.5) LPM3.5 and LPM4.5 are low-power modes in which the core voltage regulator of the PMM is completely disabled to provide additional power savings. Because there is no power supplied to $V_{\text{CORE}}$ during LPMx.5, the CPU and all digital modules including RAM are unpowered. This essentially disables the entire device and, as a result, the contents of the registers and RAM are lost. Any essential values should be stored to FRAM prior to entering LPMx.5. See the SYS module for complete description and uses of LPMx.5. LPM3.5 and LPM4.5 can be configured with SVS enabled (SVSHE = 1) or with SVS disabled (SVSHE = 0). Disabling the SVS results in lower power consumption, whereas enabling it provides the ability to detect supply drops and getting a "wake-up" due to the supply drop below the SVS threshold. Note, the "wake-up" due to a supply failure would not be flagged as a LPMx.5 wake-up but as a SVS reset event. In LPM4.5, enabling the SVS also results in approximately 10 times faster start-up time than with disabled SVS. #### 2.2.5 Low-Power Reset In battery-operated applications, it might be desirable to limit the current drawn by the device to a minimum after the supply drops below the SVS power-down level. By default, as soon as the supply voltage drops below the SVS power-down level, the complete device is reset and prepared to return into active mode quickly when the supply voltage becomes available again. This state results in a current consumption of approximately 50 $\mu A$ to 100 $\mu A$ (typical). Pulling the reset pin during the LPM4.5 low-power reset state causes the device to enter its default reset state (with higher current consumption), and the device starts up when the supply rises above the SVS power-up level. If the device is already in LPMx.5 (with SVS enabled) before the supply voltage drops below the SVS threshold, then the device automatically enters the low-power reset state (that is, the device enters LPM4.5 state with SVS, RTC domain, and all wake-up events disabled). (In LPMx.5 the I/Os are already in a defined state. Therefore, no NMI handling is required to define the I/O states.) PMM Operation www.ti.com # 2.2.6 Brownout Reset (BOR) The primary function of the BOR circuit occurs when the device is powering up. It is functional very early in the power-up ramp, generating a BOR that initializes the system. It also functions when no SVS is enabled and a brownout condition occurs. It sustains this reset until the input power is sufficient for the logic and for proper reset of the system. In an application, it may be desired to cause a BOR in software. Setting PMMSWBOR causes a softwaredriven BOR. PMMBORIFG is set accordingly. Note that a BOR also initiates a POR and PUC. PMMBORIFG can be cleared by software or by reading SYSRSTIV. Similarly, it is possible to cause a POR in software by setting PMMSWPOR. PMMPORIFG is set accordingly. A POR also initiates a PUC. PMMPORIFG can be cleared by software or by reading SYSRSTIV. Both PMMSWBOR and PMMSWPOR are self clearing. See the SYS module for complete descriptions of BOR, POR, and PUC resets. #### 2.2.7 LPM3.5 Switch The LPM3.5 switch supplies the LPM3.5 power domain with main LDO output, which allows the peripherals to consume more current and operate at high frequency. When the device enters LPM3.5, all peripherals in LPM3.5 domains are isolated from the core domain and fully supplied by the LPM3.5 LDO. The LPM3.5 switch can be either manually or automatically controlled. The LPM3.5 switch mode can be set by LPM5SM in the PM5CTL0 register. In the automatic control mode (the LPM5SM bit is clear), all peripherals in LPM3.5 domains are automatically controlled by PMM depending on the dynamic loading. This is the recommended mode for general operation. In the manual control mode (the LPM5SM bit is set), the LPM3.5 switch is specified by the LPM5SW bit in the PM5CTL0 register. When LPM5SW is set, the LPM3.5 switch is connected. When LPM5SW is clear, the LPM3.5 switch is disconnected. It is recommended to turn off the switch to avoid unnecessary leakage before the device enters LPM3.5. When the device recovers back from LPM3.5 mode, the switch should be turned on to offer sufficient current for high-frequency operation. The LPM5SW defaults to logic 1, which means that the LPM3.5 switch is always connected after a BOR, POR, or PUC reset. #### 2.2.8 Shared Reference Generation and Distribution The PMM module has a high-accuracy bandgap for various voltage references on the chip. The bandgap is automatically turned on and off depending on the operating mode. The REFBGRDY bit in the PMMCTL2 register reports the readiness of the bandgap. When REFBGRDY is set, the bandgap reference is ready for use. In basic shared reference systems, two voltage references are generated for internal shared reference (1.5 V) and external reference (VREF+ pin, 1.2 V) use. The voltage generator is automatically controlled by the device in response to the voltage reference request (either internal or external). The REFGENACT and REFGENRDY bits represent the status of the generator status and report whether or not the output is at the specified voltage. The internal reference voltage (1.5 V) is internally connected to an ADC channel (see the data sheet for device-specific configuration). The INTREFEN bit in PMMCTL2 controls when the 1.5-V voltage is available on the specified ADC channel. In enhanced shared reference systems, three voltage references are available for use: internal shared reference (1.5 V, 2.0 V, or 2.5 V), external reference (VREF+ pin, 1.2 V), and internal low-power reference (1.2 V). The voltage generator is automatically controlled by the device in response to the voltage reference request (either internal or external). The REFGENACT and REFGENRDY bits represent the status of the generator status and report whether or not the output is at the specified voltage. The internal shared reference (1.5 V, 2.0 V, or 2.5 V) is programmable by setting the REFVSEL bits in PMMCTL2. It is internally connected to an ADC channel (see the data sheet for device-specific configuration), the eCOMP built-in 6-bit DAC, and the SAC built-in 12-bit DAC. The INTREFEN bit in PMMCTL2 controls when the internal shared reference voltage is available to these modules. PMM Operation www.ti.com The external reference voltage (1.2 V) is connected a given external ADC channel (refer to the data sheet for device-specific configuration). If this ADC channel is multiplexed with other functionality, the 1.2-V output function only works when the ADC is selected as the function on this pin. The EXTREFEN bit in PMMCTL2 controls if the 1.2-V voltage is available to the specified external ADC channel. The external reference voltage supports up to 1-mA drive capability. In enhanced shared reference systems, an additional low-power 1.2-V reference is available for eCOMP operations. This reference can be activated by selecting eCOMP input channels. #### 2.2.9 Temperature Sensor The PMM contains a built-in temperature sensor that software can use to monitor the die temperature for fault protection in high-temperature environments. The temperature sensor is internally connected to an ADC channel. The connection is device specific and can be found in the ADC section in the data sheet. The TSENSOREN bit in the PMMCTL2 register must be set to turn on the sensor before it is used. The temperature of 30°C is factory-trimmed. Therefore, any temperature to be measured can be calculated by Equation 11. $$T = 0.00355 \times (V_T - V_{30°C}) + 30°C \tag{11}$$ #### 2.2.10 RST/NMI The external RST/NMI terminal is pulled low on a BOR reset condition. RST/NMI can be used as reset source for the rest of the application. #### 2.2.11 PMM Interrupts Interrupt flags generated by the PMM are routed to the system NMI interrupt vector generator register, SYSSNIV. When the PMM causes a reset, a value is generated in the system reset interrupt vector generator register, SYSRSTIV, corresponding to the source of the reset. These registers are defined within the SYS module. More information on the relationship between the PMM and SYS modules is available in the SYS chapter. #### 2.2.12 Port I/O Control The PMM ensures that I/O pins cannot behave in uncontrolled fashion during an undervoltage event. During these times, outputs are disabled, including both the normal drive and the weak pullup and pulldown functions. If the CPU is functioning normally before an undervoltage event occurs, any pin configured as an input has its PxIN register value latched when the event occurs, until voltage is restored. During the undervoltage event, external voltage changes on the pin are not registered internally. This helps prevent erratic behavior. PMM Registers www.ti.com #### 2.3 **PMM Registers** Table 2-1 shows the PMM registers and their address offsets. The base address of the PMM module can be found in the device-specific data sheet. The password defined in the PMMCTL0 register controls access to all PMM registers except PM5CTL0. PM5CTL0 can be accessed without the password. After the correct password is written, write access is enabled (this includes byte access to the PMMCTL0 lower byte). Write access is disabled by writing a wrong password in byte mode to the PMMCTL0 upper byte. Word access to PMMCTL0 with a wrong password causes a PUC. Write access to a register other than PMMCTL0 while write access is not enabled causes a PUC. NOTE: All registers have word or byte register access. For a generic register ANYREG, the suffix "\_L" (ANYREG\_L) refers to the lower byte of the register (bits 0 through 7). The suffix "\_H" (ANYREG\_H) refers to the upper byte of the register (bits 8 through 15). **Table 2-1. PMM Registers** | Offset | Acronym | Register Name | Туре | Access | Reset | Section | |--------|-----------|---------------------------------|---------------------------|--------|-------|---------------| | 00h | PMMCTL0 | PMM control register 0 | Read/write | Word | 9640h | Section 2.3.1 | | 00h | PMMCTL0_L | | Read/write | Byte | 40h | | | 01h | PMMCTL0_H | | Read/write | Byte | 96h | | | 02h | PMMCTL1 | PMM control register 1 | Read/write <sup>(1)</sup> | Word | 9600h | Section 2.3.2 | | 02h | PMMCTL1_L | | Read <sup>(1)</sup> | Byte | 00h | | | 03h | PMMCTL1_H | | Read <sup>(1)</sup> | Byte | 96h | | | 04h | PMMCTL2 | PMM control register 2 | Read/write | Word | 0000h | Section 2.3.3 | | 04h | PMMCTL2_L | | Read/write | Byte | 00h | | | 05h | PMMCTL2_H | | Read/write | Byte | 00h | | | 0Ah | PMMIFG | PMM interrupt flag register | Read/write | Word | 0000h | Section 2.3.5 | | 0Ah | PMMIFG_L | | Read/write | Byte | 00h | | | 0Bh | PMMIFG_H | | Read/write | Byte | 00h | | | 0Eh | PMMIE | PMM interrupt enable register | Read/write | Word | 0000h | Section 2.3.4 | | 0Eh | PMMIE_L | | Read/write | Byte | 00h | | | 0Fh | PMMIE_H | | Read/write | Byte | 00h | | | 10h | PM5CTL0 | Power mode 5 control register 0 | Read/write | Word | 0011h | Section 2.3.6 | | 10h | PM5CTL0_L | | Read/write | Byte | 11h | | | 11h | PM5CTL0_H | | Read/write | Byte | 00h | | <sup>(1)</sup> PMMCTL1 can be written as word only. www.ti.com PMM Registers # 2.3.1 PMMCTL0 Register (offset = 00h) [reset = 9640h] Power Management Module Control Register 0 # Figure 2-4. PMMCTL0 Register # Table 2-2. PMMCTL0 Register Description | Bit | Field | Туре | Reset | Description | |------|-----------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-8 | PMMPW | RW | 96h | PMM password. Always reads as 096h. Write with 0A5h to unlock the PMM registers. | | 7 | Reserved | RW | 0h | Reserved. Must be written with 0. | | 6 | SVSHE | RW | 1h | High-side SVS enable. 0b = High-side SVS (SVSH) is disabled in LPM2, LPM3, LPM4, LPM3.5, and LPM4.5. SVSH is enabled in active mode, LPM0, and LPM1. 1b = SVSH is always enabled. | | 5 | Reserved | R | 0h | Reserved. Always reads as 0 | | 4 | PMMREGOFF | RW | Oh | Regulator off 0b = Regulator remains on when going into LPM3 or LPM4 1b = Regulator is turned off when going to LPM3 or LPM4. System enters LPM3.5 or LPM4.5, respectively. | | 3 | PMMSWPOR | RW | 0h | Software POR. Set this bit to 1 to trigger a POR. This bit is self clearing. 0b = Normal operation 1b = Set to 1 to trigger a POR | | 2 | PMMSWBOR | RW | Oh | Software brownout reset. Set this bit to 1 to trigger a BOR. This bit is self clearing. 0b = Normal operation 1b = Set to 1 to trigger a BOR | | 1-0 | Reserved | R | 0h | Reserved. Always reads as 0. | PMM Registers www.ti.com # 2.3.2 PMMCTL1 Register (offset = 02h) [reset = 0000h] Power Management Module Control Register 1 # Figure 2-5. PMMCTL1 Register # Table 2-3. PMMCTL1 Register Description | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|----------------------------------| | 15-0 | Reserved | R | 9600h | Reserved. Always reads as 9600h. | www.ti.com PMM Registers # 2.3.3 PMMCTL2 Register (offset = 04h) [reset = 0000h] Power Management Module Control Register 2 # Figure 2-6. PMMCTL2 Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------|--------|----------|-----------|-----------|----------|----------|-----------| | Reserved | | REFBGRDY | REFGENRDY | BGMODE | Reserved | REFBGACT | REFGENACT | | r-0 | r-0 | r-(0) | r-(0) | r-(0) | rO | r-(0) | r-(0) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | REFBGEN | REFGEN | REF | VSEL | TSENSOREN | Reserved | EXTREFEN | INTREFEN | | rw-0 | rw-0 | rw-(0) | rw-(0) | rw-(0) | r0 | rw-(0) | rw-(0) | # Table 2-4. PMMCTL2 Register Description | Bit | Field | Туре | Reset | Description | |-------|--------------------------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-14 | Reserved | R | 0h | Reserved. Always reads as 0 | | 13 | REFBGRDY <sup>(1)</sup> | R | 0h | Buffered bandgap voltage ready status. 0b = Buffered bandgap voltage is not ready to be used 1b = Buffered bandgap voltage is ready to be used | | 12 | REFGENRDY <sup>(1)</sup> | R | 0h | Variable reference voltage ready status. 0b = Reference voltage output is not ready to be used. 1b = Reference voltage output is ready to be used | | 11 | BGMODE | R | 0h | Bandgap mode. Ready only. 0b = Static mode (higher precision) 1b = Sampled mode (lower power consumption) | | 10 | Reserved | R | 0h | Reserved. Always reads as 0 | | 9 | REFBGACT <sup>(1)</sup> | R | Oh | Reference bandgap active. Ready only. 0b = Reference bandgap buffer not active 1b = Reference bandgap buffer active | | 8 | REFGENACT | R | Oh | Reference generator active. Read only. 0b = Reference generator not active 1b = Reference generator active | | 7 | REFBGEN | RW | 0h | Bandgap and bandgap buffer trigger. If written with a 1, the generation of the buffered bandgap voltage is started. When the bandgap buffer voltage request is set, this bit is cleared by hardware or writing 0. 0b = No trigger 1b = Generation of the bandgap voltage is started by writing 1 or by a hardware trigger | | 6 | REFGEN | RW | 0h | Reference generator trigger. If written with a 1, the generation of the variable reference voltage is started. When the reference voltage request is set, this bit is cleared by hardware or writing 0. 0b = No trigger 1b = Generation of the reference voltage is started by writing 1 or by a hardware trigger | | 5-4 | REFVSEL | RW | Oh | Internal shared reference voltage level select. 00b = 1.5 V 01b = 2.0 V (Enhanced shared reference systems only) 10b = 2.5 V (Enhanced shared reference systems only) 11b = Reserved | | 3 | TSENSOREN | RW | Oh | Temperature sensor enable 0b = Disable temperature sensor 1b = Enable temperature sensor | | 2 | Reserved | R | 0h | Reserved. Always reads as 0 | <sup>(1)</sup> This bit resets to logic 0 after reset. It might change to logic 1 shortly after reset when the reference is ready. In 16-MHz systems with only the 1.5-V internal shared reference, PMMCTL2 often reads as 0x3200 after reset, because the reference is ready before user code starts execution. TI recommends checking this bit before using the reference. PMM Registers www.ti.com # Table 2-4. PMMCTL2 Register Description (continued) | Bit | Field | Туре | Reset | Description | |-----|----------|------|-------|-----------------------------------------------------------------------------------------------------------------| | 1 | EXTREFEN | RW | Oh | External reference output enable 0b = Disable external reference output 1b = Enable internal reference output | | 0 | INTREFEN | RW | 0h | Internal reference enable 0b = Disable internal reference 1b = Enable internal reference | www.ti.com PMM Registers # 2.3.4 PMMIE Register (offset = 0Eh) [reset = 0000h] (External) Power Management Module Interrupt Enable Register # Figure 2-7. PMMIE Register # **Table 2-5. PMMIE Register Description** | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|------------------------------| | 15-0 | Reserved | R | 0h | Reserved. Always reads as 0. | PMM Registers www.ti.com # 2.3.5 PMMIFG Register (offset = 0Ah) [reset = 0000h] (External) Power Management Module Interrupt Flag Register # Figure 2-8. PMMIFG Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |------------|----------|---------|--------|-------|-----------|-----------|-----------| | PMMLPM5IFG | Reserved | SVSHIFG | Rese | erved | PMMPORIFG | PMMRSTIFG | PMMBORIFG | | rw-{0} | rO | rw-{0} | r-(1 ) | r-(0) | rw-[0] | rw-{0} | rw-{0} | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Reserved | | | | | | | | | r-0 | r-0 | r0 | r0 | r0 | r0 | r0 | r0 | # **Table 2-6. PMMIFG Register Description** | Bit | Field | Туре | Reset | Description | |---------------|-----------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15 PMMLPM5IFG | | RW | 0h | LPMx.5 flag. | | | | | | This bit has a specific reset conditions. This bit is only set if the system was in LPMx.5 before reset. | | | | | | The bit is cleared by software or by reading the reset vector word. A power failure on the DVCC domain triggered by the high-side SVS (if enabled) or the brownout clears the bit. | | | | | | 0b = Reset not due to wake-up from LPMx.5 | | | | | | 1b = Reset due to wake-up from LPMx.5 | | 14 | Reserved | R | 0h | Reserved. Always reads as 0. | | 13 | SVSHIFG | RW | 0h | High-side SVS interrupt flag. | | | | | | This bit has a specific reset conditions. | | | | | | The SVSHIFG interrupt flag is only set if the SVSH is the reset source; that is, DVCC dropped below the high-side SVS levels but remained above the brownout levels. The bit is cleared by software or by reading the reset vector word SYSRSTIV. | | | | | | 0b = Reset not due to SVSH | | | | | | 1b = Reset due to SVSH | | 12-11 | Reserved | R | 0h | Reserved. Always reads as 0. | | 10 | PMMPORIFG | RW | 0h | PMM software POR interrupt flag. | | | | | | This bit has a specific reset conditions. This interrupt flag is only set if a software POR (PMMSWPOR) is triggered. | | | | | | The bit is cleared by software or by reading the reset vector word. | | | | | | 0b = Reset not due to PMMSWPOR | | | | | | 1b = Reset due to PMMSWPOR | | 9 | PMMRSTIFG | RW | 0h | PMM reset pin interrupt flag. | | | | | | This bit has a specific reset conditions. This interrupt flag is only set if the RST/NMI pin is the reset source. | | | | | | The bit is cleared by software or by reading the reset vector word. | | | | | | 0b = Reset not due to reset pin | | | | | | 1b = Reset due to reset pin | | 8 | PMMBORIFG | RW | 0h | PMM software brownout reset interrupt flag. | | | | | | This bit has a specific reset conditions. This interrupt flag is only set if a software BOR (PMMSWBOR) is triggered. | | | | | | The bit is cleared by software or by reading the reset vector word. | | | | | | 0b = Reset not due to PMMSWBOR | | | | | | 1b = Reset due to PMMSWBOR | | 7-0 | Reserved | R | 0h | Reserved. Always reads as 0. | www.ti.com PMM Registers # 2.3.6 *PM5CTL0 Register* (offset = 10h) [reset = 0011h] Power Mode 5 Control Register 0 # Figure 2-9. PM5CTL0 Register # Table 2-7. PM5CTL0 Register Description | Bit | Field | Туре | Reset | Description | | |----------|----------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | 15-6 | Reserved | R | 0h | Reserved. Always reads as 0. | | | 5 LPM5SM | | RW | Oh | Specifies the operation mode of the LPM3.5 switch. Only available in the FR203x, FR211x, FR2100, FR2000, FR231x, FR2433, FR2422, FR263x, FR253x, FR252x, and FR413x devices. Ob = Automatic mode. The LPM3.5 switch is fully handled by the circuitry during | | | | | | | mode switch. | | | | | | | 1b = Manual mode. The LPM3.5 switch is specified by LPM5SW bit setting in software. | | | 4 | LPM5SW | RW | 1h | Reports or sets the LPM3.5 switch connection, based on the switch mode set by LPM5SM. When LPM5SW = 1, the $V_{\rm LPM3.5}$ domain can accept full-speed read and write operation by the CPU MCLK. If the switch is disconnected (LPM5SW = 0), all peripherals within this domain can accept clock operation no faster than 40 kHz. | | | | | | | In automatic mode (LPM5SM = 0), this bit represents the switch connection between $V_{core}$ and $V_{LPM3.5}$ . Any write to this bit has no effect. | | | | | | | In manual mode (LPM5SM = 1), this bit is read/write by software. When this bit is set, the switch connection between $V_{core}$ and $V_{LPM3.5}$ is connected. Otherwise, the switch is disconnected. Only available in the FR203x, FR211x, FR2100, FR2000, FR231x, FR2433, FR2422, FR263x, FR253x, FR252x, and FR413x devices. | | | | | | | 0b = LPMx.5 switch disconnected | | | | | | | 1b = LPMx.5 switch connected | | | 3-1 | Reserved | R | 0h | Reserved. Always reads as 0. | | | 0 | LOCKLPM5 | RW | 1h | Lock I/O pin and other LPMx.5 relevant (for example, RTC) configurations upon entry to or exit from LPMx.5. After the LOCKLPM5 bit is set, it can be cleared only by software or by a power cycle. | | | | | | | This bit is reset by a power cycle; that is, if SVSH (if enabled) or brownout triggered a reset. | | | | | | | 0b = LPMx.5 configuration is not locked and defaults to its reset condition. | | | | | | | 1b = LPMx.5 configuration remains locked. Pin state is held during LPMx.5 entry and exit. | | # Clock System (CS) The Clock System (CS) module generates and distributes the various clock sources used on MCU. This chapter describes the operation of the CS module, which is implemented in all devices. The CS module supports two configurations: Basic CS and Enhanced CS. Table 3-1 lists the differences. # **Table 3-1. CS Configurations** | | Basic CS | Enhanced CS | |------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------| | DCO range select (DCORSEL) | 1 MHz, 2 MHz, 4 MHz, 8 MHz, 12 MHz, 16 MHz | 1 MHz, 2 MHz, 4 MHz, 8 MHz, 12 MHz, 16 MHz,<br>20 MHz, 24 MHz | | FLL reference divider (FLLREFDIV) | ÷1, ÷32, ÷64, ÷128, ÷256, ÷512 | ÷1, ÷32, ÷64, ÷128, ÷256, ÷512,<br>÷640, , ÷768 | | Low-power REFO<br>(REFLP) | N/A | Can enable 1 µA ±3.5% LREFO | | ACLK source (SELA) | XT1CLK, REFO | XT1, REFO, VLO | | ACLK source divider (DIVA) | ÷1, ÷16, ÷32, ÷64, ÷128, ÷256, ÷384, ÷512 | ÷1, ÷16, ÷32, ÷64, ÷128, ÷256, ÷384, ÷512,<br>÷768, ÷1024, ÷108, ÷338, ÷414, ÷640 | | XT1 fault switching off (XT1FAULTOFF) | N/A | Can disable the switch from XT1 to REFO when XT1 fails | | XT1 high-frequency selection (XT1HFFREQ) | 1 to 16 MHz | 1 to 24 MHz | | Low-power REFO ready (REFOREADY) | N/A | Low-power REFO ready indication | | Devices | MSP430FR413x, MSP430FR2033<br>MSP430FR263x, MSP430FR253x,<br>MSP430FR2433<br>MSP430FR231x, MSP043FR211x,<br>MSP430FR2100, MSP430FR2000<br>MSP430FR2522, MSP430FR2512,<br>MSP430FR2422 | MSP430FR235x, MSP430FR215x | #### Topic Page | 3.1 | CS Introduction99 | |-----|-------------------| | 3.2 | CS Operation | | 3.3 | CS Registers | | | | www.ti.com CS Introduction #### 3.1 CS Introduction The CS module supports low system cost and low power consumption. This module supports four internal and two external clock sources, by which users can optimize the clock configuration for different design goals. Not all clock sources present in one device. For a detailed description of the configuration for any given device, see the device-specific data sheet. All clock sources can be fully selected by software. External clock sources can use either crystal or ceramic oscillators or resonators. The CS module includes up to six clock sources: - XT1CLK: High-frequency or low-frequency oscillator that can be used with a high-frequency ceramic or crystal oscillator or a low-frequency 32768-Hz crystal. XT1CLK can be used as a clock reference into the FLL. Some devices only support the low-frequency oscillator for XT1CLK. See the device-specific data sheet for more details. - VLOCLK: Internal very-low-power low-frequency oscillator with 10-kHz typical frequency - REFOCLK: Internal trimmed low-frequency oscillator with 32768-Hz typical frequency. Can be used as a clock reference into the FLL. - DCOCLK: Internal digitally controlled oscillator (DCO) that can be stabilized by the FLL. - MODCLK: Internal high-frequency oscillator with 5-MHz typical frequency. Three clock signals are available from the CS module: - ACLK: Auxiliary clock. ACLK can be used for peripherals low-frequency operation. This clock is software selectable as XT1CLK or REFOCLK. The selected clock source must always be approximately 32 kHz, and no more than 40 kHz (typical). ACLK is software selectable by individual peripheral modules. - MCLK: Master clock. MCLK is the main clock source of CPU, CRC, and some other digital peripherals directly operated by the CPU or its clock. This clock is software selectable as REFOCLK, DCOCLK, XT1CLK, or VLOCLK. When available, the selected clock source can be predivided by 1, 2, 4, 8, 16, 32, 64, or 128. - SMCLK: Subsystem master clock. SMCLK is the clock for the peripherals that can work independently from CPU operation. This clock always derives from MCLK. When available, SMCLK can be predivided by 1, 2, 4, or 8. SMCLK is software selectable by individual peripheral modules. Figure 3-1 and Figure 3-2 show the block diagrams of the basic and enhanced CS modules, respectively. CS Introduction www.ti.com Figure 3-1. Basic Clock System Block Diagram www.ti.com CS Introduction Figure 3-2. Enhanced Clock System Block Diagram CS Operation www.ti.com ### 3.2 CS Operation After a PUC, the CS module default configuration is: - MCLK and SMCLK use DCOCLKDIV, which is locked by the FLL and referenced by REFO if XT1 is not available. - ACLK uses REFO. - XT1 external crystal oscillator is selected as the XT1CLK clock source. XT1IN and XT1OUT pins are set to general-purpose I/Os and XT1 remains disabled until the I/O ports are configured for XT1 operation. After PUC, DCO locked by FLL operation with XT1CLK is selected by default. The FLL stabilizes MCLK and SMCLK to 1 MHz and $f_{DCOCLKDIV} = 1$ MHz An external 32768-Hz crystal can be used as the FLL reference. By default, the crystal pins (XT1IN, XT1OUT) are shared with general-purpose I/Os. To enable XT1, the PSEL bits associated with the crystal pins must be set to use the external 32768-Hz crystal as the clock source. After the crystal starts up and settles, the FLL reference clock is automatically switched to XT1CLK when XT1OFFG, DCOFFG, and OFIFG are clear. A default monitor is engaged with XT1 oscillation. If XT1 is used but does not work properly, fault protection logic forces REFO as the FLL reference clock. The status register control bits (SCG0, SCG1, OSCOFF, and CPUOFF) configure the MCU operating modes and enable or disable portions of the CS module. Registers CSCTL0 to CSCTL8 configure the CS module. The CS module can be configured or reconfigured by software at any time during program execution. # 3.2.1 CS Module Features for Low-Power Applications Conflicting requirements typically exist in battery-powered applications: - Low clock frequency for energy conservation and time keeping - High clock frequency for fast response times and fast burst processing capabilities - · Clock stability over operating temperature and supply voltage - Low-cost applications with less constrained clock accuracy requirements The CS module addresses these conflicting requirements by allowing the user to select from the three available clock signals: ACLK, MCLK, and SMCLK. MCLK can be sourced from any of the available clock sources (DCOCLK, REFOCLK, XT1CLK, or VLOCLK). SMCLK is derived from MCLK and always uses the same clock source as MCLK. ACLK can be source from either REFO or XT1CLK. ### 3.2.2 Internal Very Low-Power Low-Frequency Oscillator (VLO) The internal VLO provides a typical frequency of 10 kHz (see the device-specific data sheet for parameters) without requiring a crystal. The VLO provides for a low-cost low-power clock source for applications that do not require an accurate time base. VLOCLK is active in the following conditions: - VLO is selected as the source of MCLK and SMCLK (SELMS = {3}), and MCLK or SMCLK is active. - The VLOAUTOOFF bit is cleared and the MCU is in AM through LPM4. - At least one peripheral requests VLO as clock source. www.ti.com CS Operation # 3.2.3 Internal Trimmed Low-Frequency Reference Oscillator (REFO) The internal trimmed low-frequency REFO can be used for cost-sensitive applications in which a crystal is not required or desired. REFO is internally trimmed to 32.768 kHz (typical) and provides a stable reference frequency that can be used as FLLREFCLK. REFO, combined with the FLL, provides for a flexible range of system clock settings without the need for a crystal. REFO consumes no power when it is not in use. REFO is enabled under any of the following conditions: - REFO is a source for MCLK and SMCLK (SELMS = {1}) and MCLK or SMCLK is active. - REFO is a source for ACLK (SELA = {1}) and ACLK is active. - REFO is a source for FLLREFCLK (SELREF = {1}) and DCO is active. #### 3.2.4 XT1 Oscillator The XT1 oscillator supports low-current consumption using a 32768-Hz watch crystal in low-frequency (LF) mode. A watch crystal connects to XIN and XOUT and requires external loading capacitors on both terminals. These capacitors should be sized according to the crystal or resonator specifications. The drive settings of XT1 can be increased with the XT1DRIVE bits. At power up, the XT1 starts with the highest drive settings for fast reliable startup. After startup, user software can reduce the drive strength to reduce power consumption. In some devices, the XT1 oscillator supports high-frequency crystals or resonators when in high-frequency (HF) mode (XTS = 1). The high-frequency crystal or resonator connects to XT1IN and XT1OUT and requires external capacitors on both terminals. These capacitors should be sized according to the crystal or resonator specifications. The XT1 pins are shared with general-purpose I/O ports. At power up, the default operation is general-purpose I/O ports. XT1 remains disabled until the ports shared with XT1 are configured for XT1 operation. The configuration of the shared I/O is determined by the Px.SEL bit associated with the XT1IN pin and the XT1BYPASS bit. Setting the Px.SEL bit causes the XT1IN and XT1OUT ports to be configured for XT1 operation. If XT1BYPASS is also set, XT1 is configured for bypass mode of operation, and the oscillator associated with XT1 is powered down. In bypass mode of operation, XT1IN can accept an external clock input signal and XT1OUT is configured as a general-purpose I/O. The Px.SEL bit associated with XT1OUT is a don't care. If the Px.SEL bit associated with XT1IN is cleared, both XT1IN and XT1OUT ports are configured as general-purpose I/Os, and XT1 is disabled. XT1 is enabled under any of the following conditions: - XT1 is a source for MCLK and SMCLK (SELMS = {2}) and MCLK or SMCLK is active. - XT1 is a source for ACLK (SELA = {0} and ACLK is active. - XT1 is a source for FLLREFCLK (SELREF = {0}) and DCO is active. - XT1AUTOOFF is clear and the MCU is in AM through LPM4. - At least one peripheral requests XT1 as clock source. #### NOTE: XT1 in HF mode configuration ACLK is the auxiliary clock. ACLK must be approximately 32 kHz and no faster than 40 kHz (typical). There is a divider (DIVA) if ACLK sources from XT1 in HF mode. The divider setting depends on the external high-frequency oscillator value. This divider is always bypassed if ACLK sources from XT1 in LF mode. CS Operation www.ti.com # 3.2.5 Digitally Controlled Oscillator (DCO) The DCO is an integrated digitally controlled oscillator. The DCO frequency can be adjusted by software using the DCORSEL, DCO, and MOD bits. Optionally, the DCO frequency can be stabilized by the FLL to a multiple frequency of FLLREFCLK $\div$ n. The FLL accepts different reference sources selected by the SELREF bits. Reference sources include XT1CLK and REFOCLK. The value of n is defined by the FLLREFDIV bits (n = 1, 32, 64, 128, 256, or 512). When XT1 only supports a 32-kHz clock, FLLREFDIV is always read and written as 0 (n = 1). The default is n = 1. There may be scenarios in which FLL operation is not required or desired, and therefore no FLLREFCLK is necessary. The FLLD bits configure the FLL prescaler divider value to 1, 2, 4, 8, 16, or 32. By default, FLLD = 1, and MCLK and SMCLK are sourced from DCOCLKDIV, providing a clock frequency DCOCLK÷2. The divider (FLLN + 1) and the divider value of FLLD define the DCOCLK and DCOCLKDIV frequencies, where FLLN > 0. Writing FLLN = 0 causes the divider to be set to 1. $$\begin{split} f_{DCOCLK} &= 2^{FLLD} \times (FLLN + 1) \times (f_{FLLREFCLK} \div n) \\ f_{DCOCLKDIV} &= (FLLN + 1) \times (f_{FLLREFCLK} \div n) \end{split}$$ #### 3.2.5.1 Adjusting DCO Frequency By default, FLL operation is enabled. FLL operation can be disabled by setting SCG0 or SCG1. When the FLL is disabled, the DCO continues to operate at the current settings defined in CSCTL0 and CSCTL1. The DCO frequency can be adjusted manually if desired. Otherwise, the DCO frequency is stabilized by the FLL operation. After a PUC, DCORSEL = $\{1\}$ and DCO = $\{0\}$ . MCLK and SMCLK are sourced from DCOCLKDIV. Because the CPU executes code from MCLK, which is sourced from the fast-starting DCO, code execution begins from PUC in less than 5 $\mu$ s. The frequency of DCOCLK is set by the following functions: - The three DCORSEL bits select one of eight nominal frequency ranges for the DCO. These ranges are defined for each individual device in the device-specific data sheet. - The nine DCO bits divide the DCO range selected by the DCORSEL bits into 512 frequency steps, separated by approximately 0.1%. - The five MOD bits switch between the frequency selected by the DCO bits and the next-higher frequency set by {DCO + 1} (see Section 3.2.7). When DCO = {511}, the MOD bits have no effect, because the DCO is already at the highest setting for the selected DCORSEL range. #### 3.2.6 Frequency Locked Loop (FLL) The FLL continuously counts up or down a frequency integrator. The output of the frequency integrator that drives the DCO can be read in CSCTL0 (bits MOD and DCO). Nine of the integrator bits (CSCTL0 bits 8 to 0) set the DCO frequency tap. 512 taps are implemented for the DCO, and each is approximately 0.1% higher than the previous. The modulator mixes two adjacent DCO frequencies to produce fractional taps. For a given DCO bias range setting, time must be allowed for the DCO to settle on the proper tap for normal operation. The value n is defined by the FLLREFDIV bits (n = 1, 32, 64, 128, 256, or 512). When XT1 only supports a 32-kHz clock, FLLREFDIV is always read and written as 0 (n = 1). For a typical 32768-Hz clock source, FLLREFDIV should always be set to 0 (that is, n = 1). CS Operation www.ti.com #### 3.2.7 DCO Modulator The modulator mixes two DCO frequencies, $f_{DCO}$ and $f_{DCO}$ +1 to produce an intermediate effective frequency between f<sub>DCO</sub> and f<sub>DCO</sub>+1 and spread the clock energy and reduce electromagnetic interference (EMI). The modulator mixes f<sub>DCO</sub> and f<sub>DCO</sub>+1 for 32 DCOCLK clock cycles and is configured with the MOD bits. When $MOD = \{0\}$ , the modulator is off. The modulator mixing formula is: $$t = (32 - MOD) \times t_{DCO} + MOD \times t_{DCO+1}$$ Figure 3-3 shows the modulator operation. When FLL operation is enabled, the modulator settings and DCO are controlled by the FLL hardware. If FLL operation is not desired, the modulator settings and DCO control can be configured with software. Figure 3-3. Modulator Patterns #### 3.2.8 Disabling FLL Hardware and Modulator The FLL is disabled when the status register bits SCG0 or SCG1 are set. When the FLL is disabled, the DCO runs at the previously selected tap, and DCOCLK is not automatically stabilized. The DCO modulator is disabled when DISMOD is set. When the DCO modulator is disabled, the DCOCLK is adjusted to the DCO tap selected by the DCO bits. #### NOTE: DCO operation without FLL When the FLL operation is disabled, the DCO continues to operate at the current settings. Because it is not stabilized by the FLL, temperature and voltage variations influence the frequency of operation. See the device-specific data sheet for voltage and temperature coefficients to ensure reliable operation. ### 3.2.9 FLL Unlock Detection The FLL unlock detection function can generate PUC reset or an interrupt, when the divided DCO output fails to lock the reference clock. When the FLL is enabled, the FLLUNLOCK bits reflect the DCO status if it is locked, too slow, too fast, or out of DCO range. When FLL recovers as locked, the FLLUNLOCK bit will be cleared and the FLLUNLOCKHIS bits will automatically log previous unlock status. CS Operation www.ti.com If the FLLULPUC bit is set (FLLULPUC = 1), when DCO runs too fast (FLLUNLOCK = 10b), the FLLULIFG bit flag being set causes a PUC reset. If FLLWARNEN bit is set, when FLLUNLOCKHIS changes to unlock, the OFIFG flag is set. Figure 3-4. FLL Unlock Detection # 3.2.10 FLL Operation From Low-Power Modes An interrupt service request clears SCG1, CPUOFF, and OSCOFF if set, but does not clear SCG0. This means that for FLL operation from within an interrupt service routine entered from LPM1, LPM3, or LPM4, the FLL remains disabled and the DCO operates at the previous setting as defined in CSCTL0 and CSCTL1. SCG0 can be cleared by user software if FLL operation is required. ### 3.2.11 DCO Factory Trim and Software Trim # 3.2.11.1 DCO Factory Trim To ensure the FLL can be locked, TI recommends using the factory DCO trim (default value) to configure the DCO frequency when the DCO range is selected on maximum valid values (see the DCORSEL bit and the device-specific data sheet for details). For other target frequencies, DCO software trim (Section 3.2.11.2) is recommended. To configure the DCO frequency or FLL reference clock with DCO factory trim, first clear the CSCTL0 register. This makes sure that the DCO starts from the lowest frequency to avoid a frequency above specification due to temperature or supply voltage drift over time. Wait at least two MCLK cycles before the FLL is enabled. After the wait cycles, poll the FLLUNLOCK bits to determine if the FLL is locked in the target frequency range. The recommended process to configure the FLL is: - 1. Disable the FLL. - 2. Select the reference clock. - 3. Clear the CSCTL0 register. - 4. Set the DCO range and set FLLN and FLLD for target frequency. - 5. Execute NOP three times to allow time for the settings to be applied. - 6. Enable the FLL. - 7. Poll the FLLUNLOCK bits until the FLL is locked. www.ti.com CS Operation #### 3.2.11.2 DCO Software Trim The clock system supports varying trim levels for the selected DCO frequency range (using DCORSEL). Ensuring the FLL can be locked for the frequency range selected by your application is the responsibility of the application and requires the use of a software calibration and lock routine. Even when the FLL is locked at a specific trim setting, large variations in temperature or prolonged shutdown of the FLL may result in the FLL unlock bit being set, which requires the execution of the software calibration and lock routine. The CS module supports multiple DCO frequency ranges, each of which require a device-specific DCOFTRIM setting (see the DCOFTRIMEN bit). This trimming is enabled by setting the DCOFTRIMEN bit and selecting DCOFTRIM values between 0 and 7. The DCO tap selection bits (see the DCO) that are modified automatically during FLL operation support up to 512 steps of DCO operation. The DCOFTRIM bits can be considered a 'coarse' tuning of the DCO frequency, and the DCO bits represent more of a 'fine' tuning. The main purpose of executing the software calibration and lock routine is to ensure the correct 'coarse' selection is enabled for the selected frequency, allowing the DCO taps to be adjusted such that the FLL lock can be ensured. Ideally, the DCO taps are locked close to the midrange (that is, 256 taps). This ensures that for large variations of temperature, the FLL stays locked without the taps reaching the boundaries of the allowed settings. The DCOFFG bit is set to indicate when the DCO tap moves to either the lowest or highest boundary setting (DCO = 0 or DCO = 511). Hence the best DCOFTRIM value is the one that ensures the DCO tap is closest to the midrange. The software calibration and lock routine ensures this, by checking the delta between DCO taps and 256 for consecutive locked settings. This software calibration and lock routine only needs to be executed once if the trim setting is saved in FRAM for reuse. The following procedure explains a step-by-step process to achieving FLL lock for a given frequency: - 1. Disable the FLL. - 2. Select the reference clock. - 3. Set DCO range, enable DCO frequency trim. - 4. Set FLLN and FLLD for target frequency. - 5. Execute NOP three times to allow time for the settings to be applied. - 6. Enable the FLL. - 7. Set DCO tap = 256. - 8. Clear the DCO fault flag (DCOFFG). - 9. Wait to allow the FLL lock status (FLLUNLOCK) to be stable. The minimum recommended wait time is 24 divided by the FLL reference clock frequency (for example, if the divided reference clock = 32768 Hz, wait time = 0.733 ms.) - 10. Poll the FLLUNLOCK bits and DCOFFG bit until FLL is locked or DCO fault. - 11. Read DCO tap value, calculate the delta value between the DCO tap and 256. - 12. Record the CSCTL0 and CSCTL1 registers value when the DCO tap is closer to 256 than the last recorded one. - 13. Increase or decrease DCOFTRIM based on the relative position of DCO tap with respect to the midrange (if DCO tap < 256, DCOFTRIM − 1; if DCO tap ≥ 256, DCOFTRIM + 1). - 14. Repeat the process starting from step 7 in a loop until the DCO tap values cross 256 for two adjacent DCOFTRIM settings. - 15. Reload the recorded CSCTL0 and CSCTL1. #### NOTE: DCO Trim Software Routine An implementation of this software routine is available in the code example msp430frxx\_cs07.c available in the software section of the product folder on www.ti.com (search the part number on the TI website at and click the Software tab in the product folder). Alternatively, the Driver Library API also implements this routine. CS Operation www.ti.com #### 3.2.12 Operation From Low-Power Modes, Requested by Peripheral Modules A peripheral module requests its clock sources automatically from the CS module if required for its proper operation, regardless of the current mode of operation (see Figure 3-5). A peripheral module asserts one of three possible clock request signals based on its control bits: ACLK\_REQ, MCLK\_REQ, or SMCLK\_REQ. These request signals are based on the configuration and clock selection of the module. For example, if a timer selects ACLK as its clock source and the timer is enabled, the timer generates an ACLK\_REQ signal to the CS system. The CS, in turn, enables ACLK regardless of the LPM settings. Any clock request from a peripheral module causes its respective clock off signal to be overridden but does not change the setting of the clock off control bit. For example, a peripheral module may require ACLK even if it is currently disabled by the OSCOFF bit (OSCOFF = 1). The module requests ACLK by generating an ACLK\_REQ. This causes the OSCOFF bit to have no effect and makes ACLK available to the requesting peripheral module. The OSCOFF bit remains at its current setting (OSCOFF = 1). If the requested source is not active, the software NMI handler must take care of the required actions. For the previous example, if ACLK was sourced by XT1, and XT1 was not enabled, an oscillator fault condition occurs and the software must handle the event. The watchdog, due to its security requirement, actively selects the VLOCLK source if the originally selected clock source is not available. Due to the clock request feature, care must be taken in the application when entering low-power modes to save power. Although the device enters the selected low-power mode, a clock request may exhibit more current consumption than the values specified in the data sheet. Figure 3-5. Module Request Clock System By default, the clock request logic is enabled. The clock request logic can be disabled by clearing ACLKREQEN, MCLKREQEN, or SMCLKREQEN, for each respective system clock. When ACLKREQEN or MCLKREQEN bits are set, or active, the clock is available to the system and prevents entry into a low-power mode until all modules requesting the clock are disabled. When ACLKREQEN or MCLKREQEN bits are cleared, or disabled, the clock is always halted as defined by the low-power modes. The SMCLKREQEN logic behaves similarly, but it is also influenced by the SMCLKOFF bit in the CSCTL5 register. www.ti.com CS Operation Table 3-2 shows the relationship between the system clocks and the low-power modes in conjunction with the clock request logic. | ı | | ACLK | | MCLK | | SMCLK | | | | | |---|--------|-----------|-----------|-----------|-----------|-------------------|-------------------|-------------------|-------------------|--| | | | ACLKREQEN | ACLKREQEN | MCLKREQEN | MCLKREQEN | SMCLK | OFF = 0 | SMCLKOFF = 1 | | | | | Mode | = 0 | = 1 | = 0 | = 1 | SMCLKREQEN<br>= 0 | SMCLKREQEN<br>= 1 | SMCLKREQEN<br>= 0 | SMCLKREQEN<br>= 1 | | | | AM | Active | Active | Active | Active | Active | Active | Disabled | Active | | | | LPM0 | Active | Active | Disabled | Active | Active | Active | Disabled | Active | | | | LPM3 | Active | Active | Disabled | Active | Disabled | Active | Disabled | Active | | | | LPM4 | Active | Active | Disabled | Active | Disabled | Active | Disabled | Active | | | | LPM3.5 | Disabled | | | LPM4.5 | Disabled | Table 3-2. Clock Request System and Power Modes #### 3.2.12.1 LPM3.5 and LPM4.5 Clock Request Handling After clearing ACLK request enable signal (ACLKREQEN = 0), the device is able to enter LPMx.5. See the PMM chapter for details on the requirements to enter LPMx.5. #### 3.2.13 Fail-Safe Operation The CS module incorporates an oscillator-fault fail-safe feature. This feature detects an oscillator fault for XT1 and DCO as shown in Figure 3-6. The available fault conditions are: - High-frequency or low-frequency oscillator fault (XT10FFG) for XT1 - DCO fault flag (DCOFFG) for the DCO The crystal oscillator fault bit XT10FFG is set if the corresponding crystal oscillator is turned on and not operating properly. Once set, the fault bits remain set until software resets them, even if the fault condition no longer exists. If software clears the fault bits and the fault condition still exists, the fault bits are automatically set again; otherwise, they remain cleared. When using XT1 operation in LF mode as the reference source into the FLL (SELREF = $\{0\}$ ), a crystal fault automatically causes the FLL reference source, FLLREFCLK, to be sourced by the REFO. XT10FFG is set. When using XT1 operation in HF mode as the reference source into the FLL, a crystal fault causes no FLLREFCLK signal to be generated and the FLL continues to count down to zero in an attempt to lock FLLREFCLK $\div$ n and DCOCLK $\div$ [ $2^{\text{FLLD}} \times$ (FLLN + 1)]. The DCO tap moves to the lowest position (DCO bits are cleared) and the DCOFFG is set. DCOFFG is also set if the N-multiplier value is set too high for the selected DCO frequency range, resulting in the DCO tap moving to the highest position (CSCTL0.8 to CSCTL0.0 are set). The DCOFFG remains set until cleared by the user. If the user clears the DCOFFG and the fault condition remains, it is automatically set, otherwise it remains cleared. XT1HF0FFG is set. The OFIFG oscillator-fault interrupt flag is set and latched at POR or when any oscillator fault (XT10FFG or DC0FFG) is detected. When OFIFG is set and OFIE is set, the OFIFG requests an NMI. When the interrupt is granted, the OFIE is not reset automatically as it is in previous MSP430 families. It is no longer required to reset the OFIE. NMI entry/exit circuitry removes this requirement. The OFIFG flag must be cleared by software. The source of the fault can be identified by checking the individual fault bits. If MCLK is sourced from XT1 in LF mode, an oscillator fault causes MCLK to be automatically switched to the REFO for its clock source (REFOCLK). If MCLK is sourced from XT1 in HF mode, an oscillator fault causes MCLK to be automatically switched to the DCO for its clock source (DCOCLKDIV). This fault switch does not change the SELMS bit settings. This condition must be handled by user software. If SMCLK sources from XT1 in LF mode, an oscillator fault causes SMCLK to be automatically switched to the REFO for its clock source (REFOCLK). If SMCLK sources from XT1 in HF mode, an oscillator fault causes SMCLK to be automatically switched to the DCO for its clock source (DCOCLKDIV). This fault switch does not change the SELMS bit settings. This condition must be handled by user software. If ACLK sources from XT1 in LF or HF mode, an oscillator fault causes ACLK to be automatically switched to the REFO for its clock source (REFOCLK). This does not change the SELA bit settings. This condition must be handled by user software. CS Operation www.ti.com In enhanced clock systems, if ACLK sources from XT1 in LF or HF mode, an oscillator fault causes ACLK to be automatically switched to the REFO for its clock source (REFOCLK), when XT1FAULTOFF is clear. When XT1FAULTOFF is set the auto switching shall be disabled. This does not change the SELA bit settings. This condition must be handled by user software #### NOTE: DCO active during oscillator fault DCOCLKDIV is active even at the lowest DCO tap. The clock signal is available for the CPU to execute code and service an NMI during an oscillator fault. Figure 3-6. Oscillator Fault Logic #### NOTE: Fault conditions **DCO\_Fault:** DCOFFG is set if DCO bits in CSCTL0 register value equals {0} or {511} and DCO is unlocked. DCO\_Fault is ignored when FLL is disabled. It is suggested to clear DCOFFG before FLL disabled. **XT1\_OscFault:** This signal is set after the XT1 oscillator has stopped operation and is cleared after operation resumes. The fault condition causes XT1OFFG to be set and remain set. If the user clears XT1OFFG and the fault condition still exists, XT1OFFG remains set. #### **Fault logic** Note that as long as a fault condition still exists, the OFIFG remains set. The application must take special care when clearing the OFIFG signal. If no fault condition remains when the OFIFG signal is cleared, the clock logic switches back to the original user settings before the fault condition. #### **Fault logic counters** Each crystal oscillator circuit has hardware counters. These counters are reset each time a fault condition occurs on its respective oscillator, causing the fault flag to be set. The counters begin to count after the fault condition is removed. When the maximum count is reached, the fault flag is removed. In XT1 LF mode, the maximum count is 8192. In XT1 HF mode, the maximum count is 1024. In bypass modes, regardless of LF or HF settings, the maximum count is 8192. www.ti.com CS Operation # 3.2.14 Synchronization of Clock Signals When switching MCLK or SMCLK from one clock source to the another, the switch is synchronized as shown in Figure 3-7 to avoid critical race conditions. - The current clock cycle continues until the next rising edge. - The clock remains high until the next rising edge of the new clock. - The new clock source is selected and continues with a full high period. Figure 3-7. Switch MCLK From DCOCLK to XT1CLK ## 3.2.15 Module Oscillator (MODOSC) The CS module also supports an internal oscillator, MODOSC, that is used by ADC and, optionally, by other modules in the system. The MODOSC sources MODCLK. #### 3.2.15.1 MODOSC Operation To conserve power, MODOSC is powered down when not needed and enabled only when required. When the MODOSC source is required, the respective module requests it. MODOSC is enabled based on unconditional and conditional requests. Setting MODOSCREQEN enables conditional requests. Unconditional requests are always enabled. It is not necessary to set MODOSCREQEN for modules that use unconditional requests (for example, the ADC). The ADC may optionally use MODOSC as a clock source for its conversion clock. The user chooses the MODOSC as the conversion clock source. During a conversion, the ADC module issues an unconditional request for the MODOSC clock source. Upon doing so, the MODOSC source is enabled, if not already enabled by a previous request from another module. CS Registers www.ti.com #### 3.3 **CS** Registers Table 3-3 lists the CS registers with offsets. See the device-specific data sheet for the base address. NOTE: All registers have word or byte register access. For a generic register ANYREG, the suffix "\_L" (ANYREG\_L) refers to the lower byte of the register (bits 0 to 7). The suffix "\_H" (ANYREG\_H) refers to the upper byte of the register (bits 8 to 15). Table 3-3. CS Registers | Offset | Acronym | Register Name | Туре | Access | Reset | Section | |--------|---------|---------------------------------|------------|--------|-------|---------------| | 00h | CSCTL0 | Clock System Control Register 0 | Read/write | Word | 0000h | Section 3.3.1 | | 02h | CSCTL1 | Clock System Control Register 1 | Read/write | Word | 0033h | Section 3.3.2 | | 04h | CSCTL2 | Clock System Control Register 2 | Read/write | Word | 101Fh | Section 3.3.3 | | 06h | CSCTL3 | Clock System Control Register 3 | Read/write | Word | 0000h | Section 3.3.4 | | 08h | CSCTL4 | Clock System Control Register 4 | Read/write | Word | 0100h | Section 3.3.5 | | 0Ah | CSCTL5 | Clock System Control Register 5 | Read/write | Word | 1000h | Section 3.3.6 | | 0Ch | CSCTL6 | Clock System Control Register 6 | Read/write | Word | 08C1h | Section 3.3.7 | | 0Eh | CSCTL7 | Clock System Control Register 7 | Read/write | Word | 0740h | Section 3.3.8 | | 10h | CSCTL8 | Clock System Control Register 8 | Read/write | Word | 0007h | Section 3.3.9 | www.ti.com CS Registers # 3.3.1 CSCTL0 Register Clock System Control Register 0 # Figure 3-8. CSCTL0 Register # Table 3-4. CSCTL0 Register Description | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-14 | Reserved | R | 0h | Reserved. Always reads as 0. | | 13-9 | MOD | RW | 0h | Modulation bit counter. These bits select the modulation pattern. All MOD bits are modified automatically during FLL operation. The DCO register value is incremented when the modulation bit counter rolls over from 31 to 0. If the modulation bit counter decrements from 0 to the maximum count, the DCO register value is also decreased. | | 8-0 | DCO | RW | 0h | DCO tap selection. These bits select the DCO tap and are modified automatically during FLL operation. | CS Registers www.ti.com # 3.3.2 CSCTL1 Register Clock System Control Register 1 # Figure 3-9. CSCTL1 Register # Table 3-5. CSCTL1 Register Description | Bit | Field | Туре | Reset | Description | |------|------------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-8 | Reserved | R | 0h | Reserved. Always reads as 0. | | 7 | DCOFTRIMEN | RW | Oh | DCO frequency trim enable. When this bit is set, DCOFTRIM value is selected to set the DCO frequency. Otherwise, DCOFTRIM value is bypassed, and the DCO applies default settings from manufacture. | | | | | | 0b = Disable frequency trim | | | | | | 1b = Enable frequency trim | | 6-4 | DCOFTRIM | RW | 3h | DCO frequency trim. These bits trims the DCO frequency. By default, it is chip-<br>specific trimmed. These bits can also be trimmed by user code. | | 3-1 | DCORSEL | RW | 1h | DCO range select | | | | | | 000b = 1 MHz | | | | | | 001b = 2 MHz (default) | | | | | | 010b = 4 MHz | | | | | | 011b = 8 MHz | | | | | | 100b = 12 MHz | | | | | | 101b = 16 MHz | | | | | | 110b = 20 MHz (available in enhanced clock system only) | | | | | | 111b = 24 MHz (available in enhanced clock system only) | | 0 | DISMOD | RW | 1h | Modulation. This bit enables or disables the modulation. | | | | | | 0b = Modulation enabled | | | | | | 1b = Modulation disabled | www.ti.com CS Registers # 3.3.3 CSCTL2 Register Clock System Control Register 2 # Figure 3-10. CSCTL2 Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | |----------|------|------|------|------|-------|------|------|--|--|--| | Reserved | | FLLD | | Rese | erved | FL | LN | | | | | r0 | rw-0 | rw-0 | rw-1 | rO | r0 | rw-0 | rw-0 | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | FLLN | | | | | | | | | | | rw-0 | rw-0 | rw-0 | rw-1 | rw-1 | rw-1 | rw-1 | rw-1 | | | | # Table 3-6. CSCTL2 Register Description | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15 | Reserved | R | 0h | Reserved. Always reads as 0. | | 14-12 | FLLD | RW | 1h | FLL loop divider. These bits divide $f_{DCOCLK}$ in the FLL feedback loop. This results in an additional multiplier for the multiplier bits. Also see the FLLN multiplier bits. $000b = f_{DCOCLK} \div 1$ $001b = f_{DCOCLK} \div 2$ (default) $010b = f_{DCOCLK} \div 4$ $011b = f_{DCOCLK} \div 8$ $100b = f_{DCOCLK} \div 16$ $101b = f_{DCOCLK} \div 32$ $110b = Reserved for future use$ $111b = Reserved for future use$ | | 11-10 | Reserved | R | 0h | Reserved. Always reads as 0. | | 9-0 | FLLN | RW | 1Fh | Multiplier bits. These bits set the multiplier value N of the DCO. N must be greater than 0. Writing zero to FLLN causes N to be set to 1. | CS Registers www.ti.com # 3.3.4 CSCTL3 Register Clock System Control Register 3 ## Figure 3-11. CSCTL3 Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----------|-----|-----|----------|----|--------------------------|----| | | | | Res | served | | | | | r0 | r0 | rO | r0 | r0 | rO | r0 | r0 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | REFOLP | Reserved | SEL | REF | Reserved | | FLLREFDIV <sup>(1)</sup> | | <sup>(1)</sup> These bits are always read and written as 000b, when XT1 only supports 32 kHz. # Table 3-7. CSCTL3 Register Description | Bit | Field | Туре | Reset | Description | |------|-----------------------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-8 | Reserved | R | 0h | Reserved. Always reads as 0. | | 7 | REFOLP <sup>(1)</sup> | RW | Oh | REFO low-power enable. This bit turns on REFO low-power mode. During switching, the low-power mode is invalid until REFOREADY is set. 0b = REFO low power disabled (high-power mode) 1b = REFO low power enabled | | 6 | Reserved | R | 0h | Reserved. Always reads as 0. | | 5-4 | SELREF | RW | 0h | FLL reference select. These bits select the FLL reference clock source. 00b = XT1CLK 01b = REFOCLK 10b = Reserved for future use 11b = Reserved for future use. | | 3 | Reserved | R | 0h | Reserved. Always reads as 0. | | 2-0 | FLLREFDIV | RW | Oh | FLL reference divider. These bits define the divide factor for $f_{\text{FLLREFCLK}}$ . If XT1 supports high-frequency input greater than 32 kHz, the divided frequency is used as the FLL reference frequency. $000b = f_{\text{FLLREFCLK}} \div 1$ $001b = f_{\text{FLLREFCLK}} \div 32$ $010b = f_{\text{FLLREFCLK}} \div 64$ $011b = f_{\text{FLLREFCLK}} \div 128$ $100b = f_{\text{FLLREFCLK}} \div 256$ $101b = f_{\text{FLLREFCLK}} \div 512$ $110b = f_{\text{FLLREFCLK}} \div 640$ (available in enhanced clock systems only) $111b = f_{\text{FLLREFCLK}} \div 768$ (available in enhanced clock systems only) If XT1 supports only a 32-kHz clock, FLLREFDIV always reads and should be written as zero: $000b = f_{\text{FLLREFCLK}} \div 1$ | <sup>(1)</sup> This bit is only available in enhanced clock systems. Additionally, this bit must be cleared before the device entering LPMx.5 mode to avoid additional current consumption. www.ti.com CS Registers # 3.3.5 CSCTL4 Register Clock System Control Register 4 # Figure 3-12. CSCTL4 Register # Table 3-8. CSCTL4 Register Description | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-10 | Reserved | R | 0h | Reserved. Always reads as 0. | | 9-8 | SELA | RW | 1h | Selects the ACLK source. 00b = XT1CLK with divider (must be no more than 40 kHz) 01b = REFO (internal 32-kHz clock source) 10b = VLO (internal 10-kHz clock source) <sup>(1)</sup> 11b = Reserved for future use | | 7-3 | Reserved | R | 0h | Reserved. Always reads as 0. | | 2-0 | SELMS | RW | Oh | Selects the MCLK and SMCLK source. 000b = DCOCLKDIV 001b = REFOCLK 010b = XT1CLK 011b = VLOCLK 1xxb = Reserved for future use | <sup>(1)</sup> This is only available in enhanced CS systems. CS Registers www.ti.com # 3.3.6 CSCTL5 Register Clock System Control Register 5 # Figure 3-13. CSCTL5 Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----|----------|------|------------|----------|----------|------|----------| | | Reserved | | VLOAUTOOFF | | Reserved | | SMCLKOFF | | r0 | r0 | rO | rw-1 | rO | r0 | r0 | rw-0 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | R | Reserved | D | IVS | Reserved | | DIVM | | | rO | r0 | rw-0 | rw-0 | r0 | rw-0 | rw-0 | rw-0 | # Table 3-9. CSCTL5 Register Description | Bit | Field | Туре | Reset | Description | |-------|------------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-13 | Reserved | R | 0h | Reserved. Always reads as 0. | | 12 | VLOAUTOOFF | RW | 1h | VLO automatic off enable. This bit turns off VLO, if VLO is not used. 0b = VLO always on 1b = VLO automatically turned off if not used(default) | | 11-9 | Reserved | R | 0h | Reserved. Always reads as 0. | | 8 | SMCLKOFF | R/W | Oh | SMCLK off. This bit turns off SMCLK clock. 0b = SMCLK on 1b = SMCLK off | | 7-6 | Reserved | R | 0h | Reserved. Always reads as 0. | | 5-4 | DIVS | RW | Oh | SMCLK source divider. SMCLK directly derives from MCLK. SMCLK frequency is the combination of DIVM and DIVS out of selected clock source. $00b = \div 1 \\ 01b = \div 2 \\ 10b = \div 4 \\ 11b = \div 8$ | | 3 | Reserved | R | 0h | Reserved. Always reads as 0. | | 2-0 | DIVM | RW | Oh | MCLK source divider $000b = \div 1$ $001b = \div 2$ $010b = \div 4$ $011b = \div 8$ $100b = \div 16$ $101b = \div 32$ $110b = \div 64$ $111b = \div 128$ | www.ti.com CS Registers ## 3.3.7 CSCTL6 Register Clock System Control Register 6 #### Figure 3-14. CSCTL6 Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | |------|-------|--------------------|-----------|-------|------|-----------|------------|--| | | Rese | erved | | DIVA | | | | | | rO | rO | rO | r0 | rw-1 | rw-0 | rw-0 | rw-0 | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | XT1 | DRIVE | XTS <sup>(1)</sup> | XT1BYPASS | XT1HF | FREQ | XT1AGCOFF | XT1AUTOOFF | | | rw-1 | rw-1 | rw-0 | rw-0 | rw-0 | rw-0 | rw-0 | rw-1 | | <sup>(1)</sup> This bit is read-only as 0 if the device does not support XT1 HF mode. See the device-specific data sheet for configuration information. #### Table 3-10. CSCTL6 Register Description | Bit | Field | Туре | Reset | Description | |-------|-------------|-------------------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-14 | Reserved | R | 0h | Reserved. Always reads as 0. | | 13 | XT1FAULTOFF | RW | Oh | XT1 oscillator fault detection off 0b = Enabling XT1 fault to switch ACLK to REFO 1b = Disabling XT1 fault to switch ACLK to REFO | | 12 | Reserved | R | 0h | Reserved. Always reads as 0. | | 11-8 | DIVA | RW | 8h | ACLK source divider. (1)(2) 0000b = ÷1 0001b = ÷16 0010b = ÷32 0011b = ÷64 0100b = ÷128 0101b = ÷256 0110b = ÷384 0111b = ÷512 1000b = ÷768 (available in enhanced clock system only, 24 MHz preference) 1001b = ÷1024 (available in enhanced clock system only, 32 MHz preference) 1010b = ÷108 (available in enhanced clock system only, 3.5712 MHz preference) 1011b = ÷338 (available in enhanced clock system only, 11.0592 MHz preference) 1100b = ÷414 (available in enhanced clock system only, 13.56 MHz preference) 1101b = ÷640 (available in enhanced clock system only, 20.00 MHz preference) 1110b to 1111b = Reserved | | 7-6 | XT1DRIVE | RW | 3h | The XT1 oscillator current can be adjusted to its drive needs. Initially, it starts with the highest supply current for reliable and quick startup. If needed, user software can reduce the drive strength. The configuration of these bits is retained during LPM3.5 until LOCKLPM5 is cleared, but not the register bits itself; therefore, reconfiguration is required after wakeup from LPM3.5 and before clearing LOCKLPM5. Obe = Lowest drive strength and current consumption Obe = Lower drive strength and current consumption The = Highest drive strength and current consumption | | 5 | XTS | RW <sup>(3)</sup> | 0h <sup>(4)</sup> | XT1 mode select. 0b = Low-frequency mode 1b = High-frequency mode | <sup>(1)</sup> These bits are valid only in XT1 HF mode. The divider setting depends on the external high-frequency oscillator value, because ACLK is fixed to no more than 40 kHz (typical). See the device-specific data sheet for details. <sup>&</sup>lt;sup>(2)</sup> This divider is always bypassed if ACLK sources from XT1 in LF mode. <sup>(3)</sup> The bits are read-only if XT1 HF mode is not supported in the device. See the device-specific data sheet for configuration information. <sup>(4)</sup> The bits are read-only as 0 if XT1 HF mode is not supported in the device. See the device-specific data sheet for configuration information. CS Registers www.ti.com # Table 3-10. CSCTL6 Register Description (continued) | Bit | Field | Туре | Reset | Description | |-----|------------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 4 | XT1BYPASS | RW | Oh | XT1 bypass select. 0b = XT1 source internally 1b = XT1 sources externally from pin | | 3-2 | XT1HFFREQ | RW | Oh | The XT1 high-frequency selection. These bits must be set to appropriate frequency for crystal or bypass modes of operation. (1) 00b = 1 MHz to 4 MHz 01b = Above 4 MHz to 6 MHz 10b = Above 6 MHz to 16 MHz 11b = Above 16 MHz to 24 MHz (available in enhanced clock system only) | | 1 | XT1AGCOFF | RW | Oh | Automatic gain control (AGC) disable. 0b = AGC on 1b = AGC off | | 0 | XT1AUTOOFF | RW | 1h | XT1 automatic off enable. This bit allows XT1 turned turns off when it is not used. 0b = XT1 is on if XT1 is selected by the port selection and XT1 is not in bypass mode of operation. 1b = XT1 is off if it is not used as a source for ACLK, MCLK, or SMCLK or is not used as a reference source required for FLL operation. | www.ti.com CS Registers # 3.3.8 CSCTL7 Register Clock System Control Register 7 # Figure 3-15. CSCTL7 Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------|-----------|-----------|----------|--------------|-----------|-----------|--------| | Reserved | | FLLWARNEN | FLLULPUC | FLLUNLOCKHIS | | FLLUNLOCK | | | r0 | rO | rw-0 | rw-(0) | rw-(0) | rw-(1) | r-1 | r-1 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Reserved | ENSTFCNT1 | Reserved | FLLULIFG | Reserved | REFOREADY | XT10FFG | DCOFFG | | r-0 | rw-(1) | r0 | rw-(0) | r0 | r-0 | rw-(0) | rw-(0) | # Table 3-11. CSCTL7 Register Description | Bit | Field | Туре | Reset | Description | |-------|--------------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-14 | Reserved | R | 0h | Reserved. Always reads as 0. | | 13 | FLLWARNEN | RW | Oh | Warning enable. If this bit is set, an interrupt is generated based on the FLLUNLOCKHIS bits. If FLLUNLOCKHIS is not equal to 00, an OFIFG is generated. 0b = FLLUNLOCKHIS status cannot set OFIFG. 1b = FLLUNLOCKHIS status can set OFIFG. | | 12 | FLLULPUC | RW | Oh | FLL unlock PUC enable. If the FLLULPUC bit is set, a reset (PUC) is triggered if FLLULIFG is set. FLLULIFG indicates when FLLUNLOCK bits equal 10 (too fast). FLLULPUC is automatically cleared upon servicing the event. If FLLULPUC is cleared (0), no PUC can be triggered by FLLULIFG. | | 11-10 | FLLUNLOCKHIS | RW | 1h | Unlock history bits. These bits indicate the FLL unlock condition history. As soon as any unlock condition happens, the respective bits are set and remain set until cleared by software by writing 0 to it or by a POR. 00b = FLL is locked. No unlock situation has been detected since the last reset of these bits. 01b = DCOCLK has been too slow since the bits were cleared. 10b = DCOCLK has been too fast since the bits were cleared. 11b = DCOCLK has been both too fast and too slow since the bits were cleared. | | 9-8 | FLLUNLOCK | R | 3h | Unlock. These bits indicate the current FLL unlock condition. These bits are both set as long as the DCOFFG flag is set. 00b = FLL is locked. No unlock condition currently active. 01b = DCOCLK is currently too slow. 10b = DCOCLK is currently too fast. 11b = DCOERROR. DCO out of range. | | 7 | Reserved | R | 0h | Reserved. Always reads as 0. | | 6 | ENSTFCNT1 | RW | 1h | Enable start counter for XT1. 0b = Start fault counter disabled. Counter is cleared. 1b = Start fault counter enabled. | | 5 | Reserved | R | 0h | Reserved. Always reads as 0. | | 4 | FLLULIFG | RW | Oh | FLL unlock interrupt flag. This flag is set when FLLUNLOCK bits equal 10b (DCO too fast). If FLLULPUC is also set, a PUC is triggered when FLLULIFG is set. 0b = FLLUNLOCK bits not equal to 10b 1b = FLLUNLOCK bits equal to 10b | | 3-2 | Reserved | R | 0h | Reserved. Always reads as 0. | | 2 | REFOREADY | R | Oh | REFO ready flag. This bit reports when REFO is ready for operation (such as for the FLL reference). 0b = REFO unstable 1b = REFO ready | CS Registers www.ti.com # Table 3-11. CSCTL7 Register Description (continued) | Bit | Field | Туре | Reset | Description | |-----|---------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1 | XT10FFG | RW | 0h | XT1 oscillator fault flag. If this bit is set, the OFIFG flag is also set. XT1OFFG is set if a XT1 fault condition exists. XT1OFFG can be cleared by software. If the XT1 fault condition still remains, XT1OFFG is set. 0b = No fault condition occurred | | | | | | 1b = XT1 fault. An XT1 fault occurred. | | 0 | DCOFFG | RW | 0h | DCO fault flag. If this bit is set, the OFIFG flag is also set. The DCOFFG bit is set if DCO = {0} or DCO = {511}. DCOFFG can be cleared by software. If the DCO fault condition still remains, DCOFFG is set. As long as DCOFFG is set, FLLUNLOCK shows the DCOERROR condition. | | | | | | 0b = No fault condition occurred | | | | | | 1b = DCO fault. A DCO fault occurred. | www.ti.com CS Registers # 3.3.9 CSCTL8 Register Clock System Control Register 8 # Figure 3-16. CSCTL8 Register # Table 3-12. CSCTL8 Register Description | Bit | Field | Type | Reset | Description | |------|-------------|------|-------|-------------------------------------------------------------------------------------------| | 15-4 | Reserved | R | 0h | Reserved. Always reads as 0. | | 3 | MODOSCREQEN | RW | 0h | MODOSC clock request enable. Setting this enables conditional module requests for MODOSC. | | | | | | 0b = MODOSC conditional requests are disabled. | | | | | | 1b = MODOSC conditional requests are enabled. | | 2 | SMCLKREQEN | RW | 1h | SMCLK clock request enable. Setting this enables conditional module requests for SMCLK. | | | | | | 0b = SMCLK conditional requests are disabled. | | | | | | 1b = SMCLK conditional requests are enabled. | | 1 | MCLKREQEN | RW | 1h | MCLK clock request enable. Setting this enables conditional module requests for MCLK. | | | | | | 0b = MCLK conditional requests are disabled. | | | | | | 1b = MCLK conditional requests are enabled. | | 0 | ACLKREQEN | RW | 1h | ACLK clock request enable. Setting this enables conditional module requests for ACLK. | | | | | | 0b = ACLK conditional requests are disabled. | | | | | | 1b = ACLK conditional requests are enabled. | # **CPUX** This chapter describes the extended MSP430X 16-bit RISC CPU (CPUX) with 1MB memory access, its addressing modes, and instruction set. NOTE: The MSP430X CPUX implemented on this device family, formally called CPUXV2, has in some cases, slightly different cycle counts from the MSP430X CPUX implemented on the 2xx and 4xx families. **Topic Page** | 4.1 | MSP430X CPU (CPUX) Introduction | 125 | |-----|---------------------------------|-----| | 4.2 | Interrupts | 127 | | 4.3 | CPU Registers | 128 | | 4.4 | Addressing Modes | 134 | | 4.5 | MSP430 and MSP430X Instructions | | | 4.6 | Instruction Set Description | 167 | 124 # 4.1 MSP430X CPU (CPUX) Introduction The MSP430X CPU incorporates features specifically designed for modern programming techniques, such as calculated branching, table processing, and the use of high-level languages such as C. The MSP430X CPU can address a 1MB address range without paging. The MSP430X CPU is completely backward compatible with the MSP430 CPU. The MSP430X CPU features include: - RISC architecture - Orthogonal architecture - Full register access including program counter (PC), status register (SR), and stack pointer (SP) - Single-cycle register operations - Large register file reduces fetches to memory. - 20-bit address bus allows direct access and branching throughout the entire memory range without paging. - 16-bit data bus allows direct manipulation of word-wide arguments. - Constant generator provides the six most often used immediate values and reduces code size. - Direct memory-to-memory transfers without intermediate register holding - Byte, word, and 20-bit address-word addressing The block diagram of the MSP430X CPU is shown in Figure 4-1. Figure 4-1. MSP430X CPU Block Diagram www.ti.com Interrupts #### 4.2 Interrupts The MSP430X has the following interrupt structure: - Vectored interrupts with no polling necessary - Interrupt vectors are located downward from address 0FFFEh. The interrupt vectors contain 16-bit addresses that point into the lower 64KB memory. This means all interrupt handlers must start in the lower 64KB memory. During an interrupt, the program counter (PC) and the status register (SR) are pushed onto the stack as shown in Figure 4-2. The MSP430X architecture stores the complete 20-bit PC value efficiently by appending the PC bits 19:16 to the stored SR value automatically on the stack. When the RETI instruction is executed, the full 20-bit PC is restored making return from interrupt to any address in the memory range possible. Figure 4-2. PC Storage on the Stack for Interrupts CPU Registers www.ti.com # 4.3 CPU Registers The CPU incorporates 16 registers (R0 through R15). Registers R0, R1, R2, and R3 have dedicated functions. Registers R4 through R15 are working registers for general use. #### 4.3.1 Program Counter (PC) The 20-bit Program Counter (PC, also called R0) points to the next instruction to be executed. Each instruction uses an even number of bytes (2, 4, 6, or 8 bytes), and the PC is incremented accordingly. Instruction accesses are performed on word boundaries, and the PC is aligned to even addresses. Figure 4-3 shows the PC. Figure 4-3. Program Counter The PC can be addressed with all instructions and addressing modes. A few examples: ``` MOV.W #LABEL,PC; Branch to address LABEL (lower 64KB) MOVA #LABEL,PC; Branch to address LABEL (1MB memory) MOV.W LABEL,PC; Branch to address in word LABEL; (lower 64KB) MOV.W @R14,PC; Branch indirect to address in; R14 (lower 64KB) ADDA #4,PC; Skip two words (1MB memory) ``` The BR and CALL instructions reset the upper four PC bits to 0. Only addresses in the lower 64KB address range can be reached with the BR or CALL instruction. When branching or calling, addresses beyond the lower 64KB range can only be reached using the BRA or CALLA instructions. Also, any instruction to directly modify the PC does so according to the used addressing mode. For example, MOV.W #value,PC clears the upper four bits of the PC, because it is a .W instruction. The PC is automatically stored on the stack with CALL (or CALLA) instructions and during an interrupt service routine. Figure 4-4 shows the storage of the PC with the return address after a CALLA instruction. A CALL instruction stores only bits 15:0 of the PC. Figure 4-4. PC Storage on the Stack for CALLA The RETA instruction restores bits 19:0 of the PC and adds 4 to the stack pointer (SP). The RET instruction restores bits 15:0 to the PC and adds 2 to the SP. ## 4.3.2 Stack Pointer (SP) The 20-bit Stack Pointer (SP, also called R1) is used by the CPU to store the return addresses of subroutine calls and interrupts. It uses a predecrement, postincrement scheme. In addition, the SP can be used by software with all instructions and addressing modes. Figure 4-5 shows the SP. The SP is initialized into RAM by the user, and is always aligned to even addresses. www.ti.com CPU Registers Figure 4-6 shows the stack usage. Figure 4-7 shows the stack usage when 20-bit address words are pushed. Figure 4-5. Stack Pointer Figure 4-6. Stack Usage Figure 4-7. PUSHX.A Format on the Stack The special cases of using the SP as an argument to the PUSH and POP instructions are described and shown in Figure 4-8. The stack pointer is changed after a PUSH SP instruction. The stack pointer is not changed after a POP SP instruction. The POP SP instruction places SP1 into the stack pointer SP (SP2 = SP1) Figure 4-8. PUSH SP, POP SP Sequence CPU Registers www.ti.com ## 4.3.3 Status Register (SR) The 16-bit Status Register (SR, also called R2), used as a source or destination register, can only be used in register mode addressed with word instructions. The remaining combinations of addressing modes are used to support the constant generator. Figure 4-9 shows the SR bits. Do not write 20-bit values to the SR. Unpredictable operation can result. Figure 4-9. SR Bits Table 4-1 describes the SR bits. **Table 4-1. SR Bit Description** | Bit | Description | | | | | | | | | |-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|--|--|--|--|--|--|--| | Reserved | Reserved | | | | | | | | | | | Overflow. This bit is set when the result of an arithmetic operation overflows the signed-variable range. | | | | | | | | | | V | ADD(.B), ADDX(.B,.A),<br>ADDC(.B), ADDCX(.B.A),<br>ADDA | Set when: positive + positive = negative negative + negative = positive otherwise reset | | | | | | | | | | SUB(.B), SUBX(.B,.A),<br>SUBC(.B), SUBCX(.B,.A),<br>SUBA, CMP(.B),<br>CMPX(.B,.A), CMPA | Set when: positive – negative = negative negative – positive = positive otherwise reset | | | | | | | | | SCG1 <sup>(1)</sup> | System clock generator 1. This bit may be used to enable or disable functions in the clock system depending on the device family; for example, DCO bias enable or disable. | | | | | | | | | | SCG0 <sup>(1)</sup> | System clock generator 0. This bit may be used to enable or distinct the device family; for example, FLL enable or disable. | sable functions in the clock system depending on | | | | | | | | | OSCOFF <sup>(1)</sup> | Oscillator off. When this bit is set, it turns off the LFXT1 crystal SMCLK. | oscillator when LFXT1CLK is not used for MCLK or | | | | | | | | | CPUOFF <sup>(1)</sup> | CPU off. When this bit is set, it turns off the CPU. | | | | | | | | | | GIE | General interrupt enable. When this bit is set, it enables maskal interrupts are disabled. | ble interrupts. When it is reset, all maskable | | | | | | | | | N | Negative. This bit is set when the result of an operation is negative and cleared when the result is positive. | | | | | | | | | | Z | Zero. This bit is set when the result of an operation is 0 and cle | ared when the result is not 0. | | | | | | | | | С | Carry. This bit is set when the result of an operation produced a | a carry and cleared when no carry occurred. | | | | | | | | The bits CPUOFF, OSCOFF, SCG0, and SCG1 request the system to enter a low-power mode NOTE: Bit manipulations of the SR should be done by the following instructions: MOV, BIS, and BIC. www.ti.com CPU Registers # 4.3.4 Constant Generator Registers (CG1 and CG2) Six commonly-used constants are generated with the constant generator registers R2 (CG1) and R3 (CG2), without requiring an additional 16-bit word of program code. The constants are selected with the source register addressing modes (As), as described in Table 4-2. Table 4-2. Values of Constant Generators CG1, CG2 | Register | As | Constant | Remarks | |----------|----|--------------------|-----------------------| | R2 | 00 | _ | Register mode | | R2 | 01 | (0) | Absolute address mode | | R2 | 10 | 00004h | +4, bit processing | | R2 | 11 | 00008h | +8, bit processing | | R3 | 00 | 00000h | 0, word processing | | R3 | 01 | 00001h | +1 | | R3 | 10 | 00002h | +2, bit processing | | R3 | 11 | FFh, FFFFh, FFFFFh | −1, word processing | The constant generator advantages are: - No special instructions required - No additional code word for the six constants - No code memory access required to retrieve the constant The assembler uses the constant generator automatically if one of the six constants is used as an immediate source operand. Registers R2 and R3, used in the constant mode, cannot be addressed explicitly; they act as source-only registers. #### 4.3.4.1 Constant Generator – Expanded Instruction Set The RISC instruction set of the MSP430 has only 27 instructions. However, the constant generator allows the MSP430 assembler to support 24 additional emulated instructions. For example, the single-operand instruction: CLR dst is emulated by the double-operand instruction with the same length: MOV R3,dst where the #0 is replaced by the assembler, and R3 is used with As = 00. INC dst is replaced by: ADD #1,dst CPU Registers www.ti.com ## 4.3.5 General-Purpose Registers (R4 to R15) The 12 CPU registers (R4 to R15) contain 8-bit, 16-bit, or 20-bit values. Any byte-write to a CPU register clears bits 19:8. Any word-write to a register clears bits 19:16. The only exception is the SXT instruction. The SXT instruction extends the sign through the complete 20-bit register. Figure 4-10 through Figure 4-14 show the handling of byte, word, and address-word data. Note the reset of the leading most significant bits (MSBs) if a register is the destination of a byte or word instruction. Figure 4-10 shows byte handling (8-bit data, .B suffix). The handling is shown for a source register and a destination memory byte and for a source memory byte and a destination register. Figure 4-10. Register-Byte and Byte-Register Operation Figure 4-11 and Figure 4-12 show 16-bit word handling (.W suffix). The handling is shown for a source register and a destination memory word and for a source memory word and a destination register. Figure 4-11. Register-Word Operation www.ti.com CPU Registers Word Register Operation Figure 4-12. Word-Register Operation Figure 4-13 and Figure 4-14 show 20-bit address-word handling (.A suffix). The handling is shown for a source register and a destination memory address-word and for a source memory address-word and a destination register. Register - Address-Word Operation Figure 4-13. Register - Address-Word Operation Addressing Modes www.ti.com Address-Word – Register Operation High Byte Low Byte 19 16 15 8 7 0 Memory +2 Unused Memory Register Operation Register #### Figure 4-14. Address-Word – Register Operation ## 4.4 Addressing Modes Seven addressing modes for the source operand and four addressing modes for the destination operand use 16-bit or 20-bit addresses (see Table 4-3). The MSP430 and MSP430X instructions are usable throughout the entire 1MB memory range. Table 4-3. Source and Destination Addressing | As, Ad | Addressing Mode | Syntax | Description | |--------|---------------------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 00, 0 | Register | Rn | Register contents are operand. | | 01, 1 | Indexed | X(Rn) | (Rn + X) points to the operand. X is stored in the next word, or stored in combination of the preceding extension word and the next word. | | 01, 1 | Symbolic | ADDR | (PC + X) points to the operand. X is stored in the next word, or stored in combination of the preceding extension word and the next word. Indexed mode $X(PC)$ is used. | | 01, 1 | Absolute | &ADDR | The word following the instruction contains the absolute address. X is stored in the next word, or stored in combination of the preceding extension word and the next word. Indexed mode X(SR) is used. | | 10, – | Indirect Register | @Rn | Rn is used as a pointer to the operand. | | 11, – | Indirect<br>Autoincrement | @Rn+ | Rn is used as a pointer to the operand. Rn is incremented afterwards by 1 for .B instructions, by 2 for .W instructions, and by 4 for .A instructions. | | 11, – | Immediate | #N | N is stored in the next word, or stored in combination of the preceding extension word and the next word. Indirect autoincrement mode @PC+ is used. | The seven addressing modes are explained in detail in the following sections. Most of the examples show the same addressing mode for the source and destination, but any valid combination of source and destination addressing modes is possible in an instruction. #### NOTE: Use of Labels EDE, TONI, TOM, and LEO Throughout MSP430 documentation, EDE, TONI, TOM, and LEO are used as generic labels. They are only labels and have no special meaning. www.ti.com Addressing Modes #### 4.4.1 Register Mode Operation: The operand is the 8-, 16-, or 20-bit content of the used CPU register. Length: One, two, or three words Comment: Valid for source and destination Byte operation: Byte operation reads only the eight least significant bits (LSBs) of the source register Rsrc and writes the result to the eight LSBs of the destination register Rdst. The bits Rdst.19:8 are cleared. The register Rsrc is not modified. Word operation: Word operation reads the 16 LSBs of the source register Rsrc and writes the result to the 16 LSBs of the destination register Rdst. The bits Rdst.19:16 are cleared. The register Rsrc is not modified. Address-word operation: Address-word operation reads the 20 bits of the source register Rsrc and writes the result to the 20 bits of the destination register Rdst. The register Rsrc is not modified SXT exception: The SXT instruction is the only exception for register operation. The sign of the low byte in bit 7 is extended to the bits Rdst.19:8. Example: BIS.W R5,R6; This instruction logically ORs the 16-bit data contained in R5 with the 16-bit contents of R6. R6.19:16 is cleared. A550h.or.1111h = B551h Example: BISX.A R5,R6; This instruction logically ORs the 20-bit data contained in R5 with the 20-bit contents of R6. The extension word contains the A/L bit for 20-bit data. The instruction word uses byte mode with bits A/L:B/W = 01. The result of the instruction is: AA550h.or.11111h = BB551h Addressing Modes www.ti.com #### 4.4.2 Indexed Mode The Indexed mode calculates the address of the operand by adding the signed index to a CPU register. The Indexed mode has three addressing possibilities: - Indexed mode in lower 64KB memory - MSP430 instruction with Indexed mode addressing memory above the lower 64KB memory - MSP430X instruction with Indexed mode #### 4.4.2.1 Indexed Mode in Lower 64KB Memory If the CPU register Rn points to an address in the lower 64KB of the memory range, the calculated memory address bits 19:16 are cleared after the addition of the CPU register Rn and the signed 16-bit index. This means the calculated memory address is always located in the lower 64KB and does not overflow or underflow out of the lower 64KB memory space. The RAM and the peripheral registers can be accessed this way and existing MSP430 software is usable without modifications as shown in Figure 4-15. Figure 4-15. Indexed Mode in Lower 64KB Length: Two or three words Operation: The signed 16-bit index is located in the next word after the instruction and is added to the CPU register Rn. The resulting bits 19:16 are cleared giving a truncated 16-bit memory address, which points to an operand address in the range 00000h to 0FFFFh. The operand is the content of the addressed memory location. Comment: Valid for source and destination. The assembler calculates the register index and inserts it. Example: ADD.B 1000h(R5),0F000h(R6); This instruction adds the 8-bit data contained in source byte 1000h(R5) and the destination byte 0F000h(R6) and places the result into the destination byte. Source and destination bytes are both located in the lower 64KB due to the cleared bits 19:16 of registers R5 and R6. Source: The byte pointed to by R5 + 1000h results in address 0479Ch + 1000h = 0579Ch after truncation to a 16-bit address. Destination: The byte pointed to by R6 + F000h results in address 01778h + F000h = 00778h after truncation to a 16-bit address. www.ti.com Addressing Modes #### 4.4.2.2 MSP430 Instruction With Indexed Mode in Upper Memory If the CPU register Rn points to an address above the lower 64KB memory, the Rn bits 19:16 are used for the address calculation of the operand. The operand may be located in memory in the range Rn ±32KB, because the index, X, is a signed 16-bit value. In this case, the address of the operand can overflow or underflow into the lower 64KB memory space (see Figure 4-16 and Figure 4-17). Figure 4-16. Indexed Mode in Upper Memory Addressing Modes www.ti.com Figure 4-17. Overflow and Underflow for Indexed Mode Length: Two or three words Operation: The sign-extended 16-bit index in the next word after the instruction is added to the 20 bits of the CPU register Rn. This delivers a 20-bit address, which points to an address in the range 0 to FFFFFh. The operand is the content of the addressed memory location. Comment: Valid for source and destination. The assembler calculates the register index and inserts it. Example: ADD.W 8346h(R5),2100h(R6); This instruction adds the 16-bit data contained in the source and the destination addresses and places the 16-bit result into the destination. Source and destination operand can be located in the entire address range. Source: The word pointed to by R5 + 8346h. The negative index 8346h is sign extended, which results in address 23456h + F8346h = 1B79Ch. Destination: The word pointed to by R6 + 2100h results in address 15678h + 2100h = 17778h. www.ti.com Addressing Modes Figure 4-18. Example for Indexed Mode #### 4.4.2.3 MSP430X Instruction With Indexed Mode When using an MSP430X instruction with Indexed mode, the operand can be located anywhere in the range of Rn + 19 bits. Length: Three or four words Operation: The operand address is the sum of the 20-bit CPU register content and the 20-bit index. The 4 MSBs of the index are contained in the extension word; the 16 LSBs are contained in the word following the instruction. The CPU register is not modified Comment: Valid for source and destination. The assembler calculates the register index and inserts it. Example: ADDX.A 12346h(R5),32100h(R6); This instruction adds the 20-bit data contained in the source and the destination addresses and places the result into the destination. Source: Two words pointed to by R5 + 12346h which results in address 23456h + 12346h = 3579Ch. Destination: Two words pointed to by R6 + 32100h which results in address 45678h + 32100h = 77778h. Addressing Modes www.ti.com The extension word contains the MSBs of the source index and of the destination index and the A/L bit for 20-bit data. The instruction word uses byte mode due to the 20-bit data length with bits A/L:B/W = 01. #### 4.4.3 Symbolic Mode The Symbolic mode calculates the address of the operand by adding the signed index to the PC. The Symbolic mode has three addressing possibilities: - Symbolic mode in lower 64KB memory - MSP430 instruction with Symbolic mode addressing memory above the lower 64KB memory. - MSP430X instruction with Symbolic mode #### 4.4.3.1 Symbolic Mode in Lower 64KB If the PC points to an address in the lower 64KB of the memory range, the calculated memory address bits 19:16 are cleared after the addition of the PC and the signed 16-bit index. This means the calculated memory address is always located in the lower 64KB and does not overflow or underflow out of the lower 64KB memory space. The RAM and the peripheral registers can be accessed this way and existing MSP430 software is usable without modifications as shown in Figure 4-19. www.ti.com Addressing Modes Figure 4-19. Symbolic Mode Running in Lower 64KB Operation: The signed 16-bit index in the next word after the instruction is added temporarily to the PC. The resulting bits 19:16 are cleared giving a truncated 16-bit memory address, which points to an operand address in the range 00000h to 0FFFFh. The operand is the content of the addressed memory location. Length: Two or three words Comment: Valid for source and destination. The assembler calculates the PC index and inserts it. Example: ADD.B EDE, TONI ; This instruction adds the 8-bit data contained in source byte EDE and destination byte TONI and places the result into the destination byte TONI. Bytes EDE and TONI and the program are located in the lower 64KB. Source: Byte EDE located at address 0579Ch, pointed to by PC + 4766h, where the PC index 4766h is the result of 0579Ch - 01036h = 04766h. Address 01036h is the location of the index for this example. Destination: Byte TONI located at address 00778h, pointed to by PC + F740h, is the truncated 16-bit result of 00778h - 1038h = FF740h. Address 01038h is the location of the index for this example. Addressing Modes www.ti.com #### 4.4.3.2 MSP430 Instruction With Symbolic Mode in Upper Memory If the PC points to an address above the lower 64KB memory, the PC bits 19:16 are used for the address calculation of the operand. The operand may be located in memory in the range PC $\pm$ 32KB, because the index, X, is a signed 16-bit value. In this case, the address of the operand can overflow or underflow into the lower 64KB memory space as shown in Figure 4-20 and Figure 4-21. Figure 4-20. Symbolic Mode Running in Upper Memory www.ti.com Addressing Modes Figure 4-21. Overflow and Underflow for Symbolic Mode Length: Two or three words Operation: The sign-extended 16-bit index in the next word after the instruction is added to the 20 bits of the PC. This delivers a 20-bit address, which points to an address in the range 0 to FFFFh. The operand is the content of the addressed memory location. Comment: Valid for source and destination. The assembler calculates the PC index and inserts it Example: ADD.W EDE,&TONI; This instruction adds the 16-bit data contained in source word EDE and destination word TONI and places the 16-bit result into the destination word TONI. For this example, the instruction is located at address 2F034h. Source: Word EDE at address 3379Ch, pointed to by PC + 4766h, which is the 16-bit result of 3379Ch – 2F036h = 04766h. Address 2F036h is the location of the index for this example. Destination: Word TONI located at address 00778h pointed to by the absolute address 00778h Addressing Modes www.ti.com | Before: | Address<br>Space | | | After: | Address<br>Space | | | |--------------------------------------|----------------------------------|----|-----------------------------|--------------------------------------|----------------------------------|--------------------------|-------------------| | 2F03Ah<br>2F038h<br>2F036h<br>2F034h | xxxxh<br>0778h<br>4766h<br>5092h | PC | | 2F03Ah<br>2F038h<br>2F036h<br>2F034h | xxxxh<br>0778h<br>4766h<br>5092h | PC | | | 3379Eh<br>3379Ch | xxxxh<br>5432h | | 2F036h<br>+04766h<br>3379Ch | 3379Eh<br>3379Ch | xxxxh<br>5432h | | | | 0077Ah<br>00778h | xxxxh<br>2345h | | | 0077Ah<br>00778h | xxxxh<br>7777h | 5432h<br>+2345h<br>7777h | src<br>dst<br>Sum | #### 4.4.3.3 MSP430X Instruction With Symbolic Mode When using an MSP430X instruction with Symbolic mode, the operand can be located anywhere in the range of PC + 19 bits. Length: Three or four words Operation: The operand address is the sum of the 20-bit PC and the 20-bit index. The 4 MSBs of the index are contained in the extension word; the 16 LSBs are contained in the word following the instruction. Comment: Valid for source and destination. The assembler calculates the register index and inserts it. Example: ADDX.B EDE, TONI ; This instruction adds the 8-bit data contained in source byte EDE and destination byte TONI and places the result into the destination byte TONI. Source: Byte EDE located at address 3579Ch, pointed to by PC + 14766h, is the 20-bit result of 3579Ch - 21036h = 14766h. Address 21036h is the address of the index in this example. Destination: Byte TONI located at address 77778h, pointed to by PC + 56740h, is the 20-bit result of 77778h - 21038h = 56740h. Address 21038h is the address of the index in this example. www.ti.com Addressing Modes | Before: A | Address Spa | ice | | After: A | Address Spa | ce | | |------------------------------------------------|-------------------------------|-----|-----------------------------|------------------------------------------------|-------------------------------------------|---------------------------|-------------------| | 2103Ah<br>21038h<br>21036h<br>21034h<br>21032h | xxxxh 6740h 4766h 50D0h 18C5h | PC | | 2103Ah<br>21038h<br>21036h<br>21034h<br>21032h | xxxxh<br>6740h<br>4766h<br>50D0h<br>18C5h | PC | | | 7777Ah<br>77778h | xxxxh<br>xx45h | | 21038h<br>+56740h<br>77778h | 7777Ah<br>77778h | xxxxh<br>xx77h | 32h<br><u>+45h</u><br>77h | src<br>dst<br>Sum | | 3579Eh<br>3579Ch | xxxxh<br>xx32h | | 21036h<br>+14766h<br>3579Ch | 3579Eh<br>3579Ch | xxxxh<br>xx32h | | | ### 4.4.4 Absolute Mode The Absolute mode uses the contents of the word following the instruction as the address of the operand. The Absolute mode has two addressing possibilities: - Absolute mode in lower 64KB memory - MSP430X instruction with Absolute mode ### 4.4.4.1 Absolute Mode in Lower 64KB If an MSP430 instruction is used with Absolute addressing mode, the absolute address is a 16-bit value and, therefore, points to an address in the lower 64KB of the memory range. The address is calculated as an index from 0 and is stored in the word following the instruction The RAM and the peripheral registers can be accessed this way and existing MSP430 software is usable without modifications. Length: Two or three words Operation: The operand is the content of the addressed memory location. Comment: Valid for source and destination. The assembler calculates the index from 0 and inserts it. Example: ADD.W &EDE,&TONI; This instruction adds the 16-bit data contained in the absolute source and destination addresses and places the result into the destination. Source: Word at address EDE Destination: Word at address TONI Addressing Modes www.ti.com | Before: A | ddress Spac | ce | After: A | ddress Spac | ce | | |--------------------------------------|----------------------------------|----|--------------------------------------|----------------------------------|----------------------|-------------------| | 2103Ah<br>21038h<br>21036h<br>21034h | xxxxh<br>7778h<br>579Ch<br>5292h | PC | 2103Ah<br>21038h<br>21036h<br>21034h | xxxxh<br>7778h<br>579Ch<br>5292h | PC | | | 0777Ah<br>07778h | xxxxh<br>2345h | | 0777Ah<br>07778h | xxxxh<br>7777h | 5432h<br>_+2345h<br> | src<br>dst<br>Sum | | 0579Eh<br>0579Ch | xxxxh<br>5432h | | 0579Eh<br>0579Ch | xxxxh<br>5432h | | | ### 4.4.4.2 MSP430X Instruction With Absolute Mode If an MSP430X instruction is used with Absolute addressing mode, the absolute address is a 20-bit value and, therefore, points to any address in the memory range. The address value is calculated as an index from 0. The 4 MSBs of the index are contained in the extension word, and the 16 LSBs are contained in the word following the instruction. Length: Three or four words Operation: The operand is the content of the addressed memory location. Comment: Valid for source and destination. The assembler calculates the index from 0 and inserts it. Example: ADDX.A &EDE,&TONI; This instruction adds the 20-bit data contained in the absolute source and destination addresses and places the result into the destination. Source: Two words beginning with address EDE Destination: Two words beginning with address TONI www.ti.com Addressing Modes | Before: | Address<br>Space | | | Address<br>Space | | | |---------|------------------|----|--------|------------------|---------|-----| | | | | | | | | | 2103Ah | xxxxh | | 2103Ah | xxxxh | PC | | | 21038h | 7778h | | 21038h | 7778h | | | | 21036h | 579Ch | | 21036h | 579Ch | | | | 21034h | 52D2h | | 21034h | 52D2h | | | | 21032h | 1987h | PC | 21032h | 1987h | | | | | | | | | | | | | | | | | 65432h | src | | 7777Ah | 0001h | | 7777Ah | 0007h | +12345h | dst | | 77778h | 2345h | | 77778h | 7777h | 77777h | Sum | | | | | | | | | | | | | | | | | | | 1 | 1 | | 1 | l | | | | | | | | | | | 3579Eh | 0006h | | 3579Eh | 0006h | | | | 3579Ch | 5432h | | 3579Ch | 5432h | | | | | | | | | | | | | | | | | | | ## 4.4.5 Indirect Register Mode The Indirect Register mode uses the contents of the CPU register Rsrc as the source operand. The Indirect Register mode always uses a 20-bit address. Length: One, two, or three words Operation: The operand is the content the addressed memory location. The source register Rsrc is not modified. Comment: Valid only for the source operand. The substitute for the destination operand is 0(Rdst). Example: ADDX.W @R5,2100h(R6) This instruction adds the two 16-bit operands contained in the source and the destination addresses and places the result into the destination. Source: Word pointed to by R5. R5 contains address 3579Ch for this example. Destination: Word pointed to by R6 + 2100h, which results in address 45678h + 2100h = 7778h Addressing Modes www.ti.com ### 4.4.6 Indirect Autoincrement Mode The Indirect Autoincrement mode uses the contents of the CPU register Rsrc as the source operand. Rsrc is then automatically incremented by 1 for byte instructions, by 2 for word instructions, and by 4 for address-word instructions immediately after accessing the source operand. If the same register is used for source and destination, it contains the incremented address for the destination access. Indirect Autoincrement mode always uses 20-bit addresses. Length: One, two, or three words Operation: The operand is the content of the addressed memory location. Comment: Valid only for the source operand Example: ADD.B @R5+,0(R6) This instruction adds the 8-bit data contained in the source and the destination addresses and places the result into the destination. Source: Byte pointed to by R5. R5 contains address 3579Ch for this example. Destination: Byte pointed to by R6 + 0h, which results in address 0778h for this example www.ti.com Addressing Modes ### 4.4.7 Immediate Mode The Immediate mode allows accessing constants as operands by including the constant in the memory location following the instruction. The PC is used with the Indirect Autoincrement mode. The PC points to the immediate value contained in the next word. After the fetching of the immediate operand, the PC is incremented by 2 for byte, word, or address-word instructions. The Immediate mode has two addressing possibilities: - 8-bit or 16-bit constants with MSP430 instructions - 20-bit constants with MSP430X instruction ### 4.4.7.1 MSP430 Instructions With Immediate Mode If an MSP430 instruction is used with Immediate addressing mode, the constant is an 8- or 16-bit value and is stored in the word following the instruction. Length: Two or three words. One word less if a constant of the constant generator can be used for the immediate operand. Operation: The 16-bit immediate source operand is used together with the 16-bit destination operand. Comment: Valid only for the source operand Example: ADD #3456h,&TONI This instruction adds the 16-bit immediate operand 3456h to the data in the destination address TONI. Source: 16-bit immediate value 3456h Destination: Word at address TONI Addressing Modes www.ti.com | Before: | Address<br>Space | | After: | Address<br>Space | | | |--------------------------------------|----------------------------------|----|--------------------------------------|----------------------------------|--------------------------|-------------------| | 2103Ah<br>21038h<br>21036h<br>21034h | xxxxh<br>0778h<br>3456h<br>50B2h | PC | 2103Ah<br>21038h<br>21036h<br>21034h | xxxxh<br>0778h<br>3456h<br>50B2h | PC | | | 0077Ah<br>00778h | xxxxh<br>2345h | | 0077Ah<br>00778h | xxxxh<br>579Bh | 3456h<br>+2345h<br>579Bh | src<br>dst<br>Sum | ### 4.4.7.2 MSP430X Instructions With Immediate Mode If an MSP430X instruction is used with Immediate addressing mode, the constant is a 20-bit value. The 4 MSBs of the constant are stored in the extension word, and the 16 LSBs of the constant are stored in the word following the instruction. Length: Three or four words. One word less if a constant of the constant generator can be used for the immediate operand. Operation: The 20-bit immediate source operand is used together with the 20-bit destination operand. Comment: Valid only for the source operand Example: ADDX.A #23456h,&TONI ; This instruction adds the 20-bit immediate operand 23456h to the data in the destination address TONI. Source: 20-bit immediate value 23456h Destination: Two words beginning with address TONI ### 4.5 MSP430 and MSP430X Instructions MSP430 instructions are the 27 implemented instructions of the MSP430 CPU. These instructions are used throughout the 1MB memory range unless their 16-bit capability is exceeded. The MSP430X instructions are used when the addressing of the operands or the data length exceeds the 16-bit capability of the MSP430 instructions. There are three possibilities when choosing between an MSP430 and MSP430X instruction: - To use only the MSP430 instructions The only exceptions are the CALLA and the RETA instruction. This can be done if a few, simple rules are met: - Place all constants, variables, arrays, tables, and data in the lower 64KB. This allows the use of MSP430 instructions with 16-bit addressing for all data accesses. No pointers with 20-bit addresses are needed. - Place subroutine constants immediately after the subroutine code. This allows the use of the symbolic addressing mode with its 16-bit index to reach addresses within the range of PC + 32KB. - To use only MSP430X instructions The disadvantages of this method are the reduced speed due to the additional CPU cycles and the increased program space due to the necessary extension word for any double-operand instruction. - Use the best fitting instruction where needed. Section 4.5.1 lists and describes the MSP430 instructions, and Section 4.5.2 lists and describes the MSP430X instructions. ### 4.5.1 MSP430 Instructions The MSP430 instructions can be used, regardless if the program resides in the lower 64KB or beyond it. The only exceptions are the instructions CALL and RET, which are limited to the lower 64KB address range. CALLA and RETA instructions have been added to the MSP430X CPU to handle subroutines in the entire address range with no code size overhead. ### 4.5.1.1 MSP430 Double-Operand (Format I) Instructions Figure 4-22 shows the format of the MSP430 double-operand instructions. Source and destination words are appended for the Indexed, Symbolic, Absolute, and Immediate modes. Table 4-4 lists the 12 MSP430 double-operand instructions. Figure 4-22. MSP430 Double-Operand Instruction Format | Mnemonic S-Reg,<br>D-Reg | | Operation | | Status Bits <sup>(1)</sup> | | | | |--------------------------|---------|------------------------------------------------------------------|---|----------------------------|---|---|--| | | | Operation | V | N | Z | С | | | MOV(.B) | src,dst | $src \rightarrow dst$ | - | - | - | - | | | ADD(.B) | src,dst | $\operatorname{src} + \operatorname{dst} \to \operatorname{dst}$ | * | * | * | * | | | ADDC(.B) | src,dst | $src + dst + C \rightarrow dst$ | * | * | * | * | | | SUB(.B) | src,dst | $dst + .not.src + 1 \rightarrow dst$ | * | * | * | * | | | SUBC(.B) | src,dst | $dst + .not.src + C \rightarrow dst$ | * | * | * | * | | | CMP(.B) | src,dst | dst - src | * | * | * | * | | | DADD(.B) | src,dst | $src + dst + C \rightarrow dst (decimally)$ | * | * | * | * | | | BIT(.B) | src,dst | src .and. dst | 0 | * | * | Z | | | BIC(.B) | src,dst | .not.src .and. $dst \rightarrow dst$ | _ | - | _ | _ | | | BIS(.B) | src,dst | $src.or. dst \rightarrow dst$ | _ | _ | _ | _ | | | XOR(.B) | src,dst | $src.xor.dst \rightarrow dst$ | * | * | * | Z | | | AND(.B) | src,dst | $\text{src .and. dst} \rightarrow \text{dst}$ | 0 | * | * | Z | | <sup>(1) \* =</sup> Status bit is affected. ## 4.5.1.2 MSP430 Single-Operand (Format II) Instructions Figure 4-23 shows the format for MSP430 single-operand instructions, except RETI. The destination word is appended for the Indexed, Symbolic, Absolute, and Immediate modes. Table 4-5 lists the seven single-operand instructions. Figure 4-23. MSP430 Single-Operand Instructions Table 4-5. MSP430 Single-Operand Instructions | Mnemonic | S-Reg, | d, Operation | | Status Bits <sup>(1)</sup> | | | | |------------|--------|------------------------------------------------------------------------------------------------|---|----------------------------|---|---|--| | Willemonic | D-Reg | Operation | ٧ | N | Z | С | | | RRC(.B) | dst | $C \to MSB \to \!\! \dots \!\! \dots \!\! LSB \to C$ | 0 | * | * | * | | | RRA(.B) | dst | $MSB \to MSB \to LSB \to C$ | 0 | * | * | * | | | PUSH(.B) | src | SP - 2 $\rightarrow$ SP, src $\rightarrow$ SP | - | - | - | - | | | SWPB | dst | bit 15bit 8 ↔ bit 7bit 0 | - | - | - | - | | | CALL | dst | Call subroutine in lower 64KB | - | - | - | - | | | RETI | | $TOS \to SR, SP + 2 \to SP$ | * | * | * | * | | | | | $TOS \to PC, SP + 2 \to SP$ | | | | | | | SXT | dst | Register mode: bit $7 \rightarrow$ bit 8bit 19<br>Other modes: bit $7 \rightarrow$ bit 8bit 15 | 0 | * | * | Z | | <sup>(1) \* =</sup> Status bit is affected. <sup>– =</sup> Status bit is not affected. <sup>0 =</sup> Status bit is cleared. <sup>1 =</sup> Status bit is set. <sup>-</sup> = Status bit is not affected. <sup>0 =</sup> Status bit is cleared. <sup>1 =</sup> Status bit is set. ### 4.5.1.3 Jump Instructions Figure 4-24 shows the format for MSP430 and MSP430X jump instructions. The signed 10-bit word offset of the jump instruction is multiplied by two, sign-extended to a 20-bit address, and added to the 20-bit PC. This allows jumps in a range of –511 to +512 words relative to the PC in the full 20-bit address space. Jumps do not affect the status bits. Table 4-6 lists and describes the eight jump instructions. Figure 4-24. Format of Conditional Jump Instructions **Table 4-6. Conditional Jump Instructions** | Mnemonic | S-Reg,<br>D-Reg | Operation | |----------|-----------------|--------------------------------------| | JEQ, JZ | Label | Jump to label if zero bit is set | | JNE, JNZ | Label | Jump to label if zero bit is reset | | JC | Label | Jump to label if carry bit is set | | JNC | Label | Jump to label if carry bit is reset | | JN | Label | Jump to label if negative bit is set | | JGE | Label | Jump to label if (N .XOR. V) = 0 | | JL | Label | Jump to label if (N .XOR. V) = 1 | | JMP | Label | Jump to label unconditionally | ### 4.5.1.4 Emulated Instructions In addition to the MSP430 and MSP430X instructions, emulated instructions are instructions that make code easier to write and read, but do not have op-codes themselves. Instead, they are replaced automatically by the assembler with a core instruction. There is no code or performance penalty for using emulated instructions. The emulated instructions are listed in Table 4-7. Table 4-7. Emulated Instructions | Instruction | Evaluation | Emulation - | Status Bits <sup>(1)</sup> | | | | |------------------------|----------------------------|-----------------|----------------------------|---|---|---| | mstruction | Explanation | Emulation | ٧ | N | Z | С | | ADC(.B) dst | Add Carry to dst | ADDC(.B) #0,dst | * | * | * | * | | BR dst | Branch indirectly dst | MOV dst,PC | - | - | - | _ | | CLR(.B) dst | Clear dst | MOV(.B) #0,dst | - | - | _ | _ | | CLRC | Clear Carry bit | BIC #1,SR | - | - | - | 0 | | CLRN | Clear Negative bit | BIC #4,SR | - | 0 | - | _ | | CLRZ | Clear Zero bit | BIC #2,SR | - | - | 0 | _ | | DADC(.B) dst | Add Carry to dst decimally | DADD(.B) #0,dst | * | * | * | * | | DEC(.B) dst | Decrement dst by 1 | SUB(.B) #1,dst | * | * | * | * | | DECD(.B) dst | Decrement dst by 2 | SUB(.B) #2,dst | * | * | * | * | | DINT | Disable interrupt | BIC #8,SR | - | - | - | _ | | EINT | Enable interrupt | BIS #8,SR | - | - | - | _ | | <pre>INC(.B) dst</pre> | Increment dst by 1 | ADD(.B) #1,dst | * | * | * | * | | INCD(.B) dst | Increment dst by 2 | ADD(.B) #2,dst | * | * | * | * | <sup>(1) \* =</sup> Status bit is affected. <sup>-=</sup> Status bit is not affected. <sup>0 =</sup> Status bit is cleared. <sup>1 =</sup> Status bit is set. **Table 4-7. Emulated Instructions (continued)** | Instruction | Explanation | Emulation — | Status Bits <sup>(1)</sup> | | | | |-------------|----------------------------------------|------------------|----------------------------|---|---|---| | instruction | Explanation | Emulation — | ٧ | N | Z | С | | INV(.B) dst | Invert dst | XOR(.B) #-1,dst | * | * | * | * | | NOP | No operation | MOV R3,R3 | - | - | _ | - | | POP dst | Pop operand from stack | MOV @SP+,dst | - | - | _ | - | | RET | Return from subroutine | MOV @SP+,PC | - | - | _ | - | | RLA(.B) dst | Shift left dst arithmetically | ADD(.B) dst,dst | * | * | * | * | | RLC(.B) dst | Shift left dst logically through Carry | ADDC(.B) dst,dst | * | * | * | * | | SBC(.B) dst | Subtract Carry from dst | SUBC(.B) #0,dst | * | * | * | * | | SETC | Set Carry bit | BIS #1,SR | - | - | _ | 1 | | SETN | Set Negative bit | BIS #4,SR | - | 1 | _ | - | | SETZ | Set Zero bit | BIS #2,SR | - | - | 1 | - | | TST(.B) dst | Test dst (compare with 0) | CMP(.B) #0,dst | 0 | * | * | 1 | ### 4.5.1.5 MSP430 Instruction Execution The number of CPU clock cycles required for an instruction depends on the instruction format and the addressing modes used – not the instruction itself. The number of clock cycles refers to MCLK. ### 4.5.1.5.1 Instruction Cycles and Length for Interrupt, Reset, and Subroutines Table 4-8 lists the length and the CPU cycles for reset, interrupts, and subroutines. Table 4-8. Interrupt, Return, and Reset Cycles and Length | Action | Execution Time (MCLK Cycles) | Length of Instruction (Words) | |--------------------------------------------------------------------|------------------------------|-------------------------------| | Return from interrupt RETI | 5 | 1 | | Return from subroutine RET | 4 | 1 | | Interrupt request service (cycles needed before first instruction) | 6 | - | | WDT reset | 4 | - | | Reset (RST/NMI) | 4 | - | ## 4.5.1.5.2 Format II (Single-Operand) Instruction Cycles and Lengths Table 4-9 lists the length and the CPU cycles for all addressing modes of the MSP430 single-operand instructions. Table 4-9. MSP430 Format II Instruction Cycles and Length | | No. of Cycles | | | Length of | | | |-----------------|-----------------------|------|------|-------------|-------------|--| | Addressing Mode | RRA, RRC<br>SWPB, SXT | PUSH | CALL | Instruction | Example | | | Rn | 1 | 3 | 4 | 1 | SWPB R5 | | | @Rn | 3 | 3 | 4 | 1 | RRC @R9 | | | @Rn+ | 3 | 3 | 4 | 1 | SWPB @R10+ | | | #N | N/A | 3 | 4 | 2 | CALL #LABEL | | | X(Rn) | 4 | 4 | 5 | 2 | CALL 2(R7) | | | EDE | 4 | 4 | 5 | 2 | PUSH EDE | | | &EDE | 4 | 4 | 6 | 2 | SXT &EDE | | ## 4.5.1.5.3 Jump Instructions Cycles and Lengths All jump instructions require one code word and take two CPU cycles to execute, regardless of whether the jump is taken or not. ## 4.5.1.5.4 Format I (Double-Operand) Instruction Cycles and Lengths Table 4-10 lists the length and CPU cycles for all addressing modes of the MSP430 Format I instructions. Table 4-10. MSP430 Format I Instructions Cycles and Length | Add | ressing Mode | — No. of Cycles | Length of | Example | |--------|--------------|------------------|-------------|------------------| | Source | Destination | — No. of Cycles | Instruction | Example | | Rn | Rm | 1 | 1 | MOV R5,R8 | | | PC | 3 | 1 | BR R9 | | | x(Rm) | 4 <sup>(1)</sup> | 2 | ADD R5,4(R6) | | | EDE | 4 <sup>(1)</sup> | 2 | XOR R8, EDE | | | &EDE | 4 <sup>(1)</sup> | 2 | MOV R5,&EDE | | @Rn | Rm | 2 | 1 | AND @R4,R5 | | | PC | 4 | 1 | BR @R8 | | | x(Rm) | 5 <sup>(1)</sup> | 2 | XOR @R5,8(R6) | | | EDE | 5 <sup>(1)</sup> | 2 | MOV @R5,EDE | | | &EDE | 5 <sup>(1)</sup> | 2 | XOR @R5,&EDE | | @Rn+ | Rm | 2 | 1 | ADD @R5+,R6 | | | PC | 4 | 1 | BR @R9+ | | | x(Rm) | 5 <sup>(1)</sup> | 2 | XOR @R5,8(R6) | | | EDE | 5 <sup>(1)</sup> | 2 | MOV @R9+,EDE | | | &EDE | 5 <sup>(1)</sup> | 2 | MOV @R9+,&EDE | | #N | Rm | 2 | 2 | MOV #20,R9 | | | PC | 3 | 2 | BR #2AEh | | | x(Rm) | 5 <sup>(1)</sup> | 3 | MOV #0300h,0(SP) | | | EDE | 5 <sup>(1)</sup> | 3 | ADD #33,EDE | | | &EDE | 5 <sup>(1)</sup> | 3 | ADD #33,&EDE | | x(Rn) | Rm | 3 | 2 | MOV 2(R5),R7 | | | PC | 5 | 2 | BR 2(R6) | | | TONI | 6 <sup>(1)</sup> | 3 | MOV 4(R7),TONI | | | x(Rm) | 6 <sup>(1)</sup> | 3 | ADD 4(R4),6(R9) | | | &TONI | 6 <sup>(1)</sup> | 3 | MOV 2(R4),&TONI | | EDE | Rm | 3 | 2 | AND EDE,R6 | | | PC | 5 | 2 | BR EDE | | | TONI | 6 <sup>(1)</sup> | 3 | CMP EDE, TONI | | | x(Rm) | 6 <sup>(1)</sup> | 3 | MOV EDE, 0(SP) | | | &TONI | 6 <sup>(1)</sup> | 3 | MOV EDE,&TONI | | &EDE | Rm | 3 | 2 | MOV &EDE,R8 | | | PC | 5 | 2 | BR &EDE | | | TONI | 6 <sup>(1)</sup> | 3 | MOV &EDE,TONI | | | x(Rm) | 6 <sup>(1)</sup> | 3 | MOV &EDE,0(SP) | | | &TONI | 6 <sup>(1)</sup> | 3 | MOV &EDE,&TONI | <sup>(1)</sup> MOV, BIT, and CMP instructions execute in one fewer cycle. ## 4.5.2 MSP430X Extended Instructions The extended MSP430X instructions give the MSP430X CPU full access to its 20-bit address space. Most MSP430X instructions require an additional word of op-code called the extension word. Some extended instructions do not require an additional word and are noted in the instruction description. All addresses, indexes, and immediate numbers have 20-bit values when preceded by the extension word. There are two types of extension words: - Register or register mode for Format I instructions and register mode for Format II instructions - · Extension word for all other address mode combinations ### 4.5.2.1 Register Mode Extension Word The register mode extension word is shown in Figure 4-25 and described in Table 4-11. An example is shown in Figure 4-27. Figure 4-25. Extension Word for Register Modes Table 4-11. Description of the Extension Word Bits for Register Mode | Bit | Descr | iption | | | | | | | | | | | |-------|-----------------------------------------------------------------------------------------------------------------------|------------|------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--| | 15:11 | Extens | sion wor | d op-code. Op-codes 1800h to 1FFFh are extension words. | | | | | | | | | | | 10:9 | Reser | ved | | | | | | | | | | | | ZC | Zero c | Zero carry | | | | | | | | | | | | | 0 | The ex | xecuted instruction uses the status of the carry bit C. | | | | | | | | | | | | 1 | | executed instruction uses the carry bit as 0. The carry bit is defined by the result of the final operation after execution. | | | | | | | | | | | # | Repeti | ition | | | | | | | | | | | | | 0 | The n | umber of instruction repetitions is set by extension word bits 3:0. | | | | | | | | | | | | 1 The number of instruction repetitions is defined by the value of the four LSBs of Rn. See description for bits 3:0. | | | | | | | | | | | | | A/L | | | ttension. Together with the B/W bits of the following MSP430 instruction, the AL bit defines the used data instruction. | | | | | | | | | | | | A/L | B/W | Comment | | | | | | | | | | | | 0 | 0 | Reserved | | | | | | | | | | | | 0 | 1 | 20-bit address word | | | | | | | | | | | | 1 | 0 | 16-bit word | | | | | | | | | | | | 1 | 1 | 8-bit byte | | | | | | | | | | | 5:4 | Reser | ved | | | | | | | | | | | | 3:0 | Repeti | ition cou | int | | | | | | | | | | | | # = 0 | These | four bits set the repetition count n. These bits contain $n-1$ . | | | | | | | | | | | | # = 1 | These | four bits define the CPU register whose bits 3:0 set the number of repetitions. Rn.3:0 contain n - 1. | | | | | | | | | | ## 4.5.2.2 Non-Register Mode Extension Word The extension word for non-register modes is shown in Figure 4-26 and described in Table 4-12. An example is shown in Figure 4-28. Figure 4-26. Extension Word for Non-Register Modes Table 4-12. Description of Extension Word Bits for Non-Register Modes | Bit | Desc | ription | | | | | | | | | | |---------------------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--| | 15:11 | Exten | extension word op-code. Op-codes 1800h to 1FFFh are extension words. | | | | | | | | | | | Source Bits<br>19:16 | | | Bs of the 20-bit source. Depending on the source addressing mode, these four MSBs may belong to an operand, an index, or to an absolute address. | | | | | | | | | | A/L | | Data length extension. Together with the B/W bits of the following MSP430 instruction, the AL bit defines the used data length of the instruction. | | | | | | | | | | | | A/L | B/W | Comment | | | | | | | | | | | 0 | 0 | Reserved | | | | | | | | | | | 0 | 1 | 20-bit address word | | | | | | | | | | | 1 | 0 | 16-bit word | | | | | | | | | | | 1 | 1 | 8-bit byte | | | | | | | | | | 5:4 | Rese | rved | | | | | | | | | | | Destination<br>Bits 19:16 | | | Bs of the 20-bit destination. Depending on the destination addressing mode, these four MSBs may index or to an absolute address. | | | | | | | | | ### NOTE: B/W and A/L bit settings for SWPBX and SXTX | A/L | B/W | | |-----|-----|-----------------| | 0 | 0 | SWPBX.A, SXTX.A | | 0 | 1 | N/A | | 1 | 0 | SWPB.W, SXTX.W | | 1 | 1 | N/A | XORX.A R9, R8 Figure 4-27. Example for Extended Register or Register Instruction XORX.A #12345h, 45678h(R15) Figure 4-28. Example for Extended Immediate or Indexed Instruction ## 4.5.2.3 Extended Double-Operand (Format I) Instructions All 12 double-operand instructions have extended versions as listed in Table 4-13. Table 4-13. Extended Double-Operand Instructions | Mnemonic | Operands | Operation - | Status Bits <sup>(1)</sup> | | | | | |--------------|----------|-------------------------------------------|----------------------------|---|---|---|--| | Willemonic | Operanus | Operation - | ٧ | N | Z | С | | | MOVX(.B,.A) | src,dst | $src \rightarrow dst$ | _ | - | - | _ | | | ADDX(.B,.A) | src,dst | $src + dst \rightarrow dst$ | * | * | * | * | | | ADDCX(.B,.A) | src,dst | $src + dst + C \rightarrow dst$ | * | * | * | * | | | SUBX(.B,.A) | src,dst | $dst + .not.src + 1 \rightarrow dst$ | * | * | * | * | | | SUBCX(.B,.A) | src,dst | $dst + .not.src + C \rightarrow dst$ | * | * | * | * | | | CMPX(.B,.A) | src,dst | dst - src | * | * | * | * | | | DADDX(.B,.A) | src,dst | $src + dst + C \rightarrow dst (decimal)$ | * | * | * | * | | | BITX(.B,.A) | src,dst | src .and. dst | 0 | * | * | Z | | | BICX(.B,.A) | src,dst | .not.src .and. dst $\rightarrow$ dst | - | - | - | - | | | BISX(.B,.A) | src,dst | $\text{src .or. dst} \to \text{dst}$ | - | - | - | _ | | | XORX(.B,.A) | src,dst | $srcxordst \rightarrow dst$ | * | * | * | Z | | | ANDX(.B,.A) | src,dst | $src.and.dst \rightarrow dst$ | 0 | * | * | Z | | <sup>(1) \* =</sup> Status bit is affected. <sup>-</sup> = Status bit is not affected. <sup>0 =</sup> Status bit is cleared. <sup>1 =</sup> Status bit is set. The four possible addressing combinations for the extension word for Format I instructions are shown in Figure 4-29. Figure 4-29. Extended Format I Instruction Formats If the 20-bit address of a source or destination operand is located in memory, not in a CPU register, then two words are used for this operand as shown in Figure 4-30. Figure 4-30. 20-Bit Addresses in Memory ## 4.5.2.4 Extended Single-Operand (Format II) Instructions Extended MSP430X Format II instructions are listed in Table 4-14. **Table 4-14. Extended Single-Operand Instructions** | Mnemonic | Operands | Operation | | Status Bits <sup>(1)</sup> | | | | |---------------------|----------|----------------------------------------------------------------|---------|----------------------------|---|---|---| | whethoric Operation | | Operation | n | ٧ | N | Z | С | | CALLA | dst | Call indirect to subroutine (20-bit address) | | _ | - | - | _ | | POPM.A | #n,Rdst | Pop n 20-bit registers from stack | 1 to 16 | - | - | - | _ | | POPM.W | #n,Rdst | Pop n 16-bit registers from stack | 1 to 16 | - | - | _ | _ | | PUSHM.A | #n,Rsrc | Push n 20-bit registers to stack | 1 to 16 | - | - | - | - | | PUSHM.W | #n,Rsrc | Push n 16-bit registers to stack | 1 to 16 | - | - | - | - | | PUSHX(.B,.A) | src | Push 8-, 16-, or 20-bit source to stack | | - | - | - | - | | RRCM(.A) | #n,Rdst | Rotate right Rdst n bits through carry (16-, 20-bit register) | 1 to 4 | 0 | * | * | * | | RRUM(.A) | #n,Rdst | Rotate right Rdst n bits unsigned (16-, 20-bit register) | 1 to 4 | 0 | * | * | * | | RRAM(.A) | #n,Rdst | Rotate right Rdst n bits arithmetically (16-, 20-bit register) | 1 to 4 | 0 | * | * | * | | RLAM(.A) | #n,Rdst | Rotate left Rdst n bits arithmetically (16-, 20-bit register) | 1 to 4 | * | * | * | * | | RRCX(.B,.A) | dst | Rotate right dst through carry (8-, 16-, 20-bit data) | 1 | 0 | * | * | * | | RRUX(.B,.A) | Rdst | Rotate right dst unsigned (8-, 16-, 20-bit) | 1 | 0 | * | * | * | | RRAX(.B,.A) | dst | Rotate right dst arithmetically | 1 | 0 | * | * | * | | SWPBX(.A) | dst | Exchange low byte with high byte | 1 | _ | - | _ | _ | | SXTX(.A) | Rdst | Bit7 $\rightarrow$ bit8 bit19 | 1 | 0 | * | * | Z | | SXTX(.A) | dst | Bit7 → bit8 MSB | 1 | 0 | * | * | Z | <sup>&</sup>lt;sup>1)</sup> \* = Status bit is affected. The three possible addressing mode combinations for Format II instructions are shown in Figure 4-31. Figure 4-31. Extended Format II Instruction Format <sup>-</sup> = Status bit is not affected. <sup>0 =</sup> Status bit is cleared. <sup>1 =</sup> Status bit is set. ## 4.5.2.4.1 Extended Format II Instruction Format Exceptions Exceptions for the Format II instruction formats are shown in Figure 4-32 through Figure 4-35. Figure 4-32. PUSHM and POPM Instruction Format Figure 4-33. RRCM, RRAM, RRUM, and RLAM Instruction Format Figure 4-34. BRA Instruction Format Figure 4-35. CALLA Instruction Format ## 4.5.2.5 Extended Emulated Instructions The extended instructions together with the constant generator form the extended emulated instructions. Table 4-15 lists the emulated instructions. **Table 4-15. Extended Emulated Instructions** | Instruction | Explanation | Emulation | |-----------------------------|----------------------------------------|-----------------------| | ADCX(.B,.A) dst | Add carry to dst | ADDCX(.B,.A) #0,dst | | BRA dst | Branch indirect dst | MOVA dst,PC | | RETA | Return from subroutine | MOVA @SP+,PC | | CLRA Rdst | Clear Rdst | MOV #0,Rdst | | CLRX(.B,.A) dst | Clear dst | MOVX(.B,.A) #0,dst | | DADCX(.B,.A) dst | Add carry to dst decimally | DADDX(.B,.A) #0,dst | | DECX(.B,.A) dst | Decrement dst by 1 | SUBX(.B,.A) #1,dst | | DECDA Rdst | Decrement Rdst by 2 | SUBA #2,Rdst | | DECDX(.B,.A) dst | Decrement dst by 2 | SUBX(.B,.A) #2,dst | | <pre>INCX(.B,.A) dst</pre> | Increment dst by 1 | ADDX(.B,.A) #1,dst | | INCDA Rdst | Increment Rdst by 2 | ADDA #2,Rdst | | <pre>INCDX(.B,.A) dst</pre> | Increment dst by 2 | ADDX(.B,.A) #2,dst | | INVX(.B,.A) dst | Invert dst | XORX(.B,.A) #-1,dst | | RLAX(.B,.A) dst | Shift left dst arithmetically | ADDX(.B,.A) dst,dst | | RLCX(.B,.A) dst | Shift left dst logically through carry | ADDCX(.B,.A) dst,dst | | SBCX(.B,.A) dst | Subtract carry from dst | SUBCX(.B,.A) #0,dst | | TSTA Rdst | Test Rdst (compare with 0) | CMPA #0,Rdst | | TSTX(.B,.A) dst | Test dst (compare with 0) | CMPX(.B,.A) #0,dst | | POPX dst | Pop to dst | MOVX(.B, .A) @SP+,dst | ### 4.5.2.6 MSP430X Address Instructions MSP430X address instructions are instructions that support 20-bit operands but have restricted addressing modes. The addressing modes are restricted to the Register mode and the Immediate mode, except for the MOVA instruction as listed in Table 4-16. Restricting the addressing modes removes the need for the additional extension-word op-code improving code density and execution time. Address instructions should be used any time an MSP430X instruction is needed with the corresponding restricted addressing mode. Table 4-16. Address Instructions, Operate on 20-Bit Register Data | Manania | Onerendo | Operation | S | tatus | Bits | (1) | |----------|----------------|-------------------------------------------|---|-------|------|-----| | Mnemonic | Operands | Operation | ٧ | N | Z | С | | ADDA | Rsrc,Rdst | Add source to destination register | * | * | * | * | | | #imm20,Rdst | | | | | | | MOVA | Rsrc,Rdst | Move source to destination | - | - | - | - | | | #imm20,Rdst | | | | | | | | z16(Rsrc),Rdst | | | | | | | | EDE,Rdst | | | | | | | | &abs20,Rdst | | | | | | | | @Rsrc,Rdst | | | | | | | | @Rsrc+,Rdst | | | | | | | | Rsrc,z16(Rdst) | | | | | | | | Rsrc,&abs20 | | | | | | | CMPA | Rsrc,Rdst | Compare source to destination register | * | * | * | * | | | #imm20,Rdst | | | | | | | SUBA | Rsrc,Rdst | Subtract source from destination register | * | * | * | * | | | #imm20,Rdst | | | | | | <sup>&</sup>lt;sup>1)</sup> \* = Status bit is affected. <sup>-</sup> = Status bit is not affected. <sup>0 =</sup> Status bit is cleared. <sup>1 =</sup> Status bit is set. ### 4.5.2.7 MSP430X Instruction Execution The number of CPU clock cycles required for an MSP430X instruction depends on the instruction format and the addressing modes used, not the instruction itself. The number of clock cycles refers to MCLK. # 4.5.2.7.1 MSP430X Format II (Single-Operand) Instruction Cycles and Lengths Table 4-17 lists the length and the CPU cycles for all addressing modes of the MSP430X extended single-operand instructions. Table 4-17. MSP430X Format II Instruction Cycles and Length | Instruction | | Execution | Cycles, Ler | gth of Ins | truction (Wo | rds) | | |-------------|---------|-----------|-------------|------------|----------------------|------|------| | instruction | Rn | @Rn | @Rn+ | #N | X(Rn) | EDE | &EDE | | RRAM | n, 1 | - | - | - | - | _ | _ | | RRCM | n, 1 | _ | _ | _ | _ | _ | _ | | RRUM | n, 1 | _ | _ | _ | _ | _ | _ | | RLAM | n, 1 | - | _ | - | - | - | - | | PUSHM | 2+n, 1 | - | _ | - | - | - | - | | PUSHM.A | 2+2n, 1 | - | _ | - | - | - | - | | POPM | 2+n, 1 | - | _ | - | - | - | - | | POPM.A | 2+2n, 1 | - | _ | - | - | - | - | | CALLA | 5, 1 | 6, 1 | 6, 1 | 5, 2 | 5 <sup>(1)</sup> , 2 | 7, 2 | 7, 2 | | RRAX(.B) | 1+n, 2 | 4, 2 | 4, 2 | - | 5, 3 | 5, 3 | 5, 3 | | RRAX.A | 1+n, 2 | 6, 2 | 6, 2 | - | 7, 3 | 7, 3 | 7, 3 | | RRCX(.B) | 1+n, 2 | 4, 2 | 4, 2 | - | 5, 3 | 5, 3 | 5, 3 | | RRCX.A | 1+n, 2 | 6, 2 | 6, 2 | - | 7, 3 | 7, 3 | 7, 3 | | PUSHX(.B) | 4, 2 | 4, 2 | 4, 2 | 4, 3 | 5 <sup>(1)</sup> , 3 | 5, 3 | 5, 3 | | PUSHX.A | 5, 2 | 6, 2 | 6, 2 | 5, 3 | 7 <sup>(1)</sup> , 3 | 7, 3 | 7, 3 | | POPX(.B) | 3, 2 | - | - | _ | 5, 3 | 5, 3 | 5, 3 | | POPX.A | 4, 2 | - | _ | - | 7, 3 | 7, 3 | 7, 3 | <sup>(1)</sup> Add one cycle when Rn = SP ## 4.5.2.7.2 MSP430X Format I (Double-Operand) Instruction Cycles and Lengths Table 4-18 lists the length and CPU cycles for all addressing modes of the MSP430X extended Format I instructions. Table 4-18. MSP430X Format I Instruction Cycles and Length | A | ddressing Mode | No. of | Cycles | Length of<br>Instruction | Examples | |--------|-------------------|------------------|-------------------|--------------------------|-------------------| | Source | Destination | .B/.W | .A | .B/.W/.A | -<br>- | | Rn | Rm <sup>(1)</sup> | 2 | 2 | 2 | BITX.B R5,R8 | | | PC | 4 | 4 | 2 | ADDX R9,PC | | | x(Rm) | 5 <sup>(2)</sup> | 7 <sup>(3)</sup> | 3 | ANDX.A R5,4(R6) | | | EDE | 5 <sup>(2)</sup> | 7 <sup>(3)</sup> | 3 | XORX R8,EDE | | | &EDE | 5 <sup>(2)</sup> | 7 <sup>(3)</sup> | 3 | BITX.W R5,&EDE | | @Rn | Rm | 3 | 4 | 2 | BITX @R5,R8 | | | PC | 5 | 6 | 2 | ADDX @R9,PC | | | x(Rm) | 6 <sup>(2)</sup> | 9 <sup>(3)</sup> | 3 | ANDX.A @R5,4(R6) | | | EDE | 6 <sup>(2)</sup> | 9(3) | 3 | XORX @R8,EDE | | | &EDE | 6 <sup>(2)</sup> | 9(3) | 3 | BITX.B @R5,&EDE | | @Rn+ | Rm | 3 | 4 | 2 | BITX @R5+,R8 | | | PC | 5 | 6 | 2 | ADDX.A @R9+,PC | | | x(Rm) | 6 <sup>(2)</sup> | 9 <sup>(3)</sup> | 3 | ANDX @R5+,4(R6) | | | EDE | 6 <sup>(2)</sup> | 9 <sup>(3)</sup> | 3 | XORX.B @R8+,EDE | | | &EDE | 6 <sup>(2)</sup> | 9 <sup>(3)</sup> | 3 | BITX @R5+,&EDE | | #N | Rm | 3 | 3 | 3 | BITX #20,R8 | | | PC <sup>(4)</sup> | 4 | 4 | 3 | ADDX.A #FE000h,PC | | | x(Rm) | 6 <sup>(2)</sup> | 8 <sup>(3)</sup> | 4 | ANDX #1234,4(R6) | | | EDE | 6 <sup>(2)</sup> | 8 <sup>(3)</sup> | 4 | XORX #A5A5h,EDE | | | &EDE | 6 <sup>(2)</sup> | 8 <sup>(3)</sup> | 4 | BITX.B #12,&EDE | | x(Rn) | Rm | 4 | 5 | 3 | BITX 2(R5),R8 | | | PC <sup>(4)</sup> | 6 | 7 | 3 | SUBX.A 2(R6),PC | | | TONI | 7 <sup>(2)</sup> | 10 <sup>(3)</sup> | 4 | ANDX 4(R7),4(R6) | | | x(Rm) | 7 <sup>(2)</sup> | 10 <sup>(3)</sup> | 4 | XORX.B 2(R6),EDE | | | &TONI | 7 <sup>(2)</sup> | 10 <sup>(3)</sup> | 4 | BITX 8(SP),&EDE | | EDE | Rm | 4 | 5 | 3 | BITX.B EDE,R8 | | | PC <sup>(4)</sup> | 6 | 7 | 3 | ADDX.A EDE,PC | | | TONI | 7 <sup>(2)</sup> | 10 <sup>(3)</sup> | 4 | ANDX EDE,4(R6) | | | x(Rm) | 7 <sup>(2)</sup> | 10 <sup>(3)</sup> | 4 | ANDX EDE, TONI | | | &TONI | 7 <sup>(2)</sup> | 10 <sup>(3)</sup> | 4 | BITX EDE,&TONI | | &EDE | Rm | 4 | 5 | 3 | BITX &EDE,R8 | | | PC <sup>(4)</sup> | 6 | 7 | 3 | ADDX.A &EDE,PC | | | TONI | 7 <sup>(2)</sup> | 10 <sup>(3)</sup> | 4 | ANDX.B &EDE,4(R6) | | | x(Rm) | 7 <sup>(2)</sup> | 10 <sup>(3)</sup> | 4 | XORX &EDE, TONI | | | &TONI | 7 <sup>(2)</sup> | 10 <sup>(3)</sup> | 4 | BITX &EDE,&TONI | <sup>(1)</sup> Repeat instructions require n + 1 cycles, where n is the number of times the instruction is executed. <sup>(2)</sup> Reduce the cycle count by one for MOV, BIT, and CMP instructions. <sup>(3)</sup> Reduce the cycle count by two for MOV, BIT, and CMP instructions. <sup>(4)</sup> Reduce the cycle count by one for MOV, ADD, and SUB instructions. ## 4.5.2.7.3 MSP430X Address Instruction Cycles and Lengths Table 4-19 lists the length and the CPU cycles for all addressing modes of the MSP430X address instructions. Table 4-19. Address Instruction Cycles and Length | Addre | essing Mode | Execution (MCLK | on Time<br>Cycles) | | Instruction<br>ords) | | | | |--------|-------------|-----------------|----------------------|------|----------------------|-----------------|--|--| | Source | Destination | MOVA<br>BRA | CMPA<br>ADDA<br>SUBA | MOVA | CMPA<br>ADDA<br>SUBA | Example | | | | Rn | Rn | 1 | 1 | 1 | 1 | CMPA R5,R8 | | | | | PC | 3 | 3 | 1 | 1 | SUBA R9,PC | | | | | x(Rm) | 4 | _ | 2 | _ | MOVA R5,4(R6) | | | | | EDE | 4 | _ | 2 | - | MOVA R8,EDE | | | | | &EDE | 4 | _ | 2 | - | MOVA R5,&EDE | | | | @Rn | Rm | 3 | _ | 1 | - | MOVA @R5,R8 | | | | | PC | 5 | _ | 1 | - | MOVA @R9,PC | | | | @Rn+ | Rm | 3 | _ | 1 | - | MOVA @R5+,R8 | | | | | PC | 5 | _ | 1 | - | MOVA @R9+,PC | | | | #N | Rm | 2 | 3 | 2 | 2 | CMPA #20,R8 | | | | | PC | 3 | 3 | 2 | 2 | SUBA #FE000h,PC | | | | x(Rn) | Rm | 4 | - | 2 | - | MOVA 2(R5),R8 | | | | | PC | 6 | - | 2 | - | MOVA 2(R6),PC | | | | EDE | Rm | 4 | _ | 2 | - | MOVA EDE,R8 | | | | | PC | 6 | _ | 2 | - | MOVA EDE,PC | | | | &EDE | Rm | 4 | _ | 2 | - | MOVA &EDE,R8 | | | | | PC | 6 | _ | 2 | _ | MOVA &EDE,PC | | | # 4.6 Instruction Set Description Table 4-20 shows all available instructions: # Table 4-20. Instruction Map of MSP430X | | 000 | 040 | 080 | 0C0 | 100 | 140 | 180 | 1C0 | 200 | 240 | 280 | 2C0 | 300 | 340 | 380 | 3C0 | |------|--------------------------------------------------------|----------------------------------|----------|-----|--------|-----------|--------|--------|----------|------------|--------|-----|------|-----------|-----|-----| | 0xxx | | | | МО | VA, CN | PA, AD | DA, SU | BA, RR | CM, RR | AM, RL | AM, RR | UM | | | | | | 10xx | RRC | RRC.<br>B | SWP<br>B | | RRA | RRA.<br>B | SXT | | PUS<br>H | PUS<br>H.B | CALL | | RETI | CALL<br>A | | | | 14xx | | PUSHM.A, POPM.A, PUSHM.W, POPM.W | | | | | | | | | | | | | | | | 18xx | Extension word for Format I and Format II instructions | | | | | | | | | | | | | | | | | 1Cxx | | | | | | | | | | | | | | | | | | 20xx | JNE, JNZ | | | | | | | | | | | | | | | | | 24xx | | JEQ, JZ | | | | | | | | | | | | | | | | 28xx | | JNC | | | | | | | | | | | | | | | | 2Cxx | JC | | | | | | | | | | | | | | | | | 30xx | JN | | | | | | | | | | | | | | | | | 34xx | | | | | | | | JC | 3E | | | | | | | | | 38xx | | | | | | | | J | L | | | | | | | | | 3Схх | | | | | | | | JN | ΛP | | | | | | | | | 4xxx | | | | | | | | MOV, | MOV.B | | | | | | | | | 5xxx | | | | | | | | | ADD.B | | | | | | | | | 6xxx | | | | | | | | | ADDC.E | | | | | | | | | 7xxx | | | | | | | , | SUBC, | SUBC.E | 3 | | | | | | | | 8xxx | | | | | | | | SUB, | SUB.B | | | | | | | | | 9xxx | | | | | | | | CMP, | CMP.B | | | | | | | | | Axxx | | | | | | | | DADD, | DADD.E | 3 | | | | | | | | Bxxx | | | | | | | | BIT, | BIT.B | | | | | | | | | Cxxx | | | | | | | | BIC, | BIC.B | | | | | | | | | Dxxx | | | | | | | | | BIS.B | | | | | | | | | Exxx | | | | | | | | XOR, | XOR.B | | | | | | | | | Fxxx | | | | | | | | AND, | AND.B | | | | | | | | # 4.6.1 Extended Instruction Binary Descriptions Detailed MSP430X instruction binary descriptions are shown in the following tables. | Instruction | Instruction<br>Group | | | | src or data.19:16 | | nstru<br>Iden | ıctio<br>tifier | | dst | | |-------------|----------------------|-----------|---|----|-------------------|-----------------|---------------|-----------------|---|------------|-------------------| | | 15 | | | 12 | 11 8 | 7 | | | 4 | 3 0 | | | MOVA | 0 | 0 | 0 | 0 | src | 0 | 0 | 0 | 0 | dst | MOVA @Rsrc,Rdst | | | 0 | 0 | 0 | 0 | src | 0 | 0 | 0 | 1 | dst | MOVA @Rsrc+,Rdst | | | 0 | 0 | 0 | 0 | &abs.19:16 | 0 | 0 | 1 | 0 | dst | MOVA &abs20,Rdst | | | | | | | &abs | .15:0 | ) | | | | | | | 0 | 0 | 0 | 0 | src | 0 | 0 | 1 | 1 | dst | MOVA x(Rsrc),Rdst | | | | | | | x.1 | 5:0 | | | | | ±15-bit index x | | | 0 | 0 | 0 | 0 | src | 0 | 1 | 1 | 0 | &abs.19:16 | MOVA Rsrc,&abs20 | | | | &abs.15:0 | | | | | | | | | | | | 0 | 0 | 0 | 0 | src | 0 | 1 | 1 | 1 | dst | MOVA Rsrc,X(Rdst) | | | | | | | x.1 | ±15-bit index x | | | | | | | | 0 | 0 | 0 | 0 | imm.19:16 | 1 | 0 | 0 | 0 | dst | MOVA #imm20,Rdst | | | | | | | imm.15:0 | | | | | | | | CMPA | 0 | 0 | 0 | 0 | imm.19:16 | 1 | 0 | 0 | 1 | dst | CMPA #imm20,Rdst | | | | | | | imm | .15:0 | | | | | | | ADDA | 0 | 0 | 0 | 0 | imm.19:16 | 1 | 0 | 1 | 0 | dst | ADDA #imm20,Rdst | | | | | | | imm | .15:0 | | | | | | | SUBA | 0 | 0 | 0 | 0 | imm.19:16 | 1 | 0 | 1 | 1 | dst | SUBA #imm20,Rdst | | | imm.15:0 | | | | | | | | | | | | MOVA | 0 | 0 | 0 | 0 | src | 1 | 1 | 0 | 0 | dst | MOVA Rsrc,Rdst | | CMPA | 0 | 0 | 0 | 0 | src | 1 | 1 | 0 | 1 | dst | CMPA Rsrc,Rdst | | ADDA | 0 | 0 | 0 | 0 | src | 1 | 1 | 1 | 0 | dst | ADDA Rsrc,Rdst | | SUBA | 0 | 0 | 0 | 0 | src | 1 | 1 | 1 | 1 | dst | SUBA Rsrc,Rdst | | Instruction | ı | nstru<br>Gre | uction<br>oup | n | Bit Loc. | Inst | . ID | ı | nstru<br>Iden | ıctio<br>tifier | | dst | | | |-------------|----|--------------|---------------|----|----------|------|------|---|---------------|-----------------|---|-----|---|----------------| | | 15 | | | 12 | 11 10 | 9 | 8 | 7 | | | 4 | 3 | 0 | | | RRCM.A | 0 | 0 | 0 | 0 | n – 1 | 0 | 0 | 0 | 1 | 0 | 0 | dst | | RRCM.A #n,Rdst | | RRAM.A | 0 | 0 | 0 | 0 | n – 1 | 0 | 1 | 0 | 1 | 0 | 0 | dst | | RRAM.A #n,Rdst | | RLAM.A | 0 | 0 | 0 | 0 | n – 1 | 1 | 0 | 0 | 1 | 0 | 0 | dst | | RLAM.A #n,Rdst | | RRUM.A | 0 | 0 | 0 | 0 | n – 1 | 1 | 1 | 0 | 1 | 0 | 0 | dst | | RRUM.A #n,Rdst | | RRCM.W | 0 | 0 | 0 | 0 | n – 1 | 0 | 0 | 0 | 1 | 0 | 1 | dst | | RRCM.W #n,Rdst | | RRAM.W | 0 | 0 | 0 | 0 | n – 1 | 0 | 1 | 0 | 1 | 0 | 1 | dst | | RRAM.W #n,Rdst | | RLAM.W | 0 | 0 | 0 | 0 | n – 1 | 1 | 0 | 0 | 1 | 0 | 1 | dst | | RLAM.W #n,Rdst | | RRUM.W | 0 | 0 | 0 | 0 | n – 1 | 1 | 1 | 0 | 1 | 0 | 1 | dst | | RRUM.W #n,Rdst | ### www.ti.com | | | | | | | | | | | | | | | | | | · | |-------------|----|---|---|-------|--------|--------|---|------|-------|-------|---|-------------|-------------|-----------|----|----------------|-----------------| | Instruction | | | | Instr | n Idei | ntifie | • | | | | | | d | st | | | | | instruction | 15 | | | 12 | 11 | | | 8 | 7 | 6 | 5 | 4 | 3 | | | 0 | | | RETI | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | CALLA | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 0 | 1 | 0 | 0 | | d | st | | CALLA Rdst | | | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 0 | 1 | 0 | 1 | dst | | | CALLA x(Rdst) | | | | | • | | | | | | x.1 | 5:0 | • | | | | | | | | | | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 0 | 1 | 1 | 0 | | dst | | | CALLA @Rdst | | | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 0 | 1 | 1 | 1 | | dst | | | CALLA @Rdst+ | | | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | &abs.19:16 | | 6 | CALLA &abs20 | | | | | • | | | | | | &abs | .15:0 | | | | | | | | = | | | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 1 | | x.19:16 | | | CALLA EDE | | | | | | | • | | | x.1 | 5:0 | | | | | | | | CALLA x(PC) | | | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 1 | 1 | | imm.19:16 | | i | CALLA #imm20 | | | | • | | | | | | imm | .15:0 | | | | | | | = | | | Reserved | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 1 | 0 | х | Х | Х | Х | | | Reserved | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 1 | 1 | Х | Х | Х | Х | Х | Х | | | PUSHM.A | 0 | 0 | 0 | 1 | 0 | 1 | 0 | 0 | | n – 1 | | | | d | st | | PUSHM.A #n,Rdst | | PUSHM.W | 0 | 0 | 0 | 1 | 0 | 1 | 0 | 1 | n – 1 | | | | dst | | | | PUSHM.W #n,Rdst | | POPM.A | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 0 | n – 1 | | | | dst - n + 1 | | | | POPM.A #n,Rdst | | POPM.W | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 1 | n – 1 | | | dst - n + 1 | | | | POPM.W #n,Rdst | | ## 4.6.2 MSP430 Instructions The MSP430 instructions are listed and described on the following pages. ### 4.6.2.1 ADC \* ADC[.W] Add carry to destination \* ADC.B Add carry to destination Syntax ADC dst Or ADC.W dst ADC.B dst Operation $dst + C \rightarrow dst$ Emulation ADDC #0, dst ADDC.B #0, dst **Description** The carry bit (C) is added to the destination operand. The previous contents of the destination are lost. **Status Bits** N: Set if result is negative, reset if positive Z: Set if result is zero, reset otherwise C: Set if dst was incremented from 0FFFh to 0000, reset otherwise Set if dst was incremented from 0FFh to 00, reset otherwise V: Set if an arithmetic overflow occurs, otherwise reset **Mode Bits** OSCOFF, CPUOFF, and GIE are not affected. **Example** The 16-bit counter pointed to by R13 is added to a 32-bit counter pointed to by R12. ADD @R13,0(R12) ; Add LSDs ADC 2(R12) ; Add carry to MSD **Example** The 8-bit counter pointed to by R13 is added to a 16-bit counter pointed to by R12. ADD.B @R13,0(R12) ; Add LSDs ADC.B 1(R12) ; Add carry to MSD ### 4.6.2.2 ADD ADD[.W] Add source word to destination word ADD.B Add source byte to destination byte Syntax ADD src,dst Or ADD.W src,dst ADD.B src,dst **Operation** $\operatorname{src} + \operatorname{dst} \to \operatorname{dst}$ **Description** The source operand is added to the destination operand. The previous content of the destination is lost. **Status Bits** N: Set if result is negative (MSB = 1), reset if positive (MSB = 0) Z: Set if result is zero, reset otherwise C: Set if there is a carry from the MSB of the result, reset otherwise V: Set if the result of two positive operands is negative, or if the result of two negative numbers is positive, reset otherwise **Mode Bits** OSCOFF, CPUOFF, and GIE are not affected. **Example** Ten is added to the 16-bit counter CNTR located in lower 64 K. ADD.W #10,&CNTR ; Add 10 to 16-bit counter **Example** A table word pointed to by R5 (20-bit address in R5) is added to R6. The jump to label TONI is performed on a carry. ADD.W @R5,R6 ; Add table word to R6.R6.19:16 = 0 JC TONI ; Jump if carry ... ; No carry **Example** A table byte pointed to by R5 (20-bit address) is added to R6. The jump to label TONI is performed if no carry occurs. The table pointer is auto-incremented by 1. R6.19:8 = 0 ADD.B @R5+,R6 ; Add byte to R6. R5 + 1. R6: 000xxh JNC TONI ; Jump if no carry ... ; Carry occurred ### 4.6.2.3 ADDC ADDC.W Add source word and carry to destination word ADDC.B Add source byte and carry to destination byte Syntax ADDC src,dst Or ADDC.W src,dst ADDC.B src,dst **Operation** $\operatorname{src} + \operatorname{dst} + \operatorname{C} \to \operatorname{dst}$ **Description** The source operand and the carry bit C are added to the destination operand. The previous content of the destination is lost. **Status Bits** N: Set if result is negative (MSB = 1), reset if positive (MSB = 0) Z: Set if result is zero, reset otherwise C: Set if there is a carry from the MSB of the result, reset otherwise V: Set if the result of two positive operands is negative, or if the result of two negative numbers is positive, reset otherwise **Mode Bits** OSCOFF, CPUOFF, and GIE are not affected. **Example** Constant value 15 and the carry of the previous instruction are added to the 16-bit counter CNTR located in lower 64 K. ADDC.W #15,&CNTR ; Add 15 + C to 16-bit CNTR **Example** A table word pointed to by R5 (20-bit address) and the carry C are added to R6. The jump to label TONI is performed on a carry. R6.19:16 = 0 ADDC.W @R5,R6 ; Add table word + C to R6 JC TONI ; Jump if carry ... ; No carry **Example** A table byte pointed to by R5 (20-bit address) and the carry bit C are added to R6. The jump to label TONI is performed if no carry occurs. The table pointer is auto-incremented by 1. R6.19:8 = 0 ADDC.B @R5+,R6 ; Add table byte + C to R6. R5 + 1 JNC TONI ; Jump if no carry ... ; Carry occurred ### 4.6.2.4 AND **AND[.W]** Logical AND of source word with destination word **AND.B** Logical AND of source byte with destination byte Syntax AND src,dst Or AND.W src,dst AND.B src,dst **Operation** src .and. $dst \rightarrow dst$ **Description** The source operand and the destination operand are logically ANDed. The result is placed into the destination. The source operand is not affected. **Status Bits** N: Set if result is negative (MSB = 1), reset if positive (MSB = 0) Z: Set if result is zero, reset otherwise C: Set if the result is not zero, reset otherwise. C = (.not. Z) V: Reset Mode Bits OSCOFF, CPUOFF, and GIE are not affected. **Example** The bits set in R5 (16-bit data) are used as a mask (AA55h) for the word TOM located in the lower 64 K. If the result is zero, a branch is taken to label TONI. R5.19:16 = 0 MOV #AA55h,R5 ; Load 16-bit mask to R5 AND R5,&TOM ; TOM .and. R5 -> TOM JZ TONI ; Jump if result 0 ... ; Result > 0 or shorter: AND #AA55h,&TOM ; TOM .and. AA55h -> TOM JZ TONI ; Jump if result 0 **Example** A table byte pointed to by R5 (20-bit address) is logically ANDed with R6. R5 is incremented by 1 after the fetching of the byte. R6.19:8 = 0 AND.B @R5+,R6 ; AND table byte with R6. R5 + 1 ### 4.6.2.5 BIC BIC[.W] Clear bits set in source word in destination word Clear bits set in source byte in destination byte Syntax BIC src,dst Or BIC.W src,dst BIC.B src,dst **Operation** (.not. src) .and. $dst \rightarrow dst$ **Description** The inverted source operand and the destination operand are logically ANDed. The result is placed into the destination. The source operand is not affected. Status Bits N: Not affected Z: Not affectedC: Not affectedV: Not affected Mode Bits OSCOFF, CPUOFF, and GIE are not affected. **Example** The bits 15:14 of R5 (16-bit data) are cleared. R5.19:16 = 0 BIC #0C000h,R5 ; Clear R5.19:14 bits **Example** A table word pointed to by R5 (20-bit address) is used to clear bits in R7. R7.19:16 = 0 BIC.W @R5,R7 ; Clear bits in R7 set in @R5 **Example** A table byte pointed to by R5 (20-bit address) is used to clear bits in Port1. BIC.B @R5,&P1OUT ; Clear I/O port P1 bits set in @R5 ### 4.6.2.6 BIS BIS[.W] Set bits set in source word in destination word BIS.B Set bits set in source byte in destination byte Syntax BIS src,dst Or BIS.W src,dst BIS.B src,dst **Description** The source operand and the destination operand are logically ORed. The result is placed into the destination. The source operand is not affected. Status Bits N: Not affected Z: Not affectedC: Not affectedV: Not affected **Mode Bits** OSCOFF, CPUOFF, and GIE are not affected. **Example** Bits 15 and 13 of R5 (16-bit data) are set to one. R5.19:16 = 0 BIS #A000h,R5 ; Set R5 bits **Example** A table word pointed to by R5 (20-bit address) is used to set bits in R7. R7.19:16 = 0 BIS.W @R5,R7 ; Set bits in R7 **Example** A table byte pointed to by R5 (20-bit address) is used to set bits in Port1. R5 is incremented by 1 afterwards. BIS.B @R5+,&P1OUT ; Set I/O port P1 bits. R5 + 1 ### 4.6.2.7 BIT BIT.B Test bits set in source word in destination word Test bits set in source byte in destination byte Syntax BIT src,dst Or BIT.W src,dst BIT.B src,dst **Operation** src .and. dst **Description** The source operand and the destination operand are logically ANDed. The result affects only the status bits in SR. Register mode: the register bits Rdst.19:16 (.W) resp. Rdst. 19:8 (.B) are not cleared! **Status Bits** N: Set if result is negative (MSB = 1), reset if positive (MSB = 0) Z: Set if result is zero, reset otherwise C: Set if the result is not zero, reset otherwise. C = (.not. Z) V: Reset **Mode Bits** OSCOFF, CPUOFF, and GIE are not affected. **Example** Test if one (or both) of bits 15 and 14 of R5 (16-bit data) is set. Jump to label TONI if this is the case. R5.19:16 are not affected. BIT #C000h,R5 ; Test R5.15:14 bits JNZ TONI ; At least one bit is set in R5 ... ; Both bits are reset **Example** A table word pointed to by R5 (20-bit address) is used to test bits in R7. Jump to label TONI if at least one bit is set. R7.19:16 are not affected. BIT.W @R5,R7 ; Test bits in R7 JC TONI ; At least one bit is set ... ; Both are reset **Example** A table byte pointed to by R5 (20-bit address) is used to test bits in output Port1. Jump to label TONI if no bit is set. The next table byte is addressed. BIT.B @R5+,&P1OUT ; Test I/O port P1 bits. R5 + 1 JNC TONI ; No corresponding bit is set ... ; At least one bit is set ### 4.6.2.8 BR, BRANCH \* BR, Branch to destination in lower 64K address space **BRANCH** **Description** An unconditional branch is taken to an address anywhere in the lower 64K address space. All source addressing modes can be used. The branch instruction is a word instruction. Status Bits Status bits are not affected. **Example** Examples for all addressing modes are given. BR #EXEC ; Branch to label EXEC or direct branch (for example #0A4h); Core instruction MOV @PC+,PC BR EXEC ; Branch to the address contained in EXEC; Core instruction MOV X(PC),PC; Indirect address BR &EXEC ; Branch to the address contained in absolute; address EXEC ; Core instruction MOV X(0),PC ; Indirect address BR R5 ; Branch to the address contained in R5 ; Core instruction MOV R5,PC ; Indirect R5 BR @R5 ; Branch to the address contained in the word ; pointed to by R5. ; Core instruction MOV @R5,PC ; Indirect, indirect R5 BR @R5+ ; Branch to the address contained in the word pointed ; to by R5 and increment pointer in R5 afterwards. ; The next time-S/W flow uses R5 pointer-it can ; alter program execution due to access to ; next address in a table pointed to by R5 ; Core instruction MOV @R5,PC ; Indirect, indirect R5 with autoincrement BR X(R5); Branch to the address contained in the address ; pointed to by R5 + X (for example table with address ; starting at X). X can be an address or a label ; Core instruction MOV X(R5),PC ; Indirect, indirect R5 + X ### 4.6.2.9 CALL CALL Call a subroutine in lower 64 K Syntax CALL dst **Operation** dst → tmp 16-bit dst is evaluated and stored $SP - 2 \rightarrow SP$ $PC \rightarrow @SP$ updated PC with return address to TOS tmp → PC saved 16-bit dst to PC **Description** A subroutine call is made from an address in the lower 64 K to a subroutine address in the lower 64 K. All seven source addressing modes can be used. The call instruction is a word instruction. The return is made with the RET instruction. **Status Bits** Status bits are not affected. PC.19:16 cleared (address in lower 64 K) **Mode Bits** OSCOFF, CPUOFF, and GIE are not affected. **Examples** Examples for all addressing modes are given. Immediate Mode: Call a subroutine at label EXEC (lower 64 K) or call directly to address. CALL #EXEC ; Start address EXEC CALL #0AA04h ; Start address 0AA04h Symbolic Mode: Call a subroutine at the 16-bit address contained in address EXEC. EXEC is located at the address (PC + X) where X is within PC $\pm$ 32 K. CALL EXEC ; Start address at @EXEC. z16(PC) Absolute Mode: Call a subroutine at the 16-bit address contained in absolute address EXEC in the lower 64 K. CALL &EXEC ; Start address at @EXEC Register mode: Call a subroutine at the 16-bit address contained in register R5.15:0. CALL R5 ; Start address at R5 Indirect Mode: Call a subroutine at the 16-bit address contained in the word pointed to by register R5 (20-bit address). CALL @R5 ; Start address at @R5 ## 4.6.2.10 CLR \* CLR[.W] Clear destination \* CLR.B Clear destination Syntax CLR dst Or CLR.W dst CLR.B dst MOV.B #0,dst **Description** The destination operand is cleared. Status Bits Status bits are not affected. Example RAM word TONI is cleared. CLR TONI ; 0 -> TONI **Example** Register R5 is cleared. CLR R5 **Example** RAM byte TONI is cleared. CLR.B TONI ; 0 -> TONI # 4.6.2.11 CLRC \* CLRC Clear carry bit **Description** The carry bit (C) is cleared. The clear carry instruction is a word instruction. Status Bits N: Not affected Z: Not affectedC: ClearedV: Not affected **Mode Bits** OSCOFF, CPUOFF, and GIE are not affected. **Example** The 16-bit decimal counter pointed to by R13 is added to a 32-bit counter pointed to by R12. CLRC ; C=0: defines start DADD @R13,0(R12) ; add 16-bit counter to low word of 32-bit counter DADC 2(R12) ; add carry to high word of 32-bit counter 181 #### 4.6.2.12 CLRN \* CLRN Clear negative bit or (.NOT.src .AND. $dst \rightarrow dst$ ) Emulation BIC #4,SR **Description** The constant 04h is inverted (0FFFBh) and is logically ANDed with the destination operand. The result is placed into the destination. The clear negative bit instruction is a word instruction. Status Bits N: Reset to 0 Z: Not affectedC: Not affectedV: Not affected Mode Bits OSCOFF, CPUOFF, and GIE are not affected. **Example** The negative bit in the SR is cleared. This avoids special treatment with negative numbers of the subroutine called. CLRN CALL SUBR . . . . . . SUBR JN SUBRET ; If input is negative: do nothing and return SUBRET RET #### 4.6.2.13 CLRZ \* CLRZ Clear zero bit or (.NOT.src .AND. $dst \rightarrow dst$ ) Emulation BIC #2,SR **Description** The constant 02h is inverted (0FFFDh) and logically ANDed with the destination operand. The result is placed into the destination. The clear zero bit instruction is a word instruction. Status Bits N: Not affected Z: Reset to 0C: Not affectedV: Not affected Mode Bits OSCOFF, CPUOFF, and GIE are not affected. **Example** The zero bit in the SR is cleared. CLRZ Indirect, Auto-Increment mode: Call a subroutine at the 16-bit address contained in the word pointed to by register R5 (20-bit address) and increment the 16-bit address in R5 afterwards by 2. The next time the software uses R5 as a pointer, it can alter the program execution due to access to the next word address in the table pointed to by R5. CALL @R5+ ; Start address at @R5. R5 + 2 Indexed mode: Call a subroutine at the 16-bit address contained in the 20-bit address pointed to by register (R5 + X); for example, a table with addresses starting at X. The address is within the lower 64KB. X is within ±32KB. CALL X(R5) ; Start address at @(R5+X). z16(R5) #### 4.6.2.14 CMP **CMP[.W]** Compare source word and destination word CMP.B Compare source byte and destination byte Syntax CMP src,dst Of CMP.W src,dst CMP.B src,dst **Operation** (.not.src) + 1 + dst or dst - src Emulation BIC #2,SR **Description** The source operand is subtracted from the destination operand. This is made by adding the 1s complement of the source + 1 to the destination. The result affects only the status bits in SR Register mode: the register bits Rdst.19:16 (.W) resp. Rdst. 19:8 (.B) are not cleared. **Status Bits** N: Set if result is negative (src > dst), reset if positive (src = dst) Z: Set if result is zero (src = dst), reset otherwise (src $\neq$ dst) C: Set if there is a carry from the MSB, reset otherwise V: Set if the subtraction of a negative source operand from a positive destination operand delivers a negative result, or if the subtraction of a positive source operand from a negative destination operand delivers a positive result, reset otherwise (no overflow). **Mode Bits** OSCOFF, CPUOFF, and GIE are not affected. Example Compare word EDE with a 16-bit constant 1800h. Jump to label TONI if EDE equals the constant. The address of EDE is within PC + 32 K. CMP #01800h,EDE ; Compare word EDE with 1800h JEQ TONI ; EDE contains 1800h ... ; Not equal Example A table word pointed to by (R5 + 10) is compared with R7. Jump to label TONI if R7 contains a lower, signed 16-bit number. R7.19:16 is not cleared. The address of the source operand is a 20-bit address in full memory range. ``` CMP.W 10(R5),R7 ; Compare two signed numbers JL ; R7 < 10(R5) ... ; R7 >= 10(R5) ``` #### **Example** A table byte pointed to by R5 (20-bit address) is compared to the value in output Port1. Jump to label TONI if values are equal. The next table byte is addressed. #### 4.6.2.15 DADC \* DADC[.W] Add carry decimally to destination \* DADC.B Add carry decimally to destination Syntax DADC dst Or DADC.W dst DADC.B dst **Operation** $dst + C \rightarrow dst (decimally)$ Emulation DADD #0,dst DADD.B #0,dst **Description** The carry bit (C) is added decimally to the destination. Status Bits N: Set if MSB is 1 Z: Set if dst is 0, reset otherwise C: Set if destination increments from 9999 to 0000, reset otherwise Set if destination increments from 99 to 00, reset otherwise V: Undefined Mode Bits OSCOFF, CPUOFF, and GIE are not affected. **Example** The four-digit decimal number contained in R5 is added to an eight-digit decimal number pointed to by R8. CLRC ; Reset carry ; next instruction's start condition is defined DADD R5,0(R8) ; Add LSDs + C DADC 2(R8) ; Add carry to MSD **Example** The two-digit decimal number contained in R5 is added to a four-digit decimal number pointed to by R8. CLRC ; Reset carry ; next instruction's start condition is defined DADD.B R5,0(R8) ; Add LSDs + C DADC 1(R8) ; Add carry to MSDs # 4.6.2.16 DADD \* **DADD[.W]** Add source word and carry decimally to destination word \* **DADD.B** Add source byte and carry decimally to destination byte Syntax DADD src,dst Of DADD.W src,dst DADD.B src,dst **Operation** $\operatorname{src} + \operatorname{dst} + \operatorname{C} \to \operatorname{dst} (\operatorname{decimally})$ **Description** The source operand and the destination operand are treated as two (.B) or four (.W) binary coded decimals (BCD) with positive signs. The source operand and the carry bit C are added decimally to the destination operand. The source operand is not affected. The previous content of the destination is lost. The result is not defined for non-BCD numbers. Status Bits N: Set if MSB of result is 1 (word > 7999h, byte > 79h), reset if MSB is 0 Z: Set if result is zero, reset otherwise C: Set if the BCD result is too large (word > 9999h, byte > 99h), reset otherwise V: Undefined Mode Bits OSCOFF, CPUOFF, and GIE are not affected. **Example** Decimal 10 is added to the 16-bit BCD counter DECCNTR. ``` DADD #10h, &DECCNTR ; Add 10 to 4-digit BCD counter ``` #### **Example** The eight-digit BCD number contained in 16-bit RAM addresses BCD and BCD+2 is added decimally to an eight-digit BCD number contained in R4 and R5 (BCD+2 and R5 contain the MSDs). The carry C is added, and cleared. #### Example The two-digit BCD number contained in word BCD (16-bit address) is added decimally to a two-digit BCD number contained in R4. The carry C is added, also. R4.19:8 = 0 ``` CLRC ; Clear carry DADD.B &BCD,R4 ; Add BCD to R4 decimally. R4: 0,00ddh ``` #### 4.6.2.17 DEC \* **DEC[.W]** Decrement destination \* **DEC.B** Decrement destination Syntax DEC dst Or DEC.W dst DEC.B dst Operation $dst - 1 \rightarrow dst$ Emulation SUB #1, dst SUB.B #1, dst **Description** The destination operand is decremented by one. The original contents are lost. Status Bits N: Set if result is negative, reset if positive Z: Set if dst contained 1, reset otherwiseC: Reset if dst contained 0, set otherwise V: Set if an arithmetic overflow occurs, otherwise reset. Set if initial value of destination was 08000h, otherwise reset. Set if initial value of destination was 080h, otherwise reset. Mode Bits OSCOFF, CPUOFF, and GIE are not affected. **Example** R10 is decremented by 1. ``` DEC R10 ; Decrement R10 ``` ``` ; Move a block of 255 bytes from memory location starting with EDE to ; memory location starting with TONI. Tables should not overlap: start of ``` ; destination address TONI must not be within the range EDE to EDE+0FEh MOV #EDE,R6 MOV #255,R10 L\$1 MOV.B @R6+,TONI-EDE-1(R6) DEC R10 JNZ L\$1 Do not transfer tables using the routine above with the overlap shown in Figure 4-36. Figure 4-36. Decrement Overlap #### 4.6.2.18 DECD \* **DECD[.W]** Double-decrement destination \* **DECD.B** Double-decrement destination Syntax DECD dst Or DECD.W dst DECD.B dst $dst - 2 \rightarrow dst$ Operation $dst - 2 \rightarrow dst$ Emulation SUB #2,dst SUB.B #2,dst **Description** The destination operand is decremented by two. The original contents are lost. Status Bits N: Set if result is negative, reset if positive Z: Set if dst contained 2, reset otherwise C: Reset if dst contained 0 or 1, set otherwise V: Set if an arithmetic overflow occurs, otherwise reset Set if initial value of destination was 08001 or 08000h, otherwise reset Set if initial value of destination was 081 or 080h, otherwise reset Mode Bits OSCOFF, CPUOFF, and GIE are not affected. **Example** R10 is decremented by 2. DECD R10 ; Decrement R10 by two ; Move a block of 255 bytes from memory location starting with EDE to ; memory location starting with TONI. ; Tables should not overlap: start of destination address TONI must not ; be within the range EDE to EDE+0FEh MOV #EDE,R6 MOV #255,R10 L\$1 MOV.B @R6+,TONI-EDE-2(R6) DECD R10 JNZ L\$1 **Example** Memory at location LEO is decremented by two. DECD.B LEO ; Decrement MEM(LEO) Decrement status byte STATUS by two DECD.B STATUS #### 4.6.2.19 DINT \* **DINT** Disable (general) interrupts or (0FFF7h .AND. SR $\rightarrow$ SR / .NOT.src .AND. dst $\rightarrow$ dst) Emulation BIC #8,SR **Description** All interrupts are disabled. The constant 08h is inverted and logically ANDed with the SR. The result is placed into the SR. Status Bits Status bits are not affected. Mode Bits GIE is reset. OSCOFF and CPUOFF are not affected. **Example** The general interrupt enable (GIE) bit in the SR is cleared to allow a nondisrupted move of a 32-bit counter. This ensures that the counter is not modified during the move by any interrupt. DINT ; All interrupt events using the GIE bit are disabled NOP MOV COUNTHI, R5 ; Copy counter MOV COUNTLO, R6 EINT ; All interrupt events using the GIE bit are enabled #### **NOTE:** Disable interrupt If any code sequence needs to be protected from interruption, DINT should be executed at least one instruction before the beginning of the uninterruptible sequence, or it should be followed by a NOP instruction. # NOTE: Enable and Disable Interrupt Due to the pipelined CPU architecture, the instruction following the enable interrupt instruction (EINT) is always executed, even if an interrupt service request is pending when the interrupts are enabled. If the enable interrupt instruction (EINT) is immediately followed by a disable interrupt instruction (DINT), a pending interrupt might not be serviced. Further instructions after DINT might execute incorrectly and result in unexpected CPU execution. It is recommended to always insert at least one instruction between EINT and DINT. Note that any alternative instruction use that sets and immediately clears the CPU status register GIE bit must be considered in the same fashion. #### 4.6.2.20 EINT \* **EINT** Enable (general) interrupts or $(0008h .OR. SR \rightarrow SR / .src .OR. dst \rightarrow dst)$ Emulation BIS #8,SR **Description** All interrupts are enabled. The constant #08h and the SR are logically ORed. The result is placed into the SR. **Status Bits** Status bits are not affected. Mode Bits GIE is set. OSCOFF and CPUOFF are not affected. Example The general interrupt enable (GIE) bit in the SR is set. ``` PUSH.B &P1IN BIC.B @SP,&I ``` BIC.B @SP,&P1IFG ; Reset only accepted flags EINT ; Preset port 1 interrupt flags stored on stack ; other interrupts are allowed BIT #Mask,@SP JEQ MaskOK ; Flags are present identically to mask: jump . . . . . MaskOK BIC #Mask,@SP • • • • • INCD SP ; Housekeeping: inverse to PUSH instruction ; at the start of interrupt subroutine. Corrects ; the stack pointer. RETI #### NOTE: Enable and Disable Interrupt Due to the pipelined CPU architecture, the instruction following the enable interrupt instruction (EINT) is always executed, even if an interrupt service request is pending when the interrupts are enabled. If the enable interrupt instruction (EINT) is immediately followed by a disable interrupt instruction (DINT), a pending interrupt might not be serviced. Further instructions after DINT might execute incorrectly and result in unexpected CPU execution. It is recommended to always insert at least one instruction between EINT and DINT. Note that any alternative instruction use that sets and immediately clears the CPU status register GIE bit must be considered in the same fashion. # 4.6.2.21 INC \* INC[.W] Increment destination \* INC.B Increment destination Syntax INC dst Or INC.W dst INC.B dst **Description** The destination operand is incremented by one. The original contents are lost. Status Bits N: Set if result is negative, reset if positive Z: Set if dst contained 0FFFFh, reset otherwiseSet if dst contained 0FFh, reset otherwiseC: Set if dst contained 0FFFFh, reset otherwise Set if dst contained 07FFh, reset otherwise V: Set if dst contained 07FFFh, reset otherwise Set if dst contained 07Fh, reset otherwise Mode Bits OSCOFF, CPUOFF, and GIE are not affected. **Example** The status byte, STATUS, of a process is incremented. When it is equal to 11, a branch to OVFL is taken. INC.B STATUS CMP.B #11,STATUS JEQ OVFL #### 4.6.2.22 INCD \* INCD[.W] Double-increment destination \* INCD.B Double-increment destination Syntax INCD dst Or INCD.W dst INCD.B dst **Description** The destination operand is incremented by two. The original contents are lost. **Status Bits** N: Set if result is negative, reset if positive Z: Set if dst contained 0FFFEh, reset otherwise Set if dst contained 0FEh, reset otherwise C: Set if dst contained 0FFFEh or 0FFFFh, reset otherwiseSet if dst contained 0FEh or 0FFh, reset otherwiseV: Set if dst contained 07FFEh or 07FFFh, reset otherwise Set if dst contained 07FFEIT of 07FFFIT, reset otherwise Mode Bits OSCOFF, CPUOFF, and GIE are not affected. Example The item on the top of the stack (TOS) is removed without using a register. . . . . . . . PUSH R5; R5 is the result of a calculation, which is stored ; in the system stack INCD SP ; Remove TOS by double-increment from stack ; Do not use INCD.B, SP is a word-aligned register RET **Example** The byte on the top of the stack is incremented by two. INCD.B 0(SP) ; Byte on TOS is increment by two #### 4.6.2.23 INV \* INV[.W] Invert destination \* INV.B Invert destination Syntax INV dst Or INV.W dst INV.B dst **Operation** .not.dst $\rightarrow$ dst **Emulation** XOR #0FFFFh,dst XOR.B #0FFh,dst **Description** The destination operand is inverted. The original contents are lost. Status Bits N: Set if result is negative, reset if positive Z: Set if dst contained 0FFFh, reset otherwise Set if dst contained 0FFh, reset otherwise C: Set if result is not zero, reset otherwise ( = .NOT. Zero) V: Set if initial destination operand was negative, otherwise reset Mode Bits OSCOFF, CPUOFF, and GIE are not affected. Example Content of R5 is negated (2s complement). MOV #00AEh,R5 ; R5 = 000AEh INV R5 ; Invert R5, R5 = 0FF51h INC R5 ; R5 is now negated, R5 = 0FF52h # **Example** Content of memory byte LEO is negated. MOV.B #0AEh,LEO ; MEM(LEO) = 0AEh INV.B LEO ; Invert LEO, MEM(LEO) = 051h INC.B LEO ; MEM(LEO) is negated, MEM(LEO) = 052h #### 4.6.2.24 JC, JHS JC Jump if carry **JHS** Jump if higher or same (unsigned) Syntax JC label JHS label **Operation** If C = 1: $PC + (2 \times Offset) \rightarrow PC$ If C = 0: execute the following instruction **Description** The carry bit C in the SR is tested. If it is set, the signed 10-bit word offset contained in the instruction is multiplied by two, sign extended, and added to the 20-bit PC. This means a jump in the range –511 to +512 words relative to the PC in the full memory range. If C is reset, the instruction after the jump is executed. JC is used for the test of the carry bit C. JHS is used for the comparison of unsigned numbers. Status Bits Status bits are not affected **Mode Bits** OSCOFF, CPUOFF, and GIE are not affected. **Example** The state of the port 1 pin P1IN.1 bit defines the program flow. ``` BIT.B #2,&P1IN ; Port 1, bit 1 set? Bit -> C JC Label1 ; Yes, proceed at Label1 ... ; No, continue ``` ### **Example** If $R5 \ge R6$ (unsigned), the program continues at Label2. ``` CMP R6,R5 ; Is R5 \Rightarrow R6? Info to C JHS Label2 ; Yes, C = 1 ... ; No, R5 < R6. Continue ``` # **Example** If $R5 \ge 12345h$ (unsigned operands), the program continues at Label2. ``` CMPA #12345h,R5 ; Is R5 >= 12345h? Info to C JHS Label2 ; Yes, 12344h < R5 <= F,FFFFh. C = 1 ... ; No, R5 < 12345h. Continue</pre> ``` #### 4.6.2.25 JEQ, JZ JEQ Jump if equal JZ Jump if zero Syntax JEQ label JZ label **Operation** If Z = 1: PC + $(2 \times Offset) \rightarrow PC$ If Z = 0: execute following instruction **Description** The zero bit Z in the SR is tested. If it is set, the signed 10-bit word offset contained in the instruction is multiplied by two, sign extended, and added to the 20-bit PC. This means a jump in the range –511 to +512 words relative to the PC in the full memory range. If Z is reset, the instruction after the jump is executed. JZ is used for the test of the zero bit Z. JEQ is used for the comparison of operands. Status Bits Status bits are not affected Mode Bits OSCOFF, CPUOFF, and GIE are not affected. **Example** The state of the P2IN.0 bit defines the program flow. BIT.B #1,&P2IN ; Port 2, bit 0 reset? JZ Label1 ; Yes, proceed at Label1 ... ; No, set, continue **Example** If R5 = 15000h (20-bit data), the program continues at Label2. CMPA #15000h,R5 ; Is R5 = 15000h? Info to SR JEQ Label2 ; Yes, R5 = 15000h. Z = 1 ... ; No, R5 not equal 15000h. Continue **Example** R7 (20-bit counter) is incremented. If its content is zero, the program continues at Label4. ADDA #1,R7 ; Increment R7 JZ Label4 ; Zero reached: Go to Label4 ... ; R7 not equal 0. Continue here. #### 4.6.2.26 JGE **JGE** Jump if greater or equal (signed) Syntax JGE label **Operation** If (N .xor. V) = 0: PC + $(2 \times Offset) \rightarrow PC$ If $(N \cdot xor. \ V) = 1$ : execute following instruction **Description** The negative bit N and the overflow bit V in the SR are tested. If both bits are set or both are reset, the signed 10-bit word offset contained in the instruction is multiplied by two, sign extended, and added to the 20-bit PC. This means a jump in the range -511 to +512 words relative to the PC in full Memory range. If only one bit is set, the instruction after the jump is executed. JGE is used for the comparison of signed operands: also for incorrect results due to overflow, the decision made by the JGE instruction is correct. Note that JGE emulates the nonimplemented JP (jump if positive) instruction if used after the instructions AND, BIT, RRA, SXTX, and TST. These instructions clear the V bit. **Status Bits** Status bits are not affected. **Mode Bits** OSCOFF, CPUOFF, and GIE are not affected. **Example** If byte EDE (lower 64 K) contains positive data, go to Label1. Software can run in the full memory range. ``` TST.B &EDE ; Is EDE positive? V <- 0 JGE Labell ; Yes, JGE emulates JP ... ; No, 80h <= EDE <= FFh ``` # **Example** If the content of R6 is greater CMP If the content of R6 is greater than or equal to the memory pointed to by R7, the program continues a Label5. Signed data. Data and program in full memory range. @R7,R6 ; Is R6 >= @R7? JGE Label5 ; Yes, go to Label5 ... ; No, continue here # **Example** If $R5 \ge 12345h$ (signed operands), the program continues at Label2. Program in full memory range. CMPA #12345h,R5 ; Is R5 >= 12345h? JGE Label2 ; Yes, 12344h < R5 <= 7FFFFh ... ; No, 80000h <= R5 < 12345h</pre> #### 4.6.2.27 JL **JL** Jump if less (signed) Syntax JL label **Operation** If (N .xor. V) = 1: PC + $(2 \times Offset) \rightarrow PC$ If $(N \cdot xor. V) = 0$ : execute following instruction **Description** The negative bit N and the overflow bit V in the SR are tested. If only one is set, the signed 10-bit word offset contained in the instruction is multiplied by two, sign extended, and added to the 20-bit PC. This means a jump in the range -511 to +512 words relative to the PC in full memory range. If both bits N and V are set or both are reset, the instruction after the jump is executed. JL is used for the comparison of signed operands: also for incorrect results due to overflow, the decision made by the JL instruction is correct. **Status Bits** Status bits are not affected. Mode Bits OSCOFF, CPUOFF, and GIE are not affected. **Example** If byte EDE contains a smaller, signed operand than byte TONI, continue at Label1. The address EDE is within PC ± 32 K. CMP.B &TONI,EDE ; IS EDE < TONI JL Label1 ; Yes ... ; No, TONI <= EDE **Example** If the signed content of R6 is less than the memory pointed to by R7 (20-bit address), the program continues at Label5. Data and program in full memory range. **Example** If R5 < 12345h (signed operands), the program continues at Label2. Data and program in full memory range. CMPA #12345h,R5 ; Is R5 < 12345h? JL Label2 ; Yes, 80000h =< R5 < 12345h ... ; No, 12344h < R5 <= 7FFFFh</pre> #### 4.6.2.28 JMP **JMP** Jump unconditionally Syntax JMP label **Operation** $PC + (2 \times Offset) \rightarrow PC$ **Description** The signed 10-bit word offset contained in the instruction is multiplied by two, sign extended, and added to the 20-bit PC. This means an unconditional jump in the range –511 to +512 words relative to the PC in the full memory. The JMP instruction may be used as a BR or BRA instruction within its limited range relative to the PC. Status Bits Status bits are not affected Mode Bits OSCOFF, CPUOFF, and GIE are not affected. **Example** The byte STATUS is set to 10. Then a jump to label MAINLOOP is made. Data in lower 64 K, program in full memory range. MOV.B #10,&STATUS ; Set STATUS to 10 JMP MAINLOOP ; Go to main loop **Example** The interrupt vector TAIV of Timer\_A3 is read and used for the program flow. Program in full memory range, but interrupt handlers always starts in lower 64 K. ADD &TAIV,PC ; Add Timer\_A interrupt vector to PC RETI ; No Timer\_A interrupt pending JMP IHCCR1 ; Timer block 1 caused interrupt JMP IHCCR2 ; Timer block 2 caused interrupt RETI ; No legal interrupt, return #### 4.6.2.29 JN JN Jump if negative JN label **Syntax** Operation If N = 1: PC + $(2 \times Offset) \rightarrow PC$ If N = 0: execute following instruction The negative bit N in the SR is tested. If it is set, the signed 10-bit word offset contained **Description** > in the instruction is multiplied by two, sign extended, and added to the 20-bit program PC. This means a jump in the range -511 to +512 words relative to the PC in the full memory range. If N is reset, the instruction after the jump is executed. **Status Bits** Status bits are not affected. **Mode Bits** OSCOFF, CPUOFF, and GIE are not affected. **Example** The byte COUNT is tested. If it is negative, program execution continues at Label0. Data in lower 64 K, program in full memory range. ``` TST.B &COUNT ; Is byte COUNT negative? Label0 ; Yes, proceed at Label0 JN ; COUNT >= 0 . . . ``` #### **Example** R6 is subtracted from R5. If the result is negative, program continues at Label2. Program in full memory range. ``` SUB R6,R5 ; R5 - R6 -> R5 JN Label2 ; R5 is negative: R6 > R5 (N = 1) ; R5 >= 0. Continue here. . . . ``` #### Example R7 (20-bit counter) is decremented. If its content is below zero, the program continues at Label4. Program in full memory range. ``` #1,R7 ; Decrement R7 SUBA Label4 JN ; R7 < 0: Go to Label4 ; R7 >= 0. Continue here. . . . ``` #### 4.6.2.30 JNC, JLO **JNC** Jump if no carry **JLO** Jump if lower (unsigned) Syntax JNC label JLO label **Operation** If C = 0: $PC + (2 \times Offset) \rightarrow PC$ If C = 1: execute following instruction **Description** The carry bit C in the SR is tested. If it is reset, the signed 10-bit word offset contained in the instruction is multiplied by two, sign extended, and added to the 20-bit PC. This means a jump in the range –511 to +512 words relative to the PC in the full memory range. If C is set, the instruction after the jump is executed. JNC is used for the test of the carry bit C. JLO is used for the comparison of unsigned numbers. Status Bits Status bits are not affected. **Mode Bits** OSCOFF, CPUOFF, and GIE are not affected. **Example** If byte EDE < 15, the program continues at Label2. Unsigned data. Data in lower 64 K, program in full memory range. CMP.B #15,&EDE ; Is EDE < 15? Info to C JLO Label2 ; Yes, EDE < 15. C = 0 ... ; No, EDE >= 15. Continue **Example** The word TONI is added to R5. If no carry occurs, continue at Label0. The address of TONI is within PC ± 32 K. ADD TONI,R5 ; TONI + R5 -> R5. Carry -> C JNC Label0 ; No carry ... ; Carry = 1: continue here #### 4.6.2.31 JNZ, JNE JNZ Jump if not zero JNE Jump if not equal Syntax JNZ label JNE label **Operation** If Z = 0: PC + $(2 \times Offset) \rightarrow PC$ If Z = 1: execute following instruction **Description** The zero bit Z in the SR is tested. If it is reset, the signed 10-bit word offset contained in the instruction is multiplied by two, sign extended, and added to the 20-bit PC. This means a jump in the range –511 to +512 words relative to the PC in the full memory range. If Z is set, the instruction after the jump is executed. JNZ is used for the test of the zero bit Z. JNE is used for the comparison of operands. Status Bits Status bits are not affected. Mode Bits OSCOFF, CPUOFF, and GIE are not affected. **Example** The byte STATUS is tested. If it is not zero, the program continues at Label3. The address of STATUS is within PC ± 32 K. TST.B STATUS ; Is STATUS = 0? JNZ Label3 ; No, proceed at Label3 ... ; Yes, continue here **Example** If word EDE ≠ 1500, the program continues at Label2. Data in lower 64 K, program in full memory range. CMP #1500,&EDE ; Is EDE = 1500? Info to SR JNE Label2 ; No, EDE not equal 1500. ... ; Yes, R5 = 1500. Continue **Example** R7 (20-bit counter) is decremented. If its content is not zero, the program continues at Label4. Program in full memory range. SUBA #1,R7 ; Decrement R7 JNZ Label4 ; Zero not reached: Go to Label4 ... ; Yes, R7 = 0. Continue here. #### 4.6.2.32 MOV MOV[.W]Move source word to destination wordMOV.BMove source byte to destination byteSyntaxMOV src,dst or MOV.W src,dst MOV.B src,dst **Operation** $\operatorname{src} \to \operatorname{dst}$ **Description** The source operand is copied to the destination. The source operand is not affected. Status Bits N: Not affected Z: Not affectedC: Not affectedV: Not affected **Mode Bits** OSCOFF, CPUOFF, and GIE are not affected. Example Move a 16-bit constant 1800h to absolute address-word EDE (lower 64 K) MOV #01800h,&EDE ; Move 1800h to EDE #### **Example** The contents of table EDE (word data, 16-bit addresses) are copied to table TOM. The length of the tables is 030h words. Both tables reside in the lower 64 K. ``` MOV #EDE,R10 ; Prepare pointer (16-bit address) MOV @R10+,TOM-EDE-2(R10) ; R10 points to both tables. Loop ; R10+2 CMP #EDE+60h,R10 ; End of table reached? JLO Loop ; Not yet ; Copy completed . . . ``` ### Example The contents of table EDE (byte data, 16-bit addresses) are copied to table TOM. The length of the tables is 020h bytes. Both tables may reside in full memory range, but must be within R10 $\pm$ 32 K. ``` #EDE,R10 MOVA ; Prepare pointer (20-bit) #20h,R9 ; Prepare counter MOV @R10+,TOM-EDE-1(R10) ; R10 points to both tables. good MOV.B ; R10+1 DEC R9 ; Decrement counter JNZ Loop ; Not yet done ; Copy completed ``` # 4.6.2.33 NOP \* NOP No operation Syntax NOP Operation None **Emulation** MOV #0, R3 **Description** No operation is performed. The instruction may be used for the elimination of instructions during the software check or for defined waiting times. **Status Bits** Status bits are not affected. #### 4.6.2.34 POP \* POP[.W] Pop word from stack to destination \* POP.B Pop byte from stack to destination Syntax POP dst POP.B dst $\textbf{Operation} \qquad @\,\mathsf{SP} \to \mathsf{temp}$ $SP + 2 \rightarrow SP$ temp $\rightarrow$ dst Emulation Mov @SP+,dst or Mov.W @SP+,dst MOV.B @SP+,dst **Description** The stack location pointed to by the SP (TOS) is moved to the destination. The SP is incremented by two afterwards. **Status Bits** Status bits are not affected. **Example** The contents of R7 and the SR are restored from the stack. POP R7 ; Restore R7 POP SR ; Restore status register **Example** The contents of RAM byte LEO is restored from the stack. POP.B LEO ; The low byte of the stack is moved to LEO. **Example** The contents of R7 is restored from the stack. ``` POP.B R7; The low byte of the stack is moved to R7, ; the high byte of R7 is 00h ``` **Example** The contents of the memory pointed to by R7 and the SR are restored from the stack. ``` POP.B 0(R7) ; The low byte of the stack is moved to the ; the byte which is pointed to by R7 : Example: R7 = 203h ; Mem(R7) = low byte of system stack : Example: R7 = 20Ah ; Mem(R7) = low byte of system stack POP SR ; Last word on stack moved to the SR ``` ### NOTE: System stack pointer The system SP is always incremented by two, independent of the byte suffix. #### 4.6.2.35 PUSH PUSH[.W] Save a word on the stack PUSH.B Save a byte on the stack Syntax PUSH dst Or PUSH.W dst PUSH.B dst **Operation** $SP - 2 \rightarrow SP$ $dst \rightarrow @SP$ **Description** The 20-bit SP SP is decremented by two. The operand is then copied to the RAM word addressed by the SP. A pushed byte is stored in the low byte; the high byte is not affected. **Status Bits** Status bits are not affected. **Mode Bits** OSCOFF, CPUOFF, and GIE are not affected. **Example** Save the two 16-bit registers R9 and R10 on the stack PUSH R9 ; Save R9 and R10 XXXXh PUSH R10 ; YYYYh **Example** Save the two bytes EDE and TONI on the stack. The addresses EDE and TONI are within PC ± 32 K. PUSH.B EDE ; Save EDE xxXXh PUSH.B TONI ; Save TONI xxYYh #### 4.6.2.36 RET \* **RET** Return from subroutine Syntax RET **Operation** @SP $\rightarrow$ PC.15:0 Saved PC to PC.15:0. PC.19:16 $\leftarrow$ 0 $SP + 2 \rightarrow SP$ **Description** The 16-bit return address (lower 64 K), pushed onto the stack by a CALL instruction is restored to the PC. The program continues at the address following the subroutine call. The four MSBs of the PC.19:16 are cleared. Status Bits Status bits are not affected. PC.19:16: Cleared **Mode Bits** OSCOFF, CPUOFF, and GIE are not affected. **Example** Call a subroutine SUBR in the lower 64 K and return to the address in the lower 64 K after the CALL. CALL #SUBR ; Call subroutine starting at SUBR ... ; Return by RET to here SUBR PUSH R14 ; Save R14 (16 bit data) ... ; Subroutine code POP R14 ; Restore R14 RET ; Return to lower 64 K Figure 4-37. Stack After a RET Instruction #### 4.6.2.37 RETI **RETI** Return from interrupt Syntax RETI **Operation** @SP → SR.15:0 Restore saved SR with PC.19:16 $SP + 2 \rightarrow SP$ $@SP \rightarrow PC.15:0$ Restore saved PC.15:0 $SP + 2 \rightarrow SP$ Housekeeping **Description** The SR is restored to the value at the beginning of the interrupt service routine. This includes the four MSBs of the PC.19:16. The SP is incremented by two afterward. The 20-bit PC is restored from PC.19:16 (from same stack location as the status bits) and PC.15:0. The 20-bit PC is restored to the value at the beginning of the interrupt service routine. The program continues at the address following the last executed instruction when the interrupt was granted. The SP is incremented by two afterward. Status Bits N: Restored from stack C: Restored from stackZ: Restored from stackV: Restored from stack **Mode Bits** OSCOFF, CPUOFF, and GIE are restored from stack. **Example** Interrupt handler in the lower 64 K. A 20-bit return address is stored on the stack. INTRPT PUSHM.A #2,R14 ; Save R14 and R13 (20-bit data) ... ; Interrupt handler code POPM.A #2,R14 ; Restore R13 and R14 (20-bit data) RETI ; Return to 20-bit address in full memory range #### 4.6.2.38 RLA \* RLA[.W] Rotate left arithmetically \* RLA.B Rotate left arithmetically RLA dst Or **Syntax** RLA.W dst RLA.B dst $\mathsf{C} \leftarrow \mathsf{MSB} \leftarrow \mathsf{MSB-1} \; .... \; \mathsf{LSB+1} \; \leftarrow \mathsf{LSB} \; \leftarrow 0$ Operation ADD dst,dst **Emulation** ADD.B dst,dst #### Description The destination operand is shifted left one position as shown in Figure 4-38. The MSB is shifted into the carry bit (C) and the LSB is filled with 0. The RLA instruction acts as a signed multiplication by 2. An overflow occurs if dst ≥ 04000h and dst < 0C000h before operation is performed; the result has changed sign. Figure 4-38. Destination Operand—Arithmetic Shift Left An overflow occurs if dst ≥ 040h and dst < 0C0h before the operation is performed; the result has changed sign. #### **Status Bits** - Set if result is negative, reset if positive N: - Z: Set if result is zero, reset otherwise - C: Loaded from the MSB - Set if an arithmetic overflow occurs; the initial value is 04000h ≤ dst < 0C000h, reset otherwise Set if an arithmetic overflow occurs; the initial value is 040h ≤ dst < 0C0h, reset otherwise # **Mode Bits** OSCOFF, CPUOFF, and GIE are not affected. # **Example** R7 is multiplied by 2. RLA ; Shift left R7 (x 2) #### **Example** The low byte of R7 is multiplied by 4. ``` RLA.B R7 ; Shift left low byte of R7 (x 2) RLA.B R7 ; Shift left low byte of R7 (x 4) ``` #### **NOTE: RLA substitution** The assembler does not recognize the instructions: RLA @R5+ RLA.B @R5+ RLA(.B) @R5 They must be substituted by: ADD @R5+,-2(R5)ADD.B @R5+,-1(R5)ADD(.B) @R5 #### 4.6.2.39 RLC \* RLC[.W] Rotate left through carry \* RLC.B Rotate left through carry Syntax RLC dst Or RLC.W dst RLC.B dst **Operation** $C \leftarrow MSB \leftarrow MSB-1 \dots LSB+1 \leftarrow LSB \leftarrow C$ Emulation ADDC dst,dst **Description** The destination operand is shifted left one position as shown in Figure 4-39. The carry bit (C) is shifted into the LSB, and the MSB is shifted into the carry bit (C). Figure 4-39. Destination Operand—Carry Left Shift Status Bits N: Set if result is negative, reset if positive Z: Set if result is zero, reset otherwise C: Loaded from the MSB V: Set if an arithmetic overflow occurs; the initial value is 04000h ≤ dst < 0C000h, reset otherwise Set if an arithmetic overflow occurs; the initial value is $040h \le dst < 0C0h$ , reset otherwise Mode Bits OSCOFF, CPUOFF, and GIE are not affected. **Example** R5 is shifted left one position. RLC R5 ; $(R5 \times 2) + C \rightarrow R5$ **Example** The input P1IN.1 information is shifted into the LSB of R5. BIT.B #2,&P1IN ; Information -> Carry RLC R5 ; Carry=P0in.1 -> LSB of R5 **Example** The MEM(LEO) content is shifted left one position. RLC.B LEO ; $Mem(LEO) \times 2 + C \rightarrow Mem(LEO)$ #### NOTE: RLA substitution The assembler does not recognize the instructions: RLC @R5+ RLC.B @R5+ RLC(.B) @R5 They must be substituted by: ADDC @R5+,-2(R5) ADDC.B @R5+,-1(R5) ADDC(.B) @R5 209 #### 4.6.2.40 RRA **RRA[.W]** Rotate right arithmetically destination word **RRA.B** Rotate right arithmetically destination byte **Description** The destination operand is shifted right arithmetically by one bit position as shown in Figure 4-40. The MSB retains its value (sign). RRA operates equal to a signed division by 2. The MSB is retained and shifted into the MSB–1. The LSB+1 is shifted into the LSB. The previous LSB is shifted into the carry bit C. **Status Bits** N: Set if result is negative (MSB = 1), reset otherwise (MSB = 0) Z: Set if result is zero, reset otherwise C: Loaded from the LSB V: Reset Mode Bits OSCOFF, CPUOFF, and GIE are not affected. **Example** The signed 16-bit number in R5 is shifted arithmetically right one position. RRA R5 ; R5/2 -> R5 **Example** The signed RAM byte EDE is shifted arithmetically right one position. Figure 4-40. Rotate Right Arithmetically RRA.B and RRA.W #### 4.6.2.41 RRC RRC[.W] Rotate right through carry destination word RRC.B Rotate right through carry destination byte Syntax RRC dst or RRC.W dst RRC.B dst $\textbf{Operation} \qquad C \rightarrow \text{MSB} \rightarrow \text{MSB-1} \rightarrow ... \ \text{LSB+1} \rightarrow \text{LSB} \rightarrow C$ **Description** The destination operand is shifted right by one bit position as shown in Figure 4-41. The carry bit C is shifted into the MSB and the LSB is shifted into the carry bit C. **Status Bits** N: Set if result is negative (MSB = 1), reset otherwise (MSB = 0) Z: Set if result is zero, reset otherwise C: Loaded from the LSB V: Reset Mode Bits OSCOFF, CPUOFF, and GIE are not affected. **Example** RAM word EDE is shifted right one bit position. The MSB is loaded with 1. Figure 4-41. Rotate Right Through Carry RRC.B and RRC.W #### 4.6.2.42 SBC \* SBC[.W] Subtract borrow (.NOT. carry) from destination \* SBC.B Subtract borrow (.NOT. carry) from destination Syntax SBC dst or SBC.W dst SBC.B dst **Operation** $dst + 0FFFFh + C \rightarrow dst$ $dst + 0FFh + C \rightarrow dst$ **Emulation** SUBC #0,dst SUBC.B #0,dst **Description** The carry bit (C) is added to the destination operand minus one. The previous contents of the destination are lost. Status Bits N: Set if result is negative, reset if positive Z: Set if result is zero, reset otherwise C: Set if there is a carry from the MSB of the result, reset otherwise Set to 1 if no borrow, reset if borrow V: Set if an arithmetic overflow occurs, reset otherwise **Mode Bits** OSCOFF, CPUOFF, and GIE are not affected. **Example** The 16-bit counter pointed to by R13 is subtracted from a 32-bit counter pointed to by R12. SUB @R13,0(R12) ; Subtract LSDs SBC 2(R12) ; Subtract carry from MSD **Example** The 8-bit counter pointed to by R13 is subtracted from a 16-bit counter pointed to by R12. SUB.B @R13,0(R12) ; Subtract LSDs SBC.B 1(R12) ; Subtract carry from MSD # NOTE: Borrow implementation The borrow is treated as a .NOT. carry: Borrow Carry Bit Yes 0 No 1 #### 4.6.2.43 SETC \* **SETC** Set carry bit **Description** The carry bit (C) is set. **Status Bits** N: Not affected Z: Not affected C: Set V: Not affected Mode Bits OSCOFF, CPUOFF, and GIE are not affected. **Example** Emulation of the decimal subtraction: Subtract R5 from R6 decimally. Assume that R5 = 03987h and R6 = 04137h. ``` DSUB ADD #06666h,R5 ; Move content R5 from 0-9 to 6-0Fh ; R5 = 03987h + 06666h = 09FEDh INV R5 ; Invert this (result back to 0-9) ; R5 = .NOT. R5 = 06012h ; Prepare carry = 1 DADD R5,R6 ; Emulate subtraction by addition of: ; (010000h - R5 - 1) ``` ; R6 = R6 + R5 + 1 ; R6 = 0150h # 4.6.2.44 SETN \* **SETN** Set negative bit **Description** The negative bit (N) is set. Status Bits N: Set Z: Not affectedC: Not affectedV: Not affected Mode Bits OSCOFF, CPUOFF, and GIE are not affected. # 4.6.2.45 SETZ \* **SETZ** Set zero bit **Description** The zero bit (Z) is set. **Status Bits** N: Not affected Z: Set C: Not affectedV: Not affected **Mode Bits** OSCOFF, CPUOFF, and GIE are not affected. 215 #### 4.6.2.46 SUB SUB[.W] Subtract source word from destination word SUB.B Subtract source byte from destination byte Syntax SUB src,dst Or SUB.W src,dst SUB.B src,dst **Operation** (.not.src) + 1 + dst $\rightarrow$ dst or dst – src $\rightarrow$ dst **Description** The source operand is subtracted from the destination operand. This is made by adding the 1s complement of the source + 1 to the destination. The source operand is not affected, the result is written to the destination operand. Status Bits N: Set if result is negative (src > dst), reset if positive (src ≤ dst) Z: Set if result is zero (src = dst), reset otherwise (src $\neq$ dst) C: Set if there is a carry from the MSB, reset otherwise V: Set if the subtraction of a negative source operand from a positive destination operand delivers a negative result, or if the subtraction of a positive source operand from a negative destination operand delivers a positive result, reset otherwise (no overflow) Mode Bits OSCOFF, CPUOFF, and GIE are not affected. **Example** A 16-bit constant 7654h is subtracted from RAM word EDE. SUB #7654h, &EDE ; Subtract 7654h from EDE **Example** A table word pointed to by R5 (20-bit address) is subtracted from R7. Afterwards, if R7 contains zero, jump to label TONI. R5 is then auto-incremented by 2. R7.19:16 = 0. SUB @R5+,R7 ; Subtract table number from R7. R5 + $^{2}$ JZ TONI ; R7 = @R5 (before subtraction) ... ; R7 <> @R5 (before subtraction) **Example** Byte CNT is subtracted from byte R12 points to. The address of CNT is within PC ± 32K. The address R12 points to is in full memory range. SUB.B CNT,0(R12) ; Subtract CNT from @R12 #### 4.6.2.47 SUBC SUBC[.W] Subtract source word with carry from destination word SUBC.B Subtract source byte with carry from destination byte Syntax SUBC src,dst Of SUBC.W src,dst SUBC.B src,dst $\textbf{Operation} \qquad \text{(.not.src)} + C + dst \rightarrow dst \quad \text{or} \quad dst - (src - 1) + C \rightarrow dst$ **Description** The source operand is subtracted from the destination operand. This is done by adding the 1s complement of the source + carry to the destination. The source operand is not affected, the result is written to the destination operand. Used for 32, 48, and 64-bit operands. **Status Bits** N: Set if result is negative (MSB = 1), reset if positive (MSB = 0) Z: Set if result is zero, reset otherwise C: Set if there is a carry from the MSB, reset otherwise V: Set if the subtraction of a negative source operand from a positive destination operand delivers a negative result, or if the subtraction of a positive source operand from a negative destination operand delivers a positive result, reset otherwise (no overflow) Mode Bits OSCOFF, CPUOFF, and GIE are not affected. **Example** A 16-bit constant 7654h is subtracted from R5 with the carry from the previous instruction. R5.19:16 = 0 SUBC.W #7654h,R5 ; Subtract 7654h + C from R5 **Example** A 48-bit number (3 words) pointed to by R5 (20-bit address) is subtracted from a 48-bit counter in RAM, pointed to by R7. R5 points to the next 48-bit number afterwards. The address R7 points to is in full memory range. **Example** Byte CNT is subtracted from the byte, R12 points to. The carry of the previous instruction is used. The address of CNT is in lower 64 K. SUBC.B &CNT,0(R12) ; Subtract byte CNT from @R12 # 4.6.2.48 SWPB SWPB Swap bytes Syntax SWPB dst **Operation** $dst.15:8 \leftrightarrow dst.7:0$ **Description** The high and the low byte of the operand are exchanged. PC.19:16 bits are cleared in register mode. Status Bits Status bits are not affected Mode Bits OSCOFF, CPUOFF, and GIE are not affected. Example Exchange the bytes of RAM word EDE (lower 64 K) MOV #1234h,&EDE ; 1234h -> EDE SWPB &EDE ; 3412h -> EDE Low Byte # Before SWPB Figure 4-42. Swap Bytes in Memory High Byte Figure 4-43. Swap Bytes in a Register ### 4.6.2.49 SXT SXT Extend sign Syntax SXT dst **Operation** $dst.7 \rightarrow dst.15:8$ , $dst.7 \rightarrow dst.19:8$ (register mode) **Description** Register mode: the sign of the low byte of the operand is extended into the bits Rdst.19:8. Rdst.7 = 0: Rdst.19:8 = 000h afterwards Rdst.7 = 1: Rdst.19:8 = FFFh afterwards Other modes: the sign of the low byte of the operand is extended into the high byte. dst.7 = 0: high byte = 00h afterwards dst.7 = 1: high byte = FFh afterwards **Status Bits** N: Set if result is negative, reset otherwise Z: Set if result is zero, reset otherwise C: Set if result is not zero, reset otherwise (C = .not.Z) V: Reset Mode Bits OSCOFF, CPUOFF, and GIE are not affected. **Example** The signed 8-bit data in EDE (lower 64 K) is sign extended and added to the 16-bit signed data in R7. MOV.B &EDE,R5 ; EDE -> R5. 00XXh SXT R5 ; Sign extend low byte to R5.19:8 ADD R5,R7 ; Add signed 16-bit values Example The signed 8-bit data in EDE (PC +32 K) is sign extended and added to the 20-bit data in R7. MOV.B EDE,R5 ; EDE -> R5. 00XXh SXT R5 ; Sign extend low byte to R5.19:8 ADDA R5,R7 ; Add signed 20-bit values ### 4.6.2.50 TST \* TST[.W] Test destination \* TST.B Test destination Syntax TST dst Or TST.W dst TST.B dst **Operation** dst + 0FFFFh + 1 dst + 0FFh + 1 **Emulation** CMP #0,dst CMP.B #0,dst **Description** The destination operand is compared with zero. The status bits are set according to the result. The destination is not affected. **Status Bits** N: Set if destination is negative, reset if positive Z: Set if destination contains zero, reset otherwise C: Set V: Reset **Mode Bits** OSCOFF, CPUOFF, and GIE are not affected. **Example** R7 is tested. If it is negative, continue at R7NEG; if it is positive but not zero, continue at R7POS. TST R7 ; Test R7 JN R7NEG ; R7 is negative JZ R7ZERO ; R7 is zero R7POS ..... ; R7 is positive but not zero R7NEG ..... ; R7 is negative R7ZERO ..... ; R7 is zero **Example** The low byte of R7 is tested. If it is negative, continue at R7NEG; if it is positive but not zero, continue at R7POS. TST.B R7 ; Test low byte of R7 JN R7NEG ; Low byte of R7 is negative JZ R7ZERO ; Low byte of R7 is zero R7POS ..... ; Low byte of R7 is positive but not zero R7NEG .... ; Low byte of R7 is negative R7ZERO ..... ; Low byte of R7 is zero ### 4.6.2.51 XOR XOR[.W] Exclusive OR source word with destination word XOR.B Exclusive OR source byte with destination byte Syntax XOR src,dst Or XOR.W src,dst XOR.B src,dst **Operation** $\operatorname{src} .\operatorname{xor} .\operatorname{dst} \to \operatorname{dst}$ **Description** The source and destination operands are exclusively ORed. The result is placed into the destination. The source operand is not affected. The previous content of the destination is lost. **Status Bits** N: Set if result is negative (MSB = 1), reset if positive (MSB = 0) Z: Set if result is zero, reset otherwise C: Set if result is not zero, reset otherwise (C = .not. Z) V: Set if both operands are negative before execution, reset otherwise Mode Bits OSCOFF, CPUOFF, and GIE are not affected. **Example** Toggle bits in word CNTR (16-bit data) with information (bit = 1) in address-word TONI. Both operands are located in lower 64 K. XOR &TONI, &CNTR ; Toggle bits in CNTR **Example** A table word pointed to by R5 (20-bit address) is used to toggle bits in R6. R6.19:16 = 0. XOR @R5,R6 ; Toggle bits in R6 **Example** Reset to zero those bits in the low byte of R7 that are different from the bits in byte EDE. R7.19:8 = 0. The address of EDE is within PC $\pm$ 32 K. XOR.B EDE,R7 ; Set different bits to 1 in R7. INV.B R7 ; Invert low byte of R7, high byte is 0h # 4.6.3 Extended Instructions The extended MSP430X instructions give the MSP430X CPU full access to its 20-bit address space. MSP430X instructions require an additional word of op-code called the extension word. All addresses, indexes, and immediate numbers have 20-bit values when preceded by the extension word. The MSP430X extended instructions are listed and described in the following pages. Operation **Emulation** ### 4.6.3.1 ADCX \* ADCX.A Add carry to destination address-word \* ADCX.[W] Add carry to destination word ADCX.B Add carry to destination byte Syntax ADCX.A dst ADCX dst Of ADCX.W dst ADCX.B dst $dst + C \rightarrow dst$ ADDCX.A #0,dst ADDCX #0,dst ADDCX.B #0,dst **Description** The carry bit (C) is added to the destination operand. The previous contents of the destination are lost. **Status Bits** N: Set if result is negative (MSB = 1), reset if positive (MSB = 0) Z: Set if result is zero, reset otherwise C: Set if there is a carry from the MSB of the result, reset otherwise V: Set if the result of two positive operands is negative, or if the result of two negative numbers is positive, reset otherwise **Mode Bits** OSCOFF, CPUOFF, and GIE are not affected. **Example** The 40-bit counter, pointed to by R12 and R13, is incremented. INCX.A @R12 ; Increment lower 20 bits ADCX.A @R13 ; Add carry to upper 20 bits #### 4.6.3.2 ADDX ADDX.A Add source address-word to destination address-word ADDX.[W] Add source word to destination word ADDX.B Add source byte to destination byte Syntax ADDX.A src,dst ADDX src,dst Of ADDX.W src,dst ADDX.B src,dst **Operation** $\operatorname{src} + \operatorname{dst} \to \operatorname{dst}$ **Description** The source operand is added to the destination operand. The previous contents of the destination are lost. Both operands can be located in the full address space. **Status Bits** N: Set if result is negative (MSB = 1), reset if positive (MSB = 0) Z: Set if result is zero, reset otherwise C: Set if there is a carry from the MSB of the result, reset otherwise V: Set if the result of two positive operands is negative, or if the result of two negative numbers is positive, reset otherwise **Mode Bits** OSCOFF, CPUOFF, and GIE are not affected. **Example** Ten is added to the 20-bit pointer CNTR located in two words CNTR (LSBs) and CNTR+2 (MSBs). ``` ADDX.A #10,CNTR ; Add 10 to 20-bit pointer ``` ### **Example** A table word (16-bit) pointed to by R5 (20-bit address) is added to R6. The jump to label TONI is performed on a carry. ``` ADDX.W @R5,R6 ; Add table word to R6 JC TONI ; Jump if carry ... ; No carry ``` ### Example A table byte pointed to by R5 (20-bit address) is added to R6. The jump to label TONI is performed if no carry occurs. The table pointer is auto-incremented by 1. ``` ADDX.B @R5+,R6 ; Add table byte to R6. R5 + 1. R6: 000xxh JNC TONI ; Jump if no carry .... ; Carry occurred ``` Note: Use ADDA for the following two cases for better code density and execution. ``` ADDX.A Rsrc,Rdst ADDX.A #imm20,Rdst ``` ### 4.6.3.3 ADDCX ADDCX.A Add source address-word and carry to destination address-word ADDCX.[W] Add source word and carry to destination word ADDCX.B Add source byte and carry to destination byte Syntax ADDCX.A src,dst ADDCX src,dst Of ADDCX.W src,dst ADDCX.B src,dst **Operation** $\operatorname{src} + \operatorname{dst} + \operatorname{C} \to \operatorname{dst}$ **Description** The source operand and the carry bit C are added to the destination operand. The previous contents of the destination are lost. Both operands may be located in the full address space. Status Bits N: Set if result is negative (MSB = 1), reset if positive (MSB = 0) Z: Set if result is zero, reset otherwise C: Set if there is a carry from the MSB of the result, reset otherwise V: Set if the result of two positive operands is negative, or if the result of two negative numbers is positive, reset otherwise **Mode Bits** OSCOFF, CPUOFF, and GIE are not affected. **Example** Constant 15 and the carry of the previous instruction are added to the 20-bit counter CNTR located in two words. ``` ADDCX.A #15,&CNTR ; Add 15 + C to 20-bit CNTR ``` ## Example A table word pointed to by R5 (20-bit address) and the carry C are added to R6. The jump to label TONI is performed on a carry. ``` ADDCX.W @R5,R6 ; Add table word + C to R6 JC TONI ; Jump if carry ... ; No carry ``` #### **Example** A table byte pointed to by R5 (20-bit address) and the carry bit C are added to R6. The jump to label TONI is performed if no carry occurs. The table pointer is auto-incremented by 1. ``` ADDCX.B @R5+,R6 ; Add table byte + C to R6. R5 + 1 JNC ; Jump if no carry ... ; Carry occurred ``` ### 4.6.3.4 ANDX ANDX.A Logical AND of source address-word with destination address-word ANDX.[W] Logical AND of source word with destination word ANDX.B Logical AND of source byte with destination byte Syntax ANDX.A src,dst ANDX src,dst Of ANDX.W src,dst ANDX.B src,dst **Operation** $\operatorname{src}$ .and. $\operatorname{dst} \to \operatorname{dst}$ **Description** The source operand and the destination operand are logically ANDed. The result is placed into the destination. The source operand is not affected. Both operands may be located in the full address space. **Status Bits** N: Set if result is negative (MSB = 1), reset if positive (MSB = 0) Z: Set if result is zero, reset otherwise C: Set if the result is not zero, reset otherwise. C = (.not. Z) V: Reset **Mode Bits** OSCOFF, CPUOFF, and GIE are not affected. **Example** The bits set in R5 (20-bit data) are used as a mask (AAA55h) for the address-word TOM located in two words. If the result is zero, a branch is taken to label TONI. ``` MOVA #AAA55h,R5 ; Load 20-bit mask to R5 ANDX.A R5,TOM ; TOM .and. R5 -> TOM JZ TONI ; Jump if result 0 ... ; Result > 0 ``` # or shorter: ``` ANDX.A #AAA55h,TOM ; TOM .and. AAA55h -> TOM JZ TONI ; Jump if result 0 ``` #### **Example** A table byte pointed to by R5 (20-bit address) is logically ANDed with R6. R6.19:8 = 0. The table pointer is auto-incremented by 1. ``` ANDX.B @R5+,R6 ; AND table byte with R6. R5 + 1 ``` ### 4.6.3.5 BICX **BICX.A** Clear bits set in source address-word in destination address-word BICX.[W] Clear bits set in source word in destination word Clear bits set in source byte in destination byte Syntax BICX.A src,dst BICX src,dst Of BICX.W src,dst BICX.B src,dst **Operation** (.not. src) .and. $dst \rightarrow dst$ **Description** The inverted source operand and the destination operand are logically ANDed. The result is placed into the destination. The source operand is not affected. Both operands may be located in the full address space. Status Bits N: Not affected Z: Not affectedC: Not affectedV: Not affected Mode Bits OSCOFF, CPUOFF, and GIE are not affected. Example The bits 19:15 of R5 (20-bit data) are cleared. BICX.A #0F8000h,R5 ; Clear R5.19:15 bits **Example** A table word pointed to by R5 (20-bit address) is used to clear bits in R7. R7.19:16 = 0. BICX.W @R5,R7 ; Clear bits in R7 **Example** A table byte pointed to by R5 (20-bit address) is used to clear bits in output Port1. BICX.B @R5,&P1OUT ; Clear I/O port P1 bits ### 4.6.3.6 BISX **BISX.A** Set bits set in source address-word in destination address-word BISX.[W] Set bits set in source word in destination word BISX.B Set bits set in source byte in destination byte Syntax BISX.A src,dst BISX src,dst Of BISX.W src,dst BISX.B src,dst **Description** The source operand and the destination operand are logically ORed. The result is placed into the destination. The source operand is not affected. Both operands may be located in the full address space. Status Bits N: Not affected Z: Not affectedC: Not affectedV: Not affected Mode Bits OSCOFF, CPUOFF, and GIE are not affected. Example Bits 16 and 15 of R5 (20-bit data) are set to one. BISX.A #018000h,R5 ; Set R5.16:15 bits **Example** A table word pointed to by R5 (20-bit address) is used to set bits in R7. BISX.W @R5,R7 ; Set bits in R7 **Example** A table byte pointed to by R5 (20-bit address) is used to set bits in output Port1. BISX.B @R5,&P1OUT ; Set I/O port P1 bits #### 4.6.3.7 BITX **BITX.A** Test bits set in source address-word in destination address-word BITX.[W] Test bits set in source word in destination word BITX.B Test bits set in source byte in destination byte Syntax BITX.A src,dst BITX src,dst Of BITX.W src,dst BITX.B src,dst **Description** The source operand and the destination operand are logically ANDed. The result affects only the status bits. Both operands may be located in the full address space. **Status Bits** N: Set if result is negative (MSB = 1), reset if positive (MSB = 0) Z: Set if result is zero, reset otherwise C: Set if the result is not zero, reset otherwise. C = (.not. Z) V: Reset **Mode Bits** OSCOFF, CPUOFF, and GIE are not affected. **Example** Test if bit 16 or 15 of R5 (20-bit data) is set. Jump to label TONI if so. ``` BITX.A #018000h,R5 ; Test R5.16:15 bits JNZ TONI ; At least one bit is set ... ; Both are reset ``` ### **Example** A table word pointed to by R5 (20-bit address) is used to test bits in R7. Jump to label TONI if at least one bit is set. ``` BITX.W @R5,R7 ; Test bits in R7: C = .not.Z JC TONI ; At least one is set ... ; Both are reset ``` # Example A table byte pointed to by R5 (20-bit address) is used to test bits in input Port1. Jump to label TONI if no bit is set. The next table byte is addressed. ``` BITX.B @R5+,&P1IN ; Test input P1 bits. R5 + 1 JNC TONI ; No corresponding input bit is set ... ; At least one bit is set ``` # 4.6.3.8 CLRX \* CLRX.A Clear destination address-word \* CLRX.[W] Clear destination word \* CLRX.B Clear destination byte Syntax CLRX.A dst CLRX dst Of CLRX.W dst CLRX.B dst **Emulation** MOVX.A #0,dst MOVX #0,dst MOVX.B #0,dst **Description** The destination operand is cleared. Status Bits Status bits are not affected. **Mode Bits** OSCOFF, CPUOFF, and GIE are not affected. **Example** RAM address-word TONI is cleared. CLRX.A TONI ; 0 -> TONI #### 4.6.3.9 CMPX **CMPX.A** Compare source address-word and destination address-word **CMPX.[W]** Compare source word and destination word **CMPX.B** Compare source byte and destination byte Syntax CMPX.A src,dst CMPX src,dst Of CMPX.W src,dst CMPX.B src,dst **Operation** (.not. src) + 1 + dst or dst - src **Description** The source operand is subtracted from the destination operand by adding the 1s complement of the source + 1 to the destination. The result affects only the status bits. Both operands may be located in the full address space. Status Bits N: Set if result is negative (src > dst), reset if positive (src ≤ dst) Z: Set if result is zero (src = dst), reset otherwise (src $\neq$ dst) C: Set if there is a carry from the MSB, reset otherwise V: Set if the subtraction of a negative source operand from a positive destination operand delivers a negative result, or if the subtraction of a positive source operand from a negative destination operand delivers a positive result, reset otherwise (no overflow) Mode Bits OSCOFF, CPUOFF, and GIE are not affected. **Example** Compare EDE with a 20-bit constant 18000h. Jump to label TONI if EDE equals the constant. ``` CMPX.A #018000h,EDE ; Compare EDE with 18000h JEQ TONI ; EDE contains 18000h ... ; Not equal ``` # **Example** A table word pointed to by R5 (20-bit address) is compared with R7. Jump to label TONI if R7 contains a lower, signed, 16-bit number. ### Example A table byte pointed to by R5 (20-bit address) is compared to the input in I/O Port1. Jump to label TONI if the values are equal. The next table byte is addressed. Note: Use CMPA for the following two cases for better density and execution. CMPA Rsrc,Rdst CMPA #imm20,Rdst ## 4.6.3.10 DADCX \* **DADCX.A** Add carry decimally to destination address-word \* **DADCX.[W]** Add carry decimally to destination word \* **DADCX.B** Add carry decimally to destination byte Syntax DADCX.A dst DADCX dst Or DADCX.W dst DADCX.B dst **Operation** $dst + C \rightarrow dst (decimally)$ Emulation DADDX.A #0,dst DADDX #0,dst DADDX.B #0,dst **Description** The carry bit (C) is added decimally to the destination. Status Bits N: Set if MSB of result is 1 (address-word > 79999h, word > 7999h, byte > 79h), reset if MSB is 0 Z: Set if result is zero, reset otherwise C: Set if the BCD result is too large (address-word > 99999h, word > 9999h, byte > 99h), reset otherwise V: Undefined **Mode Bits** OSCOFF, CPUOFF, and GIE are not affected. **Example** The 40-bit counter, pointed to by R12 and R13, is incremented decimally. DADDX.A #1,0(R12) ; Increment lower 20 bits DADCX.A 0(R13) ; Add carry to upper 20 bits #### 4.6.3.11 DADDX **DADDX.A** Add source address-word and carry decimally to destination address-word **DADDX.[W]** Add source word and carry decimally to destination word **DADDX.B** Add source byte and carry decimally to destination byte Syntax DADDX.A src,dst DADDX src,dst Of DADDX.W src,dst DADDX.B src,dst **Operation** $\operatorname{src} + \operatorname{dst} + \operatorname{C} \to \operatorname{dst} (\operatorname{decimally})$ **Description** The source operand and the destination operand are treated as two (.B), four (.W), or five (.A) binary coded decimals (BCD) with positive signs. The source operand and the carry bit C are added decimally to the destination operand. The source operand is not affected. The previous contents of the destination are lost. The result is not defined for non-BCD numbers. Both operands may be located in the full address space. Status Bits N: Set if MSB of result is 1 (address-word > 79999h, word > 7999h, byte > 79h), reset if MSB is 0. Z: Set if result is zero, reset otherwise C: Set if the BCD result is too large (address-word > 99999h, word > 9999h, byte > 99h), reset otherwise V: Undefined **Mode Bits** OSCOFF, CPUOFF, and GIE are not affected. **Example** Decimal 10 is added to the 20-bit BCD counter DECCNTR located in two words. ``` DADDX.A #10h,&DECCNTR ; Add 10 to 20-bit BCD counter ``` # **Example** The eight-digit BCD number contained in 20-bit addresses BCD and BCD+2 is added decimally to an eight-digit BCD number contained in R4 and R5 (BCD+2 and R5 contain the MSDs). #### **Example** The two-digit BCD number contained in 20-bit address BCD is added decimally to a two-digit BCD number contained in R4. ``` CLRC ; Clear carry DADDX.B BCD,R4 ; Add BCD to R4 decimally. ; R4: 000ddh ``` ### 4.6.3.12 DECX \* **DECX.A** Decrement destination address-word \* **DECX.[W]** Decrement destination word \* **DECX.B** Decrement destination byte Syntax DECX.A dst DECX dst Of DECX.W dst $\begin{array}{c} \text{DECX.B dst} \\ \text{Operation} & \text{dst} - 1 \rightarrow \text{dst} \\ \text{Emulation} & \text{SUBX.A #1,dst} \\ \text{SUBX #1,dst} \end{array}$ SUBX.B #1,dst **Description** The destination operand is decremented by one. The original contents are lost. Status Bits N: Set if result is negative, reset if positive Z: Set if dst contained 1, reset otherwise C: Reset if dst contained 0, set otherwise V: Set if an arithmetic overflow occurs, otherwise reset Mode Bits OSCOFF, CPUOFF, and GIE are not affected. Example RAM address-word TONI is decremented by one. DECX.A TONI ; Decrement TONI ### 4.6.3.13 DECDX Operation **Emulation** \* **DECDX.A** Double-decrement destination address-word \* **DECDX.[W]** Double-decrement destination word Double-decrement destination byte Syntax DECDX.A dst DECDX dst Of DECDX.W dst DECDX.B dst $dst - 2 \rightarrow dst$ SUBX.A #2,dst SUBX #2,dst SUBX.B #2,dst **Description** The destination operand is decremented by two. The original contents are lost. Status Bits N: Set if result is negative, reset if positive Z: Set if dst contained 2, reset otherwise C: Reset if dst contained 0 or 1, set otherwise V: Set if an arithmetic overflow occurs, otherwise reset Mode Bits OSCOFF, CPUOFF, and GIE are not affected. Example RAM address-word TONI is decremented by two. DECDX.A TONI ; Decrement TONI Operation **Emulation** ### 4.6.3.14 INCX \* INCX.A Increment destination address-word \* INCX.[W] Increment destination word \* INCX.B Increment destination byte Syntax INCX.A dst INCX dst Or INCX.W dst INCX.B dst $dst + 1 \rightarrow dst$ ADDX.A #1,dst ADDX #1,dst ADDX.B #1,dst **Description** The destination operand is incremented by one. The original contents are lost. Status Bits N: Set if result is negative, reset if positive Z: Set if dst contained 0FFFFh, reset otherwise Set if dst contained 0FFFh, reset otherwise Set if dst contained 0FFh, reset otherwise C: Set if dst contained 0FFFFh, reset otherwise Set if dst contained 0FFFh, reset otherwise Set if dst contained 0FFh, reset otherwise V: Set if dst contained 07FFFh, reset otherwise Set if dst contained 07FFFh, reset otherwise Set if dst contained 07Fh, reset otherwise Mode Bits OSCOFF, CPUOFF, and GIE are not affected. Example RAM address-wordTONI is incremented by one. INCX.A TONI ; Increment TONI (20-bits) ### 4.6.3.15 INCDX Operation \* INCDX.A Double-increment destination address-word \* INCDX.[W] Double-increment destination word \* INCDX.B Double-increment destination byte Syntax INCDX.A dst INCDX dst Of INCDX.W dst INCDX.B dst $dst + 2 \rightarrow dst$ Emulation ADDX.A #2,dst ADDX #2,dst ADDX.B #2,dst **Description** The destination operand is incremented by two. The original contents are lost. Status Bits N: Set if result is negative, reset if positive Z: Set if dst contained 0FFFEh, reset otherwise Set if dst contained 0FFFEh, reset otherwise Set if dst contained 0FEh, reset otherwise C: Set if dst contained 0FFFEh or 0FFFFh, reset otherwise Set if dst contained 0FFFEh or 0FFFh, reset otherwise Set if dst contained 0FEh or 0FFh, reset otherwise V: Set if dst contained 07FFFEh or 07FFFFh, reset otherwise Set if dst contained 07FFEh or 07FFFh, reset otherwise Set if dst contained 07Eh or 07Fh, reset otherwise **Mode Bits** OSCOFF, CPUOFF, and GIE are not affected. **Example** RAM byte LEO is incremented by two; PC points to upper memory. INCDX.B LEO ; Increment LEO by two ### 4.6.3.16 INVX \* INVX.A Invert destination \* INVX.[W] Invert destination \* INVX.B Invert destination Syntax INVX.A dst INVX dst Or INVX.W dst INVX.B dst **Operation** .NOT.dst $\rightarrow$ dst Emulation XORX.A #0FFFFFh,dst XORX #0FFFFh,dst XORX.B #0FFh,dst **Description** The destination operand is inverted. The original contents are lost. Status Bits N: Set if result is negative, reset if positive Z: Set if dst contained 0FFFFh, reset otherwise Set if dst contained 0FFFh, reset otherwise Set if dst contained 0FFh, reset otherwise C: Set if result is not zero, reset otherwise ( = .NOT. Zero) V: Set if initial destination operand was negative, otherwise reset Mode Bits OSCOFF, CPUOFF, and GIE are not affected. Example 20-bit content of R5 is negated (2s complement). INVX.A R5 ; Invert R5 INCX.A R5 ; R5 is now negated **Example** Content of memory byte LEO is negated. PC is pointing to upper memory. INVX.B LEO ; Invert LEO INCX.B LEO ; MEM(LEO) is negated ### 4.6.3.17 MOVX MOVX.A Move source address-word to destination address-word MOVX.[W] Move source word to destination word MOVX.B Move source byte to destination byte Syntax MOVX.A src,dst MOVX src,dst Of MOVX.W src,dst MOVX.B src,dst **Operation** $\operatorname{src} \to \operatorname{dst}$ **Description** The source operand is copied to the destination. The source operand is not affected. Both operands may be located in the full address space. Status Bits N: Not affected Z: Not affectedC: Not affectedV: Not affected Mode Bits OSCOFF, CPUOFF, and GIE are not affected. **Example** Move a 20-bit constant 18000h to absolute address-word EDE ``` MOVX.A #018000h, &EDE ; Move 18000h to EDE ``` ### **Example** The contents of table EDE (word data, 20-bit addresses) are copied to table TOM. The length of the table is 030h words. ``` MOVA #EDE,R10 ; Prepare pointer (20-bit address) Loop MOVX.W @R10+,TOM-EDE-2(R10) ; R10 points to both tables. ; R10+2 CMPA #EDE+60h,R10 ; End of table reached? JLO Loop ; Not yet ... ; Copy completed ``` #### **Example** The contents of table EDE (byte data, 20-bit addresses) are copied to table TOM. The length of the table is 020h bytes. ``` MOVA #EDE,R10 ; Prepare pointer (20-bit) MOV #20h,R9 ; Prepare counter @R10+,TOM-EDE-2(R10) Loop MOVX.W ; R10 points to both tables. ; R10+1 DEC R9 ; Decrement counter JNZ Loop ; Not yet done ; Copy completed ``` Ten of the 28 possible addressing combinations of the MOVX.A instruction can use the MOVA instruction. This saves two bytes and code cycles. Examples for the addressing combinations are: | MOVX.A | Rsrc,Rdst | MOVA | Rsrc,Rdst | ; | Reg/Reg | |--------|-------------|------|-------------|---|--------------------| | MOVX.A | #imm20,Rdst | MOVA | #imm20,Rdst | ; | Immediate/Reg | | MOVX.A | &abs20,Rdst | MOVA | &abs20,Rdst | ; | Absolute/Reg | | MOVX.A | @Rsrc,Rdst | MOVA | @Rsrc,Rdst | ; | Indirect/Reg | | MOVX.A | @Rsrc+,Rdst | MOVA | @Rsrc+,Rdst | ; | Indirect, Auto/Reg | | MOVX.A | Rsrc,&abs20 | MOVA | Rsrc,&abs20 | ; | Reg/Absolute | The next four replacements are possible only if 16-bit indexes are sufficient for the addressing: | MOVX.A | z20(Rsrc),Rdst | MOVA | z16(Rsrc),Rdst | ; | Indexed/Reg | |--------|----------------|------|----------------|---|--------------| | MOVX.A | Rsrc,z20(Rdst) | MOVA | Rsrc,z16(Rdst) | ; | Reg/Indexed | | MOVX.A | symb20,Rdst | MOVA | symb16,Rdst | ; | Symbolic/Reg | | MOVX.A | Rsrc,symb20 | MOVA | Rsrc,symb16 | ; | Reg/Symbolic | ### 4.6.3.18 POPM **POPM.A** Restore n CPU registers (20-bit data) from the stack **POPM.[W]** Restore n CPU registers (16-bit data) from the stack Syntax POPM.A #n,Rdst $1 \le n \le 16$ POPM.W #n,Rdst Or POPM #n,Rdst $1 \le n \le 16$ Operation POPM.A: Restore the register values from stack to the specified CPU registers. The SP is incremented by four for each register restored from stack. The 20-bit values from stack (two words per register) are restored to the registers. POPM.W: Restore the 16-bit register values from stack to the specified CPU registers. The SP is incremented by two for each register restored from stack. The 16-bit values from stack (one word per register) are restored to the CPU registers. Note: This instruction does not use the extension word. **Description** POPM.A: The CPU registers pushed on the stack are moved to the extended CPU registers, starting with the CPU register (Rdst - n + 1). The SP is incremented by (n $\times$ 4) after the operation. POPM.W: The 16-bit registers pushed on the stack are moved back to the CPU registers, starting with CPU register (Rdst - n + 1). The SP is incremented by (n × 2) after the instruction. The MSBs (Rdst.19:16) of the restored CPU registers are cleared. **Status Bits** Status bits are not affected, except SR is included in the operation. **Mode Bits** OSCOFF, CPUOFF, and GIE are not affected. **Example** Restore the 20-bit registers R9, R10, R11, R12, R13 from the stack POPM.A #5,R13 ; Restore R9, R10, R11, R12, R13 **Example** Restore the 16-bit registers R9, R10, R11, R12, R13 from the stack. POPM.W #5,R13 ; Restore R9, R10, R11, R12, R13 ### 4.6.3.19 PUSHM **PUSHM.A** Save n CPU registers (20-bit data) on the stack **PUSHM.[W]** Save n CPU registers (16-bit words) on the stack Syntax PUSHM.A #n,Rdst $1 \le n \le 16$ PUSHM.W #n,Rdst Or PUSHM #n,Rdst $1 \le n \le 16$ Operation PUSHM.A: Save the 20-bit CPU register values on the stack. The SP is decremented by four for each register stored on the stack. The MSBs are stored first (higher address). PUSHM.W: Save the 16-bit CPU register values on the stack. The SP is decremented by two for each register stored on the stack. **Description** PUSHM.A: The n CPU registers, starting with Rdst backwards, are stored on the stack. The SP is decremented by $(n \times 4)$ after the operation. The data (Rn.19:0) of the pushed CPU registers is not affected. PUSHM.W: The n registers, starting with Rdst backwards, are stored on the stack. The SP is decremented by $(n \times 2)$ after the operation. The data (Rn.19:0) of the pushed CPU registers is not affected. Note: This instruction does not use the extension word. Status Bits Status bits are not affected. **Mode Bits** OSCOFF, CPUOFF, and GIE are not affected. **Example** Save the five 20-bit registers R9, R10, R11, R12, R13 on the stack PUSHM.A #5,R13 ; Save R13, R12, R11, R10, R9 **Example** Save the five 16-bit registers R9, R10, R11, R12, R13 on the stack PUSHM.W #5,R13; Save R13, R12, R11, R10, R9 ### 4.6.3.20 POPX \* **POPX.A** Restore single address-word from the stack \* POPX.[W] Restore single word from the stack \* POPX.B Restore single byte from the stack Syntax POPX.A dst POPX dst Or POPX.W dst POPX.B dst **Operation** Restore the 8-, 16-, 20-bit value from the stack to the destination. 20-bit addresses are possible. The SP is incremented by two (byte and word operands) and by four (address-word operand). **Emulation** MOVX(.B,.A) @SP+,dst **Description** The item on TOS is written to the destination operand. Register mode, Indexed mode, Symbolic mode, and Absolute mode are possible. The SP is incremented by two or four. Note: the SP is incremented by two also for byte operations. **Status Bits** Status bits are not affected. **Mode Bits** OSCOFF, CPUOFF, and GIE are not affected. **Example** Write the 16-bit value on TOS to the 20-bit address &EDE POPX.W &EDE ; Write word to address EDE **Example** Write the 20-bit value on TOS to R9 POPX.A R9 ; Write address-word to R9 ## 4.6.3.21 PUSHX **PUSHX.A** Save single address-word to the stack PUSHX.[W] Save single word to the stack PUSHX.B Save single byte to the stack Syntax PUSHX.A src PUSHX src Of PUSHX.W src PUSHX.B src **Operation** Save the 8-, 16-, 20-bit value of the source operand on the TOS. 20-bit addresses are possible. The SP is decremented by two (byte and word operands) or by four (address- word operand) before the write operation. **Description** The SP is decremented by two (byte and word operands) or by four (address-word operand). Then the source operand is written to the TOS. All seven addressing modes are possible for the source operand. Status Bits Status bits are not affected. Mode Bits OSCOFF, CPUOFF, and GIE are not affected. **Example** Save the byte at the 20-bit address &EDE on the stack PUSHX.B &EDE ; Save byte at address EDE **Example** Save the 20-bit value in R9 on the stack. PUSHX.A R9 ; Save address-word in R9 ### 4.6.3.22 RLAM **RLAM.A** Rotate left arithmetically the 20-bit CPU register content RLAM.[W] Rotate left arithmetically the 16-bit CPU register content Syntax RLAM.A #n, Rdst $1 \le n \le 4$ RLAM.W #n, Rdst Of RLAM #n, Rdst $1 \le n \le 4$ **Operation** $C \leftarrow MSB \leftarrow MSB-1 \dots LSB+1 \leftarrow LSB \leftarrow 0$ **Description** The destination operand is shifted arithmetically left one, two, three, or four positions as shown in Figure 4-44. RLAM works as a multiplication (signed and unsigned) with 2, 4, 8, or 16. The word instruction RLAM.W clears the bits Rdst.19:16. Note: This instruction does not use the extension word. Status Bits N: Set if result is negative .A: Rdst.19 = 1, reset if Rdst.19 = 0 .W: Rdst.15 = 1, reset if Rdst.15 = 0 Z: Set if result is zero, reset otherwise C: Loaded from the MSB (n = 1), MSB-1 (n = 2), MSB-2 (n = 3), MSB-3 (n = 4) V: Undefined Mode Bits OSCOFF, CPUOFF, and GIE are not affected. **Example** The 20-bit operand in R5 is shifted left by three positions. It operates equal to an arithmetic multiplication by 8. Figure 4-44. Rotate Left Arithmetically—RLAM[.W] and RLAM.A ## 4.6.3.23 RLAX \* **RLAX.A** Rotate left arithmetically address-word \* RLAX.[W] Rotate left arithmetically word \* RLAX.B Rotate left arithmetically byte Syntax RLAX.A dst RLAX dst Of RLAX.W dst RLAX.B dst **Operation** $C \leftarrow MSB \leftarrow MSB-1 \dots LSB+1 \leftarrow LSB \leftarrow 0$ **Emulation** ADDX.A dst,dst ADDX dst,dst ADDX.B dst,dst **Description** The destination operand is shifted left one position as shown in Figure 4-45. The MSB is shifted into the carry bit (C) and the LSB is filled with 0. The RLAX instruction acts as a signed multiplication by 2. Status Bits N: Set if result is negative, reset if positive Z: Set if result is zero, reset otherwise C: Loaded from the MSB V: Set if an arithmetic overflow occurs: the initial value is 040000h ≤ dst < 0C0000h; reset otherwise Set if an arithmetic overflow occurs: the initial value is 04000h ≤ dst < 0C000h; reset otherwise Set if an arithmetic overflow occurs: the initial value is 040h ≤ dst < 0C0h; reset otherwise **Mode Bits** OSCOFF, CPUOFF, and GIE are not affected. **Example** The 20-bit value in R7 is multiplied by 2 RLAX.A R7 ; Shift left R7 (20-bit) Figure 4-45. Destination Operand-Arithmetic Shift Left ### 4.6.3.24 RLCX \* RLCX.A Rotate left through carry address-word \* RLCX.[W] Rotate left through carry word \* RLCX.B Rotate left through carry byte Syntax RLCX.A dst RLCX dst Of RLCX.W dst RLCX.B dst **Operation** $C \leftarrow MSB \leftarrow MSB-1 \dots LSB+1 \leftarrow LSB \leftarrow C$ Emulation ADDCX.A dst,dst ADDCX dst,dst ADDCX.B dst,dst **Description** The destination operand is shifted left one position as shown in Figure 4-46. The carry bit (C) is shifted into the LSB and the MSB is shifted into the carry bit (C). Status Bits N: Set if result is negative, reset if positive Z: Set if result is zero, reset otherwise C: Loaded from the MSB V: Set if an arithmetic overflow occurs: the initial value is 040000h ≤ dst < 0C0000h; reset otherwise Set if an arithmetic overflow occurs: the initial value is 04000h ≤ dst < 0C000h; reset otherwise Set if an arithmetic overflow occurs: the initial value is 040h ≤ dst < 0C0h; reset otherwise Mode Bits OSCOFF, CPUOFF, and GIE are not affected. Example The 20-bit value in R5 is shifted left one position. RLCX.A R5 ; $(R5 \times 2) + C -> R5$ **Example** The RAM byte LEO is shifted left one position. PC is pointing to upper memory. RLCX.B LEO ; RAM(LEO) x 2 + C -> RAM(LEO) Figure 4-46. Destination Operand-Carry Left Shift ### 4.6.3.25 RRAM RRAM.A Rotate right arithmetically the 20-bit CPU register content RRAM.[W] Rotate right arithmetically the 16-bit CPU register content Syntax RRAM.A #n,Rdst $1 \le n \le 4$ RRAM.W #n,Rdst Of RRAM #n,Rdst $1 \le n \le 4$ $\textbf{Operation} \qquad \text{MSB} \rightarrow \text{MSB} \rightarrow \text{MSB-1} \ ... \ \text{LSB+1} \rightarrow \text{LSB} \rightarrow \text{C}$ **Description** The destination operand is shifted right arithmetically by one, two, three, or four bit positions as shown in Figure 4-47. The MSB retains its value (sign). RRAM operates equal to a signed division by 2, 4, 8, or 16. The MSB is retained and shifted into MSB-1. The LSB+1 is shifted into the LSB, and the LSB is shifted into the carry bit C. The word instruction RRAM.W clears the bits Rdst.19:16. Note: This instruction does not use the extension word. Status Bits N: Set if result is negative .A: Rdst.19 = 1, reset if Rdst.19 = 0 .W: Rdst.15 = 1, reset if Rdst.15 = 0 Z: Set if result is zero, reset otherwise C: Loaded from the LSB (n = 1), LSB+1 (n = 2), LSB+2 (n = 3), or LSB+3 (n = 4) V: Reset **Mode Bits** OSCOFF, CPUOFF, and GIE are not affected. **Example** The signed 20-bit number in R5 is shifted arithmetically right two positions. RRAM.A #2,R5 ; R5/4 -> R5 # **Example** The signed 20-bit value in R15 is multiplied by 0.75. $(0.5 + 0.25) \times R15$ . ``` PUSHM.A #1,R15 ; Save extended R15 on stack RRAM.A #1,R15 ; R15 y 0.5 -> R15 @SP+,R15 ADDX.A ; R15 y 0.5 + R15 = 1.5 y R15 \rightarrow R15 #1,R15 ; (1.5 \text{ y R15}) \text{ y } 0.5 = 0.75 \text{ y R15} \rightarrow \text{R15} RRAM.A 19 15 0 0000 MSB LSB 0 19 MSB LSB ``` Figure 4-47. Rotate Right Arithmetically RRAM[.W] and RRAM.A ### 4.6.3.26 RRAX RRAX.A Rotate right arithmetically the 20-bit operand RRAX.[W] Rotate right arithmetically the 16-bit operand RRAX.B Rotate right arithmetically the 8-bit operand Syntax RRAX.A Rdst RRAX.W Rdst RRAX Rdst RRAX.B Rdst RRAX.A dst RRAX dst Or RRAX.W dst RRAX.B dst Operation $MSB \rightarrow MSB \rightarrow MSB-1 \dots LSB+1 \rightarrow LSB \rightarrow C$ **Description** Register mode for the destination: the destination operand is shifted right by one bit position as shown in Figure 4-48. The MSB retains its value (sign). The word instruction RRAX.W clears the bits Rdst.19:16, the byte instruction RRAX.B clears the bits Rdst.19:8. The MSB retains its value (sign), the LSB is shifted into the carry bit. RRAX here operates equal to a signed division by 2. All other modes for the destination: the destination operand is shifted right arithmetically by one bit position as shown in Figure 4-49. The MSB retains its value (sign), the LSB is shifted into the carry bit. RRAX here operates equal to a signed division by 2. All addressing modes, with the exception of the Immediate mode, are possible in the full memory. **Status Bits** N: Set if result is negative, reset if positive .A: dst.19 = 1, reset if dst.19 = 0 .W: dst.15 = 1, reset if dst.15 = 0 .B: dst.7 = 1, reset if dst.7 = 0 Z: Set if result is zero, reset otherwise C: Loaded from the LSB V: Reset Mode Bits OSCOFF, CPUOFF, and GIE are not affected. Example The signed 20-bit number in R5 is shifted arithmetically right four positions. RPT #4 RRAX.A R5 ; R5/16 -> R5 **Example** The signed 8-bit value in EDE is multiplied by 0.5. Figure 4-48. Rotate Right Arithmetically RRAX(.B,.A) - Register Mode Figure 4-49. Rotate Right Arithmetically RRAX(.B,.A) - Non-Register Mode ### 4.6.3.27 RRCM RRCM.A Rotate right through carry the 20-bit CPU register content RRCM.[W] Rotate right through carry the 16-bit CPU register content Syntax RRCM.A #n,Rdst $1 \le n \le 4$ RRCM.W #n,Rdst Of RRCM #n,Rdst $1 \le n \le 4$ $\textbf{Operation} \qquad \qquad C \to MSB \to MSB-1 \ ... \ LSB+1 \to LSB \to C$ **Description** The destination operand is shifted right by one, two, three, or four bit positions as shown in Figure 4-50. The carry bit C is shifted into the MSB, the LSB is shifted into the carry bit. The word instruction RRCM.W clears the bits Rdst.19:16. Note: This instruction does not use the extension word. Status Bits N: Set if result is negative .A: Rdst.19 = 1, reset if Rdst.19 = 0 .W: Rdst.15 = 1, reset if Rdst.15 = 0 Z: Set if result is zero, reset otherwise C: Loaded from the LSB (n = 1), LSB+1 (n = 2), LSB+2 (n = 3), or LSB+3 (n = 4) V: Reset **Mode Bits** OSCOFF, CPUOFF, and GIE are not affected. **Example** The address-word in R5 is shifted right by three positions. The MSB–2 is loaded with 1. ``` SETC ; Prepare carry for MSB-2 RRCM.A \#3,R5 ; R5 = R5 \gg 3 + 20000h ``` # Example The word in R6 is shifted right by two positions. The MSB is loaded with the LSB. The MSB–1 is loaded with the contents of the carry flag. Figure 4-50. Rotate Right Through Carry RRCM[.W] and RRCM.A #### 4.6.3.28 RRCX RRCX.A Rotate right through carry the 20-bit operand RRCX.[W] Rotate right through carry the 16-bit operand RRCX.B Rotate right through carry the 8-bit operand Syntax RRCX.A Rdst RRCX.W Rdst RRCX Rdst RRCX.B Rdst RRCX.A dst RRCX dst Or RRCX.W dst RRCX.B dst Operation $C \rightarrow MSB \rightarrow MSB-1 \dots LSB+1 \rightarrow LSB \rightarrow C$ Description Register mode for the destination: the destination operand is shifted right by one bit position as shown in Figure 4-51. The word instruction RRCX.W clears the bits Rdst.19:16, the byte instruction RRCX.B clears the bits Rdst.19:8. The carry bit C is shifted into the MSB, the LSB is shifted into the carry bit. All other modes for the destination: the destination operand is shifted right by one bit position as shown in Figure 4-52. The carry bit C is shifted into the MSB, the LSB is shifted into the carry bit. All addressing modes, with the exception of the Immediate mode, are possible in the full memory. The 20-bit operand at address EDE is shifted right by one position. The MSB is loaded **Status Bits** N: Set if result is negative .A: dst.19 = 1, reset if dst.19 = 0.W: dst.15 = 1, reset if dst.15 = 0.B: dst.7 = 1, reset if dst.7 = 0 Z: Set if result is zero, reset otherwise C: Loaded from the LSB V: Reset Mode Bits Example OSCOFF, CPUOFF, and GIE are not affected. with 1. SETC ; Prepare carry for MSB RRCX.A EDE ; EDE = EDE » 1 + 80000h **Example** The word in R6 is shifted right by 12 positions. Figure 4-51. Rotate Right Through Carry RRCX(.B,.A) - Register Mode Figure 4-52. Rotate Right Through Carry RRCX(.B,.A) - Non-Register Mode #### 4.6.3.29 RRUM **RRUM.A** Rotate right through carry the 20-bit CPU register content RRUM.[W] Rotate right through carry the 16-bit CPU register content Syntax RRUM.A #n,Rdst $1 \le n \le 4$ RRUM.W #n,Rdst Of RRUM #n,Rdst $1 \le n \le 4$ **Operation** $0 \rightarrow MSB \rightarrow MSB-1 \dots LSB+1 \rightarrow LSB \rightarrow C$ **Description** The destination operand is shifted right by one, two, three, or four bit positions as shown in Figure 4-53. Zero is shifted into the MSB, the LSB is shifted into the carry bit. RRUM works like an unsigned division by 2, 4, 8, or 16. The word instruction RRUM.W clears the bits Rdst.19:16. Note: This instruction does not use the extension word. Status Bits N: Set if result is negative .A: Rdst.19 = 1, reset if Rdst.19 = 0 .W: Rdst.15 = 1, reset if Rdst.15 = 0 Z: Set if result is zero, reset otherwise C: Loaded from the LSB (n = 1), LSB+1 (n = 2), LSB+2 (n = 3), or LSB+3 (n = 4) V: Reset Mode Bits OSCOFF, CPUOFF, and GIE are not affected. Example The unsigned address-word in R5 is divided by 16. RRUM.A #4,R5 ; $R5 = R5 \gg 4. R5/16$ **Example** The word in R6 is shifted right by one bit. The MSB R6.15 is loaded with 0. Figure 4-53. Rotate Right Unsigned RRUM[.W] and RRUM.A #### 4.6.3.30 RRUX RRUX.A Shift right unsigned the 20-bit CPU register content Shift right unsigned the 16-bit CPU register content Shift right unsigned the 8-bit CPU register content Shift right unsigned the 8-bit CPU register content Syntax RRUX.A Rdst RRUX.W Rdst RRUX Rdst RRUX.B Rdst $\textbf{Operation} \qquad \quad \text{C=0} \rightarrow \text{MSB} \rightarrow \text{MSB-1} \; ... \; \text{LSB+1} \rightarrow \text{LSB} \rightarrow \text{C}$ **Description** RRUX is valid for register mode only: the destination operand is shifted right by one bit position as shown in Figure 4-54. The word instruction RRUX.W clears the bits Rdst.19:16. The byte instruction RRUX.B clears the bits Rdst.19:8. Zero is shifted into the MSB, the LSB is shifted into the carry bit. Status Bits N: Set if result is negative .A: dst.19 = 1, reset if dst.19 = 0.W: dst.15 = 1, reset if dst.15 = 0.B: dst.7 = 1, reset if dst.7 = 0 Z: Set if result is zero, reset otherwise C: Loaded from the LSB V: Reset Mode Bits OSCOFF, CPUOFF, and GIE are not affected. **Example** The word in R6 is shifted right by 12 positions. RPT #12 RRUX.W R6 ; R6 = R6 » 12. R6.19:16 = 0 Figure 4-54. Rotate Right Unsigned RRUX(.B,.A) – Register Mode #### 4.6.3.31 SBCX \* SBCX.A Subtract borrow (.NOT. carry) from destination address-word \* **SBCX.[W]** Subtract borrow (.NOT. carry) from destination word \* **SBCX.B** Subtract borrow (.NOT. carry) from destination byte Syntax SBCX.A dst SBCX dst Or SBCX.W dst SBCX.B dst **Operation** $dst + 0FFFFFh + C \rightarrow dst$ $dst + 0FFFFh + C \rightarrow dst$ $dst + 0FFh + C \rightarrow dst$ Emulation SBCX.A #0,dst SBCX #0,dst SBCX.B #0,dst **Description** The carry bit (C) is added to the destination operand minus one. The previous contents of the destination are lost. Status Bits N: Set if result is negative, reset if positive Z: Set if result is zero, reset otherwise C: Set if there is a carry from the MSB of the result, reset otherwise Set to 1 if no borrow, reset if borrow V: Set if an arithmetic overflow occurs, reset otherwise Mode Bits OSCOFF, CPUOFF, and GIE are not affected. **Example** The 8-bit counter pointed to by R13 is subtracted from a 16-bit counter pointed to by R12. SUBX.B @R13,0(R12) ; Subtract LSDs SBCX.B 1(R12) ; Subtract carry from MSD #### NOTE: Borrow implementation The borrow is treated as a .NOT. carry: | Borrow | Carry Bit | |--------|-----------| | Yes | 0 | | No | 1 | #### 4.6.3.32 SUBX **SUBX.A** Subtract source address-word from destination address-word **SUBX.[W]** Subtract source word from destination word **SUBX.B** Subtract source byte from destination byte Syntax SUBX.A src,dst SUBX src,dst Of SUBX.W src,dst SUBX.B src,dst Operation $(.not. src) + 1 + dst \rightarrow dst$ or $dst - src \rightarrow dst$ **Description** The source operand is subtracted from the destination operand. This is done by adding the 1s complement of the source + 1 to the destination. The source operand is not affected. The result is written to the destination operand. Both operands may be located in the full address space. **Status Bits** N: Set if result is negative (src > dst), reset if positive (src $\leq$ dst) Z: Set if result is zero (src = dst), reset otherwise (src $\neq$ dst) C: Set if there is a carry from the MSB, reset otherwise V: Set if the subtraction of a negative source operand from a positive destination operand delivers a negative result, or if the subtraction of a positive source operand from a negative destination operand delivers a positive result, reset otherwise (no overflow) **Mode Bits** OSCOFF, CPUOFF, and GIE are not affected. **Example** A 20-bit constant 87654h is subtracted from EDE (LSBs) and EDE+2 (MSBs). ``` SUBX.A #87654h,EDE ; Subtract 87654h from EDE+2|EDE ``` # **Example** A table word pointed to by R5 (20-bit address) is subtracted from R7. Jump to label TONI if R7 contains zero after the instruction. R5 is auto-incremented by two. R7.19:16 = 0. ``` SUBX.W @R5+,R7 ; Subtract table number from R7. R5 + 2 JZ TONI ; R7 = @R5 (before subtraction) ... ; R7 <> @R5 (before subtraction) ``` #### **Example** Byte CNT is subtracted from the byte R12 points to in the full address space. Address of CNT is within PC $\pm$ 512 K. ``` SUBX.B CNT,0(R12) ; Subtract CNT from @R12 ``` Note: Use SUBA for the following two cases for better density and execution. ``` SUBX.A Rsrc,Rdst SUBX.A #imm20,Rdst ``` # 4.6.3.33 SUBCX SUBCX.A Subtract source address-word with carry from destination address-word SUBCX.[W] SUBCX.B Subtract source word with carry from destination word Subtract source byte with carry from destination byte Syntax SUBCX.A src,dst SUBCX src,dst Of SUBCX.W src,dst SUBCX.B src,dst Operation $(.not. src) + C + dst \rightarrow dst$ or $dst - (src - 1) + C \rightarrow dst$ Description The source operand is subtracted from the destination operand. This is made by adding the 1s complement of the source + carry to the destination. The source operand is not affected, the result is written to the destination operand. Both operands may be located in the full address space. **Status Bits** N: Set if result is negative (MSB = 1), reset if positive (MSB = 0) Z: Set if result is zero, reset otherwise C: Set if there is a carry from the MSB, reset otherwise V: Set if the subtraction of a negative source operand from a positive destination operand delivers a negative result, or if the subtraction of a positive source operand from a negative destination operand delivers a positive result, reset otherwise (no overflow). **Mode Bits** OSCOFF, CPUOFF, and GIE are not affected. **Example** A 20-bit constant 87654h is subtracted from R5 with the carry from the previous instruction. ``` SUBCX.A #87654h,R5 ; Subtract 87654h + C from R5 ``` #### **Example** A 48-bit number (3 words) pointed to by R5 (20-bit address) is subtracted from a 48-bit counter in RAM, pointed to by R7. R5 auto-increments to point to the next 48-bit number. ``` SUBX.W @R5+,0(R7) ; Subtract LSBs. R5 + 2 SUBCX.W @R5+,2(R7) ; Subtract MIDs with C. R5 + 2 SUBCX.W @R5+,4(R7) ; Subtract MSBs with C. R5 + 2 ``` #### **Example** Byte CNT is subtracted from the byte R12 points to. The carry of the previous instruction is used. 20-bit addresses. ``` SUBCX.B &CNT,0(R12); Subtract byte CNT from @R12 ``` #### 4.6.3.34 SWPBX SWPBX.A Swap bytes of lower word SWPBX.[W] Swap bytes of word Syntax SWPBX.A dst SWPBX dst Or SWPBX.W dst **Operation** $dst.15:8 \leftrightarrow dst.7:0$ **Description** Register mode: Rn.15:8 are swapped with Rn.7:0. When the .A extension is used, Rn.19:16 are unchanged. When the .W extension is used, Rn.19:16 are cleared. Other modes: When the .A extension is used, bits 31:20 of the destination address are cleared, bits 19:16 are left unchanged, and bits 15:8 are swapped with bits 7:0. When the .W extension is used, bits 15:8 are swapped with bits 7:0 of the addressed word. Status Bits Status bits are not affected. Mode Bits OSCOFF, CPUOFF, and GIE are not affected. Example Exchange the bytes of RAM address-word EDE MOVX.A #23456h,&EDE ; 23456h -> EDE SWPBX.A EDE ; 25634h -> EDE # **Example** Exchange the bytes of R5 MOVA #23456h,R5 ; 23456h -> R5 SWPBX.W R5 ; 05634h -> R5 ### Before SWPBX.A Figure 4-55. Swap Bytes SWPBX.A Register Mode 8 7 20 19 16 15 Figure 4-56. Swap Bytes SWPBX.A In Memory 0 Figure 4-57. Swap Bytes SWPBX[.W] Register Mode Figure 4-58. Swap Bytes SWPBX[.W] In Memory #### 4.6.3.35 SXTX **SXTX.A** Extend sign of lower byte to address-word **SXTX.[W]** Extend sign of lower byte to word Syntax SXTX.A dst SXTX dst Or SXTX.W dst **Operation** dst.7 → dst.15:8, Rdst.7 → Rdst.19:8 (Register mode) **Description** Register mode: The sign of the low byte of the operand (Rdst.7) is extended into the bits Rdst.19:8. Other modes: SXTX.A: the sign of the low byte of the operand (dst.7) is extended into dst.19:8. The bits dst.31:20 are cleared. SXTX[.W]: the sign of the low byte of the operand (dst.7) is extended into dst.15:8. Status Bits N: Set if result is negative, reset otherwise Z: Set if result is zero, reset otherwise C: Set if result is not zero, reset otherwise (C = .not.Z) V: Reset Mode Bits OSCOFF, CPUOFF, and GIE are not affected. **Example** The signed 8-bit data in EDE.7:0 is sign extended to 20 bits: EDE.19:8. Bits 31:20 located in EDE+2 are cleared. Figure 4-59. Sign Extend SXTX.A Figure 4-60. Sign Extend SXTX[.W] #### 4.6.3.36 TSTX \* TSTX.A Test destination address-word \* TSTX.[W] Test destination word \* TSTX.B Test destination byte Syntax TSTX.A dst TSTX dst Of TSTX.W dst TSTX.B dst Operation dst + 0FFFFFh + 1 dst + 0FFFFh + 1 dst + 0FFh + 1 Emulation CMPX.A #0,dst CMPX #0,dst CMPX.B #0,dst **Description** The destination operand is compared with zero. The status bits are set according to the result. The destination is not affected. Status Bits N: Set if destination is negative, reset if positive Z: Set if destination contains zero, reset otherwise C: Set V: Reset Mode Bits OSCOFF, CPUOFF, and GIE are not affected. **Example** RAM byte LEO is tested; PC is pointing to upper memory. If it is negative, continue at LEONEG; if it is positive but not zero, continue at LEOPOS. TSTX.B LEO ; Test LEO JN LEONEG ; LEO is negative JZ LEOZERO ; LEO is zero LEOPOS ..... ; LEO is positive but not zero LEONEG ..... ; LEO is negative LEOZERO ..... ; LEO is zero #### 4.6.3.37 XORX XORX.A Exclusive OR source address-word with destination address-word **XORX.[W]** Exclusive OR source word with destination word **XORX.B** Exclusive OR source byte with destination byte Syntax XORX.A src,dst XORX src,dst Of XORX.W src,dst XORX.B src,dst **Description** The source and destination operands are exclusively ORed. The result is placed into the destination. The source operand is not affected. The previous contents of the destination are lost. Both operands may be located in the full address space. **Status Bits** N: Set if result is negative (MSB = 1), reset if positive (MSB = 0) Z: Set if result is zero, reset otherwise C: Set if result is not zero, reset otherwise (carry = .not. Zero) V: Set if both operands are negative (before execution), reset otherwise **Mode Bits** OSCOFF, CPUOFF, and GIE are not affected. **Example** Toggle bits in address-word CNTR (20-bit data) with information in address-word TONI (20-bit address) XORX.A TONI, &CNTR ; Toggle bits in CNTR **Example** A table word pointed to by R5 (20-bit address) is used to toggle bits in R6. XORX.W @R5,R6 ; Toggle bits in R6. R6.19:16 = 0 **Example** Reset to zero those bits in the low byte of R7 that are different from the bits in byte EDE (20-bit address) # 4.6.4 Address Instructions MSP430X address instructions are instructions that support 20-bit operands but have restricted addressing modes. The addressing modes are restricted to the Register mode and the Immediate mode, except for the MOVA instruction. Restricting the addressing modes removes the need for the additional extension-word op-code improving code density and execution time. The MSP430X address instructions are listed and described in the following pages. 265 #### 4.6.4.1 ADDA ADDA Add 20-bit source to a 20-bit destination register Syntax ADDA Rsrc,Rdst ADDA #imm20,Rdst **Operation** $\operatorname{src} + \operatorname{Rdst} \to \operatorname{Rdst}$ **Description** The 20-bit source operand is added to the 20-bit destination CPU register. The previous contents of the destination are lost. The source operand is not affected. **Status Bits** N: Set if result is negative (Rdst.19 = 1), reset if positive (Rdst.19 = 0) Z: Set if result is zero, reset otherwise C: Set if there is a carry from the 20-bit result, reset otherwise V: Set if the result of two positive operands is negative, or if the result of two negative numbers is positive, reset otherwise **Mode Bits** OSCOFF, CPUOFF, and GIE are not affected. **Example** R5 is increased by 0A4320h. The jump to TONI is performed if a carry occurs. ADDA #0A4320h,R5 ; Add A4320h to 20-bit R5 JC TONI ; Jump on carry ... ; No carry occurred #### 4.6.4.2 BRA \* **BRA** Branch to destination **Description** An unconditional branch is taken to a 20-bit address anywhere in the full address space. All seven source addressing modes can be used. The branch instruction is an address-word instruction. If the destination address is contained in a memory location X, it is contained in two ascending words: X (LSBs) and (X + 2) (MSBs). Status Bits N: Not affected Z: Not affectedC: Not affectedV: Not affected **Mode Bits** OSCOFF, CPUOFF, and GIE are not affected. **Examples** Examples for all addressing modes are given. Immediate mode: Branch to label EDE located anywhere in the 20-bit address space or branch directly to address. BRA #EDE ; MOVA #imm20,PC BRA #01AA04h Symbolic mode: Branch to the 20-bit address contained in addresses EXEC (LSBs) and EXEC+2 (MSBs). EXEC is located at the address (PC + X) where X is within +32 K. Indirect addressing. BRA EXEC ; MOVA z16(PC),PC Note: If the 16-bit index is not sufficient, a 20-bit index may be used with the following instruction. ${\tt MOVX.A}$ ${\tt EXEC,PC}$ ; 1M byte range with 20-bit index Absolute mode: Branch to the 20-bit address contained in absolute addresses EXEC (LSBs) and EXEC+2 (MSBs). Indirect addressing. BRA &EXEC ; MOVA &abs20,PC Register mode: Branch to the 20-bit address contained in register R5. Indirect R5. BRA R5 ; MOVA R5, PC Indirect mode: Branch to the 20-bit address contained in the word pointed to by register R5 (LSBs). The MSBs have the address (R5 + 2). Indirect, indirect R5. BRA @R5 ; MOVA @R5,PC Indirect, Auto-Increment mode: Branch to the 20-bit address contained in the words pointed to by register R5 and increment the address in R5 afterwards by 4. The next time the software flow uses R5 as a pointer, it can alter the program execution due to access to the next address in the table pointed to by R5. Indirect, indirect R5. BRA @R5+ ; MOVA @R5+,PC. R5 + 4 Indexed mode: Branch to the 20-bit address contained in the address pointed to by register (R5 + X) (for example, a table with addresses starting at X). (R5 + X) points to the LSBs, (R5 + X + 2) points to the MSBs of the address. X is within R5 + 32 K. Indirect, indirect (R5 + X). BRA X(R5) ; MOVA z16(R5), PC Note: If the 16-bit index is not sufficient, a 20-bit index X may be used with the following instruction: MOVX.A X(R5),PC ; 1M byte range with 20-bit index #### 4.6.4.3 CALLA **CALLA** Call a subroutine CALLA dst **Syntax** Operation dst → tmp 20-bit dst is evaluated and stored $SP - 2 \rightarrow SP$ PC.19:16 → @SP updated PC with return address to TOS (MSBs) $SP - 2 \rightarrow SP$ PC.15:0 → @SP updated PC to TOS (LSBs) tmp → PC saved 20-bit dst to PC Description A subroutine call is made to a 20-bit address anywhere in the full address space. All seven source addressing modes can be used. The call instruction is an address-word instruction. If the destination address is contained in a memory location X, it is contained in two ascending words, X (LSBs) and (X + 2) (MSBs). Two words on the stack are needed for the return address. The return is made with the instruction RETA. **Status Bits** N: Not affected > Z: Not affected Not affected V: Not affected **Mode Bits** OSCOFF, CPUOFF, and GIE are not affected. **Examples** Examples for all addressing modes are given. Immediate mode: Call a subroutine at label EXEC or call directly an address. CALLA #EXEC ; Start address EXEC CALLA #01AA04h ; Start address 01AA04h > Symbolic mode: Call a subroutine at the 20-bit address contained in addresses EXEC (LSBs) and EXEC+2 (MSBs). EXEC is located at the address (PC + X) where X is within +32 K. Indirect addressing. CALLA EXEC ; Start address at @EXEC. z16(PC) Absolute mode: Call a subroutine at the 20-bit address contained in absolute addresses EXEC (LSBs) and EXEC+2 (MSBs). Indirect addressing. CALLA &EXEC ; Start address at @EXEC Register mode: Call a subroutine at the 20-bit address contained in register R5. Indirect CALLA R5 ; Start address at @R5 > Indirect mode: Call a subroutine at the 20-bit address contained in the word pointed to by register R5 (LSBs). The MSBs have the address (R5 + 2). Indirect, indirect R5. CALLA @R5 ; Start address at @R5 Indirect, Auto-Increment mode: Call a subroutine at the 20-bit address contained in the words pointed to by register R5 and increment the 20-bit address in R5 afterwards by 4. The next time the software flow uses R5 as a pointer, it can alter the program execution due to access to the next word address in the table pointed to by R5. Indirect, indirect R5. CALLA @R5+ ; Start address at @R5. R5 + 4 Indexed mode: Call a subroutine at the 20-bit address contained in the address pointed to by register (R5 + X); for example, a table with addresses starting at X. (R5 + X) points to the LSBs, (R5 + X + 2) points to the MSBs of the word address. X is within R5 + 32 K. Indirect, indirect (R5 + X). CALLA X(R5) ; Start address at @(R5+X). z16(R5) # 4.6.4.4 CLRA \* CLRA Clear 20-bit destination register **Description** The destination register is cleared. Status Bits Status bits are not affected. **Example** The 20-bit value in R10 is cleared. CLRA R10 ; 0 -> R10 **Example** CMPA #### 4.6.4.5 CMPA CMPA Compare the 20-bit source with a 20-bit destination register Syntax CMPA Rsrc,Rdst CMPA #imm20,Rdst **Operation** (.not. src) + 1 + Rdst or Rdst – src **Description** The 20-bit source operand is subtracted from the 20-bit destination CPU register. This is made by adding the 1s complement of the source + 1 to the destination register. The result affects only the status bits. Status Bits N: Set if result is negative (src > dst), reset if positive (src ≤ dst) Z: Set if result is zero (src = dst), reset otherwise (src $\neq$ dst) C: Set if there is a carry from the MSB, reset otherwise V: Set if the subtraction of a negative source operand from a positive destination operand delivers a negative result, or if the subtraction of a positive source operand from a negative destination operand delivers a positive result, reset The 20-bit values in R5 and R6 are compared. If R5 is greater than (signed) or equal to ; Compare R6 with R5 (R5 - R6) otherwise (no overflow) **Mode Bits** OSCOFF, CPUOFF, and GIE are not affected. **Example** A 20-bit immediate operand and R6 are compared. If they are equal, the program continues at label EQUAL. CMPA #12345h,R6 ; Compare R6 with 12345h R6, the program continues at label GRE. , - JGE GRE ; R5 >= R6 ... ; R5 < R6 R6,R5 # 4.6.4.6 DECDA \* **DECDA** Double-decrement 20-bit destination register **Description** The destination register is decremented by two. The original contents are lost. Status Bits N: Set if result is negative, reset if positive Z: Set if Rdst contained 2, reset otherwiseC: Reset if Rdst contained 0 or 1, set otherwise V: Set if an arithmetic overflow occurs, otherwise reset Mode Bits OSCOFF, CPUOFF, and GIE are not affected. **Example** The 20-bit value in R5 is decremented by 2. DECDA R5 ; Decrement R5 by two #### 4.6.4.7 INCDA \* **INCDA** Double-increment 20-bit destination register **Description** The destination register is incremented by two. The original contents are lost. Status Bits N: Set if result is negative, reset if positive Z: Set if Rdst contained 0FFFEh, reset otherwise Set if Rdst contained 0FFFEh, reset otherwise Set if Rdst contained 0FEh, reset otherwise C: Set if Rdst contained 0FFFFEh or 0FFFFh, reset otherwise Set if Rdst contained 0FFFEh or 0FFFh, reset otherwise Set if Rdst contained 0FEh or 0FFh, reset otherwise V: Set if Rdst contained 07FFFEh or 07FFFFh, reset otherwise Set if Rdst contained 07FFEh or 07FFFh, reset otherwise Set if Rdst contained 07Eh or 07Fh, reset otherwise Mode Bits OSCOFF, CPUOFF, and GIE are not affected. **Example** The 20-bit value in R5 is incremented by two. INCDA R5 ; Increment R5 by two #### 4.6.4.8 MOVA MOVA Move the 20-bit source to the 20-bit destination Syntax MOVA Rsrc,Rdst MOVA #imm20,Rdst MOVA z16(Rsrc),Rdst MOVA EDE,Rdst MOVA &abs20,Rdst MOVA @Rsrc,Rdst MOVA @Rsrc+,Rdst MOVA Rsrc,z16(Rdst) MOVA Rsrc,&abs20 **Operation** $\operatorname{src} \to \operatorname{Rdst}$ $Rsrc \rightarrow dst$ **Description** The 20-bit source operand is moved to the 20-bit destination. The source operand is not affected. The previous content of the destination is lost. Status Bits N: Not affected Z: Not affectedC: Not affectedV: Not affected **Mode Bits** OSCOFF, CPUOFF, and GIE are not affected. **Examples** Copy 20-bit value in R9 to R8 MOVA R9,R8 ; R9 -> R8 Write 20-bit immediate value 12345h to R12 MOVA #12345h,R12 ; 12345h -> R12 Copy 20-bit value addressed by (R9 + 100h) to R8. Source operand in addresses (R9 + 100h) LSBs and (R9 + 102h) MSBs. MOVA 100h(R9),R8 ; Index: + 32 K. 2 words transferred Move 20-bit value in 20-bit absolute addresses EDE (LSBs) and EDE+2 (MSBs) to R12 MOVA &EDE,R12 ; &EDE -> R12. 2 words transferred Move 20-bit value in 20-bit addresses EDE (LSBs) and EDE+2 (MSBs) to R12. PC index ± 32 K. MOVA EDE,R12 ; EDE -> R12. 2 words transferred Copy 20-bit value R9 points to (20 bit address) to R8. Source operand in addresses @R9 LSBs and @(R9 + 2) MSBs. MOVA @R9,R8 ; @R9 -> R8. 2 words transferred 275 Copy 20-bit value R9 points to (20 bit address) to R8. R9 is incremented by four afterwards. Source operand in addresses @R9 LSBs and @(R9 + 2) MSBs. MOVA @R9+,R8 ; @R9 -> R8. R9 + 4. 2 words transferred. Copy 20-bit value in R8 to destination addressed by (R9 + 100h). Destination operand in addresses @(R9 + 100h) LSBs and @(R9 + 102h) MSBs. MOVA R8,100h(R9) ; Index: +- 32 K. 2 words transferred Move 20-bit value in R13 to 20-bit absolute addresses EDE (LSBs) and EDE+2 (MSBs) MOVA R13, &EDE ; R13 -> EDE. 2 words transferred Move 20-bit value in R13 to 20-bit addresses EDE (LSBs) and EDE+2 (MSBs). PC index $\pm$ 32 K. MOVA R13, EDE ; R13 -> EDE. 2 words transferred #### 4.6.4.9 RETA \* **RETA** Return from subroutine Syntax RETA **Operation** @SP $\rightarrow$ PC.15:0 LSBs (15:0) of saved PC to PC.15:0 $SP + 2 \rightarrow SP$ @SP $\rightarrow$ PC.19:16 MSBs (19:16) of saved PC to PC.19:16 $SP + 2 \rightarrow SP$ Emulation MOVA @SP+,PC **Description** The 20-bit return address information, pushed onto the stack by a CALLA instruction, is restored to the PC. The program continues at the address following the subroutine call. The SR bits SR.11:0 are not affected. This allows the transfer of information with these bits. Status Bits N: Not affected Z: Not affectedC: Not affectedV: Not affected Mode Bits OSCOFF, CPUOFF, and GIE are not affected. **Example** Call a subroutine SUBR from anywhere in the 20-bit address space and return to the address after the CALLA CALLA #SUBR ; Call subroutine starting at SUBR ... ; Return by RETA to here SUBR PUSHM.A #2,R14 ; Save R14 and R13 (20 bit data) ... ; Subroutine code POPM.A #2,R14 ; Restore R13 and R14 (20 bit data) RETA ; Return (to full address space) ### 4.6.4.10 SUBA SUBA Subtract 20-bit source from 20-bit destination register Syntax SUBA Rsrc,Rdst SUBA #imm20,Rdst $\textbf{Operation} \qquad \quad (.not.src) + 1 + Rdst \rightarrow Rdst \quad or \quad Rdst - src \rightarrow Rdst$ **Description** The 20-bit source operand is subtracted from the 20-bit destination register. This is made by adding the 1s complement of the source + 1 to the destination. The result is written to the destination register, the source is not affected. Status Bits N: Set if result is negative (src > dst), reset if positive (src ≤ dst) Z: Set if result is zero (src = dst), reset otherwise (src $\neq$ dst) C: Set if there is a carry from the MSB (Rdst.19), reset otherwise V: Set if the subtraction of a negative source operand from a positive destination operand delivers a negative result, or if the subtraction of a positive source operand from a negative destination operand delivers a positive result, reset otherwise (no overflow) **Mode Bits** OSCOFF, CPUOFF, and GIE are not affected. **Example** The 20-bit value in R5 is subtracted from R6. If a carry occurs, the program continues at label TONI. SUBA R5,R6 ; R6 - R5 -> R6 JC TONI ; Carry occurred ... ; No carry #### 4.6.4.11 TSTA \* **TSTA** Test 20-bit destination register Syntax TSTA Rdst **Operation** dst + 0FFFFFh + 1 dst + 0FFFFh + 1dst + 0FFh + 1 Emulation CMPA #0, Rdst **Description** The destination register is compared with zero. The status bits are set according to the result. The destination register is not affected. **Status Bits** N: Set if destination register is negative, reset if positive Z: Set if destination register contains zero, reset otherwise C: Set V: Reset **Mode Bits** OSCOFF, CPUOFF, and GIE are not affected. **Example** The 20-bit value in R7 is tested. If it is negative, continue at R7NEG; if it is positive but not zero, continue at R7POS. TSTA R7 ; Test R7 JN R7NEG ; R7 is negative JZ R7ZERO ; R7 is zero R7POS ..... ; R7 is positive but not zero R7NEG ..... ; R7 is negative R7ZERO ..... ; R7 is zero 279 # Interrupt Compare Controller (ICC) The Interrupt Compare Controller (ICC) supports a hardware nested interrupt mechanism. The ICC allows all maskable interrupts to be served based on both software configured priority and vector table priority. The hardware nested interrupt can support a small scheduler or complicated task switching in an RTOS. Topic Page | 5.1 | Interrupt Compare Controller (ICC) Introduction | 281 | |-----|-------------------------------------------------|-----| | 5.2 | ICC Operation | 282 | | 5.3 | ICC Registers | 292 | | | | | # 5.1 Interrupt Compare Controller (ICC) Introduction The ICC module allows preemptive interrupt processing according to the programmed interrupt priority with minimal software overhead. This module can be bypassed by clearing the ICCEN bit in the ICCSC register. The ICC module features include: - · Four-level configurable priority for each maskable interrupt source - · Real-time hardware nested interrupt capability - Lower-priority interrupt requests cannot preempt higher-priority interrupts - Higher-priority interrupts can preempt lower-priority interrupts - Reduces design effort to develop a preemptive scheduler or RTOS - ICC can be enabled and disabled in the control register in the SYS module Figure 5-1 shows the ICC block diagram. The ICC includes three major functional blocks: the interrupt level setting (see Section 5.2.2), the interrupt priority level compare (see Section 5.2.3), and the interrupt mask compare register update and virtual stack (see Section 5.2.4). Figure 5-1. Interrupt Compare Controller Block Diagram ICC Operation www.ti.com # 5.2 ICC Operation The ICC module allows nesting of the interrupt service routines for maskable interrupts. 2-bit configuration supports 4-level priority assignments for each maskable interrupt. Only maskable interrupts are managed by the ICC module. System reset and nonmaskable interrupt are served before maskable interrupts. Maskable interrupts are usually triggered by peripherals. Each maskable interrupt source can be disabled individually by an interrupt enable bit in the module. In addition, all maskable interrupts can be disabled by the general interrupt enable (GIE) bit in the status register (SR). When the ICC is enabled, it supports nested interrupts with software-configured four-level priority. The ICC compares both the software priority and the vector table priority for interrupts. Each time, the ICC passes only one interrupt request to the CPU. - If a higher-priority interrupt happens when a lower-priority interrupt is being served, the lower-priority ISR is interrupted, the higher-priority interrupt is served, and then the lower-priority ISR resumes. - If a lower-priority interrupt happens when a higher-priority interrupt is being served, the lower-priority interrupt is not served until the higher-priority interrupt is served. - If two or more interrupts with the same software priority occur at the same time, the vector table priority determines the highest priority. The highest priority interrupt is served, and the others remain pending until that interrupt service routine (ISR) is complete. When the ICC is disabled (or in devices without the ICC), interrupt priority is tied to vector table allocation. Higher priority interrupts are allocated higher addresses, and lower priority interrupts are allocated lower addresses. In this case, when interrupts are enabled (both the individual enable bits and GIE): - When multiple interrupts occur at the same time, the vector table priority in SYS determines which interrupt has the highest priority. The highest priority interrupt is served, and the others remain pending until that ISR is complete. - Any later interrupt can preempt an ongoing ISR, even if the later interrupt is lower priority than the ongoing ISR. In non-nested interrupt processing, is if a higher-priority interrupt happens when lower-priority interrupt is being served, the higher-priority interrupt is not served until the lower-priority ISR is complete. The ICC module works in AM to LPM3 and is not support in LPMx.5 mode. ### 5.2.1 Nested Interrupt and Non-Nested Interrupt Comparison In non-nested interrupt mode, the lower-priority interrupt cannot be preempted by the higher-priority interrupt until the lower-priority one is served, and then the higher-priority one can be served. In nested interrupt mode, the lower-priority interrupt can be preempted by the higher-priority interrupt, even though the lower-priority one is being served. The lower-priority ISR resumes after the higher-priority ISR completes. In nested interrupt mode, the higher-priority interrupt can always be served in time. www.ti.com ICC Operation Figure 5-2 compares nested interrupts and non-nested interrupts. Figure 5-2. Nested and Non-Nested Interrupt Comparison Block Diagram # 5.2.2 Interrupt Priority Levels The ICCILSRx (ICCILSR0, ICCILSR1, ......) registers assign the priority level of each module interrupt source. Each ILSRx bit field is a 2-bit value that assigns each interrupt a priority of 0 to 3. Level 3 is the lowest priority, and level 0 is the highest. Software can read or write these registers at any time. After reset or exiting from LPMx.5 modes, the interrupt levels default to the lowest priority of 3. See the device-specific data sheet to determine which interrupt is configured by each bit in these registers. # 5.2.3 Interrupt Priority Level Comparison When the ICC is enabled, it stores the priority level of the current interrupt in the interrupt compare mask (ICMC bits in the ICCSC register) (for details, see Section 5.2.4). When another interrupt occurs, the ICC compares the corresponding software priority (ILSRx[1:0]) of each active interrupt request to the value in ICMC. If the ILSRx value is greater than the value of ICMC, the corresponding interrupt request is accepted and submitted to CPU. If the ILSRx value is less than the value of ICMC, the new interrupt remains pending. When the ICC is disabled, the interrupt request from the source is directly passed to CPU. The interrupt software priority level programmed in ILSRx[1:0] is ignored. If concurrent interrupts occur, the vector table priority in SYS determines the interrupt to be served if the GIE is asserted. ICC Operation www.ti.com #### NOTE: GIE Setting When the ICC module is enabled, it is recommended that GIE is asserted in each maskable interrupt service routine. #### Interrupt Comparison Result The corresponding interrupt is submitted to the CPU only when the ILSRx value is greater than the ICMC. If concurrent interrupts are present, the software ILSRx priority and the vector table priority are both compared. Each time, only one interrupt request is passed to the CPU. # 5.2.4 Interrupt Compare Mask Update and Virtual Stack The current interrupt compare mask (ICMC) bit is in the ICCSC register. The two bits specify the minimum interrupt priority level that is sent to be serviced. When the ICC submits an interrupt request to the CPU, it immediately pushes the ILSRx value of that interrupt onto the virtual stack (ICM0 to ICM3 bit fields in the ICCMVS register) and increases the stack pointer one step. The current interrupt compare mask (ICMC) is updated automatically to the same value that is identified by the stack pointer. When the submitted interrupt is served, the stack is popped when the RETI instruction is executed. The virtual stack (ICCMVS) implements a first-in-last-out storage of ICMC. The VSFFLG flag is set when the stack is full, and the VSEFLG flag is set when the stack is empty. # 5.2.5 Virtual Stack Push and Pop #### Virtual stack push - The ICMC is the element stack that the stack pointer is pointing to. - If the priority of the request interrupt is higher than the ICMC, the request interrupt is accepted, and its priority ILSRx is pushed into stack. The stack pointer is increased one step. - If the priority of the next requested interrupt is not higher than the ICMC, the requested interrupt is pending, and the virtual stack remains unchanged. #### Virtual stack pop When the submitted interrupt is served, the stack is popped when the RETI instruction is executed. The stack pointer is decreased one step. The VSEFLG flag indicates that the stack is empty when the stack pointer register MVSSP is 0. The VSFFLG flag indicates that the stack is full when the stack pointer register MVSSP is 4. www.ti.com ICC Operation Figure 5-3 shows the virtual stack push flow block diagram. Figure 5-3. Virtual Stack Push Flow Block Diagram ICC Operation www.ti.com Figure 5-4 shows the virtual stack pop flow block diagram. Figure 5-4. Virtual Stack Pop Flow Block Diagram ### 5.2.6 Application Operation #### 5.2.6.1 Globe Interrupt Enable (GIE) Operation The globe interrupt enable bit is in the CPU module. It enables or disables all maskable interrupts. The GIE bit is disabled by default, and it is asserted in the main loop of software code to enable all maskable interrupts to be served. The GIE bit is automatically disabled by hardware when entering the ISR for a maskable interrupt to prevent unexpected interrupts from happening. The following occurs when GIE is asserted in the maskable ISR of devices without the ICC module or when the ICC module is disabled: - When concurrent interrupts occur, the vector table priority in SYS determine which one has the highest priority. The other interrupts are pending until the highest one is served. - If GIE is enabled in the ISR, any later interrupt can preempt the ongoing ISR, even if the ongoing ISR has a higher priority than the new interrupt. - A self-nested interrupt can happen if the GIE bit is enabled before the interrupt flag (IFG) is cleared in the ISR. ICC Operation www.ti.com #### 5.2.6.2 **Maskable Interrupt Service Routine Operation Flow** The ICC module supports the nested interrupt capability when it is enabled. The GIE bit is asserted in maskable ISR when ICC is enabled. The following code example shows the recommended flow of the ISR: ``` ; XXX_ISR ; ISR for XXX ; for example: needs user to clear the IFG #XXXIFG, &XXXCTL ; Clear interrupt flag in XXX control registers BIC.W BIS #GIE,SR ; General Interrupt Enable is asserted if ICC used : ; Interrupt handling RETI ``` Figure 5-5 shows the recommended flow for the ISR of a maskable interrupt. Figure 5-5. ISR Recommended Flow Block Diagram ICC Operation www.ti.com # 5.2.6.3 ICC Enable or Disable Operation Flow The ICC module can be disabled by clearing the control register ICCEN in the ICCSC register. The ICC module is disabled by default. It is recommended to enable or disable the ICC module in the main loop of the software code to prevent unexpected interrupts from happening. The following code example shows the recommended flow to enable the ICC. www.ti.com ICC Operation Figure 5-6 shows the recommended flow to enable the ICC. Figure 5-6. Recommended ICC Enable Operation Flow Block Diagram ICC Operation www.ti.com The following code example shows the recommended flow to disable the ICC. Figure 5-7 shows the recommended flow to disable the ICC. Figure 5-7. Recommended ICC Disabled Operation Flow Block Diagram www.ti.com ICC Operation #### NOTE: ICC Enable in LPM If the ICC module is enabled before entering LPM3 or LPM4, there is an additional 5 to 6 clock cycle delay for the CPU to exit from LPM3 or LPM4 before interrupt service starts. This delay is an additional 200 $\mu$ s for exit from LPMx.5. #### **ICC Bypass** The virtual stack of priority levels is cleared if the ICC is bypassed (disabled). When it is recovered into AM, the interrupt priority history is covered. It is recommended to disable the GIE bit before enabling or disabling the ICC. It is recommended to enable or disable the ICC module only in the main loop of the software code. #### Flag Clear The maskable interrupt flag must be cleared in the ISR. ICC Registers www.ti.com # 5.3 ICC Registers Table 5-1 lists the ICC registers and their address offsets. See the device-specific data sheet for the base address of the ICC module. Table 5-1. ICC Registers | Offset | Acronym | Register Name | Туре | Access | Reset | Section | |--------|--------------------------------------------------------------------------|--------------------------------------------------------------------|------------|--------|-------|----------------| | 00h | ICCSC | Interrupt Compare Controller Status and Control Register | Read/write | Word | 0023h | Section 5.3.1 | | 02h | ICCMVS | Interrupt Compare Controller Mask<br>Virtual Stack Register | Read | Word | 00FFh | Section 5.3.2 | | 04h | ICCILSR0 | Interrupt Compare Controller Interrupt<br>Level Setting Register 0 | Read/write | Word | FFFFh | Section 5.3.3 | | 06h | ICCILSR1 | Interrupt Compare Controller Interrupt<br>Level Setting Register 1 | Read/write | Word | FFFFh | Section 5.3.4 | | 08h | ICCILSR2 | Interrupt Compare Controller Interrupt<br>Level Setting Register 2 | Read/write | Word | FFFFh | Section 5.3.5 | | 0Ah | ICCILSR3 | Interrupt Compare Controller Interrupt<br>Level Setting Register 3 | Read/write | Word | FFFFh | Section 5.3.6 | | 0Ch | ICCILSR4 | Interrupt Compare Controller Interrupt<br>Level Setting Register 4 | Read/write | Word | FFFFh | Section 5.3.7 | | 0Eh | ICCILSR5 | Interrupt Compare Controller Interrupt<br>Level Setting Register 5 | Read/write | Word | FFFFh | Section 5.3.8 | | 10h | ICCILSR6 | Interrupt Compare Controller Interrupt<br>Level Setting Register 6 | Read/write | Word | FFFFh | Section 5.3.9 | | 12h | ICCILSR7 Interrupt Compare Controller Interrupt Level Setting Register 7 | | Read/write | Word | FFFFh | Section 5.3.10 | www.ti.com ICC Registers # 5.3.1 ICCSC Register (offset = 00h) [reset = 0023h] ICC Status and Control Register #### Figure 5-8. ICCSC Register #### **Table 5-2. ICCSC Register Description** | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|-----------------------------------------------------------------------------------------------------------------------------| | 15-8 | Reserved | R | 0h | Reserved | | 7 | ICCEN | RW | 0h | ICC enable | | | | | | This bit enables or disables all ICC functionalities | | | | | | 0b = ICC module disabled | | | | | | 1b = ICC module enabled | | 6 | Reserved | R | 0h | Reserved | | 5 | VSEFLG | R | 1h | Virtual stack empty flag | | | | | | This bit indicates whether or not the virtual stack is empty. It is automatically | | | | | | updated when the stack is pushed or popped. | | | | | | 0b = Stack has valid data | | | | | | 1b = Stack has no valid data | | 4 | VSFFLG | R | 0h | Virtual stack full flag | | | | | | This bit indicates whether or not the virtual stack is full. It is automatically | | | | | | updated when the stack is pushed or popped. | | | | | | 0b = ICCMVS register is not full | | | | | | 1b = ICCMVS register is full | | 3-2 | Reserved | R | 0h | Reserved. Reads as 0. | | 1-0 | ICMC | R | 3h | Current Interrupt compare mask | | | | | | Specifies the minimum interrupt priority level that will be sent for service. | | | | | | If ICM[1:0] is less than the priority level (ILSRx[1:0]) of the new interrupt, the corresponding source is sent to the CPU. | | | | | | Note that the ICMC is the element stack that the stack pointer is pointing to. | # 5.3.2 ICCMVS Register (offset = 02h) [reset = 00FFh] ICC Mask Virtual Stack (MVS) Register ## Figure 5-9. ICCMVS Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |-----|-----|----------|-----|-----|------------|-----|-----| | | | Reserved | | | MVSSP | | | | r-0 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | IC | CM3 | IC | M2 | ICN | <b>Л</b> 1 | ICN | ЛО | | r-1 ICC Registers www.ti.com ## **Table 5-3. ICCMVS Register Description** | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|-------------------------------------------------------------------------------------------------------------------| | 15-11 | Reserved | R | 0h | Reserved | | 10-8 | MVSSP | R | Oh | MVS stack pointer indicate register 000b = Stack empty 001b = ICM0 affected 010b = ICM0 and ICM1 affected | | | | | | 011b = ICM0, ICM1, and ICM2 affected<br>100b = ICM0, ICM1, ICM2, and ICM3 affected. Also means the stack is full. | | 7-6 | ICM3 | R | 3h | Interrupt compare mask virtual stack position 3 This field is the virtual stack register for ICM3. | | 5-4 | ICM2 | R | 3h | Interrupt compare mask virtual stack position 2 This field is the virtual stack register for ICM2. | | 3-2 | ICM1 | R | 3h | Interrupt compare mask virtual stack position 1 This field is the virtual stack register for ICM1. | | 1-0 | ICM0 | R | 3h | Interrupt compare mask virtual stack position 0 This field is the virtual stack register for ICM0. | # 5.3.3 ICCILSR0 Register (offset = 04h) [reset = FFFFh] ICC Interrupt Level Setting Register 0 ## Figure 5-10. ICCILRS0 Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |-------|-------|-------|------|------|------|-------|------| | ILSR7 | | ILSR6 | | ILS | R5 | ILSR4 | | | rw-1 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | ILS | ILSR3 | | SR2 | ILS | R1 | ILS | SR0 | | rw-1 ## Table 5-4. ICCILRS0 Register Description | Bit | Field | Туре | Reset | Description | | | | | |-------|-------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | 15-14 | ILSR7 | RW | 3h | Sets the interrupt level for this interrupt source. Maskable interrupt sources only. See the device-specific data sheet to determine the interrupt source for each ILSRx bit. | | | | | | 13-12 | ILSR6 | RW | 3h | Sets the interrupt level for this interrupt source. Maskable interrupt sources only. See the device-specific data sheet to determine the interrupt source for each ILSRx bit. | | | | | | 11-10 | ILSR5 | RW | 3h | Sets the interrupt level for this interrupt source. Maskable interrupt sources only. See the device-specific data sheet to determine the interrupt source for each ILSRx bit. | | | | | | 9-8 | ILSR4 | RW | 3h | Sets the interrupt level for this interrupt source. Maskable interrupt sources only. See the device-specific data sheet to determine the interrupt source for each ILSRx bit. | | | | | | 7-6 | ILSR3 | RW | 3h | Sets the interrupt level for this interrupt source. Maskable interrupt sources only. See the device-specific data sheet to determine the interrupt source for each ILSRx bit. | | | | | | 5-4 | ILSR2 | RW | 3h | Sets the interrupt level for this interrupt source. Maskable interrupt sources only. See the device-specific data sheet to determine the interrupt source for each ILSRx bit. | | | | | | 3-2 | ILSR1 | RW | 3h | Sets the interrupt level for this interrupt source. Maskable interrupt sources only. See the device-specific data sheet to determine the interrupt source for each ILSRx bit. | | | | | | 1-0 | ILSR0 | RW | 3h | Sets the interrupt level for this interrupt source. Maskable interrupt sources only. See the device-specific data sheet to determine the interrupt source for each ILSRx bit. | | | | | www.ti.com ICC Registers # 5.3.4 ICCILSR1 Register (offset = 06h) [reset = FFFFh] ICC Interrupt Level Setting Register 1 #### Figure 5-11. ICCILRS1 Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|--------|------|--------|------|--------|------|------| | ILSR15 | | ILS | ILSR14 | | ILSR13 | | R12 | | rw-1 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | ILS | ILSR11 | | R10 | ILS | R9 | ILS | SR8 | | rw-1 #### Table 5-5. ICCILRS1 Register Description | Bit | Field | Туре | Reset | Description | | |-------|--------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | 15-14 | ILSR15 | RW | 3h | Sets the interrupt level for this interrupt source. Maskable interrupt sources only. See the device-specific data sheet to determine the interrupt source for each ILSRxx bit. | | | 13-12 | ILSR14 | RW | 3h | Sets the interrupt level for this interrupt source. Maskable interrupt sources on See the device-specific data sheet to determine the interrupt source for each ILSRxx bit. | | | 11-10 | ILSR13 | RW | 3h | Sets the interrupt level for this interrupt source. Maskable interrupt sources only. See the device-specific data sheet to determine the interrupt source for each ILSRxx bit. | | | 9-8 | ILSR12 | RW | 3h | Sets the interrupt level for this interrupt source. Maskable interrupt sources only. See the device-specific data sheet to determine the interrupt source for each ILSRxx bit. | | | 7-6 | ILSR11 | RW | 3h | Sets the interrupt level for this interrupt source. Maskable interrupt sources only. See the device-specific data sheet to determine the interrupt source for each ILSRxx bit. | | | 5-4 | ILSR10 | RW | 3h | Sets the interrupt level for this interrupt source. Maskable interrupt sources only. See the device-specific data sheet to determine the interrupt source for each ILSRxx bit. | | | 3-2 | ILSR9 | RW | 3h | Sets the interrupt level for this interrupt source. Maskable interrupt sources only. See the device-specific data sheet to determine the interrupt source for each ILSRxx bit. | | | 1-0 | ILSR8 | RW | 3h | Sets the interrupt level for this interrupt source. Maskable interrupt sources only. See the device-specific data sheet to determine the interrupt source for each ILSRxx bit. | | # 5.3.5 ICCILSR2 Register (offset = 08h) [reset = FFFFh] ICC Interrupt Level Setting Register 2 ## Figure 5-12. ICCILRS2 Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|------|--------|------|--------|------|--------|------| | ILSR23 | | ILSR21 | | ILSR21 | | ILSR20 | | | rw-1 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | ILSR19 | | ILS | R18 | ILS | R17 | ILS | R16 | | rw-1 #### Table 5-6. ICCILRS2 Register Description | Bit | Field | Туре | Reset | Description | |-------|--------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-14 | ILSR23 | RW | 3h | Sets the interrupt level for this interrupt source. Maskable interrupt sources only. See the device-specific data sheet to determine the interrupt source for each ILSRxx bit. | ICC Registers www.ti.com ## Table 5-6. ICCILRS2 Register Description (continued) | Bit | Field | Туре | Reset | Description | |-------|--------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 13-12 | ILSR22 | RW | 3h | Sets the interrupt level for this interrupt source. Maskable interrupt sources only. See the device-specific data sheet to determine the interrupt source for each ILSRxx bit. | | 11-10 | ILSR21 | RW | 3h | Sets the interrupt level for this interrupt source. Maskable interrupt sources only. See the device-specific data sheet to determine the interrupt source for each ILSRxx bit. | | 9-8 | ILSR20 | RW | 3h | Sets the interrupt level for this interrupt source. Maskable interrupt sources only. See the device-specific data sheet to determine the interrupt source for each ILSRxx bit. | | 7-6 | ILSR19 | RW | 3h | Sets the interrupt level for this interrupt source. Maskable interrupt sources only. See the device-specific data sheet to determine the interrupt source for each ILSRxx bit. | | 5-4 | ILSR18 | RW | 3h | Sets the interrupt level for this interrupt source. Maskable interrupt sources only. See the device-specific data sheet to determine the interrupt source for each ILSRxx bit. | | 3-2 | ILSR17 | RW | 3h | Sets the interrupt level for this interrupt source. Maskable interrupt sources only. See the device-specific data sheet to determine the interrupt source for each ILSRxx bit. | | 1-0 | ILSR16 | RW | 3h | Sets the interrupt level for this interrupt source. Maskable interrupt sources only. See the device-specific data sheet to determine the interrupt source for each ILSRxx bit. | # 5.3.6 ICCILSR3 Register (offset = 0Ah) [reset = FFFFh] ICC Interrupt Level Setting Register 3 #### Figure 5-13. ICCILRS3 Register | | | | _ | | | | | |--------|------|------|------|------|------|------|------| | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | ILS | R31 | ILS | R30 | ILSF | R29 | ILS | R28 | | rw-1 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | ILSR27 | | ILS | R26 | ILSF | R25 | ILS | R24 | | rw-1 ## **Table 5-7. ICCILRS3 Register Description** | Bit | Field | Туре | Reset | Description | |-------|--------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-14 | ILSR31 | RW | 3h | Sets the interrupt level for this interrupt source. Maskable interrupt sources only. See the device-specific data sheet to determine the interrupt source for each ILSRxx bit. | | 13-12 | ILSR30 | RW | 3h | Sets the interrupt level for this interrupt source. Maskable interrupt sources only. See the device-specific data sheet to determine the interrupt source for each ILSRxx bit. | | 11-10 | ILSR29 | RW | 3h | Sets the interrupt level for this interrupt source. Maskable interrupt sources only. See the device-specific data sheet to determine the interrupt source for each ILSRxx bit. | | 9-8 | ILSR28 | RW | 3h | Sets the interrupt level for this interrupt source. Maskable interrupt sources only. See the device-specific data sheet to determine the interrupt source for each ILSRxx bit. | | 7-6 | ILSR27 | RW | 3h | Sets the interrupt level for this interrupt source. Maskable interrupt sources only. See the device-specific data sheet to determine the interrupt source for each ILSRxx bit. | | 5-4 | ILSR26 | RW | 3h | Sets the interrupt level for this interrupt source. Maskable interrupt sources only. See the device-specific data sheet to determine the interrupt source for each ILSRxx bit. | | 3-2 | ILSR25 | RW | 3h | Sets the interrupt level for this interrupt source. Maskable interrupt sources only. See the device-specific data sheet to determine the interrupt source for each ILSRxx bit. | www.ti.com ICC Registers ## Table 5-7. ICCILRS3 Register Description (continued) | Bit | Field | Туре | Reset | Description | |-----|--------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1-0 | ILSR24 | RW | | Sets the interrupt level for this interrupt source. Maskable interrupt sources only. See the device-specific data sheet to determine the interrupt source for each ILSRxx bit. | # 5.3.7 ICCILSR4 Register (offset = 0Ch) [reset = FFFFh] ICC Interrupt Level Setting Register 4 #### Figure 5-14. ICCILRS4 Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|------|------|------|------|------|--------|------| | ILS | SR39 | ILS | R38 | ILSF | R37 | ILSR36 | | | rw-1 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | ILSR35 | | ILS | R34 | ILSF | R33 | ILS | R32 | | rw-1 ## Table 5-8. ICCILRS4 Register Description | Bit | Field | Туре | Reset | Description | | | | |-------|--------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | 15-14 | ILSR39 | RW | 3h | Sets the interrupt level for this interrupt source. Maskable interrupt sources only. See the device-specific data sheet to determine the interrupt source for each ILSRxx bit. | | | | | 13-12 | ILSR38 | RW | 3h | Sets the interrupt level for this interrupt source. Maskable interrupt sources only See the device-specific data sheet to determine the interrupt source for each ILSRxx bit. | | | | | 11-10 | ILSR37 | RW | 3h | Sets the interrupt level for this interrupt source. Maskable interrupt sources of See the device-specific data sheet to determine the interrupt source for each ILSRxx bit. | | | | | 9-8 | ILSR36 | RW | 3h | Sets the interrupt level for this interrupt source. Maskable interrupt sources only. See the device-specific data sheet to determine the interrupt source for each ILSRxx bit. | | | | | 7-6 | ILSR35 | RW | 3h | Sets the interrupt level for this interrupt source. Maskable interrupt sources only See the device-specific data sheet to determine the interrupt source for each ILSRxx bit. | | | | | 5-4 | ILSR34 | RW | 3h | Sets the interrupt level for this interrupt source. Maskable interrupt sources only. See the device-specific data sheet to determine the interrupt source for each ILSRxx bit. | | | | | 3-2 | ILSR33 | RW | 3h | Sets the interrupt level for this interrupt source. Maskable interrupt sources only. See the device-specific data sheet to determine the interrupt source for each ILSRxx bit. | | | | | 1-0 | ILSR32 | RW | 3h | Sets the interrupt level for this interrupt source. Maskable interrupt sources only. See the device-specific data sheet to determine the interrupt source for each ILSRxx bit. | | | | # 5.3.8 ICCILSR5 Register (offset = 0Eh) [reset = FFFFh] ICC Interrupt Level Setting Register 5 #### Figure 5-15. ICCILRS5 Register | | | | 9 | | 9.010. | | | |------|--------|--------|------|--------|--------|--------|------| | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | ILSR47 | ILS | R46 | ILS | R45 | ILSR44 | | | rw-1 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | ILSR43 | ILSR42 | | ILSR41 | | ILSR40 | | | rw-1 ICC Registers www.ti.com ## Table 5-9. ICCILRS5 Register Description | Bit | Field | Туре | Reset | Description | |-------|--------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-14 | ILSR47 | RW | 3h | Sets the interrupt level for this interrupt source. Maskable interrupt sources only. See the device-specific data sheet to determine the interrupt source for each ILSRxx bit. | | 13-12 | ILSR46 | RW | 3h | Sets the interrupt level for this interrupt source. Maskable interrupt sources only. See the device-specific data sheet to determine the interrupt source for each ILSRxx bit. | | 11-10 | ILSR45 | RW | 3h | Sets the interrupt level for this interrupt source. Maskable interrupt sources only. See the device-specific data sheet to determine the interrupt source for each ILSRxx bit. | | 9-8 | ILSR44 | RW | 3h | Sets the interrupt level for this interrupt source. Maskable interrupt sources only. See the device-specific data sheet to determine the interrupt source for each ILSRxx bit. | | 7-6 | ILSR43 | RW | 3h | Sets the interrupt level for this interrupt source. Maskable interrupt sources only. See the device-specific data sheet to determine the interrupt source for each ILSRxx bit. | | 5-4 | ILSR42 | RW | 3h | Sets the interrupt level for this interrupt source. Maskable interrupt sources only. See the device-specific data sheet to determine the interrupt source for each ILSRxx bit. | | 3-2 | ILSR41 | RW | 3h | Sets the interrupt level for this interrupt source. Maskable interrupt sources only. See the device-specific data sheet to determine the interrupt source for each ILSRxx bit. | | 1-0 | ILSR40 | RW | 3h | Sets the interrupt level for this interrupt source. Maskable interrupt sources only. See the device-specific data sheet to determine the interrupt source for each ILSRxx bit. | # 5.3.9 ICCILSR6 Register (offset = 10h) [reset = FFFFh] ICC Interrupt Level Setting Register 6 ## Figure 5-16. ICCILRS6 Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|--------|--------|------|--------|------|--------|------| | ILSR55 | | ILSR54 | | ILSR53 | | ILSR52 | | | rw-1 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | ILS | ILSR51 | | R50 | ILSI | R49 | ILS | R48 | | rw-1 # Table 5-10. ICCILRS6 Register Description | Bit | Field | Туре | Reset | Description | |-------|--------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-14 | ILSR55 | RW | 3h | Sets the interrupt level for this interrupt source. Maskable interrupt sources only. See the device-specific data sheet to determine the interrupt source for each ILSRxx bit. | | 13-12 | ILSR54 | RW | 3h | Sets the interrupt level for this interrupt source. Maskable interrupt sources only. See the device-specific data sheet to determine the interrupt source for each ILSRxx bit. | | 11-10 | ILSR53 | RW | 3h | Sets the interrupt level for this interrupt source. Maskable interrupt sources only. See the device-specific data sheet to determine the interrupt source for each ILSRxx bit. | | 9-8 | ILSR52 | RW | 3h | Sets the interrupt level for this interrupt source. Maskable interrupt sources only. See the device-specific data sheet to determine the interrupt source for each ILSRxx bit. | | 7-6 | ILSR51 | RW | 3h | Sets the interrupt level for this interrupt source. Maskable interrupt sources only. See the device-specific data sheet to determine the interrupt source for each ILSRxx bit. | | 5-4 | ILSR50 | RW | 3h | Sets the interrupt level for this interrupt source. Maskable interrupt sources only. See the device-specific data sheet to determine the interrupt source for each ILSRxx bit. | www.ti.com ICC Registers ## Table 5-10. ICCILRS6 Register Description (continued) | Bit | Field | Туре | Reset | Description | |-----|--------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 3-2 | ILSR49 | RW | 3h | Sets the interrupt level for this interrupt source. Maskable interrupt sources only. See the device-specific data sheet to determine the interrupt source for each ILSRxx bit. | | 1-0 | ILSR48 | RW | 3h | Sets the interrupt level for this interrupt source. Maskable interrupt sources only. See the device-specific data sheet to determine the interrupt source for each ILSRxx bit. | # 5.3.10 ICCILSR7 Register (offset = 12h) [reset = FFFFh] ICC Interrupt Level Setting Register 7 ## Figure 5-17. ICCILRS7 Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |------|--------|--------|------|--------|------|--------|------| | | ILSR63 | ILS | R62 | ILSI | R61 | ILSR60 | | | rw-1 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | ILSR59 | ILSR58 | | ILSR57 | | ILSR56 | | | rw-1 ## Table 5-11. ICCILRS7 Register Description | Bit | Field | Туре | Reset | Description | | | | |-------|--------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | 15-14 | ILSR63 | RW | 3h | Sets the interrupt level for this interrupt source. Maskable interrupt sources only. See the device-specific data sheet to determine the interrupt source for each ILSRxx bit. | | | | | 13-12 | ILSR62 | RW | 3h | Sets the interrupt level for this interrupt source. Maskable interrupt sources only. See the device-specific data sheet to determine the interrupt source for each ILSRxx bit. | | | | | 11-10 | ILSR61 | RW | 3h | Sets the interrupt level for this interrupt source. Maskable interrupt sources only. See the device-specific data sheet to determine the interrupt source for each ILSRxx bit. | | | | | 9-8 | ILSR60 | RW | 3h | Sets the interrupt level for this interrupt source. Maskable interrupt sources only. See the device-specific data sheet to determine the interrupt source for each ILSRxx bit. | | | | | 7-6 | ILSR59 | RW | 3h | Sets the interrupt level for this interrupt source. Maskable interrupt sources only. See the device-specific data sheet to determine the interrupt source for each ILSRxx bit. | | | | | 5-4 | ILSR58 | RW | 3h | Sets the interrupt level for this interrupt source. Maskable interrupt sources only. See the device-specific data sheet to determine the interrupt source for each ILSRxx bit. | | | | | 3-2 | ILSR57 | RW | 3h | Sets the interrupt level for this interrupt source. Maskable interrupt sources only. See the device-specific data sheet to determine the interrupt source for each ILSRxx bit. | | | | | 1-0 | ILSR56 | RW | 3h | Sets the interrupt level for this interrupt source. Maskable interrupt sources only. See the device-specific data sheet to determine the interrupt source for each ILSRxx bit. | | | | # FRAM Controller (FRCTL) This chapter describes the operation of the FRAM controller. Page **Topic** | 6.1 | FRAM Introduction | 301 | |------|--------------------------|-----| | 6.2 | FRAM Organization | 301 | | 6.3 | FRCTL Module Operation | 301 | | 6.4 | Programming FRAM Devices | 302 | | 6.5 | Wait State Control | 302 | | 6.6 | FRAM ECC | 303 | | 6.7 | FRAM Write Back | 303 | | 6.8 | FRAM Power Control | 303 | | 6.9 | FRAM Cache | 304 | | 6.10 | FRCTL Registers | 305 | www.ti.com FRAM Introduction #### **FRAM Introduction** 6.1 FRAM is a nonvolatile memory that reads and writes like standard SRAM. The MSP430 FRAM features include: - Byte or word write access - Automatic and programmable wait state control with independent wait state settings for access and cycle times - Error correction code (ECC) with bit error correction, extended bit error detection, and flag indicators - Cache for fast read - Power control for disabling FRAM if it is not used Figure 6-1 shows the block diagram of the FRAM Controller. Figure 6-1. FRAM Controller Block Diagram #### 6.2 FRAM Organization The FRAM address space is linear with the exception of the User Information Memory and the Device Descriptor Information (TLV). #### 6.3 **FRCTL Module Operation** The FRAM module can be read in a similar fashion to SRAM and needs no special requirements. A FRAM read always requires a write back to the same memory location with the same information read. This write back is part of the FRAM module itself and requires no user interaction. These write backs are different from the normal write access from application code. The FRAM module has built-in error correction code (ECC) logic that can correct bit errors and detect multiple bit errors. Two flags are available that indicate the presence of an error. The CBDIFG is set when a correctable bit error is detected. If CBDIE is also set, a System NMI event (SYSNMI) occurs. The UBDIFG is set when a multiple bit error which is not correctable is detected. If UBDIE is also set, a System NMI event (SYSNMI) occurs. Upon correctable or uncorrectable bit errors, the program vectors to the SYSSNIV if the NMI is enabled. If desired, a system reset event (SYSRST) can be generated by setting the UBDRSTEN bit. If an uncorrectable error is detected, a PUC is initiated and the program vectors to the SYSRSTIV. #### 6.4 Programming FRAM Devices There are three options for programming an MSP430 FRAM device. All options support in-system programming. - Program through JTAG or the Spy-Bi-Wire interface - Program through the BSL - Program through a custom solution ## 6.4.1 Programming FRAM Through JTAG or Spy-Bi-Wire Devices can be programmed through the JTAG port or the Spy-Bi-Wire port. The JTAG interface requires access to TDI, TDO, TMS, TCK, TEST, ground, and optionally VCC and RST/NMI. Spy-Bi-Wire interface requires access to TEST, RST/NMI, ground and optionally VCC. For more details, see MSP430 Programming With the JTAG Interface. #### 6.4.2 Programming FRAM Through the Bootloader (BSL) Every device contains a BSL stored in ROM. The BSL enables users to read or program the FRAM or RAM using a UART serial interface. Access to the FRAM through the BSL is protected by a 256-bit user-defined password. For more details, see *MSP430 Programming With the Bootloader (BSL)*. #### 6.4.3 Programming FRAM Through a Custom Solution The ability of the CPU to write to its own FRAM allows for in-system and external custom programming solutions. The user can choose to provide data to the device through any means available (for example, UART or SPI). User-developed software can receive the data and program the FRAM. Because this type of solution is developed by the user, it can be completely customized to fit the application needs for programming or updating the FRAM. #### 6.5 Wait State Control The system clock for the CPU may exceed the FRAM access and cycle time requirements. For these scenarios, a wait state generator mechanism is implemented. The *Recommended Operating Conditions* of the device-specific data sheet lists the frequency ranges with the required wait state settings. The number of wait states is controlled by the NWAITS[2:0] bits in the FRCTL0 register. To increase the system clock frequency beyond the maximum frequency allowed by the current wait state setting, the following steps are required: - 1. Increase the number of wait states by configuring NWAITS[2:0] according to the target frequency. - 2. Increase the frequency to the new target. To decrease the system clock frequency to a range that supports fewer wait states, the following steps are required: - 1. Decrease frequency to the new target. - 2. Decrease number of wait states by configuring NWAITS[2:0] according to the new frequency setting. To ensure memory integrity, a mechanism is implemented that resets the device with a PUC if the system clock frequency and the wait state settings violate the FRAM access timing. #### **NOTE: Wait State Settings** - The device starts with zero wait states. - Correct wait state settings must be ensured, otherwise a PUC might be generated to avoid erratic FRAM accesses. www.ti.com Wait State Control #### 6.5.1 Wait State and Cache Hit The FRAM controller contains a cache with two cache sets. Each of these cache sets contains two lines that are preloaded with four words (64 bits) during one access cycle. An intelligent logic selects one of the cache lines to preload FRAM data and preserves recently accessed data in the other cache. If one of the four words stored in one of the cache lines is requested (a cache hit), no FRAM access occurs; instead, a cache request occurs. No wait state is needed for a cache request, and the data is accessed with full system speed. However, if none of the words that are available in the cache are requested (a cache miss), the wait state controls the CPU to ensure proper FRAM access. #### 6.6 FRAM ECC The FRAM supports bit error correction and uncorrectable bit error detection. The FRAM uncorrectable bit error flag (UBDIFG) is set if an uncorrectable bit error has been detected in the FRAM error detection logic. The FRAM correctable bit error flag (CBDIFG) is set if a correctable bit error has been detected and corrected. UBDRSTEN enables a power-up clear (PUC) reset if an uncorrectable bit error is detected, and UBDIE enables a NMI event if an uncorrectable bit error is detected. CBDIE enables an NMI if a marginal correctable bit error is detected and corrected. #### 6.7 FRAM Write Back All reads from FRAM require a write back of the previously read content. This write back is performed under all circumstances without any interaction from the application. #### 6.8 FRAM Power Control The FRAM controller can disable the power supply for the FRAM array. When FRPWR = 0, the FRAM array supply is disabled, but register accesses in the FRAM controller are still possible. Memory accesses pointing into the FRAM address space automatically set FRPWR = 1 and re-enable the power supply of the FRAM. For LPM0, the FRAM power state during LPM0 is saved from the previous state in active mode. If FRAM power is disabled, any memory access automatically inserts wait states to ensure sufficient time for the FRAM power up and access. Accesses to FRAM that can be served from cache do not change the power state of the FRAM power control. A PUC reset forces the state machine to Active with FRAM enabled. Figure 6-2 shows the activation flow of the FRAM controller. FRAM Cache www.ti.com Figure 6-2. FRAM Power Control Diagram #### 6.9 **FRAM Cache** The FRAM controller implements a read cache to provide a speed benefit when running the CPU at higher speeds than the FRAM supports without wait states. The cache implemented is a 2-way associative cache with 4 cache lines of 64 bits each. Memory read accesses on consecutive addresses can be executed without wait states when they are within the same cache line. FRCTL Registers www.ti.com #### 6.10 FRCTL Registers The FRCTL registers and their address offsets are listed in Table 6-1 . The base address of the FRCTL module can be found in the device-specific data sheet. The password defined in the FRCTL0 register controls access to all FRCTL registers. When the correct password is written, write access to the registers is enabled. The write access is disabled by writing a wrong password in byte mode to the FRCTL upper byte. Word accesses to FRCTL with a wrong password triggers a PUC. A write access to a register other than FRCTL while write access is not enabled causes a PÚČ. NOTE: All registers have word or byte register access. For a generic register ANYREG, the suffix "\_L" (ANYREG\_L) refers to the lower byte of the register (bits 0 through 7). The suffix "\_H" (ANYREG\_H) refers to the upper byte of the register (bits 8 through 15). Table 6-1. FRCTL Registers | Offset | Acronym | Register Name | Type | Access | Reset | Section | |--------|----------|---------------------------|------------|--------|-------|----------------| | 00h | FRCTL0 | FRAM Controller Control 0 | Read/write | Word | 9600h | Section 6.10.1 | | 00h | FRCTL0_L | | Read/Write | Byte | 00h | | | 01h | FRCTL0_H | | Read/Write | Byte | 96h | | | 04h | GCCTL0 | General Control 0 | Read/write | Word | 0006h | Section 6.10.2 | | 04h | GCCTL0_L | | Read/Write | Byte | 06h | | | 05h | GCCTL0_H | | Read/Write | Byte | 00h | | | 06h | GCCTL1 | General Control 1 | Read/write | Word | 0000h | Section 6.10.3 | | 06h | GCCTL1_L | | Read/Write | Byte | 00h | | | 07h | GCCTL1_H | | Read/Write | Byte | 00h | | FRCTL Registers www.ti.com ## 6.10.1 FRCTL0 Register FRAM Controller Control Register 0 #### Figure 6-3. FRCTL0 Register ## Table 6-2. FRCTL0 Register Description | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-8 | FRCTLPW | RW | 96h | FRCTLPW password. Always reads as 96h. | | | | | | To enable write access to the FRCTL registers, write A5h. A word write of any other value causes a PUC. | | | | | | After a correct password is written and register access is enabled, write a wrong password in byte mode to disable the access. In this case, no PUC is generated. | | 7 | Reserved | R | 0h | Reserved. Always reads as 0. | | 6-4 | NWAITS | RW | 0h | Wait state control. Specifies number of wait states (0 to 7) required for an FRAM access (cache miss). 0 implies no wait states. | | 3 | Reserved | R | 0h | Reserved. Must be written as 0. | | 2-0 | Reserved | R | 0h | Reserved. Always reads as 0. | www.ti.com FRCTL Registers # 6.10.2 GCCTL0 Register General Control Register 0 ## Figure 6-4. GCCTL0 Register (16-MHz Devices) | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------|--------|--------|----------|----------|-------|----------|----------| | | | | Rese | erved | | | | | r-0 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | UBDRSTEN | UBDIE | CBDIE | Reserved | Reserved | FRPWR | FRLPMPWR | Reserved | | rw-[0] | rw-[0] | rw-[0] | r-0 | rw-0 | rw-1 | rw-1 | r-0 | #### Figure 6-5. GCCTL0 Register (24-MHz Devices) | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------|--------|--------|----------|----------|-------|----------|----------| | | | | Rese | erved | | | | | r-0 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | UBDRSTEN | UBDIE | CBDIE | Reserved | Reserved | FRPWR | FRLPMPWR | Reserved | | rw-[0] | rw-[0] | rw-[0] | r-0 | rw-0 | rw-1 | r0 | r-0 | ## Table 6-3. GCCTL0 Register Description | Bit | Field | Туре | Reset | Description | |------|----------|------|--------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-8 | Reserved | R | 0h | Reserved. Always reads as 0. | | 7 | UBDRSTEN | RW | 0h | Enable power-up clear (PUC) reset if FRAM uncorrectable bit error detected. | | | | | | The bits UBDRSTEN and UBDIE are mutual exclusive and are not allowed to be set simultaneously. Only one error handling can be selected at one time. 0b = PUC not initiated on uncorrectable bit detection flag. 1b = PUC initiated on uncorrectable bit detection flag. Generates vector in | | | | | | SYSRSTIV. | | 6 | UBDIE | RW | 0h | Enable NMI event if uncorrectable bit error detected. | | | | | | The bits UBDRSTEN and UBDIE are mutual exclusive and are not allowed to be set simultaneously. Only one error handling can be selected at one time. | | | | | | 0b = Uncorrectable bit detection interrupt disabled. | | | | | | 1b = Uncorrectable bit detection interrupt enabled. Generates vector in SYSSNIV. | | 5 | CBDIE | RW | 0h | Enable NMI event if correctable bit error detected. | | | | | | 0b = Correctable bit detection interrupt disabled. | | | | | | 1b = Correctable bit detection interrupt enabled. Generates vector in SYSSNIV. | | 4 | Reserved | R | 0h | Reserved. Always reads as 0. | | 3 | Reserved | RW | 0h | Reserved. Must be written as 0. | | 2 | FRPWR | RW | 1h | FRAM power control. | | | | | | Writing to the register enables or disables the FRAM power supply. The read of the register returns the actual state of the FRAM power supply, also reflecting a possible delay after enabling the power supply. FRPWR = 1 indicates that the FRAM power is up and ready. 0b = FRAM power supply disabled 1b = FRAM power supply enabled | | 1 | FRLPMPWR | R | 1h<br>(16-MHz<br>devices)<br>or<br>0h<br>(24-MHz<br>devices) | Enables FRAM auto power up after LPM. 0b = FRAM startup is delayed to the first FRAM access after LPM exit 1b = FRAM is powered up instantly with LPM exit. For FR203x, FR211x, FR2100, FR2000, FR231x, FR2433, FR2422, FR263x, FR253x, FR252x, and FR413x devices: This bit is always reads as 1 after reset. For other devices: This bit is always reads as 0 after reset. | | 0 | Reserved | R | 0h | Reserved. Always reads as 0. | FRCTL Registers www.ti.com ## 6.10.3 GCCTL1 Register General Control Register 1 ## Figure 6-6. GCCTL1 Register ## Table 6-4. GCCTL1 Register Description | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-3 | Reserved | R | 0h | Reserved. Always reads as 0. | | 3 | ACCTEIFG | RW | Oh | Access time error flag. This flag is set and a reset PUC is generated if a wrong setting for NWAITS is set and the FRAM access time is violated. This bit is cleared by software or by reading the system reset vector word SYSRSTIV if it is the highest pending flag. This bit is write 0 only, write 1 has no effect. Note: The ACCTEIFG bit may be set in debug mode when the system frequency is configured to be greater than 8 MHz, regardless of the wait states (NWAITS). In the case, it is not an FRAM access violation. The ACCTEIFG bit does not trigger a PUC or change the SYSRSTIV register value. The ACCTEIFG bit is cleared only by writing 0. It is recommended to use SYSRSTIV register to check | | | | | | FRAM access violation error to avoid confusion. | | 2 | UBDIFG | RW | Oh | FRAM uncorrectable bit error flag. This interrupt flag is set if an uncorrectable bit error has been detected in the FRAM memory error detection logic. This bit is cleared by software or by reading the system NMI vector word SYSSNIV if it is the highest pending interrupt flag. This bit is write 0 only and write 1 has no effect. | | | | | | 0b = No interrupt pending | | | | | | 1b = Interrupt pending. Can be cleared by user or by reading SYSSNIV. | | 1 | CBDIFG | RW | Oh | FRAM correctable bit error flag. This interrupt flag is set if a correctable bit error has been detected and corrected in the FRAM memory error detection logic. This bit is cleared by software or by reading the system NMI vector word SYSSNIV if it is the highest pending interrupt flag. This bit is write 0 only and write 1 has no effect. | | | | | | 0b = No interrupt pending | | | | | | 1b = Interrupt pending. Can be cleared by user or by reading SYSSNIV | | 0 | Reserved | R | 0h | Reserved. Always reads as 0. | # Backup Memory (BAKMEM) The Backup Memory provides up to 256 bytes that are retained during LPM3.5. The size of the Backup Memory varies by device—see the device-specific data sheet for details. This chapter describes the Backup Memory functionality and features. Topic Page | 7.1 | Backup Memory Introduction | 310 | |-----|----------------------------|-----| | 7.2 | BAKMEM Registers | 310 | ## 7.1 Backup Memory Introduction Features of the Backup Memory include: - Configurable from 32 bytes to 256 bytes - Supports modes from AM to LPM3.5 - Supports word or byte access #### 7.2 BAKMEM Registers Table 7-1 lists the Backup Memory registers. The base address of the Backup Memory module can be found in the device-specific data sheet. Table 7-1. BAKMEM Registers | Offset | Acronym | Register Name | Туре | Access | Reset | |--------|-----------|--------------------------------|------------|--------|-----------| | 00h | BAKMEM0 | Backup Memory 0 | Read/write | Word | Undefined | | 00h | BAKMEM0_L | | Read/write | Byte | | | 01h | BAKMEM0_H | | Read/write | Byte | | | 02h | BAKMEM1 | Backup Memory 1 <sup>(1)</sup> | Read/write | Word | Undefined | | 02h | BAKMEM1_L | | Read/write | Byte | | | 03h | BAKMEM1_H | | Read/write | Byte | | <sup>(1)</sup> Both bit 15 and bit 14 must be asserted for dual-edge mode. # Digital I/O This chapter describes the operation of the digital I/O ports in all devices. # Topic Page 8.1 Digital I/O Introduction 312 | 8.1 | Digital I/O Introduction | 312 | |-----|--------------------------|-----| | 8.2 | Digital I/O Operation | 313 | | 8.3 | I/O Configuration | 316 | | 8.4 | Digital I/O Registers | 319 | Digital I/O Introduction www.ti.com #### 8.1 Digital I/O Introduction The digital I/O features include: - Independently programmable individual I/Os - Any combination of input or output - Individually configurable P1 and P2 interrupts. Some devices may include additional port interrupts. - · Independent input and output data registers - Individually configurable pullup or pulldown resistors Devices within the family may have up to twelve digital I/O ports implemented (P1 to P11 and PJ). Most ports contain eight I/O lines; however, some ports may contain fewer lines (see the device-specific data sheet for ports available). Each I/O line is individually configurable for input or output direction, and each can be individually read or written. Each I/O line is individually configurable for pullup or pulldown resistors. Ports P1 and P2 always have interrupt capability. Each interrupt for the P1 and P2 I/O lines can be individually enabled and configured to provide an interrupt on a rising or falling edge of an input signal. All P1 I/O lines source a single interrupt vector (P1IV), and all P2 I/O lines source a different single interrupt vector (P2IV). Additional ports with interrupt capability may be available (see the device-specific data sheet for details) and contain their own respective interrupt vectors. Individual ports can be accessed as byte-wide ports or can be combined into word-wide ports and accessed by word formats. Port pairs P1 and P2, P3 and P4, P5 and P6, P7 and P8, and so on, are associated with the names PA, PB, PC, PD, and so on, respectively. All port registers are handled in this manner with this naming convention except for the interrupt vector registers, P1IV and P2IV; that is, PAIV does not exist. When writing to port PA with word operations, all 16 bits are written to the port. When writing to the lower byte of port PA using byte operations, the upper byte remains unchanged. Similarly, writing to the upper byte of port PA using byte instructions leaves the lower byte unchanged. When writing to a port that contains fewer than the maximum number of bits possible, the unused bits are don't care. Ports PB, PC, PD, PE, and PF behave similarly. Reading port PA using word operations causes all 16 bits to be transferred to the destination. Reading the lower or upper byte of port PA (P1 or P2) and storing to memory using byte operations causes only the lower or upper byte to be transferred to the destination, respectively. Reading of port PA and storing to a general-purpose register using byte operations writes the byte that is transferred to the least significant byte of the register. The upper significant byte of the destination register is cleared automatically. Ports PB, PC, PD, PE, and PF behave similarly. When reading from ports that contain fewer than the maximum bits possible, unused bits are read as zeros (similarly for port PJ). www.ti.com Digital I/O Operation #### 8.2 Digital I/O Operation The digital I/Os are configured with user software. The setup and operation of the digital I/Os are discussed in the following sections. #### 8.2.1 Input Registers (PxIN) Each bit in each PxIN register reflects the value of the input signal at the corresponding I/O pin when the pin is configured as I/O function. These registers are read only. - Bit = 0: Input is low - Bit = 1: Input is high #### NOTE: Writing to read-only registers PxIN Writing to these read-only registers results in increased current consumption while the write attempt is active. #### 8.2.2 Output Registers (PxOUT) Each bit in each PxOUT register is the value to be output on the corresponding I/O pin when the pin is configured as I/O function, output direction. - Bit = 0: Output is low - Bit = 1: Output is high If the pin is configured as I/O function, input direction and the pullup or pulldown resistor are enabled; the corresponding bit in the PxOUT register selects pullup or pulldown. - Bit = 0: Pin is pulled down - Bit = 1: Pin is pulled up #### 8.2.3 Direction Registers (PxDIR) Each bit in each PxDIR register selects the direction of the corresponding I/O pin, regardless of the selected function for the pin. PxDIR bits for I/O pins that are selected for other functions must be set as required by the other function. - Bit = 0: Port pin is switched to input direction - Bit = 1: Port pin is switched to output direction #### 8.2.4 Pullup or Pulldown Resistor Enable Registers (PxREN) Each bit in each PxREN register enables or disables the pullup or pulldown resistor of the corresponding I/O pin. The corresponding bit in the PxOUT register selects if the pin contains a pullup or pulldown. - Bit = 0: Pullup or pulldown resistor disabled - Bit = 1: Pullup or pulldown resistor enabled Table 8-1 summarizes the use of PxDIR, PxREN, and PxOUT for proper I/O configuration. | PxDIR | PxREN | PxOUT | I/O Configuration | |-------|-------|-------|------------------------------| | 0 | 0 | х | Input | | 0 | 1 | 0 | Input with pulldown resistor | | 0 | 1 | 1 | Input with pullup resistor | | 1 | Х | Х | Output | Table 8-1. I/O Configuration Digital I/O Operation www.ti.com #### 8.2.5 Function Select Registers (PxSEL0, PxSEL1) Port pins are often multiplexed with other peripheral module functions. See the device-specific data sheet to determine pin functions. Each port pin uses two bits to select the pin function: I/O port or one of the three possible peripheral module functions. Table 8-3 shows how to select the various module functions. See the device-specific data sheet to determine pin functions. Each PxSEL bit is used to select the pin function: I/O port or peripheral module function. A device in this family may have only PxSEL0 or both PxSEL0 and PxSEL1. Table 8-2. I/O Function Selection for Devices With Only One Selection Bit – PxSEL0 | PxSEL0 | I/O Function | | | | |--------|---------------------------------------|--|--|--| | 0 | General purpose I/O is selected | | | | | 1 | 1 Primary module function is selected | | | | Table 8-3. I/O Function Selection for Devices With Two Selection Bits - PxSEL0 and PxSEL1 | PxSEL1 | PxSEL0 | I/O Function | |--------|--------|---------------------------------------| | 0 | 0 | General purpose I/O is selected | | 0 | 1 | Primary module function is selected | | 1 | 0 | Secondary module function is selected | | 1 | 1 | Tertiary module function is selected | Setting the PxSEL1 or PxSEL0 bits to a module function does not automatically set the pin direction. Other peripheral module functions may require the PxDIR bits to be configured according to the direction needed for the module function. See the pin schematics in the device-specific data sheet. When a port pin is selected as an input to peripheral modules, the input signal to those peripheral modules is a latched representation of the signal at the device pin. While PxSEL1 and PxSEL0 is other than 00, the internal input signal follows the signal at the pin for all connected modules. However, if PxSEL1 and PxSEL0 = 00, the input to the peripherals maintain the value of the input signal at the device pin before the PxSEL1 and PxSEL0 bits were reset. Because the PxSEL1 and PxSEL0 bits do not reside in contiguous addresses, changing both bits at the same time is not possible. For example, an application might need to change P1.0 from general purpose I/O to the tertiary module function residing on P1.0. Initially, P1SEL1 = 00h and P1SEL0 = 00h. To change the function, it would be necessary to write both P1SEL1 = 01h and P1SEL0 = 01h. This is not possible without first passing through an intermediate configuration, and this configuration may not be desirable from an application standpoint. The PxSELC complement register can be used to handle such situations. The PxSELC register always reads 0. Each set bit of the PxSELC register complements the corresponding respective bit of the PxSEL1 and PxSEL0 registers. In the example, with P1SEL1 = 00h and P1SEL0 = 00h initially, writing P1SELC = 01h causes P1SEL1 = 01h and P1SEL0 = 01h to be written simultaneously. #### NOTE: Interrupts are disabled when PxSEL1 = 1 or PxSEL0 = 1 When any PxSEL bit is set, the corresponding pin interrupt function is disabled. Therefore, signals on these pins do not generate interrupts, regardless of the state of the corresponding PxIE bit. #### 8.2.6 Port Interrupts At least each pin in ports P1 and P2 have interrupt capability, configured with the PxIFG, PxIE, and PxIES registers. Some devices may contain additional port interrupts in addition to P1 and P2. See the devicespecific data sheet to determine which port interrupts are available. www.ti.com Digital I/O Operation All Px interrupt flags are prioritized, with PxIFG.0 being the highest, and combined to source a single interrupt vector. The highest priority enabled interrupt generates a number in the PxIV register. This number can be evaluated or added to the program counter to automatically enter the appropriate software routine. Disabled Px interrupts do not affect the PxIV value. The PxIV registers are word or byte access. Each PxIFG bit is the interrupt flag for its corresponding I/O pin, and the flag is set when the selected input signal edge occurs at the pin. All PxIFG interrupt flags request an interrupt when their corresponding PxIE bit and the GIE bit are set. Software can also set each PxIFG flag, providing a way to generate a software-initiated interrupt. - Bit = 0: No interrupt is pending - Bit = 1: An interrupt is pending Only transitions, not static levels, cause interrupts. If any PxIFG flag becomes set during a Px interrupt service routine or is set after the RETI instruction of a Px interrupt service routine is executed, the set PxIFG flag generates another interrupt. This ensures that each transition is acknowledged. #### NOTE: PxIFG flags when changing PxOUT, PxDIR, or PxREN Writing to PxOUT, PxDIR, or PxREN can result in setting the corresponding PxIFG flags. Any access (read or write) of the lower byte of the PxIV register, either word or byte access, 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 P1IFG.0 has the highest priority. If the P1IFG.0 and P1IFG.2 flags are set when the interrupt service routine accesses the P1IV register, P1IFG.0 is reset automatically. After the RETI instruction of the interrupt service routine is executed, the P1IFG.2 generates another interrupt. #### 8.2.6.1 P1IV Software Example The following software example shows the recommended use of P1IV and the handling overhead. The P1IV value is added to the PC to automatically jump to the appropriate routine. The code to handle any other PxIV register is similar. The numbers at the right margin show the number of CPU cycles that are required for each instruction. The software overhead for different interrupt sources includes interrupt latency and return-from-interrupt cycles but not the task handling itself. ``` ;Interrupt handler for Pl Cycles ; Interrupt latency P1_HND 6 &P1IV,PC ; Add offset to Jump table ADD 3 RETI ; Vector 0: No interrupt JMP P1_0_HND ; Vector 2: Port 1 bit 0 P1_1_HND JMP ; Vector 4: Port 1 bit 1 JMP P1_2_HND ; Vector 6: Port 1 bit 2 тмр P1_3_HND ; Vector 8: Port 1 bit 3 P1 4 HND ; Vector 10: Port 1 bit 4 JMP JMP P1_5_HND ; Vector 12: Port 1 bit 5 ; Vector 14: Port 1 bit 6 JMP P1_6_HND P1_7_HND ; Vector 16: Port 1 bit 7 JMP P1_7_HND ; Vector 16: Port 1 bit 7 ; Task starts here ; Back to main program 5 RETI P1_6_HND ; Vector 14: Port 1 bit 6 ; Task starts here RETT ; Back to main program 5 P1_5_HND ; Vector 12: Port 1 bit 5 ; Task starts here RETI ; Back to main program 5 P1_4_HND ; Vector 10: Port 1 bit 4 ``` I/O Configuration www.ti.com | <br>RETI | ; Task starts here<br>; Back to main program | 5 | |-------------|------------------------------------------------------|---| | P1_3_HND | ; Vector 8: Port 1 bit 3 ; Task starts here | | | RETI | ; Back to main program | 5 | | P1_2_HND | ; Vector 6: Port 1 bit 2 | | | <br>RETI | ; Task starts here ; Back to main program | 5 | | חווו 1 וווו | ; Vector 4: Port 1 bit 1 | | | P1_1_HND | ; Task starts here | | | RETI | ; Back to main program | 5 | | P1_0_HND | ; Vector 2: Port 1 bit 0 | | | RETI | <pre>; Task starts here ; Back to main program</pre> | 5 | #### 8.2.6.2 Interrupt Edge Select Registers (PxIES) Each PxIES bit selects the interrupt edge for the corresponding I/O pin. - Bit = 0: Respective PxIFG flag is set on a low-to-high transition - Bit = 1: Respective PxIFG flag is set on a high-to-low transition #### **NOTE: Writing to PxIES** Writing to P1IES or P2IES for each corresponding I/O can result in setting the corresponding interrupt flags. | PxIES | PxIN | PxIFG | |-------------------|------|------------| | $0 \rightarrow 1$ | 0 | May be set | | $0 \rightarrow 1$ | 1 | Unchanged | | $1 \rightarrow 0$ | 0 | Unchanged | | $1 \rightarrow 0$ | 1 | May be set | #### 8.2.6.3 Interrupt Enable Registers (PxIE) Each PxIE bit enables the associated PxIFG interrupt flag. - Bit = 0: The interrupt is disabled - Bit = 1: The interrupt is enabled #### 8.3 I/O Configuration #### 8.3.1 Configuration After Reset After a BOR reset, all port pins are high-impedance with Schmitt triggers and their module functions disabled to prevent any cross currents. The application must initialize all port pins including unused ones (Section 8.3.2) as input high impedance, input with pulldown, input with pullup, output high, or output low according to the application needs by configuring PxDIR, PxREN, PxOUT, and PxIES accordingly. This initialization takes effect as soon as the LOCKLPM5 bit in the PM5CTL register (described in the PMM chapter) is cleared; until then, the I/Os remain in their high-impedance state with Schmitt trigger inputs disabled. Note that this is usually the same I/O initialization that is required after a wakeup from LPMx.5. After clearing LOCKLPM5, all interrupt flags should be cleared (note, this is different from the flow for wakeup from LPMx.5). Then port interrupts can be enabled by setting the corresponding PxIE bits. After a POR or PUC reset, all port pins are configured as inputs with their module function disabled. To prevent floating inputs, all port pins including unused ones (Section 8.3.2) should be configured according to the application needs as early as possible during the initialization procedure. www.ti.com I/O Configuration Note that the same I/O initialization procedure can be used for all reset cases and wakeup from LPMx.5, except for PxIFG: - 1. Initialize Ports: PxDIR, PxREN, PxOUT, and PxIES - 2. Clear LOCKLPM5 - 3. If not waking up from LPMx.5: clear all PxIFGs to avoid erroneous port interrupts - 4. Enable port interrupts in PxIE #### 8.3.2 Configuration of Unused Port Pins To prevent a floating input and to reduce power consumption, unused I/O pins should be configured as I/O function, output direction, and left unconnected on the PC board. The value of the PxOUT bit is don't care, because the pin is unconnected. Alternatively, the integrated pullup or pulldown resistor can be enabled by setting the PxREN bit of the unused pin to prevent a floating input. See the System Resets, Interrupts, and Operating Modes, System Control Module (SYS) chapter for termination of unused pins. #### NOTE: Configuring port PJ and shared JTAG pins: The application should make sure that port PJ is configured properly to prevent a floating input. Because port PJ is shared with the JTAG function, floating inputs may not be noticed when in an emulation environment. Port J is initialized to high-impedance inputs by default. ## 8.3.3 Configuration for LPMx.5 Low-Power Modes NOTE: See Section 1.4.3, Low-Power Modes LPM3.5 and LPM4.5 (LPMx.5), in the System Resets, Interrupts, and Operating Modes, System Control Module (SYS) chapter for details about LPMx.5 low-power modes. See the device-specific data sheet to determine which LPMx.5 low-power modes are available and which modules can operate in LPM3.5, if any. With regard to the digital I/Os, the following description is applicable to both LPM3.5 and LPM4.5. Upon entering LPMx.5 (LPM3.5 or LPM4.5), the LDO of the PMM module is disabled, which removes the supply voltage from the core of the device. This causes all I/O register configurations to be lost, thus the configuration of I/O pins must be handled differently to make sure that all pins in the application behave in a controlled manner upon entering and exiting LPMx.5. Properly setting the I/O pins is critical to achieve the lowest possible power consumption in LPMx.5 and to prevent an uncontrolled input or output I/O state in the application. The application has complete control of the I/O pin conditions that are necessary to prevent unwanted spurious activity upon entry and exit from LPMx.5. Before entering LPMx.5, the following operations are required for the I/Os: - a. Set all I/Os to general-purpose I/Os (PxSEL0 = 000h and PxSEL1 = 000h) and configure as needed. Each I/O can be set to input high impedance, input with pulldown, input with pullup, output high, or output low. It is critical that no inputs are left floating in the application; otherwise, excess current may be drawn in LPMx.5. - Configuring the I/O in this manner makes sure that each pin is in a safe condition before entering LPMx.5. - b. Optionally, configure input interrupt pins for wake-up from LPMx.5. To wake the device from LPMx.5, a general-purpose I/O port must contain an input port with interrupt and wakeup capability. Not all inputs with interrupt capability offer wakeup from LPMx.5. See the device-specific data sheet for availability. To wake up the device, a port pin must be configured properly before entering LPMx.5. Each port should be configured as general-purpose input. Pulldowns or pullups can be applied if required. Setting the PxIES bit of the corresponding register determines the edge transition that wakes the device. Last, the PxIE for the port must be enabled, as well as the general interrupt enable. I/O Configuration www.ti.com NOTE: It is not possible to wake up from a port interrupt if its respective port interrupt flag is already asserted. TI recommends clearing the flags before entering LPMx.5. TI also recommends setting GIE = 1 before entry into LPMx.5. This allows any pending flags to be serviced before LPMx.5 entry. This completes the operations required for the I/Os before entering LPMx.5. During LPMx.5 the I/O pin states are held and locked based on the settings before LPMx.5 entry. Note that only the pin conditions are retained. All other port configuration register settings such as PxDIR, PxREN, PxOUT, PxIES, and PxIE contents are lost. Upon exit from LPMx.5, all peripheral registers are set to their default conditions but the I/O pins remain locked while LOCKLPM5 remains set. Keeping the I/O pins locked ensures that all pin conditions remain stable when entering the active mode, regardless of the default I/O register settings. When back in active mode, the I/O configuration and I/O interrupt configuration such as PxDIR, PxREN, PxOUT, and PxIES should be restored to the values before entering LPMx.5. The LOCKLPM5 bit can then be cleared, which releases the I/O pin conditions and I/O interrupt configuration. Any changes to the port configuration registers while LOCKLPM5 is set have no effect on the I/O pins. After enabling the I/O interrupts by configuring PxIE, the I/O interrupt that caused the wakeup can be serviced as indicated by the PxIFG flags. These flags can be used directly, or the corresponding PxIV register may be used. Note that the PxIFG flag cannot be cleared until the LOCKLPM5 bit has been cleared. NOTE: It is possible that multiple events occurred on various ports. In these cases, multiple PxIFG flags are set, and it cannot be determined which port caused the I/O wakeup. Digital I/O Registers www.ti.com #### 8.4 **Digital I/O Registers** The digital I/O registers are listed in Table 8-4. The base addresses can be found in the device-specific data sheet. Each port grouping begins at its base address. The address offsets are given in Table 8-4. NOTE: All registers have word or byte register access. For a generic register ANYREG, the suffix "\_L" (ANYREG\_L) refers to the lower byte of the register (bits 0 through 7). The suffix "\_H" (ANYREG\_H) refers to the upper byte of the register (bits 8 through 15). Table 8-4. Digital I/O Registers | Offset | Acronym | Register Name | Type | Access | Reset | Section | |--------|-----------------------|------------------------------|------------|--------|-----------|----------------| | 0Eh | P1IV | Port 1 Interrupt Vector | Read only | Word | 0000h | Section 8.4.1 | | 0Eh | P1IV_L | | Read only | Byte | 00h | | | 0Fh | P1IV_H | | Read only | Byte | 00h | | | 1Eh | P2IV | Port 2 Interrupt Vector | Read only | Word | 0000h | Section 8.4.2 | | 1Eh | P2IV_L | | Read only | Byte | 00h | | | 1Fh | P2IV_H | | Read only | Byte | 00h | | | 2Eh | P3IV | Port 3 Interrupt Vector | Read only | Word | 0000h | Section 8.4.3 | | 2Eh | P3IV_L | | Read only | Byte | 00h | | | 2Fh | P3IV_H | | Read only | Byte | 00h | | | 3Eh | P4IV | Port 4 Interrupt Vector | Read only | Word | 0000h | Section 8.4.4 | | 3Eh | P4IV_L | | Read only | Byte | 00h | | | 3Fh | P4IV_H | | Read only | Byte | 00h | | | 00h | P1IN<br>or PAIN_L | Port 1 Input | Read only | Byte | undefined | Section 8.4.5 | | 02h | P1OUT<br>or PAOUT_L | Port 1 Output | Read/write | Byte | undefined | Section 8.4.6 | | 04h | P1DIR<br>or PADIR_L | Port 1 Direction | Read/write | Byte | 00h | Section 8.4.7 | | 06h | P1REN<br>or PAREN_L | Port 1 Resistor Enable | Read/write | Byte | 00h | Section 8.4.8 | | 0Ah | P1SEL0<br>or PASEL0_L | Port 1 Select 0 | Read/write | Byte | 00h | Section 8.4.9 | | 0Ch | P1SEL1<br>or PASEL1_L | Port 1 Select 1 | Read/write | Byte | 00h | Section 8.4.10 | | 16h | P1SELC<br>or PASELC_L | Port 1 Complement Selection | Read/write | Byte | 00h | Section 8.4.11 | | 18h | P1IES<br>or PAIES_L | Port 1 Interrupt Edge Select | Read/write | Byte | undefined | Section 8.4.12 | | 1Ah | P1IE<br>or PAIE_L | Port 1 Interrupt Enable | Read/write | Byte | 00h | Section 8.4.13 | | 1Ch | P1IFG<br>or PAIFG_L | Port 1 Interrupt Flag | Read/write | Byte | 00h | Section 8.4.14 | Digital I/O Registers www.ti.com | Offset | Acronym | Register Name | Туре | Access | Reset | Section | |--------|-----------------------|------------------------------|------------|--------|-----------|----------------| | 01h | P2IN<br>or PAIN_H | Port 2 Input | Read only | Byte | undefined | Section 8.4.5 | | 03h | P2OUT<br>or PAOUT_H | Port 2 Output | Read/write | Byte | undefined | Section 8.4.6 | | 05h | P2DIR<br>or PADIR_H | Port 2 Direction | Read/write | Byte | 00h | Section 8.4.7 | | 07h | P2REN<br>or PAREN_H | Port 2 Resistor Enable | Read/write | Byte | 00h | Section 8.4.8 | | 0Bh | P2SEL0<br>or PASEL0_H | Port 2 Select 0 | Read/write | Byte | 00h | Section 8.4.9 | | 0Dh | P2SEL1<br>or PASEL1_H | Port 2 Select 1 | Read/write | Byte | 00h | Section 8.4.10 | | 17h | P2SELC<br>or PASELC_L | Port 2 Complement Selection | Read/write | Byte | 00h | Section 8.4.11 | | 19h | P2IES<br>or PAIES_H | Port 2 Interrupt Edge Select | Read/write | Byte | undefined | Section 8.4.12 | | 1Bh | P2IE<br>or PAIE_H | Port 2 Interrupt Enable | Read/write | Byte | 00h | Section 8.4.13 | | 1Dh | P2IFG<br>or PAIFG_H | Port 2 Interrupt Flag | Read/write | Byte | 00h | Section 8.4.14 | | 00h | P3IN<br>or PBIN_L | Port 3 Input | Read only | Byte | undefined | Section 8.4.5 | | 02h | P3OUT<br>or PBOUT_L | Port 3 Output | Read/write | Byte | undefined | Section 8.4.6 | | 04h | P3DIR<br>or PBDIR_L | Port 3 Direction | Read/write | Byte | 00h | Section 8.4.7 | | 06h | P3REN<br>or PBREN_L | Port 3 Resistor Enable | Read/write | Byte | 00h | Section 8.4.8 | | 0Ah | P3SEL0<br>or PBSEL0_L | Port 3 Select 0 | Read/write | Byte | 00h | Section 8.4.9 | | 0Ch | P3SEL1<br>or PBSEL1_L | Port 3 Select 1 | Read/write | Byte | 00h | Section 8.4.10 | | 16h | P3SELC<br>or PBSELC_L | Port 3 Complement Selection | Read/write | Byte | 00h | Section 8.4.11 | | 18h | P3IES<br>or PBIES_L | Port 3 Interrupt Edge Select | Read/write | Byte | undefined | Section 8.4.12 | | 1Ah | P3IE<br>or PBIE_L | Port 3 Interrupt Enable | Read/write | Byte | 00h | Section 8.4.13 | | 1Ch | P3IFG<br>or PBIFG_L | Port 3 Interrupt Flag | Read/write | Byte | 00h | Section 8.4.14 | www.ti.com Digital I/O Registers | Offset | Acronym | Register Name | Туре | Access | Reset | Section | |--------|-----------------------|------------------------------|------------|--------|-----------|----------------| | 01h | P4IN<br>or PBIN_H | Port 4 Input | Read only | Byte | undefined | Section 8.4.5 | | 03h | P4OUT<br>or PBOUT_H | Port 4 Output | Read/write | Byte | undefined | Section 8.4.6 | | 05h | P4DIR<br>or PBDIR_H | Port 4 Direction | Read/write | Byte | 00h | Section 8.4.7 | | 07h | P4REN<br>or PBREN_H | Port 4 Resistor Enable | Read/write | Byte | 00h | Section 8.4.8 | | 0Bh | P4SEL0<br>or PBSEL0_H | Port 4 Select 0 | Read/write | Byte | 00h | Section 8.4.9 | | 0Dh | P4SEL1<br>or PBSEL1_H | Port 4 Select 1 | Read/write | Byte | 00h | Section 8.4.10 | | 17h | P4SELC<br>or PBSELC_L | Port 4 Complement Selection | Read/write | Byte | 00h | Section 8.4.11 | | 19h | P4IES<br>or PBIES_H | Port 4 Interrupt Edge Select | Read/write | Byte | undefined | Section 8.4.12 | | 1Bh | P4IE<br>or PBIE_H | Port 4 Interrupt Enable | Read/write | Byte | 00h | Section 8.4.13 | | 1Dh | P4IFG<br>or PBIFG_H | Port 4 Interrupt Flag | Read/write | Byte | 00h | Section 8.4.14 | | 00h | P5IN<br>or PCIN_L | Port 5 Input | Read only | Byte | undefined | Section 8.4.5 | | 02h | P5OUT<br>or PCOUT_L | Port 5 Output | Read/write | Byte | undefined | Section 8.4.6 | | 04h | P5DIR<br>or PCDIR_L | Port 5 Direction | Read/write | Byte | 00h | Section 8.4.7 | | 06h | P5REN<br>or PCREN_L | Port 5 Resistor Enable | Read/write | Byte | 00h | Section 8.4.8 | | 0Ah | P5SEL0<br>or PCSEL0_L | Port 5 Select 0 | Read/write | Byte | 00h | Section 8.4.9 | | 0Ch | P5SEL1<br>or PCSEL1_L | Port 5 Select 1 | Read/write | Byte | 00h | Section 8.4.10 | | 16h | P5SELC<br>or PCSELC_L | Port 5 Complement Selection | Read/write | Byte | 00h | Section 8.4.11 | | 18h | P5IES<br>or PCIES_L | Port 5 Interrupt Edge Select | Read/write | Byte | undefined | Section 8.4.12 | | 1Ah | P5IE<br>or PCIE_L | Port 5 Interrupt Enable | Read/write | Byte | 00h | Section 8.4.13 | | 1Ch | P5IFG<br>or PCIFG_L | Port 5 Interrupt Flag | Read/write | Byte | 00h | Section 8.4.14 | Digital I/O Registers www.ti.com | Offset | Acronym | Register Name | Туре | Access | Reset | Section | |--------|-----------------------|------------------------------|------------|--------|-----------|----------------| | 01h | P6IN<br>or PCIN_H | Port 6 Input | Read only | Byte | undefined | Section 8.4.5 | | 03h | P6OUT<br>or PCOUT_H | Port 6 Output | Read/write | Byte | undefined | Section 8.4.6 | | 05h | P6DIR<br>or PCDIR_H | Port 6 Direction | Read/write | Byte | 00h | Section 8.4.7 | | 07h | P6REN<br>or PCREN_H | Port 6 Resistor Enable | Read/write | Byte | 00h | Section 8.4.8 | | 0Bh | P6SEL0<br>or PCSEL0_H | Port 6 Select 0 | Read/write | Byte | 00h | Section 8.4.9 | | 0Dh | P6SEL1<br>or PCSEL1_H | Port 6 Select 1 | Read/write | Byte | 00h | Section 8.4.10 | | 17h | P6SELC<br>or PCSELC_L | Port 6 Complement Selection | Read/write | Byte | 00h | Section 8.4.11 | | 19h | P6IES<br>or PCIES_H | Port 6 Interrupt Edge Select | Read/write | Byte | undefined | Section 8.4.12 | | 1Bh | P6IE<br>or PCIE_H | Port 6 Interrupt Enable | Read/write | Byte | 00h | Section 8.4.13 | | 1Dh | P6IFG<br>or PCIFG_H | Port 6 Interrupt Flag | Read/write | Byte | 00h | Section 8.4.14 | | 00h | P7IN<br>or PDIN_L | Port 7 Input | Read only | Byte | undefined | Section 8.4.5 | | 02h | P7OUT<br>or PDOUT_L | Port 7 Output | Read/write | Byte | undefined | Section 8.4.6 | | 04h | P7DIR<br>or PDDIR_L | Port 7 Direction | Read/write | Byte | 00h | Section 8.4.7 | | 06h | P7REN<br>or PDREN_L | Port 7 Resistor Enable | Read/write | Byte | 00h | Section 8.4.8 | | 0Ah | P7SEL0<br>or PDSEL0_L | Port 7 Select 0 | Read/write | Byte | 00h | Section 8.4.9 | | 0Ch | P7SEL1<br>or PDSEL1_L | Port 7 Select 1 | Read/write | Byte | 00h | Section 8.4.10 | | 16h | P7SELC<br>or PDSELC_L | Port 7 Complement Selection | Read/write | Byte | 00h | Section 8.4.11 | | 18h | P7IES<br>or PDIES_L | Port 7 Interrupt Edge Select | Read/write | Byte | undefined | Section 8.4.12 | | 1Ah | P7IE<br>or PDIE_L | Port 7 Interrupt Enable | Read/write | Byte | 00h | Section 8.4.13 | | 1Ch | P7IFG<br>or PDIFG_L | Port 7 Interrupt Flag | Read/write | Byte | 00h | Section 8.4.14 | www.ti.com Digital I/O Registers | Acronym | Register Name | Type | Access | Reset | Section | |-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | P8IN<br>or PDIN_H | Port 8 Input | Read only | Byte | undefined | Section 8.4.5 | | P8OUT<br>or PDOUT_H | Port 8 Output | Read/write | Byte | undefined | Section 8.4.6 | | P8DIR<br>or PDDIR_H | Port 8 Direction | Read/write | Byte | 00h | Section 8.4.7 | | P8REN<br>or PDREN_H | Port 8 Resistor Enable | Read/write | Byte | 00h | Section 8.4.8 | | P8SEL0<br>or PDSEL0_H | Port 8 Select 0 | Read/write | Byte | 00h | Section 8.4.9 | | P8SEL1<br>or PDSEL1_H | Port 8 Select 1 | Read/write | Byte | 00h | Section 8.4.10 | | P8SELC<br>or PDSELC_L | Port 8 Complement Selection | Read/write | Byte | 00h | Section 8.4.11 | | P8IES<br>or PDIES_H | Port 8 Interrupt Edge Select | Read/write | Byte | undefined | Section 8.4.12 | | P8IE<br>or PDIE_H | Port 8 Interrupt Enable | Read/write | Byte | 00h | Section 8.4.13 | | P8IFG<br>or PDIFG_H | Port 8 Interrupt Flag | Read/write | Byte | 00h | Section 8.4.14 | | P9IN<br>or PEIN_L | Port 9 Input | Read only | Byte | undefined | Section 8.4.5 | | P9OUT<br>or PEOUT_L | Port 9 Output | Read/write | Byte | undefined | Section 8.4.6 | | P9DIR<br>or PEDIR_L | Port 9 Direction | Read/write | Byte | 00h | Section 8.4.7 | | P9REN<br>or PEREN_L | Port 9 Resistor Enable | Read/write | Byte | 00h | Section 8.4.8 | | P9SEL0<br>or PESEL0_L | Port 9 Select 0 | Read/write | Byte | 00h | Section 8.4.9 | | P9SEL1<br>or PESEL1_L | Port 9 Select 1 | Read/write | Byte | 00h | Section 8.4.10 | | P9SELC<br>or PESELC_L | Port 9 Complement Selection | Read/write | Byte | 00h | Section 8.4.11 | | P9IES<br>or PEIES_L | Port 9 Interrupt Edge Select | Read/write | Byte | undefined | Section 8.4.12 | | P9IE<br>or PEIE_L | Port 9 Interrupt Enable | Read/write | Byte | 00h | Section 8.4.13 | | P9IFG<br>or PEIFG_L | Port 9 Interrupt Flag | Read/write | Byte | 00h | Section 8.4.14 | | | P8IN or PDIN_H P8OUT or PDOUT_H P8DIR or PDDIR_H P8REN or PDREN_H P8SEL0 or PDSEL0_H P8SEL1 or PDSEL1_H P8SELC or PDSELC_L P8IES or PDIES_H P8IF or PDIFG_H P8IFG or PDIFG_H P9IN or PEIN_L P9OUT or PEOUT_L P9DIR or PEDIR_L P9SEL0 or PESEL0_L P9SEL1 or PESEL1_L P9SEL0 or PESEL1_L P9SEL1 or PESEL1_L P9SEL1 or PESEL1_L P9SEL1 or PESEL1_L P9SEL2 or PESEL2_L P9IES or PEIES_L P9IE or PEIES_L P9IE or PEIES_L P9IFG | P8IN or PDIN_H P8OUT or PDOUT_H P8DIR or PDDIR_H P8REN or PDREN_H P8SEL0 Port 8 Select 0 POSEL0_H P8SEL1 PORT 8 Complement Selection or PDSEL1_H P8SEC PORT 8 Interrupt Edge Select or PDIES_H P8IE PORT 8 Interrupt Flag PORT 8 Interrupt Flag PORT 9 DIR PORT 9 DIRECTION PORT 9 PORT 9 PORT 9 Select 0 P9SEL0_L P9SEL0 PORT 9 Select 1 P9SEL0 PORT 9 Select 0 1 P9SEL0 PORT 9 Select 1 P9SEL1 PORT 9 Select 1 P9SEL1 PORT 9 Select 1 P9SEL1 PORT 9 Select 1 PPSEL1_L P9SELC PORT 9 Complement Selection or PESEL0_L P9SELC PORT 9 Interrupt Edge Select PORT 9 Interrupt Edge Select PORT 9 Interrupt Edge Select PORT 9 Interrupt Enable | P8IN Port 8 Input Read only or PDIN_H P8OUT POUT_H P8DIR P8DIR Port 8 Direction Read/write or PDDIR_H P8ERN PORT 8 Select 0 Read/write or PDSEL0_H P8SEL0 Port 8 Select 1 Read/write or PDSEL1_H P8SELC Port 8 Complement Selection Read/write or PDIES_H P8IES Port 8 Interrupt Edge Select Read/write or PDIES_H P8IFG PDIFG_H P9IN PORT 9 Input Read/write or PEIN_L P9DIR PORT 9 Direction Read/write or PESEL0_L P9REN PORT 9 Direction Read/write or PESEL0_L P9REN PORT 9 Direction Read/write or PESEL0_L P9REN PORT 9 Direction Read/write or PESEL0_L P9SEL0 Port 9 Resistor Enable Read/write or PESEL0_L P9SEL0 Port 9 Select 0 Read/write or PESEL0_L P9SEL1 PORT 9 Select 1 Read/write or PESEL0_L P9SEL0 PORT 9 Select 1 Read/write or PESEL0_L P9SEL1 PORT 9 Select 1 Read/write or PESEL0_L P9SELC PORT 9 Select 1 Read/write or PESEL0_L P9SELC PORT 9 Select 1 Read/write or PESEL0_L P9SELC PORT 9 Select 1 Read/write or PESEL0_L P9SELC PORT 9 Select 1 Read/write or PESEL0_L P9SELC PORT 9 Interrupt Edge Select Read/write or PESEL0_L P9SELC PORT 9 Interrupt Edge Select Read/write or PESEL0_L P9SELC PORT 9 Interrupt Edge Select Read/write or PEIES_L P9IFG PORT 9 Interrupt Enable Read/write | P8IN or PDIN_H P8OUT Or PDOUT_H P8DIR P8DIR Or PDDIR_H P8TH P8TH P8TH P8TH P8TH P8TH P8TH P8T | P8IN or PDIN_H P8OUT or PDOUT_H P8OUT or PDOUT_H P8DIR port 8 Direction Read/write Byte undefined or PDOUT_H P8DIR port 8 Resistor Enable Read/write Byte O0h P8REN port 8 Resistor Enable Read/write Byte O0h P8REN_H P8SEL0 port 8 Select 0 Read/write Byte O0h P8SEL1 port 8 Select 1 Read/write Byte O0h P8SEL1 port 8 Select 1 Read/write Byte O0h P8SEL1 port 8 Complement Selection Read/write Byte O0h P8SEL1 port 8 Interrupt Edge Select Read/write Byte O0h P8IES port 8 Interrupt Edge Select Read/write Byte O0h P8IES or PDIES_H P8IE port 8 Interrupt Enable Read/write Byte O0h P9IN port 9 Not 8 Interrupt Flag Read/write Byte Undefined or PDIFG_H P9IN port 9 Input Read only Byte Undefined or PEIN_L P9OUT port 9 Output Read/write Byte Undefined or PEOUT_L P9DIR port 9 Ort 9 Output Read/write Byte Undefined or PEOUT_L P9DIR port 9 Port 9 Not N | Digital I/O Registers www.ti.com | Offset | Acronym | Register Name | Туре | Access | Reset | Section | |--------|------------------------|-------------------------------|------------|--------|-----------|----------------| | 01h | P10IN<br>or PEIN_H | Port 10 Input | Read only | Byte | undefined | Section 8.4.5 | | 03h | P10OUT<br>or PEOUT_H | Port 10 Output | Read/write | Byte | undefined | Section 8.4.6 | | 05h | P10DIR<br>or PEDIR_H | Port 10 Direction | Read/write | Byte | 00h | Section 8.4.7 | | 07h | P10REN<br>or PEREN_H | Port 10 Resistor Enable | Read/write | Byte | 00h | Section 8.4.8 | | 0Bh | P10SEL0<br>or PESEL0_H | Port 10 Select 0 | Read/write | Byte | 00h | Section 8.4.9 | | 0Dh | P10SEL1<br>or PESEL1_H | Port 10 Select 1 | Read/write | Byte | 00h | Section 8.4.10 | | 17h | P10SELC<br>or PESELC_L | Port 10 Complement Selection | Read/write | Byte | 00h | Section 8.4.11 | | 19h | P10IES<br>or PEIES_H | Port 10 Interrupt Edge Select | Read/write | Byte | undefined | Section 8.4.12 | | 1Bh | P10IE<br>or PEIE_H | Port 10 Interrupt Enable | Read/write | Byte | 00h | Section 8.4.13 | | 1Dh | P10IFG<br>or PEIFG_H | Port 10 Interrupt Flag | Read/write | Byte | 00h | Section 8.4.14 | | 00h | P11IN<br>or PFIN_L | Port 11 Input | Read only | Byte | undefined | Section 8.4.5 | | 02h | P11OUT<br>or PFOUT_L | Port 11 Output | Read/write | Byte | undefined | Section 8.4.6 | | 04h | P11DIR<br>or PFDIR_L | Port 11 Direction | Read/write | Byte | 00h | Section 8.4.7 | | 06h | P11REN<br>or PFREN_L | Port 11 Resistor Enable | Read/write | Byte | 00h | Section 8.4.8 | | 0Ah | P11SEL0<br>or PFSEL0_L | Port 11 Select 0 | Read/write | Byte | 00h | Section 8.4.9 | | 0Ch | P11SEL1<br>or PFSEL1_L | Port 11 Select 1 | Read/write | Byte | 00h | Section 8.4.10 | | 16h | P11SELC<br>or PFSELC_L | Port 11 Complement Selection | Read/write | Byte | 00h | Section 8.4.11 | | 18h | P11IES<br>or PFIES_L | Port 11 Interrupt Edge Select | Read/write | Byte | undefined | Section 8.4.12 | | 1Ah | P11IE<br>or PFIE_L | Port 11 Interrupt Enable | Read/write | Byte | 00h | Section 8.4.13 | | 1Ch | P11IFG<br>or PFIFG_L | Port 11 Interrupt Flag | Read/write | Byte | 00h | Section 8.4.14 | www.ti.com Digital I/O Registers | Offset | Acronym | Register Name | Туре | Access | Reset | Section | |--------|----------|------------------------------|------------|--------|-----------|---------| | 00h | PAIN | Port A Input | Read only | Word | undefined | | | 00h | PAIN_L | | Read only | Byte | undefined | | | 01h | PAIN_H | | Read only | Byte | undefined | | | 02h | PAOUT | Port A Output | Read/write | Word | undefined | | | 02h | PAOUT_L | | Read/write | Byte | undefined | | | 03h | PAOUT_H | | Read/write | Byte | undefined | | | 04h | PADIR | Port A Direction | Read/write | Word | 0000h | | | 04h | PADIR_L | | Read/write | Byte | 00h | | | 05h | PADIR_H | | Read/write | Byte | 00h | | | 06h | PAREN | Port A Resistor Enable | Read/write | Word | 0000h | | | 06h | PAREN_L | | Read/write | Byte | 00h | | | 07h | PAREN_H | | Read/write | Byte | 00h | | | 0Ah | PASEL0 | Port A Select 0 | Read/write | Word | 0000h | | | 0Ah | PASEL0_L | | Read/write | Byte | 00h | | | 0Bh | PASEL0_H | | Read/write | Byte | 00h | | | 0Ch | PASEL1 | Port A Select 1 | Read/write | Word | 0000h | | | 0Ch | PASEL1_L | | Read/write | Byte | 00h | | | 0Dh | PASEL1_H | | Read/write | Byte | 00h | | | 16h | PASELC | Port A Complement Select | Read/write | Word | 0000h | | | 16h | PASELC_L | | Read/write | Byte | 00h | | | 17h | PASELC_H | | Read/write | Byte | 00h | | | 18h | PAIES | Port A Interrupt Edge Select | Read/write | Word | undefined | | | 18h | PAIES_L | | Read/write | Byte | undefined | | | 19h | PAIES_H | | Read/write | Byte | undefined | | | 1Ah | PAIE | Port A Interrupt Enable | Read/write | Word | 0000h | | | 1Ah | PAIE_L | | Read/write | Byte | 00h | | | 1Bh | PAIE_H | | Read/write | Byte | 00h | | | 1Ch | PAIFG | Port A Interrupt Flag | Read/write | Word | 0000h | | | 1Ch | PAIFG_L | | Read/write | Byte | 00h | | | 1Dh | PAIFG_H | | Read/write | Byte | 00h | | Digital I/O Registers www.ti.com | Offset | Acronym | Register Name | Туре | Access | Reset Section | |--------|----------|------------------------------|------------|--------|---------------| | 00h | PBIN | Port B Input | Read only | Word | undefined | | 00h | PBIN_L | | Read only | Byte | undefined | | 01h | PBIN_H | | Read only | Byte | undefined | | 02h | PBOUT | Port B Output | Read/write | Word | undefined | | 02h | PBOUT_L | | Read/write | Byte | undefined | | 03h | PBOUT_H | | Read/write | Byte | undefined | | 04h | PBDIR | Port B Direction | Read/write | Word | 0000h | | 04h | PBDIR_L | | Read/write | Byte | 00h | | 05h | PBDIR_H | | Read/write | Byte | 00h | | 06h | PBREN | Port B Resistor Enable | Read/write | Word | 0000h | | 06h | PBREN_L | | Read/write | Byte | 00h | | 07h | PBREN_H | | Read/write | Byte | 00h | | 0Ah | PBSEL0 | Port B Select 0 | Read/write | Word | 0000h | | 0Ah | PBSEL0_L | | Read/write | Byte | 00h | | 0Bh | PBSEL0_H | | Read/write | Byte | 00h | | 0Ch | PBSEL1 | Port B Select 1 | Read/write | Word | 0000h | | 0Ch | PBSEL1_L | | Read/write | Byte | 00h | | 0Dh | PBSEL1_H | | Read/write | Byte | 00h | | 16h | PBSELC | Port B Complement Select | Read/write | Word | 0000h | | 16h | PBSELC_L | | Read/write | Byte | 00h | | 17h | PBSELC_H | | Read/write | Byte | 00h | | 18h | PBIES | Port B Interrupt Edge Select | Read/write | Word | undefined | | 18h | PBIES_L | | Read/write | Byte | undefined | | 19h | PBIES_H | | Read/write | Byte | undefined | | 1Ah | PBIE | Port B Interrupt Enable | Read/write | Word | 0000h | | 1Ah | PBIE_L | | Read/write | Byte | 00h | | 1Bh | PBIE_H | | Read/write | Byte | 00h | | 1Ch | PBIFG | Port B Interrupt Flag | Read/write | Word | 0000h | | 1Ch | PBIFG_L | | Read/write | Byte | 00h | | 1Dh | PBIFG_H | | Read/write | Byte | 00h | www.ti.com Digital I/O Registers | Offset | Acronym | Register Name | Туре | Access | Reset | Section | |--------|----------|------------------------------|------------|--------|-----------|---------| | 00h | PCIN | Port C Input | Read only | Word | undefined | | | 00h | PCIN_L | | Read only | Byte | undefined | | | 01h | PCIN_H | | Read only | Byte | undefined | | | 02h | PCOUT | Port C Output | Read/write | Word | undefined | | | 02h | PCOUT_L | | Read/write | Byte | undefined | | | 03h | PCOUT_H | | Read/write | Byte | undefined | | | 04h | PCDIR | Port C Direction | Read/write | Word | 0000h | | | 04h | PCDIR_L | | Read/write | Byte | 00h | | | 05h | PCDIR_H | | Read/write | Byte | 00h | | | 06h | PCREN | Port C Resistor Enable | Read/write | Word | 0000h | | | 06h | PCREN_L | | Read/write | Byte | 00h | | | 07h | PCREN_H | | Read/write | Byte | 00h | | | 0Ah | PCSEL0 | Port C Select 0 | Read/write | Word | 0000h | | | 0Ah | PCSEL0_L | | Read/write | Byte | 00h | | | 0Bh | PCSEL0_H | | Read/write | Byte | 00h | | | 0Ch | PCSEL1 | Port C Select 1 | Read/write | Word | 0000h | | | 0Ch | PCSEL1_L | | Read/write | Byte | 00h | | | 0Dh | PCSEL1_H | | Read/write | Byte | 00h | | | 16h | PCSELC | Port C Complement Select | Read/write | Word | 0000h | | | 16h | PCSELC_L | | Read/write | Byte | 00h | | | 17h | PCSELC_H | | Read/write | Byte | 00h | | | 18h | PCIES | Port C Interrupt Edge Select | Read/write | Word | undefined | | | 18h | PCIES_L | | Read/write | Byte | undefined | | | 19h | PCIES_H | | Read/write | Byte | undefined | | | 1Ah | PCIE | Port C Interrupt Enable | Read/write | Word | 0000h | | | 1Ah | PCIE_L | | Read/write | Byte | 00h | | | 1Bh | PCIE_H | | Read/write | Byte | 00h | | | 1Ch | PCIFG | Port C Interrupt Flag | Read/write | Word | 0000h | | | 1Ch | PCIFG_L | | Read/write | Byte | 00h | | | 1Dh | PCIFG_H | | Read/write | Byte | 00h | | Digital I/O Registers www.ti.com | Offset | Acronym | Register Name | Туре | Access | Reset | Section | |--------|----------|------------------------------|------------|--------|-----------|---------| | 00h | PDIN | Port D Input | Read only | Word | undefined | | | 00h | PDIN_L | | Read only | Byte | undefined | | | 01h | PDIN_H | | Read only | Byte | undefined | | | 02h | PDOUT | Port D Output | Read/write | Word | undefined | | | 02h | PDOUT_L | | Read/write | Byte | undefined | | | 03h | PDOUT_H | | Read/write | Byte | undefined | | | 04h | PDDIR | Port D Direction | Read/write | Word | 0000h | | | 04h | PDDIR_L | | Read/write | Byte | 00h | | | 05h | PDDIR_H | | Read/write | Byte | 00h | | | 06h | PDREN | Port D Resistor Enable | Read/write | Word | 0000h | | | 06h | PDREN_L | | Read/write | Byte | 00h | | | 07h | PDREN_H | | Read/write | Byte | 00h | | | 0Ah | PDSEL0 | Port D Select 0 | Read/write | Word | 0000h | | | 0Ah | PDSEL0_L | | Read/write | Byte | 00h | | | 0Bh | PDSEL0_H | | Read/write | Byte | 00h | | | 0Ch | PDSEL1 | Port D Select 1 | Read/write | Word | 0000h | | | 0Ch | PDSEL1_L | | Read/write | Byte | 00h | | | 0Dh | PDSEL1_H | | Read/write | Byte | 00h | | | 16h | PDSELC | Port D Complement Select | Read/write | Word | 0000h | | | 16h | PDSELC_L | | Read/write | Byte | 00h | | | 17h | PDSELC_H | | Read/write | Byte | 00h | | | 18h | PDIES | Port D Interrupt Edge Select | Read/write | Word | undefined | | | 18h | PDIES_L | | Read/write | Byte | undefined | | | 19h | PDIES_H | | Read/write | Byte | undefined | | | 1Ah | PDIE | Port D Interrupt Enable | Read/write | Word | 0000h | | | 1Ah | PDIE_L | | Read/write | Byte | 00h | | | 1Bh | PDIE_H | | Read/write | Byte | 00h | | | 1Ch | PDIFG | Port D Interrupt Flag | Read/write | Word | 0000h | | | 1Ch | PDIFG_L | | Read/write | Byte | 00h | | | 1Dh | PDIFG_H | | Read/write | Byte | 00h | | www.ti.com Digital I/O Registers | Offset | Acronym | Register Name | Туре | Access | Reset | Section | |--------|----------|------------------------------|------------|--------|-----------|---------| | 00h | PEIN | Port E Input | Read only | Word | undefined | | | 00h | PEIN_L | | Read only | Byte | undefined | | | 01h | PEIN_H | | Read only | Byte | undefined | | | 02h | PEOUT | Port E Output | Read/write | Word | undefined | | | 02h | PEOUT_L | | Read/write | Byte | undefined | | | 03h | PEOUT_H | | Read/write | Byte | undefined | | | 04h | PEDIR | Port E Direction | Read/write | Word | 0000h | | | 04h | PEDIR_L | | Read/write | Byte | 00h | | | 05h | PEDIR_H | | Read/write | Byte | 00h | | | 06h | PEREN | Port E Resistor Enable | Read/write | Word | 0000h | | | 06h | PEREN_L | | Read/write | Byte | 00h | | | 07h | PEREN_H | | Read/write | Byte | 00h | | | 0Ah | PESEL0 | Port E Select 0 | Read/write | Word | 0000h | | | 0Ah | PESEL0_L | | Read/write | Byte | 00h | | | 0Bh | PESEL0_H | | Read/write | Byte | 00h | | | 0Ch | PESEL1 | Port E Select 1 | Read/write | Word | 0000h | | | 0Ch | PESEL1_L | | Read/write | Byte | 00h | | | 0Dh | PESEL1_H | | Read/write | Byte | 00h | | | 16h | PESELC | Port E Complement Select | Read/write | Word | 0000h | | | 16h | PESELC_L | | Read/write | Byte | 00h | | | 17h | PESELC_H | | Read/write | Byte | 00h | | | 18h | PEIES | Port E Interrupt Edge Select | Read/write | Word | undefined | | | 18h | PEIES_L | | Read/write | Byte | undefined | | | 19h | PEIES_H | | Read/write | Byte | undefined | | | 1Ah | PEIE | Port E Interrupt Enable | Read/write | Word | 0000h | | | 1Ah | PEIE_L | | Read/write | Byte | 00h | | | 1Bh | PEIE_H | | Read/write | Byte | 00h | | | 1Ch | PEIFG | Port E Interrupt Flag | Read/write | Word | 0000h | | | 1Ch | PEIFG_L | | Read/write | Byte | 00h | | | 1Dh | PEIFG_H | | Read/write | Byte | 00h | | Digital I/O Registers www.ti.com | Offset | Acronym | Register Name | Туре | Access | Reset | Section | |--------|----------|------------------------------|------------|--------|-----------|---------| | 00h | PFIN | Port F Input | Read only | Word | undefined | | | 00h | PFIN_L | | Read only | Byte | undefined | | | 01h | PFIN_H | | Read only | Byte | undefined | | | 02h | PFOUT | Port F Output | Read/write | Word | undefined | | | 02h | PFOUT_L | | Read/write | Byte | undefined | | | 03h | PFOUT_H | | Read/write | Byte | undefined | | | 04h | PFDIR | Port F Direction | Read/write | Word | 0000h | | | 04h | PFDIR_L | | Read/write | Byte | 00h | | | 05h | PFDIR_H | | Read/write | Byte | 00h | | | 06h | PFREN | Port F Resistor Enable | Read/write | Word | 0000h | | | 06h | PFREN_L | | Read/write | Byte | 00h | | | 07h | PFREN_H | | Read/write | Byte | 00h | | | 0Ah | PFSEL0 | Port F Select 0 | Read/write | Word | 0000h | | | 0Ah | PFSEL0_L | | Read/write | Byte | 00h | | | 0Bh | PFSEL0_H | | Read/write | Byte | 00h | | | 0Ch | PFSEL1 | Port F Select 1 | Read/write | Word | 0000h | | | 0Ch | PFSEL1_L | | Read/write | Byte | 00h | | | 0Dh | PFSEL1_H | | Read/write | Byte | 00h | | | 16h | PFSELC | Port F Complement Select | Read/write | Word | 0000h | | | 16h | PFSELC_L | | Read/write | Byte | 00h | | | 17h | PFSELC_H | | Read/write | Byte | 00h | | | 18h | PFIES | Port F Interrupt Edge Select | Read/write | Word | undefined | | | 18h | PFIES_L | | Read/write | Byte | undefined | | | 19h | PFIES_H | | Read/write | Byte | undefined | | | 1Ah | PFIE | Port F Interrupt Enable | Read/write | Word | 0000h | | | 1Ah | PFIE_L | | Read/write | Byte | 00h | | | 1Bh | PFIE_H | | Read/write | Byte | 00h | | | 1Ch | PFIFG | Port F Interrupt Flag | Read/write | Word | 0000h | | | 1Ch | PFIFG_L | | Read/write | Byte | 00h | | | 1Dh | PFIFG_H | | Read/write | Byte | 00h | | www.ti.com Digital I/O Registers | Offset | Acronym | Register Name | Туре | Access | Reset | Section | |--------|----------|--------------------------|------------|--------|-----------|---------| | 00h | PJIN | Port J Input | Read only | Word | undefined | | | 00h | PJIN_L | | Read only | Byte | undefined | | | 01h | PJIN_H | | Read only | Byte | undefined | | | 02h | PJOUT | Port J Output | Read/write | Word | undefined | | | 02h | PJOUT_L | | Read/write | Byte | undefined | | | 03h | PJOUT_H | | Read/write | Byte | undefined | | | 04h | PJDIR | Port J Direction | Read/write | Word | 0000h | | | 04h | PJDIR_L | | Read/write | Byte | 00h | | | 05h | PJDIR_H | | Read/write | Byte | 00h | | | 06h | PJREN | Port J Resistor Enable | Read/write | Word | 0000h | | | 06h | PJREN_L | | Read/write | Byte | 00h | | | 07h | PJREN_H | | Read/write | Byte | 00h | | | 0Ah | PJSEL0 | Port J Select 0 | Read/write | Word | 0000h | | | 0Ah | PJSEL0_L | | Read/write | Byte | 00h | | | 0Bh | PJSEL0_H | | Read/write | Byte | 00h | | | 0Ch | PJSEL1 | Port J Select 1 | Read/write | Word | 0000h | | | 0Ch | PJSEL1_L | | Read/write | Byte | 00h | | | 0Dh | PJSEL1_H | | Read/write | Byte | 00h | | | 16h | PJSELC | Port J Complement Select | Read/write | Word | 0000h | | | 16h | PJSELC_L | | Read/write | Byte | 00h | | | 17h | PJSELC_H | | Read/write | Byte | 00h | | Digital I/O Registers www.ti.com # 8.4.1 P1IV Register Port 1 Interrupt Vector Register # Figure 8-1. P1IV Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | |----|------|----|-----|-----|-----|-----|----|--|--|--| | | P1IV | | | | | | | | | | | r0 | rO | rO | rO | rO | rO | r0 | r0 | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | P1IV | | | | | | | | | | | r0 | r0 | r0 | r-0 | r-0 | r-0 | r-0 | r0 | | | | # Table 8-5. P1IV Register Description | Bit | Field | Туре | Reset | Description | | | | |------|-------|------|-------|--------------------------------------------------------------------------------------------------|--|--|--| | 15-0 | P1IV | R | 0h | Port 1 interrupt vector value | | | | | | | | | 00h = No interrupt pending | | | | | | | | | 02h = Interrupt Source: Port 1.0 interrupt; Interrupt Flag: P1IFG.0; Interrupt Priority: Highest | | | | | | | | | 04h = Interrupt Source: Port 1.1 interrupt; Interrupt Flag: P1IFG.1 | | | | | | | | | 06h = Interrupt Source: Port 1.2 interrupt; Interrupt Flag: P1IFG.2 | | | | | | | | | 08h = Interrupt Source: Port 1.3 interrupt; Interrupt Flag: P1IFG.3 | | | | | | | | | 0Ah = Interrupt Source: Port 1.4 interrupt; Interrupt Flag: P1IFG.4 | | | | | | | | | 0Ch = Interrupt Source: Port 1.5 interrupt; Interrupt Flag: P1IFG.5 | | | | | | | | | 0Eh = Interrupt Source: Port 1.6 interrupt; Interrupt Flag: P1IFG.6 | | | | | | | | | 10h = Interrupt Source: Port 1.7 interrupt; Interrupt Flag: P1IFG.7; Interrupt Priority: Lowest | | | | # 8.4.2 P2IV Register Port 2 Interrupt Vector Register # Figure 8-2. P2IV Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | |----|------|----|-----|-----|-----|-----|----|--|--|--| | | P2IV | | | | | | | | | | | r0 | rO | rO | rO | rO | rO | r0 | r0 | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | P2IV | | | | | | | | | | | r0 | r0 | rO | r-0 | r-0 | r-0 | r-0 | r0 | | | | # Table 8-6. P2IV Register Description | Bit | Field | Туре | Reset | Description | |------|-------|------|-------|--------------------------------------------------------------------------------------------------| | 15-0 | P2IV | R | 0h | Port 2 interrupt vector value | | | | | | 00h = No interrupt pending | | | | | | 02h = Interrupt Source: Port 2.0 interrupt; Interrupt Flag: P2IFG.0; Interrupt Priority: Highest | | | | | | 04h = Interrupt Source: Port 2.1 interrupt; Interrupt Flag: P2IFG.1 | | | | | | 06h = Interrupt Source: Port 2.2 interrupt; Interrupt Flag: P2IFG.2 | | | | | | 08h = Interrupt Source: Port 2.3 interrupt; Interrupt Flag: P2IFG.3 | | | | | | 0Ah = Interrupt Source: Port 2.4 interrupt; Interrupt Flag: P2IFG.4 | | | | | | 0Ch = Interrupt Source: Port 2.5 interrupt; Interrupt Flag: P2IFG.5 | | | | | | 0Eh = Interrupt Source: Port 2.6 interrupt; Interrupt Flag: P2IFG.6 | | | | | | 10h = Interrupt Source: Port 2.7 interrupt; Interrupt Flag: P2IFG.7; Interrupt Priority: Lowest | www.ti.com Digital I/O Registers # 8.4.3 P3IV Register Port 3 Interrupt Vector Register ### Figure 8-3. P3IV Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | |----|------|----|-----|-----|-----|-----|----|--|--|--| | | P3IV | | | | | | | | | | | r0 | rO | rO | rO | rO | r0 | rO | r0 | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | P3IV | | | | | | | | | | | r0 | r0 | r0 | r-0 | r-0 | r-0 | r-0 | r0 | | | | ### Table 8-7. P3IV Register Description | Bit | Field | Туре | Reset | Description | |------|-------|------|-------|--------------------------------------------------------------------------------------------------| | 15-0 | P3IV | R | 0h | Port 3 interrupt vector value | | | | | | 00h = No interrupt pending | | | | | | 02h = Interrupt Source: Port 3.0 interrupt; Interrupt Flag: P3IFG.0; Interrupt Priority: Highest | | | | | | 04h = Interrupt Source: Port 3.1 interrupt; Interrupt Flag: P3IFG.1 | | | | | | 06h = Interrupt Source: Port 3.2 interrupt; Interrupt Flag: P3IFG.2 | | | | | | 08h = Interrupt Source: Port 3.3 interrupt; Interrupt Flag: P3IFG.3 | | | | | | 0Ah = Interrupt Source: Port 3.4 interrupt; Interrupt Flag: P3IFG.4 | | | | | | 0Ch = Interrupt Source: Port 3.5 interrupt; Interrupt Flag: P3IFG.5 | | | | | | 0Eh = Interrupt Source: Port 3.6 interrupt; Interrupt Flag: P3IFG.6 | | | | | | 10h = Interrupt Source: Port 3.7 interrupt; Interrupt Flag: P3IFG.7; Interrupt Priority: Lowest | # 8.4.4 P4IV Register Port 4 Interrupt Vector Register # Figure 8-4. P4IV Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----|----|----|-----|------|-----|-----|----| | | | | | P4IV | | | | | r0 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | P4IV | | | | | r0 | r0 | r0 | r-0 | r-0 | r-0 | r-0 | r0 | | | | | | | | | | # **Table 8-8. P4IV Register Description** | Bit | Field | Туре | Reset | Description | |------|-------|------|-------|--------------------------------------------------------------------------------------------------| | 15-0 | P4IV | R | 0h | Port 4 interrupt vector value | | | | | | 00h = No interrupt pending | | | | | | 02h = Interrupt Source: Port 4.0 interrupt; Interrupt Flag: P4IFG.0; Interrupt Priority: Highest | | | | | | 04h = Interrupt Source: Port 4.1 interrupt; Interrupt Flag: P4IFG.1 | | | | | | 06h = Interrupt Source: Port 4.2 interrupt; Interrupt Flag: P4IFG.2 | | | | | | 08h = Interrupt Source: Port 4.3 interrupt; Interrupt Flag: P4IFG.3 | | | | | | 0Ah = Interrupt Source: Port 4.4 interrupt; Interrupt Flag: P4IFG.4 | | | | | | 0Ch = Interrupt Source: Port 4.5 interrupt; Interrupt Flag: P4IFG.5 | | | | | | 0Eh = Interrupt Source: Port 4.6 interrupt; Interrupt Flag: P4IFG.6 | | | | | | 10h = Interrupt Source: Port 4.7 interrupt; Interrupt Flag: P4IFG.7; Interrupt Priority: Lowest | Digital I/O Registers www.ti.com ### 8.4.5 PxIN Register Port x Input Register ### Figure 8-5. PxIN Register | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|---|----|----|---|---|---| | | | | P> | dN | | | | | r | r | r | r | r | r | r | r | # Table 8-9. PxIN Register Description | Bit | Field | Туре | Reset | Description | |-----|-------|------|-----------|--------------------| | 7-0 | PxIN | R | Undefined | Port x input | | | | | | 0b = Input is low | | | | | | 1b = Input is high | # 8.4.6 PxOUT Register Port x Output Register # Figure 8-6. PxOUT Register | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|-----|-----|----|----|----| | | | | PxC | DUT | | | | | rw ### Table 8-10. PxOUT Register Description | Bit | Field | Туре | Reset | Description | |-----|-------|------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7-0 | PxOUT | RW | Undefine<br>d | Port x output When I/O configured to output mode: 0b = Output is low. 1b = Output is high. When I/O configured to input mode and pullups/pulldowns enabled: 0b = Pulldown selected 1b = Pullup selected | # 8.4.7 PxDIR Register Port x Direction Register ### Figure 8-7. PxDIR Register # Table 8-11. P1DIR Register Description | Bit | Field | Туре | Reset | Description | |-----|-------|------|-------|---------------------------------------------------------------------------------| | 7-0 | PxDIR | RW | Oh | Port x direction 0b = Port configured as input 1b = Port configured as output | www.ti.com Digital I/O Registers ### 8.4.8 PxREN Register Port x Pullup or Pulldown Resistor Enable Register ### Figure 8-8. PxREN Register | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------|------|------|------|------|------|------|------| | | | | | REN | | | | | rw-0 ### Table 8-12. PxREN Register Description | Bit | Field | Туре | Reset | Description | |-----|-------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7-0 | PXREN | RW | Oh | Port x pullup or pulldown resistor enable. When the port is configured as an input, setting this bit enables or disables the pullup or pulldown. 0b = Pullup or pulldown disabled 1b = Pullup or pulldown enabled | # 8.4.9 PxSEL0 Register Port x Function Selection Register 0 # Figure 8-9. PxSEL0 Register | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------|------|------|------|------|------|------|------| | | | | PxS | EL0 | | | | | rw-0 ### Table 8-13. PxSEL0 Register Description | Bit | Field | Туре | Reset | Description | |-----|--------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7-0 | PxSEL0 | RW | Oh | Port function selection. Each bit corresponds to one channel on Port x. The values of each bit position in PxSEL1 and PxSEL0 are combined to specify the function. For example, if P1SEL1.5 = 1 and P1SEL0.5 = 0, then the secondary module function is selected for P1.5. See PxSEL1 for the definition of each value. | # 8.4.10 PxSEL1 Register Port x Function Selection Register 1 ### Figure 8-10. PxSEL1 Register | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------|------|------|------|------|------|------|------| | | | | PxS | SEL1 | | | | | rw-0 ### Table 8-14. PxSEL1 Register Description | Bit | Field | Туре | Reset | Description | |-----|--------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7-0 | PxSEL1 | RW | Oh | Port function selection. Each bit corresponds to one channel on Port x. The values of each bit position in PxSEL1 and PxSEL0 are combined to specify the function. For example, if P1SEL1.5 = 1 and P1SEL0.5 = 0, then the secondary module function is selected for P1.5. 00b = General-purpose I/O is selected 01b = Primary module function is selected 10b = Secondary module function is selected | | | | | | · · | Digital I/O Registers www.ti.com ### 8.4.11 PxSELC Register Port x Complement Selection ### Figure 8-11. PxSELC Register | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------|------|------|------|------|------|------|------| | | | | PxS | ELC | | | | | rw-0 # Table 8-15. PxSELC Register Description | Bit | Field | Туре | Reset | Description | |-----|--------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7-0 | PxSELC | RW | Oh | Port selection complement. Each bit that is set in PxSELC complements the corresponding respective bit of both the PxSEL1 and PxSEL0 registers; that is, for each bit set in PxSELC, the corresponding bits in both PxSEL1 and PxSEL0 are both changed at the same time. Always reads as 0. | # 8.4.12 PxIES Register Port x Interrupt Edge Select Register ### Figure 8-12. PxIES Register ### Table 8-16. PxIES Register Description | Bit | Field | Туре | Reset | Description | |-----|-------|------|-----------|------------------------------------------------------| | 7-0 | PxIES | RW | Undefined | Port x interrupt edge select | | | | | | 0b = PxIFG flag is set with a low-to-high transition | | | | | | 1b = PxIFG flag is set with a high-to-low transition | # 8.4.13 PxIE Register Port x Interrupt Enable Register ### Figure 8-13. PxIE Register # **Table 8-17. PxIE Register Description** | Bit | Field | Туре | Reset | Description | |-----|-------|------|-------|--------------------------------------------| | 7-0 | PxIE | RW | 0h | Port x interrupt enable | | | | | | 0b = Corresponding port interrupt disabled | | | | | | 1b = Corresponding port interrupt enabled | www.ti.com Digital I/O Registers # 8.4.14 PxIFG Register Port x Interrupt Flag Register # Figure 8-14. PxIFG Register # Table 8-18. PxIFG Register Description | Bit | Field | Туре | Reset | Description | |-----|-------|------|-------|----------------------------------------------------------------------------------| | 7-0 | PxIFG | RW | 0h | Port x interrupt flag 0b = No interrupt is pending. 1b = Interrupt is pending. | # Capacitive Touch I/O This chapter describes the functionality of the Capacitive Touch I/Os and related control. **Topic Page** 9.1 Capacitive Touch I/O Introduction ..... 9.2 Capacitive Touch I/O Operation......340 9.3 ### 9.1 Capacitive Touch I/O Introduction The Capacitive Touch I/O module allows implementation of a simple capacitive touch sense application. The module uses the integrated pullup and pulldown resistors and an external capacitor to form an oscillator by feeding back the inverted input voltage sensed by the input Schmitt triggers to the pullup and pulldown control. Figure 9-1 shows the capacitive touch I/O principle. Figure 9-1. Capacitive Touch I/O Principle Figure 9-2 shows the block diagram of the Capacitive Touch I/O module. Figure 9-2. Capacitive Touch I/O Block Diagram ### 9.2 Capacitive Touch I/O Operation Enable the Capacitive Touch I/O functionality with CAPTIOEN = 1 and select a port pin using CAPTIOPOSELx and CAPTIOPISELx. The selected port pin is switched into the capacitive touch state, and the resulting oscillating signal is provided to be measured by a timer. The connected timers are device-specific (see the device-specific data sheet). It is possible to scan to successive port pins by incrementing the low byte of the Capacitive Touch I/O control register (CAPTIOCTL\_L) by 2. CapTouch Registers www.ti.com #### 9.3 CapTouch Registers The Capacitive Touch I/O registers and their address offsets are listed in Table 9-1. In a given device, multiple Capacitive Touch I/O registers might be available. The base address of each Capacitive Touch I/O module can be found in the device-specific data sheet. NOTE: All registers have word or byte register access. For a generic register ANYREG, the suffix "\_L" (ANYREG\_L) refers to the lower byte of the register (bits 0 through 7). The suffix "\_H" (ANYREG\_H) refers to the upper byte of the register (bits 8 through 15). Table 9-1. CapTouch Registers | Offset | Acronym | Register Name | Туре | Access | Reset | Section | |--------|--------------|-----------------------------------------|------------|--------|-------|---------------| | 0Eh | CAPTIOxCTL | Capacitive Touch I/O x control register | Read/write | Word | 0000h | Section 9.3.1 | | 0Eh | CAPTIOxCTL_L | | Read/write | Byte | 00h | | | 0Fh | CAPTIOxCTL_H | | Read/write | Byte | 00h | | CapTouch Registers www.ti.com # 9.3.1 CAPTIOxCTL Register (offset = 0Eh) [reset = 0000h] Capacitive Touch I/O x Control Register # Figure 9-3. CAPTIOxCTL Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------------|------|------|-------|--------------|------|----------|----------| | | | Res | erved | | | CAPTIO | CAPTIOEN | | r0 | rO | rO | rO | rO | rO | r-0 | rw-0 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | CAPTIOPOSELx | | | | CAPTIOPISELx | | Reserved | | | rw-0 r0 | # Table 9-2. CAPTIOxCTL Register Description | Bit | Field | Туре | Reset | Description | |-------|--------------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-10 | Reserved | R | 0h | Reserved. Always reads 0. | | 9 | CAPTIO | R | Oh | Capacitive Touch I/O state. Reports the current state of the selected Capacitive Touch I/O. Reads 0 when Capacitive Touch I/O is disabled. 0b = Curent state 0 or Capacitive Touch I/O is disabled 1b = Current state 1 | | 8 | CAPTIOEN | RW | Oh | Capacitive Touch I/O enable 0b = All Capacitive Touch I/Os are disabled. Signal toward timers is 0. 1b = Selected Capacitive Touch I/O is enabled | | 7-4 | CAPTIOPOSELX | RW | Oh | Capacitive Touch I/O port select. Selects port Px. Selecting a port pin that is not available on the device in use gives unpredictible results. 0000b = Px = PJ 0001b = Px = P1 0010b = Px = P2 0011b = Px = P3 0100b = Px = P4 0101b = Px = P5 0110b = Px = P6 0111b = Px = P7 1000b = Px = P8 1001b = Px = P9 1010b = Px = P1 1010b = Px = P1 1100b = Px = P11 1100b = Px = P12 1101b = Px = P13 1110b = Px = P14 1111b = Px = P15 | | 3-1 | CAPTIOPISELx | RW | Oh | Capacitive Touch I/O pin select. Selects the pin within selected port Px (see CAPTIOPOSELx). Selecting a port pin that is not available on the device in use gives unpredictible results. 000b = Px.0 001b = Px.1 010b = Px.2 011b = Px.3 100b = Px.4 101b = Px.5 110b = Px.6 111b = Px.7 | | 0 | Reserved | R | 0h | Reserved. Always reads 0. | # CapTivate™ Module This chapter introduces the CapTIvate module. For additional documentation, examples, and other information, see the CapTIvate Technology Guide. Topic Page | 10.1 | CapTIvate Introduction | 344 | |------|------------------------|-----| | 10.2 | CapTlvate Overview | 344 | | 10.3 | CapTIvate Registers | 348 | | | • | | CapTIvate Introduction www.ti.com ### 10.1 CapTIvate Introduction The CapTlvate module performs relative capacitance measurement to detect capacitance changes. Features of CapTlvate include: - Charge-transfer capacitance measurement technology - Wake on touch: finite state machine to automate detection and environmental compensation without CPU interaction - Each channel can be configured independently as either a receiver (Rx) or a transmitter (Tx) to support both mutual- and self-capacitance measurements - Configuration allows simultaneous or sequential capacitance measurements - Device measurement blocks and I/O channels per block are configurable (see device-specific data sheet for details) - Signal conditioning provides signal gain - Signal conditioning provides offset to compensate for parasitic capacitance - Integrated calibration capacitors - · Frequency hopping (shift) provides immunity to radiated and conducted noises (EMI) - Frequency modulation reduces emissions and improves compatibility with other electronic devices (EMC) - Synchronized conversion reduces measurement noise due to periodic events (for example, trigger conversions on periodic zero-crossing events) - Integrated timer for timer-triggered conversions - Integrated LDO for increased immunity to power supply noise - Integrated oscillator - Processing logic performs measurement filtering, environmental compensation, and threshold detection ### 10.2 CapTIvate Overview ### 10.2.1 Declarations The following declarations, or terms, are used to describe parts of the CapTlvate module: | Contains the <b>core</b> and several <b>blocks</b> | |-------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Contains common digital and analog functions such as oscillator, timing generator, $V_{\text{REG}}$ generator required to supply multiple blocks | | A block contains the analog and digital functions used for charge transfer measurement. | | Nomenclature: CAPx refers to block x, $(x = 0 \text{ up to } 11)$ . This example shows only four blocks. A CapTIvate block is also referred to as a CAPPROX block | | A channel is the physical connection between an external electrode and the corresponding charge-transfer switches | | Nomenclature: | | CAPx.y, refers to block x channel y (maximum configuration: $x = 0$ to 11, $y = 0$ to 7) | | | www.ti.com CapTlvate Overview NOTE: This figure shows the implementation in the MSP430FR26xx devices. Figure 10-1. CapTIvate Declarations ### 10.2.2 Terms The following is a list of abbreviations and application-specific terms. | CT | Charge transfer | |--------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | CAPx.y | CapTIvate block x channel y, $x = 0$ up to 11, $y = 0$ up to 7 | | CRx | CapTIvate channels configured to receive input ( $x = 0$ to 15 in FR26xx) | | CTx | CapTIvate channels configured to transmit output ( $x = 0$ to 15 in FR26xx) | | Vdd | Voltage supply to the device | | Vreg | Regulated voltage supply | | C <sub>s</sub> capacitor | A capacitor used to accumulate charge from an unknown capacitor $(C_x)$ , usually the antenna or touch pad. $C_s$ is named for the sampling capacitor. This capacitor is implemented on the chip. It is also referred to as the <i>pool capacitor</i> . | | C <sub>x</sub> capacitor | In self-capacitance mode, this is a capacitor of unknown value (relative to ground), | generally referred to as the electrode or touch pad. CapTIvate Overview www.ti.com C<sub>M</sub> capacitor In mutual-capacitance mode, this is the capacitor between a transmit antenna (CTx) and a receive antenna (CRx). Channel A channel is a 'CapTIvate Block' I/O. A single channel can be used to measure the self-capacitance of an electrode. Two channels can be used to measure the mutual capacitance between two electrodes (receive electrode and transmit electrode). Figure 10-2. Channel Definition Element (Sensing Element) An element refers to a touch instance (see Figure 10-3). This instance can be realized with a single channel in *self mode* or with two channels in *mutual mode*. Figure 10-3. Element Definition Time slot (Cycle) A time slot represents a single time period during which a number of elements are converted in parallel. For example, if there are four CapTlvate Blocks then four elements can be measured in parallel during one time slot. This is also referred as a *cycle* in CapTlvate Design Center. Wake on touch Periodically measure, filter, and analyze touch elements without CPU interaction. Wake up the CPU (that is, trigger an interrupt) if the analysis determines an event that requires further processing or decision making. Conversion Refers to capacitance measurement of multiple elements within a single time slot. The element with the longest measurement time determines the conversion time. From a hardware perspective, the *conversion* translates the unknown capacitance values to the number of charge transfers required to charge the $C_{\rm S}$ capacitor to the trip voltage, $V_{\rm TRIP}$ . CapTIvate Overview www.ti.com ### 10.2.3 Operation Modes ### 10.2.3.1 Self-Capacitance Mode A capacitor (C<sub>x</sub>) of unknown value (referenced to earth) is formed with a single electrode. As the user approaches (or touches) the single electrode, the capacitance of the electrode increases (see Figure 10-4). This change in capacitance is typically measured relative to the capacitance on the electrode without a user nearby. Should a threshold set by firmware be exceeded, the condition is reported as a 'proximity' or 'contact' event, depending on the level of change detected. Self-capacitive techniques can be employed for buttons, sliders, wheels, proximity sensors, and single-touch panels. Figure 10-4. Self-Capacitance Mode ### 10.2.3.2 Mutual-Capacitance Mode A capacitor (C<sub>M</sub>) is formed between two electrodes where the two electrodes are connected to different pins of the controller IC. When an object approaches or touches the capacitor structure, the electric field between the two electrodes is modified and the capacitance is reduced (see Figure 10-5). This change is measured and compared with a threshold. If the variance exceeds the threshold set in firmware, a contact or proximity event is reported. Figure 10-5. Mutual-Capacitance Mode CapTIvate™ Module CapTIvate Registers www.ti.com # 10.3 CapTIvate Registers Table 10-1 lists the registers for the CapTlvate module. For more information, see the CapTlvate™ Technology Guide. Table 10-1. CapTlvate Registers | Offset | Acronym | Register Name | Section | |--------|---------|-------------------------------------|----------------| | 0x120 | CAPIE | CapTIvate Interrupt Enable Register | Section 10.3.1 | | 0x122 | CAPIFG | CapTIvate Interrupt Flag Register | Section 10.3.2 | | 0x124 | CAPIV | CapTIvate Interrupt Vector Register | Section 10.3.3 | www.ti.com CapTlvate Registers ### 10.3.1 CAPIE Register CapTIvate Interrupt Enable Register # Figure 10-6. CAPIE Register # **Table 10-2. CAPIE Register Description** | Bit | Field | Туре | Reset | Description | |------|------------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-9 | Reserved | R | 0b | Reserved. Always reads as 0. | | 8 | CAPMAXIEN | RW | Ob | CapTlvate maximum count interrupt enable 0b = Interrupt disabled 1b = Interrupt enabled | | 7-4 | Reserved | R | 0b | Reserved. Always reads as 0. | | 3 | CAPCNTRIEN | RW | Ob | CapTlvate conversion counter interrupt enable 0b = Interrupt disabled 1b = Interrupt enabled | | 2 | CAPTIEN | RW | 0b | CapTlvate timer interrupt enable 0b = Interrupt disabled 1b = Interrupt enabled | | 1 | CAPDTCTIEN | RW | Ob | CapTlvate detection interrupt enable 0b = Interrupt disabled 1b = Interrupt enabled | | 0 | EOCIEN | RW | Ob | End of conversion interrupt enable 0b = Interrupt disabled 1b = Interrupt enabled When enabled, an interrupt is called when EOCIFG = 1; that is, at the end of each conversion. EOCIFG must be cleared during the interrupt service routine. | CapTIvate Registers www.ti.com # 10.3.2 CAPIFG Register CapTIvate Interrupt Flag Register # Figure 10-7. CAPIFG Register | • | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |---|----------|------|------|---------|------------|---------|------------|-----------| | | | | | Reserve | d | | | CAPMAXIFG | | r | (0) | r(0) | r(0) | r(0) | r(0) | r(0) | r(0) | rw-(0) | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | Reserved | | | | CAPCNTRIFG | CAPTIFG | CAPDTCTIFG | EOCIFG | | r | (0) | r(0) | r(0) | r(0) | rw-(0) | rw-(0) | rw-(0) | rw-(0) | # **Table 10-3. CAPIFG Register Description** | Bit | Field | Туре | Reset | Description | |------|------------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-9 | Reserved | R | 0b | Reserved. Always reads as 0. | | 8 | CAPMAXIFG | RW | 0b | CapTlvate maximum count interrupt flag 0b = Maximum count not reached 1b = Maximum count reached | | 7-4 | Reserved | R | 0b | Reserved. Always reads as 0. | | 3 | CAPCNTRIFG | RW | 0b | Specified number of conversion have been reached 0b = No interrupt pending 1b = Interrupt pending | | 2 | CAPTIFG | RW | 0b | CapTlvate timer interrupt flag 0b = No interrupt pending 1b = Interrupt pending | | 1 | CAPDTCTIFG | RW | 0b | CapTlvate detection interrupt flag 0b = No interrupt pending 1b = Interrupt pending | | 0 | EOCIFG | RW | Ob | End of conversion interrupt flag 0b = No end of conversion has occurred 1b = End of conversion has occurred This bit is set by hardware when each of the enabled CRx channels has finished converting and its results are ready. This bit is cleared by hardware when a conversion is launched (when CIPF becomes 1) or when CAPPWR = 0. If EOCIEN = 1, the CapTIvate interrupt occurs when EOCIFG transitions to 1. EOCIFG must be cleared by software before exiting the interrupt service routine. | www.ti.com CapTlvate Registers # 10.3.3 CAPIV Register CapTIvate Interrupt Vector Register # Figure 10-8. CAPIV Register # Table 10-4. CAPIV Register Description | Bit | Field | Туре | Reset | Description | |------|--------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------| | 15-0 | CAPIVx | R | 0 | CapTlvate interrupt vector value. Generates a value that can be used as address offset for fast interrupt service routine handling. | | | | | | 0000h = No interrupt pending | | | | | | 0002h = Interrupt source: End of conversion interrupt, Flag = EOCIFG | | | | | | 0004h = Interrupt source: Detection interrupt, Flag = CAPDTCTIFG | | | | | | 0006h = Interrupt source: CapTlvate timer interrupt, Flag = CAPTIFG | | | | | | 0008h = Interrupt source: CapTIvate counter interrupt, Flag = CAPCNTRIFG | | | | | | 000Ah = Interrupt source: Maximun count value reached, Flag = CAPMAXIFG | | | | | | 000Ch to FFFEh = Reserved | | | | | | A read of this register clears the highest-priority interrupt. A write to this register clears all pending interrupts. | # **CRC Module** The cyclic redundancy check (CRC) module provides a signature for a given data sequence. This chapter describes the operation and use of the CRC module. Topic Page | 11.1 | Cyclic Redundancy Check (CRC) Module Introduction | 353 | |------|---------------------------------------------------|-----| | 11.2 | CRC Standard and Bit Order | 353 | | 11.3 | CRC Checksum Generation | 354 | | 11.4 | CRC Registers | 357 | | | | | ## 11.1 Cyclic Redundancy Check (CRC) Module Introduction The CRC module produces a signature for a given sequence of data values. The signature is generated through a feedback path from data bits 0, 4, 11, and 15 (see Figure 11-1). The CRC signature is based on the polynomial given in the CRC-CCITT-BR polynomial (see Equation 12). $$f(x) = x^{16} + x^{12} + x^5 + 1 ag{12}$$ Figure 11-1. LFSR Implementation of CRC-CCITT Standard, Bit 0 is the MSB of the Result Identical input data sequences result in identical signatures when the CRC is initialized with a fixed seed value, whereas different sequences of input data, in general, result in different signatures. ### 11.2 CRC Standard and Bit Order The definitions of the various CRC standards were done in the era of main frame computers, and by convention bit 0 was treated as the MSB. Today, as in most microcontrollers such as the MSP430, bit 0 normally denotes the LSB. In Figure 11-1, the bit convention shown is as given in the original standards (that is, bit 0 is the MSB). The fact that bit 0 is treated for some as LSB and for others as MSB continues to cause confusion. The CRC16 module therefore provides a bit reversed register pair for CRC16 operations to support both conventions. CRC Checksum Generation www.ti.com ### 11.3 CRC Checksum Generation The CRC generator is first initialized by writing a 16-bit word (seed) to the CRC Initialization and Result (CRCINIRES) register. Any data that should be included into the CRC calculation must be written to the CRC Data Input (CRCDI or CRCDIRB) register in the same order that the original CRC signature was calculated. The actual signature can be read from the CRCINIRES register to compare the computed checksum with the expected checksum. Signature generation describes a method of how the result of a signature operation can be calculated. The calculated signature, which is computed by an external tool, is called checksum in the following text. The checksum is stored in the product's memory and is used to check the correctness of the CRC operation result. ### 11.3.1 CRC Implementation To allow parallel processing of the CRC, the linear feedback shift register (LFSR) functionality is implemented with an XOR tree. This implementation shows the identical behavior as the LFSR approach after 8 bits of data are shifted in when the LSB is 'shifted' in first. The generation of a signature calculation must be started by writing a seed to the CRCINIRES register to initialize the register. Software or hardware can transfer data to the CRCDI or CRCDIRB register (for example, from memory). The value in CRCDI or CRCDIRB is then included into the signature, and the result is available in the signature result registers at the next read access (CRCINIRES and CRCRESR). The signature can be generated using word or byte data. If a word data is processed, the lower byte at the even address is used at the first clock (MCLK) cycle. During the second clock cycle, the higher byte is processed. Thus, it takes two clock cycles to process word data, while it takes only one clock (MCLK) cycle to process byte data. Data bytes written to CRCDIRB in word mode or the data byte in byte mode are bit-wise reversed before the CRC engine adds them to the signature. The bits among each byte are reversed. Data bytes written to CRCDI in word mode or the data byte in byte mode are not bit reversed before use by the CRC engine. If the checksum itself (with reversed bit order) is included into the CRC operation (as data written to CRCDI or CRCDIRB), the result in the CRCINIRES and CRCRESR registers must be zero. Figure 11-2. Implementation of CRC-CCITT Using the CRCDI and CRCINIRES Registers ### 11.3.2 Assembler Examples Example 11-1 demonstrates the operation of the on-chip CRC. ### Example 11-1. General Assembler Example ``` PUSH R4 ; Save registers R5 PUSH VOM #StartAddress,R4 ; StartAddress < EndAddress MOV #EndAddress,R5 &INIT, &CRCINIRES ; INIT to CRCINIRES MOV L1 MOV @R4+,&CRCDI ; Item to Data In register R5,R4 CMP ; End address reached? L1 JLO ; No MOV &Check_Sum, &CRCDI ; Yes, Include checksum TST &CRCINIRES ; Result = 0? CRC_ERROR ; No, CRCRES <> 0: error JNZ ; Yes, CRCRES=0: ; information ok. R5 POP ; Restore registers POP R4 ``` The details of the implemented CRC algorithm are shown by the data sequences in Example 11-2 using word or byte accesses and the CRC data-in as well as the CRC data-in reverse byte registers. CRC Checksum Generation www.ti.com ### Example 11-2. Reference Data Sequence ``` #0FFFFh,&CRCINIRES ; initialize CRC mov #00031h,&CRCDI_L ; "1" mov.b #00032h,&CRCDI_L ; "2" mov.b ; "3" #00033h,&CRCDI_L mov.b ; "4" mov.b #00034h,&CRCDI_L ; "5" mov.b #00035h,&CRCDI_L mov.b #00036h,&CRCDI_L ; "6" mov.b #00037h,&CRCDI_L ; "7" ; "8" mov.b #00038h,&CRCDI_L ; "9" mov.b #00039h,&CRCDI_L cmp #089F6h, &CRCINIRES ; compare result ; CRCRESR contains 06F91h jeq &Success ; no error br &Error ; to error handler mov #OFFFFh, &CRCINIRES ; initialize CRC #03231h,&CRCDI mov.w ; "1" & "2" ; "3" & "4" mov.w #03433h,&CRCDI mov.w #03635h,&CRCDI ; "5" & "6" #03837h,&CRCDI ; "7" & "8" mov.w mov.b #039h, &CRCDI_L ; "9" cmp #089F6h, &CRCINIRES ; compare result ; CRCRESR contains 06F91h iea &Success ; no error br &Error ; to error handler #0FFFFh, &CRCINIRES ; initialize CRC mov mov.b #00031h,&CRCDIRB_L ; "1" mov.b #00032h,&CRCDIRB_L ; "2" #00033h,&CRCDIRB_L ; "3" mov.b #00034h,&CRCDIRB_L ; "4" mov.b mov.b #00035h,&CRCDIRB_L ; "5" mov.b #00036h,&CRCDIRB_L ; "6" mov.b #00037h,&CRCDIRB_L ; "7" mov.b #00038h,&CRCDIRB_L ; "8" mov.b #00039h,&CRCDIRB_L ; "9" cmp #029B1h,&CRCINIRES ; compare result ; CRCRESR contains 08D94h &Success iea ; no error ; to error handler br &Error #0FFFFh,&CRCINIRES ; initialize CRC mov #03231h,&CRCDIRB ; "1" & "2" mov.w #03433h,&CRCDIRB ; "3" & "4" mov.w #03635h,&CRCDIRB ; "5" & "6" ; "7" & "8" mov.w #03837h,&CRCDIRB #039h, &CRCDIRB_L ; "9" mov.b #029B1h, &CRCINIRES ; compare result cmp ; CRCRESR contains 08D94h jeq &Success ; no error hr &Error ; to error handler ``` CRC Registers www.ti.com ### 11.4 CRC Registers The CRC module registers are listed in Table 11-1. The base address can be found in the device-specific data sheet. The address offset is given in Table 11-1. NOTE: All registers have word or byte register access. For a generic register ANYREG, the suffix "\_L" (ANYREG\_L) refers to the lower byte of the register (bits 0 through 7). The suffix "\_H" (ANYREG\_H) refers to the upper byte of the register (bits 8 through 15). Table 11-1. CRC Registers | Offset | Acronym | Register Name | Туре | Access | Reset | Section | |--------|-------------|-------------------------------|------------|--------|-------|----------------| | 00h | CRCDI | CRC Data In | Read/write | Word | 0000h | Section 11.4.1 | | 00h | CRCDI_L | | Read/write | Byte | 00h | | | 01h | CRCDI_H | | Read/write | Byte | 00h | | | 02h | CRCDIRB | CRC Data In Reverse Byte | Read/write | Word | 0000h | Section 11.4.2 | | 02h | CRCDIRB_L | | Read/write | Byte | 00h | | | 03h | CRCDIRB_H | | Read/write | Byte | 00h | | | 04h | CRCINIRES | CRC Initialization and Result | Read/write | Word | FFFFh | Section 11.4.3 | | 04h | CRCINIRES_L | | Read/write | Byte | FFh | | | 05h | CRCINIRES_H | | Read/write | Byte | FFh | | | 06h | CRCRESR | CRC Result Reverse | Read only | Word | FFFFh | Section 11.4.4 | | 06h | CRCRESR_L | | Read/write | Byte | FFh | | | 07h | CRCRESR_H | | Read/write | Byte | FFh | | CRC Registers www.ti.com ### 11.4.1 CRCDI Register CRC Data In Register ### Figure 11-3. CRCDI Register ### Table 11-2. CRCDI Register Description | Bit | Field | Туре | Reset | Description | |------|-------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------| | 15-0 | CRCDI | RW | | CRC data in. Data written to the CRCDI register is included to the present signature in the CRCINIRES register according to the CRC-CCITT standard. | # 11.4.2 CRCDIRB Register CRC Data In Reverse Register ### Figure 11-4. CRCDIRB Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | |------|---------|------|------|------|------|------|------|--| | | CRCDIRB | | | | | | | | | rw-0 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | CRCDIRB | | | | | | | | | rw-0 | ### Table 11-3. CRCDIRB Register Description | Bit | Field | Туре | Reset | Description | |------|---------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-0 | CRCDIRB | RW | Oh | CRC data in reverse byte. Data written to the CRCDIRB register is included to the present signature in the CRCINIRES and CRCRESR registers according to the CRC-CCITT standard. Reading the register returns the register CRCDI content. | www.ti.com CRC Registers ### 11.4.3 CRCINIRES Register CRC Initialization and Result Register ### Figure 11-5. CRCINIRES Register ### Table 11-4. CRCINIRES Register Description | Bit | Field | Туре | Reset | Description | |------|-----------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-0 | CRCINIRES | RW | FFFFh | CRC initialization and result. This register holds the current CRC result (according to the CRC-CCITT standard). Writing to this register initializes the CRC calculation with the value written to it. The value just written can be read from CRCINIRES register. | ### 11.4.4 CRCRESR Register CRC Reverse Result Register ### Figure 11-6. CRCRESR Register | | 3 | | | | | | | | | | | | | |---------|-----|-----|-----|-----|-----|-----|-----|--|--|--|--|--|--| | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | | | CRCRESR | | | | | | | | | | | | | | | r-1 | | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | CRCRESR | | | | | | | | | | | | | | | r-1 | | | | | | ### Table 11-5. CRCRESR Register Description | Bit | Field | Туре | Reset | Description | |------|---------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-0 | CRCRESR | R | | CRC reverse result. This register holds the current CRC result (according to the CRC-CCITT standard). The order of bits is reverse (for example, CRCINIRES[15] = CRCRESR[0]) to the order of bits in the CRCINIRES register (see example code). | # Watchdog Timer (WDT\_A) The watchdog timer is a 32-bit timer that can be used as a watchdog or as an interval timer. This chapter describes the watchdog timer. The enhanced watchdog timer, WDT\_A, is implemented in all devices. Topic Page | 12.1 | WDT_A Introduction | 361 | |------|--------------------|-----| | 12.2 | WDT_A Operation | 363 | | 12.3 | WDT_A Registers | 365 | | | | | www.ti.com WDT\_A Introduction #### 12.1 WDT\_A Introduction The primary function of the watchdog timer (WDT\_A) module is to perform a controlled system restart after a software problem occurs. If the selected time interval expires, a system reset is generated. If the watchdog function is not needed in an application, the module can be configured as an interval timer and can generate interrupts at selected time intervals. Features of the watchdog timer module include: - Eight software-selectable time intervals - Watchdog mode - · Interval mode - Password-protected access to Watchdog Timer Control (WDTCTL) register - Selectable clock source - · Can be stopped to conserve power - Clock fail-safe feature Figure 12-1 shows the watchdog timer block diagram. #### NOTE: Watchdog timer powers up active. After a PUC, the WDT\_A module is automatically configured in the watchdog mode with an initial approximately 32-ms reset interval using the SMCLK. The user must set up or halt the WDT\_A before the initial reset interval expires. WDT\_A Introduction www.ti.com Figure 12-1. Watchdog Timer Block Diagram www.ti.com WDT\_A Operation ### 12.2 WDT\_A Operation The watchdog timer module can be configured as either a watchdog or interval timer with the WDTCTL register. WDTCTL is a 16-bit password-protected read/write register. Any read or write access must use word instructions, and write accesses must include the write password 05Ah in the upper byte. A write to WDTCTL with any value other than 05Ah in the upper byte is a password violation and causes a PUC system reset, regardless of timer mode. Any read of WDTCTL reads 069h in the upper byte. A byte read of the WDTCTL high or low byte returns the value of the low byte. Writing a byte wide to upper or lower byte of WDTCTL results in a PUC. ### 12.2.1 Watchdog Timer Counter (WDTCNT) The WDTCNT is a 32-bit up counter that is not directly accessible by software. The WDTCNT is controlled and its time intervals are selected through the Watchdog Timer Control (WDTCTL) register. The WDTCNT can be sourced from SMCLK, ACLK, VLOCLK, or X\_CLK on some devices. The clock source is selected with the WDTSSEL bits. The timer interval is selected with the WDTIS bits. ### 12.2.2 Watchdog Mode After a PUC condition, the WDT module is configured in the watchdog mode with an initial 32-ms (approximate) reset interval using the SMCLK. The user must set up, halt, or clear the watchdog timer before this initial reset interval expires, or another PUC is generated. When the watchdog timer is configured to operate in watchdog mode, either writing to WDTCTL with an incorrect password or expiration of the selected time interval triggers a PUC. A PUC resets the watchdog timer to its default condition. ### 12.2.3 Interval Timer Mode Setting the WDTTMSEL bit to 1 selects the interval timer mode. This mode can be used to provide periodic interrupts. In interval timer mode, the WDTIFG flag is set at the expiration of the selected time interval. A PUC is not generated in interval timer mode at expiration of the selected timer interval, and the WDTIFG enable bit WDTIE remains unchanged. When the WDTIE bit and the GIE bit are set, the WDTIFG flag requests an interrupt. The WDTIFG interrupt flag is automatically reset when its interrupt request is serviced, or may be reset by software. The interrupt vector address in interval timer mode is different from that in watchdog mode. #### NOTE: Modifying the watchdog timer The watchdog timer interval should be changed together with WDTCNTCL = 1 in a single instruction to avoid an unexpected immediate PUC or interrupt. The watchdog timer should be halted before changing the clock source to avoid a possible incorrect interval. #### 12.2.4 Watchdog Timer Interrupts The watchdog timer uses two bits in the SFRs for interrupt control: - WDT interrupt flag, WDTIFG, located in SFRIFG1.0 - WDT interrupt enable, WDTIE, located in SFRIE1.0 When using the watchdog timer in the watchdog mode, the WDTIFG flag sources a reset vector interrupt. The WDTIFG can be used by the reset interrupt service routine to determine if the watchdog caused the device to reset. If the flag is set, the watchdog timer initiated the reset condition, either by timing out or by a password violation. If WDTIFG is cleared, the reset was caused by a different source. When using the watchdog timer in interval timer mode, the WDTIFG flag is set after the selected time interval and requests a watchdog timer interval timer interrupt if the WDTIE and the GIE bits are set. The interval timer interrupt vector is different from the reset vector used in watchdog mode. In interval timer mode, the WDTIFG flag is reset automatically when the interrupt is serviced, or can be reset with software. WDT\_A Operation www.ti.com #### 12.2.5 Clock Fail-Safe Feature The WDT\_A provides a fail-safe clocking feature, ensuring the clock to the WDT\_A cannot be disabled while in watchdog mode. This means the low-power modes may be affected by the choice for the WDT\_A clock. If SMCLK or ACLK fails as the WDT\_A clock source, VLOCLK is automatically selected as the WDT\_A clock source. When the WDT\_A module is used in interval timer mode, there is no fail-safe feature within WDT\_A for the clock source. #### 12.2.6 Operation in Low-Power Modes MSP devices have several low-power modes. Different clock signals are available in different low-power modes. The requirements of the application and the type of clocking that is used determine how the WDT\_A should be configured. For example, the WDT\_A should not be configured in watchdog mode with a clock source that is originally sourced from DCO, XT1 in high-frequency mode, or XT2 using SMCLK or ACLK if the user wants to use low-power mode 3. In this case, SMCLK or ACLK would remain enabled, increasing the current consumption of LPM3. When the watchdog timer is not required, the WDTHOLD bit can be used to hold the WDTCNT, reducing power consumption. Any write operation to WDTCTL must be a word operation with 05Ah (WDTPW) in the upper byte (see Example 12-1). #### Example 12-1. Writes to WDTCTL ``` ; Periodically clear an active watchdog MOV #WDTPW+WDTIS2+WDTIS1+WDTCNTCL,&WDTCTL ; ; Change watchdog timer interval MOV #WDTPW+WDTCNTCL+SSEL,&WDTCTL ; ; Stop the watchdog MOV #WDTPW+WDTHOLD,&WDTCTL ; ; Change WDT to interval timer mode, clock/8192 interval MOV #WDTPW+WDTCNTCL+WDTTMSEL+WDTIS2+WDTIS0,&WDTCTL ``` WDT\_A Registers www.ti.com ### 12.3 WDT\_A Registers The watchdog timer module registers are listed in Table 12-1. The base address for the watchdog timer module registers and special function registers (SFRs) can be found in the device-specific data sheets. The address offset is given in Table 12-1. NOTE: All registers have word or byte register access. For a generic register ANYREG, the suffix "\_L" (ANYREG\_L) refers to the lower byte of the register (bits 0 through 7). The suffix "\_H" (ANYREG\_H) refers to the upper byte of the register (bits 8 through 15). Table 12-1. WDT\_A Registers | Offset | Acronym | Register Name | Туре | Access | Reset | Section | |--------|----------|------------------------|------------|--------|-------|----------------| | 00h | WDTCTL | Watchdog Timer Control | Read/write | Word | 6904h | Section 12.3.1 | | 00h | WDTCTL_L | | Read/write | Byte | 04h | | | 01h | WDTCTL_H | | Read/write | Byte | 69h | | WDT\_A Registers www.ti.com ### 12.3.1 WDTCTL Register Watchdog Timer Control Register ### Figure 12-2. WDTCTL Register ### Table 12-2. WDTCTL Register Description | Bit | Field | Туре | Reset | Description | | | | |------|----------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | 15-8 | WDTPW | RW | 69h | Watchdog timer password. Always reads as 069h. Must be written as 05Ah, or a PUC is generated. | | | | | 7 | WDTHOLD | RW | 0h | Watchdog timer hold. This bit stops the watchdog timer. Setting WDTHOLD = 1 when the WDT is not in use conserves power. 0b = Watchdog timer is not stopped 1b = Watchdog timer is stopped | | | | | 6-5 | WDTSSEL | RW | 0h | 0h Watchdog timer clock source select 00b = SMCLK 01b = ACLK 10b = VLOCLK 11b = X CLK | | | | | 4 | WDTTMSEL | RW | Oh | Watchdog timer mode select 0b = Watchdog mode 1b = Interval timer mode | | | | | 3 | WDTCNTCL | RW | 0h | Watchdog timer counter clear. Setting WDTCNTCL = 1 clears the count value to 0000h. WDTCNTCL is automatically reset. 0b = No action 1b = WDTCNT = 0000h | | | | | 2-0 | WDTIS | RW | 4h | Watchdog timer interval select. These bits select the watchdog timer interval to set the WDTIFG flag or generate a PUC. 000b = Watchdog clock source / 2³1 (18:12:16 at 32.768 kHz) 001b = Watchdog clock source / 2²7 (01:08:16 at 32.768 kHz) 010b = Watchdog clock source / 2²3 (00:04:16 at 32.768 kHz) 011b = Watchdog clock source / 2¹9 (00:00:16 at 32.768 kHz) 100b = Watchdog clock source / 2¹5 (1 s at 32.768 kHz) 101b = Watchdog clock source / 2¹3 (250 ms at 32.768 kHz) 110b = Watchdog clock source / 2⁰ (15.625 ms at 32.768 kHz) 111b = Watchdog clock source / 2⁰ (1.95 ms at 32.768 kHz) | | | | ## Chapter 13 # Timer\_A Timer\_A is a 16-bit timer/counter with multiple capture/compare registers. There can be multiple Timer\_A modules on a given device (see the device-specific data sheet). This chapter describes the operation and use of the Timer\_A module. Topic Page | 13.1 | Timer_A Introduction | 368 | |------|----------------------|-----| | | Timer_A Operation | | | | Timer_A Registers | | | | | | Timer A Introduction www.ti.com #### 13.1 Timer\_A Introduction Timer\_A is a 16-bit timer/counter with up to seven capture/compare registers. Timer\_A can support multiple captures or compares, PWM outputs, and interval timing. Timer\_A also has extensive interrupt capabilities. Interrupts may be generated from the counter on overflow conditions and from each of the capture/compare registers. Timer\_A features include: - Asynchronous 16-bit timer/counter with four operating modes - · Selectable and configurable clock source - Up to seven configurable capture/compare registers - · Configurable outputs with pulse width modulation (PWM) capability - Asynchronous input and output latching - · Interrupt vector register for fast decoding of all Timer\_A interrupts Figure 13-1 shows the block diagram of Timer\_A. #### NOTE: Use of the word count Count is used throughout this chapter. It means the counter must be in the process of counting for the action to take place. If a particular value is directly written to the counter, an associated action does not take place. #### **NOTE:** Nomenclature There may be multiple instantiations of Timer\_A on a given device. The prefix TAx is used, where x is a greater than equal to zero indicating the Timer\_A instantiation. For devices with one instantiation, x = 0. The suffix n, where n = 0 to 6, represents the specific capture/compare registers associated with the Timer\_A instantiation. www.ti.com Timer\_A Introduction 13 0 Figure 13-1. Timer\_A Block Diagram Timer A Operation www.ti.com #### 13.2 Timer\_A Operation The Timer\_A module is configured with user software. The setup and operation of Timer\_A are discussed in the following sections. #### 13.2.1 16-Bit Timer Counter The 16-bit timer/counter register, TAXR, increments or decrements (depending on mode of operation) with each rising edge of the clock signal. TAXR can be read or written with software. Additionally, the timer can generate an interrupt when it overflows. #### NOTE: Accessing TAXR Care must be taken when accessing TAxR. If TAxR is accessed (read or write) by the CPU while the timer is running, the value read from TAxR or the value written to TAxR could be unpredictable. To avoid this uncertainty, the timer should be stopped by writing the MC bits to zero before accessing TAxR. For read, alternatively TAxR can be read multiple times while the timer is running, and a majority vote taken in software to determine the correct reading. #### 13.2.1.1 Clock Source Select and Divider The timer clock can be sourced from ACLK, SMCLK, or externally from TAxCLK or INCLK. The clock source is selected with the TASSEL bits. The selected clock source may be passed directly to the timer or divided by 2, 4, or 8, using the ID bits. The selected clock source can be further divided by 2, 3, 4, 5, 6, 7, or 8 using the TAIDEX bits. The timer clock divider logic is reset when TACLR is set. #### NOTE: Timer A dividers The timer clock dividers are reset by the TACLR bit. The clock divider is implemented as a down counter. To reset the down counter's state, write one to the TACLR bit in Stop mode. When the timer starts counting, the timer clock begins clocking at the first rising edge of the Timer\_A clock source selected with the TASSEL bits and continues clocking at the divider setting set by the ID and TAIDEX bits. The clock divider (ID bits and TAIDEX bits) should not be changed while the timer is running. It could cause unexpected behaviors. Stop the timer first (MC = 0) when changing the ID bits or TAIDEX bits. #### 13.2.2 Starting the Timer When the device is out of reset (BOR or POR), the timer is at stop condition and all registers have default values. To start the timer from the default condition, perform the following steps: - 1. Write 1 to the TACLR bit (TACLR = 1) to clear TAxR, clock divider state, and the counter direction. - 2. If necessary, write initial counter value to TAxR. - 3. Initialize TAxCCRn. - 4. Apply desired configuration to TAxIV, TAIDEX and TAxCCTLn. - 5. Apply desired configuration to TAxCTL including to MC bits. Timer\_A Operation www.ti.com #### 13.2.3 Timer Mode Control The timer has four modes of operation: stop, up, continuous, and up/down (see Table 13-1). The operating mode is selected with the MC bits. | MC | Mode | Description | |----|------------|-----------------------------------------------------------------------------------------| | 00 | Stop | The timer is halted. | | 01 | Up | The timer repeatedly counts from zero to the value of TAxCCR0 | | 10 | Continuous | The timer repeatedly counts from zero to 0FFFFh. | | 11 | Up/down | The timer repeatedly counts from zero up to the value of TAxCCR0 and back down to zero. | Table 13-1. Timer Modes To move from one mode to another, first stop the timer by writing zero to the MC bits (MC = 0), then set the MC bits to the desired mode (see Table 13-1 for details). ### 13.2.3.1 Up Mode The Up mode is used if the timer period must be different from 0FFFFh counts. The timer repeatedly counts up to the value of compare register TAxCCR0, which defines the period (see Figure 13-2). The number of timer counts in the period is TAxCCR0 + 1. When the timer value equals TAxCCR0, the timer restarts counting from zero. If Up mode is selected when the timer value is greater than TAxCCR0, the timer immediately restarts counting from zero. Figure 13-2. Up Mode The TAXCCR0 CCIFG interrupt flag is set when the timer counts to the TAXCCR0 value. The TAIFG interrupt flag is set when the timer counts from TAxCCR0 to zero. Figure 13-3 shows the flag set cycle. Figure 13-3. Up Mode Flag Setting ### 13.2.3.1.1 Changing Period Register TAxCCR0 When the MC bits are configured to Up mode (MC = 1) from Stop mode (MC = 0), the timer starts counting up from the value in TAxR if the TAxCCR0 is greater than TAxR. If TAxCCR0 is less than TAxR or equal to TAxR, the timer rolls back to zero and then counts up to TAxCCR0. One additional count may occur before the counter rolls to zero. Changing TAxCCR0 while the timer is running may result in unexpected behaviors. To avoid the uncertainty, TAxCCR0 should be updated in Stop mode (MC = 0). Timer A Operation www.ti.com #### 13.2.3.2 Continuous Mode In the Continuous mode, the timer repeatedly counts up to 0FFFFh and restarts from zero as shown in Figure 13-4. The capture/compare register TAxCCR0 works the same way as the other capture/compare registers. Figure 13-4. Continuous Mode The TAIFG interrupt flag is set when the timer *counts* from 0FFFFh to zero. Figure 13-5 shows the flag set cycle. Figure 13-5. Continuous Mode Flag Setting #### 13.2.3.3 Use of Continuous Mode The Continuous mode can be used to generate independent time intervals and output frequencies. Each time an interval is completed, an interrupt is generated. The next time interval is added to the TAxCCRn register in the interrupt service routine. Figure 13-6 shows two separate time intervals, $t_0$ and $t_1$ , being added to the capture/compare registers. In this usage, the time interval is controlled by hardware, not software, without impact from interrupt latency. Up to n (where n = 0 to 6), independent time intervals or output frequencies can be generated using capture/compare registers. Figure 13-6. Continuous Mode Time Intervals www.ti.com Timer A Operation Time intervals can be produced with other modes as well, where TAxCCR0 is used as the period register. Their handling is more complex because the sum of the old TAxCCR0 data and the new period can be higher than the TAxCCR0 value. When the previous TAxCCR0 value plus $t_x$ is greater than the TAxCCR0 data, the TAxCCR0 value must be subtracted to obtain the correct time interval. #### 13.2.3.4 Up/Down Mode The Up/Down mode is used if the timer period must be different from 0FFFFh counts, and if symmetrical pulse generation is needed. The timer repeatedly counts up to the value of compare register TAxCCR0 and back down to zero (see Figure 13-7). The period is twice the value in TAxCCR0. Figure 13-7. Up/Down Mode The count direction is latched. This allows the timer to be stopped and then restarted in the same direction it was counting before it was stopped. If this is not desired, the TACLR bit must be set in Stop mode to clear the direction. The TACLR bit also clears the TAXR value and the timer clock divider (the divider setting remains unchanged). In Up/Down mode, the TAxCCR0 CCIFG interrupt flag and the TAIFG interrupt flag are set only once during a period, separated by one-half the timer period. The TAxCCR0 CCIFG interrupt flag is set when the timer *counts* from TAxCCR0 – 1 to TAxCCR0, and TAIFG is set when the timer completes *counting* down from 0001h to 0000h. Figure 13-8 shows the flag set cycle. Figure 13-8. Up/Down Mode Flag Setting #### 13.2.3.4.1 Changing Period Register TAxCCR0 When the MC bits is configured to Up/Down mode (MC = 3) from Stop mode, the timer starts counting up or down depending on the previous direction. The timer keeps the previous direction regardless of the previous mode. The direction can be forced to up direction by setting to TACLR bit in Stop mode, but the direction cannot be forced to down direction when the timer starts with up direction, if TAxCCR0 is greater than TAxR, the timer will count up to TAxCC0. If TAxCCR0 is less than TAxR, or equal to TAxR, the timer begins counting down. However, one additional count may occur before the counter begins counting down. In Up/Down mode, updating TAxCCR0 while the timer is running may result in unexpected behaviors. To avoid the uncertainly, TAxCCR0 should be updated in Stop mode (MC = 0). Timer\_A Operation www.ti.com #### 13.2.3.5 Use of Up/Down Mode The Up/Down mode supports applications that require dead times between output signals (see Section 13.2.5). For example, to avoid overload conditions, two outputs driving an H-bridge must never be in a high state simultaneously. In the example shown in Figure 13-9, the t<sub>dead</sub> is: $$t_{dead} = t_{timer} \times (TAxCCR1 - TAxCCR2)$$ Where: $t_{dead}$ = Time during which both outputs need to be inactive $t_{timer}$ = Cycle time of the timer clock TAxCCRn = Content of capture/compare register n Figure 13-9. Output Unit in Up/Down Mode #### 13.2.4 Capture/Compare Blocks Up to seven identical capture/compare blocks, TAxCCRn (where n = 0 to 7), are present in Timer\_A. Any of the blocks may be used to capture the timer data or to generate time intervals. #### 13.2.4.1 Capture Mode The capture mode is selected when CAP = 1. Capture mode is used to record time events. It can be used for speed computations or time measurements. The capture inputs CCIxA and CCIxB are connected to external pins or internal signals and are selected with the CCIS bits. The CM bits select the capture edge of the input signal as rising, falling, or both. A capture occurs on the selected edge of the input signal. If a capture occurs: - The timer value is copied into the TAxCCRn register. - The interrupt flag CCIFG is set. The input signal level can be read at any time through the CCI bit. Devices may have different signals connected to CCIxA and CCIxB. See the device-specific data sheet for the connections of these signals. ### NOTE: Reading TAxCCRn in Capture mode In Capture mode, if TAxCCRn is ready by the CPU while the timer counter value is being copied into TAxCCRn at a capture event, the value ready by the CPU could be invalid. To avoid this undesired result, TAxCCRn must be read after the CCIFG flag is set and before the next capture event occurs. www.ti.com Timer A Operation The capture signal can be asynchronous to the timer clock and cause a race condition. Setting the SCS bit synchronizes the capture with the next timer clock. Setting the SCS bit to synchronize the capture signal with the timer clock is recommended (see Figure 13-10). Figure 13-10. Capture Signal (SCS = 1) #### NOTE: Changing Capture Input source (CCIS bits) Switching between CCIxA and CCIxB while in capture mode may cause unintended capture events. To avoid this scenario, capture inputs should only be changed when capture mode is disabled (CM = {0} or CAP = 0). Note that switching between GND and VCC can be performed at any time. See Section 13.2.4.1.1 for details. Overflow logic is provided in each capture/compare register to indicate if a second capture was performed before the value from the first capture was read. Bit COV is set when this occurs as shown in Figure 13-11. COV must be reset with software. Figure 13-11. Capture Cycle Timer A Operation www.ti.com #### 13.2.4.1.1 Capture Initiated by Software Captures can be initiated by software. The CM bits can be set for capture on both edges. Software then sets CCIS1 = 1 and toggles bit CCIS0 to switch the capture signal between $V_{CC}$ and GND, initiating a capture each time CCIS0 changes state: ``` MOV #CAP+SCS+CCIS1+CM_3,&TAOCCTL1 ; Setup TAOCCTL1, synch. capture mode ; Event trigger on both edges of capture input. XOR #CCISO,&TAOCCTL1 ; TAOCCR1 = TAOR ``` #### 13.2.4.2 Compare Mode The compare mode is selected when CAP = 0. The compare mode is used to generate PWM output signals or interrupts at specific time intervals. When TAXR counts to the value in a TAXCCRn, where n represents the specific capture/compare register. - Interrupt flag CCIFG is set. - Internal signal EQUn = 1. - EQUn affects the output according to the output mode. - The input signal CCI is latched into SCCI. #### NOTE: Updating TAxCCRn registers In Compare mode, the timer should be stopped by writing the MC bits to zero (MC = 0) before writing new data to TAxCCRn. Updating TAxCCRn while the timer is running could result in unexpected behaviors. ### 13.2.5 Output Unit Each capture/compare block contains an output unit. The output unit is used to generate output signals, such as PWM signals. Each output unit has eight operating modes that generate signals based on the EQU0 and EQUn signals. ### 13.2.5.1 Output Modes The output modes are defined by the OUTMOD bits and are described in Table 13-2. The OUTn signal is changed with the rising edge of the timer clock for all modes except mode 0. Output modes 2, 3, 6, and 7 are not useful for output unit 0 because EQUn = EQU0. **Table 13-2. Output Modes** | OUTMOD | Mode | Description | |--------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 000 | Output | The output signal OUTn is defined by the OUT bit. The OUTn signal updates immediately when OUT is updated. | | 001 | Set | The output is set when the timer <i>counts</i> to the TAxCCRn value. It remains set until a reset of the timer, or until another output mode is selected and affects the output. | | 010 | Toggle/Reset | The output is toggled when the timer <i>counts</i> to the TAxCCRn value. It is reset when the timer <i>counts</i> to the TAxCCR0 value. | | 011 | Set/Reset | The output is set when the timer <i>counts</i> to the TAxCCRn value. It is reset when the timer <i>counts</i> to the TAxCCR0 value. | | 100 | Toggle | The output is toggled when the timer <i>counts</i> to the TAxCCRn value. The output period is double the timer period. | | 101 | Reset | The output is reset when the timer <i>counts</i> to the TAxCCRn value. It remains reset until another output mode is selected and affects the output. | | 110 | Toggle/Set | The output is toggled when the timer <i>counts</i> to the TAxCCRn value. It is set when the timer <i>counts</i> to the TAxCCR0 value. | | 111 | Reset/Set | The output is reset when the timer <i>counts</i> to the TAxCCRn value. It is set when the timer <i>counts</i> to the TAxCCR0 value. | www.ti.com Timer\_A Operation ### 13.2.5.1.1 Output Example—Timer in Up Mode The OUTn signal is changed when the timer *counts* up to the TAxCCRn value and rolls from TAxCCR0 to zero, depending on the output mode. Figure 13-12 shows an example using TAxCCR0 and TAxCCR1. Figure 13-12. Output Example – Timer in Up Mode Timer\_A Operation www.ti.com ### 13.2.5.1.2 Output Example – Timer in Continuous Mode The OUTn signal is changed when the timer reaches the TAxCCRn and TAxCCR0 values, depending on the output mode. An example is shown in Figure 13-13 using TAxCCR0 and TAxCCR1. Figure 13-13. Output Example - Timer in Continuous Mode www.ti.com Timer A Operation ### 13.2.5.1.3 Output Example – Timer in Up/Down Mode The OUTn signal changes when the timer equals TAxCCRn in either count direction and when the timer equals TAxCCR0, depending on the output mode. Figure 13-14 shows an example using TAxCCR0 and TAxCCR2. Figure 13-14. Output Example - Timer in Up/Down Mode #### NOTE: Switching between output modes TI recommends stopping the timer (MC = 0) before changing the OUTMOD bits. However, if it is necessary to change OUTMOD bits while the timer is running, one of the OUTMOD bits should remain set during the transition, unless switching to mode 0. Otherwise, output glitching can occur, because a NOR gate decodes output mode 0. A safe method for switching between output modes is to use output mode 7 as a transition state: BIS #OUTMOD\_7,&TAOCCTL1 ; Set output mode=7 BIC #OUTMOD,&TAOCCTL1 ; Clear unwanted bits Timer A Operation www.ti.com #### 13.2.6 Timer A Interrupts Two interrupt vectors are associated with the 16-bit Timer A module: - TAXCCR0 interrupt vector for TAXCCR0 CCIFG - TAXIV interrupt vector for all other CCIFG flags and TAIFG In capture mode, any CCIFG flag is set when a timer value is captured in the associated TAxCCRn register. In compare mode, any CCIFG flag is set if TAxR counts to the associated TAxCCRn value. Software may also set or clear any CCIFG flag. All CCIFG flags request an interrupt when their corresponding CCIE bit and the GIE bit are set. #### 13.2.6.1 TAxCCR0 Interrupt The TAXCCR0 CCIFG flag has the highest Timer\_A interrupt priority and has a dedicated interrupt vector as shown in Figure 13-15. The TAXCCR0 CCIFG flag is automatically reset when the TAXCCR0 interrupt request is serviced. Figure 13-15. Capture/Compare TAxCCR0 Interrupt Flag #### 13.2.6.2 TAxIV, Interrupt Vector Generator The TAXCCRy CCIFG flags and TAIFG flags are prioritized and combined to source a single interrupt vector. The interrupt vector register TAXIV is used to determine which flag requested an interrupt. The highest-priority enabled interrupt generates a number in the TAxIV register (see register description). This number can be evaluated or added to the program counter to automatically enter the appropriate software routine. Disabled Timer\_A interrupts do not affect the TAxIV value. Any access, read or write, of the TAxIV 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, if the TAxCCR1 and TAxCCR2 CCIFG flags are set when the interrupt service routine accesses the TAxIV register, TAxCCR1 CCIFG is reset automatically. After the RETI instruction of the interrupt service routine is executed, the TAxCCR2 CCIFG flag generates another interrupt. www.ti.com Timer\_A Operation ### 13.2.6.2.1 TAxIV Software Example The following software example shows the recommended use of TAxIV and the handling overhead. The TAxIV value is added to the PC to automatically jump to the appropriate routine. The example assumes a single instantiation of the largest timer configuration available. The numbers at the right margin show the necessary CPU cycles for each instruction. The software overhead for different interrupt sources includes interrupt latency and return-from-interrupt cycles, but not the task handling itself. The latencies are: - Capture/compare block TA0CCR0: 11 cycles - Capture/compare blocks TA0CCR1, TA0CCR2, TA0CCR3, TA0CCR4, TA0CCR5, TA0CCR6: 16 cycles - Timer overflow TA0IFG: 14 cycles | | _ | er for TAOCCR | 0 ( | CCIFG. | Cycles | |-----------------------|-----------|---------------|-----|----------------------------|--------| | CCIFG_0_ | | | | | _ | | ; | | ; Start o | Ė J | handler Interrupt latency | 6 | | | RETI | | | | 5 | | ; Interr | upt handl | er for TAOIFG | , : | TAOCCR1 through TAOCCR6 CC | IFG. | | TA0_HND | | | ; | Interrupt latency | 6 | | | ADD | &TAOIV,PC | ; | Add offset to Jump table | 3 | | | RETI | | | Vector 0: No interrupt | 5 | | | JMP | CCIFG_1_HND | ; | Vector 2: TAOCCR1 | 2 | | | JMP | | | Vector 4: TA0CCR2 | 2 | | | JMP | | | Vector 6: TAOCCR3 | 2 | | | JMP | | | Vector 8: TAOCCR4 | 2 | | | JMP | | | Vector 10: TAOCCR5 | 2 | | | JMP | CCIFG_6_HND | ; | Vector 12: TA0CCR6 | 2 | | TA0IFG_H | ND | | ; | Vector 14: TA0IFG Flag | | | 1110 11 0 <u>_</u> 11 | | | | Task starts here | | | | RETI | | | | 5 | | | | | | | | | CCIFG_6_ | HND | | ; | Vector 12: TAOCCR6 | | | | • • • | | | Task starts here | | | | RETI | | ; | Back to main program | 5 | | CCIFG_5_ | HND | | ; | Vector 10: TA0CCR5 | | | 0011 0_0_ | | | | Task starts here | | | | RETI | | | Back to main program | 5 | | | 1122 | | • | zacii de mazii program | 3 | | CCIFG_4_ | HND | | ; | Vector 8: TAOCCR4 | | | | | | ; | Task starts here | | | | RETI | | ; | Back to main program | 5 | | CCIFG_3_ | HND | | ; | Vector 6: TAOCCR3 | | | 00110_5_ | | | | Task starts here | | | | RETI | | | Back to main program | 5 | | | 11211 | | • | bacil to mail program | 3 | | CCIFG_2_ | HND | | ; | Vector 4: TAOCCR2 | | | | | | ; | Task starts here | | | | RETI | | ; | Back to main program | 5 | | CCIFG_1_ | ПИП | | | Vector 2: TAOCCR1 | | | CC11, G_1_ | | | | Task starts here | | | | RETI | | | Back to main program | 5 | | | VF1T | | , | pack to main broaram | Э | Timer A Operation www.ti.com #### NOTE: Changing Timer Clock source TI recommends stopping the timer before modifying its operation while it is running. A delay of at least 1.5 timer clocks is required to resynchronize before restarting the timer if the timer clock source is asynchronous to MCLK, because the timer state machine takes this time to synchronize the clock source as the new configuration. (Assuming the timer uses a 1-MHz clock, it is recommended to have a 1.5-µs delay before starting the timer.) ### 13.2.7 Updating Timer\_A Configuration Care must be taken when applying new configuration to TAxCTL, TAxCTLn, or TAxEX0. The control bits listed are designed not to be dynamically updated while the timer is running, Changing the controls listed below while the timer is running could result in unexpected behaviors. Note that the control bits that are not listed below can be read or updated while the timer is running. - TAxCTL register - Clock source select (TASSEL) - Input divider (ID) - Mode control (MC) (Note: Switching to Stop mode can be performed at any time) - Timer A clear (TACLR) - TAxCCTLn registers - Capture mode (CM) (Note: Switching to no capture mode can be performed any time) - Capture/compare input select (CCIS) (Note: Switching between GND an VCC can be performed at any time) - Synchronize capture source (SCS) - Capture mode (CAP) - Output mode (OUTMOD) - TAxEX0 register - Input divider expansion (TAIDEX) Follow these steps to update Timer A configuration: - 1. Write zero to the mode control bits (MC = 0) (Note: Do not use TACLR bit to reset the mode control bits). - If necessary, write 1 to the TACLR bit (TACLR = 1) to clear TAxR, clock divider state, and the counter direction. - 3. If necessary, update counter value to TAxR. - 4. If updating the CM, CCIS, SCS bits or the TAxCCRn registers and the timer is in capture mode, disable capture mode first by writing zero to the CAP bit (CAP = 0) or the CM bits (CM = 0). - 5. Apply desired configuration to TAxCCRn, TAIDEX, and TAxCCTLn. - 6. Apply desired configuration to TAxCTL including the MC bits. www.ti.com Timer\_A Registers ## 13.3 Timer\_A Registers Timer\_A registers are listed in Table 13-3 for the largest configuration available. The base address can be found in the device-specific data sheet. Table 13-3. Timer\_A Registers | Offset | Acronym | Register Name | Туре | Access | Reset | Section | |--------|----------|------------------------------------|------------|--------|-------|----------------| | 00h | TAxCTL | Timer_Ax Control | Read/write | Word | 0000h | Section 13.3.1 | | 02h | TAxCCTL0 | Timer_Ax Capture/Compare Control 0 | Read/write | Word | 0000h | Section 13.3.3 | | 04h | TAxCCTL1 | Timer_Ax Capture/Compare Control 1 | Read/write | Word | 0000h | Section 13.3.3 | | 06h | TAxCCTL2 | Timer_Ax Capture/Compare Control 2 | Read/write | Word | 0000h | Section 13.3.3 | | 08h | TAxCCTL3 | Timer_Ax Capture/Compare Control 3 | Read/write | Word | 0000h | Section 13.3.3 | | 0Ah | TAxCCTL4 | Timer_Ax Capture/Compare Control 4 | Read/write | Word | 0000h | Section 13.3.3 | | 0Ch | TAxCCTL5 | Timer_Ax Capture/Compare Control 5 | Read/write | Word | 0000h | Section 13.3.3 | | 0Eh | TAxCCTL6 | Timer_Ax Capture/Compare Control 6 | Read/write | Word | 0000h | Section 13.3.3 | | 10h | TAxR | Timer_Ax Counter | Read/write | Word | 0000h | Section 13.3.2 | | 12h | TAxCCR0 | Timer_Ax Capture/Compare 0 | Read/write | Word | 0000h | Section 13.3.4 | | 14h | TAxCCR1 | Timer_Ax Capture/Compare 1 | Read/write | Word | 0000h | Section 13.3.4 | | 16h | TAxCCR2 | Timer_Ax Capture/Compare 2 | Read/write | Word | 0000h | Section 13.3.4 | | 18h | TAxCCR3 | Timer_Ax Capture/Compare 3 | Read/write | Word | 0000h | Section 13.3.4 | | 1Ah | TAxCCR4 | Timer_Ax Capture/Compare 4 | Read/write | Word | 0000h | Section 13.3.4 | | 1Ch | TAxCCR5 | Timer_Ax Capture/Compare 5 | Read/write | Word | 0000h | Section 13.3.4 | | 1Eh | TAxCCR6 | Timer_Ax Capture/Compare 6 | Read/write | Word | 0000h | Section 13.3.4 | | 2Eh | TAxIV | Timer_Ax Interrupt Vector | Read only | Word | 0000h | Section 13.3.5 | | 20h | TAxEX0 | Timer_Ax Expansion 0 | Read/write | Word | 0000h | Section 13.3.6 | Timer\_A Registers www.ti.com ## 13.3.1 TAxCTL Register Timer\_Ax Control Register ### Figure 13-16. TAxCTL Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|--------|--------|--------|----------|--------|--------|--------| | | | Rese | erved | | | TAS | SEL | | rw-(0) | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | ID | M | С | Reserved | TACLR | TAIE | TAIFG | | rw-(0) | rw-(0) | rw-(0) | rw-(0) | rw-(0) | w-(0) | rw-(0) | rw-(0) | ## Table 13-4. TAxCTL Register Description | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-10 | Reserved | RW | 0h | Reserved | | 9-8 | TASSEL | RW | 0h | Timer_A clock source select 00b = TAxCLK 01b = ACLK 10b = SMCLK 11b = INCLK | | 7-6 | ID | RW | Oh | Input divider. These bits along with the TAIDEX bits select the divider for the input clock. 00b = /1 01b = /2 10b = /4 11b = /8 | | 5-4 | MC | RW | 0h | Mode control. Setting MC = 0 when Timer_A is not in use conserves power. 00b = Stop mode: Timer is halted 01b = Up mode: Timer counts up to TAxCCR0 10b = Continuous mode: Timer counts up to 0FFFFh 11b = Up/Down mode: Timer counts up to TAxCCR0 then down to 0000h | | 3 | Reserved | RW | 0h | Reserved | | 2 | TACLR | RW | 0h | Timer_A clear. Setting this bit resets TAxR, the timer clock divider logic (the divider setting remains unchanged), and the count direction. The TACLR bit is automatically reset and always reads as zero. | | 1 | TAIE | RW | Oh | Timer_A interrupt enable. This bit enables the TAIFG interrupt request. 0b = Interrupt disabled 1b = Interrupt enabled | | 0 | TAIFG | RW | Oh | Timer_A interrupt flag 0b = No interrupt pending 1b = Interrupt pending | www.ti.com Timer\_A Registers ### 13.3.2 TAXR Register Timer\_Ax Counter Register ### Figure 13-17. TAxR Register ### **Table 13-5. TAxR Register Description** | Bit | Field | Туре | Reset | Description | |------|-------|------|-------|-------------------------------------------------------------| | 15-0 | TAxR | RW | 0h | Timer_A counter. The TAxR register is the count of Timer_A. | Timer\_A Registers www.ti.com ## 13.3.3 TAxCCTLn Register Timer\_Ax Capture/Compare Control n Register ### Figure 13-18. TAxCCTLn Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|--------|--------|--------|--------|--------|----------|--------| | C | CM | CC | CIS | SCS | SCCI | Reserved | CAP | | rw-(0) | rw-(0) | rw-(0) | rw-(0) | rw-(0) | r-(0) | r-(0) | rw-(0) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | OUTMOD | | CCIE | CCI | OUT | COV | CCIFG | | rw-(0) | rw-(0) | rw-(0) | rw-(0) | r | rw-(0) | rw-(0) | rw-(0) | ## Table 13-6. TAxCCTLn Register Description | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-14 | СМ | RW | Oh | Capture mode 00b = No capture 01b = Capture on rising edge 10b = Capture on falling edge 11b = Capture on both rising and falling edges | | 13-12 | CCIS | RW | 0h | Capture/compare input select. These bits select the TAxCCR0 input signal. See the device-specific data sheet for specific signal connections. 00b = CCIxA 01b = CCIxB 10b = GND 11b = VCC | | 11 | SCS | RW | Oh | Synchronize capture source. This bit is used to synchronize the capture input signal with the timer clock. 0b = Asynchronous capture 1b = Synchronous capture | | 10 | SCCI | RW | 0h | Synchronized capture/compare input. The selected CCI input signal is latched with the EQUx signal and can be read from this bit. | | 9 | Reserved | R | 0h | Reserved. Reads as 0. | | 8 | CAP | RW | Oh | Capture mode 0b = Compare mode 1b = Capture mode | | 7-5 | OUTMOD | RW | Oh | Output mode. Modes 2, 3, 6, and 7 are not useful for TAxCCR0 because EQUx = EQU0. 000b = OUT bit value 001b = Set 010b = Toggle/reset 011b = Set/reset 100b = Toggle 101b = Reset 110b = Toggle/set 111b = Reset/set | | 4 | CCIE | RW | Oh | Capture/compare interrupt enable. This bit enables the interrupt request of the corresponding CCIFG flag. 0b = Interrupt disabled 1b = Interrupt enabled | | 3 | CCI | R | 0h | Capture/compare input. The selected input signal can be read by this bit. | | 2 | OUT | RW | Oh | Output. For OUTMOD = 0, this bit directly controls the state of the output. 0b = Output low 1b = Output high | www.ti.com Timer\_A Registers ## Table 13-6. TAxCCTLn Register Description (continued) | Bit | Field | Туре | Reset | Description | |-----|-------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1 | cov | RW | 0h | Capture overflow. This bit indicates a capture overflow occurred. COV must be reset with software. 0b = No capture overflow occurred 1b = Capture overflow occurred | | 0 | CCIFG | RW | Oh | Capture/compare interrupt flag 0b = No interrupt pending 1b = Interrupt pending | Timer\_A Registers www.ti.com ### 13.3.4 TAxCCRn Register Timer\_A Capture/Compare n Register ### Figure 13-19. TAxCCRn Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|--------|--------|--------|--------|--------|--------|--------| | | | | TAxC | CCRn | | | | | rw-(0) | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | TAxC | CCRn | | | | | rw-(0) ### Table 13-7. TAxCCRn Register Description | Bit | Field | Туре | Reset | Description | |------|---------|------|-------|------------------------------------------------------------------------------------------------------------| | 15-0 | TAxCCRn | RW | 0h | Compare mode: TAxCCRn holds the data for the comparison to the timer value in the Timer_A Register, TAR. | | | | | | Capture mode: The Timer_A register, TAxR, is copied into the TAxCCRn register when a capture is performed. | ### 13.3.5 TAxIV Register Timer\_Ax Interrupt Vector Register ### Figure 13-20. TAxIV Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----|----|----|----|-------|-------|-------|----| | | | | TA | AIV | | | | | r0 | r0 | r0 | rO | r0 | rO | r0 | r0 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | TA | AIV | | | | | r0 | r0 | r0 | r0 | r-(0) | r-(0) | r-(0) | r0 | ### Table 13-8. TAxIV Register Description | Bit | Field | Туре | Reset | Description | |------|-------|------|-------|-------------------------------------------------------------------------------------------------------| | 15-0 | TAIV | R | 0h | Timer_A interrupt vector value | | | | | | 00h = No interrupt pending | | | | | | 02h = Interrupt Source: Capture/compare 1; Interrupt Flag: TAxCCR1 CCIFG; Interrupt Priority: Highest | | | | | | 04h = Interrupt Source: Capture/compare 2; Interrupt Flag: TAxCCR2 CCIFG | | | | | | 06h = Interrupt Source: Capture/compare 3; Interrupt Flag: TAxCCR3 CCIFG | | | | | | 08h = Interrupt Source: Capture/compare 4; Interrupt Flag: TAxCCR4 CCIFG | | | | | | 0Ah = Interrupt Source: Capture/compare 5; Interrupt Flag: TAxCCR5 CCIFG | | | | | | 0Ch = Interrupt Source: Capture/compare 6; Interrupt Flag: TAxCCR6 CCIFG | | | | | | 0Eh = Interrupt Source: Timer overflow; Interrupt Flag: TAxCTL TAIFG; Interrupt Priority: Lowest | www.ti.com Timer\_A Registers ### 13.3.6 TAxEX0 Register Timer\_Ax Expansion 0 Register ### Figure 13-21. TAxEX0 Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----|----|----------|------|-------|--------|-----------|--------| | | | | Rese | erved | | | | | r0 | r0 | r0 | rO | rO | rO | rO | r0 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | Reserved | | | | TAIDEX(1) | | | r0 | r0 | r0 | r0 | r0 | rw-(0) | rw-(0) | rw-(0) | <sup>&</sup>lt;sup>(1)</sup> After programming TAIDEX bits and configuration of the timer, set TACLR bit to ensure proper reset of the timer divider logic. ### Table 13-9. TAxEX0 Register Description | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-3 | Reserved | R | 0h | Reserved. Reads as 0. | | 2-0 | TAIDEX | RW | Oh | Input divider expansion. These bits along with the ID bits select the divider for the input clock. 000b = Divide by 1 001b = Divide by 2 010b = Divide by 3 011b = Divide by 4 100b = Divide by 5 101b = Divide by 6 110b = Divide by 7 111b = Divide by 8 | ## Chapter 14 # Timer\_B Timer\_B is a 16-bit timer/counter with multiple capture/compare registers. There can be multiple Timer\_B modules on a given device (see the device-specific data sheet). This chapter describes the operation and use of the Timer\_B module. **Topic** Page | 14.1 | Timer_B Introduction | 391 | |------|----------------------|-----| | 14.2 | Timer_B Operation | 393 | | 14.3 | Timer_B Registers | 408 | | | _ <b>-</b> | | www.ti.com Timer\_B Introduction #### 14.1 Timer\_B Introduction Timer\_B is a 16-bit timer/counter with up to seven capture/compare registers. Timer\_B can support multiple capture/compares, PWM outputs, and interval timing. Timer\_B also has extensive interrupt capabilities. Interrupts may be generated from the counter on overflow conditions and from each of the capture/compare registers. Timer\_B features include: - Asynchronous 16-bit timer/counter with four operating modes and four selectable lengths - Selectable and configurable clock source - Up to seven configurable capture/compare registers - Configurable outputs with PWM capability - Double-buffered compare latches with synchronized loading - Interrupt vector register for fast decoding of all Timer\_B interrupts Figure 14-1 shows the block diagram of Timer\_B. #### NOTE: Use of the word count Count is used throughout this chapter. It means the counter must be in the process of counting for the action to take place. If a particular value is directly written to the counter, an associated action does not take place. #### **NOTE: Nomenclature** There may be multiple instantiations of Timer\_B on a given device. The prefix TBx is used, where x is greater than or equal to zero, indicating the Timer\_B instantiation. For devices with one instantiation, x = 0. The suffix n, where n = 0 to 6, represents the specific capture/compare registers associated with the Timer\_B instantiation. #### 14.1.1 Similarities and Differences From Timer A Timer\_B is identical to Timer\_A with the following exceptions: - The length of Timer\_B is programmable to be 8, 10, 12, or 16 bits. - Timer B TBxCCRn registers are double-buffered and can be grouped. - All Timer\_B outputs can be put into a high-impedance state. - The SCCI bit function is not implemented in Timer B. Timer\_B Introduction www.ti.com Figure 14-1. Timer\_B Block Diagram www.ti.com Timer\_B Operation #### 14.2 Timer\_B Operation The Timer\_B module is configured with user software. The setup and operation of Timer\_B is discussed in the following sections. #### 14.2.1 16-Bit Timer Counter The 16-bit timer/counter register, TBxR, increments or decrements (depending on mode of operation) with each rising edge of the clock signal. TBxR can be read or written with software. Additionally, the timer can generate an interrupt when it overflows. #### NOTE: Accessing TBxR Care must be taken when accessing TBxR. If TBxR is accessed (read or write) by the CPU while the timer is running, the value that is read from TBxR or the value that is written to TBxR could be unpredictable. To avoid this uncertainty, the timer should be stopped by writing the MC bits to zero before accessing TBxR. For read, alternatively TBxR can be read multiple times while the timer is running, and a majority vote taken in software to determine the correct reading. #### 14.2.1.1 TBxR Length Timer\_B can be configured to operate as an 8-, 10-, 12-, or 16-bit timer with the CNTL bits. The maximum count value, TBxR<sub>(max)</sub>, for the selectable lengths is 0FFh, 03FFh, 0FFFh, and 0FFFFh, respectively. Data written to the TBxR register in 8-, 10-, and 12-bit mode is right justified with leading zeros. #### 14.2.1.2 Clock Source Select and Divider The timer clock can be sourced from ACLK, SMCLK, or externally through the TBxCLK or INCLK pins. The clock source is selected with the TBSSEL bits. The selected clock source may be passed directly to the timer or divided by 2,4, or 8, using the ID bits. The selected clock source can be further divided by 2, 3, 4, 5, 6, 7, or 8 using the TBIDEX bits. The timer clock divider logic is reset when TBCLR is set. ### NOTE: Timer\_B dividers The timer clock dividers are reset by the TBCLR bit. The clock divider is implemented as a down counter. To reset the state of the down counter, write one to the TBCLR bit when the timer is stopped. When the timer starts counting, the timer clock begins clocking at the first rising edge of the Timer\_B clock source selected with the TBSSEL bits and continues clocking at the divider setting set by the ID and TBIDEX bits. The clock divider (ID bits and TBIDEX bits) should not be changed while the timer is running, as this change could cause unexpected behaviors. Stop the timer first (MC = 0) when changing the ID or TBIDEX bits. #### 14.2.2 Starting the Timer When the device is out of reset (BOR or POR), the timer is at stop condition and all registers have default values. To start the timer from the default condition: - Write 1 to the TBCLR bit (TBCLR = 1) to clear TBxR, clock divider state, and the counter direction. - If necessary, write initial counter value to TBxR. - Initialize TBxCCRn. - Apply desired configuration to TBxIV, TBIDEX, and TBxCCTLn. - Apply desired configuration to TBxCTL including to MC bits. Timer B Operation www.ti.com #### 14.2.3 Timer Mode Control The timer has four modes of operation: stop, up, continuous, and up/down. The operating mode is selected with the MC bits (see Table 14-1). To move one mode to another, first stop the timer by writing zero to the MC bits (MC = 0), then set the MC bits to the desired mode. See Section 14.2.7 for details. | MC | Mode | Description | | | | | | |----|------------|---------------------------------------------------------------------------------------------|--|--|--|--|--| | 00 | Stop | The timer is halted. | | | | | | | 01 | Up | The timer repeatedly counts from zero to the value of compare register TBxCL0. | | | | | | | 10 | Continuous | The timer repeatedly counts from zero to the value selected by the CNTL bits. | | | | | | | 11 | Up/down | The timer repeatedly counts from zero up to the value of TBxCL0 and then back down to zero. | | | | | | #### 14.2.3.1 Up Mode The up mode is used if the timer period must be different from $\mathsf{TBxR}_{(\mathsf{max})}$ count. The timer repeatedly counts up to the value of compare latch $\mathsf{TBxCL0}$ , which defines the period (see Figure 14-2). The number of timer counts in the period is $\mathsf{TBxCL0} + 1$ . When the timer value equals $\mathsf{TBxCL0}$ , the timer restarts counting from zero. If up mode is selected when the timer value is greater than $\mathsf{TBxCL0}$ , the timer immediately restarts counting from zero. Figure 14-2. Up Mode The TBxCCR0 CCIFG interrupt flag is set when the timer *counts* to the TBxCL0 value. The TBIFG interrupt flag is set when the timer *counts* from TBxCL0 to zero. Figure 14-3 shows the flag set cycle. Figure 14-3. Up Mode Flag Setting ### 14.2.3.1.1 Changing Period Register TBxCL0 When the MC bits are configured to up mode (MC = 1) from stop mode (MC = 0), the timer starts counting up from the value in TBxR if TBxCL0 is greater than TBxR. If TBxCL0 is less than TBxR or equal to TBxR, the timer rolls back to zero and then counts up to TBxCL0. One additional count may occur before the counter rolls to zero. Care must be taken when updating TBxCCR0. TBxCCR0 is automatically transferred to TBxCL0 based on the timing selected by the CLLD bits. If the CPU accesses TBxCCR0 to write new data while the automatic data transfer from TBxCCR0 to TBxCL0 is in process, the data transferred to TBxCL0 is unpredictable. Thus the user software must not update TBxCCR0 while TBxCL0 are being copied from TBxCCR0. www.ti.com Timer\_B Operation #### 14.2.3.2 Continuous Mode In continuous mode, the timer repeatedly counts up to $TBxR_{(max)}$ and restarts from zero (see Figure 14-4). The compare latch TBxCL0 works the same way as the other capture/compare registers. Figure 14-4. Continuous Mode The TBIFG interrupt flag is set when the timer *counts* from TBxR<sub>(max)</sub> to zero. Figure 14-5 shows the flag set cycle. Figure 14-5. Continuous Mode Flag Setting #### 14.2.3.3 Use of Continuous Mode The continuous mode can be used to generate independent time intervals and output frequencies. Each time an interval is completed, an interrupt is generated. The next time interval is added to the TBxCLn latch in the interrupt service routine (ISR). Figure 14-6 shows two separate time intervals ( $t_0$ and $t_1$ ) being added to the capture/compare registers. The time interval is controlled by hardware, not software, without impact from interrupt latency. Up to n (where n = 0 to 7), independent time intervals or output frequencies can be generated using capture/compare registers. Figure 14-6. Continuous Mode Time Intervals Timer B Operation www.ti.com Time intervals can be produced with other modes as well, where TBxCL0 is used as the period register. Their handling is more complex, because the sum of the old TBxCLn data and the new period can be higher than the TBxCL0 value. When the sum of the previous TBxCLn value plus $t_x$ is greater than the TBxCL0 data, the old TBxCL0 value must be subtracted to obtain the correct time interval. ### 14.2.3.4 Up/Down Mode The up/down mode is used if the timer period must be different from TBxR<sub>(max)</sub> counts and if symmetrical pulse generation is needed. The timer repeatedly counts up to the value of compare latch TBxCL0, and back down to zero (see Figure 14-7). The period is twice the value in TBxCL0. ### NOTE: $TBxCL0 > TBxR_{(max)}$ If TBxCL0 > TBxR $_{\text{(max)}}$ , the counter operates as if it were configured for continuous mode. It does not count down from TBxR $_{\text{(max)}}$ to zero. Figure 14-7. Up/Down Mode The count direction is latched. This allows the timer to be stopped and then restarted in the same direction it was counting before it was stopped. If this is not desired, the TBCLR bit must be set in stop mode to clear the direction. Setting TBCLR also clears the TBxR value and the clock divider counter logic (the divider setting remains unchanged). In up/down mode, the TBxCCR0 CCIFG interrupt flag and the TBIFG interrupt flag are set only once during the period, separated by one-half the timer period. The TBxCCR0 CCIFG interrupt flag is set when the timer *counts* from TBxCL0 – 1 to TBxCL0, and TBIFG is set when the timer completes *counting* down from 0001h to 0000h. Figure 14-8 shows the flag set cycle. Figure 14-8. Up/Down Mode Flag Setting www.ti.com Timer\_B Operation # 14.2.3.4.1 Changing the Value of Period Register TBxCL0 When the MC bits are changed to up/down mode (MC = 3) from stop mode (MC = 0), the timer starts counting up or down depending on the previous direction. The timer keeps the previous direction regardless of the previous mode. The direction can be forced to up direction by setting the TBCLR bit when in stop mode, but the direction cannot be forced to down direction. When the timer starts with up direction, if TBxCL0 is greater than TBxR, the timer *counts* up to TBxCL0. If TBxCL0 is less than TBxR or equal to TBxR, the timer *counts* down. However, one additional count may occur before the counter begins counting down. Care must be taken when updating TBxCCR0. TBxCCR0 is automatically transferred to TBxCL0 based on the timing selected by the CLLD bits. If the CPU accesses TBxCCR0 to write new data while the automatic data transfer from TBxCCR0 to TBxCL0 is in process, the data transferred to TBxCL0 is unpredictable. Thus the user software must not update TBxCCR0 while TBxCL0 is being copied from TBxCCR0. # 14.2.3.5 Use of Up/Down Mode The up/down mode supports applications that require dead times between output signals (see Section 14.2.5). For example, to avoid overload conditions, two outputs driving an H-bridge must never be in a high state simultaneously. In the example shown in Figure 14-9, the $t_{dead}$ is: $$t_{dead} = t_{timer} \times (TBxCL1 - TBxCL3)$$ #### where - t<sub>dead</sub> = Time during which both outputs need to be inactive - t<sub>timer</sub> = Cycle time of the timer clock - TBxCLn = Content of compare latch n (13) The ability to simultaneously load grouped compare latches ensures the dead times. Figure 14-9. Output Unit in Up/Down Mode Timer B Operation www.ti.com ### 14.2.4 Capture/Compare Blocks Up to seven identical capture/compare blocks, TBxCCRn (where n = 0 to 6), are present in Timer\_B. Any of the blocks may be used to capture the timer data or to generate time intervals. ### 14.2.4.1 Capture Mode The capture mode is selected when CAP = 1. Capture mode is used to record time events. It can be used for speed computations or time measurements. The capture inputs CCIxA and CCIxB are connected to external pins or internal signals and are selected with the CCIS bits. The CM bits select the capture edge of the input signal as rising, falling, or both. A capture occurs on the selected edge of the input signal. If a capture is performed: - The timer value is copied into the TBxCCRn register. - · The interrupt flag CCIFG is set. The input signal level can be read at any time from the CCI bit. Devices may have different signals connected to CCIxA and CCIxB. See the device-specific data sheet for the connections of these signals. The capture signal can be asynchronous to the timer clock and cause a race condition. Setting the SCS bit synchronizes the capture with the next timer clock. Setting the SCS bit to synchronize the capture signal with the timer clock is recommended (see Figure 14-10). Figure 14-10. Capture Signal (SCS = 1) #### **NOTE: Changing Capture Input source (CCIS bits)** Switching between CCIxA and CCIxB while an capture mode may cause unintended capture events. To avoid this scenario, capture inputs should be changed only when capture mode is disabled (CM = 0 or CAP = 0). Note that switching between GND and VCC can be performed at any time. See Section 14.2.4.1.1 for details. Overflow logic is provided in each capture/compare register to indicate if a second capture was performed before the value from the first capture was read. Bit COV is set when this occurs (see Figure 14-11). COV must be reset with software. www.ti.com Timer\_B Operation Figure 14-11. Capture Cycle ### 14.2.4.1.1 Capture Initiated by Software Captures can be initiated by software. The CM bits can be set for capture on both edges. Software then sets CCIS1 = 1 and toggles CCIS0 to switch the capture signal between $V_{CC}$ and GND, initiating a capture each time CCIS0 changes state: MOV #CAP+SCS+CCIS1+CM\_3,&TB0CCTL1 ; Setup TB0CCTL1 XOR #CCIS0,&TB0CCTL1 ; TB0CCR1 = TB0R ### NOTE: Capture Initiated by Software In general, changing capture inputs while in capture mode may cause unintended capture events. For this scenario, switching the capture input between VCC and GND, disabling the capture mode is not required. #### 14.2.4.2 Compare Mode The compare mode is selected when CAP = 0. Compare mode is used to generate PWM output signals or interrupts at specific time intervals. When TBxR *counts* to the value in a TBxCLn, where n represents the specific capture/compare latch: - · Interrupt flag CCIFG is set. - Internal signal EQUn = 1. - EQUn affects the output according to the output mode. Timer B Operation www.ti.com ### 14.2.4.2.1 Compare Latch TBxCLn The TBxCCRn compare latch, TBxCLn, holds the data for the comparison to the timer value in compare mode. TBxCLn is buffered by TBxCCRn. The buffered compare latch gives the user control over when a compare period updates. The user cannot directly access TBxCLn. Compare data is written to each TBxCCRn and automatically transferred to TxBCLn. The timing of the transfer from TBxCCRn to TBxCLn is selectable with the CLLD bits (see Table 14-2). Table 14-2. TBxCLn Load Events | CLLD | Description | |------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 00 | New data is transferred from TBxCCRn to TBxCLn immediately when TBxCCRn is written. | | 01 | New data is transferred from TBxCCRn to TBxCLn when TBxR counts to 0. | | 10 | New data is transferred from TBxCCRn to TBxCLn when TBxR <i>counts</i> to 0 for up and continuous modes. New data is transferred to from TBxCCRn to TBxCLn when TBxR <i>counts</i> to the old TBxCL0 value or to 0 for up/down mode. | | 11 | New data is transferred from TBxCCRn to TBxCLn when TBxR counts to the old TBxCLn value. | # 14.2.4.2.2 Grouping Compare Latches Multiple compare latches may be grouped together for simultaneous updates with the TBCLGRPx bits. When using groups, the CLLD bits of the lowest numbered TBxCCRn in the group determine the load event for each compare latch of the group, except when TBCLGRP = 3 (see Table 14-3). The CLLD bits of the controlling TBxCCRn must not be set to zero. When the CLLD bits of the controlling TBxCCRn are set to zero, all compare latches update immediately when their corresponding TBxCCRn is written; no compare latches are grouped. Two conditions must exist for the compare latches to be loaded when grouped. First, all TBxCCRn registers of the group must be updated, even when new TBxCCRn data = old TBxCCRn data. Second, the load event must occur. **Table 14-3. Compare Latch Operating Modes** | TBCLGRPx | Grouping | Update Control | |----------|--------------------------------------------------------------|-------------------------------| | 00 | None | Individual | | 01 | TBxCL1 + TBxCL2<br>TBxCL3 + TBxCL4<br>TBxCL5 + TBxCL6 | TBxCCR1<br>TBxCCR3<br>TBxCCR5 | | 10 | TBxCL1 + TBxCL2 + TBxCL3<br>TBxCL4 + TBxCL5 + TBxCL6 | TBxCCR1<br>TBxCCR4 | | 11 | TBxCL0 + TBxCL1 + TBxCL2 + TBxCL3 + TBxCL4 + TBxCL5 + TBxCL6 | TBxCCR1 | www.ti.com Timer\_B Operation ### 14.2.5 Output Unit Each capture/compare block contains an output unit. The output unit is used to generate output signals, such as PWM signals. Each output unit has eight operating modes that generate signals based on the EQU0 and EQUn signals. The TBOUTH pin function can be used to put all Timer\_B outputs into a high-impedance state. When the TBOUTH pin function is selected for the pin (corresponding PSEL bit is set, and port configured as input) and when the pin is pulled high, all Timer\_B outputs are in a high-impedance state. # 14.2.5.1 Output Modes The output modes are defined by the OUTMOD bits (see Table 14-4). The OUTn signal is changed with the rising edge of the timer clock for all modes except mode 0. Output modes 2, 3, 6, and 7 are not useful for output unit 0 because EQUn = EQU0. **Table 14-4. Output Modes** | OUTMOD | Mode | Description | |--------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 000 | Output | The output signal OUTn is defined by the OUT bit. The OUTn signal updates immediately when OUT is updated. | | 001 | Set | The output is set when the timer <i>counts</i> to the TBxCLn value. It remains set until a reset of the timer, or until another output mode is selected and affects the output. | | 010 | Toggle/Reset | The output is toggled when the timer <i>counts</i> to the TBxCLn value. It is reset when the timer <i>counts</i> to the TBxCL0 value. | | 011 | Set/Reset | The output is set when the timer <i>counts</i> to the TBxCLn value. It is reset when the timer <i>counts</i> to the TBxCL0 value. | | 100 | Toggle | The output is toggled when the timer <i>counts</i> to the TBxCLn value. The output period is double the timer period. | | 101 | Reset | The output is reset when the timer <i>counts</i> to the TBxCLn value. It remains reset until another output mode is selected and affects the output. | | 110 | Toggle/Set | The output is toggled when the timer <i>counts</i> to the TBxCLn value. It is set when the timer <i>counts</i> to the TBxCL0 value. | | 111 | Reset/Set | The output is reset when the timer <i>counts</i> to the TBxCLn value. It is set when the timer <i>counts</i> to the TBxCL0 value. | Timer\_B Operation www.ti.com # 14.2.5.1.1 Output Example - Timer in Up Mode The OUTn signal is changed when the timer *counts* up to the TBxCLn value, and rolls from TBxCL0 to zero, depending on the output mode. Figure 14-12 shows an example using TBxCL0 and TBxCL1. Figure 14-12. Output Example – Timer in Up Mode Timer\_B Operation www.ti.com # 14.2.5.1.2 Output Example – Timer in Continuous Mode The OUTn signal is changed when the timer reaches the TBxCLn and TBxCL0 values, depending on the output mode. Figure 14-13 shows an example using TBxCL0 and TBxCL1. Figure 14-13. Output Example – Timer in Continuous Mode Timer\_B Operation www.ti.com ### 14.2.5.1.3 Output Example – Timer in Up/Down Mode The OUTn signal changes when the timer equals TBxCLn in either count direction and when the timer equals TBxCL0, depending on the output mode. Figure 14-14 shows an example using TBxCL0 and TBxCL3. Figure 14-14. Output Example - Timer in Up/Down Mode ### NOTE: Switching between output modes When switching between output modes, one of the OUTMOD bits should remain set during the transition, unless switching to mode 0. Otherwise, output glitching can occur because a NOR gate decodes output mode 0. A safe method for switching between output modes is to use output mode 7 as a transition state: ``` BIS #OUTMOD_7,&TBCCTLx ; Set output mode = 7 BIC #OUTMOD,&TBCCTLx ; Clear unwanted bits ``` Timer\_B Operation www.ti.com ### 14.2.6 Timer B Interrupts Two interrupt vectors are associated with the 16-bit Timer B module: - TBxCCR0 interrupt vector for TBxCCR0 CCIFG - TBIV interrupt vector for all other CCIFG flags and TBIFG In capture mode, any CCIFG flag is set when a timer value is captured in the associated TBxCCRn register. In compare mode, any CCIFG flag is set when TBxR counts to the associated TBxCLn value. Software may also set or clear any CCIFG flag. All CCIFG flags request an interrupt when their corresponding CCIE bit and the GIE bit are set. ### 14.2.6.1 TBxCCR0 Interrupt Vector The TBxCCR0 CCIFG flag has the highest Timer B interrupt priority and has a dedicated interrupt vector (see Figure 14-15). The TBxCCR0 CCIFG flag is automatically reset when the TBxCCR0 interrupt request is serviced. Figure 14-15. Capture/Compare TBxCCR0 Interrupt Flag # 14.2.6.2 TBxIV, Interrupt Vector Generator The TBIFG flag and TBxCCRn CCIFG flags (excluding TBxCCR0 CCIFG) are prioritized and combined to source a single interrupt vector. The interrupt vector register TBxIV is used to determine which flag requested an interrupt. The highest-priority enabled interrupt (excluding TBxCCR0 CCIFG) generates a number in the TBxIV register (see register description). This number can be evaluated or added to the program counter to automatically enter the appropriate software routine. Disabled Timer\_B interrupts do not affect the TBxIV value. Any access, read or write, of the TBxIV 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, if the TBxCCR1 and TBxCCR2 CCIFG flags are set when the interrupt service routine accesses the TBxIV register, TBxCCR1 CCIFG is reset automatically. After the RETI instruction of the interrupt service routine is executed, the TBxCCR2 CCIFG flag generates another interrupt. ### 14.2.6.3 TBxIV, Interrupt Handler Examples The following software example shows the recommended use of TBxIV and the handling overhead. The TBxIV value is added to the PC to automatically jump to the appropriate routine. The example assumes a single instantiation of the largest timer configuration available. The numbers at the right margin show the necessary CPU clock cycles for each instruction. The software overhead for different interrupt sources includes interrupt latency and return-from-interrupt cycles, but not the task handling itself. The latencies are: - Capture/compare block CCR0: 11 cycles - Capture/compare blocks CCR1 to CCR6: 16 cycles - Timer overflow TBIFG: 14 cycles Timer\_B Operation www.ti.com # The following software example shows the recommended use of TBxIV for Timer\_B3. | ; Interrupt CCIFG_0_HND | | r for TB00 | CCR0 | CCIFG. | | Cycle | |-------------------------|--------|------------|------|---------|--------------------|--------| | ;<br>RE | | ; Start | of | handler | Interrupt latency | 6<br>5 | | ; Interrupt | handle | r for TB0 | IFG, | TB0CCR1 | through TBOCCR6 CC | IFG. | | TB0_HND | | | | | upt latency | 6 | | AD | D | &TB0IV,PC | ; | Add off | fset to Jump table | 3 | | RE | TI | | ; | Vector | 0: No interrupt | 5 | | JM | | | | | 2: TB0CCR1 | 2 | | JM | P | CCIFG_2_H | ND ; | Vector | 4: TB0CCR2 | 2 | | JM | P | CCIFG_3_HI | ND ; | Vector | 6: TB0CCR3 | 2 | | JM | P | CCIFG_4_HI | ND ; | Vector | 8: TB0CCR4 | 2 | | JM | P | CCIFG_5_HI | ND ; | Vector | 10: TB0CCR5 | 2 | | JM | P | CCIFG_6_H | ND ; | Vector | 12: TBOCCR6 | 2 | | TB0IFG_HND | | | ; | Vector | 14: TB0IFG Flag | | | | | | ; | Task st | tarts here | | | RE | TI | | | | | 5 | | CCIFG_6_HND | | | | | 12: TBOCCR6 | | | | • | | | | tarts here | | | RE | TI | | ; | Back to | o main program | 5 | | CCIFG_5_HND | | | | | 10: TBOCCR5 | | | • • | | | | | tarts here | | | RE | TI | | ; | Back to | o main program | 5 | | CCIFG_4_HND | | | | | 8: TBOCCR4 | | | | | | | | tarts here | _ | | RE | Ή1 | | , | Back to | o main program | 5 | | CCIFG_3_HND | | | ; | Vector | 6: TB0CCR3 | | | | | | ; | Task st | tarts here | | | RE | TI | | ; | Back to | o main program | 5 | | CCIFG_2_HND | | | | | 4: TB0CCR2 | | | | • | | | | tarts here | | | RE | TI | | ; | Back to | o main program | 5 | | CCIFG_1_HND | | | ; | Vector | 2: TB0CCR1 | | | | | | ; | Task st | tarts here | | | RE | TI | | ; | Back to | o main program | 5 | | | | | | | | | www.ti.com Timer\_B Operation # 14.2.7 Updating Timer\_B Configuration Take care when applying new configuration to TBxCTL, TBxCTLn, or TBxEX0. These control bits are designed not to be dynamically updated while the timer is running. Changing the controls listed below while the timer is running could result in unexpected behaviors. Control bits that are not listed below can be read or updated while the timer is running. ### **NOTE: Changing Timer Clock source** TI recommends stopping the timer before modifying its operation. At least 1.5 timer clocks delay are required to resynchronize before restarting the timer if the timer clock source is asynchronous to MCLK, because the timer state machine takes this time to synchronize the clock source as the reconfiguration. For example, assuming that the timer uses a 1-MHz clock, TI recommends a 1.5-µs delay before starting the timer after stop. - TBxCTL register - TBxCLn group (TBCLGRP) - Counter length (CNTL) - Clock source select (TBSSEL) - Input divider (ID) - Timer\_B clear (TBCLR) - TBxCCTLn registers - Capture mode (CM) (switching to no capture mode can be performed any time) - Capture/compare input select (CCIS) (switching between GND an VCC can be performed at any time) - Synchronize capture source (SCS) - Capture mode (CAP) - Output mode (OUTMOD) - TBxEX0 register - Input divider expansion (TBIDEX) To update Timer\_B configuration: - 1. Write zero to the mode control bits (MC = 0) (do not use the TBCLR bit to reset the mode control bits). - 2. If necessary, write 1 to the TBCLR bit (TBCLR = 1 ) to clear TBxR, clock divider state, and the counter direction. - 3. If necessary, update counter value to TBxR. - 4. If required to initialize TBxCLn, write zero to the CLLD bits so that the values written to TBxCCRn are immediately transferred to TBxCLn. - 5. To update the CM, CCIS, or SCS bits or the TBxCCRn register, and the timer is in capture mode, disable capture mode first by writing zero to the CAP bit (CAP = 0) or the CM bits (CM = 0). - 6. Apply desired configuration to TBxCCRn, TBIDEX, and TBxCCTLn. - 7. Apply desired configuration to TBxCTL including the MC bits. Timer\_B Registers www.ti.com # 14.3 Timer\_B Registers The Timer\_B registers are listed in Table 14-5. The base address can be found in the device-specific data sheet. The address offset is listed in Table 14-5. Table 14-5. Timer\_B Registers | Offset | Acronym | Register Name | Туре | Access | Reset | Section | |--------|----------|-----------------------------------|------------|--------|-------|----------------| | 00h | TBxCTL | Timer_B Control | Read/write | Word | 0000h | Section 14.3.1 | | 02h | TBxCCTL0 | Timer_B Capture/Compare Control 0 | Read/write | Word | 0000h | Section 14.3.3 | | 04h | TBxCCTL1 | Timer_B Capture/Compare Control 1 | Read/write | Word | 0000h | Section 14.3.3 | | 06h | TBxCCTL2 | Timer_B Capture/Compare Control 2 | Read/write | Word | 0000h | Section 14.3.3 | | 08h | TBxCCTL3 | Timer_B Capture/Compare Control 3 | Read/write | Word | 0000h | Section 14.3.3 | | 0Ah | TBxCCTL4 | Timer_B Capture/Compare Control 4 | Read/write | Word | 0000h | Section 14.3.3 | | 0Ch | TBxCCTL5 | Timer_B Capture/Compare Control 5 | Read/write | Word | 0000h | Section 14.3.3 | | 0Eh | TBxCCTL6 | Timer_B Capture/Compare Control 6 | Read/write | Word | 0000h | Section 14.3.3 | | 10h | TBxR | Timer_B Counter | Read/write | Word | 0000h | Section 14.3.2 | | 12h | TBxCCR0 | Timer_B Capture/Compare 0 | Read/write | Word | 0000h | Section 14.3.4 | | 14h | TBxCCR1 | Timer_B Capture/Compare 1 | Read/write | Word | 0000h | Section 14.3.4 | | 16h | TBxCCR2 | Timer_B Capture/Compare 2 | Read/write | Word | 0000h | Section 14.3.4 | | 18h | TBxCCR3 | Timer_B Capture/Compare 3 | Read/write | Word | 0000h | Section 14.3.4 | | 1Ah | TBxCCR4 | Timer_B Capture/Compare 4 | Read/write | Word | 0000h | Section 14.3.4 | | 1Ch | TBxCCR5 | Timer_B Capture/Compare 5 | Read/write | Word | 0000h | Section 14.3.4 | | 1Eh | TBxCCR6 | Timer_B Capture/Compare 6 | Read/write | Word | 0000h | Section 14.3.4 | | 2Eh | TBxIV | Timer_B Interrupt Vector | Read only | Word | 0000h | Section 14.3.5 | | 20h | TBxEX0 | Timer_B Expansion 0 | Read/write | Word | 0000h | Section 14.3.6 | www.ti.com Timer\_B Registers # 14.3.1 TBxCTL Register Timer\_B x Control Register # Figure 14-16. TBxCTL Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------|--------|----------|--------|----------|----------|--------|--------| | Reserved | TBCL | TBCLGRPx | | NTL | Reserved | TBS | SEL | | rw-(0) | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | I | D | M | С | Reserved | TBCLR | TBIE | TBIFG | | rw-(0) | rw-(0) | rw-(0) | rw-(0) | rw-(0) | w-(0) | rw-(0) | rw-(0) | # Table 14-6. TBxCTL Register Description | Bit | Field | Туре | Reset | Description | | | |-------|----------|------|---------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | 15 | Reserved | R | 0h | Reserved. Always reads as 0. | | | | 14-13 | TBCLGRP | RW | 0h | TBxCLn group 00b = Each TBxCLn latch loads independently. 01b = TBxCL1 + TBxCL2 (TBxCCR1 CLLD bits control the update); TBxCL3 + TBxCL4 (TBxCCR3 CLLD bits control the update); TBxCL5 + TBxCL6 (TBxCCR5 CLLD bits control the update); TBxCL0 independent 10b = TBxCL1 + TBxCL2 + TBxCL3 (TBxCCR1 CLLD bits control the update); TBxCL4 + TBxCL5 + TBxCL6 (TBxCCR4 CLLD bits control the update); TBxCL0 independent 11b = TBxCL0 + TBxCL1 + TBxCL2 + TBxCL3 + TBxCL4 + TBxCL5 + TBxCL6 (TBxCCR1 CLLD bits control the update) | | | | 12-11 | CNTL | RW | 0h | Counter length $00b = 16\text{-bit}, TBxR_{(max)} = 0FFFFh$ $01b = 12\text{-bit}, TBxR_{(max)} = 0FFFh$ $10b = 10\text{-bit}, TBxR_{(max)} = 03FFh$ $11b = 8\text{-bit}, TBxR_{(max)} = 0FFh$ | | | | 10 | Reserved | R | 0h Reserved. Always reads as 0. | | | | | 9-8 | TBSSEL | RW | Oh | Timer_B clock source select 00b = TBxCLK 01b = ACLK 10b = SMCLK 11b = INCLK | | | | 7-6 | ID | RW | Oh | Input divider. These bits, along with the TBIDEX bits, select the divider for the input clock. 00b = /1 01b = /2 10b = /4 11b = /8 | | | | 5-4 | мс | RW | 0h | Mode control. Set MC = 00h when Timer_B is not in use to conserve power. 00b = Stop mode: Timer is halted 01b = Up mode: Timer counts up to TBxCL0 10b = Continuous mode: Timer counts up to the value set by CNTL 11b = Up/down mode: Timer counts up to TBxCL0 and down to 0000h | | | | 3 | Reserved | R | 0h | Reserved. Always reads as 0. | | | | 2 | TBCLR | RW | 0h | Timer_B clear. Setting this bit clears TBxR, the clock divider logic (the divider setting remains unchanged), and the count direction. The TBCLR bit is automatically reset and is always read as zero. | | | Timer\_B Registers www.ti.com # Table 14-6. TBxCTL Register Description (continued) | Bit | Field | Туре | Reset | Description | |-----|-------|------|-------|--------------------------------------------------------------------------------------------------------------------------| | 1 | TBIE | RW | 0h | Timer_B interrupt enable. This bit enables the TBIFG interrupt request. 0b = Interrupt disabled 1b = Interrupt enabled | | 0 | TBIFG | RW | 0h | Timer_B interrupt flag 0b = No interrupt pending 1b = Interrupt pending | # 14.3.2 TBxR Register Timer\_B x Counter Register # Figure 14-17. TBxR Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | |--------|--------|--------|--------|--------|--------|--------|--------|--|--|--| | | TBxR | | | | | | | | | | | rw-(0) | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | TBxR | | | | | | | | | | | rw-(0) | | | # Table 14-7. TBxR Register Description | Bit | Field | Туре | Reset | Description | |------|-------|------|-------|--------------------------------------------------------------| | 15-0 | TBxR | RW | 0h | Timer_B register. The TBxR register is the count of Timer_B. | www.ti.com Timer\_B Registers # 14.3.3 TBxCCTLn Register Timer\_B x Capture/Compare Control Register n # Figure 14-18. TBxCCTLn Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|--------|--------|--------|--------|--------|--------|--------| | CM CC | | CCIS | | CLLD | | CAP | | | rw-(0) | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | OUTMOD | | CCIE | CCI | OUT | COV | CCIFG | | rw-(0) | rw-(0) | rw-(0) | rw-(0) | r | rw-(0) | rw-(0) | rw-(0) | # Table 14-8. TBxCCTLn Register Description | Bit | Field | Туре | Reset | Description | |-------|--------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-14 | СМ | RW | 0h | Capture mode 00b = No capture 01b = Capture on rising edge 10b = Capture on falling edge 11b = Capture on both rising and falling edges | | 13-12 | CCIS | RW | 0h | Capture/compare input select. These bits select the TBxCCRn input signal. See the device-specific data sheet for specific signal connections. 00b = CCIxA 01b = CCIxB 10b = GND 11b = VCC | | 11 | scs | RW | 0h | Synchronize capture source. This bit is used to synchronize the capture input signal with the timer clock. 0b = Asynchronous capture 1b = Synchronous capture | | 10-9 | CLLD | RW | 0h | Compare latch load. These bits select the compare latch load event. 00b = TBxCLn loads on write to TBxCCRn 01b = TBxCLn loads when TBxR counts to 0 10b = TBxCLn loads when TBxR counts to 0 (up or continuous mode). TBxCLn loads when TBxR counts to TBxCL0 or to 0 (up/down mode). 11b = TBxCLn loads when TBxR counts to TBxCLn | | 8 | CAP | RW | 0h | Capture mode 0b = Compare mode 1b = Capture mode | | 7-5 | OUTMOD | RW | Oh | Output mode. Modes 2, 3, 6, and 7 are not useful for TBxCL0 because EQUn = EQUO. 000b = OUT bit value 001b = Set 010b = Toggle/reset 100b = Toggle 101b = Reset 110b = Toggle/set 111b = Reset/set | | 4 | CCIE | RW | 0h | Capture/compare interrupt enable. This bit enables the interrupt request of the corresponding CCIFG flag. 0b = Interrupt disabled 1b = Interrupt enabled | | 3 | CCI | R | Х | Capture/compare input. The selected input signal can be read by this bit. | Timer\_B Registers www.ti.com # Table 14-8. TBxCCTLn Register Description (continued) | Bit | Field | Туре | Reset | Description | |-----|-------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 2 | OUT | RW | 0h | Output. For output mode 0, this bit directly controls the state of the output. 0b = Output low 1b = Output high | | 1 | COV | RW | 0h | Capture overflow. This bit indicates a capture overflow occurred. COV must be reset with software. 0b = No capture overflow occurred 1b = Capture overflow occurred | | 0 | CCIFG | RW | 0h | Capture/compare interrupt flag 0b = No interrupt pending 1b = Interrupt pending | www.ti.com Timer\_B Registers # 14.3.4 TBxCCRn Register Timer\_B x Capture/Compare Register n # Figure 14-19. TBxCCRn Register # Table 14-9. TBxCCRn Register Description | Bit | Field | Туре | Reset | Description | |------|---------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-0 | TBxCCRn | RW | 0h | Timer_B capture/compare register. Compare mode: TBxCCRn holds the data for the comparison to the timer value in the Timer_B Register, TBxR. Capture mode: The Timer_B Register, TBxR, is copied into the TBxCCRn register when a capture is performed. | Timer\_B Registers www.ti.com # 14.3.5 TBxIV Register Timer\_B x Interrupt Vector Register # Figure 14-20. TBxIV Register | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | |---|------|-------|-------|-------|-------|-------|-------|-------|--|--|--|--| | | | | | TE | 3IV | | | | | | | | | ı | -(0) | r-(0) | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | TBIV | | | | | | | | | | | | | ı | -(0) | r-(0) | | | | # Table 14-10. TBxIV Register Description | Bit | Field | Туре | Reset | Description | |------|-------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-0 | TBIV | R | Oh | Timer_B interrupt vector value 00h = No interrupt pending 02h = Interrupt Source: Capture/compare 1; Interrupt Flag: TBxCCR1 CCIFG; Interrupt Priority: Highest 04h = Interrupt Source: Capture/compare 2; Interrupt Flag: TBxCCR2 CCIFG 06h = Interrupt Source: Capture/compare 3; Interrupt Flag: TBxCCR3 CCIFG 08h = Interrupt Source: Capture/compare 4; Interrupt Flag: TBxCCR4 CCIFG 0Ah = Interrupt Source: Capture/compare 5; Interrupt Flag: TBxCCR5 CCIFG 0Ch = Interrupt Source: Capture/compare 6; Interrupt Flag: TBxCCR6 CCIFG 0Eh = Interrupt Source: Timer overflow; Interrupt Flag: TBxCTL TBIFG; Interrupt Priority: Lowest | # 14.3.6 TBxEX0 Register Timer\_B x Expansion Register 0 # Figure 14-21. TBxEX0 Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----|----|----------|------|-----------------------|--------|--------|--------| | | | | Rese | rved | | | | | r0 | r0 | r0 | r0 | rO | r0 | rO | rO | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | Reserved | | TBIDEX <sup>(1)</sup> | | | | | r0 | r0 | r0 | r0 | r0 | rw-(0) | rw-(0) | rw-(0) | <sup>(1)</sup> After programming TBIDEX bits and configuring the timer, set TBCLR bit to ensure proper reset of the timer divider logic. # Table 14-11. TBxEX0 Register Description | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-3 | Reserved | R | 0h | Reserved. Always reads as 0. | | 2-0 | TBIDEX | RW | Oh | Input divider expansion. These bits along with the ID bits select the divider for the input clock. 000b = Divide by 1 001b = Divide by 2 010b = Divide by 3 011b = Divide by 4 100b = Divide by 5 101b = Divide by 6 110b = Divide by 7 111b = Divide by 8 | # Real-Time Clock (RTC) Counter The Real-Time Clock (RTC) counter is a 16-bit counter that is functional in active mode (AM) and several low-power modes (LPMs). RTC counter accepts multiple clock sources, which are selected by control registers settings, to generate timing from less than 1 µs up to many hours. This chapter describes the operation and use of the RTC counter module. Topic Page | 15.1 | RTC Counter Introduction | 416 | |------|--------------------------|-----| | 15.2 | RTC Counter Operation | 417 | | 15.3 | RTC Counter Registers | 419 | | | | | RTC Counter Introduction www.ti.com ### 15.1 RTC Counter Introduction The RTC counter is a 16-bit counter that functions in AM and all LPMs except LPM4.5. This module can accept any one of three clock sources: - Device specific: SMCLK (maximum operating frequency depends on device configuration) or ACLK (approximately 32 kHz) - 2. XT1CLK (approximately 32 kHz) - 3. VLOCLK (approximately 10 kHz) In LPM3.5, RTC counter accepts only XT1CLK or VLOCLK as its clock source to periodically wake up the device. The selected clock source can be predivided before driving the main 16-bit counter. The 16-bit counter supports continuous tick by a 16-bit modulo register that is user accessible and a 16-bit shadow register that is not user accessible. The RTC counter can generate an interrupt when the counter value overflows at the preset shadow register value. RTC counter features include: - 16-bit modulo counter architecture - 16-bit basic counter - 16-bit modulo register that is user accessible for read and write - 16-bit shadow register that is not user accessible to support continued operation when the modulo value is updated - 16-bit compare logic to detect counter overflow at the boundary of the shadow register value - Three possible clock sources that are selected by setting the RTCSS bits: XT1CLK, VLOCLK, or device specific (SMCLK or ACLK) - SMCLK is functional in AM and LPM0 only - ACLK is functional in AM to LPM3. - XT1CLK and VLOCLK are functional in AM and LPMs, excluding LPM4.5 - Configurable predivider for the source clock input is set by the RTCPS bits - Passthrough: ÷1; the input clock source directly drives the 16-bit counter - Predivider: ÷10, ÷100, ÷1000, ÷16, ÷64, ÷256, or ÷1024; the input clock source is divided by the selected value before it drives the 16-bit counter - A hardware interrupt is triggered (if enabled by the RTCIE bit) when the counter value reaches the shadow register value. - An overflow event can be a trigger in hardware for other modules. See the device-specific data sheet for details on which modules support this trigger. - Software can reset the counter by setting the RTCSR bit. Figure 15-1 shows the block diagram of the RTC counter. Figure 15-1. RTC Counter Block Diagram ### 15.2 RTC Counter Operation The RTC counter module is configured with user software. The setup and operation of RTC counter is described in the following sections. #### 15.2.1 16-Bit Timer Counter The 16-bit timer counter register, RTCCNT, increments with each rising edge of the source clock signal. RTCCNT is read only with software. When the counter value reaches the value of the shadow register, the RTC counter generates an overflow signal, the counter value resets to zero, and the counter continues to tick without interruption. As long as the counter clock source that is specified by the RTCSS bit is active, the counter is operational. RTCCNT is cleared by the overflow event, or it can be reset by software writing logic 1 to the RTCSR bit in the RTCCTL register. If the counter is reset by software, the shadow register is updated by the value in the modulo register at the next cycle of the divided clock, but no overflow event or interrupt is generated. The maximum input frequency to the counter during LPM3.5 is 40 kHz. Therefore, the predivider must be configured so that the divided clock frequency does not exceed 40 kHz. ### 15.2.2 Clock Source Select and Divider In AM and LPM0, the RTC counter clock can be sourced from device-specific (SMCLK or ACLK), XT1CLK, or VLOCLK. In LPM3, ACLK, XT1CLK, or VLOCLK can be selected. In LPM3.5, only XT1CLK or VLOCLK can be selected. The clock source is specified by the RTCSS bits in the RTCCTL register. After reset, RTCSS defaults to 00b (disabled), which means that no clock source is selected. The selected clock source can be predivided before it is used by the counter. If the passthrough mode $(\div 1)$ is selected, the predivider is bypassed and the selected clock source directly sources the counter. The predivider options of $\div 16$ , $\div 64$ , $\div 256$ , and $\div 1024$ allow simple division of clock source frequencies that are powers of 2, such as from 32768-Hz crystals. The predivider options of $\div 10$ , $\div 100$ , and $\div 1000$ allow simple division of clock source frequencies that are multiples of 10, such as from 4-MHz or 8-MHz clock inputs. ### **NOTE: Clock Source Selection** In LPM3.5, the RTC counter is very low power, and the divided clock source that drives the counter can have a maximum frequency of 40 kHz. TI recommends a software reset by asserting the RTCSR bit after the RTC clock source is switched. An unexpected interrupt may happen during the clock source change, because of the synchronization time. The count setting is resynchronized with the new clock on this software reset. # 15.2.3 Modulo Register (RTCMOD) and Shadow Register The modulo register (RTCMOD) is a 16-bit register that is set by user software. The value in RTCMOD is latched and does not take effect until it is loaded into the shadow register. The shadow register is also a 16-bit register, and it stores the modulo value that the RTC counter logic compares with the counter value. The shadow register acts as a buffer to the RTCMOD register, so that software can set a new modulo value without interrupting the counter. The RTCMOD register is read and write accessible by the user. The shadow register is not directly accessible by the user. The value in RTCMOD is loaded to the shadow register under two conditions: - 1. When the counter reaches the value in the shadow register, which also triggers an overflow signal and clears the counter value. - When a software reset is triggered by software writing logic 1 to the RTCSR bit in the RTCCTL register. RTC Counter Operation www.ti.com Because the shadow register always updates its value from RTCMOD, software must set RTCMOD before the hardware overflow occurs. Using the software reset lets software immediately set the target modulo value into shadow register without waiting for the next overflow. If the value in RTCMOD is not updated when the hardware overflow occurs, the shadow register fetches the previous modulo value stored in RTCMOD. If RTCMOD is changed multiple times before the overflow, only the last value is loaded to the shadow register. RTC counter always generates an overflow when the RTCMOD is set to either 0x0000 or 0x0001. Care should be taken when setting RTCMOD so that the overflow events do not happen too quickly to be serviced. When the selected RTC counter source frequency is close to the CPU clock frequency, the modulo value must be long enough that the CPU is able to respond to the RTC counter interrupt service routine (ISR) in time before the next RTC counter interrupt occurs. In addition, frequent writes to the RTCSR bit (software reset) could lead to an overflow event being missed, as the count is reset each time, and the RTCMOD setting overwrites the current shadow register setting. Figure 15-2 shows a hardware overflow event loading the new value (0x2000) from RTCMOD into the shadow register, replacing the previous value (0x4000). Figure 15-2. Shadow Register Example ### 15.2.4 RTC Counter Interrupt and External Event/Trigger There is an interrupt vector (RTCIV) associated with the 16-bit RTC counter module interrupt flag (RTCIFG). When an overflow occurs, the RTCIFG bit in the RTCCTL register is set until it is cleared by a read of the RTCIV register. At the same time, an interrupt is submitted to the CPU for post-processing, if the RTCIE bit in the RTCCTL register is set. Reading RTCIV register clears the interrupt flag. TI recommends clearing the RTCIFG bit by reading the RTCIV register before enabling the RTC counter interrupt. Otherwise, an interrupt might be generated if the RTCIFG was already set by a previous overflow. In addition to the interrupt, the hardware overflow also submits an external trigger to other on-chip modules as a synchronous signal. Refer to the device-specific data sheet for more information on module triggers that are available on particular devices. www.ti.com RTC Counter Registers # 15.3 RTC Counter Registers Table 15-1 lists the RTC counter registers and the address offset for each register. Refer to the device-specific data sheet for the base address of the module. **Table 15-1. RTC Counter Registers** | Offset | Acronym | Register Name | Туре | Access | Reset | Section | |--------|----------|----------------------------------|------------|--------|-------|----------------| | 00h | RTCCTL | Real-Time Clock Control | Read/write | Word | 0000h | Section 15.3.1 | | 00h | RTCCTL_L | | Read/write | Byte | 00h | | | 01h | RTCCTL_H | | Read/write | Byte | 00h | | | 04h | RTCIV | Real-Time Clock Interrupt Vector | Read/write | Word | 0000h | Section 15.3.2 | | 04h | RTCIV_L | | Read/write | Byte | 00h | | | 05h | RTCIV_H | | Read/write | Byte | 00h | | | 08h | RTCMOD | Real-Timer Clock Modulo | Read/write | Word | BEEFh | Section 15.3.3 | | 08h | RTCMOD_L | | Read/write | Byte | EFh | | | 09h | RTCMOD_H | | Read/write | Byte | BEh | | | 0Ch | RTCCNT | Real-Time Clock Counter | Read | Word | 0000h | Section 15.3.4 | | 0Ch | RTCCNT_L | | Read | Byte | 00h | | | 0Dh | RTCCNT_H | | Read | Byte | 00h | | RTC Counter Registers www.ti.com # 15.3.1 RTCCTL Register RTC Counter Control Register # Figure 15-3. RTCCTL Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------|-------|--------|--------|----------|--------|--------|--------| | Reserved | | RTCSS | | Reserved | | RTCPS | | | r0 | r0 | rw-{0} | rw-{0} | rO | rw-{0} | rw-{0} | rw-{0} | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Reserved | RTCSR | | Res | | RTCIE | RTCIFG | | | r0 | w-{0} | r0 | r0 | r0 | r0 | rw-{0} | r-{0} | # Table 15-2. RTCCTL Register Description | Bit | Field | Туре | Reset | Description | | | | |-------|----------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | 15-14 | Reserved | R | 0h | Reserved | | | | | 13-12 | RTCSS | RW | 0h | Real-time clock source select 00b = No clock (Stop) 01b = Device specific 10b = XT1CLK 11b = VLOCLK | | | | | 11 | Reserved | R | 0h | Reserved | | | | | 10-8 | RTCPS | RW | Oh | Real-time clock predivider select<br>000b = /1<br>001b = /10<br>010b = /100<br>011b = /1000<br>100b = /16<br>101b = /64<br>110b = /256<br>111b = /1024 | | | | | 7 | Reserved | R | 0h | Reserved | | | | | 6 | RTCSR | W | Oh | Real-time software reset. This is a write-only bit and is always read with logic 0. 0b = Write 0 has no effect 1b = Write 1 to this bit clears the counter value and reloads the shadow register value from the modulo register at the next tick of the selected source clock. No overflow event or interrupt is generated. | | | | | 5-2 | Reserved | R | 0h | Reserved | | | | | 1 | RTCIE | RW | Oh | Real-time interrupt enable 0b = Interrupt disabled 1b = Interrupt enabled | | | | | 0 | RTCIFG | R | 0h | Real-time interrupt flag. This bit reports the status of a pending interrupt. This read only bit can be cleared by reading RTCIV register. 0b = No interrupt pending 1b = Interrupt pending | | | | www.ti.com RTC Counter Registers # 15.3.2 RTCIV Register RTC Counter Interrupt Vector Register # Figure 15-4. RTCIV Register # Table 15-3. RTCIV Register Description | Bit | Field | Туре | Reset | Description | | | | |------|-------|------|-------|----------------------------------------------------------------------|--|--|--| | 15-0 | RTCIV | R | 0h | Low-power-counter interrupt vector. | | | | | | | | | 00h = No interrupt pending | | | | | | | | | 02h = Interrupt Source: RTC Counter Overflow; Interrupt Flag: RTCIFG | | | | RTC Counter Registers www.ti.com # 15.3.3 RTCMOD Register RTC Counter Modulo Register # Figure 15-5. RTCMOD Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | | |--------|--------|--------|--------|--------|--------|--------|--------|--|--|--|--|--|--| | | RTCMOD | | | | | | | | | | | | | | rw-{1} | rw-{0} | rw-{1} | rw-{1} | rw-{1} | rw-{1} | rw-{1} | rw-{0} | | | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | RTCMOD | | | | | | | | | | | | | | rw-{1} | rw-{1} | rw-{1} | rw-{0} | rw-{1} | rw-{1} | rw-{1} | rw-{1} | | | | | | | # **Table 15-4. RTCMOD Register Description** | Bit | Field | Туре | Reset | Description | |------|--------|------|-------|------------------| | 15-0 | RTCMOD | RW | BEEFh | RTC modulo value | # 15.3.4 RTCCNT Register **RTC Counter Register** # Figure 15-6. RTCCNT Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |--------|-------|-------|-------|-------|-------|-------|-------|--|--| | RTCCNT | | | | | | | | | | | r-{0} | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | RTCCNT | | | | | | | | | | | r-{0} | | # **Table 15-5. RTCCNT Register Description** | Bit | Field | Туре | Reset | Description | |------|--------|------|-------|-----------------------------------------------------------------------------------| | 15-0 | RTCCNT | R | 0h | RTC counter. This is a read-only register and reflects the current counter value. | # 32-Bit Hardware Multiplier (MPY32) This chapter describes the 32-bit hardware multiplier (MPY32). The MPY32 module is implemented in all devices. Topic Page | 16.1 | 32-Bit Hardware Multiplier (MPY32) Introduction | 424 | |------|-------------------------------------------------|-----| | 16.2 | MPY32 Operation | 426 | | 16.3 | MPY32 Registers | 438 | | | • | | # 16.1 32-Bit Hardware Multiplier (MPY32) Introduction The MPY32 is a peripheral and is not part of the CPU. This means its activities do not interfere with the CPU activities. The multiplier registers are peripheral registers that are loaded and read with CPU instructions. The MPY32 supports: - Unsigned multiply - · Signed multiply - · Unsigned multiply accumulate - Signed multiply accumulate - 8-bit, 16-bit, 24-bit, and 32-bit operands - Saturation - Fractional numbers - 8-bit and 16-bit operation compatible with 16-bit hardware multiplier - 8-bit and 24-bit multiplications without requiring a "sign extend" instruction The MPY32 block diagram is shown in Figure 16-1. Figure 16-1. MPY32 Block Diagram MPY32 Operation www.ti.com ### 16.2 MPY32 Operation The MPY32 supports 8-bit, 16-bit, 24-bit, and 32-bit operands with unsigned multiply, signed multiply, unsigned multiply-accumulate, and signed multiply-accumulate operations. The size of the operands are defined by the address the operand is written to and if it is written as word or byte. The type of operation is selected by the address to which the first operand is written. The hardware multiplier has two 32-bit operand registers – operand one (OP1) and operand two (OP2), and a 64-bit result register accessible through registers RES0 to RES3. For compatibility with the 16×16 hardware multiplier, the result of a 8-bit or 16-bit operation is also accessible through RESLO, RESHI, and SUMEXT. RESLO stores the low word of the 16×16-bit result, RESHI stores the high word of the result, and SUMEXT stores information about the result. The result of a 8-bit or 16-bit operation is ready in three MCLK cycles and can be read with the next instruction after writing to OP2, except when using an indirect addressing mode to access the result. When using indirect addressing for the result, a NOP is required before the result is ready. The result of a 24-bit or 32-bit operation can be read with successive instructions after writing OP2 or OP2H starting with RES0, except when using an indirect addressing mode to access the result. When using indirect addressing for the result, a NOP is required before the result is ready. Table 16-1 summarizes when each word of the 64-bit result is available for the various combinations of operand sizes. With a 32-bit-wide second operand, OP2L and OP2H must be written. Depending on when the two 16-bit parts are written, the result availability may vary; thus, the table shows two entries, one for OP2L written and one for OP2H written. The worst case defines the actual result availability. Result Ready in MCLK Cycles Operation After $(OP1 \times OP2)$ RES0 **MPYC Bit** RES1 RES2 RES3 $8/16 \times 8/16$ 3 OP2 written 3 4 4 3 $24/32 \times 8/16$ 3 5 6 7 7 OP2 written 5 7 $8/16 \times 24/32$ 3 6 7 OP2L written N/A 3 4 4 4 OP2H written 3 8 10 $24/32 \times 24/32$ 11 11 OP2L written N/A 3 5 6 OP2H written 6 Table 16-1. Result Availability (MPYFRAC = 0, MPYSAT = 0) www.ti.com MPY32 Operation ### 16.2.1 Operand Registers Operand one (OP1) has 12 registers (see Table 16-2) that are used to load data into the multiplier and also to select the multiply mode. Writing the low word of the first operand to a given address selects the type of multiply operation to be performed but does not start any operation. When writing a second word to a high-word register with suffix 32H, the multiplier assumes a 32-bit-wide OP1, otherwise, 16 bits are assumed. The last address written prior to writing OP2 defines the width of the first operand. For example, if MPY32L is written first followed by MPY32H, all 32 bits are used and the data width of OP1 is set to 32 bits. If MPY32H is written first followed by MPY32L, the multiplication ignores MPY32H and assumes a 16-bit-wide OP1 using the data written into MPY32L. Repeated multiply operations may be performed without reloading OP1 if the OP1 value is used for successive operations. It is not necessary to rewrite the OP1 value to perform the operations. | OP1 Register | Operation | |--------------|---------------------------------------------------------| | MPY | Unsigned multiply – operand bits 0 up to 15 | | MPYS | Signed multiply – operand bits 0 up to 15 | | MAC | Unsigned multiply accumulate –operand bits 0 up to 15 | | MACS | Signed multiply accumulate – operand bits 0 up to 15 | | MPY32L | Unsigned multiply – operand bits 0 up to 15 | | MPY32H | Unsigned multiply – operand bits 16 up to 31 | | MPYS32L | Signed multiply – operand bits 0 up to 15 | | MPYS32H | Signed multiply – operand bits 16 up to 31 | | MAC32L | Unsigned multiply accumulate – operand bits 0 up to 15 | | MAC32H | Unsigned multiply accumulate – operand bits 16 up to 31 | | MACS32L | Signed multiply accumulate – operand bits 0 up to 15 | | MACS32H | Signed multiply accumulate – operand bits 16 up to 31 | Table 16-2. OP1 Registers Writing the second operand to the OP2 initiates the multiply operation. Writing OP2 starts the selected operation with a 16-bit-wide second operand together with the values stored in OP1. Writing OP2L starts the selected operation with a 32-bit-wide second operand and the multiplier expects a the high word to be written to OP2H. Writing to OP2H without a preceding write to OP2L is ignored. OP2 Register Operation OP2 Start multiplication with 16-bit-wide OP2 – operand bits 0 up to 15 OP2L Start multiplication with 32-bit-wide OP2 – operand bits 0 up to 15 OP2H Continue multiplication with 32-bit-wide OP2 – operand bits 16 up to 31 Table 16-3. OP2 Registers For 8-bit or 24-bit operands, the operand registers can be accessed with byte instructions. Accessing the multiplier with a byte instruction during a signed operation automatically causes a sign extension of the byte within the multiplier module. For 24-bit operands, only the high word should be written as byte. If the 24-bit operands are sign-extended as defined by the register, that is used to write the low word to, because this register defines if the operation is unsigned or signed. The high-word of a 32-bit operand remains unchanged when changing the size of the operand to 16 bit, either by modifying the operand size bits or by writing to the respective operand register. During the execution of the 16-bit operation, the content of the high word is ignored. MPY32 Operation www.ti.com #### NOTE: Changing of first or second operand during multiplication By default, changing OP1 or OP2 while the selected multiply operation is being calculated renders any results invalid that are not ready at the time the new operands are changed. Writing OP2 or OP2L aborts any ongoing calculation and starts a new operation. Results that are not ready at that time are also invalid for following MAC or MACS operations. To avoid this behavior, the MPYDLYWRTEN bit can be set to 1. Then, all writes to any MPY32 registers are delayed with MPYDLY32 = 0 until the 64-bit result is ready or with MPYDLY32 = 1 until the 32-bit result is ready. For MAC and MACS operations, the complete 64-bit result should always be ready. See Table 16-1 for how many CPU cycles are needed until a certain result register is ready and valid for each of the different modes. # 16.2.2 Result Registers The multiplication result is always 64 bits wide. It is accessible through registers RES0 to RES3. Used with a signed operation, MPYS or MACS, the results are appropriately sign extended. If the result registers are loaded with initial values before a MACS operation, the user software must take care that the written value is properly sign extended to 64 bits. ### NOTE: Changing of result registers during multiplication Result was positive or zero 0FFFFh Result was negative The result registers must not be modified by the user software after writing the second operand into OP2 or OP2L until the initiated operation is completed. In addition to RES0 to RES3, for compatibility with the 16×16 hardware multiplier, the 32-bit result of a 8bit or 16-bit operation is accessible through RESLO, RESHI, and SUMEXT. In this case, the result low register RESLO holds the lower 16 bits of the calculation result and the result high register RESHI holds the upper 16 bits. RES0 and RES1 are identical to RESLO and RESHI, respectively, in usage and access of calculated results. The sum extension register SUMEXT contents depend on the multiply operation and are listed in Table 16-4. If all operands are 16 bits wide or less, the 32-bit result is used to determine sign and carry. If one of the operands is larger than 16 bits, the 64-bit result is used. The MPYC bit reflects the multiplier's carry as listed in Table 16-4 and, thus, can be used as 33rd or 65th bit of the result, if fractional or saturation mode is not selected. With MAC or MACS operations, the MPYC bit reflects the carry of the 32-bit or 64-bit accumulation and is not taken into account for successive MAC and MACS operations as the 33rd or 65th bit. | Mode | SUMEXT | MPYC | |------|--------------------------------------------------|-----------------------------------------| | MPY | SUMEXT is always 0000h. | MPYC is always 0. | | MPYS | SUMEXT contains the extended sign of the result. | MPYC contains the sign of the result. | | | 00000h Result was positive or zero | 0 Result was positive or zero | | | 0FFFFh Result was negative | <ol> <li>Result was negative</li> </ol> | | MAC | SUMEXT contains the carry of the result. | MPYC contains the carry of the result. | | | 0000h No carry for result | 0 No carry for result | | | 0001h Result has a carry | 1 Result has a carry | | MACS | SUMEXT contains the extended sign of the result. | MPYC contains the carry of the result. | n 1 Table 16-4. SUMEXT and MPYC Contents 00000h No carry for result Result has a carry www.ti.com MPY32 Operation #### 16.2.2.1 MACS Underflow and Overflow The multiplier does not automatically detect underflow or overflow in MACS mode. For example, working with 16-bit input data and 32-bit results (that is, using only RESLO and RESHI), the available range for positive numbers is 0 to 07FFF FFFFh and for negative numbers is 0FFFF FFFFh to 08000 0000h. An underflow occurs when the sum of two negative numbers yields a result that is in the range for a negative number. An overflow occurs when the sum of two positive numbers yields a result that is in the range for a negative number. The SUMEXT register contains the sign of the result in both cases described above, 0FFFFh for a 32-bit overflow and 0000h for a 32-bit underflow. The MPYC bit in MPY32CTL0 can be used to detect the overflow condition. If the carry is different from the sign reflected by the SUMEXT register, an overflow or underflow occurred. User software must handle these conditions appropriately. # 16.2.3 Software Examples Examples for all multiplier modes follow. All 8x8 modes use the absolute address for the registers, because the assembler does not allow .B access to word registers when using the labels from the standard definitions file. There is no sign extension necessary in software. Accessing the multiplier with a byte instruction during a signed operation automatically causes a sign extension of the byte within the multiplier module. ``` ; 32x32 Unsigned Multiply #01234h,&MPY32L ; Load low word of 1st operand VOM #01234h,&MPY32H ; Load high word of 1st operand MOV MOV #05678h,&OP2L ; Load low word of 2nd operand #05678h,&OP2H MOV ; Load high word of 2nd operand ; Process results . . . ; 16x16 Unsigned Multiply MOV #01234h,&MPY ; Load 1st operand MOV #05678h,&OP2 ; Load 2nd operand ; Process results . . . ; 8x8 Unsigned Multiply. Absolute addressing. MOV.B #012h,&MPY_B ; Load 1st operand MOV.B #034h,&OP2_B ; Load 2nd operand ; Process results . . . ; 32x32 Signed Multiply MOV #01234h,&MPYS32L ; Load low word of 1st operand #01234h,&MPYS32H ; Load high word of 1st operand VOM MOV #05678h,&OP2L ; Load low word of 2nd operand #05678h, &OP2H ; Load high word of 2nd operand MOV ; Process results . . . ; 16x16 Signed Multiply #01234h,&MPYS ; Load 1st operand VOM MOV #05678h,&OP2 ; Load 2nd operand ; Process results ; 8x8 Signed Multiply. Absolute addressing. MOV.B #012h,&MPYS_B ; Load 1st operand MOV.B #034h,&OP2_B ; Load 2nd operand . . . ; Process results ``` MPY32 Operation www.ti.com #### 16.2.4 Fractional Numbers The MPY32 provides support for fixed-point signal processing. In fixed-point signal processing, fractional numbers are numbers that have a fixed number of digits after (and sometimes also before) the radix point. To classify different ranges of binary fixed-point numbers, a Q-format is used. Different Q-formats represent different locations of the radix point. Figure 16-2 shows the format of a signed Q15 number using 16 bits. Every bit after the radix point has a resolution of 1/2, and the most significant bit (MSB) is used as the sign bit. The most negative number is 08000h and the maximum positive number is 07FFFh. This gives a range from -1.0 to $0.999969482 \approx 1.0$ for the signed Q15 format with 16 bits. Figure 16-2. Q15 Format Representation The range can be increased by shifting the radix point to the right as shown in Figure 16-3. The signed Q14 format with 16 bits gives a range from -2.0 to $1.999938965 \approx 2.0$ . Figure 16-3. Q14 Format Representation The benefit of using 16-bit signed Q15 or 32-bit signed Q31 numbers with multiplication is that the product of two number in the range from -1.0 to 1.0 is always in that same range. #### 16.2.4.1 Fractional Number Mode Multiplying two fractional numbers using the default multiplication mode with MPYFRAC = 0 and MPYSAT = 0 gives a result with two sign bits. For example, if two 16-bit Q15 numbers are multiplied, a 32-bit result in Q30 format is obtained. To convert the result into Q15 format manually, the first 15 trailing bits and the extended sign bit must be removed. However, when the fractional mode of the multiplier is used, the redundant sign bit is automatically removed, yielding a result in Q31 format for the multiplication of two 16-bit Q15 numbers. Reading the result register RES1 gives the result as 16-bit Q15 number. The 32-bit Q31 result of a multiplication of two 32-bit Q31 numbers is accessed by reading registers RES2 and RES3. The fractional mode is enabled with MPYFRAC = 1 in register MPY32CTL0. The actual content of the result registers is not modified when MPYFRAC = 1. When the result is accessed using software, the value is left shifted one bit, resulting in the final Q formatted result. This allows user software to switch between reading both the shifted (fractional) and the unshifted result. The fractional mode should only be enabled when required and disabled after use. In fractional mode, the SUMEXT register contains the sign extended bits 32 and 33 of the shifted result for 16×16-bit operations and bits 64 and 65 for 32×32-bit operations – not only bits 32 or 64, respectively. www.ti.com MPY32 Operation The MPYC bit is not affected by the fractional mode. It always reads the carry of the nonfractional result. ``` ; Example using ``` ; Fractional 16x16 multiplication BIS #MPYFRAC,&MPY32CTL0 ; Turn on fractional mode MOV &FRACT1,&MPYS ; Load 1st operand as Q15 MOV &FRACT2,&OP2 ; Load 2nd operand as Q15 MOV &RES1,&PROD ; Save result as Q15 BIC #MPYFRAC,&MPY32CTL0 ; Back to normal mode Table 16-5. Result Availability in Fractional Mode (MPYFRAC = 1, MPYSAT = 0) | Operation | | Result Re | After | | | | |---------------|------|-----------|-------|------|----------|--------------| | (OP1 × OP2) | RES0 | RES1 | RES2 | RES3 | MPYC Bit | Aitei | | 8/16 × 8/16 | 3 | 3 | 4 | 4 | 3 | OP2 written | | 24/32 × 8/16 | 3 | 5 | 6 | 7 | 7 | OP2 written | | 8/16 × 24/32 | 3 | 5 | 6 | 7 | 7 | OP2L written | | | N/A | 3 | 4 | 4 | 4 | OP2H written | | 24/32 × 24/32 | 3 | 8 | 10 | 11 | 11 | OP2L written | | | N/A | 3 | 5 | 6 | 6 | OP2H written | #### 16.2.4.2 Saturation Mode The multiplier prevents overflow and underflow of signed operations in saturation mode. The saturation mode is enabled with MPYSAT = 1 in register MPY32CTL0. If an overflow occurs, the result is set to the most-positive value available. If an underflow occurs, the result is set to the most-negative value available. This is useful to reduce mathematical artifacts in control systems on overflow and underflow conditions. The saturation mode should only be enabled when required and disabled after use. The actual content of the result registers is not modified when MPYSAT = 1. When the result is accessed using software, the value is automatically adjusted to provide the most-positive or most-negative result when an overflow or underflow has occurred. The adjusted result is also used for successive multiply-and-accumulate operations. This allows user software to switch between reading the saturated and the nonsaturated result. With 16x16 operations, the saturation mode only applies to the least significant 32 bits; that is, the result registers RES0 and RES1. Using the saturation mode in MAC or MACS operations that mix 16x16 operations with 32x32, 16x32, or 32x16 operations leads to unpredictable results. With 32×32, 16×32, and 32×16 operations, the saturated result can only be calculated when RES3 is ready. Enabling the saturation mode does not affect the content of the SUMEXT register nor the content of the MPYC bit. ``` ; Example using ; Fractional 16x16 ``` ; Fractional 16x16 multiply accumulate with Saturation ; Turn on fractional and saturation mode: BIS #MPYSAT+MPYFRAC, &MPY32CTL0 VOM ; Load Al for 1st term &A1,&MPYS VOM &K1,&OP2 ; Load K1 to get A1\*K1 &A2,&MACS ; Load A2 for 2nd term VOM &K2,&OP2 ; Load K2 to get A2\*K2 VOM VOM &RES1,&PROD ; Save A1\*K1+A2\*K2 as result BIC #MPYSAT+MPYFRAC, &MPY32CTLO ; turn back to normal MPY32 Operation www.ti.com | Operation | | Result | After | | | | |---------------|------|--------|-------|------|----------|--------------| | (OP1 × OP2) | RES0 | RES1 | RES2 | RES3 | MPYC Bit | Aitei | | 8/16 × 8/16 | 3 | 3 | N/A | N/A | 3 | OP2 written | | 24/32 × 8/16 | 7 | 7 | 7 | 7 | 7 | OP2 written | | 8/16 × 24/32 | 7 | 7 | 7 | 7 | 7 | OP2L written | | | 4 | 4 | 4 | 4 | 4 | OP2H written | | 24/32 × 24/32 | 11 | 11 | 11 | 11 | 11 | OP2L written | | | 6 | 6 | 6 | 6 | 6 | OP2H written | Figure 16-4 shows the flow for 32-bit saturation used for 16x16 bit multiplications and the flow for 64-bit saturation used in all other cases. Primarily, the saturated results depends on the carry bit MPYC and the MSB of the result. Secondly, if the fractional mode is enabled, it depends also on the two MSBs of the unshifted result, that is, the result that is read with fractional mode disabled. Figure 16-4. Saturation Flow Chart www.ti.com MPY32 Operation #### NOTE: Saturation in fractional mode In case of multiplying $-1.0 \times -1.0$ in fractional mode, the result of +1.0 is out of range, thus, the saturated result gives the most positive result. When using multiply-and-accumulate operations, the accumulated values are saturated as if MPYFRAC = 0; only during read accesses to the result registers the values are saturated taking the fractional mode into account. This provides additional dynamic range during the calculation and only the end result is then saturated if needed. The following example illustrates a special case showing the saturation function in fractional mode. It also uses the 8-bit functionality of the MPY32 module. ``` ; Turn on fractional and saturation mode, ; clear all other bits in MPY32CTL0: #MPYSAT+MPYFRAC, &MPY32CTL0 VOM ;Pre-load result registers to demonstrate overflow MOV #0,&RES3 VOM #0,&RES2 ; #07FFFh,&RES1 ; VOM MOV #0FA60h,&RES0 MOV.B #050h,&MACS_B ; 8-bit signed MAC operation #012h,&OP2_B ; Start 16x16 bit operation MOV.B MOV &RESO,R6 ; R6 = 0FFFFh MOV &RES1,R7 ; R7 = 07FFFh ``` The result is saturated because before the result is converted into a fractional number, it shows an overflow. The multiplication of the two positive numbers 00050h and 00012h gives 005A0h. 005A0h added to 07FFF FA60h results in 8000 059Fh, without MPYC being set. Because the MSB of the unmodified result RES1 is 1 and MPYC = 0, the result is saturated according Figure 16-4. #### NOTE: Validity of saturated result The saturated result is valid only if the registers RES0 to RES3, the size of OP1 and OP2, and MPYC are not modified. If the saturation mode is used with a preloaded result, user software must ensure that MPYC in the MPY32CTL0 register is loaded with the sign bit of the written result; otherwise, the saturation mode erroneously saturates the result. MPY32 Operation www.ti.com # 16.2.5 Putting It All Together Figure 16-5 shows the complete multiplication flow, depending on the various selectable modes for the MPY32 module. Figure 16-5. Multiplication Flow Chart www.ti.com MPY32 Operation Given the separation in processing of 16-bit operations (32-bit results) and 32-bit operations (64-bit results) by the module, it is important to understand the implications when using MAC or MACS operations and mixing 16-bit operands or results with 32-bit operands or results. User software must address these points during use when mixing these operations. The following code illustrates the issue. ``` ; Mixing 32x24 multiplication with 16x16 MACS operation #MPYSAT,&MPY32CTL0 ; Saturation mode VOM #052C5h,&MPY32L ; Load low word of 1st operand #06153h,&MPY32H ; Load high word of 1st operand #001ABh,&OP2L ; Load low word of 2nd operand MOV #001ABh,&OP2L #023h,&OP2H_B MOV ; Load high word of 2nd operand MOV.B ;... 5 NOPs required MOV &RESO,R6 ; R6 = 00E97h &RES1,R7 MOV ; R7 = 0A6EAh &RES2,R8 ; R8 = 04F06h VOM &RES3,R9 ; R9 = 0000Dh MOV ; Note that MPYC = 0! #0CCC3h,&MACS ; Signed MAC operation MOV MOV #0FFB6h,&OP2 ; 16x16 bit operation MOV &RESLO,R6 ; R6 = 0FFFFh ; R7 = 07FFFh MOV &RESHI,R7 ``` The second operation gives a saturated result because the 32-bit value used for the 16x16-bit MACS operation was already saturated when the operation was started; the carry bit MPYC was 0 from the previous operation, but the MSB in result register RES1 is set. As one can see in the flow chart, the content of the result registers are saturated for multiply-and-accumulate operations after starting a new operation based on the previous results, but depending on the size of the result (32 bit or 64 bit) of the newly initiated operation. The saturation before the multiplication can cause issues if the MPYC bit is not properly set as the following code shows. ``` ;Pre-load result registers to demonstrate overflow MOV #0,&RES3 ; VOM #0,&RES2 ; #0,&RES1 #0,&RES0 MOV ; VOM ; Saturation mode and set MPYC: #MPYSAT+MPYC, &MPY32CTL0 #082h, &MACC_ #04Fh, &OP2_B ; Starc____ ; R6 = 00000h #082h,&MACS_B ; 8-bit signed MAC operation MOV.B MOV.B ; Start 16x16 bit operation MOV MOV ``` Even though the result registers were loaded with all zeros, the final result is saturated. This is because the MPYC bit was set, causing the result used for the multiply-and-accumulate to be saturated to 08000 0000h. Adding a negative number to it would again cause an underflow, thus, the final result is also saturated to 08000 0000h. MPY32 Operation www.ti.com # 16.2.6 Indirect Addressing of Result Registers When using indirect or indirect autoincrement addressing mode to access the result registers and the multiplier requires three cycles until result availability according to Table 16-1, at least one instruction is needed between loading the second operand and accessing the result registers: ``` ; Access multiplier 16x16 results with indirect addressing MOV #RES0,R5 ; RESO address in R5 for indirect MOV &OPER1,&MPY ; Load 1st operand MOV &OPER2,&OP2 ; Load 2nd operand NOP ; Need one cycle MOV @R5+,&xxx ; Move RESO MOV @R5,&xxx ; Move RES1 ``` In case of a 32×16 multiplication, there is also one instruction required between reading the first result register RES0 and the second result register RES1: ``` ; Access multiplier 32x16 results with indirect addressing VOM #RES0,R5 ; RESO address in R5 for indirect MOV &OPER1L,&MPY32L ; Load low word of 1st operand MOV &OPER1H, &MPY32H ; Load high word of 1st operand &OPER2,&OP2 ; Load 2nd operand (16 bits) MOV NOP ; Need one cycle MOV ; Move RES0 @R5+,&xxx NOP ; Need one additional cycle MOV ; Move RES1 @R5,&xxx ; No additional cycles required! MOV @R5,&xxx ; Move RES2 ``` # 16.2.7 Using Interrupts If an interrupt occurs after writing OP, but before writing OP2, and the multiplier is used in servicing that interrupt, the original multiplier mode selection is lost and the results are unpredictable. To avoid this, disable interrupts before using the MPY32, do not use the MPY32 in interrupt service routines, or use the save and restore functionality of the MPY32. ``` ; Disable interrupts before using the hardware multiplier DINT ; Disable interrupts NOP ; Required for DINT ; Load 1st operand VOM #xxh, &MPY VOM #xxh,&OP2 ; Load 2nd operand EINT ; Interrupts may be enabled before ; processing results if result ; registers are stored and restored in ; interrupt service routines ``` www.ti.com MPY32 Operation #### 16.2.7.1 Save and Restore If the multiplier is used in interrupt service routines, its state can be saved and restored using the MPY32CTL0 register. The following code example shows how the complete multiplier status can be saved and restored to allow interruptible multiplications together with the usage of the multiplier in interrupt service routines. Because the state of the MPYSAT and MPYFRAC bits are unknown, they should be cleared before the registers are saved as shown in the code example. ``` ; Interrupt service routine using multiplier MPY USING ISR PUSH &MPY32CTL0 ; Save multiplier mode, etc. BIC #MPYSAT+MPYFRAC, &MPY32CTL0 ; Clear MPYSAT+MPYFRAC PUSH &RES3 ; Save result 3 ; Save result 2 &RES2 PUSH PUSH &RES1 ; Save result 1 PUSH &RESO ; Save result 0 PUSH &MPY32H ; Save operand 1, high word &MPY32L PUSH ; Save operand 1, low word ; Save operand 2, high word PUSH &OP2H PUSH &OP2L ; Save operand 2, low word ; Main part of ISR ; Using standard MPY routines &OP2L POP ; Restore operand 2, low word POP &OP2H ; Restore operand 2, high word ; Starts dummy multiplication but ; result is overwritten by ; following restore operations: POP &MPY32L ; Restore operand 1, low word POP &MPY32H ; Restore operand 1, high word &RESO ; Restore result 0 POP ; Restore result 1 &RES1 POP ; Restore result 2 POP &RES2 &RES3 POP ; Restore result 3 &MPY32CTL0 POP ; Restore multiplier mode, etc. reti ; End of interrupt service routine ``` #### 16.2.8 Using DMA In devices with a DMA controller, the multiplier can trigger a transfer when the complete result is available. The DMA controller needs to start reading the result with MPY32RES0 successively up to MPY32RES3. Not all registers need to be read. The trigger timing is such that the DMA controller starts reading MPY32RES0 when its ready, and that the MPY32RES3 can be read exactly in the clock cycle when it is available to allow fastest access by DMA. The signal into the DMA controller is 'Multiplier ready' (see the DMA Controller chapter for details). MPY32 Registers www.ti.com # 16.3 MPY32 Registers MPY32 registers are listed in Table 16-7. The base address can be found in the device-specific data sheet. The address offsets are listed in Table 16-7. NOTE: All registers have word or byte register access. For a generic register ANYREG, the suffix "\_L" (ANYREG\_L) refers to the lower byte of the register (bits 0 through 7). The suffix "\_H" (ANYREG\_H) refers to the upper byte of the register (bits 8 through 15). Table 16-7. MPY32 Registers | Offset | Acronym | Register Name | Туре | Access | Reset | |--------|-----------|---------------------------------------------------|------------|--------|-----------| | 00h | MPY | 16-bit operand one – multiply | Read/write | Word | Undefined | | 00h | MPY_L | | Read/write | Byte | Undefined | | 01h | MPY_H | | Read/write | Byte | Undefined | | 00h | MPY_B | 8-bit operand one – multiply | Read/write | Byte | Undefined | | 02h | MPYS | 16-bit operand one – signed multiply | Read/write | Word | Undefined | | 02h | MPYS_L | | Read/write | Byte | Undefined | | 03h | MPYS_H | | Read/write | Byte | Undefined | | 02h | MPYS_B | 8-bit operand one – signed multiply | Read/write | Byte | Undefined | | 04h | MAC | 16-bit operand one – multiply accumulate | Read/write | Word | Undefined | | 04h | MAC_L | | Read/write | Byte | Undefined | | 05h | MAC_H | | Read/write | Byte | Undefined | | 04h | MAC_B | 8-bit operand one – multiply accumulate | Read/write | Byte | Undefined | | 06h | MACS | 16-bit operand one – signed multiply accumulate | Read/write | Word | Undefined | | 06h | MACS_L | | Read/write | Byte | Undefined | | 07h | MACS_H | | Read/write | Byte | Undefined | | 06h | MACS_B | 8-bit operand one – signed multiply accumulate | Read/write | Byte | Undefined | | 08h | OP2 | 16-bit operand two | Read/write | Word | Undefined | | 08h | OP2_L | | Read/write | Byte | Undefined | | 09h | OP2_H | | Read/write | Byte | Undefined | | 08h | OP2_B | 8-bit operand two | Read/write | Byte | Undefined | | 0Ah | RESLO | 16x16-bit result low word | Read/write | Word | Undefined | | 0Ah | RESLO_L | | Read/write | Byte | Undefined | | 0Ch | RESHI | 16x16-bit result high word | Read/write | Word | Undefined | | 0Eh | SUMEXT | 16x16-bit sum extension register | Read | Word | Undefined | | 10h | MPY32L | 32-bit operand 1 – multiply – low word | Read/write | Word | Undefined | | 10h | MPY32L_L | | Read/write | Byte | Undefined | | 11h | MPY32L_H | | Read/write | Byte | Undefined | | 12h | MPY32H | 32-bit operand 1 – multiply – high word | Read/write | Word | Undefined | | 12h | MPY32H_L | | Read/write | Byte | Undefined | | 13h | MPY32H_H | | Read/write | Byte | Undefined | | 12h | MPY32H_B | 24-bit operand 1 – multiply – high byte | Read/write | Byte | Undefined | | 14h | MPYS32L | 32-bit operand 1 – signed multiply – low word | Read/write | Word | Undefined | | 14h | MPYS32L_L | | Read/write | Byte | Undefined | | 15h | MPYS32L_H | | Read/write | Byte | Undefined | | 16h | MPYS32H | 32-bit operand 1 – signed multiply – high word | Read/write | Word | Undefined | | 16h | MPYS32H_L | | Read/write | Byte | Undefined | | 17h | MPYS32H_H | | Read/write | Byte | Undefined | | 16h | MPYS32H_B | 24-bit operand 1 – signed multiply – high byte | Read/write | Byte | Undefined | | 18h | MAC32L | 32-bit operand 1 – multiply accumulate – low word | Read/write | Word | Undefined | | | | | | | | www.ti.com MPY32 Registers # Table 16-7. MPY32 Registers (continued) | Offset | Acronym | Register Name | Туре | Access | Reset | |--------|-------------|-----------------------------------------------------------|------------|--------|-----------| | 18h | MAC32L_L | | Read/write | Byte | Undefined | | 19h | MAC32L_H | | Read/write | Byte | Undefined | | 1Ah | MAC32H | 32-bit operand 1 – multiply accumulate – high word | Read/write | Word | Undefined | | 1Ah | MAC32H_L | | Read/write | Byte | Undefined | | 1Bh | MAC32H_H | | Read/write | Byte | Undefined | | 1Ah | MAC32H_B | 24-bit operand 1 – multiply accumulate – high byte | Read/write | Byte | Undefined | | 1Ch | MACS32L | 32-bit operand 1 – signed multiply accumulate – low word | Read/write | Word | Undefined | | 1Ch | MACS32L_L | | Read/write | Byte | Undefined | | 1Dh | MACS32L_H | | Read/write | Byte | Undefined | | 1Eh | MACS32H | 32-bit operand 1 – signed multiply accumulate – high word | Read/write | Word | Undefined | | 1Eh | MACS32H_L | | Read/write | Byte | Undefined | | 1Fh | MACS32H_H | | Read/write | Byte | Undefined | | 1Eh | MACS32H_B | 24-bit operand 1 – signed multiply accumulate – high byte | Read/write | Byte | Undefined | | 20h | OP2L | 32-bit operand 2 – low word | Read/write | Word | Undefined | | 20h | OP2L_L | | Read/write | Byte | Undefined | | 21h | OP2L_H | | Read/write | Byte | Undefined | | 22h | OP2H | 32-bit operand 2 – high word | Read/write | Word | Undefined | | 22h | OP2H_L | | Read/write | Byte | Undefined | | 23h | OP2H_H | | Read/write | Byte | Undefined | | 22h | OP2H_B | 24-bit operand 2 – high byte | Read/write | Byte | Undefined | | 24h | RES0 | 32x32-bit result 0 – least significant word | Read/write | Word | Undefined | | 24h | RES0_L | | Read/write | Byte | Undefined | | 26h | RES1 | 32x32-bit result 1 | Read/write | Word | Undefined | | 28h | RES2 | 32x32-bit result 2 | Read/write | Word | Undefined | | 2Ah | RES3 | 32x32-bit result 3 – most significant word | Read/write | Word | Undefined | | 2Ch | MPY32CTL0 | MPY32 control register 0 | Read/write | Word | Undefined | | 2Ch | MPY32CTL0_L | | Read/write | Byte | Undefined | | 2Dh | MPY32CTL0_H | | Read/write | Byte | 00h | The registers listed in Table 16-8 are treated equally. # Table 16-8. Alternative Registers | Register | Alternative 1 | Alternative 2 | |-------------------------------------------------|------------------|------------------------| | 16-bit operand one – multiply | MPY | MPY32L | | 8-bit operand one – multiply | MPY_B or MPY_L | MPY32L_B or MPY32L_L | | 16-bit operand one – signed multiply | MPYS | MPYS32L | | 8-bit operand one – signed multiply | MPYS_B or MPYS_L | MPYS32L_B or MPYS32L_L | | 16-bit operand one – multiply accumulate | MAC | MAC32L | | 8-bit operand one – multiply accumulate | MAC_B or MAC_L | MAC32L_B or MAC32L_L | | 16-bit operand one – signed multiply accumulate | MACS | MACS32L | | 8-bit operand one – signed multiply accumulate | MACS_B or MACS_L | MACS32L_B or MACS32L_L | | 16x16-bit result low word | RESLO | RES0 | | 16x16-bit result high word | RESHI | RES1 | MPY32 Registers www.ti.com # 16.3.1 MPY32CTL0 Register 32-Bit Hardware Multiplier Control 0 Register # Figure 16-6. MPY32CTL0 Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |-----------|-----------|-----|-----|--------|---------|----------|-----------------| | Reserved | | | | | | MPYDLY32 | MPYDLYWRTE<br>N | | r-0 | r-0 | r-0 | r-0 | r-0 | r-0 | rw-0 | rw-0 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | MPYOP2_32 | MPYOP1_32 | MP | YMx | MPYSAT | MPYFRAC | Reserved | MPYC | | rw | rw | rw | rw | rw-0 | rw-0 | rw-0 | rw | # Table 16-9. MPY32CTL0 Register Description | Bit | Field | Туре | Reset | Description | |-------|-------------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-10 | Reserved | R | 0h | Reserved. Always reads as 0. | | 9 | MPYDLY32 | RW | Oh | Delayed write mode 0b = Writes are delayed until 64-bit result (RES0 to RES3) is available. 1b = Writes are delayed until 32-bit result (RES0 to RES1) is available. | | 8 | MPYDLYWRTEN | RW | Oh | Delayed write enable All writes to any MPY32 register are delayed until the 64-bit (MPYDLY32 = 0) or 32-bit (MPYDLY32 = 1) result is ready. 0b = Writes are not delayed. 1b = Writes are delayed. | | 7 | MPYOP2_32 | RW | 0h | Multiplier bit width of operand 2 0b = 16 bits 1b = 32 bits | | 6 | MPYOP1_32 | RW | Oh | Multiplier bit width of operand 1 0b = 16 bits 1b = 32 bits | | 5-4 | MPYMx | RW | Oh | Multiplier mode 00b = MPY - Multiply 01b = MPYS - Signed multiply 10b = MAC - Multiply accumulate 11b = MACS - Signed multiply accumulate | | 3 | MPYSAT | RW | 0h | Saturation mode 0b = Saturation mode disabled 1b = Saturation mode enabled | | 2 | MPYFRAC | RW | Oh | Fractional mode 0b = Fractional mode disabled 1b = Fractional mode enabled | | 1 | Reserved | RW | 0h | Reserved. Always reads as 0. | | 0 | MPYC | RW | Oh | Carry of the multiplier. It can be considered as 33rd or 65th bit of the result if fractional or saturation mode is not selected, because the MPYC bit does not change when switching to saturation or fractional mode. It is used to restore the SUMEXT content in MAC mode. | | | | | | 0b = No carry for result<br>1b = Result has a carry | # LCD\_E Controller The LCD\_E controller drives static and 2-mux to 8-mux LCDs. This chapter describes the LCD\_E controller. The differences between LCD\_B, LCD\_C and LCD\_E are listed in Table 17-1. Topic Page | 17.1 LCD_E Introduction | 2 | |-------------------------|---| | 17.2 LCD_E Operation | 4 | | 17.3 LCD_E Registers | 3 | LCD\_E Introduction www.ti.com ## 17.1 LCD\_E Introduction The LCD\_E controller directly drives LCD displays by automatically creating the ac segment and common voltage signals. The LCD\_E controller can support static and 2-mux to 8-mux LCD glasses. The LCD E controller features are: - Display memory - Supports LPM3.5 - · Configurable SEG and COM pins - · Automatic signal generation - Configurable frame frequency - Blinking of individual segments with separate blinking memory for static and 2- to 4-mux LCDs - Blinking of complete display for 5- to 8-mux LCDs - Regulated charge pump up to 3.44 V (typical) - · Contrast control by software - Support for the following types of LCDs - Static - 2-mux, 1/3 bias - 3-mux, 1/3 bias - 4-mux, 1/3 bias - 5-mux, 1/3 bias - 6-mux, 1/3 bias - 7-mux, 1/3 bias - 8-mux, 1/3 bias Table 17-1 lists the differences between LCD\_B, LCD\_C, and LCD\_E. Table 17-1. Differences Between LCD\_B, LCD\_C, and LCD\_E | Feature | LCD_B | LCD_C | LCD_E | |---------------------------------------------|-----------------------|-----------------------------------------|-------------------------------------------------------------------| | Supported types of LCDs | Static, 2-, 3-, 4-mux | Static, 2-, 3-, 4-, 5-, 6-, 7,<br>8-mux | Static, 2-, 3-, 4-mux or<br>5-, 6-, 7, 8-mux<br>(device specific) | | LCD bias modes | 1/2 bias and 1/3 bias | 1/2 bias and 1/3 bias | 1/3 bias | | LCD blinking memory | Yes | Yes | device specific | | SEG and COM mux | COM fixed | COM fixed | Each LCD drive pin | | External pins | R03, R13, R23, R33 | R03, R13, R23, R33 | R13, R23, R33, LCDCAP0,<br>LCDCAP1 | | LPM3.5 | Not supported | Not supported | Supported | | Maximum VLCDx settings | 001111b | 001111b | 001111b | | Maximum LCD voltage (V <sub>LCD,typ</sub> ) | 3.44 V | 3.44 V | 3.44 V | | Number of LCD pins | Up to 4×46 | Up to 4×50 or 8×46 | Up to 4×60 or 8×56 | Figure 17-1 shows the LCD controller block diagram. #### NOTE: Maximum LCD Segment Control The maximum number of segment lines and memory registers available differs with device. See the device-specific data sheet for available segment pins and the maximum number of segments supported. LCD\_E Introduction www.ti.com - (1) Device specific - (2) Only static and 2- to 4-mux (3) Used LCDMx depends on selected MUX mode (LCDMXx) Figure 17-1. LCD Controller Block Diagram ## 17.2 LCD\_E Operation The LCD controller is configured with user software. The setup and operation of the LCD controller is discussed in the following sections. ## 17.2.1 LCD Memory The LCD memory organization differs slightly depending on the mode. Each memory bit corresponds to one LCD segment, LCD common, or is not used, depending on the mode. To turn on an LCD segment, its corresponding memory bit is set. The memory can also be accessed word-wise using the even addresses starting at LCDM0W, LCDM2W, and so on. Setting the bit LCDCLRM clears all LCD display memory registers at the next frame boundary. LCDCLRM is reset automatically after the registers are cleared. #### 17.2.1.1 Static and 2-Mux to 4-Mux Mode For static and 2-mux to 4-mux modes, one byte of the LCD memory contains the information for two segment lines. In static and 2-mux to 4-mux modes, the following maximum LCD segments are possible: - Static: up to 63 segments (one COM line) - 2-mux: up to 124 segments (two COM lines) - 3-mux: up to 183 segments (three COM lines) - 4-mux: up to 240 segments (four COM lines) Figure 17-2 shows an example LCD memory map for 4-mux mode with 240 segments. Figure 17-2. LCD Memory for Static to 4-Mux Mode – Example for 4-Mux Mode With 240 Segments #### 17.2.1.2 5-Mux to 8-Mux Mode For 5-mux to 8-mux modes, one byte of the LCD memory contains the information for one segment line. In 5-mux to 8-mux modes the following maximum LCD segments are possible: - 5-mux: up to 295 segments (five COM lines) - 6-mux: up to 348 segments (six COM lines) - 7-mux: up to 399 segments (seven COM lines) - 8-mux: up to 448 segments (eight COM lines) Figure 17-3 shows an example LCD memory map for 8-mux mode with 96 segments. LCD pins L0 to L7 are configured to have common functionality by setting register bits LCDCSS0 to LCDCSS7 = 1 Figure 17-3. LCD Memory for 5-Mux to 8-Mux Mode – Example for 8-Mux Mode With 96 Segments # 17.2.2 Configuration of Port Pin as LCD Output LCD segments and common functions are multiplexed with digital I/O functions. These pins can function either as digital I/O or as LCD functions. The LCD segment and common functions, when multiplexed with digital I/O, are selected using the LCDSx bits in the LCDPCTLx registers. Setting the LCDSx bits selects the LCD function for each pin. When LCDSx = 0, a multiplexed pin is set to digital I/O function. When LCDSx = 1, a multiplexed pin is selected as LCD function. See the port diagram section of the device-specific data sheet for details on controlling the pin functionality. #### NOTE: LCDSx Bits Do Not Affect Dedicated LCD Segment and Common Pins The LCDSx bits affect only pins with multiplexed LCD segment and common functions and digital I/O functions. Dedicated LCD segment and common pins are not affected by the LCDSx bits. # 17.2.3 Configuration of LCD Pin as COM or SEG To simplify board layout and routing of segment and common lines, each LCD pin can be either defined as LCD segment (SEG) or as common line (COM). The LCDCSSx bits define how the content of the LCDMx registers are interpreted. By setting LCDCSSx = 0, the LCD pins Lx operate as LCD segments. When setting LCDCSSx = 1, the contents of LCDMx define which common line (COM0 to COM7) is used at the corresponding LCD pin Lx. The use of this functionality is described in the following sections. #### 17.2.3.1 Defining LCD Pin as Segment #### Static, 2-, 3-, 4-mux Mode In static, 2-, 3-, and 4-mux mode, the LCDMx register contains the memory for two segment pins. For example LCDM1 contains L3 and L2 (see Section 17.2.1). To define the LCD pin as an LCD segment, the corresponding bit in LCDCSSELx register must be set to 0 (default). With this setting, the LCDMx registers are used to enable or disable LCD segments. For example, to define LCD pin L14 as LCD segment, set LCDCSS14 = 0 in the LCDCSSEL0 register. #### 5-, 6-, 7- and 8-mux Mode In 5-, 6-, 7- and 8-mux mode, each LCDMx register contains the memory for one segment pin. To define the LCD pin as LCD segment, the corresponding bit in LCDCSSELx register must be set to 0 (default). With this setting, the LCDMx registers are used to enable or disable LCD segments. For instance LCDM7 contains memory for L7, LCDM29 for L29, and so on. **NOTE:** See the device-specific data sheet to determine whether or not 5-, 6-, 7-, or 8-mux mode is available on a device. # 17.2.3.2 Defining LCD Pin as Common Line **NOTE:** Only one common (COMx) pin per LCD pin can be selected. Assigning two or more common functions to one LCD pin can lead to unpredicted behavior. To define the LCD pin to have LCD common functionality, the corresponding bit in LCDCSSELx register must be set to 1. With this setting, the LCDMx register is used to configure the associated LCD pin to have COMx functionality. The LCDMx setting behaves differently depending on whether static- to 4-mux mode or 5-mux to 8-mux mode is used. The differences are described in the following sections. # 17.2.3.2.1 COM Assignment in Static, 2-, 3-, or 4-Mux Mode In static, 2-, 3-, or 4-mux mode, each LCDMx is used to control the common functionality of two LCD pins. Similar to the segment functionality described in Section 17.2.1, the lower nibble of LCDMx is used to control even-numbered LCD pins (L0, L2, ...). Odd-numbered LCD pins (L1, L3, ...) are controlled by the upper nibble of LCDMx. Selecting two or more COM pins per LCD pin can lead to unpredicted behavior of the LCD and must be avoided. In static mode only COM0 is available. In 2-mux mode: COM0 and COM1 can be selected. In 3-mux mode: COM0, COM1, and COM2 can be selected. In 4-mux mode: COM0, COM1, COM2, and COM3 can be selected. ``` SEG<sub>MAX</sub> = Number of Segment Pins n = 0 ... \frac{SEG_{MAX} - 1}{2} x = n ``` Figure 17-4. LCDMx in Static, 2-, 3-, or 4-Mux Mode #### Examples: # To use LCD pin L4 as COM2, make the following configuration: ``` LCDPCTL0 = BIT4; // configure I/O pad as LCD pin LCDCSSEL0 = BIT4; // configure LCD pin L4 as COM LCDM2 = BIT2; // define L4 as COM2 ``` #### To use LCD pin L23 as COM0, make the following configuration: ``` LCDPCTL1 = BIT7; // configure I/O pad as LCD pin LCDCSSEL1 = BIT7; // configure LCD pin L23 as COM LCDM11 = BIT4; // define L23 as COM0 ``` # 17.2.3.2.2 COM Assignment in 5-, 6-, 7-, or 8-Mux Mode In 5-, 6-, 7- and 8-mux mode, each LCDMx is used to control the common functionality of one LCD pin. To define a LCD pin as LCD common, the corresponding bit in LCDCSSELx register must be set to 1. In 5-, 6-, 7- and 8-mux mode, each LCDMx register controls the common functionality of one LCD pin. Selecting two or more COM pins per LCD pin can lead to unpredicted behavior of the LCD and must be avoided. **NOTE:** See the device-specific data sheet to determine whether or not 5-, 6-, 7-, or 8-mux mode is available on a device. ``` SEG_{MAX} = Number of Segment Pins n = 0 \dots SEG_{MAX} - 1 x = n ``` Figure 17-5. LCDMx in 5-, 6-, 7-, or 8-Mux Mode # Examples: #### To use LCD pin L4 as COM6, make the following configuration: ``` LCDPCTLO |= BIT4; // configure I/O pad as LCD pin LCDCSSELO |= BIT4; // configure LCD pin L4 as COM LCDM4 = BIT6; // define L4 as COM6 ``` #### To use LCD pin L23 as COM5, make the following configuration: ``` LCDPCTL1 = BIT7; // configure I/O pad as LCD pin LCDCSSEL1 = BIT7; // configure LCD pin L23 as COM LCDM23 = BIT5; // define L23 as COM5 ``` # 17.2.4 LCD Timing Generation The LCD\_E controller uses the $f_{LCD}$ signal from the integrated clock divider to generate the timing for common and segment lines. The LCDSSEL bit sets the source frequency $f_{SOURCE}$ to ACLK (30 kHz to 40 kHz), XT1CLK (32.768 kHz), or VLOCLK (≈ 10 kHz). The $f_{LCD}$ frequency is selected with the LCDDIVx and LCDMXx bits, and depends on the selected mux mode. The divider corresponding to the mux-mode is listed in Table 17-2. **MUX Mode MUXDIVIDER** 1 (Static) 64 32 2 3 16 4 16 5 12 6 8 7 8 8 8 Table 17-2. Divider Depending on MUX Mode The resulting f<sub>LCD</sub> frequency is calculated by: $$f_{LCD} = \frac{f_{SOURCE}}{(LCDDIVx + 1) \times MUXDIVDER}$$ #### **EXAMPLE 1:** The proper $f_{LCD}$ frequency depends on the LCD's requirement for framing frequency and the LCD multiplex rate. To avoid ghosting effects on the LCD, $f_{LCD}$ should be in the range of approximately 30 Hz to 60 Hz. It is calculated by: $$f_{LCD} = 2 \times mux \times f_{FRAME}$$ For example, to calculate f<sub>LCD</sub> for a 3-mux LCD with a frame frequency of 25 Hz to 80 Hz: $f_{FRAME}$ (from LCD data sheet) = 25 Hz to 80 Hz $f_{LCD} = 2 \times 3 \times f_{FRAME}$ $f_{LCD}(min) = 150 Hz$ $f_{LCD}(max) = 480 \text{ Hz}$ With $f_{SOURCE} = 32768$ Hz, LCDDIVx = 01101, and LCDMXx = 010: $f_{LCD} = 32768 \text{ Hz} / ((13+1) \times 16) = 32768 \text{ Hz} / 224 = 146 \text{ Hz}$ With LCDDIVx = 00100 and LCDMXx = 010: $f_{LCD} = 32768 \text{ Hz} / ((4+1) \times 16) = 32768 \text{ Hz} / 56 = 409 \text{ Hz}$ The lowest frequency has the lowest current consumption. The highest frequency has the least flicker. #### **EXAMPLE 2:** Table 17-3 shows the possible $f_{LCD}$ , $f_{FRAME}$ , and $f_{BLINK}$ frequencies for a given $f_{SOURCE} = 32.768$ kHz depending on the selected mux mode. Table 17-3. Example for Possible LCD Frequencies | f <sub>SOURCE</sub> (Hz) | Mux<br>Mode | LCDDIVx <sup>(1)</sup> | f <sub>DIV</sub> (Hz) | f <sub>LCD</sub> (Hz) | f <sub>FRAME</sub> (Hz) | f <sub>BLINK</sub> (Hz) | |--------------------------|-------------|------------------------|-----------------------|---------------------------------------|---------------------------------------|-------------------------------------------------------| | 32768 | Static | 4 to 16 | 8192 to 2048 | (8192 to 2048) / 64 =<br>(128 to 32) | (128 to 32) / 2 / 1 =<br>(64 to 16) | $f_{LCD} / ((LCDMx + 1) \times 2^{(LCDBLKPREx + 2)})$ | | 32768 | 2 | 4 to 16 | 8192 to 2048 | (8192 to 2048) / 32 =<br>(256 to 64) | (256 to 64) / 2 / 2 =<br>(64 to 16) | $f_{LCD} / ((LCDMx + 1) \times 2^{(LCDBLKPREx + 2)})$ | | 32768 | 3 | 4 to 16 | 8192 to 2048 | (8192 to 2048) / 16 =<br>(512 to 128) | (512 to 128) / 2 / 3 =<br>(85 to 21) | $f_{LCD} / ((LCDMx + 1) \times 2^{(LCDBLKPREx + 2)})$ | | 32768 | 4 | 4 to 16 | 8192 to 2048 | (8192 to 2048) / 16 =<br>(512 to 128) | (512 to 128) / 2 / 4 = (64 to 16) | $f_{LCD} / ((LCDMx + 1) \times 2^{(LCDBLKPREx + 2)})$ | | 32768 | 5 | 4 to 16 | 8192 to 2048 | (8192 to 2048) / 12 =<br>(683 to 171) | (682 to 172) / 2 / 5 =<br>(68 to 17) | $f_{LCD} / ((LCDMx + 1) \times 2^{(LCDBLKPREx + 2)})$ | | 32768 | 6 | 4 to 16 | 8192 to 2048 | (8192 to 2048) / 8 =<br>(1024 to 256) | (1024 to 256) / 2 / 6 =<br>(85 to 21) | $f_{LCD} / ((LCDMx + 1) \times 2^{(LCDBLKPREx + 2)})$ | | 32768 | 7 | 4 to 16 | 8192 to 2048 | (8192 to 2048) / 8 =<br>(1024 to 256) | (1024 to 256) / 2 / 7 =<br>(73 to 18) | $f_{LCD} / ((LCDMx + 1) \times 2^{(LCDBLKPREx + 2)})$ | | 32768 | 8 | 4 to 16 | 8192 to 2048 | (8192 to 2048) / 8 =<br>(1024 to 256) | (1024 to 256) / 2 / 8 = (64 to 16) | $f_{LCD} / ((LCDMx + 1) \times 2^{(LCDBLKPREx + 2)})$ | <sup>(1)</sup> LCDDIVx < 4 is not recommended, as it would result in higher frequencies for f<sub>LCD</sub>, f<sub>FRAME</sub>, and f<sub>BLINK</sub>. # 17.2.5 Blanking the LCD The LCD controller allows blanking the complete LCD. The LCDSON bit is combined by a logical AND with the memory bit of each segment. When LCDSON = 1, each segment is on or off according to its bit value. When LCDSON = 0, each LCD segment is off. ## 17.2.6 LCD Blinking The LCD controller also supports blinking. In static and 2-mux to 4-mux mode, the blinking mode LCDBLKMODx = 01 allows blinking of individual segments; with LCDBLKMODx = 10, all segments are blinking; and with LCDBLKMODx = 00, blinking is disabled. In 5-mux mode and above, only blinking mode LCDBLKMODx = 10 that allows blinking of all segments is available; if another mode is selected, blinking is disabled. ## 17.2.6.1 Blinking Memory In static and 2-mux to 4-mux mode, a separate blinking memory is implemented to select the blinking segments. To enable individual segments for blinking, the corresponding bit in the blinking memory LCDBMx registers must be set. The blinking memory uses the same structure as the LCD memory (see Figure 17-2). Each memory bit corresponds to one LCD segment or is not used, depending on the multiplexing mode LCDMXx. To enable blinking for a LCD segment, its corresponding memory bit is set. The blinking memory can also be accessed word-wise using the even addresses starting at LCDBM0W, LCDBM2W, and so on. Setting the bit LCDCLRBM clears all blinking memory registers at the next frame boundary. LCDCLRBM is automatically reset after the registers are cleared. # 17.2.6.2 COM Configuration in Blinking Mode Special care must be taken, if LCD segments are configured for blinking. As in Section 17.2.3.2 described, a part of the display memory LCDMx is used for COM configuration. It depends on selected blinking mode LCDBLKMODx, how display memory LCDMx and blinking memory LCDBMx have to be configured. See Table 17-4 for details. Table 17-4. Overview on COM Configuration in Blinking Mode | Blinking Mode<br>LCDBLKMODx | Description | |-----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 00b | Blinking disabled, the user can select which memory to be displayed by setting LCDDISP bit in LCDMEMCTL register LCDMx: the COM related configuration bits should be set accordingly LCDBMx: the COM related configuration bits should be set according to LCDMx configuration | | 01b | Blinking of individual segments as enabled in blinking memory register LCDBMx LCDMx: the COM related memory bits should be set accordingly LCDBMx: the COM related memory bits should be set to 0 | | 10b | Blinking of all segments LCDMx: the COM related memory bits should be set accordingly LCDBMx: this memory is not used in this blinking mode, no programming of LCDBMx necessary | | 11b | Switching between display contents as stored in LCDMx and LCDBMx memory registers LCDMx: the COM related memory bits should be set accordingly LCDBMx: the COM related memory bits should be set according to LCDMx configuration | By saying LCDBMx must be configured according to LCDMx it means that the same memory number "x" must be used. For example if LCDM2 = 02h (LCD pin L2 = COM1), then LCDBM2 has also to be programmed to 02h. #### Example: LCD configured in 4-MUX mode, 20 LCD pins, 4 configured as common, 16 configured as segment L0 = COM0, L1 = COM1, L2 = COM2, L3 = COM3; L4 ... L19 = SEG0 ... SEG19 The following configuration must be done: Figure 17-6 shows how to configure the display memory LCDMx and the blinking memory LCDBMx during different blinking modes. Note: x = don't care Figure 17-6. Example LCDMx and LCDBMx Configuration in Different Blinking Modes # 17.2.6.3 Blinking Frequency The blinking frequency $f_{BLINK}$ is selected with the LCDBLKPREx and LCDMXx bits, thus depending on selected mux mode. The resulting $f_{BLINK}$ frequency is calculated by: $$f_{\text{BLINK}} = \frac{f_{\text{LCD}}}{(\text{LCDMXx} + 1) \times 2^{\text{LCDBLKPREx+2}}}$$ The divider generating the blinking frequency $f_{BLINK}$ is reset when LCDBLKMODx = 00. After a blinking mode LCDBLKMODx = 01 or 10 is selected, the enabled segments or all segments go blank at the next frame boundary and stay off for half of a BLKCLK period. Then they go active at the next frame boundary and stay on for another half BLKCLK period before they go blank again at a frame boundary. #### NOTE: Blinking Frequency Restrictions The blinking frequency must be less than the frame frequency f<sub>FRAME</sub>. Change the blinking frequency only when LCDBLKMODx = 00. ## 17.2.6.4 Dual Display Memory In static- to 4-mux mode, the blinking memory LCDBMx can also be used as a secondary display memory when no blinking mode (LCDBLKMODx = 01 or 10) is selected. With LCDBLKMODx = 00 the LCDDISP bit can be used to manually select the memory to be displayed. With LCDDISP = 0, the LCD memory LCDMx is selected, and with LCDDISP = 1 the blinking memory LCDBMx is selected as display memory. Switching between the memories is synchronized to the frame boundaries. With LCDBLKMODx = 11 the LCD controller switches automatically between the memories using the divider to generate the blinking frequency. The LCDDISP bit can be used as status bit, indicating the selected memory. After LCDBLKMODx = 11 is selected, the memory to be displayed for the first half a BLKCLK period is the LCD memory. In the second half, the blinking memory is used as display memory. Switching between the memories is synchronized to the frame boundaries. # 17.2.7 LCD Voltage and Bias Generation The LCD\_E module allows selectable sources for the peak output waveform voltage, V1, as well as the fractional LCD biasing voltages V2, V4, and V5. $V_{LCD}$ may be sourced from $V_{CC}$ , an internal charge pump, or externally. ## 17.2.7.1 LCD Voltage Selection $V_{LCD}$ is sourced from $V_{CC}$ when LCDSELVDD = 1 and LCDREFEN = 0. $V_{LCD}$ is sourced from the internal charge pump when LCDSELVDD = 0 and LCDCPEN = 1. The internal charge pump either sourced by $V_{EXT}$ or $V_{DD}$ through R33 or from external reference voltage $V_{REF,EXT}$ or internal reference voltage through R13. The VLCDx bits provide a software selectable LCD voltage from 2.6 V to 3.5 V (typical) independent of $V_{DD}$ . See the device-specific data sheet for specifications. When the internal charge pump is used, a 100-nF or larger capacitor must be connected between the LCDCAP0 and LCDCAP1 pins. The charge pump may be temporarily disabled by setting LCDCPEN = 0 with VLCDx > 0 to reduce system noise. It can be automatically disabled during certain periods by setting the corresponding bits in the LCDVCTL register. In this case, the voltage present at the external capacitor is used for the LCD voltages until the charge pump is re-enabled. #### NOTE: Capacitor Required For Internal Charge Pump Connect a 100-nF or larger capacitor between the LCDCAP0 and LCDCAP1 pins when the internal charge pump is enabled. #### 17.2.7.2 LCD Bias Generation The fractional LCD biasing voltages, V2 and V4 can be generated internally or externally, independent of the source for $V_{LCD}$ . V5 is always connected to ground. Figure 17-7 shows the bias generation block diagram for LCD\_E static and 2-mux to 8-mux modes. Figure 17-7. Bias Generation The bias voltages V1, V2, and V4 are available on pin R33, R23, and R13, repectively. To source the bias voltages V1, V2, and V4 externally, an equally weighted resistor divider is used with resistors ranging from a few $k\Omega$ to 1 $M\Omega$ , depending on the size of the display. When using the internal charge pump it is possible to derive the bias voltages V1, V2, and V4 from several sources. It is possible to connect either an external voltage $V_{EXT}$ or internally $V_{DD}$ to R33 to generate V2 and V4. See section Section 17.2.8.1 (Mode 1 and Mode 2). The third possibility is to source R13 either externally or internally. See Section 17.2.8.2 (Mode 3) and Section 17.2.8.3 (Mode 4). #### 17.2.7.3 LCD Contrast Control The peak voltage of the output waveforms together with the selected mode and biasing determine the contrast and the contrast ratio of the LCD. The LCD contrast can be controlled in software by adjusting the LCD voltage generated by the integrated charge pump using the VLCDx settings. The contrast ratio depends on the used LCD display. Table 17-5 lists the biasing configurations that apply to the different modes together with the RMS voltages for the segments turned on $(V_{RMS,OF})$ and turned off $(V_{RMS,OFF})$ as functions of $V_{LCD}$ . It also lists the resulting contrast ratios between the on and off states. Table 17-5. LCD Voltage and Biasing Characteristics | Mode | Bias<br>Config | LCDMXx | COM<br>Lines | Voltage Levels | V <sub>RMS,OFF</sub> / V <sub>LCD</sub> | V <sub>RMS,ON</sub> / V <sub>LCD</sub> | Contrast Ratio V <sub>RMS,ON</sub> / V <sub>RMS,OFF</sub> | |--------|----------------|--------|--------------|----------------|-----------------------------------------|----------------------------------------|-----------------------------------------------------------| | Static | Static | 0000 | 1 | V1, V5 | 0 | 1 | 1/0 | | 2-mux | 1/3 | 0001 | 2 | V1, V2, V4, V5 | 0.333 | 0.745 | 2.236 | | 3-mux | 1/3 | 0010 | 3 | V1, V2, V4, V5 | 0.333 | 0.638 | 1.915 | | 4-mux | 1/3 | 0011 | 4 | V1, V2, V4, V5 | 0.333 | 0.577 | 1.732 | | 5-mux | 1/3 | 0100 | 5 | V1, V2, V4, V5 | 0.333 | 0.537 | 1.612 | | 6-mux | 1/3 | 0101 | 6 | V1, V2, V4, V5 | 0.333 | 0.509 | 1.528 | | 7-mux | 1/3 | 0110 | 7 | V1, V2, V4, V5 | 0.333 | 0.488 | 1.464 | | 8-mux | 1/3 | 0111 | 8 | V1, V2, V4, V5 | 0.333 | 0.471 | 1.414 | A typical approach to determine the required $V_{LCD}$ is by equating $V_{RMS,OFF}$ with a defined LCD threshold voltage, typically when the LCD exhibits approximately 10% contrast ( $V_{th,10\%}$ ): $V_{RMS,OFF} = V_{th,10\%}$ . Using the values for $V_{RMS,OFF} / V_{LCD}$ provided in the table results in $V_{LCD} = V_{th,10\%} / (V_{RMS,OFF} / V_{LCD})$ . In the static mode, a suitable choice is $V_{LCD}$ greater than or equal to 3 x $V_{th,10\%}$ . #### 17.2.8 LCD Operation Modes This section describes the different modes in which the LCD can be operated. #### 17.2.8.1 Internal Charge Pump Enabled, Internal V<sub>RFF</sub> Disabled (Mode 1, Mode 2) In Figure 17-8 Mode 1 is depicted. LCD voltages are sourced from an external voltage $V_{EXT}$ , which is connected to pin R33. The internal charge pump is used to generate the LCD voltages V1, V2, V4 and V5. Contrast can be adjusted by changing $V_{EXT}$ . Mode 2 is shown in Figure 17-9. R33 is connected to internal supply voltage $V_{DD}$ . The internal charge pump generates the LCD voltages V1, V2, V4, and V5. Contrast can be adjusted by changing $V_{DD}$ from 3.6 V to 1.8 V. ``` LCDSELVDD = 1; // Pin R33 is connected to internal supply voltage LCDCPEN = 1; // internal charge pump enabled LCDCPEFEN = 0; // internal reference voltage at R13 is disabled LCDCPFSELx = 0b1111; // charge pump frequency select, slowest value VLCDx = 0b0000; // not used, set to reset value LCDON = 1; // enable LCD ``` Figure 17-8. LCD Operation Mode 1 Figure 17-9. LCD Operation Mode 2 # 17.2.8.2 Internal Charge Pump Enabled, Internal V<sub>REF</sub> Enabled (Mode 3) In Figure 17-10 Mode 3 is depicted. LCD voltages are derived from Bias Voltage Generator, which is connected to pin R13. The internal charge pump is used to generate the LCD voltages V1, V2, V5 is connected to ground. Contrast can be adjusted in software by changing VLCDx bits in LCDVCTL register. By setting LCDREFMODE = 1, the bias voltage generator is in switch mode. Thus the bias voltage generator is on for 1 clock cycle and off for another 256 clock cycles to save power. Setting LCDREFMODE = 0 sets the bias generator to static mode to be able to drive larger LCD panels. ``` LCDSELVDD = 0; // Pin R33 is connected to external supply voltage LCDCPEN = 1; // internal charge pump enabled LCDREFEN = 1; // internal reference voltage at R13 is enabled LCDCPFSELx = 0b1111; // charge pump frequency select, slowest value VLCDx = 0b1000; // VLCDx set to mid position LCDON = 1; // enable LCD ``` Figure 17-10. LCD Operation Mode 3 **NOTE:** Mode 3 is the recommended operating mode, as this provides the lowest external component cost and very low operating currents. ## 17.2.8.3 Internal Charge Pump Enabled, Internal V<sub>REF</sub> Disabled (Mode 4) Figure 17-11 shows Mode 4. LCD voltages are derived from external reference voltage, which is connected to pin R13. The internal charge pump is used to generate the LCD biasing voltages V1, V2. V5 is connected to ground. Contrast can be adjusted by changing external voltage V<sub>REF,EXT</sub> from 0.8 V to 1.2 V. ``` LCDSELVDD = 0; // Pin R33 is connected to external supply voltage LCDCPEN = 1; // internal charge pump enabled LCDREFEN = 0; // internal reference voltage at R13 is disabled LCDCPFSELx = 0b1111; // charge pump frequency select, slowest value VLCDx = 0b0000; // not used, set to reset value LCDON = 1; // enable LCD ``` Figure 17-11. LCD Operation Mode 4 #### 17.2.9 LCD Interrupts The LCD\_E module has three interrupt sources available, each with independent enables and flags. The three interrupt flags, namely LCDFRMIFG, LCDBLKOFFIFG, and LCDBLKONIFG are prioritized and combined to source a single interrupt vector. The interrupt vector register LCDIV is used to determine which flag requested an interrupt. The highest priority enabled interrupt generates a number in the LCDIV register (see register description). This number can be evaluated or added to the program counter to automatically enter the appropriate software routine. Disabled LCD interrupts do not affect the LCDIV value. Any read access of the LCDIV register automatically resets the highest pending interrupt flag. If another interrupt flag is set, another interrupt is immediately generated after servicing the initial interrupt. A write access to the LCDIV register automatically resets all pending interrupt flags. In addition, all flags can be cleared by software. The LCDBLKONIFG is set at the BLKCLK rising edge and LCD switches to blinking status when blinking is enabled with LCDBLKMODx = 01 or 10. It is also set at the BLKCLK edge that selects the blinking memory as display memory when LCDBLKMODx = 11. It is automatically cleared when a LCD or blinking memory register is written. Setting the LCDBLKONIE bit enables the interrupt. The LCDBLKOFFIFG is set at the BLKCLK falling edge and LCD switches to non-blinking status when blinking is enabled with LCDBLKMODx = 01 or 10. It is also set at the BLKCLK edge that selects the LCD memory as display memory when LCDBLKMODx = 11. It is automatically cleared when a LCD or blinking memory register is written. Setting the LCDBLKOFFIE bit enables the interrupt. The LCDFRMIFG is set at a frame boundary. It is automatically cleared when a LCD or blinking memory register is written. Setting the LCDFRMIFGIE bit enables the interrupt. #### 17.2.9.1 LCDIV Software Example The following software example shows the recommended use of LCDIV and the handling overhead. The LCDIV value is added to the PC to automatically jump to the appropriate routine. The numbers at the right margin show the necessary CPU cycles for each instruction. The software overhead for different interrupt sources includes interrupt latency and return-from-interrupt cycles, but not the task handling itself. ``` ; Interrupt handler for LCD_E interrupt flags. LCDB_HND ; Interrupt latency 6 ADD &LCDBIV,PC ; Add offset to Jump table 3 RETI ; Vector 0: No interrupt 5 JMP LCDBLKON_HND ; Vector 4: LCDBLKONIFG 2 JMP LCDBLKOFF_HND ; Vector 6: LCDBLKOFFIFG ; Vector 8: LCDFRMIFG LCDFRM_HND ... ; Task starts here 5 RETT LCDBLKON_HND ; Vector 4: LCDBLKONIFG ...; Task starts here RETI ; Back to main program 5 LCDBLKOFF_HND ; Vector 6: LCDBLKOFFIFG ...; Task starts here RETI ; Back to main program 5 ``` # 17.2.10 Static Mode In static mode, each MSP430 segment pin drives one LCD segment, and one common line (COM0) is used. Figure 17-12 shows some example static waveforms. Figure 17-12. Example Static Waveforms # 17.2.11 2-Mux Mode In 2-mux mode, each MSP430 segment pin drives two LCD segments, and two common lines (COM0 and COM1) are used. Figure 17-13 shows some example 2-mux 1/3-bias waveforms. Figure 17-13. Example 2-Mux Waveforms # 17.2.12 3-Mux Mode In 3-mux mode, each MSP430 segment pin drives three LCD segments, and three common lines (COM0, COM1, and COM2) are used. Figure 17-14 shows some example 3-mux 1/3-bias waveforms. Figure 17-14. Example 3-Mux Waveforms # 17.2.13 4-Mux Mode In 4-mux mode, each MSP430 segment pin drives four LCD segments and four common lines (COM0, COM1, COM2, and COM3) are used. Figure 17-15 shows some example 4-mux 1/3-bias waveforms. Figure 17-15. Example 4-Mux Waveforms # 17.2.14 6-Mux Mode In 6-mux mode, each MSP430 segment pin drives six LCD segments, and six common lines (COM0, COM1, COM2, COM3, COM4, and COM5) are used. Figure 17-16 shows some example 6-mux 1/3-bias waveforms. Figure 17-16. Example 6-Mux Waveforms # 17.2.15 8-Mux Mode In 8-mux mode, each MSP430 segment pin drives eight LCD segments, and eight common lines (COM0 through COM7) are used. Figure 17-17 shows some example 8-mux 1/3-bias waveforms. Figure 17-17. Example 8-Mux, 1/3 Bias Waveforms (LCDLP = 0) Figure 17-18 shows some example 8-mux 1/3-bias waveforms with LCDLP = 1. With LCDLP = 1, the voltage sequence compared to the non-low power waveform is reshuffled; that is, all of the timeslots marked with "\*" in Figure 17-17 are grouped together. The same principle applies to all mux modes. Figure 17-18. Example 8-Mux, 1/3 Bias Low-Power Waveforms (LCDLP = 1) LCD\_E Registers www.ti.com # 17.3 LCD\_E Registers The LCD\_E controller registers are listed in Table 17-6 to Table 17-9. The LCD memory and blinking memory registers can also be accessed as word. The number of available memory registers on a given device depends on the number of available segment pins (see the device-specific data sheet). Table 17-6. LCD\_E Registers | Offset | Acronym | Register Name | Туре | Reset | Section | |--------|-----------|--------------------------------------|------------|-------|-----------------| | 000h | LCDCTL0 | LCD_E control register 0 | Read/write | 3800h | Section 17.3.1 | | 002h | LCDCTL1 | LCD_E control register 1 | Read/write | 0000h | Section 17.3.2 | | 004h | LCDBLKCTL | LCD_E blinking control register | Read/write | 0000h | Section 17.3.3 | | 006h | LCDMEMCTL | LCD_E memory control register | Read/write | 0000h | Section 17.3.4 | | 008h | LCDVCTL | LCD_E voltage control register | Read/write | 0000h | Section 17.3.5 | | 00Ah | LCDPCTL0 | LCD_E port control 0 | Read/write | 0000h | Section 17.3.6 | | 00Ch | LCDPCTL1 | LCD_E port control 1 | Read/write | 0000h | Section 17.3.7 | | 00Eh | LCDPCTL2 | LCD_E port control 2 (=256 segments) | Read/write | 0000h | Section 17.3.8 | | 010h | LCDPCTL3 | LCD_E port control 3 (384 segments) | Read/write | 0000h | Section 17.3.9 | | 012h | | Reserved | Read/write | 0000h | | | 014h | LCDCSSEL0 | LCD_E COM/SEG select register 0 | Read/write | 0000h | Section 17.3.10 | | 016h | LCDCSSEL1 | LCD_E COM/SEG select register 1 | Read/write | 0000h | Section 17.3.11 | | 018h | LCDCSSEL2 | LCD_E COM/SEG select register 2 | Read/write | 0000h | Section 17.3.12 | | 01Ah | LCDCSSEL3 | LCD_E COM/SEG select register 3 | Read/write | 0000h | Section 17.3.13 | | 01Ch | | Reserved | Read/write | 0000h | | | 01Eh | LCDIV | LCD_E interrupt vector | Read only | 0000h | Section 17.3.16 | # Table 17-7. LCD Memory Registers for Static and 2-Mux to 4-Mux Modes<sup>(1)</sup> (2) | Offset | Acronym | Register Name | Туре | Reset | |--------|---------|-----------------------------------------|------------|-----------| | 020h | LCDM0W | LCD memory 0 Word (S3, S2, S1, S0) | Read/write | Unchanged | | 020h | LCDM0 | LCD memory 0 (S1, S0) | Read/write | Unchanged | | 021h | LCDM1 | LCD memory 1 (S3, S2) | Read/write | Unchanged | | 022h | LCD2W | LCD memory 2 Word (S7, S6, S5, S4) | Read/write | Unchanged | | 022h | LCDM2 | LCD memory 2 (S5, S4) | Read/write | Unchanged | | 023h | LCDM3 | LCD memory 3 (S7, S6) | Read/write | Unchanged | | 024h | LCD4W | LCD memory 4 Word (S11, S10, S9, S8) | Read/write | Unchanged | | 024h | LCDM4 | LCD memory 4 (S9, S8) | Read/write | Unchanged | | 025h | LCDM5 | LCD memory 5 (S11, S10) | Read/write | Unchanged | | 026h | LCDM6W | LCD memory 6 Word (S15, S14, S13, S12) | Read/write | Unchanged | | 026h | LCDM6 | LCD memory 6 (S13, S12) | Read/write | Unchanged | | 027h | LCDM7 | LCD memory 7 (S15, S14) | Read/write | Unchanged | | 028h | LCDM8W | LCD memory 8 Word (S19, S18, S17, S16) | Read/write | Unchanged | | 028h | LCDM8 | LCD memory 8 (S17, S16) | Read/write | Unchanged | | 029h | LCDM9 | LCD memory 9 (S19, S18) | Read/write | Unchanged | | 02Ah | LCDM10W | LCD memory 10 Word (S23, S22, S21, S20) | Read/write | Unchanged | | 02Ah | LCDM10 | LCD memory 10 (S21, S20) | Read/write | Unchanged | | 02/til | LCDM11 | LCD memory 11 (S23, S22) | Read/write | Unchanged | | 02Ch | LCDM12W | LCD memory 12 Word (S27, S26, S25, S24) | Read/write | Unchanged | | 02Ch | LCDM12 | LCD memory 12 (S25, S24) | Read/write | Unchanged | | 02Dh | LCDM13 | LCD memory 13 (S27, S26) | Read/write | Unchanged | | 02Eh | LCDM14W | LCD memory 14 Word (S31, S30, S29, S28) | Read/write | Unchanged | | 02Eh | LCDM14 | LCD memory 14 (S29, S28) | Read/write | Unchanged | | 02En | LCDM15 | LCD memory 15 (S31, S30) | Read/write | Unchanged | | 030h | LCDM16W | LCD memory 16 Word (S35, S34, S33, S32) | Read/write | Unchanged | | 030h | LCDM16 | LCD memory 16 (S33, S32) | Read/write | Unchanged | | 030H | | | | Unchanged | | | LCDM17 | LCD memory 17 (S35, S34) | Read/write | | | 032h | LCDM18W | LCD memory 18 Word (S39, S38, S37, S36) | Read/write | Unchanged | | 032h | LCDM18 | LCD memory 18 (S37, S36) | Read/write | Unchanged | | 033h | LCDM19 | LCD memory 19 (S39, S38) | Read/write | Unchanged | | 034h | LCDM20W | LCD memory 20 Word (S43, S42, S41, S40) | Read/write | Unchanged | | 034h | LCDM20 | LCD memory 20 (S41, S40) | Read/write | Unchanged | | 035h | LCDM21 | LCD memory 21 (S43, S42) | Read/write | Unchanged | | 036h | LCDM22W | LCD memory 22 Word (S47, S46, S45, S44) | Read/write | Unchanged | | 036h | LCDM22 | LCD memory 22 (S45, S44) | Read/write | Unchanged | | 037h | LCDM23 | LCD memory 23 (S47, S46) | Read/write | Unchanged | | 038h | LCDM24W | LCD memory 24 Word (S51, S50, S49, S48) | Read/write | Unchanged | | 038h | LCDM24 | LCD memory 24 (S49, S48) | Read/write | Unchanged | | 039h | LCDM25 | LCD memory 25 (S51, S50) | Read/write | Unchanged | | 03Ah | LCDM26W | LCD memory 26 Word (S55, S54, S53, S52) | Read/write | Unchanged | | 03Ah | LCDM26 | LCD memory 26 (S53, S52) | Read/write | Unchanged | | 03Bh | LCDM27 | LCD memory 27 (S55, S54) | Read/write | Unchanged | | 03Ch | LCDM28W | LCD memory 28 Word (S59, S58, S57, S56) | Read/write | Unchanged | | 03Ch | LCDM28 | LCD memory 28 (S57, S56) | Read/write | Unchanged | | 03Dh | LCDM29 | LCD memory 29 (S59, S58) | Read/write | Unchanged | <sup>&</sup>lt;sup>(1)</sup> The LCD memory registers can also be accessed as word. <sup>(2)</sup> The number of available memory registers on a given device depends on the amount of available segment pins. See the device-specific data sheet. # Table 17-7. LCD Memory Registers for Static and 2-Mux to 4-Mux Modes<sup>(1)</sup> (continued) | Offset | Acronym | Register Name | Туре | Reset | |--------|---------|-----------------------------------------|------------|-----------| | 03Eh | LCDM30W | LCD memory 30 Word (S63, S62, S61, S60) | Read/write | Unchanged | | 03Eh | LCDM30 | LCD memory 30 (S61, S60) | Read/write | Unchanged | | 03Fh | LCDM31 | LCD memory 31 (S63, S62) | Read/write | Unchanged | # Table 17-8. LCD Blinking Memory Registers for Static and 2-Mux to 4-Mux Modes (1)(2) | changed changed changed changed changed changed | |-------------------------------------------------| | changed<br>changed<br>changed | | changed<br>changed | | changed | | _ | | _ | | | | changed | | changed | | changed | | changed<br>changed | | | <sup>&</sup>lt;sup>(1)</sup> The LCD blinking memory registers can also be accessed as word. <sup>(2)</sup> The number of available memory registers on a given device depends on the amount of available segment pins (see the device-specific data sheet). ### Table 17-8. LCD Blinking Memory Registers for Static and 2-Mux to 4-Mux Modes<sup>(1)(2)</sup> (continued) | Offset | Acronym | Register Name | Туре | Reset | |--------|----------|-----------------------------|------------|-----------| | 05Eh | LCDBM30W | LCD blinking memory 30 Word | Read/write | Unchanged | | 05Eh | LCDBM30 | LCD blinking memory 30 | Read/write | Unchanged | | 05Fh | LCDBM31 | LCD blinking memory 31 | Read/write | Unchanged | ### Table 17-9. LCD Memory Registers for 5-Mux to 8-Mux Modes (1)(2) | Offset | Acronym | Register Name | Туре | Reset | |--------|---------|-------------------------------|------------|-----------| | 020h | LCDM0W | LCD memory 0 Word (S1, S0) | Read/write | Unchanged | | 020h | LCDM0 | LCD memory 0 (S0) | Read/write | Unchanged | | 021h | LCDM1 | LCD memory 1 (S1) | Read/write | Unchanged | | 022h | LCDM2W | LCD memory 2 Word (S3, S2) | Read/write | Unchanged | | 022h | LCDM2 | LCD memory 2 (S2) | Read/write | Unchanged | | 023h | LCDM3 | LCD memory 3 (S3) | Read/write | Unchanged | | 024h | LCDM4W | LCD memory 4 Word (S5, S4) | Read/write | Unchanged | | 024h | LCDM4 | LCD memory 4 (S4) | Read/write | Unchanged | | 025h | LCDM5 | LCD memory 5 (S5) | Read/write | Unchanged | | 026h | LCDM6W | LCD memory 6 Word (S7, S6) | Read/write | Unchanged | | 026h | LCDM6 | LCD memory 6 (S6) | Read/write | Unchanged | | 027h | LCDM7 | LCD memory 7 (S7) | Read/write | Unchanged | | 028h | LCDM8W | LCD memory 8 Word (S9, S8) | Read/write | Unchanged | | 028h | LCDM8 | LCD memory 8 (S8) | Read/write | Unchanged | | 029h | LCDM9 | LCD memory 9 (S9) | Read/write | Unchanged | | 02Ah | LCDM10W | LCD memory 10 Word (S11, S10) | Read/write | Unchanged | | 02Ah | LCDM10 | LCD memory 10 (S10) | Read/write | Unchanged | | 02Bh | LCDM11 | LCD memory 11 (S11) | Read/write | Unchanged | | 02Ch | LCDM12W | LCD memory 12 Word (S13, S12) | Read/write | Unchanged | | 02Ch | LCDM12 | LCD memory 12 (S12) | Read/write | Unchanged | | 02Dh | LCDM13 | LCD memory 13 (S13) | Read/write | Unchanged | | 02Eh | LCDM14W | LCD memory 14 Word (S15, S14) | Read/write | Unchanged | | 02Eh | LCDM14 | LCD memory 14 (S14) | Read/write | Unchanged | | 02Fh | LCDM15 | LCD memory 15 (S15) | Read/write | Unchanged | | 030h | LCDM16W | LCD memory 16 Word (S17, S16) | Read/write | Unchanged | | 030h | LCDM16 | LCD memory 16 (S16) | Read/write | Unchanged | | 031h | LCDM17 | LCD memory 17 (S17) | Read/write | Unchanged | | 032h | LCDM18W | LCD memory 18 Word (S19, S18) | Read/write | Unchanged | | 032h | LCDM18 | LCD memory 18 (S18) | Read/write | Unchanged | | 033h | LCDM19 | LCD memory 19 (S19) | Read/write | Unchanged | | 034h | LCDM20W | LCD memory 20 Word (S21, S20) | Read/write | Unchanged | | 034h | LCDM20 | LCD memory 20 (S20) | Read/write | Unchanged | | 035h | LCDM21 | LCD memory 21 (S21) | Read/write | Unchanged | | 036h | LCDM22W | LCD memory 22 Word (S23, S22) | Read/write | Unchanged | | 036h | LCDM22 | LCD memory 22 (S22) | Read/write | Unchanged | | 037h | LCDM23 | LCD memory 23 (S23) | Read/write | Unchanged | | 038h | LCDM24W | LCD memory 24 Word (S25, S24) | Read/write | Unchanged | | 038h | LCDM24 | LCD memory 24 (S24) | Read/write | Unchanged | | 039h | LCDM25 | LCD memory 25 (S25) | Read/write | Unchanged | | 03Ah | LCDM26W | LCD memory 26 Word (S27, S26) | Read/write | Unchanged | | 03Ah | LCDM26 | LCD memory 26 (S26) | Read/write | Unchanged | | 03Bh | LCDM27 | LCD memory 27 (S27) | Read/write | Unchanged | | 03Ch | LCDM28W | LCD memory 28 Word (S29, S28) | Read/write | Unchanged | | 03Ch | LCDM28 | LCD memory 28 (S28) | Read/write | Unchanged | | 03Dh | LCDM29 | LCD memory 29 (S29) | Read/write | Unchanged | <sup>&</sup>lt;sup>(1)</sup> The LCD memory registers can also be accessed as word. <sup>(2)</sup> The number of available memory registers on a given device depends on the number of available segment pins (see the device-specific data sheet). # Table 17-9. LCD Memory Registers for 5-Mux to 8-Mux Modes<sup>(1)(2)</sup> (continued) | Offset | Acronym | Register Name | Туре | Reset | |--------|---------|-------------------------------|------------|-----------| | 03Eh | LCDM30W | LCD memory 30 Word (S31, S30) | Read/write | Unchanged | | 03Eh | LCDM30 | LCD memory 30 (S30) | Read/write | Unchanged | | 03Fh | LCDM31 | LCD memory 31 (S31) | Read/write | Unchanged | | 040h | LCDM32W | LCD memory 32 Word (S33, S32) | Read/write | Unchanged | | 040h | LCDM32 | LCD memory 32 (S32) | Read/write | Unchanged | | 041h | LCDM33 | LCD memory 33 (S33) | Read/write | Unchanged | | 042h | LCDM34W | LCD memory 34 Word (S35, S34) | Read/write | Unchanged | | 042h | LCDM34 | LCD memory 34 (S34) | Read/write | Unchanged | | 043h | LCDM35 | LCD memory 35 (S35) | Read/write | Unchanged | | 044h | LCDM36W | LCD memory 36 Word (S37, S36) | Read/write | Unchanged | | 044h | LCDM36 | LCD memory 36 (S36) | Read/write | Unchanged | | 045h | LCDM37 | LCD memory 37 (S37) | Read/write | Unchanged | | 046h | LCDM38W | LCD memory 38 Word (S39, S38) | Read/write | Unchanged | | 046h | LCDM38 | LCD memory 38 (S38) | Read/write | Unchanged | | 047h | LCDM39 | LCD memory 39 (S39) | Read/write | Unchanged | | 048h | LCDM40W | LCD memory 40 Word (S41, S40) | Read/write | Unchanged | | 048h | LCDM40 | LCD memory 40 (S40) | Read/write | Unchanged | | 049h | LCDM41 | LCD memory 41 (S41) | Read/write | Unchanged | | 04Ah | LCDM42W | LCD memory 42 Word (S43, S42) | Read/write | Unchanged | | 04Ah | LCDM42 | LCD memory 42 (S42) | Read/write | Unchanged | | 04Bh | LCDM43 | LCD memory 43 (S43) | Read/write | Unchanged | | 04Ch | LCDM44W | LCD memory 44 Word (S45, S44) | Read/write | Unchanged | | 04Ch | LCDM44 | LCD memory 44 (S44) | Read/write | Unchanged | | 04Dh | LCDM45 | LCD memory 45 (S45) | Read/write | Unchanged | | 04Eh | LCDM46W | LCD memory 46 Word (S47, S46) | Read/write | Unchanged | | 04Eh | LCDM46 | LCD memory 46 (S46) | Read/write | Unchanged | | 04Fh | LCDM47 | LCD memory 47 (S47) | Read/write | Unchanged | | 050h | LCDM48W | LCD memory 48 Word (S49, S48) | Read/write | Unchanged | | 050h | LCDM48 | LCD memory 48 (S48) | Read/write | Unchanged | | 051h | LCDM49 | LCD memory 49 (S49) | Read/write | Unchanged | | 052h | LCDM50W | LCD memory 50 Word (S51, S50) | Read/write | Unchanged | | 052h | LCDM50 | LCD memory 50 (S50) | Read/write | Unchanged | | 053h | LCDM51 | LCD memory 51 (S51) | Read/write | Unchanged | | 054h | LCDM52W | LCD memory 52 Word (S53, S52) | Read/write | Unchanged | | 054h | LCDM52 | LCD memory 52 (S52) | Read/write | Unchanged | | 055h | LCDM53 | LCD memory 53 (S53) | Read/write | Unchanged | | 056h | LCDM54W | LCD memory 54 Word (S55, S54) | Read/write | Unchanged | | 056h | LCDM54 | LCD memory 54 (S54) | Read/write | Unchanged | | 057h | LCDM55 | LCD memory 55 (S55) | Read/write | Unchanged | | 058h | LCDM56W | LCD memory 56 Word (S57, S56) | Read/write | Unchanged | | 058h | LCDM56 | LCD memory 56 (S56) | Read/write | Unchanged | | 059h | LCDM57 | LCD memory 57 (S57) | Read/write | Unchanged | | 05Ah | LCDM58W | LCD memory 58 Word (S59, S58) | Read/write | Unchanged | | 05Ah | LCDM58 | LCD memory 58 (S58) | Read/write | Unchanged | | 05Bh | LCDM59 | LCD memory 59 (S59) | Read/write | Unchanged | | 05Ch | LCDM60W | LCD memory 60 Word (S61, S60) | Read/write | Unchanged | | 05Ch | LCDM60 | LCD memory 60 (S60) | Read/write | Unchanged | ### Table 17-9. LCD Memory Registers for 5-Mux to 8-Mux Modes<sup>(1)(2)</sup> (continued) | Offset | Acronym | Register Name | Туре | Reset | |--------|---------|-------------------------------|------------|-----------| | 05Dh | LCDM61 | LCD memory 61 (S61) | Read/write | Unchanged | | 05Eh | LCDM62W | LCD memory 62 Word (S63, S62) | Read/write | Unchanged | | 05Eh | LCDM62 | LCD memory 62 (S62) | Read/write | Unchanged | | 05Fh | LCDM63 | LCD memory 63 (S63) | Read/write | Unchanged | ### 17.3.1 LCDCTL0 Register LCD\_E Control Register 0 #### Figure 17-19. LCDCTL0 Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |---------------|--------|---------|--------|----------|--------|--------|--------| | | | LCDDIVx | | Reserved | | | | | rw-{0} | rw-{0} | rw-{1} | rw-{1} | rw-{1} | r-{0} | r-{0} | r-{0} | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | LCDSSEL LCDMX | | | LCDMXx | | LCDSON | LCDLP | LCDON | | rw-{0} ### Table 17-10. LCDCTL0 Register Description | Bit | Field | Туре | Reset | Description | |-------|----------|------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-11 | LCDDIVx | RW | 00111b | LCD frequency divider. Together with LCDMXx, the LCD frequency $f_{LCD}$ is calculated as $f_{LCD} = f_{SOURCE} / ((LCDDIVx + 1) \times Value[LCDMXx])$ . Change only while LCDON = 0. | | | | | | 00000b = Divide by 1<br>00001b = Divide by 2 | | | | | | :<br> | | | | | | 11110b = Divide by 31<br>11111b = Divide by 32 | | 10-8 | Reserved | R | 0h | Reserved | | | | | - | | | 7-6 | LCDSSEL | RW | 0h | Clock source $f_{SOURCE}$ select for LCD and blinking frequency. Change only while LCDON = 0. | | | | | | 00b = XT1CLK | | | | | | 01b = ACLK (30 kHz to 40 kHz) | | | | | | 10b = VLOCLK | | | | | | 11b = Reserved | | 5-3 | LCDMXx | RW | 0h | LCD mux rate. These bits select the LCD mode. Change only while LCDON = 0. | | | | | | 000b = Static | | | | | | 001b = 2-mux | | | | | | 010b = 3-mux | | | | | | 011b = 4-mux | | | | | | 100b = 5-mux<br>101b = 6-mux | | | | | | 110b = 7-mux | | | | | | 111b = 8-mux | | 2 | LCDSON | RW | 0h | LCD segments on. This bit supports flashing LCD applications by turning off all segment lines, while leaving the LCD timing generator and R33 enabled. | | | | | | 0b = All LCD segments are off. | | | | | | 1b = All LCD segments are enabled and on or off according to their | | | | | | corresponding memory location. | | 1 | LCDLP | RW | 0h | LCD low-power waveform | | | | | | 0b = Standard LCD waveforms on segment and common lines selected. | | | | | | 1b = Low-power LCD waveforms on segment and common lines selected. | | 0 | LCDON | RW | 0h | LCD on. This bit turns the LCD_E module on or off. | | | | | | 0b = LCD_E module off | | | | | | 1b = LCD_E module on | ### 17.3.2 LCDCTL1 Register LCD\_E Control Register 1 #### Figure 17-20. LCDCTL1 Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------|----|----------|------------|-------------|-------------|------------------|-----------| | | | Reserved | LCDBLKONIE | LCDBLKOFFIE | LCDFRMIE | | | | r0 | r0 | rO | r0 | rO | rw-{0} | rw-{0} | rw-{0} | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Reserved | | | | | LCDBLKONIFG | LCDBLKOFFIF<br>G | LCDFRMIFG | | r0 | r0 | r0 | r0 | r0 | rw-{0} | rw-{0} | rw-{0} | ### Table 17-11. LCDCTL1 Register Description | Bit | Field | Туре | Reset | Description | |-------|--------------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-11 | Reserved | R | 0h | Reserved | | 10 | LCDBLKONIE | RW | Oh | LCD blinking interrupt enable, segments switched on 0b = Interrupt disabled 1b = Interrupt enabled | | 9 | LCDBLKOFFIE | RW | 0h | LCD blinking interrupt enable, segments switched off 0b = Interrupt disabled 1b = Interrupt enabled | | 8 | LCDFRMIE | RW | 0h | LCD frame interrupt enable 0b = Interrupt disabled 1b = Interrupt enabled | | 7-3 | Reserved | R | 0h | Reserved | | 2 | LCDBLKONIFG | RW | Oh | LCD blinking interrupt flag, set at the rising edge of BLKCLK. Automatically cleared when data is written into a memory register. 0b = No interrupt pending 1b = Interrupt pending | | 1 | LCDBLKOFFIFG | RW | Oh | LCD blinking interrupt flag, set at the falling edge of BLKCLK. Automatically cleared when data is written into a memory register. 0b = No interrupt pending 1b = Interrupt pending | | 0 | LCDFRMIFG | RW | Oh | LCD frame interrupt flag. Automatically cleared when data is written into a memory register. 0b = No interrupt pending 1b = Interrupt pending | ### 17.3.3 LCDBLKCTL Register LCD\_E Blink Control Register #### Figure 17-21. LCDBLKCTL Register #### Table 17-12. LCDBLKCTL Register Description | Bit | Field | Туре | Reset | Description | |------|------------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-5 | Reserved | R | 0h | | | 4-2 | LCDBLKPREx | RW | 0h | Clock prescaler for blinking frequency. Together with LCDMXx, the blinking frequency $f_{BLINK}$ is calculated as $f_{BLINK} = f_{LCD} / ((LCDMXx + 1) \times 2^{(LCDBLKPREx + 2)})$ . Settings for LCDMXx and LCDBLKPREx should only be changed while LCDBLKMODx = 00. 000b = Divide by 4 | | | | | | 001b = Divide by 8 | | | | | | 010b = Divide by 16 | | | | | | 011b = Divide by 32 | | | | | | 100b = Divide by 64 | | | | | | 101b = Divide by 128 | | | | | | 110b = Divide by 256 | | | | | | 111b = Divide by 512 | | 1-0 | LCDBLKMODx | RW | 0h | Blinking mode | | | | | | 00b = Blinking disabled. | | | | | | 01b = Blinking of individual segments as enabled in blinking memory register LCDBMx. In mux mode >5 blinking is disabled. | | | | | | 10b = Blinking of all segments | | | | | | 11b = Switching between display contents as stored in LCDMx and LCDBMx memory registers. In mux mode >5 blinking is disabled. | ### 17.3.4 LCDMEMCTL Register LCD\_E Memory Control Register #### Figure 17-22. LCDMEMCTL Register #### Table 17-13. LCDMEMCTL Register Description | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-3 | Reserved | R | 0h | Reserved | | 2 | LCDCLRBM | RW | 0h | Clear LCD blinking memory | | | | | | Clears all blinking memory registers LCDBMx. The bit is automatically reset when the blinking memory is cleared. | | | | | | Setting this bit in 5-mux mode and above has no effect. It is immediately reset again. | | | | | | 0b = Contents of blinking memory registers LCDBMx remain unchanged | | | | | | 1b = Clear content of all blinking memory registers LCDBMx | | 1 | LCDCLRM | RW | 0h | Clear LCD memory | | | | | | Clears all LCD memory registers LCDMx. The bit is automatically reset when the LCD memory is cleared. | | | | | | 0b = Contents of LCD memory registers LCDMx remain unchanged | | | | | | 1b = Clear content of all LCD memory registers LCDMx | | 0 | LCDDISP | RW | 0h | Select LCD memory registers for display | | | | | | When LCDBLKMODx = 00, LCDDISP can be set by software. | | | | | | The bit is cleared in LCDBLKMODx = 01 and LCDBLKMODx = 10 or if a mux mode ≥5 is selected and cannot be changed by software. | | | | | | When LCDBLKMODx = 11, this bit reflects the currently displayed memory but cannot be changed by software. When returning to LCDBLKMODx = 00 the bit is cleared. | | | | | | 0b = Display content of LCD memory registers LCDMx | | | | | | 1b = Display content of LCD blinking memory registers LCDBMx | #### 17.3.5 LCDVCTL Register LCD\_E Voltage Control Register #### Figure 17-23. LCDVCTL Register #### Table 17-14. LCDVCTL Register Description | Bit | Field | Туре | Reset | Description | |-------|------------|------|-------|-------------------------------------------------------------------------------------------------------------------------------| | 15-12 | LCDCPFSELx | RW | 0h | Charge pump frequency selection. Clock source can be XT1, ACLK, VLO (4-bit, if $f_{SOURCE} = f_{ACLK} = 32.768 \text{ kHz}$ ) | | | | | | 0000b = 32.768 kHz / 1 / 8 = 4.096 kHz | | | | | | 0001b = 32.768 kHz / 2 / 8 = 2.048 kHz | | | | | | 0010b = 32.768 kHz / 3 / 8 = 1.365 kHz | | | | | | 0011b = 32.768 kHz / 4 / 8 = 1.024 kHz | | | | | | 0100b = 32.768 kHz / 5 / 8 = 819 Hz | | | | | | 0101b = 32.768 kHz / 6 / 8 = 682 Hz | | | | | | 0110b = 32.768 kHz / 7 / 8 = 585 Hz | | | | | | 0111b = 32.768 kHz / 8 / 8 = 512 Hz | | | | | | 1000b = 32.768 kHz / 9 / 8 = 455 Hz | | | | | | 1001b = 32.768 kHz / 10 / 8 = 409 Hz | | | | | | 1010b = 32.768 kHz / 11 / 8 = 372 Hz | | | | | | 1011b = 32.768 kHz / 12 / 8 = 341 Hz | | | | | | 1100b = 32.768 kHz / 13 / 8 = 315 Hz | | | | | | 1101b = 32.768 kHz / 14 / 8 = 292 Hz | | | | | | 1110b = 32.768 kHz / 15 / 8 = 273 Hz | | | | | | 1111b = 32.768 kHz / 16 / 8 = 256 Hz | | 11-8 | VLCDx | RW | 0h | Internal reference voltage select on R13. Only valuable when LCDCPEN = 1 and LCDREFEN = 1. | | | | | | 0000b = 2.60 V | | | | | | 0001b = 2.66 V | | | | | | 0010b = 2.72 V | | | | | | 0011b = 2.78 V | | | | | | 0100b = 2.84 V | | | | | | 0101b = 2.90 V | | | | | | 0110b = 2.96 V | | | | | | 0111b = 3.02 V | | | | | | 1000b = 3.08 V | | | | | | 1001b = 3.14 V | | | | | | 1010b = 3.20 V | | | | | | 1011b = 3.26 V | | | | | | 1100b = 3.32 V | | | | | | 1101b = 3.38 V | | | | | | 1110b = 3.44 V | | | | | | 1111b = 3.50 V | | 7 | LCDCPEN | RW | 0h | Charge pump enable | | | | | | 0b = Charge pump disabled <sup>(1)</sup> | | | | | | 1b = Charge pump enabled when $V_{LCD}$ is generated internally (VLCDEXT = 0) and VLCDx > 0 or VLCDREFx > 0. | To use LCD, an external resistor divider must be connected to R13, R23, and R33. ### Table 17-14. LCDVCTL Register Description (continued) | Bit | Field | Туре | Reset | Description | |-----|------------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------| | 6 | LCDREFEN | RW | Oh | Internal reference voltage enable on R13 0b = Internal reference voltage disabled 1b = Internal reference voltage enabled | | 5 | LCDSELVDD | RW | Oh | Selects if R33 is supplied either from $V_{CC}$ internally or from charge pump 0b = R33 connected to external supply 1b = R33 internally connected to $V_{CC}$ | | 4-1 | Reserved | R | 0h | Reserved | | 0 | LCDREFMODE | RW | Oh | Selects whether R13 voltage is switched or in static mode 0b = Static mode 1b = Switched mode | ### 17.3.6 LCDPCTL0 Register LCD\_E Port Control Register 0 Settings for LCDSx should only be changed while LCDON = 0. #### Figure 17-24. LCDPCTL0 Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|--------|--------|--------|--------|--------|--------|--------| | LCDS15 | LCDS14 | LCDS13 | LCDS12 | LCDS11 | LCDS10 | LCDS9 | LCDS8 | | rw-{0} | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | LCDS7 | LCDS6 | LCDS5 | LCDS4 | LCDS3 | LCDS2 | LCDS1 | LCDS0 | | rw-{0} ### Table 17-15. LCDPCTL0 Register Description | Bit | Field | Туре | Reset | Description | |-----|--------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15 | LCDS15 | RW | Oh | LCD pin 15 enable. This bit affects only pins with multiplexed functions. Dedicated LCD pins are always LCD function. 0b = Multiplexed pins are port functions. 1b = Pins are LCD functions. | | 14 | LCDS14 | RW | Oh | LCD pin 14 enable. This bit affects only pins with multiplexed functions. Dedicated LCD pins are always LCD function. 0b = Multiplexed pins are port functions. 1b = Pins are LCD functions. | | 13 | LCDS13 | RW | Oh | LCD pin 13 enable. This bit affects only pins with multiplexed functions. Dedicated LCD pins are always LCD function. 0b = Multiplexed pins are port functions. 1b = Pins are LCD functions. | | 12 | LCDS12 | RW | Oh | LCD pin 12 enable. This bit affects only pins with multiplexed functions. Dedicated LCD pins are always LCD function. 0b = Multiplexed pins are port functions. 1b = Pins are LCD functions. | | 11 | LCDS11 | RW | Oh | LCD pin 11 enable. This bit affects only pins with multiplexed functions. Dedicated LCD pins are always LCD function. 0b = Multiplexed pins are port functions. 1b = Pins are LCD functions. | | 10 | LCDS10 | RW | Oh | LCD pin 10 enable. This bit affects only pins with multiplexed functions. Dedicated LCD pins are always LCD function. 0b = Multiplexed pins are port functions. 1b = Pins are LCD functions. | | 9 | LCDS9 | RW | Oh | LCD pin 9 enable. This bit affects only pins with multiplexed functions. Dedicated LCD pins are always LCD function. 0b = Multiplexed pins are port functions. 1b = Pins are LCD functions. | | 8 | LCDS8 | RW | Oh | LCD pin 8 enable. This bit affects only pins with multiplexed functions. Dedicated LCD pins are always LCD function. 0b = Multiplexed pins are port functions. 1b = Pins are LCD functions. | | 7 | LCDS7 | RW | Oh | LCD pin 7 enable. This bit affects only pins with multiplexed functions. Dedicated LCD pins are always LCD function. 0b = Multiplexed pins are port functions. 1b = Pins are LCD functions. | | 6 | LCDS6 | RW | Oh | LCD pin 6 enable. This bit affects only pins with multiplexed functions. Dedicated LCD pins are always LCD function. 0b = Multiplexed pins are port functions. 1b = Pins are LCD functions. | ### Table 17-15. LCDPCTL0 Register Description (continued) | Bit | Field | Туре | Reset | Description | |-----|-------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 5 | LCDS5 | RW | Oh | LCD pin 5 enable. This bit affects only pins with multiplexed functions. Dedicated LCD pins are always LCD function. 0b = Multiplexed pins are port functions. 1b = Pins are LCD functions. | | 4 | LCDS4 | RW | Oh | LCD pin 4 enable. This bit affects only pins with multiplexed functions. Dedicated LCD pins are always LCD function. 0b = Multiplexed pins are port functions. 1b = Pins are LCD functions. | | 3 | LCDS3 | RW | Oh | LCD pin 3 enable. This bit affects only pins with multiplexed functions. Dedicated LCD pins are always LCD function. 0b = Multiplexed pins are port functions. 1b = Pins are LCD functions. | | 2 | LCDS2 | RW | Oh | LCD pin 2 enable. This bit affects only pins with multiplexed functions. Dedicated LCD pins are always LCD function. 0b = Multiplexed pins are port functions. 1b = Pins are LCD functions. | | 1 | LCDS1 | RW | Oh | LCD pin 1 enable. This bit affects only pins with multiplexed functions. Dedicated LCD pins are always LCD function. 0b = Multiplexed pins are port functions. 1b = Pins are LCD functions. | | 0 | LCDS0 | RW | Oh | LCD pin 0 enable. This bit affects only pins with multiplexed functions. Dedicated LCD pins are always LCD function. 0b = Multiplexed pins are port functions. 1b = Pins are LCD functions. | ### 17.3.7 LCDPCTL1 Register LCD\_E Port Control Register 1 Settings for LCDSx should only be changed while LCDON = 0. #### Figure 17-25. LCDPCTL1 Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|--------|--------|--------|--------|--------|--------|--------| | LCDS31 | LCDS30 | LCDS29 | LCDS28 | LCDS27 | LCDS26 | LCDS25 | LCDS24 | | rw-{0} | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | LCDS23 | LCDS22 | LCDS21 | LCDS20 | LCDS19 | LCDS18 | LCDS17 | LCDS16 | | rw-{0} # Table 17-16. LCDPCTL1 Register Description | Bit | Field | Туре | Reset | Description | |-----|--------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15 | LCDS31 | RW | 0h | LCD pin 31 enable. This bit affects only pins with multiplexed functions. Dedicated LCD pins are always LCD function. 0b = Multiplexed pins are port functions. 1b = Pins are LCD functions. | | 14 | LCDS30 | RW | Oh | LCD pin 30 enable. This bit affects only pins with multiplexed functions. Dedicated LCD pins are always LCD function. 0b = Multiplexed pins are port functions. 1b = Pins are LCD functions. | | 13 | LCDS29 | RW | Oh | LCD pin 29 enable. This bit affects only pins with multiplexed functions. Dedicated LCD pins are always LCD function. 0b = Multiplexed pins are port functions. 1b = Pins are LCD functions. | | 12 | LCDS28 | RW | Oh | LCD pin 28 enable. This bit affects only pins with multiplexed functions. Dedicated LCD pins are always LCD function. 0b = Multiplexed pins are port functions. 1b = Pins are LCD functions. | | 11 | LCDS27 | RW | Oh | LCD pin 27 enable. This bit affects only pins with multiplexed functions. Dedicated LCD pins are always LCD function. 0b = Multiplexed pins are port functions. 1b = Pins are LCD functions. | | 10 | LCDS26 | RW | Oh | LCD pin 26 enable. This bit affects only pins with multiplexed functions. Dedicated LCD pins are always LCD function. 0b = Multiplexed pins are port functions. 1b = Pins are LCD functions. | | 9 | LCDS25 | RW | Oh | LCD pin 25 enable. This bit affects only pins with multiplexed functions. Dedicated LCD pins are always LCD function. 0b = Multiplexed pins are port functions. 1b = Pins are LCD functions. | | 8 | LCDS24 | RW | Oh | LCD pin 24 enable. This bit affects only pins with multiplexed functions. Dedicated LCD pins are always LCD function. 0b = Multiplexed pins are port functions. 1b = Pins are LCD functions. | | 7 | LCDS23 | RW | Oh | LCD segment line 23 enable. This bit affects only pins with multiplexed functions. Dedicated LCD pins are always LCD function. 0b = Multiplexed pins are port functions. 1b = Pins are LCD functions. | | 6 | LCDS22 | RW | Oh | LCD segment line 22 enable. This bit affects only pins with multiplexed functions. Dedicated LCD pins are always LCD function. 0b = Multiplexed pins are port functions. 1b = Pins are LCD functions. | ### Table 17-16. LCDPCTL1 Register Description (continued) | Bit | Field | Туре | Reset | Description | |-----|--------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 5 | LCDS21 | RW | Oh | LCD segment line 21 enable. This bit affects only pins with multiplexed functions. Dedicated LCD pins are always LCD function. 0b = Multiplexed pins are port functions. 1b = Pins are LCD functions. | | 4 | LCDS20 | RW | Oh | LCD segment line 20 enable. This bit affects only pins with multiplexed functions. Dedicated LCD pins are always LCD function. 0b = Multiplexed pins are port functions. 1b = Pins are LCD functions. | | 3 | LCDS19 | RW | Oh | LCD segment line 19 enable. This bit affects only pins with multiplexed functions. Dedicated LCD pins are always LCD function. 0b = Multiplexed pins are port functions. 1b = Pins are LCD functions. | | 2 | LCDS18 | RW | Oh | LCD segment line 18 enable. This bit affects only pins with multiplexed functions. Dedicated LCD pins are always LCD function. 0b = Multiplexed pins are port functions. 1b = Pins are LCD functions. | | 1 | LCDS17 | RW | Oh | LCD segment line 17 enable. This bit affects only pins with multiplexed functions. Dedicated LCD pins are always LCD function. 0b = Multiplexed pins are port functions. 1b = Pins are LCD functions. | | 0 | LCDS16 | RW | Oh | LCD segment line 16 enable. This bit affects only pins with multiplexed functions. Dedicated LCD pins are always LCD function. 0b = Multiplexed pins are port functions. 1b = Pins are LCD functions. | ### 17.3.8 LCDPCTL2 Register LCD\_E Port Control Register 2 (= 256 Segments) Settings for LCDSx should only be changed while LCDON = 0. #### Figure 17-26. LCDPCTL2 Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|--------|--------|--------|--------|--------|--------|--------| | LCDS47 | LCDS46 | LCDS45 | LCDS44 | LCDS43 | LCDS42 | LCDS41 | LCDS40 | | rw-{0} | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | LCDS39 | LCDS38 | LCDS37 | LCDS36 | LCDS35 | LCDS34 | LCDS33 | LCDS32 | | rw-{0} ### Table 17-17. LCDPCTL2 Register Description | Bit | Field | Туре | Reset | Description | |-----|--------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15 | LCDS47 | RW | Oh | LCD pin 47 enable. This bit affects only pins with multiplexed functions. Dedicated LCD pins are always LCD function. 0b = Multiplexed pins are port functions. 1b = Pins are LCD functions. | | 14 | LCDS46 | RW | Oh | LCD pin 46 enable. This bit affects only pins with multiplexed functions. Dedicated LCD pins are always LCD function. 0b = Multiplexed pins are port functions. 1b = Pins are LCD functions. | | 13 | LCDS45 | RW | Oh | LCD pin 45 enable. This bit affects only pins with multiplexed functions. Dedicated LCD pins are always LCD function. 0b = Multiplexed pins are port functions. 1b = Pins are LCD functions. | | 12 | LCDS44 | RW | Oh | LCD pin 44 enable. This bit affects only pins with multiplexed functions. Dedicated LCD pins are always LCD function. 0b = Multiplexed pins are port functions. 1b = Pins are LCD functions. | | 11 | LCDS43 | RW | Oh | LCD pin 43 enable. This bit affects only pins with multiplexed functions. Dedicated LCD pins are always LCD function. 0b = Multiplexed pins are port functions. 1b = Pins are LCD functions. | | 10 | LCDS42 | RW | Oh | LCD pin 42 enable. This bit affects only pins with multiplexed functions. Dedicated LCD pins are always LCD function. 0b = Multiplexed pins are port functions. 1b = Pins are LCD functions. | | 9 | LCDS41 | RW | Oh | LCD pin 41 enable. This bit affects only pins with multiplexed functions. Dedicated LCD pins are always LCD function. 0b = Multiplexed pins are port functions. 1b = Pins are LCD functions. | | 8 | LCDS40 | RW | Oh | LCD pin 40 enable. This bit affects only pins with multiplexed functions. Dedicated LCD pins are always LCD function. 0b = Multiplexed pins are port functions. 1b = Pins are LCD functions. | | 7 | LCDS39 | RW | Oh | LCD pin 39 enable. This bit affects only pins with multiplexed functions. Dedicated LCD pins are always LCD function. 0b = Multiplexed pins are port functions. 1b = Pins are LCD functions. | | 6 | LCDS38 | RW | Oh | LCD pin 38 enable. This bit affects only pins with multiplexed functions. Dedicated LCD pins are always LCD function. 0b = Multiplexed pins are port functions. 1b = Pins are LCD functions. | ### Table 17-17. LCDPCTL2 Register Description (continued) | Bit | Field | Туре | Reset | Description | |-----|--------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 5 | LCDS37 | RW | Oh | LCD pin 37 enable. This bit affects only pins with multiplexed functions. Dedicated LCD pins are always LCD function. 0b = Multiplexed pins are port functions. 1b = Pins are LCD functions. | | 4 | LCDS36 | RW | Oh | LCD pin 36 enable. This bit affects only pins with multiplexed functions. Dedicated LCD pins are always LCD function. 0b = Multiplexed pins are port functions. 1b = Pins are LCD functions. | | 3 | LCDS35 | RW | Oh | LCD pin 35 enable. This bit affects only pins with multiplexed functions. Dedicated LCD pins are always LCD function. 0b = Multiplexed pins are port functions. 1b = Pins are LCD functions. | | 2 | LCDS34 | RW | Oh | LCD pin 34 enable. This bit affects only pins with multiplexed functions. Dedicated LCD pins are always LCD function. 0b = Multiplexed pins are port functions. 1b = Pins are LCD functions. | | 1 | LCDS33 | RW | Oh | LCD pin 33 enable. This bit affects only pins with multiplexed functions. Dedicated LCD pins are always LCD function. 0b = Multiplexed pins are port functions. 1b = Pins are LCD functions. | | 0 | LCDS32 | RW | Oh | LCD pin 32 enable. This bit affects only pins with multiplexed functions. Dedicated LCD pins are always LCD function. 0b = Multiplexed pins are port functions. 1b = Pins are LCD functions. | #### 17.3.9 LCDPCTL3 Register LCD\_E Port Control Register 3 (384 Segments, COMs Shared With Segments) Settings for LCDSx should only be changed while LCDON = 0. #### Figure 17-27. LCDPCTL3 Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|--------|--------|--------|--------|--------|--------|--------| | LCDS63 | LCDS62 | LCDS61 | LCDS60 | LCDS59 | LCDS58 | LCDS57 | LCDS56 | | rw-{0} | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | LCDS55 | LCDS54 | LCDS53 | LCDS52 | LCDS51 | LCDS50 | LCDS49 | LCDS48 | | rw-{0} ### Table 17-18. LCDPCTL3 Register Description | Bit | Field | Туре | Reset | Description | |-----|--------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15 | LCDS63 | RW | Oh | LCD pin 63 enable. This bit affects only pins with multiplexed functions. Dedicated LCD pins are always LCD function. 0b = Multiplexed pins are port functions. 1b = Pins are LCD functions. | | 14 | LCDS62 | RW | Oh | LCD pin 62 enable. This bit affects only pins with multiplexed functions. Dedicated LCD pins are always LCD function. 0b = Multiplexed pins are port functions. 1b = Pins are LCD functions. | | 13 | LCDS61 | RW | Oh | LCD pin 61 enable. This bit affects only pins with multiplexed functions. Dedicated LCD pins are always LCD function. 0b = Multiplexed pins are port functions. 1b = Pins are LCD functions. | | 12 | LCDS60 | RW | Oh | LCD pin 60 enable. This bit affects only pins with multiplexed functions. Dedicated LCD pins are always LCD function. 0b = Multiplexed pins are port functions. 1b = Pins are LCD functions. | | 11 | LCDS59 | RW | Oh | LCD pin 59 enable. This bit affects only pins with multiplexed functions. Dedicated LCD pins are always LCD function. 0b = Multiplexed pins are port functions. 1b = Pins are LCD functions. | | 10 | LCDS58 | RW | Oh | LCD pin 58 enable. This bit affects only pins with multiplexed functions. Dedicated LCD pins are always LCD function. 0b = Multiplexed pins are port functions. 1b = Pins are LCD functions. | | 9 | LCDS57 | RW | Oh | LCD pin 57 enable. This bit affects only pins with multiplexed functions. Dedicated LCD pins are always LCD function. 0b = Multiplexed pins are port functions. 1b = Pins are LCD functions. | | 8 | LCDS56 | RW | Oh | LCD pin 56 enable. This bit affects only pins with multiplexed functions. Dedicated LCD pins are always LCD function. 0b = Multiplexed pins are port functions. 1b = Pins are LCD functions. | | 7 | LCDS55 | RW | Oh | LCD pin 55 enable. This bit affects only pins with multiplexed functions. Dedicated LCD pins are always LCD function. 0b = Multiplexed pins are port functions. 1b = Pins are LCD functions. | | 6 | LCDS54 | RW | Oh | LCD pin 54 enable. This bit affects only pins with multiplexed functions. Dedicated LCD pins are always LCD function. 0b = Multiplexed pins are port functions. 1b = Pins are LCD functions. | ### Table 17-18. LCDPCTL3 Register Description (continued) | Bit | Field | Туре | Reset | Description | |-----|--------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 5 | LCDS53 | RW | Oh | LCD pin 53 enable. This bit affects only pins with multiplexed functions. Dedicated LCD pins are always LCD function. 0b = Multiplexed pins are port functions. 1b = Pins are LCD functions. | | 4 | LCDS52 | RW | Oh | LCD pin 52 enable. This bit affects only pins with multiplexed functions. Dedicated LCD pins are always LCD function. 0b = Multiplexed pins are port functions. 1b = Pins are LCD functions. | | 3 | LCDS51 | RW | Oh | LCD pin 51 enable. This bit affects only pins with multiplexed functions. Dedicated LCD pins are always LCD function. 0b = Multiplexed pins are port functions. 1b = Pins are LCD functions. | | 2 | LCDS50 | RW | Oh | LCD pin 50 enable. This bit affects only pins with multiplexed functions. Dedicated LCD pins are always LCD function. 0b = Multiplexed pins are port functions. 1b = Pins are LCD functions. | | 1 | LCDS49 | RW | Oh | LCD pin 49 enable. This bit affects only pins with multiplexed functions. Dedicated LCD pins are always LCD function. 0b = Multiplexed pins are port functions. 1b = Pins are LCD functions. | | 0 | LCDS48 | RW | Oh | LCD pin 48 enable. This bit affects only pins with multiplexed functions. Dedicated LCD pins are always LCD function. 0b = Multiplexed pins are port functions. 1b = Pins are LCD functions. | ### 17.3.10 LCDCSSEL0 Register LCD\_E COM/SEG Select Register 0 #### Figure 17-28. LCDCSSEL0 Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------|----------|----------|----------|----------|----------|---------|---------| | LCDCSS15 | LCDCSS14 | LCDCSS13 | LCDCSS12 | LCDCSS11 | LCDCSS10 | LCDCSS9 | LCDCSS8 | | rw-{0} | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | LCDCSS7 | LCDCSS6 | LCDCSS5 | LCDCSS4 | LCDCSS3 | LCDCSS2 | LCDCSS1 | LCDCSS0 | | | 202000 | 202000 | 2020001 | | | | | ### Table 17-19. LCDCSSEL0 Register Description | Bit | Field | Туре | Reset | Description | |-----|----------|------|-------|----------------------------------------------------------------------------------------| | 15 | LCDCSS15 | RW | 0h | Selects pin L15 as either common or segment line. 0b = Segment line 1b = Common line | | 14 | LCDCSS14 | RW | Oh | Selects pin L14 as either common or segment line. 0b = Segment line 1b = Common line | | 13 | LCDCSS13 | RW | 0h | Selects pin L13 as either common or segment line. 0b = Segment line 1b = Common line | | 12 | LCDCSS12 | RW | 0h | Selects pin L12 as either common or segment line. 0b = Segment line 1b = Common line | | 11 | LCDCSS11 | RW | Oh | Selects pin L11 as either common or segment line. 0b = Segment line 1b = Common line | | 10 | LCDCSS10 | RW | 0h | Selects pin L10 as either common or segment line. 0b = Segment line 1b = Common line | | 9 | LCDCSS9 | RW | Oh | Selects pin L9 as either common or segment line. 0b = Segment line 1b = Common line | | 8 | LCDCSS8 | RW | Oh | Selects pin L8 as either common or segment line. 0b = Segment line 1b = Common line | | 7 | LCDCSS7 | RW | Oh | Selects pin L7 as either common or segment line. 0b = Segment line 1b = Common line | | 6 | LCDCSS6 | RW | 0h | Selects pin L6 as either common or segment line. 0b = Segment line 1b = Common line | | 5 | LCDCSS5 | RW | Oh | Selects pin L5 as either common or segment line. 0b = Segment line 1b = Common line | | 4 | LCDCSS4 | RW | Oh | Selects pin L4 as either common or segment line. 0b = Segment line 1b = Common line | | 3 | LCDCSS3 | RW | Oh | Selects pin L3 as either common or segment line. 0b = Segment line 1b = Common line | ### Table 17-19. LCDCSSEL0 Register Description (continued) | Bit | Field | Туре | Reset | Description | |-----|---------|------|-------|---------------------------------------------------------------------------------------| | 2 | LCDCSS2 | RW | Oh | Selects pin L2 as either common or segment line. 0b = Segment line 1b = Common line | | 1 | LCDCSS1 | RW | Oh | Selects pin L1 as either common or segment line. 0b = Segment line 1b = Common line | | 0 | LCDCSS0 | RW | Oh | Selects pin L0 as either common or segment line. 0b = Segment line 1b = Common line | ### 17.3.11 LCDCSSEL1 Register LCD\_E COM/SEG Select Register 1 #### Figure 17-29. LCDCSSEL1 Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------|----------|----------|----------|----------|----------|----------|----------| | LCDCSS31 | LCDCSS30 | LCDCSS29 | LCDCSS28 | LCDCSS27 | LCDCSS26 | LCDCSS25 | LCDCSS24 | | rw-{0} | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | LCDCSS23 | LCDCSS22 | LCDCSS21 | LCDCSS20 | LCDCSS19 | LCDCSS18 | LCDCSS17 | LCDCSS16 | | rw-{0} ### Table 17-20. LCDCSSEL1 Register Description | Bit | Field | Туре | Reset | Description | |-----|----------|------|-------|----------------------------------------------------------------------------------------| | 15 | LCDCSS31 | RW | 0h | Selects pin L31 as either common or segment line. 0b = Segment line 1b = Common line | | 14 | LCDCSS30 | RW | Oh | Selects pin L30 as either common or segment line. 0b = Segment line 1b = Common line | | 13 | LCDCSS29 | RW | 0h | Selects pin L29 as either common or segment line. 0b = Segment line 1b = Common line | | 12 | LCDCSS28 | RW | 0h | Selects pin L28 as either common or segment line. 0b = Segment line 1b = Common line | | 11 | LCDCSS27 | RW | Oh | Selects pin L27 as either common or segment line. 0b = Segment line 1b = Common line | | 10 | LCDCSS26 | RW | 0h | Selects pin L26 as either common or segment line. 0b = Segment line 1b = Common line | | 9 | LCDCSS25 | RW | 0h | Selects pin L25 as either common or segment line. 0b = Segment line 1b = Common line | | 8 | LCDCSS24 | RW | 0h | Selects pin L24 as either common or segment line. 0b = Segment line 1b = Common line | | 7 | LCDCSS23 | RW | Oh | Selects pin L23 as either common or segment line. 0b = Segment line 1b = Common line | | 6 | LCDCSS22 | RW | Oh | Selects pin L22 as either common or segment line. 0b = Segment line 1b = Common line | | 5 | LCDCSS21 | RW | 0h | Selects pin L21 as either common or segment line. 0b = Segment line 1b = Common line | | 4 | LCDCSS20 | RW | Oh | Selects pin L20 as either common or segment line. 0b = Segment line 1b = Common line | | 3 | LCDCSS19 | RW | Oh | Selects pin L19 as either common or segment line. 0b = Segment line 1b = Common line | ### Table 17-20. LCDCSSEL1 Register Description (continued) | Bit | Field | Туре | Reset | Description | |-----|----------|------|-------|----------------------------------------------------------------------------------------| | 2 | LCDCSS18 | RW | Oh | Selects pin L18 as either common or segment line. 0b = Segment line 1b = Common line | | 1 | LCDCSS17 | RW | Oh | Selects pin L17 as either common or segment line. 0b = Segment line 1b = Common line | | 0 | LCDCSS16 | RW | Oh | Selects pin L16 as either common or segment line. 0b = Segment line 1b = Common line | ### 17.3.12 LCDCSSEL2 Register LCD\_E COM/SEG Select Register 0 #### Figure 17-30. LCDCSSEL2 Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------|----------|----------|----------|----------|----------|----------|----------| | LCDCSS47 | LCDCSS46 | LCDCSS45 | LCDCSS44 | LCDCSS43 | LCDCSS42 | LCDCSS41 | LCDCSS40 | | rw-{0} | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | | | LCDCSS39 | LCDCSS38 | LCDCSS37 | LCDCSS36 | LCDCSS35 | LCDCSS34 | LCDCSS33 | LCDCSS32 | ### Table 17-21. LCDCSSEL2 Register Description | Bit | Field | Туре | Reset | Description | |-----|----------|------|-------|----------------------------------------------------------------------------------------| | 15 | LCDCSS47 | RW | Oh | Selects pin L47 as either common or segment line. 0b = Segment line 1b = Common line | | 14 | LCDCSS46 | RW | Oh | Selects pin L46 as either common or segment line. 0b = Segment line 1b = Common line | | 13 | LCDCSS45 | RW | Oh | Selects pin L45 as either common or segment line. 0b = Segment line 1b = Common line | | 12 | LCDCSS44 | RW | Oh | Selects pin L44 as either common or segment line. 0b = Segment line 1b = Common line | | 11 | LCDCSS43 | RW | Oh | Selects pin L43 as either common or segment line. 0b = Segment line 1b = Common line | | 10 | LCDCSS42 | RW | Oh | Selects pin L42 as either common or segment line. 0b = Segment line 1b = Common line | | 9 | LCDCSS41 | RW | Oh | Selects pin L41 as either common or segment line. 0b = Segment line 1b = Common line | | 8 | LCDCSS40 | RW | 0h | Selects pin L40 as either common or segment line. 0b = Segment line 1b = Common line | | 7 | LCDCSS39 | RW | Oh | Selects pin L39 as either common or segment line. 0b = Segment line 1b = Common line | | 6 | LCDCSS38 | RW | Oh | Selects pin L38 as either common or segment line. 0b = Segment line 1b = Common line | | 5 | LCDCSS37 | RW | Oh | Selects pin L37 as either common or segment line. 0b = Segment line 1b = Common line | | 4 | LCDCSS36 | RW | Oh | Selects pin L36 as either common or segment line. 0b = Segment line 1b = Common line | | 3 | LCDCSS35 | RW | Oh | Selects pin L35 as either common or segment line. 0b = Segment line 1b = Common line | ### Table 17-21. LCDCSSEL2 Register Description (continued) | Bit | Field | Туре | Reset | Description | |-----|----------|------|-------|----------------------------------------------------------------------------------------| | 2 | LCDCSS34 | RW | Oh | Selects pin L34 as either common or segment line. 0b = Segment line 1b = Common line | | 1 | LCDCSS33 | RW | Oh | Selects pin L33 as either common or segment line. 0b = Segment line 1b = Common line | | 0 | LCDCSS32 | RW | Oh | Selects pin L32 as either common or segment line. 0b = Segment line 1b = Common line | ### 17.3.13 LCDCSSEL3 Register LCD\_E COM/SEG Select Register 0 #### Figure 17-31. LCDCSSEL3 Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------|----------|----------|----------|----------|----------|----------|----------| | LCDCSS63 | LCDCSS62 | LCDCSS61 | LCDCSS60 | LCDCSS59 | LCDCSS58 | LCDCSS57 | LCDCSS56 | | rw-{0} | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | LCDCSS55 | LCDCSS54 | LCDCSS53 | LCDCSS52 | LCDCSS51 | LCDCSS50 | LCDCSS49 | LCDCSS48 | | | | | | | | | | ### Table 17-22. LCDCSSEL3 Register Description | Bit | Field | Туре | Reset | Description | |-----|----------|------|-------|----------------------------------------------------------------------------------------| | 15 | LCDCSS63 | RW | Oh | Selects pin L63 as either common or segment line. 0b = Segment line 1b = Common line | | 14 | LCDCSS62 | RW | Oh | Selects pin L62 as either common or segment line. 0b = Segment line 1b = Common line | | 13 | LCDCSS61 | RW | Oh | Selects pin L61 as either common or segment line. 0b = Segment line 1b = Common line | | 12 | LCDCSS60 | RW | Oh | Selects pin L60 as either common or segment line. 0b = Segment line 1b = Common line | | 11 | LCDCSS59 | RW | Oh | Selects pin L59 as either common or segment line. 0b = Segment line 1b = Common line | | 10 | LCDCSS58 | RW | Oh | Selects pin L58 as either common or segment line. 0b = Segment line 1b = Common line | | 9 | LCDCSS57 | RW | Oh | Selects pin L57 as either common or segment line. 0b = Segment line 1b = Common line | | 8 | LCDCSS56 | RW | 0h | Selects pin L56 as either common or segment line. 0b = Segment line 1b = Common line | | 7 | LCDCSS55 | RW | Oh | Selects pin L55 as either common or segment line. 0b = Segment line 1b = Common line | | 6 | LCDCSS54 | RW | Oh | Selects pin L54 as either common or segment line. 0b = Segment line 1b = Common line | | 5 | LCDCSS53 | RW | Oh | Selects pin L53 as either common or segment line. 0b = Segment line 1b = Common line | | 4 | LCDCSS52 | RW | Oh | Selects pin L52 as either common or segment line. 0b = Segment line 1b = Common line | | 3 | LCDCSS51 | RW | Oh | Selects pin L51 as either common or segment line. 0b = Segment line 1b = Common line | ### Table 17-22. LCDCSSEL3 Register Description (continued) | Bit | Field | Туре | Reset | Description | |-----|----------|------|-------|----------------------------------------------------------------------------------------| | 2 | LCDCSS50 | RW | 0h | Selects pin L50 as either common or segment line. 0b = Segment line 1b = Common line | | 1 | LCDCSS49 | RW | Oh | Selects pin L49 as either common or segment line. 0b = Segment line 1b = Common line | | 0 | LCDCSS48 | RW | Oh | Selects pin L48 as either common or segment line. 0b = Segment line 1b = Common line | ### 17.3.14 LCDM[index] Register - Static, 2-Mux, 3-Mux, 4-Mux Mode LCD\_E Memory [index] Register For Static, 2-Mux, 3-Mux, 4-Mux Mode: index = 0 to 31 #### Figure 17-32. LCDM[index] Register | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|--------|--------|--------|--------|--------|--------|--------| | MBIT7 | MBIT6 | MBIT5 | MBIT4 | MBIT3 | MBIT2 | MBIT1 | MBIT0 | | rw-{0} #### Table 17-23. LCDM[index] Register Description | Bit | Field | Туре | Reset | Description | |-----|-------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | МВІТ7 | RW | Oh | If LCD pin L[2*index+1] is selected as segment line (LCDCSS[2*index+1] = 0b) and LCD mux rate is 4-mux (LCDMXx=011b): 0b = LCD segment off 1b = LCD segment on If LCD pin L[2*index+1] is selected as common line (LCDCSS[2*index+1] = 1b): 0b = Pin L[2*index+1] not used as COM3 1b = Pin L[2*index+1] is used as COM3 | | 6 | MBIT6 | RW | Oh | If LCD pin L[2*index+1] is selected as segment line (LCDCSS[2*index+1] = 0b) and LCD mux rate is 3- or 4-mux (010b <= LCDMXx <= 011b): 0b = LCD segment off 1b = LCD segment on If LCD pin L[2*index+1] is selected as common line (LCDCSS[2*index+1] = 1b): 0b = Pin L[2*index+1] not used as COM2 1b = Pin L[2*index+1] is used as COM2 | | 5 | МВІТ5 | RW | Oh | If LCD pin L[2*index+1] is selected as segment line (LCDCSS[2*index+1] = 0b) and LCD mux rate is 2-, 3- or 4-mux (001b <= LCDMXx <= 011b): 0b = LCD segment off 1b = LCD segment on If LCD pin L[2*index+1] is selected as common line (LCDCSS[2*index+1] = 1b): 0b = Pin L[2*index+1] not used as COM1 1b = Pin L[2*index+1] is used as COM1 | | 4 | MBIT4 | RW | Oh | If LCD pin L[2*index+1] is selected as segment line (LCDCSS[2*index+1] = 0b) and LCD mux rate is static, 2-, 3- or 4-mux (000b <= LCDMXx <= 011b) 0b = LCD segment off 1b = LCD segment on If LCD pin L[2*index+1] is selected as common line (LCDCSS[2*index+1] = 1b): 0b = Pin L[2*ndex+1] not used as COM0 1b = Pin L[2*ndex+1] is used as COM0 | | 3 | МВІТЗ | RW | Oh | If LCD pin L[index] is selected as segment line (LCDCSS[index] = 0b) and LCD mux rate is 4-mux (LCDMXx=011b): 0b = LCD segment off 1b = LCD segment on If LCD pin L[2*index] is selected as common line (LCDCSS[2*index] = 1b): 0b = Pin L[2*index] not used as COM3 1b = Pin L[2*index] is used as COM3 | | 2 | MBIT2 | RW | Oh | If LCD pin L[2*index] is selected as segment line (LCDCSS[2*index] = 0b) and LCD mux rate is 3- or 4-mux (010b <= LCDMXx <= 011b): 0b = LCD segment off 1b = LCD segment on If LCD pin L[2*index] is selected as common line (LCDCSS[2*index] = 1b): 0b = Pin L[2*index] not used as COM2 1b = Pin L[2*index] is used as COM2 | ### Table 17-23. LCDM[index] Register Description (continued) | Bit | Field | Туре | Reset | Description | |-----|-------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------| | 1 | MBIT1 | RW | 0h | If LCD pin L[2*index] is selected as segment line (LCDCSS[2*index] = 0b) and LCD mux rate is 2-, 3- or 4-mux (001b <= LCDMXx <= 011b): | | | | | | 0b = LCD segment off | | | | | | 1b = LCD segment on | | | | | | If LCD pin L[2*index] is selected as common line (LCDCSS[2*index] = 1b): | | | | | | 0b = Pin L[2*index] not used as COM1 | | | | | | 1b = Pin L[2*index] is used as COM1 | | 0 | MBIT0 | RW | 0h | If LCD L[2*index] is selected as segment line (LCDCSS[2*index] = 0b) and LCD mux rate is static, 2-, 3- or 4-mux (000b <= LCDMXx <= 011b) | | | | | | 0b = LCD segment off | | | | | | 1b = LCD segment on | | | | | | If LCD pin L[2*index] is selected as common line (LCDCSS[2*index] = 1b): | | | | | | 0b = Pin L[2*index] not used as COM0 | | | | | | 1b = Pin L[2*index] is used as COM0 | ### 17.3.15 LCDM[index] Register – 5-Mux, 6-Mux, 7-Mux, 8-Mux Mode LCD\_E Memory [index] Register 5-Mux, 6-Mux, 7-Mux, 8-Mux Mode: *index* = 0 to 63 #### Figure 17-33. LCDM[index] Register | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|--------|--------|--------|--------|--------|--------|--------| | MBIT7 | MBIT6 | MBIT5 | MBIT4 | MBIT3 | MBIT2 | MBIT1 | MBIT0 | | rw-{0} #### Table 17-24. LCDM[index] Register Description | Bit | Field | Туре | Reset | Description | |-----|-------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | MBIT7 | RW | Oh | If LCD pin L[index] is selected as segment line (LCDCSS[index] = 0b) and LCD mux rate is 8-mux (LCDMXx = 111b): 0b = LCD segment off 1b = LCD segment on If LCD pin L[index] is selected as common line (LCDCSS[index] = 1b): 0b = Pin L[index] not used as COM7 1b = Pin L[index] is used as COM7 | | 6 | MBIT6 | RW | Oh | If LCD pin L[index] is selected as segment line (LCDCSS[index] = 0b) and LCD mux rate is 7- or 8-mux (LCDMXx >= 110b): 0b = LCD segment off 1b = LCD segment on If LCD pin L[index] is selected as common line (LCDCSS[index] = 1b): 0b = Pin L[index] not used as COM6 1b = Pin L[index] is used as COM6 | | 5 | MBIT5 | RW | Oh | If LCD pin L[index] is selected as segment line (LCDCSS[index] = 0b) and LCD mux rate is 6-, 7- or 8-mux (LCDMXx >= 101b): 0b = LCD segment off 1b = LCD segment on If LCD pin L[index] is selected as common line (LCDCSS[index] = 1b): 0b = Pin L[index] not used as COM5 1b = Pin L[index] is used as COM5 | | 4 | MBIT4 | RW | Oh | If LCD pin L[index] is selected as segment line (LCDCSS[index] = 0b) and LCD mux rate is 5-, 6-, 7- or 8-mux (LCDMXx >= 100b): 0b = LCD segment off 1b = LCD segment on If LCD pin L[index] is selected as common line (LCDCSS[index] = 1b): 0b = Pin L[index] not used as COM4 1b = Pin L[index] is used as COM4 | | 3 | МВІТЗ | RW | Oh | If LCD pin L[index] is selected as segment line (LCDCSS[index] = 0b) and LCD mux rate is 5-, 6-, 7- or 8-mux (LCDMXx >= 100b): 0b = LCD segment off 1b = LCD segment on If LCD pin L[index] is selected as common line (LCDCSS[index] = 1b): 0b = Pin L[index] not used as COM3 1b = Pin L[index] is used as COM3 | | 2 | MBIT2 | RW | 0h | If LCD pin L[index] is selected as segment line (LCDCSS[index] = 0b) and LCD mux rate is 5-, 6-, 7- or 8-mux (LCDMXx >= 100b): 0b = LCD segment off 1b = LCD segment on If LCD pin L[index] is selected as common line (LCDCSS[index] = 1b): 0b = Pin L[index-1] not used as COM2 1b = Pin L[index-1] is used as COM2 | ### Table 17-24. LCDM[index] Register Description (continued) | Bit | Field | Туре | Reset | Description | |-----|-------|------|-------|--------------------------------------------------------------------------------------------------------------------------------| | 1 | MBIT1 | RW | 0h | If LCD pin L[index] is selected as segment line (LCDCSS[index] = 0b) and LCD mux rate is 5-, 6-, 7- or 8-mux (LCDMXx >= 100b): | | | | | | 0b = LCD segment off | | | | | | 1b = LCD segment on | | | | | | If LCD pin L[index] is selected as common line (LCDCSS[index] = 1b): | | | | | | 0b = Pin L[index] not used as COM1 | | | | | | 1b = Pin L[index] is used as COM1 | | 0 | MBIT0 | RW | 0h | If LCD pin L[index] is selected as segment line (LCDCSS[index] = 0b) and LCD mux rate is 5-, 6-, 7- or 8-mux (LCDMXx >= 100b): | | | | | | 0b = LCD segment off | | | | | | 1b = LCD segment on | | | | | | If LCD pin L[index] is selected as common line (LCDCSS[index] = 1b): | | | | | | 0b = Pin L[index] not used as COM0 | | | | | | 1b = Pin L[index] is used as COM0 | ### 17.3.16 LCDIV Register LCD\_E Interrupt Vector Register #### Figure 17-34. LCDIV Register #### Table 17-25. LCDIV Register Description | Bit | Field | Туре | Reset | Description | |------|--------|------|-------|--------------------------------------------------------------------------------------------------------| | 15-0 | LCDIVx | R | 0h | LCD_E interrupt vector value | | | | | | 00h = No interrupt pending | | | | | | 04h = Interrupt Source: Blink, segments off; Interrupt Flag: LCDBLKOFFIFG; Interrupt Priority: Highest | | | | | | 06h = Interrupt Source: Blink, segments on; Interrupt Flag: LCDBLKONIFG | | | | | | 08h = Interrupt Source: Frame interrupt; Interrupt Flag: LCDFRMIFG; Interrupt Priority: Lowest | # **Enhanced Comparator (eCOMP)** The Enhanced Comparator (eCOMP) module is an analog voltage comparator with an internal reference DAC. The eCOMP supports general comparator functionality for up to 7 channels including 4 external inputs, 2 internal inputs, and 1 for a reference DAC output. eCOMP also implements programmable hysteresis and configurable power modes. This chapter describes the eCOMP. Topic Page | 18.1 | eCOMP Introduction | 504 | |------|--------------------|-----| | 18.2 | eCOMP Operation | 505 | | | · | | | 18.3 | eCOMP Interrupts | 507 | | 18.4 | eCOMP Registers | 508 | | | | | eCOMP Introduction www.ti.com #### 18.1 eCOMP Introduction The eCOMP module supports precision slope analog-to-digital conversions, supply voltage supervision, and monitoring of external analog signals. #### Features of eCOMP include: - · Section from multiple input sources - Software-selectable analog low-pass filter for eCOMP output - Output provided to timer capture input - Interrupt capability - Integrate 6-bit DAC for eCOMP reference voltage input - Configurable high-power and low-power comparator modes - Programmable hysteresis mode - · Interrupt driven measurement system for low-power operation support Figure 18-1 shows the eCOMP block diagram. Figure 18-1. eCOMP Block Diagram www.ti.com eCOMP Operation ### 18.2 eCOMP Operation The eCOMP module is configured by user software. The eCOMP can operate in high-power (high speed) or low-power (low speed) mode according to the power mode selection. The eCOMP also supports different step hysteresis configurations for better comparison performance. #### 18.2.1 eCOMP The eCOMP compares the analog voltages at the positive (V+) and negative (V-) input terminals. If the V+ terminal is higher than the V- terminal, the eCOMP output CPOUT is high. The eCOMP output is connected to an optional analog low-pass filter and edge detection module for different trigger conditions. The eCOMP is enabled or disabled using control bit CPEN. The eCOMP output is controlled by CPEN bit. The bias current of the eCOMP has two programmable modes (CPMSEL bit): high-power mode (high speed) and low-power (low speed) mode. The eCOMP integrates a 6-bit DAC as the reference voltage input, and this DAC has a dual buffer and on-chip reference voltage selection features. #### 18.2.2 Analog Input Switches The analog input switches connect or disconnect the two comparator input terminals to associated pins using the CPPSEL and CPNSEL bits. The comparator terminal inputs can be controlled individually. The CPPSEL and CPNSEL bits allow: - Connect external signals to the V+ and V- terminals of the comparator. - Connect internal signals to the V+ and V- terminals of the comparator. - Connect an internal reference voltage from the built-in 6-bit DAC to the V+ or V- terminal of the comparator #### NOTE: eCOMP Input Connection When the eCOMP is on, the selected input terminals must be connected to a signal, power, or ground. Otherwise, floating levels can cause unexpected interrupts and increased current consumption. # 18.2.3 Output Analog Low-Pass Filter The output of the eCOMP can be used with an optional analog low-pass filter. When the control bit CPFLT is set, the output is filtered through an on-chip analog low-pass filter. The delay of the filter can be adjusted in four different steps (see Section 18.4.2 for details). All eCOMP outputs oscillate if the voltage difference across the input terminals is small. Internal and external parasitic effects and cross coupling on and between signal lines, power supply lines, and other parts of the system behave as shown in Figure 18-2. The eCOMP output oscillation reduces the accuracy and resolution of the comparison result. Selecting the output filter can reduce errors associated with eCOMP oscillation. Figure 18-2. Analog Filter Response at the Output of the eCOMP eCOMP Operation www.ti.com #### 18.2.4 eCOMP Built-in Dual Buffer 6-Bit DAC The eCOMP integrates a 6-bit DAC as the reference voltage input. This DAC has a dual buffer, on-chip reference voltage selection. The dual buffer can set different values to get two different DAC output voltages as the eCOMP reference input. This dual buffer strobe can be configured by either hardware or software. In hardware mode, the buffer is controlled by the comparator output. In software mode, the buffer is controlled by the CPDACSW bit. The DAC reference voltage can be sourced from VDD or on-chip VREF using control bit CPDACREFS. Figure 18-3 shows the eCOMP built-in 6-bit DAC overview block diagram. Figure 18-3. 6-bit eCOMP Built-in DAC Overview Block Diagram #### 18.2.4.1 eCOMP Built-in DAC Reference Voltage Selection The DAC reference voltage can be selected from two sources, the on-chip VREF (1.5 V) or VDD, using the control bit CPDACREFS. See Section 18.4.5 for details. #### 18.2.4.2 eCOMP Built-in DAC Output The DAC output is enabled or disabled using control bit CPDACEN. When disabled, the DAC always outputs low. The DAC output can be set in 64 steps from zero to (full range – 1 LSB of reference voltage). See Section 18.4.6 for details. The dual buffer setting can output two voltages, COMPREF0 or COMPREF1, which correspond to CPDACBUF1 and CPDACBUF2, respectively. See Section 18.4.5 for details. Figure 18-4 shows the eCOMP built-in 6-bit DAC detail block diagram. www.ti.com eCOMP Interrupts Figure 18-4. 6-Bit eCOMP Built-in DAC Block Diagram #### 18.3 eCOMP Interrupts Two interrupt flags and one interrupt vector are associated with the eCOMP. The following three modes can trigger an interrupt: - Noninverted edge - Inverted edge - Dual edge (either rising or falling edge can trigger an interrupt) Each trigger mode can be configured as follows: - · Noninverted edge mode is selected by CPIE bit. - Inverted edge mode is selected by CPIIE bit. - Dual-edge mode is selected by both CPIE and CPIIE bits. The interrupt flag CPIFG is set on a noninverted edge of the eCOMP output. The interrupt flag CPIIFG is set on an inverted edge of the eCOMP output. The noninverted and inverted interrupt can be exchanged by the CPIES bit, at the same time the corresponding flag is also exchanged (see Section 18.4.2). eCOMP Registers www.ti.com # 18.4 eCOMP Registers Table 18-1 lists the eCOMP registers. See the device-specific data sheet for the base address of the eCOMP module. Table 18-1. eCOMP Registers | Offset | Acronym | Register Name | Туре | Access | Reset | Section | |--------|------------|----------------------------|------------|--------|-------|----------------| | 00h | CPxCTL0 | eCOMP control 0 | Read/write | Word | 0100h | Section 18.4.1 | | 02h | CPxCTL1 | eCOMP control 1 | Read/write | Word | 0000h | Section 18.4.2 | | 06h | CPxINT | eCOMP interrupt | Read/write | Word | 0000h | Section 18.4.3 | | 08h | CPxIV | eCOMP interrupt vector | Read | Word | 0000h | Section 18.4.4 | | 10h | CPxDACCTL | eCOMP built-in DAC control | Read/write | Word | 0002h | Section 18.4.5 | | 12h | CPxDACDATA | eCOMP built-in DAC data | Read/write | Word | 0100h | Section 18.4.6 | www.ti.com eCOMP Registers # 18.4.1 CPxCTL0 Register (offset = 00h) [reset = 0100h] eCOMP Control Register 0 # Figure 18-5. CPxCTL0 Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |-----|----------|-----|-------|----------|------|--------|------| | | Reserved | | CPNEN | Reserved | | CPNSEL | | | r-0 | r-0 | r-0 | rw-0 | r-0 | rw-0 | rw-0 | rw-1 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | Reserved | | CPPEN | Reserved | | CPPSEL | | | r-0 | r-0 | r-0 | rw-0 | r-0 | rw-0 | rw-0 | rw-0 | # Table 18-2. CPxCTL0 Register Field Description | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-13 | Reserved | R | 0h | Reserved. Reads as 0. | | 12 | CPNEN | RW | 0h | Channel input enable for the V- terminal of the eCOMP. 0b = Selected analog input channel for V- terminal is disabled. 1b = Selected analog input channel for V- terminal is enabled. | | 11 | Reserved | R | 0h | Reserved. Reads as 0. | | 10-8 | CPNSEL | RW | 1h | Channel input selected for the V- terminal of the eCOMP. 000b-001b = Select external input source 010b-101b = Device specific, see the device-specific data sheet for details 110b = 6-bit DAC 111b = Reserved | | 7-5 | Reserved | R | 0h | Reserved. Reads as 0. | | 4 | CPPEN | RW | 0h | Channel input enable for the V+ terminal of the eCOMP. 0b = Selected analog input channel for V+ terminal is disabled. 1b = Selected analog input channel for V+ terminal is enabled. | | 3 | Reserved | R | 0h | Reserved. Reads as 0. | | 2-0 | CPPSEL | RW | 0h | Channel input selected for the V+ terminal of the eCOMP 000b-001b = Select external input source 010b-101b = Device specific, see the device-specific data sheet for details. 110b = 6-bit DAC 111b = Reserved | eCOMP Registers www.ti.com # 18.4.2 *CPxCTL1* Register (offset = 02h) [reset = 0000h] eCOMP Control Register 1 # Figure 18-6. CPxCTL1 Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |-------|------|-------|-------|------|-------|-------|--------| | CPIIE | CPIE | Rese | erved | CPH | SEL | CPEN | CPMSEL | | rw-0 | rw-0 | r-0 | r-0 | rw-0 | rw-0 | rw-0 | rw-0 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | CPFL | TDLY | CPFLT | CPIES | Rese | erved | CPINV | CPOUT | | rw-0 | rw-0 | rw-0 | rw-0 | r-0 | r-0 | rw-0 | r-0 | # Table 18-3. CPxCTL1 Register Field Description | Bit | Field | Туре | Reset | Description | | | | |-------------------|----------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | 15 <sup>(1)</sup> | CPIIE | RW | 0h | eCOMP inverted interrupt output enable bit 0b = Interrupt inverted output is disabled 1b = Interrupt inverted output is enabled | | | | | 14 <sup>(1)</sup> | CPIE | RW | 0h | eCOMP interrupt output enable bit 0b = Interrupt output is disabled 1b = Interrupt output is enabled | | | | | 13-12 | Reserved | R | 0h | Reads as 0. | | | | | 11-10 | CPHSEL | RW | 0h | 1/caus as 0. | | | | | 9 | CPEN | RW | Oh | eCOMP enable or disable. This bit is used to disable or enable the eCOMP. When the eCOMP is disabled, the eCOMP consumes no power. 0b = eCOMP is disabled 1b = eCOMP is enabled | | | | | 8 | CPMSEL | RW | Oh | Power mode selection. 0b = High-power and high-speed mode 1b = Low-power and low-speed mode | | | | | 7-6 | CPFLTDLY | RW | 0h | Analog filter delay selection. These bits are used to select the analog filter delay. (2) 00b = Typical filter delay of 450 ns 01b = Typical filter delay of 900 ns 10b = Typical filter delay of 1800 ns 11b = Typical filter delay of 3600 ns | | | | | 5 | CPFLT | RW | 0h | Analog output low-pass filter selection. Changing CPFLT might set interrupt flag. 0b = eCOMP output is not filtered 1b = eCOMP output is filtered | | | | | 4 | CPIES | RW | Oh | Interrupt edge select for CPIIFG and CPIFG. Changing CPIES might set interrupt flag. 0b = Rising edge for CPIFG, falling edge for CPIIFG 1b = Falling edge for CPIFG, rising edge for CPIIFG | | | | | 3-2 | Reserved | R | 0h | Reads as 0. | | | | | 1 | CPINV | RW | Oh | eCOMP output polarity control. This bit defines the eCOMP output polarity. 0b = eCOMP output is noninverted 1b = eCOMP output is inverted | | | | Both bit 15 and bit 14 must be asserted for dual-edge mode. The filter delay values are only valid in HP mode www.ti.com eCOMP Registers # Table 18-3. CPxCTL1 Register Field Description (continued) | Bit | Field | Туре | Reset | Description | |-----|-------|------|-------|--------------------------------------------------------------------------------------------------------------------------| | 0 | CPOUT | R | 0h | eCOMP output value. This bit reflects the value of the eCOMP output. Writing this bit has no effect on the eCOMP output. | # 18.4.3 *CPxINT* Register (offset = 06h) [reset = 0000h] eCOMP Interrupt Control Register # Figure 18-7. CPxINT Register | | | | _ | _ | | | | |-----|-----|------|-------|-------|-----|--------|-------| | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | Rese | erved | | | | | r-0 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | Rese | erved | | | CPIIFG | CPIFG | | r-0 | r-0 | r-0 | r-0 | r-0 | r-0 | rw-0 | rw-0 | # Table 18-4. CPxINT Register Field Description | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-2 | Reserved | R | 0h | Reserved. Reads as 0. | | 1 | CPIIFG | RW | 0h | eCOMP output inverted interrupt flag. The bit CPIES defines the transition of the output setting this bit. Write 1 to clear this bit. A read of the CPxIV register also clears this bit. 0b = No interrupt pending 1b = Output interrupt pending | | 0 | CPIFG | RW | Oh | eCOMP output interrupt flag. The bit CPIES defines the transition of the output setting this bit. Write 1 to clear this bit. A read of the CPxIV register also clears this bit. 0b = No interrupt pending 1b = Output interrupt pending | eCOMP Registers www.ti.com # 18.4.4 CPxIV Register (offset = 08h) [reset = 0000h] eCOMP Interrupt Vector Register ### Figure 18-8. CPxIV Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |-----|-----|-----|-----|-----|-----|-----|-----| | | | | CF | PIV | | | | | r-0 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | CF | PIV | | | | | r-0 #### Table 18-5. CPxIV Register Field Description | Bit | Field | Туре | Reset | Description | |------|-------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-0 | CPIV | R | Oh | eCOMP interrupt vector word register. The interrupt vector register reflects only interrupt flags whose interrupt enable bit are set. Reading the CPxIV register clears the pending interrupt flag with the highest priority. 00h = No interrupt pending 02h = CPIFG 04h = CPIIFG | # 18.4.5 CPxDACCTL Register (offset = 10h) [reset = 0002h] 6-bit eCOMP Built-in DAC Control Register #### Figure 18-9. CPxDACCTL Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |---------|-----|-----|-------|------|-----------|-----------|---------| | | | | Rese | rved | | | | | r-0 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | CPDACEN | | Res | erved | | CPDACREFS | CPDACBUFS | CPDACSW | | rw-0 | r-0 | r-0 | r-0 | r-0 | rw-0 | rw-1 | rw-0 | # Table 18-6. CPxDACCTL Register Field Description | Bit | Field | Туре | Reset | Description | |------|-----------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-8 | Reserved | R | 0h | Reserved. Reads as 0. | | 7 | CPDACEN | RW | Oh | eCOMP built-in DAC output control bit. 0b = DAC output disabled 1b = DAC output enabled | | 6-3 | Reserved | R | 0h | Reserved. Reads as 0. | | 2 | CPDACREFS | RW | Oh | eCOMP built-in DAC reference voltage selection 0b = VDD selected 1b = on-chip VREF selected | | 1 | CPDACBUFS | RW | 1h | eCOMP built-in DAC buffer controlled source selection. 0b = eCOMP output selected as the buffer control source 1b = CPDACSW bit selected as the buffer control source | | 0 | CPDACSW | RW | Oh | This bit is only valid when CPDACBUFS is set to 1. 0b = CPDACBUF1 selected 1b = CPDACBUF2 selected | www.ti.com eCOMP Registers # 18.4.6 CPxDACDATA Register (offset = 12h) [reset = 0100h] 6-bit eCOMP Built-in DAC Data Register # Figure 18-10. CPxDACDATA Register #### Table 18-7. CPxDACDATA Register Field Description | Bit | Field | Туре | Reset | Description | |-------|-----------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------| | 15-14 | Reserved | R | 0h | Reserved. Reads as 0. | | 13-8 | CPDACBUF2 | RW | 01h | Second 6-bit DAC buffer data 000000b = 0 V 000001b = selected reference voltage × 1/64 : 111111b = selected reference voltage × 63/64 | | 7-6 | Reserved | R | 0h | Reserved. Reads as 0. | | 5-0 | CPDACBUF1 | RW | 00h | First 6-bit DAC buffer data 000000b = 0 V 000001b = selected reference voltage × 1/64 : 111111b = selected reference voltage × 63/64 | # Transimpedance Amplifier (TIA) The TIA module is a transimpedance amplifier. This chapter describes the TIA functionality and features. NOTE: The transimpedance amplifier was originally given an abbreviation of TRI for use in descriptive text, pin names, and register names. The abbreviation has been changed to TIA in all descriptive text, but pin names and register names still use TRI. **Topic Page** | 19.1 | TIA Introduction | 515 | |------|------------------|-----| | 19.2 | TIA Operation | 515 | | | TIA Registers | | | | | | www.ti.com TIA Introduction #### 19.1 TIA Introduction The TIA module features include: - Single-supply low-power operation - 2.2-V to 3.6-V operation - · Rail-to-rail output - Programmable settling time and power consumption - · On-chip generation of bias voltages Figure 20-1 shows the block diagram of the TIA module. Figure 19-1. TIA Block Diagram ### 19.2 TIA Operation The TIA module works in AM through LPM4 and is configured with user software. The TIA module is fully shut down in LPMx.5. The setup and operation of the TIA is described in the following sections. #### 19.2.1 TIA Amplifier The TIA is a high-performance low-power rail-to-rail output operational amplifier. It is an amplifier that converts current to voltage. It can be configured two kinds of power modes: high power with high speed and low-power with low speed. These modes are selected by the TRIPM bit. The input range is 0 V to VDD/2. There is a dedicated input terminal for the signal input. The TIA module is enabled or disabled by the TRIEN bit. When TIA is disabled, the output is high impedance. #### 19.2.2 TIA Input and Output The TIA has a dedicated input terminal for the signal input, and this input is connected to the negative port of the amplifier. The TIA positive port can be selected from external or internal sources controlled by TRIPSEL bits. The positive TIA input can be: - A dedicated input terminal, TRIx+ - · Either one of two device-specific internal signals (see the device-specific data sheet) To convert current input to voltage output, the TIA output connects back to the negative input through an Rf resistor. The TIA output also can connect to: - An external terminal, TRIxO - OAx (refer to this module for selecting its input) - Comparator (refer to this module for selecting its input) - · ADC (refer to this module for selecting its input) TIA Operation www.ti.com Figure 19-2 shows a block diagram of a typical TIA application. Figure 19-2. TIA Typical Application Block Diagram www.ti.com TIA Registers #### 19.3 TIA Registers Table 19-1 shows the TIA registers and their address offsets. Refer to the device-specific data sheet for the base address of the TIA module. Table 19-1. TIA Registers | Offset | Acronym | Register Name | Туре | Access | Reset | Section | |--------|---------|------------------------|------------|--------|-------|----------------| | 00h | TRICTL | TIA control register 0 | Read/write | Word | 0000h | Section 19.3.1 | # 19.3.1 TRICTL Register (offset = 00h) [reset = 0000h] TIA Control Register #### Figure 19-3. TRICTL Register #### **Table 19-2. TRICTL Register Description** | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-8 | Reserved | R | 0h | Reserved. Reads as 0. | | 7-6 | TRIPSEL | RW | Oh | TIA positive input select. These bits select the input signal for the TIA positive input. 00b = External source (package terminal) 01b = Device specific; refer to the device-specific sheet for details | | | | | | 10b = Device specific; refer to the device-specific sheet for details 11b = Device specific; refer to the device-specific sheet for details | | 5-2 | Reserved | R | 0h | Reserved. Reads as 0. | | 1 | TRIPM | RW | Oh | TIA power mode select. This bit selects the slew rate and current consumption for the TIA. 0b = High speed and high power 1b = Low speed and low power | | 0 | TRIEN | RW | Oh | TIA enable. This bit enables or disable the TIA module. 0b = TIA is disabled, and its output is high impedance 1b = TIA is enabled, normal mode | # Smart Analog Combo (SAC) The Smart Analog Combo (SAC) integrates a high-performance low-power operational amplifier, up to 33x gain PGA, and a 12-bit digital-to-analog converter (DAC) core. The SAC can be used for signal conditioning for either the input or output path. This chapter describes SAC functionality and features. Topic Page | 20.1 | SAC Introduction | 519 | |------|-------------------|------------| | 20.2 | SAC Operation | <b>521</b> | | 20.3 | SAC Configuration | 530 | | | SAC Registers | | | | | | www.ti.com SAC Introduction #### 20.1 SAC Introduction SAC module features include: - OA (operational amplifier) - Rail-to rail input - Rail-to-rail output - Multiple input selection - PGA (programmable gain amplifier) - Configurable modes included buffer mode and PGA mode - Programmable PGA gain up to 33x - Supports inverting and noninverting mode - DAC (digital-to-analog converter) - 12-bit DAC core - Programmable setup time - Internal or external reference selection - Software selectable data loading #### **NOTE: SAC Module Configurations** The SAC module is flexible for different configurations in the SoC. Some configurations do not include all of the submodules (for example, the DAC circuit), and the corresponding registers are not accessible. See the device-specific data sheet for details. #### **NOTE: Multiple SAC Modules** Some devices may integrate more than one SAC module. If more than one SAC is present on a device, the multiple SAC modules operate identically. Throughout this chapter, nomenclature appears such as SACxOA to describe register names. When this occurs, the x indicates which SAC module is being discussed. In cases where operation is identical, the register is referred to as SACxOA. Figure 20-1 shows the block diagram of the SAC module. SAC Introduction www.ti.com Figure 20-1. SAC Block Diagram www.ti.com SAC Operation #### 20.2 SAC Operation The SAC module works in AM through LPM4 and is configurable with user software. The SAC module is fully shut down in LPMx.5. The setup and operation of the SAC is discussed in the following sections. #### 20.2.1 SAC OA SAC integrates a high-performance low-power rail-to-rail output operational amplifier. This OA can be configured to work independently in general purpose (GP) mode. The OA output slew rate can be configured for optimized settling time and power consumption with the OAxPM bit. See the device-specific data sheet for parameters. #### 20.2.1.1 SAC OA Input SAC OA contains 3-channel input selections on both the noninverting and inverting inputs of the amplifier for which NSEL and PSEL selects the inputs respectively. The inverting inputs include the OAx- pin, PGA, and the output of the paired OA. The noninverting inputs include the OAx+ pin, 12-bit DAC core, and the output of the paired OA. The inverting OAx- also can be connected with PGA to support inverting PGA mode. #### 20.2.2 SAC OA Configuration Table 20-1 lists the supported configurations for the SAC. Table 20-1. SAC Configuration Capability | Mode | MSEL | GAIN | NSEL | PSEL | Configuration | |------|--------|---------|------|------------|---------------------------------------------------------| | GP | _ | _ | 00 | 00, 10 | General-purpose OA by external pin or cascaded OA | | BP | 01 | - | 01 | 00, 01, 10 | Buffer output of external pin, DAC, or paired OA output | | PGA | 00, 11 | 001–111 | 01 | 00, 01 | Inverting PGA amplifier mode (see Table 20-2) | | PGA | 10 | 000–111 | 01 | 00, 10 | Noninverting PGA amplifier (see Table 20-2) | SAC Operation www.ti.com # 20.2.2.1 SAC OA General-Purpose (GP) Mode SAC OA built-in internal mux supports the GP mode. OAx+ and OAx- pins are dedicated as noninverting and inverting inputs in this mode. Figure 20-2 shows the block diagram of the SAC GP mode. Figure 20-2. SAC OA in GP Mode www.ti.com SAC Operation #### 20.2.2.2 SAC PGA The SAC PGA is a feedback resistance ladder. The PGA connects the OA output with the input as the feedback routing. This PGA module support buffer mode and PGA mode. In PGA mode, the configurable gain is up to 33x. Table 20-2 lists the SAC PGA mode gain settings. Table 20-2. Mode and PGA Gain Setting | MSEL | PSEL | NSEL | GAIN | Gain Value | Function | |--------|------------|------|------|------------|---------------------| | 01 | 00, 01, 10 | 01 | | | Buffer mode | | 00, 11 | 00, 01 | 01 | 001 | 1 | | | 00, 11 | 00, 01 | 01 | 010 | 2 | | | 00, 11 | 00, 01 | 01 | 011 | 4 | | | 00, 11 | 00, 01 | 01 | 100 | 8 | Inverting PGA mode | | 00, 11 | 00, 01 | 01 | 101 | 16 | | | 00, 11 | 00, 01 | 01 | 110 | 25 | | | 00, 11 | 00, 01 | 01 | 111 | 32 | | | 10 | 00, 10 | 01 | 000 | 1 | | | 10 | 00, 10 | 01 | 001 | 2 | | | 10 | 00, 10 | 01 | 010 | 3 | | | 10 | 00, 10 | 01 | 011 | 5 | Noninverting mode | | 10 | 00, 10 | 01 | 100 | 9 | - Noninverting mode | | 10 | 00, 10 | 01 | 101 | 17 | | | 10 | 00, 10 | 01 | 110 | 26 | | | 10 | 00, 10 | 01 | 111 | 33 | | The PGA working with the OA supports buffer mode, inverting mode, and noninverting mode. See the following sections for details. SAC Operation www.ti.com #### 20.2.2.3 Buffer Mode In this mode, the noninverting input from the external OAx+, DAC, or the output of paired OA. The output of the OA isolated from the R-ladder, and PGA MSEL is set to floating status (MSEL = 01). The OA can output to an external pin or internally to a paired OA. Figure 20-3 shows the example of the SAC buffer mode with OAx+ pin as noninverting input, Figure 20-3. SAC OA in Buffer Mode www.ti.com SAC Operation #### 20.2.2.4 Inverting Mode In this mode, the inverting input is from external OAx- pin crossing the R-ladder of PGA. The PGA MSEL selects OAx- as the source (MSEL = 00), and the OA inverting port must select PGA input (NSEL = 01). The OA noninverting input can select from the external pin OAx+ or the 12-bit DAC as bias. Table 20-2 lists the configurable gain settings. Figure 20-4 shows the example of the SAC inverting PGA mode with 12-bit DAC as bias cancellation, Figure 20-4. SAC in Inverting PGA Mode With DAC as Bias SAC Operation www.ti.com Figure 20-3 shows the example of the SAC buffer mode external bias on OAx+ pin, Figure 20-5. SAC in Inverting PGA Mode With External Bias www.ti.com SAC Operation #### 20.2.2.5 Noninverting Mode In this mode, the noninverting input is selected from the external pin of OAx+ or from a paired OA. The OA inverting input must select PGA input (NSEL = 01), and the PGA MSEL is set to ground (MSEL = 10). Table 20-2 lists the configurable gain settings. Figure 20-6 shows the example of the SAC noninverting PGA mode. Figure 20-6. SAC in Non-Inverting PGA Mode SAC Operation www.ti.com #### 20.2.3 SAC DAC SAC DAC module is a 12-bit digital-to-analog converter. The DAC can be configured in 12-bit mode. It can be used as the reference voltage and also can work with the OA and PGA to drive drive the output pad directly. The setting and operation is discussed in the following sections. #### 20.2.3.1 SAC DAC Features The DAC module is a 12-bit voltage-output digital-to-analog converter. The DAC can be configured in 12-bit mode and supports DMA data transfer. Features of the DAC include: - 12-bit monotonic output - · Programmable setup time - Internal or external reference selection - Software selectable data loading - · Unsigned right-justified binary data format Figure 20-7 shows the block diagram for the DAC module. Figure 20-7. DAC Block Diagram For Single-Module Devices www.ti.com SAC Operation #### 20.2.3.2 SAC DAC Core The DAC supports only 12-bit mode. This allows the user to control the dynamic range of $V_{ref} \div 4096$ . Table 20-3 lists the formula for the output voltage. Table 20-3. DAC Full-Scale Range ( $V_{ref} = Ve_{REF+}$ or $V_{REF+}$ ) | Resolution | Output Voltage Formula | |------------|---------------------------------------------| | 12 bit | $V_{out} = V_{ref} \times DACDAT \div 4096$ | When DAC output is enabled (DACEN = 1b), the maximum DACDAT value is 0FFFh, which leads to a rail output of $(4095 \div 4096) \times V_{ref}$ . The minimum DACDAT value is 0000h, which outputs ground. A value greater than 4095 can be written to the register, but all leading bits are ignored. #### 20.2.3.3 SAC DAC Reference The reference for the DAC is configured to use device-specific reference with the DACSREF bits. By default, DACSREF = 0 so that the primary source is used as the reference. When DACSREF = 1, the secondary reference signal is used. The device-specific reference depends on device configuration and may be either an external or an internal reference (see the device-specific data sheet). #### 20.2.3.4 SAC DAC Updating Output The DACDAT register can be connected directly to the DAC core or double buffered. The trigger for updating the DAC voltage output is selected with the DACLSEL bits. When DACLSEL = 00b, the data latch is transparent and the DACDAT register is applied directly to the DAC core. The DAC output updates immediately when new DAC data is written to the DACDAT register. When DACLSEL = 10b or 11b, data is latched on the rising edge from device-specific signals. These signals may work as synchronous or asynchronous events to trigger the buffer fetching data from DACDAT, regardless of when DACDAT is updated. New data must be loaded into the DACDAT register before the trigger occurs. The data output is unreliable if the loading and trigger happen at the same time. The DAC update period must be longer than the setup time. Otherwise, the output may distort upon the update frequency overhead. #### 20.2.3.5 SAC DAC Interrupt The DAC module can generate an interrupt when DACIE is set. When DAC data is latched from the DACDAT register into the data latch, the DACIFG bit is set and an interrupt request is generated and submitted to the CPU for interrupt service. The DACIFG bit is set when DACLSELx > 0 and DAC data is latched from the DACDAT register into the data latch. When DACLSELx = 0, the DAC12IFG flag is not set. A set DACIFG bit indicates that the DAC is ready for new data. The DACIFG flag can be cleared by writing 1 to DACIFG or can be reset automatically by reading of the DACIV register. Only the reading of the DACIV register automatically resets the DACIFG bit. If another interrupt flag is set, another interrupt is immediately generated after servicing the initial interrupt. #### 20.2.3.6 SAC DAC DMA For devices that contain a DMA, each DAC module instance has a DMA trigger associated with it. If DACDMAE is set and DAC data is updated with DACIFG set, a DMA transfer request is generated for new data DACDAT register. The DMA module automatically clears the request at the start of DMA data movement and also clears DACIFG. SAC Configuration www.ti.com # 20.3 SAC Configuration The SAC module has the following configurations: SAC-L1, SAC-L2, and SAC-L3 (see Table 20-4). SAC-L1 is the minimum feature set, and SAC-L3 is the maximum feature set. Each configuration can work individually, or multiple configurations can work together (see the device-specific data sheet for details). In devices that support a lower-level configuration, the higher-level functions and registers are reserved. For example, in a device that supports SAC-L1, the PGA and DAC functions and registers are not available. Table 20-4. SAC Configuration | SAC<br>Structure | SAC Register | Section | Function | |------------------|--------------|----------------|---------------| | SAC-L1 | SACxOA | Section 20.4.1 | OA | | SAC-L2 | SACxOA | Section 20.4.1 | PGA | | SAC-L2 | SACxPGA | Section 20.4.2 | - FGA | | | SACxOA | Section 20.4.1 | | | | SACxPGA | Section 20.4.2 | | | 64613 | SACxDAC | Section 20.4.3 | PGA and DAC | | SAC-L3 | SACxDAT | Section 20.4.4 | - PGA and DAC | | | SACxDACSTS | Section 20.4.5 | | | | SACxIV | Section 20.4.6 | | www.ti.com SAC Registers # 20.4 SAC Registers Table 20-5 lists the SAC registers. The base address can be found in the device-specific data sheet. Table 20-5 lists the address offset for each register. Table 20-5. SAC Registers | Offset | Acronym | Register Name | Туре | Access | Reset | Section | |--------|------------|--------------------------------|------------|--------|-------|----------------| | 00h | SACxOA | SACx OA Control Register | Read/write | Word | 0000h | Section 20.4.1 | | 02h | SACxPGA | SACx PGA Control Register | Read/write | Word | 0001h | Section 20.4.2 | | 04h | SACxDAC | SACx DAC Control Register | Read/write | Word | 0000h | Section 20.4.3 | | 06h | SACxDAT | SACx DAC Data Register | Read/write | Word | 0000h | Section 20.4.4 | | 08h | SACxDACSTS | SACx DAC Status Register | Read/write | Word | 0000h | Section 20.4.5 | | 0Ah | SACxIV | SACx Interrupt Vector Register | Read | Word | 0000h | Section 20.4.6 | SAC Registers www.ti.com # 20.4.1 SACxOA Register (offset = 00h) [reset = 0000h] SAC OA Control Register # Figure 20-8. SACxOA Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----------|--------|--------|--------|----------|--------|--------| | | Reserved | SACEN | OAPM | OAEN | | | | | r0 | rO | rO | r0 | r0 | rw-(0) | rw-(0) | rw-(0) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | NMUXEN | Reserved | NS | EL | PMUXEN | Reserved | PS | SEL | | rw-(0) | r0 | rw-(0) | rw-(0) | rw-(0) | r0 | rw-(0) | rw-(0) | # Table 20-6. SACxOA Register Description | Bit | Field | Туре | Reset | Description | | | |-------|----------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | 15-11 | Reserved | R | 0h | read as 0 | | | | 10 | SACEN | RW | 0h | SAC enable. This bit enables or disables the SAC. 0b = SAC all modules are disabled, then the SAC output high impedance 1b = SAC all modules are enabled, normal mode | | | | 9 | ОАРМ | RW | 0h | SAC OA power mode. This bit selects the slew rate and current consumption the OA. 0b = High speed and high power 1b = Low speed and low power | | | | 8 | OAEN | RW | 0h | SAC OA enable. This bit enables or disables the SAC. 0b = SAC OA is disabled, then the SAC OA output high impedance 1b = SAC OA is enabled, normal mode | | | | 7 | NMUXEN | RW | 0h | SAC negative input MUX control. 0b = All negative input sources are disconnected from OA negative port 1b = All negative input sources are connected to OA negative port | | | | 6 | Reserved | R | 0h | read as 0 | | | | 5-4 | NSEL | RW | 0h | SAC OA negative input source selection. These bits select the input signal for the SAC OA negative port input. 00b = External source selected 01b = PGA source selected (1) 10b = Device Specific (1) 11b = Reserved | | | | 3 | PMUXEN | RW | 0h | SAC positive input MUX control. 0b = All positive input sources are disconnected to OA positive port 1b = All positive input sources are connected to OA positive port | | | | 2 | Reserved | R | 0h | read as 0 | | | | 1-0 | PSEL | RW | 0h | SAC OA positive input source selection. These bits select the input signal for the SAC OA positive port input. 00b = External source selected 01b = 12-bit reference DAC source selected (1) 10b = Paired OA source selected 11b = Reserved | | | <sup>&</sup>lt;sup>(1)</sup> This option is reserved on SAC-L1 configuration www.ti.com SAC Registers # 20.4.2 SACxPGA Register (offset = 02h) [reset = 0001h] SAC PGA Control Register # Figure 20-9. SACxPGA Register # Table 20-7. SACxPGA Register Description | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-7 | Reserved | R | 0h | read as 0 | | 6-4 | GAIN | RW | 0h | SAC PGA gain configuration. See Table 20-2 for details. | | 3-2 | Reserved | R | 0h | read as 0 | | 1-0 | MSEL | RW | 01h | SAC PGA mode selection 00b = Inverting PGA mode (external pad OAx- is selected) 01b = Buffer mode (floating is selected ) 10b = Noninverting mode 11b = Cascade OA inverting mode | SAC Registers www.ti.com # 20.4.3 SACxDAC Register (offset = 04h) [reset = 0000h] SAC DAC Control Register This register can be modified only when DACEN = 0. # Figure 20-10. SACxDAC Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----|----------|----------|---------|-------|--------|---------|--------| | | Reserved | | DACSREF | Res | served | DACLSEL | | | r0 | r0 | rO | rw-(0) | rO | r0 | rw-(0) | rw-(0) | | 7 | 6 | 6 5 | | 3 | 2 | 1 | 0 | | | | Reserved | DACDMAE | DACIE | DACEN | | | | r0 | r0 | r0 | r0 | r0 | rw-(0) | rw-(0) | rw-(0) | # Table 20-8. SACxDAC Register Description | Bit | Field | Type | Reset | Description | |-------|----------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-13 | Reserved | R | 0h | Reserved | | 12 | DACSREF | RW | 0h | SAC DAC select reference voltage 0b = Primary reference. See the device-specific configuration. 1b = Secondary reference. See the device-specific configuration. | | 11-10 | Reserved | R | 0h | Reserved | | 9-8 | DACLSEL | RW | Oh | SAC DAC load select. Selects the load trigger for the DAC latch. DACENC must be set for the DAC to update, except when DACLSEL = 0. 00b = DAC latch loads when DACDAT written 01b = Reserved 10b = Device specific 0. DAC always loads data from DACDAT at the positive edge of this signal, such as Timer. 11b = Device specific 1. DAC always loads data from DACDAT at the positive edge of this signal, such as Timer | | 7-3 | Reserved | R | 0h | Reserved | | 2 | DACDMAE | RW | Oh | SAC DAC DMA request enable 0b = DMA request disabled 1b = DMA request enabled. A DMA request is generated when the DAC data is updated. | | 1 | DACIE | RW | 0h | SAC DAC interrupt enable 0b = Disabled 1b = Enabled | | 0 | DACEN | RW | 0h | SAC DAC enable 0b = Disabled 1b = Enabled | www.ti.com SAC Registers # 20.4.4 SACxDAT Register (offset = 06h) [reset = 0000h] SAC DAC Data Register Unsigned 12-bit binary format, right justified #### Figure 20-11. SACxDAT Register # Table 20-9. SACxDAT Register Description | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|----------------------------------------------------------------------------| | 15-12 | Reserved | R | 0h | Reserved. Always reads as 0. | | 11-0 | DAC Data | RW | 0h | SAC DAC data in unsigned format. Bit 11 represents the MSB. <sup>(1)</sup> | <sup>(1)</sup> Only word access to the SACxDAT register is allowed. Byte operation may cause unexpected results. SAC Registers www.ti.com # 20.4.5 SACxDACSTS Register (offset = 08h) [reset = 0000h] SAC DAC Status Register This register can be modified only when DACEN = 0. #### Figure 20-12. SACxDACSTS Register # Table 20-10. SACxDACSTS Register Description | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-1 | Reserved | R | 0h | Reserved | | 0 | DACIFG | RW | 0h | SAC DAC data update flag. This bit can be cleared by being written 1. It can also be cleared by reading of SACxIV register. If DMA is enabled, this bit is automatically cleared by DMA when a new data request is accepted. 0b = DAC latch data register not updated 1b = DAC latch data register updated | www.ti.com SAC Registers # 20.4.6 SACxIV Register (offset = 0Ah) [reset = 0000h] SAC Interrupt Vector Register # Figure 20-13. SACxIV Register # Table 20-11. SACxIV Register Description | Bit | Field | Туре | Reset | Description | |------|--------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------| | 15-0 | SACIVx | R | Oh | SAC DAC interrupt vector value <sup>(1)</sup> 00h = No interrupt pending 02h = Reserved 04h = DAC channel update interrupt flag Others = Reserved | <sup>&</sup>lt;sup>(1)</sup> Only word access to the SACIVx register is recommended. # **ADC Module** The ADC module is a high-performance 10-bit or 12-bit analog-to-digital converter (ADC). See the devicespecific data sheet to determine the resolution supported by a device. This chapter describes the operation of the ADC module. Page **Topic** | 21.1 | ADC Introduction | 539 | |------|------------------|-----| | 21.2 | ADC Operation | 541 | | 21.3 | ADC Registers | 560 | | | | | www.ti.com ADC Introduction #### 21.1 ADC Introduction The ADC module supports fast 10-bit or 12-bit analog-to-digital conversions. The module implements a 10-bit or 12-bit SAR core together, sample select control, and a window comparator. #### ADC features include: - Greater than 200-ksps maximum conversion rate - Monotonic 10-bit or 12-bit converter with no missing codes - Sample-and-hold with programmable sampling periods controlled by software or timers - · Conversion initiation by software or different timers - Software-selectable on-chip reference or external reference - · Twelve individually configurable external input channels - Conversion channel for on-chip temperature sensor - · Selectable conversion clock source - · Single-channel, repeat-single-channel, sequence, and repeat-sequence conversion modes - · Window comparator for low-power monitoring of input signals - Interrupt vector register for fast decoding of six ADC interrupts (ADCIFG0, ADCTOVIFG, ADCLOIFG, ADCINIFG, ADCHIIFG) Figure 21-1 shows the block diagram of the ADC module. ADC Introduction www.ti.com - A The MODCLK is part of the Clock System. See the Clock System chapter for more information. - B When using ADCSHP = 0, no synchronisation of the trigger input is done. Figure 21-1. ADC Block Diagram #### 21.2 ADC Operation The ADC module is configured with user software. The setup and operation of the ADC is described in the following sections. #### 21.2.1 ADC Core The ADC core converts an analog input to its 10-bit or 12-bit digital representation and stores the result in the conversion register ADCMEM0. The core uses two programmable and selectable 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 (03FFh for 10-bit, and 0FFFh for 12-bit) when the input signal is equal to or higher than $V_{R+}$ . The output is zero when the input signal is equal to or lower than $V_{R-}$ . The input channel and the reference voltage levels ( $V_{R+}$ and $V_{R-}$ ) are defined in the conversion control memory. The conversion formula for the ADC result $N_{ADC}$ is: 10-bit: $$N_{ADC} = 1024 \times \frac{Vin - V_{R-}}{V_{R+} - V_{R-}}$$ and, 12-bit: $N_{ADC} = 4096 \times \frac{Vin - V_{R-}}{V_{R+} - V_{R-}}$ The ADC core is configured by the control registers ADCCTL0, ADCCTL1, and ADCCTL2. The core is enabled with the ADCON bit. The ADC can be turned off when not in use to save power. With few exceptions, the ADC control bits can be modified only when ADCENC = 0. ADCENC must be set to 1 before any conversion can take place. #### 21.2.1.1 Conversion Clock Selection The ADCCLK is used as the conversion clock and also to generate the sampling period when the pulse sampling mode is selected. The ADC source clock is selected using the ADCSSELx bits. Possible ADCCLK sources are SMCLK, ACLK, and MODCLK. The input clock can be divided from 1 to 512 using the ADCDIVx bits and the ADCPDIVx bits. MODCLK, generated in the clock system, is approximately 5 MHz but varies with individual devices, supply voltage, and temperature. See the device-specific data sheet for the specifications of the MODCLK. The clock that is chosen to source ADCCLK must remain active until the end of a conversion. If the clock is removed during a conversion, the operation does not complete, and any result is invalid. #### 21.2.2 ADC Inputs and Multiplexer The channel for conversion is selected by the analog input multiplexer from 12 external and 4 internal analog signals. The input multiplexer is a break-before-make type to reduce input-to-input noise injection that can result from channel switching (see Figure 21-2). The input multiplexer is also a T-switch to minimize the coupling between channels. Channels that are not selected are isolated from the ADC, and the intermediate node is connected to analog ground ( $AV_{SS}$ ), so that the stray capacitance is grounded to eliminate crosstalk. The ADC uses the charge redistribution method. When the inputs are internally switched, the switching action may cause transients on the input signal. These transients decay and settle before causing errant conversions. Figure 21-2. Analog Multiplexer #### 21.2.2.1 Analog Port Selection The ADC inputs are multiplexed with digital port pins. When analog signals are applied to digital gates, parasitic current can flow from $V_{\rm CC}$ to GND. This parasitic current occurs if the input voltage is near the transition level of the gate. Disabling the digital part of the port pin eliminates the parasitic current flow and, therefore, reduces overall current consumption. The PySELx bits can disable the port pin input and output buffers. ``` ; Py.0 and Py.1 configured for analog input BIS.B #3h,&PySEL; Py.1 and Py.0 ADC function ``` #### 21.2.3 Voltage Reference Generator The ADC module can use either the on-chip reference voltage or an external reference voltage supplied on external pins. The on-chip reference supports either a fixed 1.5-V reference or a user-selectable 1.5-V, 2.0-V, or 2.5-V reference. See the device-specific data sheet to determine which reference is available. External references can be supplied for V<sub>R+</sub> and V<sub>R-</sub>through the VEREF+ and VEREF- pins, respectively. The ADCSREFx bits select the ADC module reference. One buffer is available for an external reference or the 1.5-V on-chip reference. This buffer is bypassed on the selectable-level on-chip reference. #### 21.2.3.1 Internal Reference Low-Power Features The on-chip reference is designed for low-power applications. This reference includes a band-gap voltage source in the PMM module. The current consumption is specified in the device-specific data sheet. The ADC also contains an internal buffer for reference voltages. This buffer is automatically enabled when the internal reference is selected for on-chip reference on 10-bit mode of ADC and bypass on 12-bit mode ADC, and it is also optionally available for $Ve_{REF+}$ . The on-chip reference from the PMM module must be enabled by software. Its settling time is $\leq 30~\mu s$ . See the PMM module chapter for more information on the on-chip reference. The reference buffer of the ADC also has selectable speed versus power settings. When the maximum conversion rate is below 50 ksps, setting ADCSR = 1 reduces the current consumption of the buffer by approximately 50%. #### 21.2.4 Automatic Power Down The ADC is designed for low-power applications. When the ADC is not actively converting, the core is automatically disabled, and it is automatically reenabled when needed. The MODCLK is also automatically enabled when needed and disabled when not needed. When the fixed 1.5-V on-chip reference is selected, this reference is always on, regardless of whether or not the ADC is performing a conversion. When the variable on-chip reference is selected, the internal reference is always on if INTREFEN = 1. If INTREFEN = 0, the reference is turned on only when an ADC conversion is triggered. When this on-chip reference buffer is powered down in pulse sample mode, the ADC sample time does not start until the buffer is ready (REFGENACT = 1), so the application does not need to be account for this time. When the buffer is powered down in extended sample mode, the application must account for the buffer ready time by using the REFGENACT = 1 in calculating the time the trigger should be asserted to make sure that the application meets the required sample time or ADC minimum sample time. #### 21.2.5 Sample and Conversion Timing An analog-to-digital conversion is initiated with a rising edge of the sample input signal SHI. The source for SHI is selected with the ADCSHSx bits and can be chosen from the following: - ADCSC bit - Three timer outputs The polarity of the SHI signal source can be inverted with the ADCISSH bit. The SAMPCON signal controls the sample period and start of conversion. When SAMPCON is high, sampling is active. The high-to-low SAMPCON transition starts the analog-to-digital conversion, which requires 11 ADCCLK cycles in 10-bit resolution mode, and 13 ADCCLK cycles in 12-bit resolution mode. One additional ADCCLK cycle is needed to synchronize the input trigger source clock and ADC clock. The window comparator needs one additional ADCCLK cycle. Two sample-timing methods are selected by control bit ADCSHP: extended sample mode and pulse mode. ## 21.2.5.1 Extended Sample Mode The extended sample mode is selected when ADCSHP = 0. The SHI signal directly controls SAMPCON and defines the length of the sample period $t_{\text{sample}}$ . When SAMPCON is high, sampling is active. The high-to-low SAMPCON transition starts the conversion after synchronization with ADCCLK (see 10-bit mode Figure 21-3 or 12-bit mode Figure 21-4). The SHI signal requires at least 4 ADCCLK cycles. Figure 21-3. Extended Sample Mode in 10-Bit Mode Figure 21-4. Extended Sample Mode With External Reference in 12-Bit Mode Figure 21-5. Extended Sample Mode With Internal Reference in 12-Bit Mode #### 21.2.5.2 Pulse Sample Mode The pulse sample mode is selected when ADCSHP = 1. The SHI signal triggers the sampling timer. The ADCSHTx bits in the ADCCTL0 register control the interval of the sampling timer that defines the SAMPCON sample period $t_{\text{sample}}$ . The sampling timer keeps SAMPCON high after synchronization with ADCCLK for a programmed interval, $t_{\text{sample}}$ . The total sampling time is $t_{\text{sample}}$ plus $t_{\text{sync}}$ (see 10-bit mode Figure 21-6 or 12-bit mode Figure 21-7). The ADCSHTx bits select the sampling time in 4x multiples of ADCCLK. The ADCSC bit is automatically cleared if it is used as the sample-and-hold source in this mode. Figure 21-6. Pulse Sample Mode in 10-Bit Mode Figure 21-7. Pulse Sample Mode With External Reference in 12-Bit Mode Figure 21-8. Pulse Sample Mode With Internal Reference in 12-Bit Mode ## 21.2.5.3 Sample Timing Considerations When SAMPCON = 0, all Ax inputs are high impedance. When SAMPCON = 1, the selected Ax input can be modeled as an RC low-pass filter during the sampling time $t_{\text{sample}}$ (see Figure 21-9). An internal MUX-on input resistance $R_{\text{I}}$ (see device-specific data sheet) in series with capacitor $C_{\text{I}}$ (see device-specific data sheet) is seen by the source. The capacitor $C_{\text{I}}$ voltage $(V_{\text{C}})$ must be charged to within one-half LSB of the source voltage $(V_{\text{S}})$ for an accurate 10-bit or 12-bit conversion. Figure 21-9. Analog Input Equivalent Circuit The resistance of the sources ( $R_s$ and $R_l$ ) affects $t_{sample}$ . Equation 14 can be used to calculate a conservative value of the minimum sample time $t_{sample}$ for an n-bit conversion. $$t_{\text{sample}} \ge (R_S + R_I) \times \ln(2^{n+2}) \times (C_I + C_{\text{Pext}} + C_{\text{Pint}}) \tag{14}$$ See the device-specific data sheet for the t<sub>sample</sub> limits. #### 21.2.6 Conversion Result For all conversion modes, the conversion result is accessible by reading the ADCMEM0 register. When a conversion result is written to ADCMEM0, the ADCIFG0 interrupt flag is set. #### 21.2.7 ADC Conversion Modes The ADC has four operating modes, selected by the CONSEQx bits (see Table 21-1). **Table 21-1. Conversion Mode Summary** | ADCCONSEQx | Mode | Operation | | | |------------|----------------------------------|-------------------------------------------------|--|--| | 00 | Single-channel single-conversion | A single channel is converted once. | | | | 01 | Sequence-of-channels | A sequence of channels is converted once. | | | | 10 | Repeat-single-channel | A single channel is converted repeatedly. | | | | 11 | Repeat-sequence-of-channels | A sequence of channels is converted repeatedly. | | | #### 21.2.7.1 Single-Channel Single-Conversion Mode A single channel selected by ADCINCHx is sampled and converted once. The ADC result is written to ADCMEM0. 10-bit mode Figure 21-10 or 12-bit mode Figure 21-11 shows the flow of the single-channel single-conversion mode. When ADCSC triggers a conversion, successive conversions can be triggered by the ADCSC bit. When any other trigger source is used, ADCENC must be toggled between each conversion. Resetting ADCON bit within a conversion causes the ADC to return to the "ADC off" state. In this case, the value of the conversion register and the value of the interrupt flags are unpredictable. <sup>\* =</sup> Conversion result is unpredictable Figure 21-10. Single-Channel Single-Conversion Mode in 10-Bit Mode x = Pointer to the selected ADC channel defined by ADCINCHx All bit and register names are in bold font; signals are in normal font. Figure 21-11. Single-Channel Single-Conversion Mode in 12-Bit Mode $<sup>^{\</sup>star}$ = Conversion result is unpredictable x = Pointer to the selected ADC channel defined by **ADCINCHx** All bit and register names are in bold font; signals are in normal font. ## 21.2.7.2 Sequence-of-Channels Mode A sequence of channels is sampled and converted once. The sequence begins with the channel selected by the ADCINCHx bits and decrements to channel A0. Each ADC result is written to ADCMEM0. The sequence stops after conversion of channel A0. 10-bit mode Figure 21-12 or 12-bit mode Figure 21-13 shows the sequence-of-channels mode. When ADCSC triggers a sequence, successive sequences can be triggered by the ADCSC bit. When any other trigger source is used, ADCENC must be toggled between each sequence. As in all conversion modes, resetting ADCON bit within a conversion causes the ADC to return to the "ADC off" state. x = Input channel Ax All bit and register names are in bold font; signals are in normal font. Figure 21-12. Sequence-of-Channels Mode in 10-Bit Mode x = Input channel Ax All bit and register names are in bold font; signals are in normal font. Figure 21-13. Sequence-of-Channels Mode in 12-Bit Mode #### 21.2.7.3 Repeat-Single-Channel Mode A single channel selected by ADCINCHx is sampled and converted continuously. Each ADC result is written to ADCMEM0. 10-bit mode Figure 21-14 or 12-bit mode Figure 21-15 shows the repeat-single-channel mode. x = Pointer to the selected ADC channel defined by ADCINCHx All bit and register names are in bold font; signals are in normal font. Figure 21-14. Repeat-Single-Channel Mode in 10-Bit Mode x = Pointer to the selected ADC channel defined by $\mbox{\bf ADCINCHx}$ All bit and register names are in bold font; signals are in normal font. Figure 21-15. Repeat-Single-Channel Mode in 12-Bit Mode ## 21.2.7.4 Repeat-Sequence-of-Channels Mode A sequence of channels is sampled and converted repeatedly. The sequence begins with the channel selected by ADCINCHx and decrements to channel A0. Each ADC result is written to ADCMEM0. The sequence ends after conversion of channel A0, and the next trigger signal restarts the sequence. 10-bit mode Figure 21-16 or 12-bit mode Figure 21-17 shows the repeat-sequence-of-channels mode. x = Input channel Ax All bit and register names are in bold font; signals are in normal font. Figure 21-16. Repeat-Sequence-of-Channels Mode in 10-Bit Mode x = Input channel Ax All bit and register names are in bold font; signals are in normal font. Figure 21-17. Repeat-Sequence-of-Channels Mode in 12-Bit Mode ## 21.2.7.5 Using the Multiple Sample and Convert (ADCMSC) Bit To configure the converter to perform successive conversions automatically and as quickly as possible, a multiple sample and convert function is available. When ADCMSC = 1, CONSEQx > 0, and the sample timer is used, the first rising edge of the SHI signal triggers the first conversion. Successive conversions are triggered automatically as soon as the prior conversion is completed. Additional rising edges on SHI are ignored until the sequence is completed in the single-sequence mode, or until the ADCENC bit is toggled in repeat-single-channel or repeated-sequence modes. The function of the ADCENC bit is unchanged when using the ADCMSC bit. #### 21.2.7.6 Stopping Conversions Stopping ADC activity depends on the mode of operation. The recommended ways to stop an active conversion or conversion sequence are: - Setting ADCENC = 0 in single-channel single-conversion mode stops a conversion immediately and the results are unpredictable. For correct results, poll the busy bit until reset before clearing ADCENC. - Setting ADCENC = 0 during repeat-single-channel operation stops the converter at the end of the current conversion. - Setting ADCENC = 0 during a sequence or repeat-sequence mode stops the converter at the end of the sequence. - Any conversion mode can be stopped immediately by setting CONSEQx = 0 and setting ADCENC = 0. Conversion data are unreliable. #### 21.2.7.7 Window Comparator The window comparator allows the ADC to monitor analog signals without any CPU interaction. The window comparator triggers the following interrupt flags: - The ADCLO interrupt flag (ADCLOIFG) is set if the current result of the ADC conversion is below the low threshold defined in register ADCLO. - The ADCHI interrupt flag (ADCHIIFG) is set if the current result of the ADC conversion is greater than the high threshold defined in register ADCHI. - The ADCIN interrupt flag (ADCINIFG) is set if the current result of the ADC conversion is between the low threshold defined in register ADCLO and the high threshold defined in ADCHI. These interrupts are generated independent of the selected conversion mode. The values in the ADCHI and ADCLO registers must be in the correct data format. For example, if the binary data format is selected (ADCDF = 0), then the thresholds in the threshold registers ADCHI and ADCLO also must be binary coded. Changing the ADCDF or ADCRES bit resets the threshold registers. The interrupt flags must be reset by software. The ADC updates the flags when a new value is available in the ADCMEMO. This update is only to set the corresponding interrupt flag. When the window comparator is used, software must reset the flags according to the application needs. #### 21.2.7.8 Using the Integrated Temperature Sensor To use the on-chip temperature sensor, select the analog input channel ADCINCHx = 1100b. Any other configuration is done as if an external channel were selected, including reference selection, conversion-mode selection, and all other settings. The temperature sensor must be activated by software. Figure 21-18 and Figure 21-19shows the typical temperature sensor transfer function for 10-bit or 12-bit ADC specified. See the device-specific data sheet for details. When using the temperature sensor, the sample period must be greater than 30 $\mu$ s. The temperature sensor offset error can be large and must be calibrated for most applications (see the device-specific data sheet for parameters). Figure 21-18. Typical Temperature Sensor Transfer Function for 10-bit ADC Figure 21-19. Typical Temperature Sensor Transfer Function for 12-bit ADC #### 21.2.7.9 ADC Grounding and Noise Considerations As with any high-resolution ADC, appropriate printed-circuit-board layout and grounding techniques must be followed to eliminate ground loops, unwanted parasitic effects, and noise. Ground loops are formed when return current from the ADC flows through paths that are common with other analog or digital circuitry. If care is not taken, this current can generate small unwanted offset voltages that can add to or subtract from the reference or input voltages of the ADC. Figure 21-20 shows connections that can prevent ground loops. In addition to grounding, ripple and noise spikes on the power-supply lines due to digital switching or switching power supplies can corrupt the conversion result. TI recommends a noise-free design using separate analog and digital ground planes with a single-point connection to achieve high accuracy. Figure 21-20. ADC Grounding and Noise Considerations #### 21.2.7.10 ADC Interrupts The ADC has six interrupt sources: ADCIFG0: conversion ready interrupt The ADCIFG0 bit is set when the ADCMEM0 memory register is loaded with the conversion result. An interrupt request is generated if the ADCIE0 bit and the GIE bit are set. ADCOVIFG: ADCMEM0 overflow The ADCOV condition occurs when a conversion result is written to the ADCMEM0 before its previous conversion result was read. ADCTOVIFG: ADC conversion-time overflow The ADCTOV condition is generated when another sample-and-conversion is requested before the current conversion is completed. ADCLOIFG, ADCINIFG, ADCHIIFG: window comparator interrupt flags The window comparator interrupt flags are described in Section 21.2.7.7. #### 21.2.7.10.1 ADCIV, Interrupt Vector Generator All ADC interrupt sources are prioritized and combined to source a single interrupt vector. Read the interrupt vector register ADCIV to determine which ADC interrupt source requested an interrupt. The highest-priority enabled ADC interrupt generates a number in the ADCIV register (see Section 21.3.13). This number can be evaluated or added to the program counter (PC) to automatically enter the appropriate software routine (see Section 21.2.7.10.2). Disabled ADC interrupts do not affect the ADCIV value. Read access of the ADCIV register automatically resets the highest-pending interrupt condition and flag. Only the ADCIFG0 is not reset by this ADCIV read access. ADCIFG0 is automatically reset by reading the ADCMEM0 register or may be reset with software. Write access to the ADCIV register clears all pending interrupt conditions and flags. If another interrupt is pending after servicing of an interrupt, another interrupt is generated. For example, if the ADCOV, ADCHIIFG, and ADCIFG0 interrupts are pending when the interrupt service routine accesses the ADCIV register, the highest priority interrupt (ADCOV interrupt condition) is reset automatically. After the RETI instruction of the interrupt service routine is executed, the ADCHIIFG generates another interrupt. #### 21.2.7.10.2 ADC Interrupt Handling Software Example The following example shows the recommended use of the ADCIV. The ADCIV value is added to the PC to automatically jump to the appropriate routine. #### ADCIFG0, ADCTOV, and ADCOV: 16 cycles ``` ; Interrupt handler for ADC. INT_ADC ; Enter Interrupt Service Routine ; Add offset to PC ADD &ADCIV,PC ; Vector 0: No interrupt RETI ; Vector 2: ADC overflow JMP ADOV JMP ADTOV ; Vector 4: ADC timing overflow ; Vector 6: ADC window comparator high interrupt JMP ADHI JMP ADLO ; Vector 8: ADC window comparator low interrupt ADIN ; Vector 10: ADC window comparator in interrupt JMP ; Handler for ADCIFGO starts here. No JMP required. ADMEM MOV &ADCMEM0, xxx ; Move result, flag is reset ; Other instruction needed? RETI ; Return ; ADOV ; Handle ADCMEMO overflow RETI ; Return ; ADTOV ; Handle Conv. time overflow . . . RETI ; Return ; ADHI ; Handle window comparator high interrupt . . . RETI ; Return ; ; Handle window comparator low interrupt ADLO RETI ; Return ; ADIN ; Handle window comparator in window interrupt . . . RETI ; Return ``` # 21.3 ADC Registers Table 21-2 lists the ADC registers and the address offset of each. See the device-specific data sheet for the base address of the ADC. Table 21-2. ADC Registers | Offset | Acronym | Register Name | Туре | Reset | Section | | |--------|----------|-----------------------------------------------|----------------------|-----------|-----------------|--| | 00h | ADCCTL0 | ADC Control 0 register | Read/write | 0100h | Section 21.3.1 | | | 02h | ADCCTL1 | ADC Control 1 register | Read/write | 0000h | Section 21.3.2 | | | 04h | ADCCTL2 | ADC Control 2 register | Read/write | 0010h | Section 21.3.3 | | | 06h | ADCLO | ADC Window Comparator Low Threshold register | . Read/write Cicion | | | | | 08h | ADCHI | ADC Window Comparator High Threshold register | ' C READ/Write USEEN | | | | | 0Ah | ADCMCTL0 | ADC Memory Control register | Read/write | 00h | Section 21.3.6 | | | 12h | ADCMEM0 | ADC Conversion Memory register | Read/write | undefined | Section 21.3.4 | | | 1Ah | ADCIE | ADC Interrupt Enable register | Read/write | 0000h | Section 21.3.11 | | | 1Ch | ADCIFG | ADC Interrupt Flag register | Read/write | 0000h | Section 21.3.12 | | | 1Eh | ADCIV | ADC Interrupt Vector register | Read/write | 0000h | Section 21.3.13 | | # 21.3.1 ADCCTL0 Register ADC Control Register 0 ## Figure 21-21. ADCCTL0 Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----------|-------|--------|----------|--------|--------|--------| | | Rese | erved | | | ADC | SHTx | | | r0 | rO | r0 | r0 | rw-(0) | rw-(0) | rw-(0) | rw-(1) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | ADCMSC | Reserved | | ADCON | Reserved | | ADCENC | ADCSC | | rw-(0) | r0 | r0 | rw-(0) | r0 | r0 | rw-(0) | rw-(0) | Can be modified only when ADCENC = 0. Resetting ADCENC = 0 by software and changing these fields immediately shows an effect when a conversion is active. # Table 21-3. ADCCTL0 Register Description | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-12 | Reserved | R | 0h | Reserved. Always reads as 0. | | 11-8 | ADCSHTx | RW | 1h <sup>(1)</sup> | ADC sample-and-hold time. These bits define the number of ADCCLK cycles in the sampling period for the ADC. | | | | | | Can be modified only when ADCENC = 0. Resetting ADCENC = 0 by software and changing these fields immediately shows an effect when a conversion is active. | | | | | | 0000b = 4 ADCCLK cycles | | | | | | 0001b = 8 ADCCLK cycles | | | | | | 0010b = 16 ADCCLK cycles | | | | | | 0011b = 32 ADCCLK cycles | | | | | | 0100b = 64 ADCCLK cycles | | | | | | 0101b = 96 ADCCLK cycles | | | | | | 0110b = 128 ADCCLK cycles | | | | | | 0111b = 192 ADCCLK cycles | | | | | | 1000b = 256 ADCCLK cycles | | | | | | 1001b = 384 ADCCLK cycles | | | | | | 1010b = 512 ADCCLK cycles | | | | | | 1011b = 768 ADCCLK cycles | | | | | | 1100b = 1024 ADCCLK cycles | | | | | | 1101b = 1024 ADCCLK cycles | | | | | | 1110b = 1024 ADCCLK cycles | | | | | | 1111b = 1024 ADCCLK cycles | | 7 | ADCMSC | RW | 0h | ADC multiple sample-and-conversion. Valid only for sequence or repeated modes. | | | | | | Can be modified only when ADCENC = 0. Resetting ADCENC = 0 by software and changing these fields immediately shows an effect when a conversion is active. | | | | | | 0b = The sampling timer requires a rising edge of the SHI signal to trigger each sample-and-convert. | | | | | | 1b = The first rising edge of the SHI signal triggers the sampling timer, but further sample-and-conversions are performed automatically as soon as the prior conversion is completed. | | 6-5 | Reserved | R | 0h | Reserved. Always reads as 0. | | 4 | ADCON | RW | 0h | ADC on. | | | | | | Can be modified only when ADCENC = 0. Resetting ADCENC = 0 by software and changing these fields immediately shows an effect when a conversion is active. | | | | | | 0b = ADC off | | | | | | 1b = ADC on | | 3-2 | Reserved | R | 0h | Reserved. Always reads as 0. | <sup>&</sup>lt;sup>(1)</sup> The default value for 10-bit ADC and 12-bit ADC is "0h" and "1h" respective. # Table 21-3. ADCCTL0 Register Description (continued) | onversion.<br>Ibled<br>bled | |--------------------------------------------------------------------------------------------------------------------------| | version. Software-controlled sample-and-conversion start. ADCSC may be set together with one instruction. ADCSC is reset | | le-and-conversion-start | # 21.3.2 ADCCTL1 Register ADC Control Register 1 ## Figure 21-22. ADCCTL1 Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |---------|--------|--------|--------|----------------|--------|---------|--------| | | Rese | erved | | ADCSHSx ADCSHP | | ADCISSH | | | rO | r0 | rO | rO | rw-(0) | rw-(0) | rw-(0) | rw-(0) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | ADCDIVx | | | ADCS | SSELx | ADCCO | ADCBUSY | | | rw-(0) r-(0) | Can be modified only when ADCENC = 0. Resetting ADCENC = 0 by software and changing these fields immediately shows an effect when a conversion is active. ## Table 21-4. ADCCTL1 Register Description | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-12 | Reserved | R | 0h | Reserved. Always reads as 0. | | 11-10 | ADCSHSx | RW | 0h | ADC sample-and-hold source select. | | | | | | Can be modified only when ADCENC = 0. Resetting ADCENC = 0 by software and changing these fields immediately shows an effect when a conversion is active. | | | | | | 00b = ADCSC bit | | | | | | 01b = Timer trigger 0 (see device-specific data sheet) | | | | | | 10b = Timer trigger 1 (see device-specific data sheet) | | | | 5, | - | 11b = Timer trigger 2 (see device-specific data sheet) | | 9 | ADCSHP | RW | 0h | ADC sample-and-hold pulse-mode select. This bit selects the source of the sampling signal (SAMPCON) to be either the output of the sampling timer or the sample-input signal directly. | | | | | | Can be modified only when ADCENC = 0. Resetting ADCENC = 0 by software and changing these fields immediately shows an effect when a conversion is active. | | | | | | 0b = SAMPCON signal is sourced from the sample input signal. | | | | | | 1b = SAMPCON signal is sourced from the sampling timer. | | 8 | ADCISSH | RW | 0h | ADC invert signal sample-and-hold. | | | | | | Can be modified only when ADCENC = 0. Resetting ADCENC = 0 by software and changing these fields immediately shows an effect when a conversion is active. | | | | | | 0b = The sample input signal is not inverted. | | | | | | 1b = The sample input signal is inverted. | | 7-5 | ADCDIVx | RW | 0h | ADC clock divider. | | | | | | Can be modified only when ADCENC = 0. Resetting ADCENC = 0 by software and changing these fields immediately shows an effect when a conversion is active. | | | | | | 000b = Divide by 1 | | | | | | 001b = Divide by 2 | | | | | | 010b = Divide by 3 | | | | | | 011b = Divide by 4 | | | | | | 100b = Divide by 5 | | | | | | 101b = Divide by 6 | | | | | | 110b = Divide by 7 | | | | | | 111b = Divide by 8 | # Table 21-4. ADCCTL1 Register Description (continued) | Bit | Field | Туре | Reset | Description | |-----|------------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 4-3 | ADCSSELx | RW | Oh | ADC clock source select. Can be modified only when ADCENC = 0. Resetting ADCENC = 0 by software and changing these fields immediately shows an effect when a conversion is active. 00b = MODCLK 01b = ACLK 10b = SMCLK 11b = SMCLK | | 2-1 | ADCCONSEQX | RW | Oh | ADC conversion sequence mode select. Can be modified only when ADCENC = 0. Resetting ADCENC = 0 by software and changing these fields immediately shows an effect when a conversion is active. 00b = Single-channel single-conversion 01b = Sequence-of-channels 10b = Repeat-single-channel 11b = Repeat-sequence-of-channels | | 0 | ADCBUSY | R | 0h | ADC busy. This bit indicates an active sample or conversion operation. 0b = No operation is active. 1b = A sequence, sample, or conversion is active. | ## 21.3.3 ADCCTL2 Register ADC Control Register 2 ## Figure 21-23. ADCCTL2 Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |------|-----------------|--------|--------|--------|----------|--------|--------| | | | | ADCI | PDIVx | | | | | r0 | rO | rO | r0 | rO | r0 | rw-(0) | rw-(0) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Rese | Reserved ADCRES | | ADCDF | ADCSR | Reserved | | | | r0 | r0 | rw-(0) | rw-(1) | rw-(0) | rw-(0) | r0 | rw-(0) | Can be modified only when ADCENC = 0. Resetting ADCENC = 0 by software and changing these fields immediately shows an effect when a conversion is active. # Table 21-5. ADCCTL2 Register Description | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-10 | Reserved | R | 0h | Reserved. Always reads as 0. | | 9-8 | ADCPDIVx | RW | Oh | ADC predivider. This bit predivides the selected ADC clock source before it gets divided again using ADCDIVx. 00b = Predivide by 1 01b = Predivide by 4 10b = Predivide by 64 11b = Reserved | | 7-6 | Reserved | R | 0h | Reserved. Always reads as 0. | | 5-4 | ADCRES | RW | 1h | ADC resolution. This bit defines the conversion result resolution. (1) 00b = 8 bit (10 clock cycle conversion time) 01b = 10 bit (12 clock cycle conversion time) 10b = 12 bit (14 clock cycle conversion time) 11b = Reserved | | 3 | ADCDF | RW | 0h | ADC data read-back format. Data is always stored in the binary unsigned format. $0b = Binary$ unsigned. Theoretically, the analog input voltage $-V_{REF}$ results in 0000h, and the analog input voltage $+V_{REF}$ results in 03FFh. $1b = Signed$ binary (2s complement), left aligned. Theoretically, the analog input voltage $-V_{REF}$ results in 8000h, and the analog input voltage $+V_{REF}$ results in 7FC0h. | | 2 | ADCSR | RW | Oh | ADC sampling rate. This bit selects the drive capability of the ADC reference buffer for the maximum sampling rate. Setting ADCSR reduces the current consumption of this buffer. 0b = ADC buffer supports up to approximately 200 ksps 1b = ADC buffer supports up to approximately 50 ksps | | 1 | Reserved | R | 0h | Reserved. Always reads as 0. | | 0 | Reserved | RW | 0h | Reserved. Must be written as 0. | <sup>(1)</sup> Only the LSB is valid on devices that support only 10-bit mode. To determine support for 10-bit or 12-bit mode, see the device-specific data sheet. ## 21.3.4 ADCMEM0 Register ADC Conversion Memory Register ## Figure 21-24. ADCMEM0 Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |----|--------------------|----|----|----|----|----|----|--|--| | | Conversion_Results | | | | | | | | | | r0 | r0 | r0 | r0 | rw | rw | rw | rw | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | Conversion_Results | | | | | | | | | | rw | | ## Table 21-6. ADCMEM0 Register Description | Bit | Field | Туре | Reset | Description | |------|--------------------|------|-----------|-------------------------------------------------------------------------------------------------------------------------| | 15-0 | Conversion_Results | RW | undefined | This data format is used if ADCDF = 0 (binary unsigned). The conversion results are right justified. | | | | | | Bit 11 is the MSB. Bits 15-12 are 0 in 12-bit mode, bits 15-10 are 0 in 10-bit mode, and bits 15-8 are 0 in 8-bit mode. | | | | | | Writing to the conversion memory register corrupts the results. | # 21.3.5 ADCMEM0 Register, 2s-Complement Format ADC Conversion Memory Register, 2s-Complement Format # Figure 21-25. ADCMEM0 Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----|----|----|------------|------------|----|----|----| | | | | Conversion | on_Results | | | | | rw | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | Conversion | on_Results | | | | | rw | rw | rw | rw | r0 | r0 | r0 | r0 | # Table 21-7. ADCMEM0 Register Description | Bit | Field | Туре | Reset | Description | |------|--------------------|------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-0 | Conversion_Results | RW | undefined | This data format is used if ADCDF = 1 (2s complement). The conversion results are left justified, 2s-complement format. | | | | | | Bit 15 is the MSB. Bits 3-0 are 0 in 12-bit mode, bits 5-0 are 0 in 10-bit mode, and bits 7-0 are 0 in 8-bit mode. | | | | | | The data is stored in the right-justified format and is converted to the left-justified 2s-complement format during read back. Writing to the conversion memory register corrupts the results. | # 21.3.6 ADCMCTL0 Register ADC Conversion Memory Control Register ## Figure 21-26. ADCMCTL0 Register Can be modified only when ADCENC = 0. Resetting ADCENC = 0 by software and changing these fields immediately shows an effect when a conversion is active. ## Table 21-8. ADCMCTL0 Register Description | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-9 | Reserved | R | 0h | Reserved. Always reads as 0. | | 8 | Reserved | RW | 0h | Reserved. Always reads as 0. | | 6-4 | ADCSREFX | RW | Oh | Select reference. It is not recommended to change this setting while a conversion is ongoing. Can be modified only when ADCENC = 0. Resetting ADCENC = 0 by software and changing these fields immediately shows an effect when a conversion is active. $000b = \{V_{R+} = \text{AVCC and } V_{R-} = \text{AVSS} \}$ $001b = \{V_{R+} = \text{VREF and } V_{R-} = \text{AVSS} \}$ $010b = \{V_{R+} = \text{VEREF+ buffered and } V_{R-} = \text{AVSS} \}$ $011b = \{V_{R+} = \text{VEREF+ and } V_{R-} = \text{AVSS} \}$ $100b = \{V_{R+} = \text{AVCC and } V_{R-} = \text{VEREF-} \}$ $101b = \{V_{R+} = \text{VREF and } V_{R-} = \text{VEREF-} \}$ $110b = \{V_{R+} = \text{VEREF+ buffered and } V_{R-} = \text{VEREF-} \}$ $111b = \{V_{R+} = \text{VEREF+ and } V_{R-} = \text{VEREF-} \}$ $111b = \{V_{R+} = \text{VEREF+ and } V_{R-} = \text{VEREF-} \}$ | | 3-0 | ADCINCHX | RW | Oh | Input channel select. Writing these bits select the channel for a single-conversion or the highest channel for a sequence of conversions. Reading these bits in ADCCONSEQ = 01,11 returns the channel currently converted. Can be modified only when ADCENC = 0. Resetting ADCENC = 0 by software and changing these fields immediately shows an effect when a conversion is active. 0000b = A0 (see device-specific data sheet) 0001b = A1 (see device-specific data sheet) 0010b = A2 (see device-specific data sheet) 0010b = A3 (see device-specific data sheet) 0100b = A4 (see device-specific data sheet) 0101b = A5 (see device-specific data sheet) 0110b = A6 (see device-specific data sheet) 0111b = A7 (see device-specific data sheet) 1000b = A8 (see device-specific data sheet) 1001b = A9 (see device-specific data sheet) 1010b = A10 (see device-specific data sheet) 1011b = A11 (see device-specific data sheet) 1100b = A12 (see device-specific data sheet) 1101b = A13 (see device-specific data sheet) 1110b = A14 (see device-specific data sheet) 1110b = A14 (see device-specific data sheet) 1111b = A15 (see device-specific data sheet) | ## 21.3.7 ADCHI Register ADC Window Comparator High Threshold Register # Figure 21-27. ADCHI Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|--------|--------|---------|----------|--------|--------|--------| | | | | High_Th | hreshold | | | | | r0 | r0 | rO | rO | rw-(1) | rw-(1) | rw-(1) | rw-(1) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | High_Th | hreshold | | | | | rw-(1) # Table 21-9. ADCHI Register Description | Bit | Field | Туре | Reset | Description | |------|----------------|------|-------|-------------------------------------------------------------------------------------------------------------------------| | 15-0 | High_Threshold | RW | 3FFh | This data format is used when ADCDF = 0 (binary unsigned). The threshold value must be right justified. | | | | | | Bit 11 is the MSB. Bits 15–12 are 0 in 12-bit mode, bits 15–10 are 0 in 10-bit mode, and bits 15–8 are 0 in 8-bit mode. | # 21.3.8 ADCHI Register, 2s-Complement Format ADC Window Comparator High Threshold Register, 2s-Complement Format # Figure 21-28. ADCHI Register | | | | ga. 0 | o. 712 o 110g | , | | | |--------|--------|--------|---------|---------------|--------|--------|--------| | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | High_TI | hreshold | | | | | rw-(0) | rw-(1) | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | High_TI | hreshold | | | | | rw-(1) | rw-(1) | rw-(1) | rw-(1) | r0 | r0 | r0 | r0 | ## Table 21-10. ADCHI Register Description | Bit | Field | Туре | Reset | Description | |------|----------------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-0 | High_Threshold | RW | 1FFh | This data format is used when ADCDF = 1 (2s complement). The threshold value must be left justified. Bit 15 is the MSB. Bits 3–0 are 0 in 12-bit mode, bits 5–0 are 0 in 10-bit mode, and bits 7–0 are 0 in 8-bit mode. | ## 21.3.9 ADCLO Register ADC Window Comparator Low Threshold Register # Figure 21-29. ADCLO Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|--------|--------|--------|----------|--------|--------|--------| | | | | Low_Th | nreshold | | | | | r0 | r0 | r0 | r0 | rw-(0) | rw-(0) | rw-(0) | rw-(0) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | Low_Th | nreshold | | | | | rw-(0) ## Table 21-11. ADCLO Register Description | Bit | Field | Туре | Reset | Description | |------|---------------|------|-------|-------------------------------------------------------------------------------------------------------------------------| | 15-0 | Low_Threshold | RW | 0h | This data format is used if ADCDF = 0 (binary unsigned). The threshold value must be right justified. | | | | | | Bit 11 is the MSB. Bits 15–12 are 0 in 12-bit mode, bits 15–10 are 0 in 10-bit mode, and bits 15–8 are 0 in 8-bit mode. | # 21.3.10 ADCLO Register, 2s-Complement Format ADC Window Comparator Low Threshold Register, 2s-Complement Format ## Figure 21-30. ADCLO Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|--------|--------|--------|---------|--------|--------|--------| | | | | Low_Th | reshold | | | | | rw-(1) | rw-(0) | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | Low_Th | reshold | | | | | rw-(0) | rw-(0) | rw-(0) | rw-(0) | r0 | r0 | r0 | r0 | ## Table 21-12. ADCLO Register Description | Bit | Field | Туре | Reset | Description | |------|---------------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-0 | Low_Threshold | RW | 200h | This data format is used if ADCDF = 1 (2s complement). The threshold value must be left justified if 2s-complement format is chosen. Bit 15 is the MSB. Bits 3-0 are 0 in 12-bit mode, bits 5-0 are 0 in 10-bit mode, and bits 7-0 are 0 in 8-bit mode. | # 21.3.11 ADCIE Register # ADC Interrupt Enable Register # Figure 21-31. ADCIE Register # Table 21-13. ADCIE Register Description | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-6 | Reserved | R | 0h | Reserved. Always reads as 0. | | 5 | ADCTOVIE | RW | 0h | ADC conversion-time-overflow interrupt enable. 0b = Conversion-time overflow interrupt disabled 1b = Conversion-time overflow interrupt enabled | | 4 | ADCOVIE | RW | Oh | ADCMEM0 overflow interrupt enable. 0b = Overflow interrupt disabled 1b = Overflow interrupt enabled | | 3 | ADCHIIE | RW | Oh | Interrupt enable for the above upper threshold interrupt of the window comparator. 0b = Above upper threshold interrupt disabled 1b = Above upper threshold interrupt enabled | | 2 | ADCLOIE | RW | Oh | Interrupt enable for the below lower threshold interrupt of the window comparator. 0b = Below lower threshold interrupt disabled 1b = Below lower threshold interrupt enabled | | 1 | ADCINIE | RW | Oh | Interrupt enable for the inside of window interrupt of the window comparator. 0b = Inside of window interrupt disabled 1b = Inside of window interrupt enabled | | 0 | ADCIE0 | RW | Oh | Interrupt enable. This bits enable or disable the interrupt request for a completed ADC conversion. 0b = Interrupt disabled 1b = Interrupt enabled | # 21.3.12 ADCIFG Register ADC Interrupt Flag Register # Figure 21-32. ADCIFG Register # Table 21-14. ADCIFG Register Description | Bit | Field | Туре | Reset | Description | |------|-----------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-6 | Reserved | R | 0h | Reserved. Always reads as 0. | | 5 | ADCTOVIFG | RW | Oh | The ADCTOVIFG is set when an ADC conversion is triggered before the actual conversion has completed. 0b = No interrupt pending 1b = Interrupt pending | | 4 | ADCOVIFG | RW | Oh | The ADCOVIFG is set when the ADCMEM0 register is written before the last conversion result has been read. 0b = No interrupt pending 1b = Interrupt pending | | 3 | ADCHIIFG | RW | Oh | The ADCHIIFG is set when the result of the current ADC conversion is greater than the upper threshold defined by the window comparator upper threshold register. Ob = No interrupt pending 1b = Interrupt pending | | 2 | ADCLOIFG | RW | Oh | The ADCLOIFG is set when the result of the current ADC conversion is below the lower threshold defined by the window comparator lower threshold register. Ob = No interrupt pending 1b = Interrupt pending | | 1 | ADCINIFG | RW | Oh | The ADCINIFG is set when the result of the current ADC conversion is within the thresholds defined by the window comparator threshold registers. 0b = No interrupt pending 1b = Interrupt pending | | 0 | ADCIFG0 | RW | Oh | The ADCIFG0 is set when an ADC conversion is completed. This bit is reset when the ADCMEM0 get read, or it may be reset by software. 0b = No interrupt pending 1b = Interrupt pending | # 21.3.13 ADCIV Register ADC Interrupt Vector Register # Figure 21-33. ADCIV Register # Table 21-15. ADCIV Register Description | Bit | Field | Туре | Reset | Description | |------|--------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-0 | ADCIVx | R | Oh | ADC interrupt vector value. It generates an value that can be used as address offset for fast interrupt service routine handling. Writing to this register clears all pending interrupt flags. | | | | | | 00h = No interrupt pending | | | | | | 02h = Interrupt Source: ADCMEM0 overflow; Interrupt Flag: ADCOVIFG; Interrupt Priority: Highest | | | | | | 04h = Interrupt Source: Conversion time overflow; Interrupt Flag: ADCTOVIFG | | | | | | 06h = Interrupt Source: ADCHI Interrupt flag; Interrupt Flag: ADCHIIFG | | | | | | 08h = Interrupt Source: ADCLO Interrupt flag; Interrupt Flag: ADCLOIFG | | | | | | 0Ah = Interrupt Source: ADCIN Interrupt flag; Interrupt Flag: ADCINIFG | | | | | | 0Ch = Interrupt Source: ADC memory Interrupt flag; Interrupt Flag: ADCIFG0; Interrupt Priority: Lowest | # 21.3.14 MSP430FR413x SYSCFG2 Register (absolute address = 0164h) [reset = 0000h] System Configuration Register 2. In MSP430FR413x devices, the ADC pins are controlled by System Configuration Register 2. This is a mirror of the register description from SYS Chapter. ## Figure 21-34. SYSCFG2 Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------|----------|----------|----------|----------|----------|----------|----------| | | Reserved | | LCDPCTL | Reserved | Reserved | ADCPCTL9 | ADCPCTL8 | | r0 | r0 | rO | rw-0 | rO | rO | rw-0 | rw-0 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | ADCPCTL7 | ADCPCTL6 | ADCPCTL5 | ADCPCTL4 | ADCPCTL3 | ADCPCTL2 | ADCPCTL1 | ADCPCTL0 | | rw-0 ## Table 21-16. SYSCFG2 Register Description | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|-------------------------------------------------------------------------------------------------------------------| | 15-13 | Reserved | R | 0h | Reserved. Always read as 0. | | 12 | LCDPCTL | RW | Oh | LCD power pin (LCDCAP0, LCDCAP1, R13, R23, R33) control. 0b = LCD power pin disabled 1b = LCD power pin enabled | | 11-10 | Reserved | R | 0h | Reserved. Always read as 0. | | 9 | ADCPCTL9 | RW | Oh | ADC input A9 pin select 0b = ADC input A9 disabled 1b = ADC input A9 enabled | | 8 | ADCPCTL8 | RW | 0h | ADC input A8 pin select 0b = ADC input A8 disabled 1b = ADC input A8 enabled | | 7 | ADCPCTL7 | RW | 0h | ADC input A7 pin select 0b = ADC input A7 disabled 1b = ADC input A7 enabled | | 6 | ADCPCTL6 | RW | 0h | ADC input A6 pin select 0b = ADC input A6 disabled 1b = ADC input A6 enabled | | 5 | ADCPCTL5 | RW | 0h | ADC input A5 pin select 0b = ADC input A5 disabled 1b = ADC input A5 enabled | | 4 | ADCPCTL4 | RW | 0h | ADC input A4 pin select 0b = ADC input A4 disabled 1b = ADC input A4 enabled | | 3 | ADCPCTL3 | RW | 0h | ADC input A3 pin select 0b = ADC input A3 disabled 1b = ADC input A3 enabled | | 2 | ADCPCTL2 | RW | 0h | ADC input A2 pin select 0b = ADC input A2 disabled 1b = ADC input A2 enabled | | 1 | ADCPCTL1 | RW | 0h | ADC input A1 pin select 0b = ADC input A1 disabled 1b = ADC input A1 enabled | | 0 | ADCPCTL0 | RW | Oh | ADC input A0 pin select 0b = ADC input A0 disabled 1b = ADC input A0 enabled | # Enhanced Universal Serial Communication Interface (eUSCI) – UART Mode The enhanced universal serial communication interface A (eUSCI\_A) supports multiple serial communication modes with one hardware module. This chapter describes the operation of the asynchronous UART mode. Topic Page | 22.1 | Enhanced Universal Serial Communication Interface A (eUSCI_A) Overview | 575 | |------|------------------------------------------------------------------------|------------| | 22.2 | eUSCI_A Introduction – UART Mode | <b>575</b> | | 22.3 | eUSCI_A Operation – UART Mode | <b>577</b> | | 22.4 | eUSCI_A UART Registers | 592 | | | _ | | ## 22.1 Enhanced Universal Serial Communication Interface A (eUSCI\_A) Overview The eUSCI\_A module supports two serial communication modes: - UART mode - SPI mode #### 22.2 eUSCI A Introduction - UART Mode In asynchronous mode, the eUSCI\_Ax modules connect the device to an external system through two external pins, UCAxRXD and UCAxTXD. UART mode is selected when the UCSYNC bit is cleared. **UART** mode features include: - 7-bit or 8-bit data with odd, even, or no parity - Independent transmit and receive shift registers - Separate transmit and receive buffer registers - · LSB-first or MSB-first data transmit and receive - Built-in idle-line and address-bit communication protocols for multiprocessor systems - Receiver start-edge detection for automatic wake up from LPMx modes (wake up from LPMx.5 is not supported) - Programmable baud rate with modulation for fractional baud-rate support - Status flags for error detection and suppression - Status flags for address detection - Independent interrupt capability for receive, transmit, start bit received, and transmit complete Figure 22-1 shows the eUSCI\_Ax when configured for UART mode. Figure 22-1. eUSCI\_Ax Block Diagram - UART Mode (UCSYNC = 0) # 22.3 eUSCI\_A Operation – UART Mode In UART mode, the eUSCI\_A 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 of the eUSCI\_A. The transmit and receive functions use the same baud-rate frequency. # 22.3.1 eUSCI A Initialization and Reset The eUSCI\_A is reset by a PUC or by setting the UCSWRST bit. After a PUC, the UCSWRST bit is automatically set, keeping the eUSCI\_A in a reset condition. When set, the UCSWRST bit sets the UCTXIFG bit and resets the UCRXIE, UCTXIE, UCRXIFG, UCRXERR, UCBRK, UCPE, UCOE, UCFE, UCSTOE, and UCBTOE bits. Clearing UCSWRST releases the eUSCI\_A for operation. To avoid unpredictable behavior, configure or reconfigure the eUSCI\_A module when UCSWRST is set. #### NOTE: Initializing or reconfiguring the eUSCI\_A module The recommended eUSCI\_A initialization/reconfiguration process is: - 1. Set UCSWRST (BIS.B #UCSWRST, &UCAxCTL1). - 2. Initialize all eUSCI\_A registers while UCSWRST = 1 (including UCAxCTL1). - Configure ports. - 4. Clear UCSWRST by software (BIC.B #UCSWRST, &UCAxCTL1). - 5. Enable interrupts (optional) using UCRXIE or UCTXIE. #### 22.3.2 Character Format The UART character format (see Figure 22-2) consists of a start bit, seven or eight data bits, an even/odd/no parity bit, an address bit (address-bit mode), and one or two stop bits. The UCMSB bit controls the direction of the transfer and selects LSB or MSB first. LSB first is typically required for UART communication. Figure 22-2. Character Format #### 22.3.3 Asynchronous Communication Format When two devices communicate asynchronously, no multiprocessor format is required for the protocol. When three or more devices communicate, the eUSCI\_A supports the idle-line and address-bit multiprocessor communication formats. # 22.3.3.1 Idle-Line Multiprocessor Format When UCMODEx = 01, the idle-line multiprocessor format is selected. Blocks of data are separated by an idle time on the transmit or receive lines (see Figure 22-3). 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 UCIDLE bit is set. The first character received after an idle period is an address character. The UCIDLE 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. Figure 22-3. Idle-Line Format The UCDORM bit is used to control data reception in the idle-line multiprocessor format. When UCDORM = 1, all nonaddress characters are assembled but not transferred into the UCAxRXBUF, and interrupts are not generated. When an address character is received, the character is transferred into UCAxRXBUF, UCRXIFG is set, and any applicable error flag is set when UCRXEIE = 1. When UCRXEIE = 0 and an address character is received but has a framing error or parity error, the character is not transferred into UCAxRXBUF, and UCRXIFG is not set. If an address is received, user software can validate the address and must reset UCDORM to continue receiving data. If UCDORM remains set, only address characters are received. When UCDORM is cleared during the reception of a character, the receive interrupt flag is set after the reception completes. The UCDORM bit is not modified automatically by the eUSCI A hardware. For address transmission in idle-line multiprocessor format, a precise idle period can be generated by the eUSCI\_A to generate address character identifiers on UCAxTXD. The double-buffered UCTXADDR flag indicates if the next character loaded into UCAxTXBUF is preceded by an idle line of 11 bits. UCTXADDR is automatically cleared when the start bit is generated. #### 22.3.3.1.1 Transmitting an Idle Frame The following procedure sends out an idle frame to indicate an address character followed by associated data: - 1. Set UCTXADDR, then write the address character to UCAxTXBUF. UCAxTXBUF must be ready for new data (UCTXIFG = 1). - This generates an idle period of exactly 11 bits followed by the address character. UCTXADDR is reset automatically when the address character is transferred from UCAxTXBUF into the shift register. - Write desired data characters to UCAxTXBUF. UCAxTXBUF must be ready for new data (UCTXIFG = 1). The data written to UCAxTXBUF 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. #### 22.3.3.2 Address-Bit Multiprocessor Format When UCMODEx = 10, the address-bit multiprocessor format is selected. Each processed character contains an extra bit used as an address indicator (see Figure 22-4). The first character in a block of characters carries a set address bit that indicates that the character is an address. The eUSCI\_A UCADDR bit is set when a received character has its address bit set and is transferred to UCAxRXBUF. The UCDORM bit is used to control data reception in the address-bit multiprocessor format. When UCDORM is set, data characters with address bit = 0 are assembled by the receiver but are not transferred to UCAxRXBUF and no interrupts are generated. When a character containing a set address bit is received, the character is transferred into UCAxRXBUF, UCRXIFG is set, and any applicable error flag is set when UCRXEIE = 1. When UCRXEIE = 0 and a character containing a set address bit is received but has a framing error or parity error, the character is not transferred into UCAxRXBUF and UCRXIFG is not set. If an address is received, user software can validate the address and must reset UCDORM to continue receiving data. If UCDORM remains set, only address characters with address bit = 1 are received. The UCDORM bit is not modified by the eUSCI\_A hardware automatically. When UCDORM = 0, all received characters set the receive interrupt flag UCRXIFG. If UCDORM is cleared during the reception of a character, the receive interrupt flag is set after the reception is completed. For address transmission in address-bit multiprocessor mode, the address bit of a character is controlled by the UCTXADDR bit. The value of the UCTXADDR bit is loaded into the address bit of the character transferred from UCAxTXBUF to the transmit shift register. UCTXADDR is automatically cleared when the start bit is generated. Figure 22-4. Address-Bit Multiprocessor Format # 22.3.3.2.1 Break Reception and Generation When UCMODEx = 00, 01, or 10, the receiver detects a break when all data, parity, and stop bits are low, regardless of the parity, address mode, or other character settings. When a break is detected, the UCBRK bit is set. If the break interrupt enable bit (UCBRKIE) is set, the receive interrupt flag UCRXIFG is also set. In this case, the value in UCAxRXBUF is 0h, because all data bits were zero. To transmit a break, set the UCTXBRK bit, then write 0h to UCAxTXBUF. UCAxTXBUF must be ready for new data (UCTXIFG = 1). This generates a break with all bits low. UCTXBRK is automatically cleared when the start bit is generated. #### 22.3.4 Automatic Baud-Rate Detection When UCMODEx = 11, UART mode with automatic baud-rate detection is selected. For automatic baud-rate detection, a data frame is preceded by a synchronization sequence that consists of a break and a synch field. A break is detected when 11 or more continuous zeros (spaces) are received. If the length of the break exceeds 21 bit times, the break timeout error flag UCBTOE is set. The eUSCI\_A cannot transmit data while receiving the break/sync field. The synch field follows the break as shown in Figure 22-5. Figure 22-5. Auto Baud-Rate Detection - Break/Synch Sequence For LIN conformance, the character format should be set to eight data bits, LSB first, no parity, and one stop bit. No address bit is available. The synch field consists of the data 055h inside a byte field (see Figure 22-6). The synchronization is based on the time measurement between the first falling edge and the last falling edge of the pattern. The transmit baud-rate generator is used for the measurement if automatic baud-rate detection is enabled by setting UCABDEN. Otherwise, the pattern is received but not measured. The result of the measurement is transferred into the baud-rate control registers (UCAxBRW and UCAxMCTLW). If the length of the synch field exceeds the measurable time, the synch timeout error flag UCSTOE is set. The result can be read after the receive interrupt flag UCRXIFG is set. Figure 22-6. Auto Baud-Rate Detection – Synch Field The UCDORM bit is used to control data reception in this mode. When UCDORM is set, all characters are received but not transferred into the UCAxRXBUF, and interrupts are not generated. When a break/synch field is detected, the UCBRK flag is set. The character following the break/synch field is transferred into UCAxRXBUF and the UCRXIFG interrupt flag is set. Any applicable error flag is also set. If the UCBRKIE bit is set, reception of the break/synch sets the UCRXIFG. The UCBRK bit is reset by user software or by reading the receive buffer UCAxRXBUF. When a break/synch field is received, user software must reset UCDORM to continue receiving data. If UCDORM remains set, only the character after the next reception of a break/synch field is received. The UCDORM bit is not modified by the eUSCI\_A hardware automatically. When UCDORM = 0, all received characters set the receive interrupt flag UCRXIFG. If UCDORM is cleared during the reception of a character, the receive interrupt flag is set after the reception is complete. The counter used to detect the baud rate is limited to 0FFFFh (2<sup>16</sup>) counts. This means the minimum baud rate detectable is 244 baud in oversampling mode and 15 baud in low-frequency mode. The highest detectable baud rate is 1 Mbaud. The automatic baud-rate detection mode can be used in a full-duplex communication system with some restrictions. The eUSCI\_A cannot transmit data while receiving the break/sync field and, if a 0h byte with framing error is received, any data transmitted during this time is corrupted. The latter case can be discovered by checking the received data and the UCFE bit. # 22.3.4.1 Transmitting a Break/Synch Field The following procedure transmits a break/synch field: - 1. Set UCTXBRK with UMODEx = 11. - 2. Write 055h to UCAxTXBUF. UCAxTXBUF must be ready for new data (UCTXIFG = 1). This generates a break field of 13 bits followed by a break delimiter and the synch character. The length of the break delimiter is controlled with the UCDELIMx bits. UCTXBRK is reset automatically when the synch character is transferred from UCAxTXBUF into the shift register. Write desired data characters to UCAxTXBUF. UCAxTXBUF must be ready for new data (UCTXIFG = 1). The data written to UCAxTXBUF is transferred to the shift register and transmitted as soon as the shift register is ready for new data. # 22.3.5 IrDA Encoding and Decoding When UCIREN is set, the IrDA encoder and decoder are enabled and provide hardware bit shaping for IrDA communication. #### 22.3.5.1 IrDA Encoding The encoder sends a pulse for every zero bit in the transmit bit stream coming from the UART (see Figure 22-7). The pulse duration is defined by UCIRTXPLx bits specifying the number of one-half clock periods of the clock selected by UCIRTXCLK. Figure 22-7. UART vs IrDA Data Format To set the pulse time of 3/16 bit period required by the IrDA standard, the BITCLK16 clock is selected with UCIRTXCLK = 1, and the pulse length is set to six one-half clock cycles with UCIRTXPLx = 6 - 1 = 5. When UCIRTXCLK = 0, the pulse length t<sub>PULSE</sub> is based on BRCLK and is calculated as: UCIRTXPLx = $$t_{PULSE} \times 2 \times f_{BRCLK} - 1$$ When UCIRTXCLK = 0, the prescaler UCBRx must be set to a value greater or equal to 5. #### 22.3.5.2 IrDA Decoding The decoder detects high pulses when UCIRRXPL = 0. Otherwise, it detects low pulses. In addition to the analog deglitch filter, an additional programmable digital filter stage can be enabled by setting UCIRRXFE. When UCIRRXFE is set, only pulses longer than the programmed filter length are passed. Shorter pulses are discarded. The equation to program the filter length UCIRRXFLx is: UCIRRXFLx = $$(t_{PULSE} - t_{WAKE}) \times 2 \times f_{BRCLK} - 4$$ Where: t<sub>PULSE</sub> = Minimum receive pulse width $t_{\text{WAKE}}$ = Wake time from any low-power mode. Zero when the device is in active mode. #### 22.3.6 Automatic Error Detection Glitch suppression prevents the eUSCI\_A from being accidentally started. Any pulse on UCAxRXD shorter than the deglitch time $t_t$ (selected by UCGLITx) is ignored (see the device-specific data sheet for parameters). When a low period on UCAxRXD exceeds t<sub>t</sub>, a majority vote is taken for the start bit. If the majority vote fails to detect a valid start bit, the eUSCI\_A halts character reception and waits for the next low period on UCAxRXD. The majority vote is also used for each bit in a character to prevent bit errors. The eUSCI\_A module automatically detects framing errors, parity errors, overrun errors, and break conditions when receiving characters. The bits UCFE, UCPE, UCOE, and UCBRK are set when their respective condition is detected. When the error flags UCFE, UCPE, or UCOE are set, UCRXERR is also set. The error conditions are described in Table 22-1. **Error Condition Error Flag** Description A framing error occurs when a low stop bit is detected. When two stop bits are used, both **UCFE** Framing error stop bits are checked for framing error. When a framing error is detected, the UCFE bit is set. A parity error is a mismatch between the number of 1s in a character and the value of the UCPE Parity error 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 UCPE bit is set. An overrun error occurs when a character is loaded into UCAxRXBUF before the prior UCOE Receive overrun character has been read. When an overrun occurs, the UCOE bit is set. When not using automatic baud-rate detection, a break is detected when all data, parity, and **UCBRK** stop bits are low. When a break condition is detected, the UCBRK bit is set. A break condition Break condition can also set the interrupt flag UCRXIFG if the break interrupt enable UCBRKIE bit is set. Table 22-1. Receive Error Conditions When UCRXEIE = 0 and a framing error or parity error is detected, no character is received into UCAxRXBUF. When UCRXEIE = 1, characters are received into UCAxRXBUF and any applicable error bit is set. When any of the UCFE, UCPE, UCOE, UCBRK, or UCRXERR bit is set, the bit remains set until user software resets it or UCAxRXBUF is read. UCOE must be reset by reading UCAxRXBUF. Otherwise, it does not function properly. To detect overflows reliably, the following flow is recommended. After a character is received and UCAxRXIFG is set, first read UCAxSTATW to check the error flags including the overflow flag UCOE. Read UCAxRXBUF next. This clears all error flags except UCOE, if UCAxRXBUF was overwritten between the read access to UCAxSTATW and to UCAxRXBUF. Therefore, the UCOE flag should be checked after reading UCAxRXBUF to detect this condition. Note that, in this case, the UCRXERR flag is not set. #### 22.3.7 eUSCI A Receive Enable The eUSCI\_A module is enabled by clearing the UCSWRST bit and the receiver is ready and in an idle state. The receive baud rate generator is in a ready state but is not clocked nor producing any clocks. The falling edge of the start bit enables the baud rate generator and the UART state machine checks for a valid start bit. If no valid start bit is detected the UART state machine returns to its idle state and the baud rate generator is turned off again. If a valid start bit is detected, a character is received. When the idle-line multiprocessor mode is selected with UCMODEx = 01, the UART state machine checks for an idle line after receiving a character. If a start bit is detected, another character is received. Otherwise, the UCIDLE flag is set after 10 ones are received, the UART state machine returns to its idle state, and the baud rate generator is turned off. #### 22.3.7.1 Receive Data Glitch Suppression Glitch suppression prevents the eUSCI\_A from being accidentally started. Any glitch on UCAxRXD shorter than the deglitch time $t_t$ is ignored by the eUSCI\_A, and further action is initiated as shown in Figure 22-8 (see the device-specific data sheet for parameters). The deglitch time $t_t$ can be set to four different values using the UCGLITx bits. Figure 22-8. Glitch Suppression, eUSCI\_A Receive Not Started When a glitch is longer than t, or a valid start bit occurs on UCAxRXD, the eUSCI\_A receive operation is started and a majority vote is taken (see Figure 22-9). If the majority vote fails to detect a start bit, the eUSCI\_A halts character reception. Figure 22-9. Glitch Suppression, eUSCI\_A Activated # 22.3.8 eUSCI A Transmit Enable The eUSCI\_A module is enabled by clearing the UCSWRST bit and the transmitter is ready and in an idle state. The transmit baud-rate generator is ready but is not clocked nor producing any clocks. A transmission is initiated by writing data to UCAxTXBUF. When this occurs, the baud-rate generator is enabled, and the data in UCAxTXBUF is moved to the transmit shift register on the next BITCLK after the transmit shift register is empty. UCTXIFG is set when new data can be written into UCAxTXBUF. Transmission continues as long as new data is available in UCAxTXBUF at the end of the previous byte transmission. If new data is not in UCAxTXBUF when the previous byte has transmitted, the transmitter returns to its idle state and the baud-rate generator is turned off. #### 22.3.9 UART Baud-Rate Generation The eUSCI\_A baud-rate generator is capable of producing standard baud rates from nonstandard source frequencies. It provides two modes of operation selected by the UCOS16 bit. A quick setup for finding the correct baud rate settings for the eUSCI A can be found in Section 22.3.10. #### 22.3.9.1 Low-Frequency Baud-Rate Generation The low-frequency mode is selected when UCOS16 = 0. This mode allows generation of baud rates from low-frequency clock sources (for example, 9600 baud from a 32768-Hz crystal). By using a lower input frequency, the power consumption of the module is reduced. Using this mode with higher frequencies and higher prescaler settings causes the majority votes to be taken in an increasingly smaller window and, thus, decrease the benefit of the majority vote. In low-frequency mode, the baud-rate generator uses one prescaler and one modulator to generate bit clock timing. This combination supports fractional divisors for baud-rate generation. In this mode, the maximum eUSCI\_A baud rate is one-third the UART source clock frequency BRCLK. Timing for each bit is shown in Figure 22-10. For each bit received, a majority vote is taken to determine the bit value. These samples occur at the N/2 - 1/2, N/2, and N/2 + 1/2 BRCLK periods, where N is the number of BRCLKs per BITCLK. Figure 22-10. BITCLK Baud-Rate Timing With UCOS16 = 0 Modulation is based on the UCBRSx setting as shown in Table 22-2. A 1 in the table indicates that m = 1 and the corresponding BITCLK period is one BRCLK period longer than a BITCLK period with m = 0. The modulation wraps around after 8 bits but restarts with each new start bit. Bit 0 **UCBRS**x Bit 1 Bit 3 Bit 4 Bit 6 Bit 2 Bit 5 Bit 7 (Start Bit) 0x00 0 0 0 0 0 0 0 0 0x01 0 0 0 0 0 0 0 1 0x35 0 O 1 1 0 1 0 1 0x36 0 0 1 0 0 1 1 1 0x37 0 0 1 1 0 1 1 1 0xFF 1 1 1 1 1 1 1 1 **Table 22-2. Modulation Pattern Examples** The correct setting of UCBRSx can be found as described in Section 22.3.10. # 22.3.9.2 Oversampling Baud-Rate Generation The oversampling mode is selected when UCOS16 = 1. This mode supports sampling a UART bit stream with higher input clock frequencies. This results in majority votes that are always 1/16 of a bit clock period apart. This mode also easily supports IrDA pulses with a 3/16 bit time when the IrDA encoder and decoder are enabled. This mode uses one prescaler and one modulator to generate the BITCLK16 clock that is 16 times faster than the BITCLK. An additional divider by 16 and modulator stage generates BITCLK from BITCLK16. This combination supports fractional divisions of both BITCLK16 and BITCLK for baud-rate generation. In this mode, the maximum eUSCI\_A baud rate is 1/16 the UART source clock frequency BRCLK. Modulation for BITCLK16 is based on the UCBRFx setting (see Table 22-3). A 1 in the table indicates that the corresponding BITCLK16 period is one BRCLK period longer than the periods m = 0. The modulation restarts with each new bit timing. Modulation for BITCLK is based on the UCBRSx setting as previously described. Number of BITCLK16 Clocks After Last Falling BITCLK Edge **UCBRFx** 00h 01h 02h 03h 04h 05h 06h 07h 08h 09h 0Ah 0Bh 0Ch 0Dh 0Eh 0Fh Table 22-3. BITCLK16 Modulation Pattern #### 22.3.10 Setting a Baud Rate For a given BRCLK clock source, the baud rate used determines the required division factor N: $N = f_{BRCLK}/Baud Rate$ The division factor N is often a noninteger value, thus, at least one divider and one modulator stage is used to meet the factor as closely as possible. If N is equal or greater than 16, it is recommended to use the oversampling baud-rate generation mode by setting UCOS16. #### NOTE: Baud Rate settings quick set up To calculate the correct the correct settings for the baud rate generation, perform these steps: - 1. Calculate $N = f_{BRCLK}/Baud$ Rate [if N > 16 continue with step 3, otherwise with step 2] - 2. OS16 = 0, UCBRx = INT(N) [continue with step 4] - 3. OS16 = 1, UCBRx = INT(N/16), UCBRFx = $INT([(N/16) INT(N/16)] \times 16)$ - UCBRSx can be found by looking up the fractional part of N ( = N INT(N) ) in table Table 22-4 - 5. If OS16 = 0 was chosen, a detailed error calculation is recommended to be performed Table 22-4 can be used as a lookup table for finding the correct UCBRSx modulation pattern for the corresponding fractional part of N. The values there are optimized for transmitting. Table 22-4. UCBRSx Settings for Fractional Portion of N = f<sub>BRCLK</sub>/Baud Rate Fractional Portion of N UCBRSx<sup>(1)</sup> Fractional Portion of N UCBRSx<sup>(1)</sup> O 0000 000 | Fractional Portion of N | UCBRSx <sup>(1)</sup> | Fractional Portion of N | UCBRSx <sup>(1)</sup> | |-------------------------|-----------------------|-------------------------|-----------------------| | 0.0000 | 0x00 | 0.5002 | 0xAA | | 0.0529 | 0.0529 0x01 0.5715 | | 0x6B | | 0.0715 | 0x02 | 0.6003 | 0xAD | | 0.0835 | 0x04 | 0.6254 | 0xB5 | | 0.1001 | 0x08 | 0.6432 | 0xB6 | | 0.1252 | 0x10 | 0.6667 | 0xD6 | | 0.1430 | 0x20 | 0.7001 | 0xB7 | | 0.1670 | 0x11 | 0.7147 | 0xBB | | 0.2147 | 0x21 | 0.7503 | 0xDD | | 0.2224 | 0.2224 0x22 0.780 | | 0xED | | 0.2503 | 0x44 | 0.8004 | 0xEE | | 0.3000 | 0x25 | 0.8333 | 0xBF | | 0.3335 | 0x49 | 0.8464 | 0xDF | | 0.3575 | 0x4A | 0.8572 | 0xEF | | 0.3753 | 0x52 | 0.8751 | 0xF7 | | 0.4003 | 0x92 | 0.9004 | 0xFB | | 0.4286 | 0x53 | 0.9170 | 0xFD | | 0.4378 | 0x55 | 0.9288 | 0xFE | <sup>(1)</sup> The UCBRSx setting in one row is valid from the fractional portion given in that row until the one in the next row #### 22.3.10.1 Low-Frequency Baud-Rate Mode Setting In low-frequency mode, the integer portion of the divisor is realized by the prescaler: UCBRx = INT(N) The fractional portion is realized by the modulator with its UCBRSx setting. The recommended way of determining the correct UCBRSx is performing a detailed error calculation as explained in the following sections. However it is also possible to look up the correct settings in table with typical crystals (see Table 22-5). # 22.3.10.2 Oversampling Baud-Rate Mode Setting In the oversampling mode, the prescaler is set to: $$UCBRx = INT(N/16)$$ and the first stage modulator is set to: $$UCBRFx = INT([(N/16) - INT(N/16)] \times 16)$$ The second modulation stage setting (UCBRSx) can be found by performing a detailed error calculation or by using Table 22-4 and the fractional part of $N = f_{BRCLK}/Baud$ Rate. # 22.3.11 Transmit Bit Timing - Error calculation The timing for each character is the sum of the individual bit timings. Using the modulation features of the baud-rate generator reduces the cumulative bit error. The individual bit error can be calculated using the following steps. #### 22.3.11.1 Low-Frequency Baud-Rate Mode Bit Timing In low-frequency mode, calculation of the length of bit i $t_{bit,TX}[i]$ is based on the UCBRx and UCBRSx settings: $$t_{bit,TX}[i] = (1/f_{BRCLK})(UCBRx + m_{UCBRSx}[i])$$ Where: $m_{UCBRSx}[i] = Modulation of bit i of UCBRSx$ #### 22.3.11.2 Oversampling Baud-Rate Mode Bit Timing In oversampling baud-rate mode, calculation of the length of bit i $T_{bit,Tx}[i]$ is based on the baud-rate generator UCBRx, UCBRFx and UCBRSx settings: $$t_{\text{bit,TX}}[i] = \frac{1}{f_{\text{BRCLK}}} \left( (16 \times \text{UCBRx}) + \sum_{i=0}^{15} m_{\text{UCBRFx}}[i] + m_{\text{UCBRSx}}[i] \right)$$ Where: $$\leq \sum_{j=0}^{15} m_{\text{UCBRFx}}[j] = \text{Sum of ones from the corresponding row in Table 22-3}$$ $$m_{UCBRSx}[i] = Modulation of bit i of UCBRSx$$ This results in an end-of-bit time $t_{bit,TX}[i]$ equal to the sum of all previous and the current bit times: $$t_{bit,TX}[i] = \sum_{i=0}^{b} t_{bit,TX}[j]$$ To calculate bit error, this time is compared to the ideal bit time t<sub>bit ideal TX</sub>[i]: $$t_{bit,ideal,TX}[i] = (1/Baud Rate)(i + 1)$$ This results in an error normalized to one ideal bit time (1/baud rate): $$Error_{TX}[i] = (t_{bit,TX}[i] - t_{bit,ideal,TX}[i]) \times Baud Rate \times 100\%$$ # 22.3.12 Receive Bit Timing – Error Calculation Receive timing error consists of two error sources. The first is the bit-to-bit timing error similar to the transmit bit timing error. The second is the error between a start edge occurring and the start edge being accepted by the eUSCI\_A module. Figure 22-11 shows the asynchronous timing errors between data on the UCAxRXD pin and the internal baud-rate clock. This results in an additional synchronization error. The synchronization error $t_{\text{SYNC}}$ is between -0.5 BRCLKs and +0.5 BRCLKs, independent of the selected baud-rate generation mode. Figure 22-11. Receive Error The ideal sampling time t<sub>bit,ideal,RX</sub>[i] is in the middle of a bit period: $$t_{bit,ideal,RX}[i] = (1/Baud Rate)(i + 0.5)$$ The real sampling time, $t_{bit,RX}[i]$ , is equal to the sum of all previous bits according to the formulas shown in the transmit timing section, plus one-half BITCLK for the current bit i, plus the synchronization error $t_{SYNC}$ . This results in the following t<sub>bit,RX</sub>[i] for the low-frequency baud-rate mode: $$t_{_{DI,RX}}[i] = t_{_{SYNC}} + \sum_{i=0}^{i-1} T_{_{DI,RX}}[j] + \frac{1}{f_{_{RRCIK}}} \left( \mathsf{INT}(\frac{1}{2}\mathsf{UCBRx}) + m_{_{UCBRSx}}[i] \right)$$ Where: $t_{bit,RX}[i] = (1/f_{BRCLK})(UCBRx + m_{UCBRSx}[i])$ $m_{UCBRSx}[i] = Modulation of bit i of UCBRSx$ For the oversampling baud-rate mode, the sampling time t<sub>bit.RX</sub>[i] of bit i is calculated by: $$t_{\text{bit,RX}}[i] = t_{\text{SYNC}} + \sum_{i=0}^{i-1} T_{\text{bit,RX}}[j] + \frac{1}{f_{\text{BRCLK}}} \Big( (8 * \text{UCBRx}) + \sum_{i=0}^{7} \ m_{\text{UCBRFx}}[j] + m_{\text{UCBRSx}}[i] \Big)$$ Where: $$t_{\text{bit,RX}}[i] = \frac{1}{f_{\text{BRCLK}}} \left( (16 \times \text{UCBRx}) + \sum_{i=0}^{15} m_{\text{UCBRFx}}[i] + m_{\text{UCBRSx}}[i] \right)$$ $$\sum_{j=0}^{7+m_{\text{UCBRSx}}[i]} m_{\text{UCBRFx}}[j]$$ Table 22-3. = Sum of ones from columns 0 to $(7 + m_{UCBRSx}[i])$ from the corresponding row in $m_{UCBRSx}[i] = Modulation of bit i of UCBRSx$ This results in an error normalized to one ideal bit time (1/baud rate) according to the following formula: $Error_{RX}[i] = (t_{bit,RX}[i] - t_{bit,ideal,RX}[i]) \times Baud Rate \times 100\%$ #### 22.3.13 Typical Baud Rates and Errors Standard baud-rate data for UCBRx, UCBRSx, and UCBRFx are listed in Table 22-5 for a 32768-Hz crystal sourcing ACLK and typical SMCLK frequencies. Make sure that the selected BRCLK frequency does not exceed the device specific maximum eUSCI\_A input frequency (see the device-specific data sheet). The receive error is the accumulated time versus the ideal scanning time in the middle of each bit. The worst-case error is given for the reception of an 8-bit character with parity and one stop bit including synchronization error. The transmit error is the accumulated timing error versus the ideal time of the bit period. The worst-case error is given for the transmission of an 8-bit character with parity and stop bit. Table 22-5. Recommended Settings for Typical Crystals and Baud Rates<sup>(1)</sup> | BRCLK | Baud Rate | UCOS16 | UCBRx | UCBRFx | UCBRSx | TX Erro | or (%) <sup>(2)</sup> | RX Error (%) <sup>(2)</sup> | | |---------|-----------|--------|-------|--------|--------|---------|-----------------------|-----------------------------|-------| | BROLK | Baud Kale | 000310 | OCBAX | OCBREX | OCBROX | neg | pos | neg | pos | | 32768 | 1200 | 1 | 1 | 11 | 0x25 | -2.29 | 2.25 | -2.56 | 5.35 | | 32768 | 2400 | 0 | 13 | _ | 0xB6 | -3.12 | 3.91 | -5.52 | 8.84 | | 32768 | 4800 | 0 | 6 | - | 0xEE | -7.62 | 8.98 | -21 | 10.25 | | 32768 | 9600 | 0 | 3 | _ | 0x92 | -17.19 | 16.02 | -23.24 | 37.3 | | 1000000 | 9600 | 1 | 6 | 8 | 0x20 | -0.48 | 0.64 | -1.04 | 1.04 | | 1000000 | 19200 | 1 | 3 | 4 | 0x2 | -0.8 | 0.96 | -1.84 | 1.84 | | 1000000 | 38400 | 1 | 1 | 10 | 0x0 | 0 | 1.76 | 0 | 3.44 | | 1000000 | 57600 | 0 | 17 | - | 0x4A | -2.72 | 2.56 | -3.76 | 7.28 | | 1000000 | 115200 | 0 | 8 | - | 0xD6 | -7.36 | 5.6 | -17.04 | 6.96 | | 1048576 | 9600 | 1 | 6 | 13 | 0x22 | -0.46 | 0.42 | -0.48 | 1.23 | | 1048576 | 19200 | 1 | 3 | 6 | 0xAD | -0.88 | 0.83 | -2.36 | 1.18 | | 1048576 | 38400 | 1 | 1 | 11 | 0x25 | -2.29 | 2.25 | -2.56 | 5.35 | | 1048576 | 57600 | 0 | 18 | _ | 0x11 | -2 | 3.37 | -5.31 | 5.55 | | 1048576 | 115200 | 0 | 9 | _ | 0x08 | -5.37 | 4.49 | -5.93 | 14.92 | | 4000000 | 9600 | 1 | 26 | 0 | 0xB6 | -0.08 | 0.16 | -0.28 | 0.2 | | 4000000 | 19200 | 1 | 13 | 0 | 0x84 | -0.32 | 0.32 | -0.64 | 0.48 | | 4000000 | 38400 | 1 | 6 | 8 | 0x20 | -0.48 | 0.64 | -1.04 | 1.04 | | 4000000 | 57600 | 1 | 4 | 5 | 0x55 | -0.8 | 0.64 | -1.12 | 1.76 | | 4000000 | 115200 | 1 | 2 | 2 | 0xBB | -1.44 | 1.28 | -3.92 | 1.68 | | 4000000 | 230400 | 0 | 17 | _ | 0x4A | -2.72 | 2.56 | -3.76 | 7.28 | | 4194304 | 9600 | 1 | 27 | 4 | 0xFB | -0.11 | 0.1 | -0.33 | 0 | | 4194304 | 19200 | 1 | 13 | 10 | 0x55 | -0.21 | 0.21 | -0.55 | 0.33 | | 4194304 | 38400 | 1 | 6 | 13 | 0x22 | -0.46 | 0.42 | -0.48 | 1.23 | | 4194304 | 57600 | 1 | 4 | 8 | 0xEE | -0.75 | 0.74 | -2 | 0.87 | | 4194304 | 115200 | 1 | 2 | 4 | 0x92 | -1.62 | 1.37 | -3.56 | 2.06 | | 4194304 | 230400 | 0 | 18 | _ | 0x11 | -2 | 3.37 | -5.31 | 5.55 | | 8000000 | 9600 | 1 | 52 | 1 | 0x49 | -0.08 | 0.04 | -0.1 | 0.14 | | 8000000 | 19200 | 1 | 26 | 0 | 0xB6 | -0.08 | 0.16 | -0.28 | 0.2 | | 8000000 | 38400 | 1 | 13 | 0 | 0x84 | -0.32 | 0.32 | -0.64 | 0.48 | | 8000000 | 57600 | 1 | 8 | 10 | 0xF7 | -0.32 | 0.32 | -1 | 0.36 | | 8000000 | 115200 | 1 | 4 | 5 | 0x55 | -0.8 | 0.64 | -1.12 | 1.76 | | 8000000 | 230400 | 1 | 2 | 2 | 0xBB | -1.44 | 1.28 | -3.92 | 1.68 | | 8000000 | 460800 | 0 | 17 | _ | 0x4A | -2.72 | 2.56 | -3.76 | 7.28 | | 8388608 | 9600 | 1 | 54 | 9 | 0xEE | -0.06 | 0.06 | -0.11 | 0.13 | | 8388608 | 19200 | 1 | 27 | 4 | 0xFB | -0.11 | 0.1 | -0.33 | 0 | | 8388608 | 38400 | 1 | 13 | 10 | 0x55 | -0.21 | 0.21 | -0.55 | 0.33 | | 8388608 | 57600 | 1 | 9 | 1 | 0xB5 | -0.31 | 0.31 | -0.53 | 0.78 | | 8388608 | 115200 | 1 | 4 | 8 | 0xEE | -0.75 | 0.74 | -2 | 0.87 | <sup>(1)</sup> The listed UCBRSx settings are determined by a search algorithm for the lowest error. Other settings for UCBRSx might result in similar or same errors. <sup>(2)</sup> Assumes a stable clock source for BRCLK with negligible jitter (for example, from a crystal oscillator). Any frequency variation or jitter of the clock source will make the errors worse. Table 22-5. Recommended Settings for Typical Crystals and Baud Rates (1) (continued) | BRCLK | Baud Rate | UCOS16 | UCBRx | UCBRFx | UCBRSx | TX Erro | or (%) <sup>(2)</sup> | RX Erre | or (%) <sup>(2)</sup> | |----------|-----------|--------|-------|--------|--------|---------|-----------------------|---------|-----------------------| | DRCLK | Daud Rate | 000316 | UCBKX | UCBKFX | UCBROX | neg | pos | neg | pos | | 8388608 | 230400 | 1 | 2 | 4 | 0x92 | -1.62 | 1.37 | -3.56 | 2.06 | | 8388608 | 460800 | 0 | 18 | - | 0x11 | -2 | 3.37 | -5.31 | 5.55 | | 12000000 | 9600 | 1 | 78 | 2 | 0x0 | 0 | 0 | 0 | 0.04 | | 12000000 | 19200 | 1 | 39 | 1 | 0x0 | 0 | 0 | 0 | 0.16 | | 12000000 | 38400 | 1 | 19 | 8 | 0x65 | -0.16 | 0.16 | -0.4 | 0.24 | | 12000000 | 57600 | 1 | 13 | 0 | 0x25 | -0.16 | 0.32 | -0.48 | 0.48 | | 12000000 | 115200 | 1 | 6 | 8 | 0x20 | -0.48 | 0.64 | -1.04 | 1.04 | | 12000000 | 230400 | 1 | 3 | 4 | 0x2 | -0.8 | 0.96 | -1.84 | 1.84 | | 12000000 | 460800 | 1 | 1 | 10 | 0x0 | 0 | 1.76 | 0 | 3.44 | | 16000000 | 9600 | 1 | 104 | 2 | 0xD6 | -0.04 | 0.02 | -0.09 | 0.03 | | 16000000 | 19200 | 1 | 52 | 1 | 0x49 | -0.08 | 0.04 | -0.1 | 0.14 | | 16000000 | 38400 | 1 | 26 | 0 | 0xB6 | -0.08 | 0.16 | -0.28 | 0.2 | | 16000000 | 57600 | 1 | 17 | 5 | 0xDD | -0.16 | 0.2 | -0.3 | 0.38 | | 16000000 | 115200 | 1 | 8 | 10 | 0xF7 | -0.32 | 0.32 | -1 | 0.36 | | 16000000 | 230400 | 1 | 4 | 5 | 0x55 | -0.8 | 0.64 | -1.12 | 1.76 | | 16000000 | 460800 | 1 | 2 | 2 | 0xBB | -1.44 | 1.28 | -3.92 | 1.68 | | 16777216 | 9600 | 1 | 109 | 3 | 0xB5 | -0.03 | 0.02 | -0.05 | 0.06 | | 16777216 | 19200 | 1 | 54 | 9 | 0xEE | -0.06 | 0.06 | -0.11 | 0.13 | | 16777216 | 38400 | 1 | 27 | 4 | 0xFB | -0.11 | 0.1 | -0.33 | 0 | | 16777216 | 57600 | 1 | 18 | 3 | 0x44 | -0.16 | 0.15 | -0.2 | 0.45 | | 16777216 | 115200 | 1 | 9 | 1 | 0xB5 | -0.31 | 0.31 | -0.53 | 0.78 | | 16777216 | 230400 | 1 | 4 | 8 | 0xEE | -0.75 | 0.74 | -2 | 0.87 | | 16777216 | 460800 | 1 | 2 | 4 | 0x92 | -1.62 | 1.37 | -3.56 | 2.06 | | 20000000 | 9600 | 1 | 130 | 3 | 0x25 | -0.02 | 0.03 | 0 | 0.07 | | 20000000 | 19200 | 1 | 65 | 1 | 0xD6 | -0.06 | 0.03 | -0.1 | 0.1 | | 20000000 | 38400 | 1 | 32 | 8 | 0xEE | -0.1 | 0.13 | -0.27 | 0.14 | | 20000000 | 57600 | 1 | 21 | 11 | 0x22 | -0.16 | 0.13 | -0.16 | 0.38 | | 20000000 | 115200 | 1 | 10 | 13 | 0xAD | -0.29 | 0.26 | -0.46 | 0.66 | | 20000000 | 230400 | 1 | 5 | 6 | 0xEE | -0.67 | 0.51 | -1.71 | 0.62 | | 20000000 | 460800 | 1 | 2 | 11 | 0x92 | -1.38 | 0.99 | -1.84 | 2.8 | | | | | | | | | | | | # 22.3.14 Using the eUSCI\_A Module in UART Mode With Low-Power Modes The eUSCI\_A module provides automatic clock activation for use with low-power modes. When the eUSCI\_A clock source is inactive because the device is in a low-power mode, the eUSCI\_A module automatically activates it when needed, regardless of the control-bit settings for the clock source. The clock remains active until the eUSCI\_A module returns to its idle condition. After the eUSCI\_A module returns to the idle condition, control of the clock source reverts to the settings of its control bits. #### 22.3.15 eUSCI A Interrupts The eUSCI\_A has only one interrupt vector that is shared for transmission and for reception. # 22.3.15.1 eUSCI\_A Transmit Interrupt Operation The UCTXIFG interrupt flag is set by the transmitter to indicate that UCAxTXBUF is ready to accept another character. An interrupt request is generated if UCTXIE and GIE are also set. UCTXIFG is automatically reset if a character is written to UCAxTXBUF. UCTXIFG is set after a PUC or when UCSWRST = 1. UCTXIE is reset after a PUC or when UCSWRST = 1. # 22.3.15.2 eUSCI\_A Receive Interrupt Operation The UCRXIFG interrupt flag is set each time a character is received and loaded into UCAxRXBUF. An interrupt request is generated if UCRXIE and GIE are also set. UCRXIFG and UCRXIE are reset by a system reset PUC signal or when UCSWRST = 1. UCRXIFG is automatically reset when UCAxRXBUF is read. Additional interrupt control features include: - When UCRXEIE = 0, erroneous characters do not set UCRXIFG. - When UCDORM = 1, nonaddress characters do not set UCRXIFG in multiprocessor modes. In plain UART mode, no characters can set UCRXIFG. - When UCBRKIE = 1, a break condition sets the UCBRK bit and the UCRXIFG flag. #### 22.3.15.3 eUSCI\_A Receive Interrupt Operation Table 22-6 describes the UART state change interrupt flags. Table 22-6. UART State Change Interrupt Flags | Interrupt Flag | Interrupt Condition | |----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------| | UCSTTIFG | START byte received interrupt. This flag is set when the UART module receives a START byte. | | UCTXCPTIFG | Transmit complete interrupt. This flag is set, after the complete UART byte in the internal shift register including STOP bit got shifted out and UCAXTXBUF is empty. | #### 22.3.15.4 UCAxIV, Interrupt Vector Generator The eUSCI\_A interrupt flags are prioritized and combined to source a single interrupt vector. The interrupt vector register UCAxIV is used to determine which flag requested an interrupt. The highest-priority enabled interrupt generates a number in the UCAxIV register that can be evaluated or added to the program counter to automatically enter the appropriate software routine. Disabled interrupts do not affect the UCAxIV value. Read access of the UCAxIV register automatically resets the highest-pending Interrupt condition and flag. Write access of the UCAxIV register clears all pending Interrupt conditions and flags. If another interrupt flag is set, another interrupt is generated immediately after servicing the initial interrupt. Example 22-1 shows the recommended use of UCAxIV. The UCAxIV value is added to the PC to automatically jump to the appropriate routine. The following example is given for eUSCI\_A0. #### Example 22-1. UCAxIV Software Example # 22.4 eUSCI\_A UART Registers The eUSCI\_A registers applicable in UART mode and their address offsets are listed in Table 22-7. The base address can be found in the device-specific data sheet. Table 22-7. eUSCI\_A UART Registers | Offset | Acronym | Register Name | Туре | Access | Reset | Section | |--------|-------------------------|----------------------------------|------------|--------|-------|-----------------| | 00h | UCAxCTLW0 | eUSCI_Ax Control Word 0 | Read/write | Word | 0001h | Section 22.4.1 | | 01h | UCAxCTL0 <sup>(1)</sup> | eUSCI_Ax Control 0 | Read/write | Byte | 00h | | | 00h | UCAxCTL1 | eUSCI_Ax Control 1 | Read/write | Byte | 01h | | | 02h | UCAxCTLW1 | eUSCI_Ax Control Word 1 | Read/write | Word | 0003h | Section 22.4.2 | | 06h | UCAxBRW | eUSCI_Ax Baud Rate Control Word | Read/write | Word | 0000h | Section 22.4.3 | | 06h | UCAxBR0 <sup>(1)</sup> | eUSCI_Ax Baud Rate Control 0 | Read/write | Byte | 00h | | | 07h | UCAxBR1 | eUSCI_Ax Baud Rate Control 1 | Read/write | Byte | 00h | | | 08h | UCAxMCTLW | eUSCI_Ax Modulation Control Word | Read/write | Word | 00h | Section 22.4.4 | | 0Ah | UCAxSTATW | eUSCI_Ax Status | Read/write | Word | 00h | Section 22.4.5 | | 0Ch | UCAxRXBUF | eUSCI_Ax Receive Buffer | Read/write | Word | 00h | Section 22.4.6 | | 0Eh | UCAxTXBUF | eUSCI_Ax Transmit Buffer | Read/write | Word | 00h | Section 22.4.7 | | 10h | UCAxABCTL | eUSCI_Ax Auto Baud Rate Control | Read/write | Word | 00h | Section 22.4.8 | | 12h | UCAxIRCTL | eUSCI_Ax IrDA Control | Read/write | Word | 0000h | Section 22.4.9 | | 12h | UCAxIRTCTL | eUSCI_Ax IrDA Transmit Control | Read/write | Byte | 00h | | | 13h | UCAxIRRCTL | eUSCI_Ax IrDA Receive Control | Read/write | Byte | 00h | | | 1Ah | UCAxIE | eUSCI_Ax Interrupt Enable | Read/write | Word | 00h | Section 22.4.10 | | 1Ch | UCAxIFG | eUSCI_Ax Interrupt Flag | Read/write | Word | 02h | Section 22.4.11 | | 1Eh | UCAxIV | eUSCI_Ax Interrupt Vector | Read | Word | 0000h | Section 22.4.12 | <sup>(1)</sup> It is recommended to access these registers using 16-bit access. If 8-bit access is used, the corresponding bit names must be followed by "\_H". # 22.4.1 UCAxCTLW0 Register eUSCI\_Ax Control Word Register 0 # Figure 22-12. UCAxCTLW0 Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |-------|-------|---------|---------|--------|----------|---------|---------| | UCPEN | UCPAR | UCMSB | UC7BIT | UCSPB | UCM | ODEx | UCSYNC | | rw-0 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | UCS | SELx | UCRXEIE | UCBRKIE | UCDORM | UCTXADDR | UCTXBRK | UCSWRST | | rw-0 rw-1 | Modify only when UCSWRST = 1 # Table 22-8. UCAxCTLW0 Register Description | Bit | Field | Туре | Reset | Description | |------|---------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15 | UCPEN | RW | 0h | Parity enable 0b = Parity disabled 1b = Parity enabled. Parity bit is generated (UCAxTXD) and expected (UCAxRXD). In address-bit multiprocessor mode, the address bit is included in the parity calculation. | | 14 | UCPAR | RW | Oh | Parity select. UCPAR is not used when parity is disabled. 0b = Odd parity 1b = Even parity | | 13 | UCMSB | RW | Oh | MSB first select. Controls the direction of the receive and transmit shift register. 0b = LSB first 1b = MSB first | | 12 | UC7BIT | RW | Oh | Character length. Selects 7-bit or 8-bit character length. 0b = 8-bit data 1b = 7-bit data | | 11 | UCSPB | RW | Oh | Stop bit select. Number of stop bits. 0b = One stop bit 1b = Two stop bits | | 10-9 | UCMODEx | RW | Oh | eUSCI_A mode. The UCMODEx bits select the asynchronous mode when UCSYNC = 0. 00b = UART mode 01b = Idle-line multiprocessor mode 10b = Address-bit multiprocessor mode 11b = UART mode with automatic baud-rate detection | | 8 | UCSYNC | RW | 0h | Synchronous mode enable 0b = Asynchronous mode 1b = Synchronous mode | | 7-6 | UCSSELx | RW | 0h | eUSCI_A clock source select. These bits select the BRCLK source clock. 00b = UCLK 01b = Device specific 10b = SMCLK 11b = SMCLK | | 5 | UCRXEIE | RW | 0h | Receive erroneous-character interrupt enable 0b = Erroneous characters rejected and UCRXIFG is not set. 1b = Erroneous characters received set UCRXIFG. | | 4 | UCBRKIE | RW | Oh | Receive break character interrupt enable 0b = Received break characters do not set UCRXIFG. 1b = Received break characters set UCRXIFG. | # Table 22-8. UCAxCTLW0 Register Description (continued) | Bit | Field | Туре | Reset | Description | |-----|----------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 3 | UCDORM | RW | 0h | Dormant. Puts eUSCI_A into sleep mode. | | | | | | 0b = Not dormant. All received characters set UCRXIFG. | | | | | | 1b = Dormant. Only characters that are preceded by an idle-line or with address bit set UCRXIFG. In UART mode with automatic baud-rate detection, only the combination of a break and synch field sets UCRXIFG. | | 2 | UCTXADDR | RW | 0h | Transmit address. Next frame to be transmitted is marked as address, depending on the selected multiprocessor mode. | | | | | | 0b = Next frame transmitted is data. | | | | | | 1b = Next frame transmitted is an address. | | 1 | UCTXBRK | RW | 0h | Transmit break. Transmits a break with the next write to the transmit buffer. In UART mode with automatic baud-rate detection, 055h must be written into UCAxTXBUF to generate the required break/synch fields. Otherwise, 0h must be written into the transmit buffer. | | | | | | 0b = Next frame transmitted is not a break. | | | | | | 1b = Next frame transmitted is a break or a break/synch. | | 0 | UCSWRST | RW | 1h | Software reset enable | | | | | | 0b = Disabled. eUSCI_A reset released for operation. | | | | | | 1b = Enabled. eUSCI_A logic held in reset state. | # 22.4.2 UCAxCTLW1 Register eUSCI\_Ax Control Word Register 1 # Figure 22-13. UCAxCTLW1 Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |-----|-----|------|-------|-------|-----|------|-------| | | | | Rese | erved | | | | | r-0 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | Rese | erved | | | UCG | SLITx | | r-0 | r-0 | r-0 | r-0 | r-0 | r-0 | rw-1 | rw-1 | # Table 22-9. UCAxCTLW1 Register Description | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|----------------------------------------------------------------------------------------------------------------------------| | 15-2 | Reserved | R | 0h | Reserved | | 1-0 | UCGLITX | RW | 3h | Deglitch time 00b = Approximately 2 ns 01b = Approximately 50 ns 10b = Approximately 100 ns 11b = Approximately 200 ns | # 22.4.3 UCAxBRW Register eUSCI\_Ax Baud Rate Control Word Register # Figure 22-14. UCAxBRW Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----|----|----|-----|-----|----|----|----| | | | | UCI | BRx | | | | | rw | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | UCI | BRx | | | | | rw Modify only when UCSWRST = 1 # Table 22-10. UCAxBRW Register Description | Bit | Field | Туре | Reset | Description | |------|-------|------|-------|----------------------------------------------------| | 15-0 | UCBRx | RW | 0h | Clock prescaler setting of the Baud rate generator | # 22.4.4 UCAxMCTLW Register eUSCI\_Ax Modulation Control Word Register # Figure 22-15. UCAxMCTLW Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |------|------|------|------|------|----------|------|--------| | | | | UCE | BRSx | | | | | rw-0 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | UCE | BRFx | | | Reserved | | UCOS16 | | rw-0 | rw-0 | rw-0 | rw-0 | r0 | r0 | r0 | rw-0 | Modify only when UCSWRST = 1 # Table 22-11. UCAxMCTLW Register Description | Bit | Field | Type | Reset | Description | |------|----------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-8 | UCBRSx | RW | 0h | Second modulation stage select. These bits hold a free modulation pattern for BITCLK. | | 7-4 | UCBRFx | RW | 0h | First modulation stage select. These bits determine the modulation pattern for BITCLK16 when UCOS16 = 1. Ignored with UCOS16 = 0. The "Oversampling Baud-Rate Generation" section shows the modulation pattern. | | 3-1 | Reserved | R | 0h | Reserved | | 0 | UCOS16 | RW | 0h | Oversampling mode enabled 0b = Disabled 1b = Enabled | # 22.4.5 UCAxSTATW Register eUSCI\_Ax Status Register # Figure 22-16. UCAxSTATW Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------|------|------|------|-------|---------|------------------|--------| | | | | Rese | erved | | | | | r0 | r0 | r0 | r0 | r0 | rO | rO | rO | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | UCLISTEN | UCFE | UCOE | UCPE | UCBRK | UCRXERR | UCADDR<br>UCIDLE | UCBUSY | | rw-0 r-0 | Modify only when UCSWRST = 1. # Table 22-12. UCAxSTATW Register Description | Bit | Field | Type | Reset | Description | |------|---------------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-8 | Reserved | R | 0h | Reserved | | 7 | UCLISTEN | RW | 0h | Listen enable. The UCLISTEN bit selects loopback mode. 0b = Disabled 1b = Enabled. UCAxTXD is internally fed back to the receiver. | | 6 | UCFE | RW | 0h | Framing error flag. UCFE is cleared when UCAxRXBUF is read. 0b = No error 1b = Character received with low stop bit | | 5 | UCOE | RW | 0h | Overrun error flag. This bit is set when a character is transferred into UCAxRXBUF before the previous character was read. UCOE is cleared automatically when UCxRXBUF is read, and must not be cleared by software. Otherwise, it does not function correctly. 0b = No error 1b = Overrun error occurred. | | 4 | UCPE | RW | Oh | Parity error flag. When UCPEN = 0, UCPE is read as 0. UCPE is cleared when UCAxRXBUF is read. 0b = No error 1b = Character received with parity error | | 3 | UCBRK | RW | Oh | Break detect flag. UCBRK is cleared when UCAxRXBUF is read. 0b = No break condition 1b = Break condition occurred. | | 2 | UCRXERR | RW | Oh | Receive error flag. This bit indicates a character was received with one or more errors. When UCRXERR = 1, on or more error flags, UCFE, UCPE, or UCOE is also set. UCRXERR is cleared when UCAxRXBUF is read. 0b = No receive errors detected 1b = Receive error detected | | 1 | UCADDR UCIDLE | RW | 0h | UCADDR: Address received in address-bit multiprocessor mode. UCADDR is cleared when UCAxRXBUF is read. UCIDLE: Idle line detected in idle-line multiprocessor mode. UCIDLE is cleared when UCAxRXBUF is read. 0b = UCADDR: Received character is data. UCIDLE: No idle line detected 1b = UCADDR: Received character is an address. UCIDLE: Idle line detected | | 0 | UCBUSY | R | Oh | eUSCI_A busy. This bit indicates if a transmit or receive operation is in progress. 0b = eUSCI_A inactive 1b = eUSCI_A transmitting or receiving | # 22.4.6 UCAxRXBUF Register eUSCI\_Ax Receive Buffer Register # Figure 22-17. UCAxRXBUF Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |-----|-----|-----|------|-------|-----|-----|-----| | | | | Rese | erved | | | | | r-0 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | UCR) | (BUFx | | | | | r | r | r | r | r | r | r | r | # Table 22-13. UCAxRXBUF Register Description | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-8 | Reserved | R | 0h | Reserved | | 7-0 | UCRXBUFx | R | | The receive-data buffer is user accessible and contains the last received character from the receive shift register. Reading UCAxRXBUF resets the receive-error bits, the UCADDR or UCIDLE bit, and UCRXIFG. In 7-bit data mode, UCAxRXBUF is LSB justified and the MSB is always reset. | # 22.4.7 UCAxTXBUF Register eUSCI\_Ax Transmit Buffer Register # Figure 22-18. UCAxTXBUF Register | | | | • | | • | | | |-----|-----|-----|------|-------|-----|-----|-----| | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | Rese | erved | | | | | r-0 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | UCT | (BUFx | | | | | rw # Table 22-14. UCAxTXBUF Register Description | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-8 | Reserved | R | 0h | Reserved | | 7-0 | UCTXBUFx | RW | 0h | The transmit data buffer is user accessible and holds the data waiting to be moved into the transmit shift register and transmitted on UCAxTXD. Writing to the transmit data buffer clears UCTXIFG. The MSB of UCAxTXBUF is not used for 7-bit data and is reset. | # 22.4.8 UCAxABCTL Register eUSCI\_Ax Auto Baud Rate Control Register # Figure 22-19. UCAxABCTL Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |-----|-------|------|----------|-------|--------|----------|---------| | | | | Rese | erved | | | | | r-0 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Res | erved | UCDI | UCDELIMx | | UCBTOE | Reserved | UCABDEN | | r-0 | r-0 | rw-0 | rw-0 | rw-0 | rw-0 | r-0 | rw-0 | Modify only when UCSWRST = 1. # Table 22-15. UCAxABCTL Register Description | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|-------------------------------------------------------------------------------------------------------------------------------| | 15-6 | Reserved | R | 0h | Reserved | | 5-4 | UCDELIMx | RW | 0h | Break/synch delimiter length | | | | | | 00b = 1 bit time | | | | | | 01b = 2 bit times | | | | | | 10b = 3 bit times | | | | | | 11b = 4 bit times | | 3 | UCSTOE | RW | 0h | Synch field time out error | | | | | | 0b = No error | | | | | | 1b = Length of synch field exceeded measurable time. | | 2 | UCBTOE | RW | 0h | Break time out error | | | | | | 0b = No error | | | | | | 1b = Length of break field exceeded 22 bit times. | | 1 | Reserved | R | 0h | Reserved | | 0 | UCABDEN | RW | 0h | Automatic baud-rate detect enable | | | | | | 0b = Baud-rate detection disabled. Length of break and synch field is not measured. | | | | | | 1b = Baud-rate detection enabled. Length of break and synch field is measured and baud-rate settings are changed accordingly. | # 22.4.9 UCAxIRCTL Register eUSCI\_Ax IrDA Control Word Register # Figure 22-20. UCAxIRCTL Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |------|-----------|----------|----------|------|------|------|--------| | | | UCIRRXPL | UCIRRXFE | | | | | | rw-0 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | UCIRTXPLx | | | | | | UCIREN | | rw-0 Modify only when UCSWRST = 1. # Table 22-16. UCAxIRCTL Register Description | Bit | Field | Туре | Reset | Description | |-------|-----------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-10 | UCIRRXFLx | RW | 0h | Receive filter length. The minimum pulse length for receive is given by: $t_{MIN} = (UCIRRXFLx + 4) / (2 \times f_{IRTXCLK})$ | | 9 | UCIRRXPL | RW | Oh | IrDA receive input UCAxRXD polarity 0b = IrDA transceiver delivers a high pulse when a light pulse is seen. 1b = IrDA transceiver delivers a low pulse when a light pulse is seen. | | 8 | UCIRRXFE | RW | Oh | IrDA receive filter enabled 0b = Receive filter disabled 1b = Receive filter enabled | | 7-2 | UCIRTXPLx | RW | 0h | Transmit pulse length. Pulse length $t_{PULSE} = (UCIRTXPLx + 1) / (2 \times f_{IRTXCLK})$ | | 1 | UCIRTXCLK | RW | Oh | IrDA transmit pulse clock select 0b = BRCLK 1b = BITCLK16 when UCOS16 = 1. Otherwise, BRCLK. | | 0 | UCIREN | RW | Oh | IrDA encoder/decoder enable 0b = IrDA encoder/decoder disabled 1b = IrDA encoder/decoder enabled | # 22.4.10 UCAxIE Register eUSCI\_Ax Interrupt Enable Register # Figure 22-21. UCAxIE Register # **Table 22-17. UCAxIE Register Description** | Bit | Field | Туре | Reset | Description | |------|-----------|------|-------|-----------------------------------------------------------------------------------| | 15-4 | Reserved | R | 0h | Reserved | | 3 | UCTXCPTIE | RW | 0h | Transmit complete interrupt enable 0b = Interrupt disabled 1b = Interrupt enabled | | 2 | UCSTTIE | RW | 0h | Start bit interrupt enable 0b = Interrupt disabled 1b = Interrupt enabled | | 1 | UCTXIE | RW | 0h | Transmit interrupt enable 0b = Interrupt disabled 1b = Interrupt enabled | | 0 | UCRXIE | RW | 0h | Receive interrupt enable 0b = Interrupt disabled 1b = Interrupt enabled | # 22.4.11 UCAxIFG Register eUSCI\_Ax Interrupt Flag Register # Figure 22-22. UCAxIFG Register # Table 22-18. UCAxIFG Register Description | Bit | Field | Туре | Reset | Description | |------|------------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-4 | Reserved | R | 0h | Reserved | | 3 | UCTXCPTIFG | RW | 0h | Transmit ready interrupt flag. UCTXCPTIFG is set when the entire byte in the internal shift register is shifted out and UCAxTXBUF is empty. 0b = No interrupt pending 1b = Interrupt pending | | 2 | UCSTTIFG | RW | Oh | Start bit interrupt flag. UCSTTIFG is set after a Start bit was received 0b = No interrupt pending 1b = Interrupt pending | | 1 | UCTXIFG | RW | 1h | Transmit interrupt flag. UCTXIFG is set when UCAxTXBUF empty. 0b = No interrupt pending 1b = Interrupt pending | | 0 | UCRXIFG | RW | 0h | Receive interrupt flag. UCRXIFG is set when UCAxRXBUF has received a complete character. 0b = No interrupt pending 1b = Interrupt pending | # 22.4.12 UCAxIV Register eUSCI\_Ax Interrupt Vector Register # Figure 22-23. UCAxIV Register # **Table 22-19. UCAxIV Register Description** | Bit | Field | Туре | Reset | Description | | |------|-------|------|-------|---------------------------------------------------------------------------------------------------|--| | 15-0 | UCIVx | R | 0h | eUSCI_A interrupt vector value | | | | | | | 00h = No interrupt pending | | | | | | | 02h = Interrupt Source: Receive buffer full; Interrupt Flag: UCRXIFG; Interrupt Priority: Highest | | | | | | | 04h = Interrupt Source: Transmit buffer empty; Interrupt Flag: UCTXIFG | | | | | | | 06h = Interrupt Source: Start bit received; Interrupt Flag: UCSTTIFG | | | | | | | 08h = Interrupt Source: Transmit complete; Interrupt Flag: UCTXCPTIFG; Interrupt Priority: Lowest | | # Enhanced Universal Serial Communication Interface (eUSCI) – SPI Mode The enhanced universal serial communication interfaces, eUSCI\_A and eUSCI\_B, support multiple serial communication modes with one hardware module. This chapter describes the operation of the synchronous peripheral interface (SPI) mode. Topic Page | 23.1 | Enhanced Universal Serial Communication Interfaces (eUSCI_A, eUSCI_B) Overview | 604 | |------|---------------------------------------------------------------------------------|-----| | 23.2 | eUSCI Introduction – SPI Mode | 604 | | 23.3 | eUSCI Operation – SPI Mode | 606 | | 23.4 | eUSCI_A SPI Registers | 612 | | 23.5 | eUSCI_B SPI Registers | 619 | | | | | # 23.1 Enhanced Universal Serial Communication Interfaces (eUSCI\_A, eUSCI\_B) Overview Both the eUSCI\_A and the eUSCI\_B support serial communication in SPI mode. #### 23.2 eUSCI Introduction – SPI Mode In synchronous mode, the eUSCI connects the device to an external system through three or four pins: UCxSIMO, UCxSOMI, UCxCLK, and UCxSTE. SPI mode is selected when the UCSYNC bit is set, and SPI mode (3-pin or 4-pin) is selected with the UCMODEx bits. #### SPI mode features include: - · 7-bit or 8-bit data length - LSB-first or MSB-first data transmit and receive - 3-pin or 4-pin SPI operation - · Master or slave modes - Independent transmit and receive shift registers - Separate transmit and receive buffer registers - Continuous transmit and receive operation - · Selectable clock polarity and phase control - · Programmable clock frequency in master mode - · Independent interrupt capability for receive and transmit - Slave operation in LPM4 Figure 23-1 shows the eUSCI when configured for SPI mode. Figure 23-1. eUSCI Block Diagram - SPI Mode # 23.3 eUSCI Operation – SPI Mode In SPI mode, serial data is transmitted and received by multiple devices using a shared clock provided by the master. An additional pin controlled by the master, UCxSTE, is provided to enable a device to receive and transmit data. Three or four signals are used for SPI data exchange: UCxSIMO – slave in, master out Master mode: UCxSIMO is the data output line. Slave mode: UCxSIMO is the data input line. UCxSOMI – slave out, master in Master mode: UCxSOMI is the data input line. Slave mode: UCxSOMI is the data output line. UCxCLK – eUSCI SPI clock Master mode: UCxCLK is an output. Slave mode: UCxCLK is an input. UCxSTE – slave transmit enable Used in 4-pin mode to allow multiple masters on a single bus. Not used in 3-pin mode. Table 23-1 describes the UCxSTE operation. | UCMODEx | UCxSTE<br>Active State | UCxSTE | Slave | Master | |---------|------------------------|--------|----------|----------| | 01 | High | 0 | Inactive | Active | | | riigii | 1 | Active | Inactive | | 10 | Low | 0 | Active | Inactive | | | Low | 1 | Inactive | Active | Table 23-1. UCxSTE Operation #### 23.3.1 eUSCI Initialization and Reset The eUSCI is reset by a PUC or by the UCSWRST bit. After a PUC, the UCSWRST bit is automatically set, which keeps the eUSCI in a reset condition. When set, the UCSWRST bit resets the UCRXIE, UCTXIE, UCRXIFG, UCOE, and UCFE bits, and sets the UCTXIFG flag. Clearing UCSWRST releases the eUSCI for operation. To avoid unpredictable behavior, configure or reconfigure the eUSCI module when UCSWRST is set. #### NOTE: Initializing or reconfiguring the eUSCI module The recommended eUSCI initialization or reconfiguration process is: 1. Set UCSWRST. BIS.B #UCSWRST, &UCxCTL1 - Initialize all eUSCI registers while UCSWRST = 1 (including UCxCTL1). - 3. Configure ports. - 4. Clear UCSWRST in software. BIC.B #UCSWRST,&UCxCTL1 5. Enable interrupts (optional) by setting UCRXIE or UCTXIE. #### 23.3.2 Character Format The eUSCI module in SPI mode supports 7-bit and 8-bit character lengths selected by the UC7BIT bit. In 7-bit data mode, UCxRXBUF is LSB justified and the MSB is always reset. The UCMSB bit controls the direction of the transfer and selects LSB or MSB first. # NOTE: Default character format The default SPI character transmission is LSB first. For communication with other SPI interfaces, MSB first mode may be required. NOTE: Character format for figures Figures throughout this chapter use MSB first format. #### 23.3.3 Master Mode Figure 23-2 shows the eUSCI as a master in both 3-pin and 4-pin configurations. Figure 23-2. eUSCI Master and External Slave (UCSTEM = 0) The eUSCI initiates data transfer when data is moved to the transmit data buffer UCxTXBUF. The UCxTXBUF data is moved to the transmit (TX) shift register when the TX shift register is empty, initiating data transfer on UCxSIMO starting with either the MSB or LSB, depending on the UCMSB setting. Data on UCxSOMI is shifted into the receive shift register on the opposite clock edge. When the character is received, the receive data is moved from the receive (RX) shift register to the received data buffer UCxRXBUF and the receive interrupt flag UCRXIFG is set, indicating that the RX or TX operation is complete. A set transmit interrupt flag, UCTXIFG, indicates that data has moved from UCxTXBUF to the TX shift register and UCxTXBUF is ready for new data. It does not indicate RX or TX completion. To receive data into the eUSCI in master mode, data must be written to UCxTXBUF, because receive and transmit operations operate concurrently. There two different options for configuring the eUSCI as a 4-pin master, which are described in the following sections: - The fourth pin is used as input to prevent conflicts with other masters (UCSTEM = 0). - The fourth pin is used as output to generate a slave enable signal (UCSTEM = 1). The bit UCSTEM is used to select the corresponding mode. #### 23.3.3.1 4-Pin SPI Master Mode (UCSTEM = 0) In 4-pin master mode with UCSTEM = 0, UCxSTE is a digital input that can be used to prevent conflicts with another master and controls the master as described in Table 23-1. When UCxSTE is in the master-inactive state and UCSTEM = 0: - UCxSIMO and UCxCLK are set to inputs and no longer drive the bus. - The error bit UCFE is set, indicating a communication integrity violation to be handled by the user. - The internal state machines are reset and the shift operation is aborted. If data is written into UCxTXBUF while the master is held inactive by UCxSTE, it is transmit as soon as UCxSTE transitions to the master-active state. If an active transfer is aborted by UCxSTE transitioning to the master-inactive state, the data must be rewritten into UCxTXBUF to be transferred when UCxSTE transitions back to the master-active state. The UCxSTE input signal is not used in 3-pin master mode. # 23.3.3.2 4-Pin SPI Master Mode (UCSTEM = 1) If UCSTEM = 1 in 4-pin master mode, UCxSTE is a digital output. In this mode the slave enable signal for a single slave is automatically generated on UCxSTE. The corresponding behavior can be seen in Figure 23-4. If multiple slaves are desired, this feature is not applicable and the software needs to use general-purpose I/O pins instead to generate STE signals for each slave individually. #### 23.3.4 Slave Mode Figure 23-3 shows the eUSCI as a slave in both 3-pin and 4-pin configurations. Figure 23-3. eUSCI Slave and External Master UCxCLK is used as the input for the SPI clock and must be supplied by the external master. The data-transfer rate is determined by this clock and not by the internal bit clock generator. Data written to UCxTXBUF and moved to the TX shift register before the start of UCxCLK is transmitted on UCxSOMI. Data on UCxSIMO is shifted into the receive shift register on the opposite edge of UCxCLK and moved to UCxRXBUF when the set number of bits are received. When data is moved from the RX shift register to UCxRXBUF, the UCRXIFG interrupt flag is set, indicating that data has been received. The overrun error bit UCOE is set when the previously received data is not read from UCxRXBUF before new data is moved to UCxRXBUF. # 23.3.4.1 4-Pin SPI Slave Mode In 4-pin slave mode, UCxSTE is a digital input used by the slave to enable the transmit and receive operations and is driven by the SPI master. When UCxSTE is in the slave-active state, the slave operates normally. When UCxSTE is in the slave- inactive state: - Any receive operation in progress on UCxSIMO is halted. - UCxSOMI is set to the input direction. - The shift operation is halted until the UCxSTE line transitions into the slave transmit active state. The UCxSTE input signal is not used in 3-pin slave mode. #### 23.3.5 SPI Enable When the eUSCI module is enabled by clearing the UCSWRST bit, it is ready to receive and transmit. In master mode, the bit clock generator is ready, but is not clocked nor producing any clocks. In slave mode, the bit clock generator is disabled and the clock is provided by the master. A transmit or receive operation is indicated by UCBUSY = 1. A PUC or set UCSWRST bit disables the eUSCI immediately and any active transfer is terminated. #### 23.3.5.1 Transmit Enable In master mode, writing to UCxTXBUF activates the bit clock generator, and the data begins to transmit. In slave mode, transmission begins when a master provides a clock and, in 4-pin mode, when the UCxSTE is in the slave-active state. #### 23.3.5.2 Receive Enable The SPI receives data when a transmission is active. Receive and transmit operations operate concurrently. # 23.3.6 Serial Clock Control UCxCLK is provided by the master on the SPI bus. When UCMST = 1, the bit clock is provided by the eUSCI bit clock generator on the UCxCLK pin. The clock used to generate the bit clock is selected with the UCSSELx bits. When UCMST = 0, the eUSCI clock is provided on the UCxCLK pin by the master, the bit clock generator is not used, and the UCSSELx bits are don't care. The SPI receiver and transmitter operate in parallel and use the same clock source for data transfer. The 16-bit value of UCBRx in the bit rate control registers UCxxBRW is the division factor of the eUSCI clock source, BRCLK. With UCBRx = 0 the maximum bit clock that can be generated in master mode is BRCLK. Modulation is not used in SPI mode, and UCAxMCTL should be cleared when using SPI mode for eUSCI A. The UCAxCLK or UCBxCLK frequency is given by Equation 15. $$f_{BitClock} = f_{BRCLK} / UCBRx$$ (15) When UCBRx = 0, no division is applied to BRCLK, and the bit clock equals BRCLK ( $f_{RifClock} = f_{RRCLK}$ ). Even UCBRx settings result in even divisions and, thus, generate a bit clock with a 50/50 duty cycle. Odd UCBRx settings result in odd divisions. In this case, the high phase of the bit clock is one BRCLK cycle longer than the low phase. #### 23.3.6.1 Serial Clock Polarity and Phase The polarity and phase of UCxCLK are independently configured with the UCCKPL and UCCKPH control bits of the eUSCI. Timing for each case is shown in Figure 23-4. Figure 23-4. eUSCI SPI Timing With UCMSB = 1 #### 23.3.7 Using the SPI Mode With Low-Power Modes The eUSCI module provides automatic clock activation for use with low-power modes. When the eUSCI clock source is inactive because the device is in a low-power mode, the eUSCI module automatically activates it when needed, regardless of the control-bit settings for the clock source. The clock remains active until the eUSCI module returns to its idle condition. After the eUSCI module returns to the idle condition, control of the clock source reverts to the settings of its control bits. In SPI slave mode, no internal clock source is required because the clock is provided by the external master. It is possible to operate the eUSCI in SPI slave mode while the device is in LPM4 and all clock sources are disabled. The receive or transmit interrupt can wake up the CPU from any low-power mode. When receiving multiple bytes as a slave in LPM4, the wake-up time of the CPU must be considered. If the wake-up time of the CPU is, for example, 150 $\mu$ s (see device-specific data-sheet), make sure that the CPU services the TXIFG of the first received byte before the second byte is completely received by the eUSCI\_A or eUSCI\_B. Otherwise an overrun error occurs. # NOTE: SPI mode in low-power modes When RXIFG is generated during a low-power mode, the MCU needs the specified time to wake up from the low-power mode to active mode and handle this event. To avoid missing an event, TI recommends that the next RXIFG is generated until after this wake up time. See the device-specific data sheet for the wake-up time details. # 23.3.8 SPI Interrupts The eUSCI has only one interrupt vector that is shared for transmission and for reception. eUSCI\_Ax and eUSCI\_Bx do not share the same interrupt vector. # 23.3.8.1 SPI Transmit Interrupt Operation The UCTXIFG interrupt flag is set by the transmitter to indicate that UCxTXBUF is ready to accept another character. An interrupt request is generated if UCTXIE and GIE are also set. UCTXIFG is automatically reset if a character is written to UCxTXBUF. UCTXIFG is set after a PUC or when UCSWRST = 1. UCTXIE is reset after a PUC or when UCSWRST = 1. NOTE: Writing to UCxTXBUF in SPI mode Data written to UCxTXBUF when UCTXIFG = 0 may result in erroneous data transmission. #### 23.3.8.2 SPI Receive Interrupt Operation The UCRXIFG interrupt flag is set each time a character is received and loaded into UCxRXBUF. An interrupt request is generated if UCRXIE and GIE are also set. UCRXIFG and UCRXIE are reset by a system reset PUC signal or when UCSWRST = 1. UCRXIFG is automatically reset when UCxRXBUF is read. #### 23.3.8.3 UCxIV, Interrupt Vector Generator The eUSCI interrupt flags are prioritized and combined to source a single interrupt vector. The interrupt vector register UCxIV is used to determine which flag requested an interrupt. The highest-priority enabled interrupt generates a number in the UCxIV register that can be evaluated or added to the program counter (PC) to automatically enter the appropriate software routine. Disabled interrupts do not affect the UCxIV value. Any access, read or write, of the UCxIV register automatically resets the highest-pending interrupt flag. If another interrupt flag is set, another interrupt is immediately generated after servicing the initial interrupt. #### 23.3.8.3.1 UCxIV Software Example The following software example shows the recommended use of UCxIV. The UCxIV value is added to the PC to automatically jump to the appropriate routine. The following example is given for eUSCI\_B0. ``` USCI_SPI_ISR &UCBOIV, PC ; Add offset to jump table ADD RETI ; Vector 0: No interrupt JMP RXIFG_ISR ; Vector 2: RXIFG TXIFG_ISR ; Vector 4: TXIFG ; Task starts here . . . RETT ; Return RXIFG_ISR ; Vector 2 ; Task starts here RETI ; Return ``` eUSCI\_A SPI Registers www.ti.com # 23.4 eUSCI\_A SPI Registers The eUSCI\_A registers applicable in SPI mode and their address offsets are listed in Table 23-2. The base addresses can be found in the device-specific data sheet. Table 23-2. eUSCI\_A SPI Registers | Offset | Acronym | Register Name | Туре | Access | Reset | Section | |--------|-----------|--------------------------------|------------|--------|-------|----------------| | 00h | UCAxCTLW0 | eUSCI_Ax Control Word 0 | Read/write | Word | 0001h | Section 23.4.1 | | 00h | UCAxCTL1 | eUSCI_Ax Control 1 | Read/write | Byte | 01h | | | 01h | UCAxCTL0 | eUSCI_Ax Control 0 | Read/write | Byte | 00h | | | 06h | UCAxBRW | eUSCI_Ax Bit Rate Control Word | Read/write | Word | 0000h | Section 23.4.2 | | 06h | UCAxBR0 | eUSCI_Ax Bit Rate Control 0 | Read/write | Byte | 00h | | | 07h | UCAxBR1 | eUSCI_Ax Bit Rate Control 1 | Read/write | Byte | 00h | | | 0Ah | UCAxSTATW | eUSCI_Ax Status | Read/write | Word | 00h | Section 23.4.3 | | 0Ch | UCAxRXBUF | eUSCI_Ax Receive Buffer | Read/write | Word | 00h | Section 23.4.4 | | 0Eh | UCAxTXBUF | eUSCI_Ax Transmit Buffer | Read/write | Word | 00h | Section 23.4.5 | | 1Ah | UCAxIE | eUSCI_Ax Interrupt Enable | Read/write | Word | 00h | Section 23.4.6 | | 1Ch | UCAxIFG | eUSCI_Ax Interrupt Flag | Read/write | Word | 02h | Section 23.4.7 | | 1Eh | UCAxIV | eUSCI_Ax Interrupt Vector | Read | Word | 0000h | Section 23.4.8 | www.ti.com # 23.4.1 UCAxCTLW0 Register eUSCI\_Ax Control Register 0 ## Figure 23-5. UCAxCTLW0 Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|--------|-------|--------|-------|------|--------|---------| | UCCKPH | UCCKPL | UCMSB | UC7BIT | UCMST | UCM | ODEx | UCSYNC | | rw-0 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | UCS | SELx | | Rese | erved | | UCSTEM | UCSWRST | | rw-0 rw-1 | Modify only when UCSWRST = 1. # Table 23-3. UCAxCTLW0 Register Description | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15 | UCCKPH | RW | Oh | Clock phase select. Modify only when UCSWRST = 1. 0b = Data is changed on the first UCLK edge and captured on the following edge. 1b = Data is captured on the first UCLK edge and changed on the following edge. | | 14 | UCCKPL | RW | Oh | Clock polarity select. Modify only when UCSWRST = 1. 0b = The inactive state is low. 1b = The inactive state is high. | | 13 | UCMSB | RW | Oh | MSB first select. Controls the direction of the receive and transmit shift register. Modify only when UCSWRST = 1. 0b = LSB first 1b = MSB first | | 12 | UC7BIT | RW | Oh | Character length. Selects 7-bit or 8-bit character length. Modify only when UCSWRST = 1. 0b = 8-bit data 1b = 7-bit data | | 11 | UCMST | RW | Oh | Master mode select. Modify only when UCSWRST = 1. 0b = Slave mode 1b = Master mode | | 10-9 | UCMODEx | RW | 0h | eUSCI mode. The UCMODEx bits select the synchronous mode when UCSYNC = 1. Modify only when UCSWRST = 1. 00b = 3-pin SPI 01b = 4-pin SPI with UCxSTE active high: Slave enabled when UCxSTE = 1 10b = 4-pin SPI with UCxSTE active low: Slave enabled when UCxSTE = 0 11b = I2C mode | | 8 | UCSYNC | RW | Oh | Synchronous mode enable. Modify only when UCSWRST = 1. 0b = Asynchronous mode 1b = Synchronous mode | | 7-6 | UCSSELx | RW | 0h | eUSCI clock source select. These bits select the BRCLK source clock in master mode. UCxCLK is always used in slave mode. Modify only when UCSWRST = 1. 00b = Reserved 01b = Device specific 10b = SMCLK 11b = SMCLK | | 5-2 | Reserved | R | 0h | Reserved | | 1 | UCSTEM | RW | Oh | STE mode select in master mode. This byte is ignored in slave or 3-wire mode. Modify only when UCSWRST = 1. 0b = STE pin is used to prevent conflicts with other masters 1b = STE pin is used to generate the enable signal for a 4-wire slave | eUSCI\_A SPI Registers www.ti.com # Table 23-3. UCAxCTLW0 Register Description (continued) | Bit | Field | Туре | Reset | Description | |-----|---------|------|-------|----------------------------------------------------| | 0 | UCSWRST | RW | 1h | Software reset enable | | | | | | 0b = Disabled. eUSCI reset released for operation. | | | | | | 1b = Enabled. eUSCI logic held in reset state. | # 23.4.2 UCAxBRW Register eUSCI\_Ax Bit Rate Control Register 1 ## Figure 23-6. UCAxBRW Register | | | | | | 9 | | | |----|----|----|-----|-----|----|----|----| | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | UCI | BRx | | | | | rw | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | UCI | BRx | | | | | rw Modify only when UCSWRST = 1. ## Table 23-4. UCAxBRW Register Description | Bit | Field | Туре | Reset | Description | |------|-------|------|-------|------------------------------------------------------------| | 15-0 | UCBRx | RW | 0h | Bit clock prescaler setting. Modify only when UCSWRST = 1. | | | | | | $f_{BitClock} = f_{BRCLK} / UCBRx$ | | | | | | If UCBRx = 0, $f_{BitClock} = f_{BRCLK}$ | # 23.4.3 UCAxSTATW Register eUSCI\_Ax Status Register ## Figure 23-7. UCAxSTATW Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------|------|------|------|-------|-------|------|--------| | - | | | Rese | erved | | | - | | r0 | r0 | r0 | r0 | rO | r0 | r0 | r0 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | UCLISTEN | UCFE | UCOE | | Rese | erved | | UCBUSY | | rw-0 r-0 | Modify only when UCSWRST = 1. # Table 23-5. UCAxSTATW Register Description | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-8 | Reserved | R | 0h | Reserved | | 7 | UCLISTEN | RW | 0h | Listen enable. The UCLISTEN bit selects loopback mode. Modify only when UCSWRST = 1. | | | | | | 0b = Disabled | | | | | | 1b = Enabled. The transmitter output is internally fed back to the receiver. | | 6 | UCFE | RW | 0h | Framing error flag. This bit indicates a bus conflict in 4-wire master mode. UCFE is not used in 3-wire master or any slave mode. | | | | | | 0b = No error | | | | | | 1b = Bus conflict occurred | | 5 | UCOE | RW | Oh | Overrun error flag. This bit is set when a character is transferred into UCxRXBUF before the previous character was read. UCOE is cleared automatically when UCxRXBUF is read and must not be cleared by software. Otherwise, it does not function correctly. | | | | | | 0b = No error | | | | | | 1b = Overrun error occurred | | 4-1 | Reserved | RW | 0h | Reserved | | 0 | UCBUSY | R | 0h | eUSCI busy. This bit indicates if a transmit or receive operation is in progress. | | | | | | 0b = eUSCI inactive | | | | | | 1b = eUSCI transmitting or receiving | eUSCI\_A SPI Registers www.ti.com # 23.4.4 UCAxRXBUF Register eUSCI\_Ax Receive Buffer Register # Figure 23-8. UCAxRXBUF Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | |----|----------|----|------|-------|----|----|----|--|--|--| | | | | Rese | erved | | | | | | | | r0 | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | UCRXBUFx | | | | | | | | | | | rw | | | ## Table 23-6. UCAxRXBUF Register Description | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-8 | Reserved | R | 0h | Reserved | | 7-0 | UCRXBUFx | R | Oh | The receive-data buffer is user accessible and contains the last received character from the receive shift register. Reading UCxRXBUF resets the receive-error bits and UCRXIFG. In 7-bit data mode, UCxRXBUF is LSB justified and the MSB is always reset. | # 23.4.5 UCAxTXBUF Register eUSCI\_Ax Transmit Buffer Register ## Figure 23-9. UCAxTXBUF Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | |----|----------|----|------|-------|----|----|----|--|--|--| | | | | Rese | erved | | | | | | | | r0 | r0 | rO | rO | rO | r0 | rO | r0 | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | UCTXBUFx | | | | | | | | | | | rw | | | ## Table 23-7. UCAxTXBUF Register Description | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-8 | Reserved | R | 0h | Reserved | | 7-0 | UCTXBUFx | RW | Oh | The transmit data buffer is user accessible and holds the data waiting to be moved into the transmit shift register and transmitted. Writing to the transmit data buffer clears UCTXIFG. The MSB of UCxTXBUF is not used for 7-bit data and is reset. | www.ti.com eUSCI\_A SPI Registers # 23.4.6 UCAxIE Register eUSCI\_Ax Interrupt Enable Register ## Figure 23-10. UCAxIE Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |-----|----------|-----|------|-------|-----|------|------| | | | | Rese | erved | | | | | r0 | rO | rO | rO | r0 | rO | r0 | rO | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | Reserved | | | | | | | | r-0 | r-0 | r-0 | r-0 | r-0 | r-0 | rw-0 | rw-0 | ## Table 23-8. UCAxIE Register Description | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|---------------------------------------------------------------------------| | 15-2 | Reserved | R | 0h | Reserved | | 1 | UCTXIE | RW | 0h | Transmit interrupt enable 0b = Interrupt disabled 1b = Interrupt enabled | | 0 | UCRXIE | RW | 0h | Receive interrupt enable 0b = Interrupt disabled 1b = Interrupt enabled | # 23.4.7 UCAxIFG Register eUSCI\_Ax Interrupt Flag Register ## Figure 23-11. UCAxIFG Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |-----|-----|------|-------|-------|-----|---------|---------| | | | | Rese | erved | | | | | r0 | rO | rO | rO | r0 | rO | rO | r0 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | Rese | erved | | | UCTXIFG | UCRXIFG | | r-0 | r-0 | r-0 | r-0 | r-0 | r-0 | rw-1 | rw-0 | ## Table 23-9. UCAxIFG Register Description | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------| | 15-2 | Reserved | R | 0h | Reserved | | 1 | UCTXIFG | RW | 1h | Transmit interrupt flag. UCTXIFG is set when UCAxTXBUF empty. 0b = No interrupt pending 1b = Interrupt pending | | 0 | UCRXIFG | RW | 0h | Receive interrupt flag. UCRXIFG is set when UCAxRXBUF has received a complete character. 0b = No interrupt pending 1b = Interrupt pending | eUSCI\_A SPI Registers www.ti.com # 23.4.8 UCAxIV Register eUSCI\_Ax Interrupt Vector Register ## Figure 23-12. UCAxIV Register ## **Table 23-10. UCAxIV Register Description** | Bit | Field | Туре | Reset | Description | |------|-------|------|-------|-----------------------------------------------------------------------------------------------------| | 15-0 | UCIVx | R | 0h | eUSCI interrupt vector value | | | | | | 000h = No interrupt pending | | | | | | 002h = Interrupt Source: Data received; Interrupt Flag: UCRXIFG; Interrupt Priority: Highest | | | | | | 004h = Interrupt Source: Transmit buffer empty; Interrupt Flag: UCTXIFG; Interrupt Priority: Lowest | www.ti.com eUSCI\_B SPI Registers # 23.5 eUSCI\_B SPI Registers The eUSCI\_B registers applicable in SPI mode and their address offsets are listed in Table 23-11. The base addresses can be found in the device-specific data sheet. Table 23-11. eUSCI\_B SPI Registers | Offset | Acronym | Register Name | Туре | Access | Reset | Section | |--------|-----------|--------------------------------|------------|--------|-------|----------------| | 00h | UCBxCTLW0 | eUSCI_Bx Control Word 0 | Read/write | Word | 01C1h | Section 23.5.1 | | 00h | UCBxCTL1 | eUSCI_Bx Control 1 | Read/write | Byte | C1h | | | 01h | UCBxCTL0 | eUSCI_Bx Control 0 | Read/write | Byte | 01h | | | 06h | UCBxBRW | eUSCI_Bx Bit Rate Control Word | Read/write | Word | 0000h | Section 23.5.2 | | 06h | UCBxBR0 | eUSCI_Bx Bit Rate Control 0 | Read/write | Byte | 00h | | | 07h | UCBxBR1 | eUSCI_Bx Bit Rate Control 1 | Read/write | Byte | 00h | | | 08h | UCBxSTATW | eUSCI_Bx Status | Read/write | Word | 00h | Section 23.5.3 | | 0Ch | UCBxRXBUF | eUSCI_Bx Receive Buffer | Read/write | Word | 00h | Section 23.5.4 | | 0Eh | UCBxTXBUF | eUSCI_Bx Transmit Buffer | Read/write | Word | 00h | Section 23.5.5 | | 2Ah | UCBxIE | eUSCI_Bx Interrupt Enable | Read/write | Word | 00h | Section 23.5.6 | | 2Ch | UCBxIFG | eUSCI_Bx Interrupt Flag | Read/write | Word | 02h | Section 23.5.7 | | 2Eh | UCBxIV | eUSCI_Bx Interrupt Vector | Read | Word | 0000h | Section 23.5.8 | eUSCI\_B SPI Registers www.ti.com # 23.5.1 UCBxCTLW0 Register eUSCI\_Bx Control Register 0 ## Figure 23-13. UCBxCTLW0 Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|--------|-------|--------|-------|------|--------|---------| | UCCKPH | UCCKPL | UCMSB | UC7BIT | UCMST | UCM | ODEx | UCSYNC | | rw-0 rw-1 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | UCS | SELx | | Rese | erved | | UCSTEM | UCSWRST | | rw-1 | rw-1 | r0 | rw-0 | rw-0 | rw-0 | rw-0 | rw-1 | Modify only when UCSWRST = 1. # Table 23-12. UCBxCTLW0 Register Description | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15 | UCCKPH | RW | Oh | Clock phase select. Modify only when UCSWRST = 1. 0b = Data is changed on the first UCLK edge and captured on the following edge. 1b = Data is captured on the first UCLK edge and changed on the following edge. | | 14 | UCCKPL | RW | Oh | Clock polarity select. Modify only when UCSWRST = 1. 0b = The inactive state is low. 1b = The inactive state is high. | | 13 | UCMSB | RW | Oh | MSB first select. Controls the direction of the receive and transmit shift register. Modify only when UCSWRST = 1. 0b = LSB first 1b = MSB first | | 12 | UC7BIT | RW | Oh | Character length. Selects 7-bit or 8-bit character length. Modify only when UCSWRST = 1. 0b = 8-bit data 1b = 7-bit data | | 11 | UCMST | RW | Oh | Master mode select. Modify only when UCSWRST = 1. 0b = Slave mode 1b = Master mode | | 10-9 | UCMODEx | RW | 0h | eUSCI mode. The UCMODEx bits select the synchronous mode when UCSYNC = 1. Modify only when UCSWRST = 1. 00b = 3-pin SPI 01b = 4-pin SPI with UCxSTE active high: Slave enabled when UCxSTE = 1 10b = 4-pin SPI with UCxSTE active low: Slave enabled when UCxSTE = 0 11b = I2C mode | | 8 | UCSYNC | RW | 1h | Synchronous mode enable. Modify only when UCSWRST = 1. 0b = Asynchronous mode 1b = Synchronous mode | | 7-6 | UCSSELx | RW | 3h | eUSCI clock source select. These bits select the BRCLK source clock in master mode. UCxCLK is always used in slave mode. Modify only when UCSWRST = 1. 00b = Reserved 01b = Device Specific 10b = SMCLK 11b = SMCLK | | 5-2 | Reserved | R | 0h | Reserved | | 1 | UCSTEM | RW | Oh | STE mode select in master mode. This byte is ignored in slave or 3-wire mode. Modify only when UCSWRST = 1. 0b = STE pin is used to prevent conflicts with other masters 1b = STE pin is used to generate the enable signal for a 4-wire slave | www.ti.com eUSCI\_B SPI Registers # Table 23-12. UCBxCTLW0 Register Description (continued) | Bit | Field | Туре | Reset | Description | |-----|---------|------|--------------------------|----------------------------------------------------| | 0 | UCSWRST | RW | 1h Software reset enable | | | | | | | 0b = Disabled. eUSCI reset released for operation. | | | | | | 1b = Enabled. eUSCI logic held in reset state. | # 23.5.2 UCBxBRW Register eUSCI\_Bx Bit Rate Control Register 1 # Figure 23-14. UCBxBRW Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----|----|----|-----|-----|----|----|----| | | | | UCI | BRx | | | | | rw | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | UCI | BRx | | | | | rw Modify only when UCSWRST = 1. # Table 23-13. UCBxBRW Register Description | Bit | Field | Туре | Reset | Description | | |------|-------|------|-------|------------------------------------------------------------|--| | 15-0 | UCBRx | RW | 0h | Bit clock prescaler setting. Modify only when UCSWRST = 1. | | | | | | | $f_{BitClock} = f_{BRCLK} / UCBRx$ | | | | | | | If $UCBRx = 0$ , $f_{BitClock} = f_{BRCLK}$ | | eUSCI\_B SPI Registers www.ti.com # 23.5.3 UCBxSTATW Register eUSCI\_Bx Status Register ## Figure 23-15. UCBxSTATW Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------|------|------|------|-------|-------|----|--------| | | | | Rese | erved | | | | | rO | r0 | r0 | r0 | r0 | r0 | r0 | rO | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | UCLISTEN | UCFE | UCOE | | Rese | erved | | UCBUSY | | rw-0 | rw-0 | rw-0 | r0 | r0 | r0 | r0 | r-0 | Modify only when UCSWRST = 1. # Table 23-14. UCBxSTATW Register Description | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-8 | Reserved | R | 0h | Reserved | | 7 | UCLISTEN | RW | 0h | Listen enable. The UCLISTEN bit selects loopback mode. Modify only when UCSWRST = 1. | | | | | | 0b = Disabled | | | | | | 1b = Enabled. The transmitter output is internally fed back to the receiver. | | 6 | UCFE | RW | 0h | Framing error flag. This bit indicates a bus conflict in 4-wire master mode. UCFE is not used in 3-wire master mode or any slave mode. | | | | | | 0b = No error | | | | | | 1b = Bus conflict occurred | | 5 | UCOE | RW | 0h | Overrun error flag. This bit is set when a character is transferred into UCxRXBUF before the previous character was read. UCOE is cleared automatically when UCxRXBUF is read and must not be cleared by software. Otherwise, it does not function correctly. | | | | | | 0b = No error | | | | | | 1b = Overrun error occurred | | 4-1 | Reserved | R | 0h | Reserved | | 0 | UCBUSY | R | 0h | eUSCI busy. This bit indicates if a transmit or receive operation is in progress. | | | | | | 0b = eUSCI inactive | | | | | | 1b = eUSCI transmitting or receiving | # 23.5.4 UCBxRXBUF Register eUSCI\_Bx Receive Buffer Register ## Figure 23-16. UCBxRXBUF Register | 15 | 1.1 | 12 | 10 | 11 | 10 | 0 | 0 | |----|-----|----|------|-------|----|-----|----| | 10 | 14 | 13 | 12 | - 11 | 10 | 9 | 0 | | | | | Rese | erved | | | | | r0 | 7 | 6 | E | 1 | 2 | 2 | 1 | 0 | | 1 | Ü | ິນ | 4 | ა | 2 | l l | U | | | | | UCRX | (BUFx | | | | | rw ## Table 23-15. UCBxRXBUF Register Description | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-8 | Reserved | R | 0h | Reserved | | 7-0 | UCRXBUFx | R | Oh | The receive-data buffer is user accessible and contains the last received character from the receive shift register. Reading UCxRXBUF resets the receive-error bits and UCRXIFG. In 7-bit data mode, UCxRXBUF is LSB justified and the MSB is always reset. | # 23.5.5 UCBxTXBUF Register eUSCI\_Bx Transmit Buffer Register ## Figure 23-17. UCBxTXBUF Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----|----|----|------|-------|----|----|----| | | | | Rese | erved | | | | | rO | r0 | r0 | rO | r0 | r0 | rO | r0 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | UCTX | (BUFx | | | | | rw # Table 23-16. UCBxTXBUF Register Description | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-8 | Reserved | R | 0h | Reserved | | 7-0 | UCTXBUFx | RW | Oh | The transmit data buffer is user accessible and holds the data waiting to be moved into the transmit shift register and transmitted. Writing to the transmit data buffer clears UCTXIFG. The MSB of UCxTXBUF is not used for 7-bit data and is reset. | eUSCI\_B SPI Registers www.ti.com # 23.5.6 UCBxIE Register eUSCI\_Bx Interrupt Enable Register # Figure 23-18. UCBxIE Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |-----|-----|----------|------|-------|-----|------|------| | | | | Rese | erved | | | | | r0 | rO | r0 | r0 | rO | r0 | r0 | r0 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | Reserved | | | | | | | r-0 | r-0 | r-0 | r-0 | r-0 | r-0 | rw-0 | rw-0 | ## Table 23-17. UCBxIE Register Description | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|----------------------------------------------------------------------------| | 15-2 | Reserved | R | 0h | Reserved | | 1 | UCTXIE | RW | 0h | Transmit interrupt enable 0b = Interrupt disabled 1b = Interrupt enabled | | 0 | UCRXIE | RW | 0h | Receive interrupt enable 0b = Interrupt disabled 1b = Interrupt enabled | # 23.5.7 UCBxIFG Register eUSCI\_Bx Interrupt Flag Register ## Figure 23-19. UCBxIFG Register | | | | 3 | | J | | | |----------|-----|-----|------|---------|---------|------|------| | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | Rese | erved | | | | | rO | rO | rO | r0 | rO | r0 | rO | r0 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Reserved | | | | UCTXIFG | UCRXIFG | | | | r-0 | r-0 | r-0 | r-0 | r-0 | r-0 | rw-1 | rw-0 | ## Table 23-18. UCBxIFG Register Description | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------| | 15-2 | Reserved | R | 0h | Reserved | | 1 | UCTXIFG | RW | 1h | Transmit interrupt flag. UCTXIFG is set when UCBxTXBUF empty. 0b = No interrupt pending 1b = Interrupt pending | | 0 | UCRXIFG | RW | 0h | Receive interrupt flag. UCRXIFG is set when UCBxRXBUF has received a complete character. 0b = No interrupt pending 1b = Interrupt pending | www.ti.com eUSCI\_B SPI Registers # 23.5.8 UCBxIV Register eUSCI\_Bx Interrupt Vector Register # Figure 23-20. UCBxIV Register ## Table 23-19. UCBxIV Register Description | Bit | Field | Туре | Reset | Description | |------|-------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-0 | UCIVx | R | Oh | eUSCI interrupt vector value 0000h = No interrupt pending 0002h = Interrupt Source: Data received; Interrupt Flag: UCRXIFG; Interrupt Priority: Highest 0004h = Interrupt Source: Transmit buffer empty; Interrupt Flag: UCTXIFG; Interrupt Priority: Lowest | # Enhanced Universal Serial Communication Interface (eUSCI) – f<sup>2</sup>C Mode The enhanced universal serial communication interface B (eUSCI\_B) supports multiple serial communication modes with one hardware module. This chapter describes the operation of the I<sup>2</sup>C mode. Topic Page | 24.1 | Enhanced Universal Serial Communication Interface B (eUSCI_B) Overview | <b>627</b> | |------|------------------------------------------------------------------------|------------| | 24.2 | eUSCI_B Introduction – I <sup>2</sup> C Mode | <b>627</b> | | 24.3 | eUSCI_B Operation – I <sup>2</sup> C Mode | 629 | | 24.4 | eUSCI_B I2C Registers | 648 | | | _ | | # 24.1 Enhanced Universal Serial Communication Interface B (eUSCI\_B) Overview The eUSCI\_B module supports two serial communication modes: - I<sup>2</sup>C mode - SPI mode If more than one eUSCI\_B module is implemented on one device, those modules are named with incrementing numbers. For example, if one device has two eUSCI\_B modules, they are named eUSCI0\_B and eUSCI1\_B. ## 24.2 eUSCI\_B Introduction - I<sup>2</sup>C Mode In I<sup>2</sup>C mode, the eUSCI\_B module provides an interface between the device and I<sup>2</sup>C-compatible devices connected by the two-wire I<sup>2</sup>C serial bus. External components attached to the I<sup>2</sup>C bus serially transmit or receive serial data to or from the eUSCI\_B module through the 2-wire I<sup>2</sup>C interface. The eUSCI B I2C mode features include: - 7-bit and 10-bit device addressing modes - General call - START, RESTART, STOP - · Multiple-master transmitter or receiver mode - Slave receiver or transmitter mode - Supports standard mode up to 100 kbps and fast mode up to 400 kbps - · Programmable UCxCLK frequency in master mode - · Designed for low power - 8-bit byte counter with interrupt capability and automatic STOP assertion - · Up to four hardware slave addresses, each having its own interrupt - Mask register for slave address and address received interrupt - Clock low time-out interrupt to avoid bus stalls - Slave operation in LPM4 - Slave receiver START detection for auto wake up from LPMx modes (not LPM3.5 and LPM4.5) Figure 24-1 shows the eUSCI\_B when configured in I<sup>2</sup>C mode. <sup>(1)</sup> Externally provided clock on the eUSCI\_B SPI clock input pin Figure 24-1. eUSCI\_B Block Diagram – I<sup>2</sup>C Mode Not the actual implementation (transistor not located in eUSCI\_B module) # 24.3 eUSCI\_B Operation – I<sup>2</sup>C Mode The I<sup>2</sup>C mode supports any slave or master I<sup>2</sup>C-compatible device. Figure 24-2 shows an example of an I<sup>2</sup>C bus. Each I<sup>2</sup>C device is recognized by a unique address and can operate as either a transmitter or a receiver. A device connected to the I<sup>2</sup>C bus can be considered as the master or the slave when performing data transfers. A master initiates a data transfer and generates the clock signal SCL. Any device addressed by a master is considered a slave. 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 bidirectional and must be connected to a positive supply voltage using a pullup resistor. Figure 24-2. I<sup>2</sup>C Bus Connection Diagram #### NOTE: SDA and SCL levels The SDA and SCL pins must not be pulled up above the device V<sub>cc</sub> level. #### 24.3.1 eUSCI B Initialization and Reset The eUSCI\_B is reset by a PUC or by setting the UCSWRST bit. After a PUC, the UCSWRST bit is automatically set, keeping the eUSCI\_B in a reset condition. To select I<sup>2</sup>C operation, the UCMODEx bits must be set to 11. After module initialization, it is ready for transmit or receive operation. Clearing UCSWRST releases the eUSCI\_B for operation. Configuring and reconfiguring the eUSCI\_B module should be done when UCSWRST is set to avoid unpredictable behavior. Setting UCSWRST in I<sup>2</sup>C mode has the following effects: - I<sup>2</sup>C communication stops. - SDA and SCL are high impedance. - · UCBxSTAT, bits 15-9 and 6-4 are cleared. - Registers UCBxIE and UCBxIFG are cleared. - All other bits and registers remain unchanged. #### NOTE: Initializing or re-configuring the eUSCI\_B module The recommended eUSCI\_B initialization or reconfiguration process is: - 1. Set UCSWRST (BIS.B #UCSWRST, &UCxCTL1). - Initialize all eUSCI\_B registers with UCSWRST = 1 (including UCxCTL1). - 3. Configure ports. - 4. Clear UCSWRST using software (BIC.B #UCSWRST, &UCxCTL1). - 5. Enable interrupts (optional). #### 24.3.2 fC Serial Data One clock pulse is generated by the master device for each data bit transferred. The I<sup>2</sup>C mode operates with byte data. Data is transferred MSB first as shown in Figure 24-3. The first byte after a START condition consists of a 7-bit slave address and the $R/\overline{W}$ bit. When $R/\overline{W} = 0$ , the master transmits data to a slave. When $R/\overline{W} = 1$ , the master receives data from a slave. The ACK bit is sent from the receiver after each byte on the ninth SCL clock. Figure 24-3. I<sup>2</sup>C Module Data Transfer START and STOP conditions are generated by the master and are shown in Figure 24-3. A START condition is a high-to-low transition on the SDA line while SCL is high. A STOP condition is a low-to-high transition on the SDA line while SCL is high. The bus busy bit, UCBBUSY, is set after a START and cleared after a STOP. Data on SDA must be stable during the high period of SCL (see Figure 24-4). The high and low state of SDA can change only when SCL is low, otherwise START or STOP conditions are generated. Figure 24-4. Bit Transfer on I<sup>2</sup>C Bus ## 24.3.3 fC Addressing Modes The I<sup>2</sup>C mode supports 7-bit and 10-bit addressing modes. #### 24.3.3.1 7-Bit Addressing In the 7-bit addressing format (see Figure 24-5), the first byte is the 7-bit slave address and the R/W bit. The ACK bit is sent from the receiver after each byte. Figure 24-5. I<sup>2</sup>C Module 7-Bit Addressing Format #### 24.3.3.2 10-Bit Addressing In the 10-bit addressing format (see Figure 24-6), the first byte is made up of 11110b plus the two MSBs of the 10-bit slave address and the R/W bit. The ACK bit is sent from the receiver after each byte. The next byte is the remaining eight bits of the 10-bit slave address, followed by the ACK bit and the 8-bit data. See I2C Slave 10-bit Addressing Mode and I2C Master 10-bit Addressing Mode for details how to use the 10-bit addressing mode with the eUSCI\_B module. Figure 24-6. I<sup>2</sup>C Module 10-Bit Addressing Format ### 24.3.3.3 Repeated Start Conditions The direction of data flow on SDA can be changed by the master, without first stopping a transfer, by issuing a repeated START condition. This is called a RESTART. After a RESTART is issued, the slave address is again sent out with the new data direction specified by the R/W bit. The RESTART condition is shown in Figure 24-7. Figure 24-7. I<sup>2</sup>C Module Addressing Format With Repeated START Condition ## 24.3.4 fC Quick Setup This section gives a quick introduction into the operation of the eUSCI\_B in I2C mode. The basic steps to start communication are described and shown as a software example. More detailed information about the possible configurations and details can be found in Section 24.3.5. The latest code examples can be found on the MSP430 website under "Code Examples". To set up the eUSCI\_B as a master transmitter that transmits to a slave with the address 0x12h, only a few steps are needed (see Example 24-1). ## Example 24-1. Master TX With 7-Bit Address ``` UCBxCTL1 |= UCSWRST; // put eUSCI_B in reset state UCBxCTLW0 |= UCMODE_3 + UCMST; // I2C master mode UCBxBRW = 0x0008; // baud rate = SMCLK / 8 UCBxCTLW1 = UCASTP_2; // automatic STOP assertion UCBxTBCNT = 0x07; // TX 7 bytes of data UCBxI2CSA = 0x0012; // address slave is 12hex // configure I2C pins (device specific) P2SEL = 0x03; UCBxCTL1 &= ^UCSWRST; // eUSCI_B in operational state // enable TX-interrupt UCBxIE |= UCTXIE; GIE; // general interrupt enable // inside the eUSCI_B TX interrupt service routine UCBxTXBUF = 0x77; // fill TX buffer ``` As shown in the code example, all configurations must be done while UCSWRST is set. To select the I<sup>2</sup>C operation of the eUSCI\_B, UCMODE must be set accordingly. The baud rate of the transmission is set by writing the correct divider in the UCBxBRW register. The default clock selected is SMCLK. How many bytes are transmitted in one frame is controlled by the byte counter threshold register UCBxTBCNT together with the UCASTPx bits. The slave address to send to is specified in the UCBxI2CSA register. Finally, the ports must be configured. This step is device dependent; see the data sheet for the pins that must be used. Each byte that is to be transmitted must be written to UCBxTXBUF inside the interrupt service routine. Example 24-3 shows the recommended structure of the interrupt service routine. Example 24-2 shows the steps needed to set up the eUSCI\_B as a slave with the address 0x12h that is able to receive and transmit data to the master. ## Example 24-2. Slave RX With 7-Bit Address As shown in Example 24-2, all configurations must be done while UCSWRST is set. For the slave, I<sup>2</sup>C operation is selected by setting UCMODE. The slave address is specified in the UCBxI2COA0 register. To enable the interrupts for receive and transmit requests, the according bits in UCBxIE and, at the end, GIE need to be set. Finally the ports must be configured. This step is device dependent; see the data sheet for the pins that are used. The RX interrupt service routine is called for every byte received by a master device. The TX interrupt service routine is executed each time the master requests a byte. The recommended structure of the interrupt service routine can be found in Example 24-3. ## 24.3.5 fC Module Operating Modes In I<sup>2</sup>C mode, the eUSCI\_B module can operate in master transmitter, master receiver, slave transmitter, or slave receiver mode. The modes are discussed in the following sections. Time lines are used to illustrate the modes. Figure 24-8 shows how to interpret the time-line figures. Data transmitted by the master is represented by grey rectangles; data transmitted by the slave is represented by white rectangles. Data transmitted by the eUSCI B module, either as master or slave, is shown by rectangles that are taller than the others. Actions taken by the eUSCI\_B module are shown in grey rectangles with an arrow indicating where in the data stream the action occurs. Actions that must be handled with software are indicated with white rectangles with an arrow pointing to where in the data stream the action must take place. Figure 24-8. I<sup>2</sup>C Time-Line Legend ### 24.3.5.1 Slave Mode The eUSCI\_B module is configured as an $I^2$ C slave by UCMODEx = 11, UCSYNC = 1, and UCMST = 0. Initially, the eUSCI\_B module must be configured in receiver mode by clearing the UCTR bit to receive the I<sup>2</sup>C address. Afterwards, transmit and receive operations are controlled automatically, depending on the R/W bit received together with the slave address. The eUSCI\_B slave address is programmed with the UCBxI2COA0 register. Support for multiple slave addresses is explained in Section 24.3.9. When UCA10 = 0, 7-bit addressing is selected. When UCA10 = 1, 10-bit addressing is selected. The UCGCEN bit selects if the slave responds to a general call. When a START condition is detected on the bus, the eUSCI\_B module receives the transmitted address and compares it against its own address stored in UCBxI2COA0. The UCSTTIFG flag is set when address received matches the eUSCI\_B slave address. ## 24.3.5.1.1 PC Slave Transmitter Mode Slave transmitter mode is entered when the slave address transmitted by the master is identical to its own address with a set $R/\overline{W}$ bit. The slave transmitter shifts the serial data out on SDA with the clock pulses that are generated by the master device. The slave device does not generate the clock, but it does hold SCL low while intervention of the CPU is required after a byte has been transmitted. If the master requests data from the slave, the eUSCI\_B module is automatically configured as a transmitter and UCTX and UCTXIFG0 become set. The SCL line is held low until the first data to be sent is written into the transmit buffer UCBxTXBUF. Then the address is acknowledged and the data is transmitted. As soon as the data is transferred into the shift register, the UCTXIFG0 is set again. After the data is acknowledged by the master, the next data byte written into UCBxTXBUF is transmitted or, if the buffer is empty, the bus is stalled during the acknowledge cycle by holding SCL low until new data is written into UCBxTXBUF. If the master sends a NACK followed by a STOP condition, the UCSTPIFG flag is set. If the NACK is followed by a repeated START condition, the eUSCI\_B I<sup>2</sup>C state machine returns to its address-reception state. Figure 24-9 shows the slave transmitter operation. Figure 24-9. I<sup>2</sup>C Slave Transmitter Mode ## 24.3.5.1.2 fC Slave Receiver Mode Slave receiver mode is entered when the slave address transmitted by the master is identical to its own address and a cleared $R/\overline{W}$ bit is received. In slave receiver mode, serial data bits received on SDA are shifted in with the clock pulses that are generated by the master device. The slave 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. If the slave receives data from the master, the eUSCI\_B module is automatically configured as a receiver and UCTR is cleared. After the first data byte is received, the receive interrupt flag UCRXIFG0 is set. The eUSCI\_B module automatically acknowledges the received data and can receive the next data byte. If the previous data was not read from the receive buffer UCBxRXBUF at the end of a reception, the bus is stalled by holding SCL low. As soon as UCBxRXBUF is read, the new data is transferred into UCBxRXBUF, an acknowledge is sent to the master, and the next data can be received. Setting the UCTXNACK bit causes a NACK to be transmitted to the master during the next acknowledgment cycle. A NACK is sent even if UCBxRXBUF is not ready to receive the latest data. If the UCTXNACK bit is set while SCL is held low, the bus is released, a NACK is transmitted immediately, and UCBxRXBUF is loaded with the last received data. Because the previous data was not read, that data is lost. To avoid loss of data, the UCBxRXBUF must be read before UCTXNACK is set. When the master generates a STOP condition, the UCSTPIFG flag is set. If the master generates a repeated START condition, the eUSCI\_B I<sup>2</sup>C state machine returns to its address-reception state. Figure 24-10 shows the I<sup>2</sup>C slave receiver operation. Figure 24-10. I<sup>2</sup>C Slave Receiver Mode #### 24.3.5.1.3 fC Slave 10-Bit Addressing Mode The 10-bit addressing mode is selected when UCA10 = 1 and is as shown in Figure 24-11. In 10-bit addressing mode, the slave is in receive mode after the full address is received. The eUSCI\_B module indicates this by setting the UCSTTIFG flag while the UCTR bit is cleared. To switch the slave into transmitter mode, the master sends a repeated START condition together with the first byte of the address but with the R/W bit set. This sets the UCSTTIFG flag if it was previously cleared by software, and the eUSCI\_B modules switches to transmitter mode with UCTR = 1. Slave Receiver #### Reception of own S 11110 xx/W SLA (2.) DATA DATA Α address and data #### **Slave Transmitter** Figure 24-11. I<sup>2</sup>C Slave 10-Bit Addressing Mode #### 24.3.5.2 Master Mode The eUSCI B module is configured as an $I^2$ C master by selecting the $I^2$ C mode with UCMODEx = 11 and UCSYNC = 1 and setting the UCMST bit. When the master is part of a multiple-master system, UCMM must be set and its own address must be programmed into the UCBxI2COA0 register. Support for multiple slave addresses is described in Section 24.3.9. When UCA10 = 0, 7-bit addressing is selected. When UCA10 = 1, 10-bit addressing is selected. The UCGCEN bit selects if the eUSCI B module responds to a general call. #### NOTE: Addresses and multiple-master systems In master mode with own-address detection enabled (UCOAEN = 1)—especially in multiplemaster systems—it is not allowed to specify the same address in the own address and slave address registers (UCBxI2CSA = UCBxI2COAx). This would mean that the eUSCI\_B addresses itself. The user software must ensure that this situation does not occur. There is no hardware detection for this case, and the consequence is unpredictable behavior of the eUSCI\_B. #### 24.3.5.2.1 fC Master Transmitter Mode After initialization, master transmitter mode is initiated by writing the desired slave address to the UCBxI2CSA register, selecting the size of the slave address with the UCSLA10 bit, setting UCTR for transmitter mode, and setting UCTXSTT to generate a START condition. The eUSCI\_B module waits until the bus is available, then generates the START condition and transmits the slave address. The UCTXIFG0 bit is set when the START condition is generated and the first data to be transmitted can be written into UCBxTXBUF. **The UCTXSTT flag is cleared as soon as the complete address is sent.** The data written into UCBxTXBUF is transmitted if arbitration is not lost during transmission of the slave address. UCTXIFG0 is set again as soon as the data is transferred from the buffer into the shift register. If there is no data loaded to UCBxTXBUF before the acknowledge cycle, the bus is held during the acknowledge cycle with SCL low until data is written into UCBxTXBUF. Data is transmitted or the bus is held as long as: - No automatic STOP is generated - The UCTXSTP bit is not set - · The UCTXSTT bit is not set Setting UCTXSTP generates a STOP condition after the next acknowledge from the slave. If UCTXSTP is set during the transmission of the slave address or while the eUSCI\_B module waits for data to be written into UCBxTXBUF, a STOP condition is generated, even if no data was transmitted to the slave. In this case, the UCSTPIFG is set. When transmitting a single byte of data, the UCTXSTP bit must be set while the byte is being transmitted or any time after transmission begins, without writing new data into UCBxTXBUF. Otherwise, only the address is transmitted. When the data is transferred from the buffer to the shift register, UCTXIFG0 is set, indicating data transmission has begun, and the UCTXSTP bit may be set. When UCASTPx = 10 is set, the byte counter is used for STOP generation and the user does not need to set the UCTXSTP. This is recommended when transmitting only one byte. Setting UCTXSTT generates a repeated START condition. In this case, UCTR may be set or cleared to configure transmitter or receiver, and a different slave address may be written into UCBxI2CSA, if desired. If the slave does not acknowledge the transmitted data, the not-acknowledge interrupt flag UCNACKIFG is set. The master must react with either a STOP condition or a repeated START condition. If data was already written into UCBxTXBUF, it is discarded. If this data should be transmitted after a repeated START, it must be written into UCBxTXBUF again. Any set UCTXSTT or UCTXSTP is also discarded. Figure 24-12 shows the I<sup>2</sup>C master transmitter operation. Figure 24-12. I<sup>2</sup>C Master Transmitter Mode #### 24.3.5.2.2 PC Master Receiver Mode After initialization, master receiver mode is initiated by writing the desired slave address to the UCBxI2CSA register, selecting the size of the slave address with the UCSLA10 bit, clearing UCTR for receiver mode, and setting UCTXSTT to generate a START condition. The eUSCI\_B module checks if the bus is available, generates the START condition, and transmits the slave address. The UCTXSTT flag is cleared as soon as the complete address is sent. After the acknowledge of the address from the slave, the first data byte from the slave is received and acknowledged and the UCRXIFG flag is set. Data is received from the slave, as long as: - No automatic STOP is generated - The UCTXSTP bit is not set - The UCTXSTT bit is not set If a STOP condition was generated by the eUSCI\_B module, the UCSTPIFG is set. If UCBxRXBUF is not read, the master holds the bus during reception of the last data bit and until the UCBxRXBUF is read. If the slave does not acknowledge the transmitted address, the not-acknowledge interrupt flag UCNACKIFG is set. The master must react with either a STOP condition or a repeated START condition. A STOP condition is either generated by the automatic STOP generation or by setting the UCTXSTP bit. The next byte received from the slave is followed by a NACK and a STOP condition. This NACK occurs immediately if the eUSCI B module is currently waiting for UCBxRXBUF to be read. If a RESTART is sent, UCTR may be set or cleared to configure transmitter or receiver, and a different slave address may be written into UCBxI2CSA if desired. Figure 24-13 shows the I<sup>2</sup>C master receiver operation. #### NOTE: Consecutive master transactions without repeated START When performing multiple consecutive $I^2C$ master transactions without the repeated START feature, the current transaction must be completed before the next one is initiated. This can be done by ensuring that the transmit STOP condition flag UCTXSTP is cleared before the next $I^2C$ transaction is initiated with setting UCTXSTT = 1. Otherwise, the current transaction might be affected. Figure 24-13. I<sup>2</sup>C Master Receiver Mode ## 24.3.5.2.3 fC Master 10-Bit Addressing Mode The 10-bit addressing mode is selected when UCSLA10 = 1 and is shown in Figure 24-14. Figure 24-14. I<sup>2</sup>C Master 10-Bit Addressing Mode #### 24.3.5.3 Arbitration If two or more master transmitters simultaneously start a transmission on the bus, an arbitration procedure is invoked. Figure 24-15 shows the arbitration procedure between two devices. The arbitration procedure uses the data presented on SDA by the competing transmitters. The first master transmitter that generates a logic high is overruled by the opposing master generating a logic low. The arbitration procedure gives priority to the device that transmits the serial data stream with the lowest binary value. The master transmitter that lost arbitration switches to the slave receiver mode and sets the arbitration lost flag UCALIFG. If two or more devices send identical first bytes, arbitration continues on the subsequent bytes. Figure 24-15. Arbitration Procedure Between Two Master Transmitters There is an undefined condition if the arbitration procedure is still in progress when one master sends a repeated START or a STOP condition while the other master is still sending data. In other words, the following combinations result in an undefined condition: - Master 1 sends a repeated START condition and master 2 sends a data bit. - Master 1 sends a STOP condition and master 2 sends a data bit. - Master 1 sends a repeated START condition and master 2 sends a STOP condition. ## 24.3.6 Glitch Filtering According to the I<sup>2</sup>C standard, both the SDA and the SCL line need to be glitch filtered. The eUSCI\_B module provides the UCGLITx bits to configure the length of this glitch filter: Table 24-1. Glitch Filter Length Selection Bits | UCGLITx | Corresponding Glitch Filter Length on SDA and SCL | According to I <sup>2</sup> C<br>Standard | |---------|---------------------------------------------------|-------------------------------------------| | 00 | Pulses of maximum 50-ns length are filtered. | yes | | 01 | Pulses of maximum 25-ns length are filtered. | no | | 10 | Pulses of maximum 12.5-ns length are filtered. | no | | 11 | Pulses of maximum 6.25-ns length are filtered. | no | ## 24.3.7 fC Clock Generation and Synchronization The I<sup>2</sup>C clock SCL is provided by the master on the I<sup>2</sup>C bus. When the eUSCI\_B is in master mode, BITCLK is provided by the eUSCI\_B bit clock generator and the clock source is selected with the UCSSELx bits. In slave mode, the bit clock generator is not used and the UCSSELx bits are don't care. The 16-bit value of UCBRx in register UCBxBRW is the division factor of the eUSCI\_B clock source, BRCLK. The maximum bit clock that can be used in single master mode is $f_{BRCLK}/4$ . In multiple-master mode, the maximum bit clock is $f_{BRCLK}/8$ . The BITCLK frequency is given by: $$f_{BitClock} = f_{BRCLK}/UCBRx$$ The minimum high and low periods of the generated SCL are: $t_{LOW,MIN} = t_{HIGH,MIN} = (UCBRx/2)/f_{BRCLK}$ when UCBRx is even $t_{LOW,MIN} = t_{HIGH,MIN} = ((UCBRx - 1)/2)/f_{BRCLK}$ when UCBRx is odd The eUSCI\_B clock source frequency and the prescaler setting UCBRx must to be chosen such that the minimum low and high period times of the I<sup>2</sup>C specification are met. During the arbitration procedure, the clocks from the different masters 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. Figure 24-16 shows the clock synchronization. This allows a slow slave to slow down a fast master. Figure 24-16. Synchronization of Two I<sup>2</sup>C Clock Generators During Arbitration ## 24.3.7.1 Clock Stretching The eUSCI\_B module supports clock stretching and also makes use of this feature as described in the operation mode sections. The UCSCLLOW bit can be used to observe if another device pulls SCL low while the eUSCI\_B module already released SCL due to the following conditions: - eUSCI B is acting as master and a connected slave drives SCL low. - eUSCI\_B is acting as master and another master drives SCL low during arbitration. The UCSCLLOW bit is also active if the eUSCI\_B holds SCL low because it is waiting as transmitter for data being written into UCBxTXBUF or as receiver for the data being read from UCBxRXBUF. The UCSCLLOW bit might be set for a short time with each rising SCL edge because the logic observes the external SCL and compares it to the internally generated SCL. ## 24.3.7.2 Avoiding Clock Stretching Even though clock stretching is part of the I2C specification, there are applications in which clock stretching should be avoided. The clock is stretched by the eUSCI\_B under the following conditions: - The internal shift register is expecting data, but the TXIFG is still pending - The internal shift register is full, but the RXIFG is still pending - The arbitration lost interrupt is pending - UCSWACK is selected and UCBxI2COA0 did cause a match To avoid clock stretching, all of these situations for clock stretch either need to be avoided or the corresponding interrupt flags need to be processed before the actual clock stretch can occur. The software must ensure that the corresponding interrupts are serviced in time before the clock is stretched. In slave transmitter mode, the TXIFG is set only after the reception of the direction bit; therefore, there is only a short amount of time for the software to write the TXBUF before a clock stretch occurs. This situation can be remedied by using the early Transmit Interrupt (see Section 24.3.11.2). #### 24.3.7.3 Clock Low Timeout The UCCLTOIFG interrupt allows the software to react if the clock is low longer than a defined time. It is possible to detect the situation, when a clock is stretched by a master or slave for a too long time. The user can then, for example, reset the eUSCI\_B module by using the UCSWRST bit. The clock low time-out feature is enabled using the UCCLTO bits. It is possible to select one of three predefined times for the clock low time-out. If the clock has been low longer than the time defined with the UCCLTO bits and the eUSCI\_B was actively receiving or transmitting, the UCCLTOIFG is set and an interrupt request is generated if UCCLTOIE and GIE are set as well. The UCCLTOIFG is set only once, even if the clock is stretched a multiple of the time defined in UCCLTO. ## 24.3.8 Byte Counter The eUSCI\_B module supports hardware counting of the bytes received or transmitted. The counter is automatically active and counts up for each byte seen on the bus in both master and slave mode. The byte counter is incremented at the second bit position of each byte independently of the following ACK or NACK. A START or RESTART condition resets the counter value to zero. Address bytes do not increment the counter. The byte counter is also incremented at the second bit position, if an arbitration lost occurs during the first bit of data. ## 24.3.8.1 Byte Counter Interrupt If UCASTPx = 01 or 10 the UCBCNTIFG is set when the byte counter threshold value UCBxTBCNT is reached in both master- and slave-mode. Writing zero to UCBxTBCNT does not generate an interrupt. #### 24.3.8.2 Automatic STOP Generation When the eUSCI\_B module is configured as a master, the byte counter can be used for automatic STOP generation by setting the UCASTPx = 10. Before starting the transmission using UCTXSTT, the byte counter threshold UCBxTBCNT must be set to the number of bytes that are to be transmitted or received. After the number of bytes that are configured in UCBxTBCNT have been transmitted, the eUSCI\_B automatically generates a STOP condition. UCBxTBCNT cannot be used if the user wants to transmit the slave address only without any data. In this case, it is recommended to set UCTXSTT and UCTXSTP at the same time. #### 24.3.9 Multiple Slave Addresses The eUSCI\_B module supports two different ways of implementing multiple slave addresses at the same time: - Hardware support for up to 4 different slave addresses, each with its own interrupt flag - Software support for up to 2<sup>10</sup> different slave addresses all sharing one interrupt #### 24.3.9.1 Multiple Slave Address Registers The registers UCBxI2COA0, UCBxI2COA1, UCBxI2COA2, and UCBxI2COA3 contain four slave addresses. Up to four address registers are compared against a received 7- or 10-bit address. Each slave address must be activated by setting the UCAOEN bit in the corresponding UCBxI2COAx register. Register UCBxI2COA3 has the highest priority if the address received on the bus matches more than one of the slave address registers. The priority decreases with the index number of the address register, so that UCBxI2COA0 in combination with the address mask has the lowest priority. When one of the slave registers matches the 7- or 10-bit address seen on the bus, the address is acknowledged. In the following the corresponding receive- or transmit-interrupt flag (UCTXIFGx or UCRXIFGx) to the received address is updated. The state change interrupt flags are independent of the address comparison result. They are updated according to the bus condition. ## 24.3.9.2 Address Mask Register The address mask register can be used when the eUSCI\_B is configured in slave or in multiple-master mode. To activate this feature, at least one bit of the address mask in register UCBxADDMASK must be cleared. If the received address matches the own address in UCBxI2COA0 on all bit positions that are not masked by UCBxADDMASK, the eUSCI\_B module considers the received address as its own address. If UCSWACK = 0, the module sends an acknowledge automatically. If UCSWACK = 1, the user software must evaluate the received address in register UCBxADDRX after the UCSTTIFG is set. To acknowledge the received address, the software must set UCTXACK to 1. The eUSCI\_B module also automatically acknowledges a slave address that is seen on the bus if the address matches any of the enabled slave addresses defined in UCBxI2COA1 to UCBxI2COA3. #### NOTE: UCSWACK and slave-transmitter If the user selects manual acknowledge of slave addresses, TXIFG is set if the slave is addressed as a transmitter. If the software decides not to acknowledge the address, TXIFG0 must be reset. ## 24.3.10 Using the eUSCI B Module in fC Mode With Low-Power Modes The eUSCI\_B module provides automatic clock activation for use with low-power modes. When the eUSCI\_B clock source is inactive because the device is in a low-power mode, the eUSCI\_B module automatically activates it when needed, regardless of the control-bit settings for the clock source. The clock remains active until the eUSCI\_B module returns to its idle condition. After the eUSCI\_B module returns to the idle condition, control of the clock source reverts to the settings of its control bits. In I<sup>2</sup>C slave mode, no internal clock source is required because the clock is provided by the external master. It is possible to operate the eUSCI\_B in I<sup>2</sup>C slave mode while the device is in LPM4 and all internal clock sources are disabled. The receive or transmit interrupts can wake up the CPU from any low-power mode. ## 24.3.11 eUSCI B Interrupts in fC Mode The eUSCI\_B has only one interrupt vector that is shared for transmission, reception, and the state change. Each interrupt flag has its own interrupt enable bit. When an interrupt is enabled and the GIE bit is set, the interrupt flag generates an interrupt request. All interrupt flags are not cleared automatically, but they need to be cleared together by user interactions (for example, reading the UCRXBUF clears UCRXIFGx). If the user wants to use an interrupt flag he needs to ensure that the flag has the correct state before the corresponding interrupt is enabled. ## 24.3.11.1 I<sup>2</sup>C Transmit Interrupt Operation The UCTXIFG0 interrupt flag is set whenever the transmitter is able to accept a new byte. When operating as a slave with multiple slave addresses, the UCTXIFGx flags are set corresponding to which address was received before. If, for example, the slave address specified in register UCBxI2COA3 did match the address seen on the bus, the UCTXIFG3 indicates that the UCBxTXBUF is ready to accept a new byte. When operating in master mode with automatic STOP generation (UCASTPx = 10), the UCTXIFG0 is set as many times as defined in UCBxTBCNT. An interrupt request is generated if UCTXIEx and GIE are also set. UCTXIFGx is automatically reset if a write to UCBxTXBUF occurs or if the UCALIFG is cleared. UCTXIFGx is set when: - Master mode: UCTXSTT was set by the user - Slave mode: own address was received(UCETXINT = 0) or START was received (UCETXINT = 1) UCTXIEx is reset after a PUC or when UCSWRST = 1. #### 24.3.11.2 Early I<sup>2</sup>C Transmit Interrupt Setting the UCETXINT causes UCTXIFG0 to be sent out automatically when a START condition is sent and the eUSCI\_B is configured as slave. In this case, it is not allowed to enable the other slave addresses UCBxI2COA1-UCBxI2COA3. This allows the software more time to handle the UCTXIFG0 compared to the normal situation, when UCTXIFG0 is sent out after the slave address match was detected. Situations where the UCTXIFG0 was set and afterward no slave address match occurred need to be handled in software. The use of the byte counter is recommended to handle this. ## 24.3.11.3 I<sup>2</sup>C Receive Interrupt Operation The UCRXIFG0 interrupt flag is set when a character is received and loaded into UCBxRXBUF. When operating as a slave with multiple slave addresses, the UCRXIFGx flag is set corresponding to which address was received before. An interrupt request is generated if UCRXIEx and GIE are also set. UCRXIFGx and UCRXIEx are reset after a PUC signal or when UCSWRST = 1. UCRXIFGx is automatically reset when UCxRXBUF is read. # 24.3.11.4 I<sup>2</sup>C State Change Interrupt Operation Table 24-2 describes the I<sup>2</sup>C state change interrupt flags. ## Table 24-2. I<sup>2</sup>C State Change Interrupt Flags | Interrupt Flag | Interrupt Condition | |----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | UCALIFG | Arbitration lost interrupt. Arbitration can be lost when two or more transmitters start a transmission simultaneously, or when the eUSCI_B operates as master but is addressed as a slave by another master in the system. The UCALIFG flag is set when arbitration is lost. When UCALIFG is set, the UCMST bit is cleared and the I <sup>2</sup> C controller becomes a slave. | | UCNACKIFG | Not acknowledge interrupt. This flag is set when an acknowledge is expected but is not received. UCNACKIFG is used in master mode only. | | UCCLTOIFG | Clock low time-out. This interrupt flag is set, if the clock is held low longer than defined by the UCCLTO bits. | | UCBIT9IFG | This interrupt flag is generated each time the eUSCI_B is transferring the nineth clock cycle of a byte of data. This gives the user the ability to follow the I <sup>2</sup> C communication in software if wanted. UCBIT9IFG is not set for address information. | | UCBCNTIFG | Byte counter interrupt. This flag is set when the byte counter value reaches the value defined in UCBxTBCNT and UCASTPx = 01 or 10. This bit allows to organize following communications, especially if a RESTART will be issued. | | UCSTTIFG | START condition detected interrupt. This flag is set when the I <sup>2</sup> C module detects a START condition together with its own address <sup>(1)</sup> . UCSTTIFG is used in slave mode only. | | UCSTPIFG | STOP condition detected interrupt. This flag is set when the I <sup>2</sup> C module detects a STOP condition on the bus. UCSTPIFG is used in slave and master mode. | <sup>(1)</sup> The address evaluation includes the address mask register if it is used. # 24.3.11.5 UCBxIV, Interrupt Vector Generator The eUSCI\_B interrupt flags are prioritized and combined to source a single interrupt vector. The interrupt vector register UCBxIV is used to determine which flag requested an interrupt. The highest-priority enabled interrupt generates a number in the UCBxIV register that can be evaluated or added to the PC to automatically enter the appropriate software routine. Disabled interrupts do not affect the UCBxIV value. Read access of the UCBxIV register automatically resets the highest-pending interrupt flag. If another interrupt flag is set, another interrupt is immediately generated after servicing the initial interrupt. Write access of the UCBxIV register clears all pending Interrupt conditions and flags. Example 24-3 shows the recommended use of UCBxIV. The UCBxIV value is added to the PC to automatically jump to the appropriate routine. The example is given for eUSCI0\_B. ## Example 24-3. UCBxIV Software Example ``` #pragma vector = USCI_B0_VECTOR __interrupt void USCI_B0_ISR(void) { switch(__even_in_range(UCB0IV,0x1e)) case 0x00: // Vector 0: No interrupts break; case 0x02: ... // Vector 2: ALIFG break; case 0x04: ... // Vector 4: NACKIFG break; case 0x06: ... // Vector 6: STTIFG break; case 0x08: ... // Vector 8: STPIFG break; case 0x0a: ... // Vector 10: RXIFG3 break; case 0x0c: ... // Vector 12: TXIFG3 break; case 0x0e: ... // Vector 14: RXIFG2 break; case 0x10: ... // Vector 16: TXIFG2 break; case 0x12: ... // Vector 18: RXIFG1 break; case 0x14: ... // Vector 20: TXIFG1 break; case 0x16: ... // Vector 22: RXIFG0 case 0x18: ... // Vector 24: TXIFG0 break; case 0x1a: ... // Vector 26: BCNTIFG break; case 0x1c: ... // Vector 28: clock low time-out break; case 0x1e: ... // Vector 30: 9th bit break; default: break; } } ``` eUSCI\_B I2C Registers www.ti.com # 24.4 eUSCI\_B I2C Registers The eUSCI\_B registers applicable in I2C mode and their address offsets are listed in Table 24-3. The base address can be found in the device-specific data sheet. Table 24-3. eUSCI\_B Registers | Offset | Acronym | Register Name | Туре | Access | Reset | Section | |--------|-------------|---------------------------------|------------|--------|-------|-----------------| | 00h | UCBxCTLW0 | eUSCI_Bx Control Word 0 | Read/write | Word | 01C1h | Section 24.4.1 | | 00h | UCBxCTL1 | eUSCI_Bx Control 1 | Read/write | Byte | C1h | | | 01h | UCBxCTL0 | eUSCI_Bx Control 0 | Read/write | Byte | 01h | | | 02h | UCBxCTLW1 | eUSCI_Bx Control Word 1 | Read/write | Word | 0000h | Section 24.4.2 | | 06h | UCBxBRW | eUSCI_Bx Bit Rate Control Word | Read/write | Word | 0000h | Section 24.4.3 | | 06h | UCBxBR0 | eUSCI_Bx Bit Rate Control 0 | Read/write | Byte | 00h | | | 07h | UCBxBR1 | eUSCI_Bx Bit Rate Control 1 | Read/write | Byte | 00h | | | 08h | UCBxSTATW | eUSCI_Bx Status Word | Read | Word | 0000h | Section 24.4.4 | | 08h | UCBxSTAT | eUSCI_Bx Status | Read | Byte | 00h | | | 09h | UCBxBCNT | eUSCI_Bx Byte Counter | Read | Byte | 00h | | | 0Ah | UCBxTBCNT | eUSCI_Bx Byte Counter Threshold | Read/Write | Word | 00h | Section 24.4.5 | | 0Ch | UCBxRXBUF | eUSCI_Bx Receive Buffer | Read/write | Word | 00h | Section 24.4.6 | | 0Eh | UCBxTXBUF | eUSCI_Bx Transmit Buffer | Read/write | Word | 00h | Section 24.4.7 | | 14h | UCBxI2COA0 | eUSCI_Bx I2C Own Address 0 | Read/write | Word | 0000h | Section 24.4.8 | | 16h | UCBxI2COA1 | eUSCI_Bx I2C Own Address 1 | Read/write | Word | 0000h | Section 24.4.9 | | 18h | UCBxI2COA2 | eUSCI_Bx I2C Own Address 2 | Read/write | Word | 0000h | Section 24.4.10 | | 1Ah | UCBxI2COA3 | eUSCI_Bx I2C Own Address 3 | Read/write | Word | 0000h | Section 24.4.11 | | 1Ch | UCBxADDRX | eUSCI_Bx Received Address | Read | Word | | Section 24.4.12 | | 1Eh | UCBxADDMASK | eUSCI_Bx Address Mask | Read/write | Word | 03FFh | Section 24.4.13 | | 20h | UCBxI2CSA | eUSCI_Bx I2C Slave Address | Read/write | Word | 0000h | Section 24.4.14 | | 2Ah | UCBxIE | eUSCI_Bx Interrupt Enable | Read/write | Word | 0000h | Section 24.4.15 | | 2Ch | UCBxIFG | eUSCI_Bx Interrupt Flag | Read/write | Word | 2A02h | Section 24.4.16 | | 2Eh | UCBxIV | eUSCI_Bx Interrupt Vector | Read | Word | 0000h | Section 24.4.17 | # www.ti.com ## 24.4.1 UCBxCTLW0 Register eUSCI\_Bx Control Word Register 0 #### Figure 24-17. UCBxCTLW0 Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |-------|---------|---------|----------|----------|---------|---------|---------| | UCA10 | UCSLA10 | UCMM | Reserved | UCMST | UCM | ODEx | UCSYNC | | rw-0 | rw-0 | rw-0 | rO | rw-0 | rw-0 | rw-0 | r1 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | UCS | SELx | UCTXACK | UCTR | UCTXNACK | UCTXSTP | UCTXSTT | UCSWRST | | rw-1 | rw-1 | rw-0 | rw-0 | rw-0 | rw-0 | rw-0 | rw-1 | Modify only when UCSWRST = 1. ## Table 24-4. UCBxCTLW0 Register Description | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15 | UCA10 | RW | Oh | Own addressing mode select. Modify only when UCSWRST = 1. 0b = Own address is a 7-bit address. 1b = Own address is a 10-bit address. | | 14 | UCSLA10 | RW | Oh | Slave addressing mode select 0b = Address slave with 7-bit address 1b = Address slave with 10-bit address | | 13 | UCMM | RW | Oh | Multi-master environment select. Modify only when UCSWRST = 1. 0b = Single master environment. There is no other master in the system. The address compare unit is disabled. 1b = Multiple-master environment | | 12 | Reserved | R | 0h | Reserved | | 11 | UCMST | RW | Oh | Master mode select. When a master loses arbitration in a multiple-master environment (UCMM = 1), the UCMST bit is automatically cleared and the module acts as slave. 0b = Slave mode 1b = Master mode | | 10-9 | UCMODEx | RW | 0h | eUSCI_B mode. The UCMODEx bits select the synchronous mode when UCSYNC = 1. Modify only when UCSWRST = 1. 00b = 3-pin SPI 01b = 4-pin SPI (master or slave enabled if STE = 1) 10b = 4-pin SPI (master or slave enabled if STE = 0) 11b = I <sup>2</sup> C mode | | 8 | UCSYNC | RW | 1h | Synchronous mode enable. For eUSCI_B always read and write as 1. | | 7-6 | UCSSELx | RW | 3h | eUSCI_B clock source select. These bits select the BRCLK source clock. These bits are ignored in slave mode. Modify only when UCSWRST = 1. 00b = UCLKI 01b = Device specific 10b = SMCLK 11b = SMCLK | | 5 | UCTXACK | RW | 0h | Transmit ACK condition in slave mode with enabled address mask register. After the UCSTTIFG has been set, the user needs to set or reset the UCTXACK flag to continue with the I2C protocol. The clock is stretched until the UCBxCTL1 register has been written. This bit is cleared automatically after the ACK has been send. 0b = Do not acknowledge the slave address 1b = Acknowledge the slave address | # Table 24-4. UCBxCTLW0 Register Description (continued) | Bit | Field | Туре | Reset | Description | |-----|----------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 4 | UCTR | RW | Oh | Transmitter/receiver 0b = Receiver 1b = Transmitter | | 3 | UCTXNACK | RW | Oh | Transmit a NACK. UCTXNACK is automatically cleared after a NACK is transmitted. Only for slave receiver mode. 0b = Acknowledge normally 1b = Generate NACK | | 2 | UCTXSTP | RW | Oh | Transmit STOP condition in master mode. Ignored in slave mode. In master receiver mode, the STOP condition is preceded by a NACK. UCTXSTP is automatically cleared after STOP is generated. This bit is a don't care, if automatic UCASTPx is different from 01 or 10. 0b = No STOP generated 1b = Generate STOP | | 1 | UCTXSTT | RW | Oh | Transmit START condition in master mode. Ignored in slave mode. In master receiver mode, a repeated START condition is preceded by a NACK. UCTXSTT is automatically cleared after START condition and address information is transmitted. Ignored in slave mode. 0b = Do not generate START condition 1b = Generate START condition | | 0 | UCSWRST | RW | 1h | Software reset enable. 0b = Disabled. eUSCI_B released for operation. 1b = Enabled. eUSCI_B logic held in reset state. | ## 24.4.2 UCBxCTLW1 Register eUSCI\_Bx Control Word Register 1 #### Figure 24-18. UCBxCTLW1 Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |------|--------|-----------|----------|------|------|------|----------| | | | | Reserved | | | | UCETXINT | | r0 | r0 | r0 | rO | r0 | r0 | r0 | rw-0 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | UCCLTO | UCSTPNACK | UCSWACK | UCAS | STPx | UCG | iLITx | | rw-0 Modify only when UCSWRST = 1. ## Table 24-5. UCBxCTLW1 Register Description | Bit | Field | Туре | Reset | Description | |------|-----------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-9 | Reserved | R | 0h | Reserved | | 8 | UCETXINT | RW | 0h | Early UCTXIFG0. Only in slave mode. When this bit is set, the slave addresses defined in UCxI2COA1 to UCxI2COA3 must be disabled. Modify only when UCSWRST = 1. 0b = UCTXIFGx is set after an address match with UCxI2COAx and the direction bit indicating slave transmit 1b = UCTXIFG0 is set for each START condition | | 7-6 | UCCLTO | RW | 0h | Clock low time-out select. Modify only when UCSWRST = 1. 00b = Disable clock low time-out counter 01b = 135000 MODCLK cycles (approximately 28 ms) 10b = 150000 MODCLK cycles (approximately 31 ms) 11b = 165000 MODCLK cycles (approximately 34 ms) | | 5 | UCSTPNACK | RW | Oh | The UCSTPNACK bit allows to make the eUSCI_B master acknowledge the last byte in master receiver mode as well. This is not conform to the I²C specification and should be used only for slaves that automatically release the SDA after a fixed packet length. Modify only when UCSWRST = 1. 0b = Send a not acknowledge before the STOP condition as a master receiver (conform to I2C standard) 1b = All bytes are acknowledged by the eUSCI_B when configured as master receiver | | 4 | UCSWACK | RW | Oh | Using this bit it is possible to select, whether the eUSCI_B module triggers the sending of the ACK of the address or if it is controlled by software. 0b = The address acknowledge of the slave is controlled by the eUSCI_B module 1b = The user needs to trigger the sending of the address ACK by issuing UCTXACK | | 3-2 | UCASTPX | RW | Oh | Automatic STOP condition generation. In slave mode, only settings 00b and 01b are available. Modify only when UCSWRST = 1. 00b = No automatic STOP generation. The STOP condition is generated after the user sets the UCTXSTP bit. The value in UCBxTBCNT is a don't care. 01b = UCBCNTIFG is set with the byte counter reaches the threshold defined in UCBxTBCNT 10b = A STOP condition is generated automatically after the byte counter value reached UCBxTBCNT. UCBCNTIFG is set with the byte counter reaching the threshold. 11b = Reserved | # Table 24-5. UCBxCTLW1 Register Description (continued) | Bit | Field | Туре | Reset | Description | |-----|---------|------|-------|----------------------------| | 1-0 | UCGLITx | RW | 0h | Deglitch time 00b = 50 ns | | | | | | 00b = 50 hs<br>01b = 25 ns | | | | | | 10b = 12.5 ns | | | | | | 11b = 6.25 ns | #### 24.4.3 UCBxBRW Register eUSCI\_Bx Bit Rate Control Word Register #### Figure 24-19. UCBxBRW Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----|----|----|-----|-----|----|----|----| | | | | UCI | BRx | | | | | rw | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | UCI | BRx | | | | | rw Modify only when UCSWRST = 1. ## Table 24-6. UCBxBRW Register Description | Bit | Field | Туре | Reset | Description | |------|-------|------|-------|-------------------------------| | 15-0 | UCBRx | RW | 0h | Bit clock prescaler. | | | | | | Modify only when UCSWRST = 1. | #### 24.4.4 UCBxSTATW eUSCI\_Bx Status Word Register ## Figure 24-20. UCBxSTATW Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------|----------|------|---------|------|------|------|-----| | | | | UCB | CNTx | | | | | r-0 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Reserved | UCSCLLOW | UCGC | UCBBUSY | | Rese | rved | | | r0 | r-0 | r-0 | r-0 | r-0 | r0 | r0 | r0 | ## Table 24-7. UCBxSTATW Register Description | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-8 | UCBCNTx | R | 0h | Hardware byte counter value. Reading this register returns the number of bytes received or transmitted on the I2C-Bus since the last START or RESTART. There is no synchronization of this register done. When reading UCBxBCNT during the first bit position, a faulty readback can occur. | | 7 | Reserved | R | 0h | Reserved | | 6 | UCSCLLOW | R | Oh | SCL low 0b = SCL is not held low 1b = SCL is held low | | 5 | UCGC | R | 0h | General call address received. UCGC is automatically cleared when a START condition is received. 0b = No general call address received 1b = General call address received | | 4 | UCBBUSY | R | Oh | Bus busy 0b = Bus inactive 1b = Bus busy | | 3-0 | Reserved | R | 0h | Reserved | ## 24.4.5 UCBxTBCNT Register eUSCI\_Bx Byte Counter Threshold Register #### Figure 24-21. UCBxTBCNT Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |------|------|------|------|-------|------|------|------| | | | | Rese | erved | | | | | rO | r0 | r0 | r0 | r0 | r0 | r0 | rO | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | UCTE | BCNTx | | | | | rw-0 Modify only when UCSWRST = 1. ## Table 24-8. UCBxTBCNT Register Description | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-8 | Reserved | R | 0h | Reserved | | 7-0 | UCTBCNTx | RW | Oh | The byte counter threshold value is used to set the number of I2C data bytes after which the automatic STOP or the UCSTPIFG should occur. This value is evaluated only if UCASTPx is different from 00. Modify only when UCSWRST = 1. | ## 24.4.6 UCBxRXBUF Register eUSCI\_Bx Receive Buffer Register #### Figure 24-22. UCBxRXBUF Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----|----|----|------|-------|----|----|----| | | | | Rese | erved | | | | | r0 | r0 | r0 | rO | rO | r0 | r0 | r0 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | UCRX | BUFx | | | | | r | r | r | r | r | r | r | r | #### Table 24-9. UCBxRXBUF Register Description | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-8 | Reserved | R | 0h | Reserved | | 7-0 | UCRXBUFx | R | 0h | The receive-data buffer is user accessible and contains the last received character from the receive shift register. Reading UCBxRXBUF resets the UCRXIFGx flags. | #### 24.4.7 UCBxTXBUF eUSCI\_Bx Transmit Buffer Register #### Figure 24-23. UCBxTXBUF Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----|----|----|------|-------|----|----|----| | | | | Rese | erved | | | | | r0 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | UCTX | BUFx | | | | | rw ## Table 24-10. UCBxTXBUF Register Description | Bit | Field | Туре | Reset | Description | |------|----------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-8 | Reserved | R | 0h | Reserved | | 7-0 | UCTXBUFx | RW | 0h | The transmit data buffer is user accessible and holds the data waiting to be moved into the transmit shift register and transmitted. Writing to the transmit data buffer clears the UCTXIFGx flags. | ## 24.4.8 UCBxI2COA0 Register eUSCI\_Bx I2C Own Address 0 Register #### Figure 24-24. UCBxI2COA0 Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|------|------|-------|------|--------|------|------| | UCGCEN | | Rese | erved | | UCOAEN | I2C | OA0 | | rw-0 | r0 | r0 | r0 | r0 | rw-0 | rw-0 | rw-0 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | I2C | OA0 | | | | | rw-0 Modify only when UCSWRST = 1. ## Table 24-11. UCBxI2COA0 Register Description | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15 | UCGCEN | RW | Oh | General call response enable. This bit is only available in UCBxI2COA0. Modify only when UCSWRST = 1. 0b = Do not respond to a general call 1b = Respond to a general call | | 14-11 | Reserved | R | 0h | Reserved | | 10 | UCOAEN | RW | Oh | Own Address enable register. With this register it can be selected if the I2C slave-address related to this register UCBxI2COA0 is evaluated or not. Modify only when UCSWRST = 1. 0b = The slave address defined in I2COA0 is disabled 1b = The slave address defined in I2COA0 is enabled | | 9-0 | I2COAx | RW | Oh | I2C own address. The I2COA0 bits contain the local address of the eUSCIx_B I2C controller. The address is right justified. In 7-bit addressing mode, bit 6 is the MSB and bits 9-7 are ignored. In 10-bit addressing mode, bit 9 is the MSB. Modify only when UCSWRST = 1. | ## 24.4.9 UCBxl2COA1 Register eUSCI\_Bx I2C Own Address 1 Register #### Figure 24-25. UCBxI2COA1 Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |------|------|----------|--------|------|------|------|------| | | | Reserved | UCOAEN | I2C | OA1 | | | | rw-0 | r0 | r0 | rO | r0 | rw-0 | rw-0 | rw-0 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | I2C | OA1 | | | | | rw-0 Modify only when UCSWRST = 1. # Table 24-12. UCBxI2COA1 Register Description | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-11 | Reserved | R | 0h | Reserved | | 10 | UCOAEN | RW | Oh | Own Address enable register. With this register it can be selected if the I2C slave-address related to this register UCBxI2COA1 is evaluated or not. Modify only when UCSWRST = 1. 0b = The slave address defined in I2COA1 is disabled 1b = The slave address defined in I2COA1 is enabled | | 9-0 | I2COA1 | RW | 0h | I2C own address. The I2COAx bits contain the local address of the eUSCIx_B I2C controller. The address is right justified. In 7-bit addressing mode, bit 6 is the MSB and bits 9-7 are ignored. In 10-bit addressing mode, bit 9 is the MSB. Modify only when UCSWRST = 1. | ## 24.4.10 UCBxI2COA2 Register eUSCI\_Bx I2C Own Address 2 Register #### Figure 24-26. UCBxI2COA2 Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |------|------|----------|--------|------|------|------|------| | | | Reserved | UCOAEN | I2C | OA2 | | | | rw-0 | rO | rO | r0 | rO | rw-0 | rw-0 | rw-0 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | I2C | OA2 | | | | | rw-0 Modify only when UCSWRST = 1. # Table 24-13. UCBxI2COA2 Register Description | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-11 | Reserved | R | 0h | Reserved | | 10 | UCOAEN | RW | Oh | Own Address enable register. With this register it can be selected if the I2C slave-address related to this register UCBxI2COA2 is evaluated or not. Modify only when UCSWRST = 1. 0b = The slave address defined in I2COA2 is disabled 1b = The slave address defined in I2COA2 is enabled | | 9-0 | I2COA2 | RW | Oh | I2C own address. The I2COAx bits contain the local address of the eUSCIx_B I2C controller. The address is right justified. In 7-bit addressing mode, bit 6 is the MSB and bits 9-7 are ignored. In 10-bit addressing mode, bit 9 is the MSB. Modify only when UCSWRST = 1. | ## 24.4.11 UCBxI2COA3 Register eUSCI\_Bx I2C Own Address 3 Register #### Figure 24-27. UCBxI2COA3 Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |------|------|----------|--------|------|------|------|------| | | | Reserved | UCOAEN | I2C | OA3 | | | | rw-0 | r0 | rO | r0 | r0 | rw-0 | rw-0 | rw-0 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | I2C | OA3 | | | | | rw-0 Modify only when UCSWRST = 1. ## Table 24-14. UCBxI2COA3 Register Description | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-11 | Reserved | R | 0h | Reserved | | 10 | UCOAEN | RW | Oh | Own Address enable register. With this register it can be selected if the I2C slave-address related to this register UCBxI2COA3 is evaluated or not. Modify only when UCSWRST = 1. 0b = The slave address defined in I2COA3 is disabled 1b = The slave address defined in I2COA3 is enabled | | 9-0 | I2COA3 | RW | 0h | I2C own address. The I2COA3 bits contain the local address of the eUSCIx_B I2C controller. The address is right justified. In 7-bit addressing mode, bit 6 is the MSB and bits 9-7 are ignored. In 10-bit addressing mode, bit 9 is the MSB. Modify only when UCSWRST = 1. | ## 24.4.12 UCBxADDRX Register eUSCI\_Bx I2C Received Address Register #### Figure 24-28. UCBxADDRX Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |-----|----------|-----|-----|------|-----|-----|-----| | | Reserved | | | | | | | | r-0 | r0 | rO | rO | rO | r0 | r-0 | r-0 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | ADD | )RXx | | | | | r-0 ## Table 24-15. UCBxADDRX Register Description | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-10 | Reserved | R | 0h | Reserved | | 9-0 | ADDRXx | R | 0h | Received Address Register. This register contains the last received slave address on the bus. Using this register and the address mask register it is possible to react on more than one slave address using one eUSCI_B module. | ## 24.4.13 UCBxADDMASK Register eUSCI\_Bx I2C Address Mask Register #### Figure 24-29. UCBxADDMASK Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |------|------|------|-------|-------|------|------|-------| | | | Rese | erved | | | ADDN | MASKx | | r-0 | r0 | r0 | r0 | r0 | r0 | rw-1 | rw-1 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | ADDN | ЛАSKx | | | | | rw-1 Modify only when UCSWRST = 1. ## Table 24-16. UCBxADDMASK Register Description | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-10 | Reserved | R | 0h | Reserved | | 9-0 | ADDMASKx | RW | 3FFh | Address Mask Register. By clearing the corresponding bit of the own address, this bit is a don't care when comparing the address on the bus to the own address. Using this method, it is possible to react on more than one slave address. When all bits of ADDMASKx are set, the address mask feature is deactivated. Modify only when UCSWRST = 1. | ## 24.4.14 UCBxI2CSA Register eUSCI\_Bx I2C Slave Address Register #### Figure 24-30. UCBxI2CSA Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |------|------|------|-------|------|------|------|------| | | | Rese | erved | | | I2C | SAx | | r-0 | rO | rO | rO | rO | rO | rw-0 | rw-0 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | I2C | SAx | | | | | rw-0 ## Table 24-17. UCBxI2CSA Register Description | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-10 | Reserved | R | 0h | Reserved | | 9-0 | I2CSAx | RW | | I2C slave address. The I2CSAx bits contain the slave address of the external device to be addressed by the eUSCIx_B module. It is only used in master mode. The address is right justified. In 7-bit slave addressing mode, bit 6 is the MSB and bits 9-7 are ignored. In 10-bit slave addressing mode, bit 9 is the MSB. | ## 24.4.15 UCBxIE Register eUSCI\_Bx I2C Interrupt Enable Register #### Figure 24-31. UCBxIE Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------|----------|----------|---------|---------|---------|---------|---------| | Reserved | UCBIT9IE | UCTXIE3 | UCRXIE3 | UCTXIE2 | UCRXIE2 | UCTXIE1 | UCRXIE1 | | r0 | rw-0 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | UCCLTOIE | UCBCNTIE | UCNACKIE | UCALIE | UCSTPIE | UCSTTIE | UCTXIE0 | UCRXIE0 | | rw-0 #### Table 24-18. UCBxIE Register Description | Bit | Field | Туре | Reset | Description | |-----|----------|------|-------|---------------------------------------------------------------------------------------| | 15 | Reserved | R | 0h | Reserved | | 14 | UCBIT9IE | RW | Oh | Bit position 9 interrupt enable 0b = Interrupt disabled 1b = Interrupt enabled | | 13 | UCTXIE3 | RW | Oh | Transmit interrupt enable 3 0b = Interrupt disabled 1b = Interrupt enabled | | 12 | UCRXIE3 | RW | Oh | Receive interrupt enable 3 0b = Interrupt disabled 1b = Interrupt enabled | | 11 | UCTXIE2 | RW | Oh | Transmit interrupt enable 2 0b = Interrupt disabled 1b = Interrupt enabled | | 10 | UCRXIE2 | RW | Oh | Receive interrupt enable 2 0b = Interrupt disabled 1b = Interrupt enabled | | 9 | UCTXIE1 | RW | Oh | Transmit interrupt enable 1 0b = Interrupt disabled 1b = Interrupt enabled | | 8 | UCRXIE1 | RW | Oh | Receive interrupt enable 1 0b = Interrupt disabled 1b = Interrupt enabled | | 7 | UCCLTOIE | RW | Oh | Clock low time-out interrupt enable. 0b = Interrupt disabled 1b = Interrupt enabled | | 6 | UCBCNTIE | RW | Oh | Byte counter interrupt enable. 0b = Interrupt disabled 1b = Interrupt enabled | | 5 | UCNACKIE | RW | Oh | Not-acknowledge interrupt enable 0b = Interrupt disabled 1b = Interrupt enabled | | 4 | UCALIE | RW | Oh | Arbitration lost interrupt enable 0b = Interrupt disabled 1b = Interrupt enabled | | 3 | UCSTPIE | RW | Oh | STOP condition interrupt enable 0b = Interrupt disabled 1b = Interrupt enabled | # Table 24-18. UCBxIE Register Description (continued) | Bit | Field | Туре | Reset | Description | |-----|---------|------|-------|-----------------------------------------------------------------------------------| | 2 | UCSTTIE | RW | Oh | START condition interrupt enable 0b = Interrupt disabled 1b = Interrupt enabled | | 1 | UCTXIE0 | RW | Oh | Transmit interrupt enable 0 0b = Interrupt disabled 1b = Interrupt enabled | | 0 | UCRXIE0 | RW | Oh | Receive interrupt enable 0 0b = Interrupt disabled 1b = Interrupt enabled | ## 24.4.16 UCBxIFG Register eUSCI\_Bx I2C Interrupt Flag Register #### Figure 24-32. UCBxIFG Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |-----------|-----------|-----------|----------|----------|----------|----------|----------| | Reserved | UCBIT9IFG | UCTXIFG3 | UCRXIFG3 | UCTXIFG2 | UCRXIFG2 | UCTXIFG1 | UCRXIFG1 | | r0 | rw-0 | rw-1 | rw-0 | rw-1 | rw-0 | rw-1 | rw-0 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | UCCLTOIFG | UCBCNTIFG | UCNACKIFG | UCALIFG | UCSTPIFG | UCSTTIFG | UCTXIFG0 | UCRXIFG0 | | rw-0 | rw-0 | rw-0 | rw-0 | rw-0 | rw-0 | rw-1 | rw-0 | # Table 24-19. UCBxIFG Register Description | Bit | Field | Туре | Reset | Description | |-----|-----------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15 | Reserved | R | 0h | Reserved | | 14 | UCBIT9IFG | RW | 0h | Bit position 9 interrupt flag 0b = No interrupt pending 1b = Interrupt pending | | 13 | UCTXIFG3 | RW | 1h | eUSCI_B transmit interrupt flag 3. UCTXIFG3 is set when UCBxTXBUF is empty in slave mode, if the slave address defined in UCBxI2COA3 was on the bus in the same frame. 0b = No interrupt pending 1b = Interrupt pending | | 12 | UCRXIFG3 | RW | Oh | Receive interrupt flag 2. UCRXIFG2 is set when UCBxRXBUF has received a complete byte in slave mode and if the slave address defined in UCBxI2COA2 was on the bus in the same frame. 0b = No interrupt pending 1b = Interrupt pending | | 11 | UCTXIFG2 | RW | Oh | eUSCI_B transmit interrupt flag 2. UCTXIFG2 is set when UCBxTXBUF is empty in slave mode, if the slave address defined in UCBxI2COA2 was on the bus in the same frame. 0b = No interrupt pending 1b = Interrupt pending | | 10 | UCRXIFG2 | RW | Oh | Receive interrupt flag 2. UCRXIFG2 is set when UCBxRXBUF has received a complete byte in slave mode and if the slave address defined in UCBxI2COA2 was on the bus in the same frame. 0b = No interrupt pending 1b = Interrupt pending | | 9 | UCTXIFG1 | RW | 1h | eUSCI_B transmit interrupt flag 1. UCTXIFG1 is set when UCBxTXBUF is empty in slave mode, if the slave address defined in UCBxI2COA1 was on the bus in the same frame. 0b = No interrupt pending 1b = Interrupt pending | | 8 | UCRXIFG1 | RW | Oh | Receive interrupt flag 1. UCRXIFG1 is set when UCBxRXBUF has received a complete byte in slave mode and if the slave address defined in UCBxI2COA1 was on the bus in the same frame. 0b = No interrupt pending 1b = Interrupt pending | | 7 | UCCLTOIFG | RW | Oh | Clock low time-out interrupt flag 0b = No interrupt pending 1b = Interrupt pending | | 6 | UCBCNTIFG | RW | Oh | Byte counter interrupt flag. When using this interrupt the user needs to ensure enough processing bandwidth (see the Byte Counter Interrupt section). 0b = No interrupt pending 1b = Interrupt pending | # Table 24-19. UCBxIFG Register Description (continued) | Bit | Field | Туре | Reset | Description | |-----|-----------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 5 | UCNACKIFG | RW | Oh | Not-acknowledge received interrupt flag. This flag only is updated when operating in master mode. 0b = No interrupt pending 1b = Interrupt pending | | 4 | UCALIFG | RW | 0h | Arbitration lost interrupt flag 0b = No interrupt pending 1b = Interrupt pending | | 3 | UCSTPIFG | RW | Oh | STOP condition interrupt flag 0b = No interrupt pending 1b = Interrupt pending | | 2 | UCSTTIFG | RW | 0h | START condition interrupt flag 0b = No interrupt pending 1b = Interrupt pending | | 1 | UCTXIFG0 | RW | Oh | eUSCI_B transmit interrupt flag 0. UCTXIFG0 is set when UCBxTXBUF is empty in master mode or in slave mode, if the slave address defined in UCBxI2COA0 was on the bus in the same frame. 0b = No interrupt pending 1b = Interrupt pending | | 0 | UCRXIFG0 | RW | Oh | eUSCI_B receive interrupt flag 0. UCRXIFG0 is set when UCBxRXBUF has received a complete character in master mode or in slave mode, if the slave address defined in UCBxI2COA0 was on the bus in the same frame. 0b = No interrupt pending 1b = Interrupt pending | ## 24.4.17 UCBxIV Register eUSCI\_Bx Interrupt Vector Register #### Figure 24-33. UCBxIV Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |-------|----|----|----|-----|-----|-----|----| | UCIVx | | | | | | | | | r0 | rO | rO | rO | rO | r0 | rO | r0 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | UCIVx | | | | | | | | | r0 | r0 | r0 | r0 | r-0 | r-0 | r-0 | r0 | #### Table 24-20. UCBxIV Register Description | Bit | Field | Туре | Reset | Description | | |------|-------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | 15-0 | UCIVx | R | 0h | eUSCI_B interrupt vector value. It generates an value that can be used as address offset for fast interrupt service routine handling. Writing to this register clears all pending interrupt flags. | | | | | | | 00h = No interrupt pending | | | | | | | 02h = Interrupt Source: Arbitration lost; Interrupt Flag: UCALIFG; Interrupt Priority: Highest | | | | | | | 04h = Interrupt Source: Not acknowledgment; Interrupt Flag: UCNACKIFG | | | | | | | 06h = Interrupt Source: Start condition received; Interrupt Flag: UCSTTIFG | | | | | | | 08h = Interrupt Source: Stop condition received; Interrupt Flag: UCSTPIFG | | | | | | | 0Ah = Interrupt Source: Slave 3 Data received; Interrupt Flag: UCRXIFG3 | | | | | | | 0Ch = Interrupt Source: Slave 3 Transmit buffer empty; Interrupt Flag: UCTXIFG3 | | | | | | | 0Eh = Interrupt Source: Slave 2 Data received; Interrupt Flag: UCRXIFG2 | | | | | | | 10h = Interrupt Source: Slave 2 Transmit buffer empty; Interrupt Flag: UCTXIFG2 | | | | | | | 12h = Interrupt Source: Slave 1 Data received; Interrupt Flag: UCRXIFG1 | | | | | | | 14h = Interrupt Source: Slave 1 Transmit buffer empty; Interrupt Flag: UCTXIFG1 | | | | | | | 16h = Interrupt Source: Data received; Interrupt Flag: UCRXIFG0 | | | | | | | 18h = Interrupt Source: Transmit buffer empty; Interrupt Flag: UCTXIFG0 | | | | | | | 1Ah = Interrupt Source: Byte counter zero; Interrupt Flag: UCBCNTIFG | | | | | | | 1Ch = Interrupt Source: Clock low time-out; Interrupt Flag: UCCLTOIFG | | | | | | | 1Eh = Interrupt Source: Nineth bit position; Interrupt Flag: UCBIT9IFG; Priority: Lowest | | # Manchester Function Module (MFM) The Manchester Function Module (MFM) is built-in glue logic between port logic and the eUSCI\_A or eUSCI\_B module. A Manchester codec is implemented to decode a 50% duty Manchester encoded data. In addition to coding function, this module is also able to generate a data frame for cooperation with the eUSCI\_A or eUSCI\_B module in SPI mode. The logic implements a virtual SPI master for buffering all transmit and receive data from and to the eUSCI\_A or eUSCI\_B module, when the latter is always configured as 4-wire SPI slave. The logic also provides one trigger output to indicate the receive completion. With proper configuration and external analog front-end circuitry, the logic can help simply implement a full-duplex Manchester codec. This module also support a hardware timing by linking the decoder and encoder through a Timer\_A or Timer\_B capture and output channel. Topic Page | 25.1 | MFM Decoder Introduction | 666 | |------|---------------------------------|-----| | 25.2 | Manchester Codec Operation | 666 | | 25.3 | Clock Generation | 667 | | 25.4 | Manchester Coding | 667 | | 25.5 | Clock Recovery and Regeneration | 668 | | 25.6 | Codec Interface | 668 | | 25.7 | System Integration Reference | 669 | MFM Decoder Introduction www.ti.com #### 25.1 MFM Decoder Introduction The MFM codec operates in AM, LPM0, and LPM1. The MFM codec is off in LPM2 and above modes. The MFM codec includes the following logic: - Clock generation - Manchester decoder - Manchester encoder - Frame control - SPI interface control - · Status machine control The Pulse Positioning Core Decoder and the Manchester Core Encoder are the core logic implementing the function. For more details, see Section 25.4 and . Figure 25-1 shows the block diagram of the MFM. Figure 25-1. MFM Block Diagram #### 25.2 Manchester Codec Operation The MFM module can construct a two-way Manchester coding of a 512-bit packet. Each transmit or receive data packet containing 256-bit data is encoded in Manchester coding. This module requires an 8x oversampling rate at each bit. With SMCLK as the oversampling clock, the baud rate is is SMCLK/8. For example, to implement a 500-kbps raw data rate, SMCLK must be configured at 4 MHz. This module is implemented as a glue logic between a port and an eUSCI\_A or eUSCI\_B module. To enable the MFM module, the port selection must be configured properly (see the device-specific data sheet for port selection details). While it is enabled by the port selection setting, the MFM module is active and operates as an SPI master. The corresponding eUSCI\_A or eUSCI\_B must be configured in SPI slave mode to fetch received data when a receive interrupt occurs and to fetch dummy data for the next transmit data then a transmit buffer empty interrupt occurs. The entire 256-bit data is divided into 32 bytes that can be read or written through the eUSCI\_A or eUSCI\_B transmit and receive data buffer. To transmit the data, a hardware trigger is pushed by a PWM output channel from given Timer\_A or Timer\_B output compare. See the device-specific data sheet for the transmit trigger configuration. Because the trigger immediately starts a complete 512-bit packet transmission, the first byte must be prepared before the trigger arrives. www.ti.com Clock Generation This module automatically receives a 512-bit data packet as long as the first bit is 1. The module receives data from the port until an error occurs or all bits are received at the end of the 32<sup>nd</sup> SPI transmission. For every 8-bit Manchester data bit received, a data ready interrupt is triggered by the SPI to notify the CPU to fetch the data before the next byte is received. Figure 25-2. Manchester Code Time Sequence #### 25.3 Clock Generation The MFM codec always uses a 8x oversampling rate for data decoding and encoding. A typical 500-kbps data requires a 4-MHz SMCLK as the clock source. Because several combinations of DIVS (SMCLK divider) and DIVM (MCLK divider) can result in the required 4 MHz, TI recommends that you configure the clock for the trade-off between systems power and performance as well as for the operation of other peripherals. A variable data rate can be achieved by changing the system clock settings to generate SMCLK at 4 times the target data rate. #### 25.4 Manchester Coding Transmit and receive data uses standard Manchester coding: - Logic 0: The first half of the bit duration is low, and the second half of the bit duration is high. - Logic 1: The first half of the bit duration is high, and the second half of the bit duration is low. Figure 25-3 shows Manchester coding. Figure 25-3. Transmit Data Manchester Coding The Manchester encoded bit is used to indicate the subcarrier modulation as output on pinout in some radio systems. #### 25.5 Clock Recovery and Regeneration Clock recovery and regeneration applies to the codec only in receiving mode when the Manchester decoder is active. Clock recovery and regeneration lets the decoder stay synchronized with the received bit stream with up to 25% clock variation between the reader and the tag. The receiver uses a sampling clock with a frequency that is 8 times the bit rate to determine the received bit stream (for example, 500-kbps bit stream at a 4-MHz clock). To effectively detect Manchester coding, each bit is detected by two durations, each of which contains 4 phases. Each pair of consecutive durations is used to decode the raw data. The phase clock at 4 MHz ticks the phase counter from 0 to 3. To compensate for phase jitter caused by clock accuracy, the counter is always forced to 0 at the transition regardless its value. The duration is detected at phase 1 and phase 2. The duration logic is detected as logic 1 only when both logic 1s are detected at ½ phase of 1 and 2. Otherwise, the phase logic is detected as logic 0. Figure 25-4 shows the ½ phase counter. The beacon is identified in the same way with 3 times of oversampling rate of general data recieving. Figure 25-4. MFM Clock Synchronization #### 25.6 Codec Interface #### 25.6.1 SPI Interface The decoder supports a general frame format with 8-bit data, which is sent to eUSCI\_A or eUSCI\_B via SPI port. When enabled, MFM works as an SPI master to transmit data to eUSCI\_A or eUSCI\_B, which must be configured as SPI slave. The SPI interface utilizes a standard 4-wire interface consisting of SIMO, SOMI, SMCLK, and STE signals. The SPI interface sequence is automatically activated by the decoder upon the completion of first data bit decoding. The sequence stops when a complete byte is received or any decoding error. The user code is recommended to configure the eUSCI\_A or eUSCI\_B in interrupt driven SPI mode. In ISR of SPI receive, user code should read out the SPI receive data from the buffer as soon as possible before the next byte arrives. This is about a duration of 16µs or 64 cycles at 4MHz SMCLK for ISR operation. The transmit is activate when encoder receives a rising edge from the output compare of given Timer\_A or Timer\_B channel. #### 25.6.2 External Event Trigger The encoder features an input trigger to start a transmission. This signal should be sourced from a Timer\_A or Timer\_B output compare channel. www.ti.com Codec Interface #### 25.6.3 Interrupt Operations The decoder does not support interrupt capability. To keep the real-time performance, user code must enable the interrupt in eUSCI\_A or eUSCI\_B to get received data. #### 25.7 System Integration Reference This section describes the system integration for the use of MFM module. As this module works as glue logic between eUSCI\_A or eUSCI\_B and external pinouts, it resets to disabled by default and eUSCI\_A or eUSCI\_B can operate external pinouts directly. A dual port mapping is recommended for either general eUSCI\_A or eUSCI\_B operation or MFM enabled operation. Only when the pinouts with MFM is selected, this module will be activated in use. When enabled, MFM module can directly operate the pinouts for either receiving or transmitting data, meanwhile it performs as an SPI master to control all data flow with eUSCI\_A or eUSCI\_B. The block diagram below shows how this module works inside system, The general firmware development includes, - The initialization routine to enable the MFM module by port selection in listen/receiver mode and configure SPI into 4-wire slave mode - The SPI receive ISR to get data received. - The SPI transmit ISR to prepare next transmit data - The timer capture ISR to get the timing if required Figure 25-5. Manchester Codec System Integration Diagram Example # Embedded Emulation Module (EEM) This chapter describes the embedded emulation module (EEM) that is implemented in all devices. Topic Page | 26.1 | Embedded Emulation Module (EEM) Introduction | 671 | |------|----------------------------------------------|-----| | 26.2 | EEM Building Blocks | 673 | | 26.3 | EEM Configurations | 674 | #### 26.1 Embedded Emulation Module (EEM) Introduction Every device in this family implements an EEM. It is accessed and controlled through either 4-wire JTAG mode or Spy-Bi-Wire mode. Each implementation is device dependent and is described in Section 26.3 and the device-specific data sheet. In general, the following features are available: - Nonintrusive code execution with real-time breakpoint control - · Single-step, step-into, and step-over functionality - Full support of all low-power modes - Support for all system frequencies and for all clock sources - Up to eight (device dependent) hardware triggers or breakpoints on memory address bus (MAB) or memory data bus (MDB) - Up to two (device dependent) hardware triggers or breakpoints on CPU register write accesses - MAB, MDB, and CPU register access triggers can be combined to form up to ten (device dependent) complex triggers or breakpoints - Up to two (device dependent) cycle counters - Trigger sequencing (device dependent) - Storage of internal bus and control signals using an integrated trace buffer (device dependent) - Clock control for timers, communication peripherals, and other modules on a global device level or on a per module basis during an emulation stop Figure 26-1 shows a simplified block diagram of the largest currently available EEM implementation. For more details on how the features of the EEM can be used together with the IAR Embedded Workbench™ debugger or with Code Composer Studio™ IDE (CCS), see the application report *Advanced Debugging Using the Enhanced Emulation Module* (SLAA393) at www.msp430.com. Most other debuggers that support the MSP430 devices have the same or a similar feature set. For details, see the user's guide of the applicable debugger. Figure 26-1. Large Implementation of EEM www.ti.com EEM Building Blocks #### 26.2 EEM Building Blocks #### 26.2.1 Triggers The event control in the EEM of the MSP430 system consists of triggers, which are internal signals indicating that a certain event has happened. These triggers may be used as simple breakpoints, but it is also possible to combine two or more triggers to allow detection of complex events and cause various reactions other than stopping the CPU. In general, the triggers can be used to control the following functional blocks of the EEM: - Breakpoints (CPU stop) - State storage - Sequencer - Cycle counter There are two different types of triggers – the memory trigger and the CPU register write trigger. Each memory trigger block can be independently selected to compare either the MAB or the MDB with a given value. Depending on the implemented EEM, the comparison can be =, $\neq$ , $\geq$ , or $\leq$ . The comparison can also be limited to certain bits with the use of a mask. The mask is either bit-wise or byte-wise, depending upon the device. In addition to selecting the bus and the comparison, the condition under which the trigger is active can be selected. The conditions include read access, write access, DMA access, and instruction fetch. Each CPU register write trigger block can be independently selected to compare what is written into a selected register with a given value. The observed register can be selected for each trigger independently. The comparison can be =, $\neq$ , or $\leq$ . The comparison can also be limited to certain bits with the use of a bit mask. Both types of triggers can be combined to form more complex triggers. For example, a complex trigger can signal when a particular value is written into a user-specified address. #### 26.2.2 Trigger Sequencer The trigger sequencer allows the definition of a certain sequence of trigger signals before an event is accepted for a break or state storage event. Within the trigger sequencer, it is possible to use the following features: - Four states (State 0 to State 3) - · Two transitions per state to any other state - Reset trigger that resets the sequencer to State 0. The trigger sequencer always starts at State 0 and must execute to State 3 to generate an action. If State 1 or State 2 are not required, they can be bypassed. #### 26.2.3 State Storage (Internal Trace Buffer) The state storage function uses a built-in buffer to store MAB, MDB, and CPU control signal information (that is, read, write, or instruction fetch) in a nonintrusive manner. The built-in buffer can hold up to eight entries. The flexible configuration allows the user to record the information of interest very efficiently. #### 26.2.4 Cycle Counter The cycle counter provides one or two 40-bit counters to measure the cycles used by the CPU to execute certain tasks. On some devices, the cycle counter operation can be controlled using triggers. This allows, for example, conditional profiling, such as profiling a specific section of code. EEM Building Blocks www.ti.com ## 26.2.5 Clock Control The EEM provides device-dependent flexible clock control. This is useful in applications where a running clock is needed for peripherals after the CPU is stopped (for example, to allow a UART module to complete its transfer of a character or to allow a timer to continue generating a PWM signal). The clock control is flexible and supports both modules that need a running clock and modules that must be stopped when the CPU is stopped due to a breakpoint. ## 26.3 EEM Configurations Table 26-1 gives an overview of the EEM configurations. The implemented configuration is device dependent, and details can be found in the device-specific data sheet and the following documents: Advanced Debugging Using the Enhanced Emulation Module (EEM) With CCS Version 4 (SLAA393) IAR Embedded Workbench for MSP430 User's Guide (SLAU138) Code Composer Studio for MSP430 User's Guide (SLAU157) **Table 26-1. EEM Configurations** | Feature | XS | S | М | L | |-----------------------------|----------------------------------------------------------|----------------------------------------------------------|----------------------------------------------------------|---------------------------------------------| | Memory bus triggers | 2<br>(=, ≠ only) | 3 | 5 | 8 | | Memory bus trigger mask for | 1) Low byte 2) High byte 3) Four upper addr bits | 1) Low byte 2) High byte 3) Four upper addr bits | 1) Low byte 2) High byte 3) Four upper addr bits | All 16 or 20 bits | | CPU register write triggers | 0 | 1 | 1 | 2 | | Combination triggers | 2 | 4 | 6 | 10 | | Sequencer | No | No | Yes | Yes | | State storage | No | No | No | Yes | | Cycle counter | 1 | 1 | 1 | 2<br>(including<br>triggered start or stop) | In general, the following features can be found on any device: - At least two MAB or MDB triggers supporting: - Distinction between CPU, DMA, read, and write accesses - =, $\neq$ , $\geq$ , or $\leq$ comparison (in XS, only =, $\neq$ ) - At least two trigger combination registers - Hardware breakpoints using the CPU stop reaction - At least one 40-bit cycle counter - Enhanced clock control with individual control of module clocks www.ti.com Revision History # **Revision History** NOTE: Page numbers for previous revisions may differ from page numbers in the current version. | CI | nanges from May 23, 2018 to March 12, 2019 | Page | |----|-------------------------------------------------------------------------------------------------------------------------------------------|-------| | • | Added the LCDPCTL bit in Section 1.16.2.3, Devices Without Smart Analog Combo SYSCFG2 Register | 82 | | • | Added description to show LPM5SM bit only works for some devices, starting "Only available in" in Table 2-7, PM5 Register Description | | | • | Added description to show LPM5SW bit only works for some devices, starting "Only available in" in Table 2-7, PM5CTL0 Register Description | 97 | | • | Changed the description for the FRLPMPWR bit in Table 6-3, GCCTL0 Register Description | . 307 | | • | In the RTCSS bit mux in Figure 15-1, RTC Counter Block Diagram, changed the 00b enum option from "Reserved" t clock" | | | • | In the RTCSS bit description in Table 15-2, RTCCTL Register Description, changed the 00b enum option from "Reseto "No clock (stop)" | | | • | Updated the description of the CPMSEL bit in Table 18-3, CPxCTL1 Register Field Description | | | • | Updated the sentence that begins "To convert current input to voltage output" in Section 19.2.2, TIA Input and Output | 515 | | • | Throughout Chapter 21, ADC Module, changed MODOSC to MODCLK | | | • | Corrected Figure 21-8, Pulse Sample Mode With Internal Reference in 12-Bit Mode | | | | | | #### IMPORTANT NOTICE AND DISCLAIMER TI PROVIDES TECHNICAL AND RELIABILITY DATA (INCLUDING DATASHEETS), 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, 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 (<a href="www.ti.com/legal/termsofsale.html">www.ti.com/legal/termsofsale.html</a>) 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. Mailing Address: Texas Instruments, Post Office Box 655303, Dallas, Texas 75265 Copyright © 2019, Texas Instruments Incorporated