# Errata **MSP430FG6626 Microcontroller**

# TEXAS INSTRUMENTS

# ABSTRACT

This document describes the known exceptions to the functional specifications (advisories).

# **Table of Contents**

| 1 Functional Advisories                                            | 2 |
|--------------------------------------------------------------------|---|
| 2 Preprogrammed Software Advisories                                | 2 |
| 3 Debug Only Advisories                                            | 2 |
| 4 Fixed by Compiler Advisories                                     |   |
| 5 Nomenclature, Package Symbolization, and Revision Identification | 4 |
| 5.1 Device Nomenclature                                            |   |
| 5.2 Package Markings                                               | 4 |
| 5.3 Memory-Mapped Hardware Revision (TLV Structure)                | 5 |
| 6 Advisory Descriptions                                            | 6 |
| 7 Revision History                                                 |   |
|                                                                    |   |



# **1** Functional Advisories

Advisories that affect the device's operation, function, or parametrics.

 $\checkmark$  The check mark indicates that the issue is present in the specified revision.

| Errata Number | <            |
|---------------|--------------|
| COMP10        | $\checkmark$ |
| CPU37         | $\checkmark$ |
| CPU47         | $\checkmark$ |
| CTSD1         | $\checkmark$ |
| DAC5          | $\checkmark$ |
| DMA4          | $\checkmark$ |
| DMA7          | $\checkmark$ |
| DMA10         | $\checkmark$ |
| LCDB5         | $\checkmark$ |
| LCDB6         | $\checkmark$ |
| PMM11         | $\checkmark$ |
| PMM12         | $\checkmark$ |
| PMM14         | $\checkmark$ |
| PMM15         | $\checkmark$ |
| PMM18         | $\checkmark$ |
| PMM20         | $\checkmark$ |
| PMM26         | $\checkmark$ |
| PORT15        | 1            |
| PORT19        | $\checkmark$ |
| RTC16         | $\checkmark$ |
| TB25          | $\checkmark$ |
| UCS11         | $\checkmark$ |
| USCI26        | 1            |
| USCI34        | $\checkmark$ |
| USCI35        | $\checkmark$ |
| USCI39        | $\checkmark$ |
| USCI40        | $\checkmark$ |

# 2 Preprogrammed Software Advisories

Advisories that affect factory-programmed software.

 $\checkmark$  The check mark indicates that the issue is present in the specified revision.

| Errata Number | Rev A |
|---------------|-------|
| BSL14         | 1     |

# **3 Debug Only Advisories**

Advisories that affect only debug operation.

 $\checkmark$  The check mark indicates that the issue is present in the specified revision.





| Errata Number | Rev A        |
|---------------|--------------|
| EEM17         | $\checkmark$ |
| EEM19         | $\checkmark$ |
| EEM23         | 1            |

# 4 Fixed by Compiler Advisories

Advisories that are resolved by compiler workaround. Refer to each advisory for the IDE and compiler versions with a workaround.

✓ The check mark indicates that the issue is present in the specified revision.

| Errata Number | Rev A        |
|---------------|--------------|
| CPU21         | 1            |
| CPU22         | $\checkmark$ |
| CPU40         | 1            |

Refer to the following MSP430 compiler documentation for more details about the CPU bugs workarounds.

#### TI MSP430 Compiler Tools (Code Composer Studio IDE)

- MSP430 Optimizing C/C++ Compiler: Check the --silicon\_errata option
- MSP430 Assembly Language Tools

#### MSP430 GNU Compiler (MSP430-GCC)

- MSP430 GCC Options: Check -msilicon-errata= and -msilicon-errata-warn= options
- MSP430 GCC User's Guide

#### IAR Embedded Workbench

IAR workarounds for msp430 hardware issues



# 5 Nomenclature, Package Symbolization, and Revision Identification

The revision of the device can be identified by the revision letter on the Package Markings or by the HW\_ID located inside the TLV structure of the device.

# 5.1 Device Nomenclature

To designate the stages in the product development cycle, TI assigns prefixes to the part numbers of all MSP MCU devices. Each MSP MCU commercial family member has one of two prefixes: MSP or XMS. These prefixes represent evolutionary stages of product development from engineering prototypes (XMS) through fully qualified production devices (MSP).

XMS - Experimental device that is not necessarily representative of the final device's electrical specifications

MSP - Fully qualified production device

Support tool naming prefixes:

X: Development-support product that has not yet completed Texas Instruments internal qualification testing.

null: Fully-qualified development-support product.

XMS devices and X development-support tools are shipped against the following disclaimer:

"Developmental product is intended for internal evaluation purposes."

MSP devices have been characterized fully, and the quality and reliability of the device have been demonstrated fully. TI's standard warranty applies.

Predictions show that prototype devices (XMS) have a greater failure rate than the standard production devices. TI recommends that these devices not be used in any production system because their expected end-use failure rate still is undefined. Only qualified production devices are to be used.

TI device nomenclature also includes a suffix with the device family name. This suffix indicates the temperature range, package type, and distribution format.

#

O N

# 5.2 Package Markings

ZQW113

BGA (ZQW), 113 Pin

|   | MSP430™      |
|---|--------------|
|   | FGxxxx       |
|   | NNNNNN #     |
|   | TI <u>G1</u> |
| С |              |

Die revisionPin 1 locationLot trace code

PZ100

LQFP (PZ) 100 Pin

| ₩ NNNNNN <u>G4</u><br>MSP430™ | #<br>○ |
|-------------------------------|--------|
| FGxxxx                        | N      |
| Rev#                          |        |
| 10                            |        |

= Die revision

= Pin 1 location = Lot trace code



#### ZCA113

#### NFBGA (ZCA), 113 Pin



xxxx = Part number N = Lot trace code # = Die revision ○ = Pin 1 location

#### 5.3 Memory-Mapped Hardware Revision (TLV Structure)

| Die Revision | TLV Hardware Revision |  |
|--------------|-----------------------|--|
| Rev A        | 10h                   |  |

Further guidance on how to locate the TLV structure and read out the HW\_ID can be found in the device User's Guide.



# **6** Advisory Descriptions

| BSL14       | BSL Module                                                                                                                                                                              |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Category    | Software in ROM                                                                                                                                                                         |
| Function    | BSL request to unlock the JTAG                                                                                                                                                          |
| Description | The feature in the BSL to keep the JTAG unlocked by setting the bit BSL_REQ_JTAG_OPEN in the return value has been disabled in this device.                                             |
| Workaround  | None                                                                                                                                                                                    |
| COMP10      | COMP Module                                                                                                                                                                             |
| Category    | Functional                                                                                                                                                                              |
| Function    | Comparator port output toggles when entering or leaving LPM3/LPM4                                                                                                                       |
| Description | The comparator port pin output (CECTL1.CEOUT) erroneously toggles when device enters or leaves LPM3/LPM4 modes under the following conditions:                                          |
|             | 1) Comparator is disabled (CECTL1.CEON = 0)                                                                                                                                             |
|             | AND                                                                                                                                                                                     |
|             | 2) Output polarity is enabled (CECTL1.CEOUTPOL = 1)                                                                                                                                     |
|             | AND                                                                                                                                                                                     |
|             | 3) The port pin is configured to have CEOUT functionality.                                                                                                                              |
|             | For example, if the CEOUT pin is high when the device is in Active Mode, CEOUT pin becomes low when the device enters LPM3/LPM4 modes.                                                  |
| Workaround  | When the comparator is disabled, ensure at least one of the following:                                                                                                                  |
|             | 1) Output inversion is disabled (CECTL.CEOUTPOL = 0)                                                                                                                                    |
|             | OR                                                                                                                                                                                      |
|             | 2) Change pin configuration from CEOUT to GPIO with output low.                                                                                                                         |
| CPU21       | CPU Module                                                                                                                                                                              |
| Category    | Compiler-Fixed                                                                                                                                                                          |
| Function    | Using POPM instruction on Status register may result in device hang up                                                                                                                  |
| Description | When an active interrupt service request is pending and the POPM instruction is used to set the Status Register (SR) and initiate entry into a low power mode , the device may hang up. |
| Workaround  | None. It is recommended not to use POPM instruction on the Status Register.                                                                                                             |
|             | Refer to the table below for compiler-specific fix implementation information.                                                                                                          |

#### CPU21 (continued) CPU Module

| IDE/Compiler                                       | Version Number                    | Notes                                                                                          |
|----------------------------------------------------|-----------------------------------|------------------------------------------------------------------------------------------------|
| IAR Embedded Workbench                             | Not affected                      |                                                                                                |
| TI MSP430 Compiler Tools (Code<br>Composer Studio) | v4.0.x or later                   | User is required to add the compiler<br>or assembler flag option below<br>silicon_errata=CPU21 |
| MSP430 GNU Compiler (MSP430-<br>GCC)               | MSP430-GCC 4.9 build 167 or later |                                                                                                |

### CPU22 CPU Module

Category

Compiler-Fixed

**Function** Indirect addressing mode with the Program Counter as the source register may produce unexpected results

**Description** When using the indirect addressing mode in an instruction with the Program Counter (PC) as the source operand, the instruction that follows immediately does not get executed. For example in the code below, the ADD instruction does not get executed.

mov @PC, R7 add #1h, R4

**Workaround** Refer to the table below for compiler-specific fix implementation information.

| IDE/Compiler                                       | Version Number                    | Notes                                                                                          |
|----------------------------------------------------|-----------------------------------|------------------------------------------------------------------------------------------------|
| IAR Embedded Workbench                             | Not affected                      |                                                                                                |
| TI MSP430 Compiler Tools (Code<br>Composer Studio) | v4.0.x or later                   | User is required to add the compiler<br>or assembler flag option below<br>silicon_errata=CPU22 |
| MSP430 GNU Compiler (MSP430-<br>GCC)               | MSP430-GCC 4.9 build 167 or later |                                                                                                |

| CPU37       | CPU Module                                                                                                                                                    |  |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Category    | Functional                                                                                                                                                    |  |
| Function    | Wrong program trace display in the debugger while using conditional jump instructions                                                                         |  |
| Description | The state storage window displays an incorrect sequence of instructions when:                                                                                 |  |
|             | 1. Conditional jump instructions are used to form a software loop                                                                                             |  |
|             | AND                                                                                                                                                           |  |
|             | 2. A false condition on the jump breaks out of the loop                                                                                                       |  |
|             | In such cases the trace buffer incorrectly displays the first instruction of the loop as the instruction that is executed immediately after exiting the loop. |  |
|             | Example:                                                                                                                                                      |  |



| CPU37 (continued) | CPU Module                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                  |                                                                                                                 |  |
|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|-----------------------------------------------------------------------------------------------------------------|--|
|                   | Actual Code:<br>mov #4,R4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                  |                                                                                                                 |  |
|                   | LABEL mov #1,R5<br>dec R4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                  |                                                                                                                 |  |
|                   | jnz LABEL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                  |                                                                                                                 |  |
|                   | mov #2,R6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                  |                                                                                                                 |  |
|                   | nop                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                  |                                                                                                                 |  |
|                   | State Storage Window Display                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | ys:                              |                                                                                                                 |  |
|                   | LABEL mov #1,R5<br>dec R4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                  |                                                                                                                 |  |
|                   | jnz LABEL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                  |                                                                                                                 |  |
|                   | mov #1,R5<br>nop                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                  |                                                                                                                 |  |
| Workaround        | None                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                  |                                                                                                                 |  |
|                   | Note: This erratum affects the debugger or free run mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | trace buffer display only. It do | es not affect code execution in                                                                                 |  |
| CPU40             | CPU Module                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                  |                                                                                                                 |  |
| Category          | Compiler-Fixed                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                  |                                                                                                                 |  |
| Function          | PC is corrupted when executing jump/conditional jump instruction that is followed by instruction with PC as destination register or a data section                                                                                                                                                                                                                                                                                                                                                                             |                                  |                                                                                                                 |  |
| Description       | If the value at the memory location immediately following a jump/conditional jump instruction is 0X40h or 0X50h (where X = don't care), which could either be an instruction opcode (for instructions like RRCM, RRAM, RLAM, RRUM) with PC as destination register or a data section (const data in flash memory or data variable in RAM), then the PC value is auto-incremented by 2 after the jump instruction is executed; therefore, branching to a wrong address location in code and leading to wrong program execution. |                                  |                                                                                                                 |  |
|                   | For example, a conditional jump instruction followed by data section (0140h).                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                  |                                                                                                                 |  |
|                   | @0x8012 Loop DEC.W R6<br>@0x8014 DEC.W R7<br>@0x8016 JNZ Loop<br>@0x8018 Value1 DW 0140h                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                  |                                                                                                                 |  |
| Workaround        | In assembly, insert a NOP between the jump/conditional jump instruction and program code with instruction that contains PC as destination register or the data section.                                                                                                                                                                                                                                                                                                                                                        |                                  |                                                                                                                 |  |
|                   | Refer to the table below for compiler-specific fix implementation information.                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                  |                                                                                                                 |  |
|                   | IDE/Compiler                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Version Number                   | Notes                                                                                                           |  |
|                   | IAR Embedded Workbench                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | IAR EW430 v5.51 or later         | For the command line version add<br>the following information Compiler:<br>hw_workaround=CPU40<br>Assembler:-v1 |  |

# CPU40 (continued) CPU Module

| IDE/Compiler                                       | Version Number  | Notes                                                                                          |  |
|----------------------------------------------------|-----------------|------------------------------------------------------------------------------------------------|--|
| TI MSP430 Compiler Tools (Code<br>Composer Studio) | v4.0.x or later | User is required to add the compiler<br>or assembler flag option below<br>silicon_errata=CPU40 |  |
| MSP430 GNU Compiler (MSP430-<br>GCC)               | Not affected    |                                                                                                |  |

| CPU47       | CPU Module                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Category    | Functional                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Function    | An unexpected Vacant Memory Access Flag (VMAIFG) can be triggered                                                                                                                                                                                                                                                                                                                                                                     |
| Description | An unexpected Vacant Memory Access Flag (VMAIFG) can be triggered, if a PC-<br>modifying instruction (e.g ret, push, call, pop, jmp, br) is fetched from the last addresses<br>(last 4 or 8 byte) of a memory (e.g FLASH, RAM, FRAM) that is not contiguous to a<br>higher, valid section on the memory map.<br>In debug mode using breakpoints the last 8 bytes are affected.<br>In free running mode the last 4 bytes are affected. |
| Workaround  | Edit the linker command file to make the last 4 or 8 bytes of affected memory sections unavailable, to avoid PC-modifying instructions on these locations. Remaining instructions or data can still be stored on these locations.                                                                                                                                                                                                     |
| CTSD1       | CTSD Module                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Category    | Functional                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Function    | CTSD16OFFG bit erroneously set while CTSD16 module is inactive                                                                                                                                                                                                                                                                                                                                                                        |
| Description | The CTSD16CTL.CTSD16OFFG bit is erroneously set when the CTSD16 module<br>is disabled and not actively converting (CTSD16CCTLx.CTSD16SC = 0). This<br>CTSD16CTL.CTSD16OFFG bit can only be cleared once the CTSD16 module is enabled<br>and actively converting (CTSD16CCTLx.CTSD16SC = 1).                                                                                                                                           |
|             | This errata effectively nullifies the ability to trigger NMI interrupts in response to oscillator faults, unless CTSD16 is kept enabled.                                                                                                                                                                                                                                                                                              |
| Workaround  | 1) If CTSD16 is enabled, and the fault condition is ensured not to be present, then CTSD16OFFG and OFIFG can function normally. The only way to keep CTSD16 enabled indefinitely is by setting CTSD16SC.                                                                                                                                                                                                                              |
|             | 2) While CTSD16 is not enabled, the OFIFG bit cannot be used. The other bits sourcing into it besides CTSD16OFFG (that is, XT1LFOFFG, XT1HFOFFG, XT2OFFG, and DCOFFG) can be polled or checked by software individually; but the ability to trigger the NMI upon OFIFG becoming set is no longer possible.                                                                                                                            |
| DAC5        | DAC Module                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Category    | Functional                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Function    | Switching events on alternative DAC output pins can change output level of active DAC output pin.                                                                                                                                                                                                                                                                                                                                     |



| DAC5 (continued) | DAC Module                                                                                                                                                                                                                                                                                                                                                                                |  |  |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Description      | When the DAC output has multiple pin output options, switching events on unused alternate pin output options, such as GPIO output voltage level transitions and pulses or input signals that pass GPIO high or low thresholds, dynamically affect the output voltage level of the DAC output in use. This effect only lasts for a short period after the switching event.                 |  |  |
| Workaround       | If the dynamic voltage level effect on the chosen DAC output cannot be tolerated, see the workarounds below:<br>A. Avoid high to low or low to high transitions on the alternate DAC output pin when selected DAC output pin is active. Keep alternate pin pulled high or low when DAC is in use.<br>B. Do not use pin featuring alternative DAC output, and keep in an output low state. |  |  |
| DMA4             | DMA Module                                                                                                                                                                                                                                                                                                                                                                                |  |  |
| Category         | Functional                                                                                                                                                                                                                                                                                                                                                                                |  |  |
| Function         | Corrupted write access to 20-bit DMA registers                                                                                                                                                                                                                                                                                                                                            |  |  |
| Description      | When a 20-bit wide write to a DMA address register (DMAxSA or DMAxDA) is interrupte<br>by a DMA transfer, the register contents may be unpredictable.                                                                                                                                                                                                                                     |  |  |
| Workaround       | <ol> <li>Design the application to guarantee that no DMA access interrupts 20-bit wide<br/>accesses to the DMA address registers.</li> </ol>                                                                                                                                                                                                                                              |  |  |
|                  | OR                                                                                                                                                                                                                                                                                                                                                                                        |  |  |
|                  | <ol> <li>When accessing the DMA address registers, enable the Read Modify Write disable bit<br/>(DMARMWDIS = 1) or temporarily disable all active DMA channels (DMAEN = 0).</li> </ol>                                                                                                                                                                                                    |  |  |
|                  | OR                                                                                                                                                                                                                                                                                                                                                                                        |  |  |
|                  | 3. Use word access for accessing the DMA address registers. Note that this limits the values that can be written to the address registers to 16-bit values (lower 64K of Flash).                                                                                                                                                                                                          |  |  |
| DMA7             | DMA Module                                                                                                                                                                                                                                                                                                                                                                                |  |  |
| Category         | <br>Functional                                                                                                                                                                                                                                                                                                                                                                            |  |  |
| Function         | DMA request may cause the loss of interrupts                                                                                                                                                                                                                                                                                                                                              |  |  |
| Description      | If a DMA request starts executing during the time when a module register containing an interrupt flags is accessed with a read-modify-write instruction, a newly arriving interrupt from the same module can get lost. An interrupt flag set prior to DMA execution would not be affected and remain set.                                                                                 |  |  |
| Workaround       | <ol> <li>Use a read of Interrupt Vector registers to clear interrupt flags and do not use read-<br/>modify-write instruction.</li> </ol>                                                                                                                                                                                                                                                  |  |  |
|                  | OR                                                                                                                                                                                                                                                                                                                                                                                        |  |  |
|                  | 2. Disable all DMA channels during read-modify-write instruction of specific module registers containing interrupts flags while these interrupts are activated.                                                                                                                                                                                                                           |  |  |

| DMA10       | DMA Module                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Category    | Functional                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |
| Function    | tion DMA access may cause invalid module operation                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |
| Description | The peripheral modules MPY, CRC, USB, RF1A and FRAM controller in manual mode can stall the CPU by issuing wait states while in operation. If a DMA access to the module occurs while that module is issuing a wait state, the module may exhibit undefined behavior.                                                                                                                                                    |  |  |  |
| Workaround  | Ensure that DMA accesses to the affected modules occur only when the modules are not in operation. For example with the MPY module, ensure that the MPY operation is completed before triggering a DMA access to the MPY module.                                                                                                                                                                                         |  |  |  |
| EEM16       | EEM Module                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |
| Category    | Debug                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |
| Function    | The state storage display does not work reliably when used on instructions with CPU Wait cycles.                                                                                                                                                                                                                                                                                                                         |  |  |  |
| Description | When executing instructions that require wait states; the state storage window updates incorrectly. For example a flash erase instruction causes the CPU to be held until the erase is completed i.e. the flash puts the CPU in a wait state. During this time if the state storage window is enabled it may incorrectly display any previously executed instruction multiple times.                                     |  |  |  |
| Workaround  | Do not enable the state storage display when executing instructions that require wait<br>states. Instead set a breakpoint after the instruction is completed to view the state storage<br>display.                                                                                                                                                                                                                       |  |  |  |
|             | <b>Note</b><br>This erratum affects debug mode only.                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |
| EEM17       | EEM Module                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |
| Category    | Debug                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |
| Function    | Wrong Breakpoint halt after executing Flash Erase/Write instructions                                                                                                                                                                                                                                                                                                                                                     |  |  |  |
| Description | Hardware breakpoints or Conditional Address triggered breakpoints on instructions that                                                                                                                                                                                                                                                                                                                                   |  |  |  |
| Seachbrion  | follow Flash Erase/Write instructions, stops the debugger at the actual Flash Erase/Write instruction even though the flash erase/write operation has already been executed. The hardware/conditional address triggered breakpoints that are placed on either the next two single opcode instructions OR the next double opcode instruction that follows the Flash Erase/Write instruction are affected by this erratum. |  |  |  |

**Workaround** None. Use other conditional/advanced triggered breakpoints to halt the debugger right after Flash erase/write instructions.

**Note** This erratum affects debug mode only.





| EEM19       | EEM Module                                                                                                                                                                                                                                                                                 |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Category    | Debug                                                                                                                                                                                                                                                                                      |
| Function    | DMA may corrupt data in debug mode                                                                                                                                                                                                                                                         |
| Description | When the DMA is enabled and the device is in debug mode, the data written by the DMA may be corrupted when a breakpoint is hit or when the debug session is halted.                                                                                                                        |
| Workaround  | This erratum has been addressed in MSPDebugStack version 3.5.0.1. It is also available<br>in released IDE EW430 IAR version 6.30.3 and CCS version 6.1.1 or newer.<br>If using an earlier version of either IDE or MSPDebugStack, do not halt or use breakpoints<br>during a DMA transfer. |
|             | <b>Note</b><br>This erratum applies to debug mode only.                                                                                                                                                                                                                                    |

| EEM23       | EEM Module                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Category    | Debug                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |
| Function    | EEM triggers incorrectly when modules using wait states are enabled                                                                                                                                                                                                                                                                                                                                                         |  |  |
| Description | When modules using wait states (USB, MPY, CRC and FRAM controller in manual mode) are enabled, the EEM may trigger incorrectly. This can lead to an incorrect profile counter value or cause issues with the EEMs data watch point, state storage, and breakpoint functionality.                                                                                                                                            |  |  |
| Workaround  | None.                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |
|             | <b>Note</b><br>This erratum affects debug mode only.                                                                                                                                                                                                                                                                                                                                                                        |  |  |
| LCDB5       | LCDB Module                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
| Category    | Functional                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |
| Function    | Static DC charge can built up on dedicated COMx pins.                                                                                                                                                                                                                                                                                                                                                                       |  |  |
| Description | If the device is set into LPMx.5, its dedicated COMx pins (not shared with GPIO function) are floating. External leakage paths to these pins can result in dedicated COMx pins being charged. This can lead to static DC voltages being applied to the external LCD display. This might cause long term over-stress to the LCD display and/or cause certain LCD segments to flare up when device wakes up from LPMx.5 mode. |  |  |
| Workaround  | Connect a high-resistance resistor between the dedicated COM pins and Vss to permanently discharge the affected pins.                                                                                                                                                                                                                                                                                                       |  |  |
| LCDB6       | LCDB Module                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
| Category    | Functional                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |
| Function    | LCD outputs may be corrupted by modifying register fields VLCDx and/or LCDCPEN of LCDCVCTL register while LCDON (LCDCCTL0) is set                                                                                                                                                                                                                                                                                           |  |  |

| LCDB6 (continued) | LCDB Module                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Description       | Writing to VLCDx and/or LCDCPEN register bits in LCDCVCTL register while LCDC is enabled (LCDON = '1' in LCDCCTL0 register) may corrupt the LCD output due to incorrect start-up of LCD-controller and internal voltage generation.                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
| Workaround        | Do not modify VLCDx and/or LCDCPEN bits in LCDCVCTL register while LCDON = '1'                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |
| PMM11             | PMM Module                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |
| Category          | Functional                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |
| Function          | MCLK comes up fast on exit from LPM3 and LPM4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |
| Description       | The DCO exceeds the programmed frequency of operation on exit from LPM3 and LPM4 for up to 6 us. This behavior is masked from affecting code execution by default: SVSL and SVML run in normal-performance mode and mask CPU execution for 150 us on wakeup from LPM3 and LPM4. However ,when the low-side SVS and the SVM are disabled or are operating in full-performance mode (SVMLE= 0 and SVSLE= 0, or SVMLFP= 1 and SVSLFP= 1) AND MCLK is sourced from the internal DCO running over 4 MHz, 7 MHz,11 MHz,or 14 MHz at core voltage levels 0, 1, 2, and 3, respectively, the mask lasts only 2 us. MCLK is, therefore, susceptible to run out of spec for 4 us. |  |  |
| Workaround        | Set the MCLK divide bits in the Unified Clock System Control 5 Register (UCSCTL5) to divide MCLK by two prior to entering LPM3 or LPM4 (set DIVMx= 001). This prevents MCLK from running out of spec when the CPU wakes from the low-power mode. Following the wakeup fromthe low-power mode, wait 32, 48, 80, or 100 cycles for core voltage levels 0, 1, 2, and 3, respectively, before resetting DIVM xto zero and running MCLK at full speed [for example,delay_cycles(100)]                                                                                                                                                                                       |  |  |
| PMM12             | PMM Module                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |
| Category          | Functional                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |
| Function          | SMCLK comesup fast on exit from LPM3 and LPM4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |
| Description       | The DCO exceeds the programmed frequency of operationon exit from LPM3 and LPM4 for up to 6 us. When SMCLK is sourced by the DCO, it is not masked on exit from LPM3 or LPM4. Therefore, SMCLK exceeds the programmed frequency of operation on exit from LPM3 and LPM4 for up to 6 us. The increased frequency has the potential to change the expected timing behavior of peripherals that select SMCLK as the clock source.                                                                                                                                                                                                                                         |  |  |
| Workaround        | - Use XT2 as the SMCLK oscillator source instead of the DCO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |
|                   | or                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |
|                   | - Do not disable the clock request bit for SMCLKREQEN in the Unified Clock System Control 8 Register (UCSCTL8). This means that all modules that depend on SMCLK to operate successfully should be halted or disabled before entering LPM3 or LPM4. If the increased frequency prevents the proper function of an affected module, wait 32, 48, 80 or 100 cycles for core voltage levels 0, 1, 2, or 3, respectively, before re-enabling the module. (for example,delay_cycles(100)                                                                                                                                                                                    |  |  |
| PMM14             | PMM Module                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |
| Category          | Functional                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |



| PMM14 (continued) | PMM Module                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Function          | Increasing the core level when SVS/SVM low side is configured in full-performance mode causes device reset                                                                                                                                                                                                                                                                                                                                                                    |  |  |
| Description       | When the SVS/SVM low side is configured in full performance mode<br>(SVSMLCTL.SVSLFP = 1), the setting time delay for the SVS comparators is ~2us. When<br>increasing the core level in full-performance mode; the core voltage does not settle to the<br>new level before the settling time delay of the SVS/SVM comparator expires. This results<br>in a device reset.                                                                                                      |  |  |
| Workaround        | When increasing the core level; enable the SVS/SVM low side in normal mode (SVSMLCTL.SVSLFP=0). This provides a settling time delay of approximately 150us allowing the core sufficient time to increase to the expected voltage before the delay expires.                                                                                                                                                                                                                    |  |  |
| PMM15             | PMM Module                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
| Category          | Functional                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
| Function          | Device may not wake up from LPM2, LPM3, or LPM4                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
| Description       | Device may not wake up from LPM2, LPM3 or LMP4 if an interrupt occurs within 1<br>us after the entry to the specified LPMx; entry can be caused either by user code or<br>automatically (for example, after a previous ISR is completed). Device can be recovered<br>with an external reset or a power cycle. Additionally, a PUC can also be used to reset<br>the failing condition and bring the device back to normal operation (for example, a PUC<br>caused by the WDT). |  |  |
|                   | This effect is seen when:<br>- A write to the SVSMHCTL and SVSMLCTL registers is immediately followed<br>by an LPM2, LPM3, LPM4 entry without waiting the requisite settling time<br>((PMMIFG.SVSMLDLYIFG = 0 and PMMIFG.SVSMHDLYIFG = 0)).                                                                                                                                                                                                                                   |  |  |

or

The following two conditions are met:

- The SVSL module is configured for a fast wake-up or when the SVSL/SVML module is turned off. The affected SVSMLCTL register settings are shaded in the following table.

|      | SVSLE | SVSLMD   | SVSLFP | AM, LPM0/1<br>SVSL state | Man ual<br>SVSMLACE = 0<br>LPM2/3/4<br>SVSL State | Automatic<br>SVSMLACE = 1<br>LPM2/3/4<br>SVSL State | Wakeup Time<br>LPM2/3/4   |
|------|-------|----------|--------|--------------------------|---------------------------------------------------|-----------------------------------------------------|---------------------------|
| SVSL | 0     | х        | х      | OFF                      | OFF                                               | OFF                                                 | twake-up fast             |
|      | 1     | 0        | 0      | Normal                   | OFF                                               | OFF                                                 | twake-up slow             |
|      | 1     | 0        | 1      | Full Performance         | OFF                                               | OFF                                                 | twake-up fast             |
|      | 1     | 1        | 0      | Normal                   | Normal                                            | OFF                                                 | twake-up slow             |
|      | 1     | 1        | 1      | Full Performance         | Full Performance                                  | Normal                                              | twake-up fast             |
|      | SVMLE | E SVMLFP |        | AM, LPM0/1<br>SVML state | Manual<br>SVSMLACE = 0<br>LPM2/3/4                | Automatic<br>SVSMLACE = 1<br>LPM2/3/4               | Wakeup Time<br>LPM2/3/4   |
| SVML | 0     |          |        |                          | SVML State                                        | SVML State                                          | 4                         |
|      | 0     | X        | -      | OFF                      | OFF                                               | OFF                                                 | twake-up fast             |
|      | 1     | 0        |        | Normal                   | Normal                                            | OFF                                                 | t <sub>WAKE-UP SLOW</sub> |
|      | 1     | 1        |        | Full Performance         | Full Performance                                  | Normal                                              | twake-up fast             |

#### and

-The SVSH/SVMH module is configured to transition from Normal mode to an OFF



#### PMM15 (continued) PMM Module

state when moving from Active/LPM0/LPM1 into LPM2/LPM3/LPM4 modes. The affected SVSMHCTL register settings are shaded in the following table.

|      | SVSHE | SVSHMD | SVSHFP | AM, LPM0/1 SVSH<br>state | Manual<br>SVSMHACE = 0<br>LPM2/3/4 SVSH<br>State | Automatic<br>SVSMHACE = 1<br>LPM2/3/4 SVSH<br>State |
|------|-------|--------|--------|--------------------------|--------------------------------------------------|-----------------------------------------------------|
|      | 0     | x      | x      | OFF                      | OFF                                              | OFF                                                 |
| SVSH | 1     | 0      | 0      | Normal                   | OFF                                              | OFF                                                 |
|      | 1     | 0      | 1      | Full Performance         | OFF                                              | OFF                                                 |
|      | 1     | 1      | 0      | Normal                   | Normal                                           | OFF                                                 |
|      | 1     | 1      | 1      | Full Performance         | Full Performance                                 | Normal                                              |
|      | 0.000 | SVMHFP |        | AM, LPM0/1 SVMH<br>state | Manual<br>SVSMHACE = 0                           | Automatic<br>SVSMHACE = 1                           |
|      | SVMHE |        |        |                          | LPM2/3/4 SVMH<br>State                           | LPM2/3/4 SVMH<br>State                              |
| SVMH | 0     | :      | <      | OFF                      | OFF                                              | OFF                                                 |
|      | 1     | (      | )      | Normal                   | Normal                                           | OFF                                                 |
|      | 1     | 1      |        | Full Performance         | Full Performance                                 | Normal                                              |

# Workaround Any write to the SVSMxCTL register must be followed by a settling delay (PMMIFG.SVSMLDLYIFG = 0 and PMMIFG.SVSMHDLYIFG = 0) before entering LPM2, LPM3, LPM4.

and

1. Ensure the SVSx, SVMx are configured to prevent the issue from occurring by the following:

- Configure the SVSL module for slow wake up (SVSLFP = 0). Note that this will increase the wakeup time from LPM2/3/4 to twakeupslow (~150 us).

#### or

- Do not configure the SVSH/SVMH such that the modules transition from Normal mode to an OFF state on LPM entry and ensure SVSH/SVMH is in manual mode. Instead force the modules to remain ON even in LPMx. Note that this will cause increased power consumption when in LPMx.

Refer to the MSP430 Driver Library(MSPDRIVERLIB) for proper PMM configuration functions.

Use the following function, PMM15Check (void), to determine whether or not the existing PMM configuration is affected by the erratum. The return value of the function is 1 if the configuration is affected, and 0 if the configuration is not affected.

unsigned char PMM15Check (void)

// First check if SVSL/SVML is configured for fast wake-up if ( (!(SVSMLCTL & SVSLE)) || ((SVSMLCTL & SVSLE) && (SVSMLCTL & SVSLFP)) || (!(SVSMLCTL & SVMLE)) || ((SVSMLCTL & SVMLE) && (SVSMLCTL & SVMLFP)) ) { // Next Check SVSH/SVMH settings to see if settings are affected by PMM15 if ((SVSMHCTL & SVSHE) && (!(SVSMHCTL & SVSHFP))) { if ((SVSMHCTL & SVSHE) && (!(SVSMHCTL & SVSHFP))) { if ((!(SVSMHCTL & SVSHMD)) || ((SVSMHCTL & SVSHMD) && (SVSMHCTL & SVSMHACE)) ) return 1; // SVSH affected configurations



### **PMM15** (continued) PMM Module if ((SVSMHCTL & SVMHE) && (!(SVSMHCTL & SVMHFP)) && (SVSMHCTL & SVSMHACE)) return 1; // SVMH affected configurations } return 0; // SVS/M settings not affected by PMM15 } } 2. If fast servicing of interrupts is required, add a 150us delay either in the interrupt service routine or before entry into LPM3/LPM4. **PMM18** PMM Module Functional Category Function PMM supply overvoltage protection falsely triggers POR Description The PMM Supply Voltage Monitor (SVM) high side can be configured as overvoltage protection (OVP) using the SVMHOVPE bit of SVSMHCTL register. In this mode a POR should typically be triggered when DVCC reaches ~3.75V. If the OVP feature of SVM high side is enabled going into LPM234, the SVM might trigger at DVCC voltages below 3.6V (~3.5V) within a few ns after wake-up. This can falsely cause an OVP-triggered POR. The OVP level is temperature sensitive during fail scenario and decreases with higher temperature (85 degC ~3.2V). Workaround Use automatic control mode for high-side SVS & SVM (SVSMHCTL.SVSMHACE=1). The SVM high side is inactive in LPM2, LPM3, and LPM4. **PMM20** PMM Module Category Functional Function Unexpected SVSL/SVML event during wakeup from LPM2/3/4 in fast wakeup mode Description If PMM low side is configured to operate in fast wakeup mode, during wakeup from LPM2/3/4 the internal VCORE voltage can experience voltage drop below the corresponding SVSL and SVML threshold (recommendation according to User's Guide) leading to an unexpected SVSL/SVML event. Depending on PMM configuration, this event triggers a POR or an interrupt. Note As soon the SVSL or the SVML is enabled in Normal performance mode the device is in slow wakeup mode and this erratum does not apply. In addition, this erratum has sporadic characteristic due to an internal asynchronous circuit. The drop of Vcore does not have an impact on specified device performance. Workaround If SVSL or SVML is required for application (to observe external disruptive events at Vcore pin) the slow wakeup mode has to be used to avoid unexpected SVSL/SVML events. This is achieved if the SVSL or the SVML is configured in "Normal" performance

mode (not disabled and not in "Full" Performance Mode).

| PMM26       | PMM Module                                                                                                                                                                                                                                                                                                                          |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Category    | Functional                                                                                                                                                                                                                                                                                                                          |
| Function    | Device lock-up if RST pin pulled low during write to SVSMHCTL or SVSMLCTL                                                                                                                                                                                                                                                           |
| Description | Device results in lock-up condition under one of the two scenarios below:                                                                                                                                                                                                                                                           |
|             | 1) If RST pin is pulled low during write access to SVSMHCTL, with the RST/NMI pin is configured to reset function and is pulled low (reset event) the device will stop code execution and is continuously held in reset state. RST pin is no longer functional. The only way to come out of the lock-up situation is a power cycle. |
|             | OR                                                                                                                                                                                                                                                                                                                                  |
|             | 2) If RST pin is pulled low during write access to SVSMLCTL and only if the code that<br>checks for SVSMLDLYIFG==1 is implemented without a timeout. The device will be stuck<br>in the polling loop polling since SVSMLDLYIFG will never be cleared.                                                                               |
| Workaround  | Follow the sequence below to prevent the lock-up for both use cases:<br>1) Disable RST pin reset function and switch to NMI before access SVSMHCTL or<br>SVSMLCTL.<br>then                                                                                                                                                          |
|             | 2) Activate NMI interrupt and handle reset events in this time by SW (optional if reset functionality required during access SVSMHCTL or SVSMLCTL) then                                                                                                                                                                             |
|             | 3) Enable RST pin reset function after access to SVSMHCTL or SVSMLCTL                                                                                                                                                                                                                                                               |
|             | To prevent lock-up caused by use case #2 a timeout for the SVSMLDLYIFG flag check should be implemented to 300us.                                                                                                                                                                                                                   |
| PORT15      | PORT Module                                                                                                                                                                                                                                                                                                                         |
| Category    | Functional                                                                                                                                                                                                                                                                                                                          |
| Function    | In-system debugging causes the PMALOCKED bit to be always set                                                                                                                                                                                                                                                                       |
| Description | The port mapping controller registers cannot be modified when single-stepping or halting<br>at break points between a valid password write to the PMAPWD register and the expected<br>lock of the port mapping (PMAP) registers. This causes the PMAPLOCKED bit to remain<br>set and not clear as expected.                         |
|             | Note: This erratum only applies to in-system debugging and is not applicable when operating in free-running mode.                                                                                                                                                                                                                   |
| Workaround  | Do not single step through or place break points in the port mapping configuration section of code.                                                                                                                                                                                                                                 |
| PORT19      | PORT Module                                                                                                                                                                                                                                                                                                                         |
| Category    | Functional                                                                                                                                                                                                                                                                                                                          |
| Function    | Port interrupt may be missed on entry to LPMx.5                                                                                                                                                                                                                                                                                     |
| Description | If a port interrupt occurs within a small timing window (~1MCLK cycle) of the device entry into LPM3.5 or LPM4.5, it is possible that the interrupt is lost. Hence this interrupt will not trigger a wakeup from LPMx.5.                                                                                                            |
| Workaround  | None                                                                                                                                                                                                                                                                                                                                |



| RTC16       | RTC Module                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Category    | Functional                                                                                                                                                                                                                                                                                                                                                                                                   |
| Function    | RTC_B module can seem stuck or function abnormally (jumping RTC)                                                                                                                                                                                                                                                                                                                                             |
| Description | If VBAT and DVCC (VPRIM) power up slowly and cross around the VBAK switching threshold, internal functions may not reset properly.<br>This can lead to a stuck RTC_B module or to unexpected functionality e.g. RTC_B is running faster which causes the observed time value to jump or skip forward.                                                                                                        |
| Workaround  | Prevent DVCC (VPRIM) and VBAT from crossing each other below 2V during power up. It does not matter which signal comes up first.                                                                                                                                                                                                                                                                             |
| TB25        | TB Module                                                                                                                                                                                                                                                                                                                                                                                                    |
| Category    | Functional                                                                                                                                                                                                                                                                                                                                                                                                   |
| Function    | In up mode, TBxCCRn value is immediately transferred to TBxCLn when TBxCCTLn.CLLD bits are set or 0x01 or 0x10                                                                                                                                                                                                                                                                                               |
| Description | IF Timer B is configured for Up mode,                                                                                                                                                                                                                                                                                                                                                                        |
|             | AND<br>the compare latch load event (TBxCCTLn.CLLD bits) setting is configured to update<br>TBxCCRn when TBxR reaches 0,<br>THEN                                                                                                                                                                                                                                                                             |
|             | TBxCCRn will update immediately instead of the described condition.                                                                                                                                                                                                                                                                                                                                          |
|             | This is contrary to the user guide description of TBxCCTLn.CLLD = 0x01 or 0x10 modes.                                                                                                                                                                                                                                                                                                                        |
| Workaround  | If user needs to update TBxCCRn value when TBxR counts to 0 in Timer B up mode:                                                                                                                                                                                                                                                                                                                              |
|             | <ol> <li>Set TBxCCTLn. CLLD = 0x00</li> <li>Enable the Timer B interrupt (TBIE) in TBxCTL</li> <li>Update TBxCCRn value within interrupt routine.</li> </ol>                                                                                                                                                                                                                                                 |
|             | Timer B Interrupt would need to be serviced in a timely manner to mitigate disruption or unintended timer output if an output mode is used.                                                                                                                                                                                                                                                                  |
| UCS11       | UCS Module                                                                                                                                                                                                                                                                                                                                                                                                   |
| Category    | Functional                                                                                                                                                                                                                                                                                                                                                                                                   |
| Function    | Modifying UCSCTL4 clock control register triggers an additional erroneous clock request                                                                                                                                                                                                                                                                                                                      |
| Description | Changing the SELM/SELS/SELA bits in the UCSCTL4 register will correctly configure the respective clock to use the intended clock source but might also erroneously set XT1/XT2 fault flag if the crystals are not present at XT1/XT2 or not configured in the application firmware. If the NMI interrupt for the OFIFG is enabled, an unintentional NMI interrupt will be triggered and needs to be handled. |
|             | <b>Note</b><br>The XT1/XT2 fault flag can be set regardless of which SELM/SELS/SELA bit<br>combinations are being changed.                                                                                                                                                                                                                                                                                   |
| Workaround  | Clear all the fault flags in UCSCTL7 register once after changing any of the SELM/SELS/<br>SELA bits in the UCSCTL4 register.<br>If OFIFG-NMI is enabled during clock switching, disable OFIFG-NMI interrupt during                                                                                                                                                                                          |

| UCS11 (continued) | UCS Module                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                   | changing the SELM/SELS/SELA bits in the UCSCTL4 register to prevent unintended NMI.<br>Alternatively it can be handled accordingly (clear falsely set fault flags) in the Interrupt<br>Service Routine to ensure proper OFIFG clearing.                                                                                                                                                                                                                                           |
| USCI26            | USCI Module                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Category          | Functional                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Function          | Tbuf parameter violation in I2C multi-master mode                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Description       | In multi-master I2C systems the timing parameter Tbuf (bus free time between a stop condition and the following start) is not guaranteed to match the I2C specification of 4.7us in standard mode and 1.3us in fast mode. If the UCTXSTT bit is set during a running I2C transaction, the USCI module waits and issues the start condition on bus release causing the violation to occur.<br>Note: It is recommended to check if UCBBUSY bit is cleared before setting UCTXSTT=1. |
| Workaround        | None                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| USCI34            | USCI Module                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Category          | Functional                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Function          | I2C multi-master transmit may lose first few bytes.                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Description       | In an I2C multi-master system (UCMM =1), under the following conditions:                                                                                                                                                                                                                                                                                                                                                                                                          |
|                   | (1)the master is configured as a transmitter (UCTR =1)                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                   | AND                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                   | (2)the start bit is set (UCTXSTT =1);                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                   | if the I2C bus is unavailable, then the USCI module enters an idle state where it waits and checks for bus release. While in the idle state it is possible that the USCI master updates its TXIFG based on clock line activity due to other master/slave communication on the bus. The data byte(s) loaded in TXBUF while in idle state are lost and transmit pointers initialized by the user in the transmit ISR are updated incorrectly.                                       |
| Workaround        | Verify that the START condition has been sent (UCTXSTT =0) before loading TXBUF with data.                                                                                                                                                                                                                                                                                                                                                                                        |
|                   | Example:<br>#pragma vector = USCIAB0TX_VECTOR<br>interrupt void USCIAB0TX_ISR(void)<br>{<br>// Workaround for USCI34<br>if(UCB0CTL1&UCTXSTT)<br>{<br>// TXData = pointer to the transmit buffer start<br>// PTxData = pointer to transmit in the ISR<br>PTxData = TXData; // restore the transmit buffer pointer if the Start bit is set<br>}<br>//<br>if(IFG2&UCB0TXIFG)<br>{                                                                                                    |



#### USCI34 (continued) USCI Module

|                                     | USCI Module                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                     | if (PTxData < = PTxDataEnd) // Check TX byte counter                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                                     | ۲<br>UCB0TXBUF = *PTxData++; // Load TX buffer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                                     | }<br>else                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                                     | {<br>UCB0CTL1  = UCTXSTP; // I2C stop condition                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                                     | IFG2 &= ~UCB0TXIFG; // Clear USCI_B0 TX int flag                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                                     | bic_SR_register_on_exit(CPUOFF); // Exit LPM0<br>}                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                                     | }<br>}                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| USCI35                              | USCI Module                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Category                            | Functional                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Function                            | Violation of setup and hold times for (repeated) start in I2C master mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Description                         | In I2C master mode, the setup and hold times for a (repeated) START, $t_{SU,STA}$ and $t_{HD,STA}$ respectively, can be violated if SCL clock frequency is greater than 50kHz in standard mode (100kbps). As a result, a slave can receive incorrect data or the I2C bus can be stalled due to clock stretching by the slave.                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Workaround                          | If using repeated start, ensure SCL clock frequencies is < 50kHz in I2C standard mode (100 kbps).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| USCI39                              | USCI Module                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| USCI39<br>Category                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                                     | USCI Module                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Category                            | USCI Module<br>Functional                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Category<br>Function                | USCI Module<br>Functional<br>USCI I2C IFGs UCSTTIFG, UCSTPIFG, UCNACKIFG<br>Unpredictable code execution can occur if one of the hardware-clear-able IFGs<br>UCSTTIFG, UCSTPIFG or UCNACKIFG is set while the global interrupt enable is set<br>by software (GIE=1). This erratum is triggered if ALL of the following events occur in                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Category<br>Function                | USCI Module<br>Functional<br>USCI I2C IFGs UCSTTIFG, UCSTPIFG, UCNACKIFG<br>Unpredictable code execution can occur if one of the hardware-clear-able IFGs<br>UCSTTIFG, UCSTPIFG or UCNACKIFG is set while the global interrupt enable is set<br>by software (GIE=1). This erratum is triggered if ALL of the following events occur in<br>following order:                                                                                                                                                                                                                                                                                                                                                                                                    |
| Category<br>Function                | USCI Module<br>Functional<br>USCI I2C IFGs UCSTTIFG, UCSTPIFG, UCNACKIFG<br>Unpredictable code execution can occur if one of the hardware-clear-able IFGs<br>UCSTTIFG, UCSTPIFG or UCNACKIFG is set while the global interrupt enable is set<br>by software (GIE=1). This erratum is triggered if ALL of the following events occur in<br>following order:<br>1. Pending Interrupt: One of the UCxIFG=1 AND UCxIE=1 while GIE=0                                                                                                                                                                                                                                                                                                                               |
| Category<br>Function                | USCI Module         Functional         USCI I2C IFGs UCSTTIFG, UCSTPIFG, UCNACKIFG         Unpredictable code execution can occur if one of the hardware-clear-able IFGs         UCSTTIFG, UCSTPIFG or UCNACKIFG is set while the global interrupt enable is set by software (GIE=1). This erratum is triggered if ALL of the following events occur in following order:         1. Pending Interrupt: One of the UCxIFG=1 AND UCxIE=1 while GIE=0         2. The GIE is set by software (e.g. EINT)         3. The pending interrupt is cleared by hardware (external I2C event) in a time window of 1                                                                                                                                                       |
| Category<br>Function<br>Description | USCI Module         Functional         USCI I2C IFGs UCSTTIFG, UCSTPIFG, UCNACKIFG         Unpredictable code execution can occur if one of the hardware-clear-able IFGs         UCSTTIFG, UCSTPIFG or UCNACKIFG is set while the global interrupt enable is set by software (GIE=1). This erratum is triggered if ALL of the following events occur in following order:         1. Pending Interrupt: One of the UCxIFG=1 AND UCxIE=1 while GIE=0         2. The GIE is set by software (e.g. EINT)         3. The pending interrupt is cleared by hardware (external I2C event) in a time window of 1 MCLK clock cycle after the "EINT" instruction is executed.         Disable the UCSTTIE, UCSTPIE and UCNACKIE before the GIE is set. After GIE is set, |



| USCI40      | USCI Module                                                                                                                                                                                                                                                                                                                                                                                      |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Category    | Functional                                                                                                                                                                                                                                                                                                                                                                                       |
| Function    | SPI Slave Transmit with clock phase select = 1                                                                                                                                                                                                                                                                                                                                                   |
| Description | In SPI slave mode with clock phase select set to 1 (UCAxCTLW0.UCCKPH=1), after the first TX byte, all following bytes are shifted by one bit with shift direction dependent on UCMSB. This is due to the internal shift register getting pre-loaded asynchronously when writing to the USCIA TXBUF register. TX data in the internal buffer is shifted by one bit after the RX data is received. |
| Workaround  | Reinitialize TXBUF before using SPI and after each transmission.<br>If transmit data needs to be repeated with the next transmission, then write back<br>previously read value:                                                                                                                                                                                                                  |



**7 Revision History** NOTE: Page numbers for previous revisions may differ from page numbers in the current version.

| Changes from May 17, 2021 to August 27, 2021 |                                            | Page |
|----------------------------------------------|--------------------------------------------|------|
| •                                            | TB25 was added to the errata documentation | 6    |
| •                                            | TB25 Function was updated                  | 18   |
|                                              | TB25 Description was updated               |      |
|                                              | TB25 Workaround was updated                |      |

# 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 (https://www.ti.com/legal/termsofsale.html) 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 © 2021, Texas Instruments Incorporated