Errata

MSP430FR5738 Microcontroller

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 .................................................................................................................. 3
4 Fixed by Compiler Advisories .................................................................................................... 3
5 Nomenclature, Package Symbolization, and Revision Identification ........................................... 4
   5.1 Device Nomenclature .............................................................................................................. 4
   5.2 Package Markings .................................................................................................................. 4
   5.3 Memory-Mapped Hardware Revision (TLV Structure) ........................................................... 5
6 Advisory Descriptions .................................................................................................................. 6
7 Revision History .......................................................................................................................... 23
1 Functional Advisories
Advisories that affect the device’s operation, function, or parametrics.
✓ The check mark indicates that the issue is present in the specified revision.

<table>
<thead>
<tr>
<th>Errata Number</th>
<th>Rev J</th>
<th>Rev H</th>
</tr>
</thead>
<tbody>
<tr>
<td>ADC38</td>
<td>✓</td>
<td>✓</td>
</tr>
<tr>
<td>ADC39</td>
<td>✓</td>
<td>✓</td>
</tr>
<tr>
<td>ADC42</td>
<td>✓</td>
<td>✓</td>
</tr>
<tr>
<td>ADC66</td>
<td>✓</td>
<td>✓</td>
</tr>
<tr>
<td>ADC69</td>
<td>✓</td>
<td>✓</td>
</tr>
<tr>
<td>ADC71</td>
<td>✓</td>
<td>✓</td>
</tr>
<tr>
<td>COMP10</td>
<td>✓</td>
<td>✓</td>
</tr>
<tr>
<td>COMP11</td>
<td>✓</td>
<td>✓</td>
</tr>
<tr>
<td>CPU46</td>
<td>✓</td>
<td>✓</td>
</tr>
<tr>
<td>CPU47</td>
<td>✓</td>
<td>✓</td>
</tr>
<tr>
<td>CS12</td>
<td>✓</td>
<td>✓</td>
</tr>
<tr>
<td>DMA7</td>
<td>✓</td>
<td>✓</td>
</tr>
<tr>
<td>DMA9</td>
<td>✓</td>
<td>✓</td>
</tr>
<tr>
<td>DMA10</td>
<td>✓</td>
<td>✓</td>
</tr>
<tr>
<td>DMA14</td>
<td>✓</td>
<td>✓</td>
</tr>
<tr>
<td>GC3</td>
<td>✓</td>
<td>✓</td>
</tr>
<tr>
<td>GC4</td>
<td>✓</td>
<td>✓</td>
</tr>
<tr>
<td>MPY1</td>
<td>✓</td>
<td>✓</td>
</tr>
<tr>
<td>PORT16</td>
<td>✓</td>
<td>✓</td>
</tr>
<tr>
<td>PORT19</td>
<td>✓</td>
<td>✓</td>
</tr>
<tr>
<td>PORT26</td>
<td>✓</td>
<td>✓</td>
</tr>
<tr>
<td>RTC14</td>
<td>✓</td>
<td>✓</td>
</tr>
<tr>
<td>TA23</td>
<td>✓</td>
<td>✓</td>
</tr>
<tr>
<td>TB25</td>
<td>✓</td>
<td>✓</td>
</tr>
<tr>
<td>USCI36</td>
<td>✓</td>
<td>✓</td>
</tr>
<tr>
<td>USCI37</td>
<td>✓</td>
<td>✓</td>
</tr>
<tr>
<td>USCI41</td>
<td>✓</td>
<td>✓</td>
</tr>
<tr>
<td>USCI42</td>
<td>✓</td>
<td>✓</td>
</tr>
<tr>
<td>USCI44</td>
<td>✓</td>
<td>✓</td>
</tr>
<tr>
<td>USCI47</td>
<td>✓</td>
<td>✓</td>
</tr>
<tr>
<td>USCI50</td>
<td>✓</td>
<td>✓</td>
</tr>
<tr>
<td>WDG6</td>
<td>✓</td>
<td>✓</td>
</tr>
<tr>
<td>XOSC13</td>
<td>✓</td>
<td>✓</td>
</tr>
</tbody>
</table>

2 Preprogrammed Software Advisories
Advisories that affect factory-programmed software.
✓ The check mark indicates that the issue is present in the specified revision.

<table>
<thead>
<tr>
<th>Errata Number</th>
<th>Rev J</th>
<th>Rev H</th>
</tr>
</thead>
<tbody>
<tr>
<td>ADC67</td>
<td>✓</td>
<td>✓</td>
</tr>
</tbody>
</table>
3 Debug Only Advisories
Advisories that affect only debug operation.
✓ The check mark indicates that the issue is present in the specified revision.

<table>
<thead>
<tr>
<th>Errata Number</th>
<th>Rev J</th>
<th>Rev H</th>
</tr>
</thead>
<tbody>
<tr>
<td>EEM19</td>
<td>✓</td>
<td>✓</td>
</tr>
<tr>
<td>EEM23</td>
<td>✓</td>
<td>✓</td>
</tr>
<tr>
<td>EEM25</td>
<td>✓</td>
<td>✓</td>
</tr>
<tr>
<td>EEM30</td>
<td>✓</td>
<td>✓</td>
</tr>
<tr>
<td>EEM31</td>
<td>✓</td>
<td>✓</td>
</tr>
<tr>
<td>JTAG27</td>
<td>✓</td>
<td>✓</td>
</tr>
</tbody>
</table>

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.

<table>
<thead>
<tr>
<th>Errata Number</th>
<th>Rev J</th>
<th>Rev H</th>
</tr>
</thead>
<tbody>
<tr>
<td>CPU21</td>
<td>✓</td>
<td>✓</td>
</tr>
<tr>
<td>CPU22</td>
<td>✓</td>
<td>✓</td>
</tr>
<tr>
<td>CPU40</td>
<td>✓</td>
<td>✓</td>
</tr>
</tbody>
</table>

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.

5.2 Package Markings

**PW28**  
**TSSOP (PW), 28 Pin**

![Package Markings Diagram]

- 4FRxxxx
- NNN #
- NNNN

# = Die revision
O = Pin 1 location
N = Lot trace code

- MSP430FRxxxx
- NNN G4
- NNNN #

# = Die revision
O = Pin 1 location
N = Lot trace code
5.3 Memory-Mapped Hardware Revision (TLV Structure)

<table>
<thead>
<tr>
<th>Die Revision</th>
<th>TLV Hardware Revision</th>
</tr>
</thead>
<tbody>
<tr>
<td>Rev J</td>
<td>26h</td>
</tr>
<tr>
<td>Rev H</td>
<td>24h</td>
</tr>
</tbody>
</table>

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

<table>
<thead>
<tr>
<th>ADC38</th>
<th><strong>ADC Module</strong></th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>Category</strong></td>
<td>Functional</td>
</tr>
<tr>
<td><strong>Function</strong></td>
<td>External ADC trigger without toggling ENC bit might prevent further ADC conversions.</td>
</tr>
<tr>
<td><strong>Description</strong></td>
<td>The ADC may stop sampling and converting until the module is reset if an external (timer) trigger occurs without toggling the ADC12CTL0.ADC12ENC bit at:</td>
</tr>
<tr>
<td></td>
<td>- The end of sequence in the sequence-of-channel mode.</td>
</tr>
<tr>
<td></td>
<td>- The end of conversion in single-channel mode.</td>
</tr>
<tr>
<td><strong>Workaround</strong></td>
<td>Ensure ADC12CTL0.ADC12ENC bit is always toggled before providing any new External Trigger to ADC.</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>ADC39</th>
<th><strong>ADC Module</strong></th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>Category</strong></td>
<td>Functional</td>
</tr>
<tr>
<td><strong>Function</strong></td>
<td>Erroneous ADC10 results in extended sample mode</td>
</tr>
<tr>
<td><strong>Description</strong></td>
<td>If the extended sample mode is selected (ADC10SHP = 0) and the ADC10CLK is asynchronous to the SHI signal, the ADC10 may generate erroneous results.</td>
</tr>
</tbody>
</table>
| **Workaround** | 1) Use the pulse sample mode (ADC10SHP=1)  
OR  
2) Use a synchronous clock for ADC10 and the SHI signal. |

<table>
<thead>
<tr>
<th>ADC42</th>
<th><strong>ADC Module</strong></th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>Category</strong></td>
<td>Functional</td>
</tr>
<tr>
<td><strong>Function</strong></td>
<td>ADC stops converting when successive ADC is triggered before the previous conversion ends</td>
</tr>
<tr>
<td><strong>Description</strong></td>
<td>Subsequent ADC conversions are halted if a new ADC conversion is triggered while ADC is busy. ADC conversions are triggered manually or by a timer. The affected ADC modes are:</td>
</tr>
<tr>
<td></td>
<td>- sequence-of-channels</td>
</tr>
<tr>
<td></td>
<td>- repeat-single-channel</td>
</tr>
<tr>
<td></td>
<td>- repeat-sequence-of-channels (ADC12CTL1.ADC12CONSEQx)</td>
</tr>
<tr>
<td>In addition, the timer overflow flag cannot be used to detect an overflow (ADC12IFGR2.ADC12TOVIFG).</td>
<td></td>
</tr>
</tbody>
</table>
| **Workaround** | 1. For manual trigger mode (ADC12CTL0.ADC12SC), ensure each ADC conversion is completed by first checking ADC12CTL1.ADC12BUSY bit before starting a new conversion.  
2. For timer trigger mode (ADC12CTL1.ADC12SHP), ensure the timer period is greater than the ADC sample and conversion time. |
| To recover the conversion halt: | |
ADC42 (continued)  

**ADC Module**

1. Disable ADC module (ADC12CTL0.ADC12ENC = 0 and ADC12CTL0.ADC12ON = 0)

2. Re-enable ADC module (ADC12CTL0.ADC12ON = 1 and ADC12CTL0.ADC12ENC = 1)

3. Re-enable conversion

---

ADC66  

**ADC Module**

**Category**  
Functional

**Function**  
ADC stops converting when ADC12ON bit is toggled during conversion

**Description**  
Subsequent ADC conversions are halted if the ADC12CTL0.ADC12ON bit is toggled while the ADC is busy. The affected ADC modes are:

- sequence-of-channels

- repeat-single-channel

- repeat-sequence-of-channels (ADC12CTL1.ADC12CONSEQx)

**Workaround**  
Stop the ADC conversion by clearing the ADC12CTL0.ADC12ENC bit. Check the ADC12CTL1.ADC12BUSY flag for 0 before toggling the ADC12CTL0.ADC12ON bit.

---

ADC67  

**ADC Module**

**Category**  
Software in ROM

**Function**  
Invalid ADC12 temperature sensor calibration data

**Description**  
The ADC12 reference temperature sensor calibration data stored in the TLV data structure (0x1A1A - 0x1A25) can be incorrect. As a result the temperature measurement when using these data can be wrong.

**Workaround**  
Record the calibration data by taking ADC measurements of the temperature sensor at 30C and 85C for the required reference voltage. The calibration data in the TLV section (0x1A1A - 0x1A25) can't be overwritten but the new calibration data can be stored in user FRAM or info memory for further temperature calculations.

---

ADC69  

**ADC Module**

**Category**  
Functional

**Function**  
ADC stops operating if ADC clock source is changed from SMCLK to another source while SMCLKOFF = 1.

**Description**  
When SMCLK is used as the clock source for the ADC (ADC12CTL1.ADC12SSELx = 11) and CSCTL4.SMCLKOFF = 1, the ADC will stop operating if the ADC clock source is changed by user software (e.g. in the ISR) from SMCLK to a different clock source. This issue appears only for the ADC12CTL1.ADC12DIVx settings /3/5/7. The hang state can be recovered by PUC/POR/BOR/Power cycle.

**Workaround**  
1. Set CSCTL4.SMCLKOFF = 0 before switch ADC clock source.
ADC69 (continued) **ADC Module**

OR

2. Only use ADC12CTL1.ADC12DIVx as /1, /2, /4, /6, /8

ADC71 **ADC Module**

**Category**
Functional

**Function**
ADC12 stops converting when ENC and SC bits are set simultaneously and ADC12 was previously set to trigger from a source that was not the SC bit.

**Description**
When using the ADC12 after being setup and triggered by a trigger source that is not the ADC12SC bit (ADC Start Conversion), if ADC12ENC (ADC Enable) and ADC12SC bits are set simultaneously, then ADC12BUSY flag stays high and ADC12SC does not get cleared. As a result, the ADC conversion never finishes.

**Workaround**
Set ADC12ENC and ADC12SC bits with separate instructions if the trigger source is changed from a source that is not ADC12SC.

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.

COMP11 **COMP Module**

**Category**
Functional

**Function**
Polling comparator interrupts may result in a missed interrupt
**COMP11 (continued) COMP Module**

**Description**
Polling the comparator output interrupt and the output inverted interrupt flags (CEIFG.CExINT and CEIIFG.CExINT) may result in a missed interrupt if the flags are modified while being read.

**Workaround**
Using an interrupt service routine to service CEIFG and CEIIFG interrupts significantly reduces the probability of the issue occurring.

**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.

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

**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.

<table>
<thead>
<tr>
<th>IDE/Compiler</th>
<th>Version Number</th>
<th>Notes</th>
</tr>
</thead>
<tbody>
<tr>
<td>IAR Embedded Workbench</td>
<td>Not affected</td>
<td></td>
</tr>
<tr>
<td>TI MSP430 Compiler Tools (Code Composer Studio)</td>
<td>v4.0.x or later</td>
<td>User is required to add the compiler or assembler flag option below. -- silicon_errata=CPU22</td>
</tr>
</tbody>
</table>

Submit Document Feedback
## CPU22 (continued)  
### CPU Module

<table>
<thead>
<tr>
<th>IDE/Compiler</th>
<th>Version Number</th>
<th>Notes</th>
</tr>
</thead>
<tbody>
<tr>
<td>MSP430 GNU Compiler (MSP430-GCC)</td>
<td>MSP430-GCC 4.9 build 167 or later</td>
<td></td>
</tr>
</tbody>
</table>

## 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).

```assembly
@0x8012 Loop DEC.W R6
@0x8014 DEC.W R7
@0x8016 JNZ Loop
@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.

<table>
<thead>
<tr>
<th>IDE/Compiler</th>
<th>Version Number</th>
<th>Notes</th>
</tr>
</thead>
<tbody>
<tr>
<td>IAR Embedded Workbench</td>
<td>IAR EW430 v5.51 or later</td>
<td>For the command line version add the following information Compiler:--hw_workaround=CPU40 Assembler:-v1</td>
</tr>
<tr>
<td>TI MSP430 Compiler Tools (Code Composer Studio)</td>
<td>v4.0.x or later</td>
<td>User is required to add the compiler or assembler flag option below. --silicon_errata=CPU40</td>
</tr>
<tr>
<td>MSP430 GNU Compiler (MSP430-GCC)</td>
<td>Not affected</td>
<td></td>
</tr>
</tbody>
</table>

## CPU46  
### CPU Module

**Category**  
Functional

**Function**  
POPM performs unexpected memory access and can cause VMAIFG to be set

**Description**  
When the POPM assembly instruction is executed, the last Stack Pointer increment is followed by an unintended read access to the memory. If this read access is performed on vacant memory, the VMAIFG will be set and can trigger the corresponding interrupt
**CPU Module**

(SFRIE1.VMAIE) if it is enabled. This issue occurs if the POPM assembly instruction is performed up to the top of the STACK.

**Workaround**

If the user is utilizing C, they will not be impacted by this issue. All TI/IAR/GCC pre-built libraries are not impacted by this bug. To ensure that POPM is never executed up to the memory border of the STACK when using assembly it is recommended to either

1. Initialize the SP to
   a. TOP of STACK - 4 bytes if POPM.A is used
   b. TOP of STACK - 2 bytes if POPM.W is used

OR

2. Use the POPM instruction for all but the last restore operation. For the the last restore operation use the POP assembly instruction instead.

For instance, instead of using:

```
POPM.W #5,R13
```

Use:

```
POPM.W #4,R12
POP.W R13
```

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

<table>
<thead>
<tr>
<th>IDE/Compiler</th>
<th>Version Number</th>
<th>Notes</th>
</tr>
</thead>
<tbody>
<tr>
<td>IAR Embedded Workbench</td>
<td>Not affected</td>
<td>C code is not impacted by this bug. User using POPM instruction in assembler is required to implement the above workaround manually.</td>
</tr>
<tr>
<td>TI MSP430 Compiler Tools (Code Composer Studio)</td>
<td>Not affected</td>
<td>C code is not impacted by this bug. User using POPM instruction in assembler is required to implement the above workaround manually.</td>
</tr>
<tr>
<td>MSP430 GNU Compiler (MSP430-GCC)</td>
<td>Not affected</td>
<td>C code is not impacted by this bug. User using POPM instruction in assembler is required to implement the above workaround manually.</td>
</tr>
</tbody>
</table>

**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-modifying instruction (e.g. - ret, push, call, pop, jmp, br) is fetched from the last addresses.
CPU47 (continued)  CPU Module

(last 4 or 8 byte) of a memory (e.g.- FLASH, RAM, FRAM) that is not contiguous to a higher, valid section on the memory map.

In debug mode using breakpoints the last 8 bytes are affected.
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.

CS12  CS Module

Category  Functional

Function  DCO overshoot at frequency change

Description  When changing frequencies (CSCTL1.DCOFSEL), the DCO frequency may overshoot and exceed the datasheet specification. After a time period of 10us has elapsed, the frequency overshoot settles down to the expected range as specified in the datasheet. The overshoot occur when switching to and from any DCOFSEL setting and impacts all peripherals using the DCO as a clock source. A potential impact can also be seen on FRAM accesses, since the overshoot may cause a temporary violation of FRAM access and cycle time requirements.

Workaround

When changing the DCO settings, use the following procedure:

1) Store the existing CSCTL3 divider into a temporary unsigned 16-bit variable
2) Set CSCTL3 to divide all corresponding clock sources by 4 or higher
3) Change DCO frequency
4) Wait ~10us
5) Restore the divider in CSCTL3 to the setting stored in the temporary variable.

The following code example shows how to increase DCO to 16MHz.

```
uint16_t tempCSCTL3 = 0;
CSCTL0_H = CSKEY_H;        // Unlock CS registers
/* Assuming SMCLK and MCLK are sourced from DCO */
/* Store CSCTL3 settings to recover later */
tempCSCTL3 = CSCTL3;
/* Keep overshoot transient within specification by setting clk sources to divide by 4*/
/* Clear the DIVS & DIVM masks (~0x77)and set both fields to 4 divider */
CSCTL3 = CSCTL3 & (~0x77)) | DIVS_4 | DIVM_4;
CSCTL1 = DCOFSEL_4 | DCOSEL;    // Set DCO to 16MHz
/* Delay by ~10us to let DCO settle. 60 cycles = 20 cycles buffer + (10us / (1/4MHz)) */
__delay_cycles(60);
CSCTL3 = tempCSCTL3;        // Set all dividers
CSCTL0_H = 0;                // Lock CS registers
```

DMA7  DMA Module

Category  Functional
**DMA7 (continued) DMA Module**

**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**

1. Use a read of Interrupt Vector registers to clear interrupt flags and do not use read-modify-write instruction.

OR

2. Disable all DMA channels during read-modify-write instruction of specific module registers containing interrupts flags while these interrupts are activated.

---

**DMA9 DMA Module**

**Category**
Functional

**Function**
DMA stops transferring bytes unexpectedly

**Description**
When the DMA is configured to transfer bytes from the eUSCI_A or eUSCI_B transmit or receive buffers, the transmit or receive triggers (TXIFG and RXIFG) may not be seen by the DMA module and the transfer of the bytes is missed. Once the first byte in a transfer sequence is missed, all the following bytes are missed as well. All eUSCI_A modes (UART, SPI, and IrDA) and all eUSCI_B modes (SPI and I2C) are affected.

**Workaround**

1) Use Interrupt Service Routines to transfer data to and from the eUSCI_A or eUSCI_B. OR

2) When using DMA channel 0 for transferring data to and from the eUSCI_A or eUSCI_B, use DMA channel 2 (lower priority than DMA channel 0) to read the same register of the eUSCI_A or eUSCI_B that DMA channel 0 is working with. Use the same USCI IFG (e.g. UCA0RXIFG) as trigger source for these both DMA channels.

---

**DMA10 DMA Module**

**Category**
Functional

**Function**
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.

---

**DMA14 DMA Module**

**Category**
Functional

**Function**
DMA misses trigger from asynchronous source and all subsequent transfers/triggers

**Description**
If DMA module is used in edge-triggered mode
DMA Module

the trigger source (e.g. TimerA, TimerB, USCI or ADC10) is running with an asynchronous clock (e.g. MODOSC, VLO or external crystal clock) versus DMA clock (MCLK), AND the DMA trigger occurs while the CPU is in active mode, then the DMA module might miss an edge trigger and then all subsequent edge triggers.

This leads to a missing DMA transfer cycle. The DMA size address register (DMAxSZ) will note decrement, and the trigger source (corresponding module flag) is not cleared. Due to this, the expected DMA interrupt is not executed and the DMA hangs.

Workaround

To prevent the issue entirely, run DMA and module from the same clock source (e.g. MCLK, SMCLK with same source as MCLK, etc) to prevent asynchronous events.

To detect the issue:
- Use overflow flags found in many modules (e.g. ADC10OVIFG) to detect DMA lockup
- Use the WDT at the system-level to detect a hang-up.

After detection, recover operation by clearing the DMA trigger source interrupt flag, clearing the data to be transferred, and re-initializing both the DMA and the module for the trigger source. If the trigger source is unknown, trigger a software BOR reset by setting the PMMSWBOR bit in the PMMCTL0 register.

EEM Module

EEM Module

EEM19

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 in released IDE EW430 IAR version 6.30.3 and CCS version 6.1.1 or newer. If using an earlier version of either IDE or MSPDebugStack, do not halt or use breakpoints during a DMA transfer.

Note
This erratum applies to debug mode only.

EEM23

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.
**EEM Module**

**EEM23 (continued)**

Note
This erratum affects debug mode only.

**EEM25**

**Category**
Debug

**Function**
Unexpected wakeup from LPMx.5

**Description**
When the device is in LPMx.5, debugging in SBW mode can cause an unexpected wakeup from the low power mode.

**Workaround**
Use 4-wire JTAG when debugging.

Note
This issue only affects debug mode.

**EEM30**

**Category**
Debug

**Function**
Missed breakpoint if FRAM power supply is disabled

**Description**
The FRAM power supply can be disabled (GCCTL0.FRPWR = 0) prior to LPM entry to save power. Upon wakeup, if a breakpoint is set on the first instruction that accesses FRAM, the breakpoint may be missed.

**Workaround**
None. This issue affects debug mode only.

**EEM31**

**Category**
Debug

**Function**
Breakpoint trigger may be lost when MPU is enabled

**Description**
A data value written to FRAM can be used as a trigger condition for breakpoints during a debug session. This trigger can be lost if the FRAM access is made to an address that has been write-protected by the MPU.

**Workaround**
None. This issue affects debug mode only.

**GC3**

**Category**
Functional

**Function**
Error flags set incorrectly after reset or wake-up from LPM

**Description**
The error flags GCCTL1.UBDIFG and GCCTL1.CBDIFG are incorrectly set after the first power-up or wake up from LPM2/LPM3/LPM4/LPM3.5/LPM4.5. If the corresponding interrupt enable bits are set, then an erroneous interrupt can be generated.

**Workaround**
Disable the UBDIEN and CBDIEN interrupts (GCCTL0.UBDIEN=0 and GCCTL0.CBDIEN=0) prior to entering LPM2/LPM3/LPM4/LPM4.5. After LPM exit, re-initialize the interrupt flags only after the first FRAM access has been completed.
GC4  GC Module

Category  Functional
Function  Unexpected PUC is triggered
Description  During execution from FRAM a non-existent uncorrectable bit error can be detected and trigger a PUC if the uncorrectable bit error detection flag is set (GCCTL0.UBDRSTEN = 1). This behavior appears only if:

1. MCLK is sourced from DCO frequency of 16 MHz
   OR
2. MCLK is sourced by external high frequency clock above 12 MHz at pin HFXIN
   OR
3. MCLK is sourced by High-Frequency crystals (HFXT) above 12 MHz.
   This PUC will not be recognized by the SYSRSTIV register (SYSRSTIV = 0x00).
   A PUC RESET will be executed with not defined reset source.
   Also the corresponding bit error detection flag is not set (GCCTL1.UBDIFG = 0).

Workaround  1. Check the reset source for SYSRSTIV = 0 and ignore the reset.
   OR
2. Set GCCTL0.UBDRSTEN = 0 to prevent unexpected PUC.
   OR
3. Set the MCLK to maximum 12MHz to leverage the uncorrectable bit error PUC feature.

JTAG27  JTAG Module

Category  Debug
Function  Unintentional code execution after programming via JTAG/SBW
Description  The device can unintentionally start executing code from uninitialized RAM addresses 0x0006 or 0x0008 after being programming via the JTAG or SBW interface. This can result in unpredictable behavior depending on the contents of the address location.

Workaround  1. If using programming tools purchased from TI (MSP-FET, LaunchPad), update to CCS version 6.1.3 later or IAR version 6.30 or later to resolve the issue.
   2. If using the MSP-GANG Production Programmer, use v1.2.3.0 or later.
   3. For custom programming solutions refer to the specification on MSP430 Programming Via the JTAG Interface User's Guide (SLAU320) revision V or newer and use MSPDebugStack v3.7.0.12 or later.
   For MSPDebugStack (MSP430.DLL) in CCS or IAR, download the latest version of the development environment or the latest version of the MSPDebugStack

NOTE: This only affects debug mode.'
MPY1  
**MPY Module**

**Category**  
Functional

**Function**  
Save and Restore feature on MPY32 not functional

**Description**  
The MPY32 module uses the Save and Restore method which involves saving the multiplier state by pushing the MPY configuration/operand values to the stack before using the multiplier inside an Interrupt Service Routine (ISR) and then restoring the state by popping the configuration/operand values back to the MPY registers at the end of the ISR. However due to the erratum the Save and Restore operation fails causing the write operation to the OP2H register right after the restore operation to be ignored as it is not preceded by a write to OP2L register resulting in an invalid multiply operation.

**Workaround**  
None. Disable interrupts when writing to OP2L and OP2H registers.

Note: When using the C-compiler, the interrupts are automatically disabled while using the MPY32

PORT16  
**PORT Module**

**Category**  
Functional

**Function**  
GPIO pins are driven low during device start-up

**Description**  
During device start-up, all of the GPIO pins are expected to be in the floating input state. Due to this erratum, some of the GPIO pins are driven low for the duration of boot code execution during device start-up, if an external reset event (via the RST pin) interrupted the previous boot code execution. Boot code is always executed after a BOR, and the duration of this boot code execution is approximately 500us.

For a given device family, this erratum affects only the GPIO pins that are not available in the smallest package device family member, but that are present on its larger package variants.

---

**Note**  
This erratum does not affect the smallest package device variants in a particular device family.

**Workaround**  
Ensure that no external reset is applied via the RST pin during boot code execution of the device, which occurs 1us after device start-up.

---

**Note**  
System application needs to account for this erratum in to ensure there is no increased current draw by the external components or damage to the external components in the system during device start-up.

PORT19  
**PORT Module**

**Category**  
Functional

**Function**  
Port interrupt may be missed on entry to LPMx.5
<table>
<thead>
<tr>
<th>PORT19 (continued)</th>
<th>PORT Module</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>Description</strong></td>
<td>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.</td>
</tr>
<tr>
<td><strong>Workaround</strong></td>
<td>None</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>PORT26</th>
<th>PORT Module</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>Category</strong></td>
<td>Functional</td>
</tr>
<tr>
<td><strong>Function</strong></td>
<td>Incorrect values for P1.3 / P1.4 input pins during power-up</td>
</tr>
<tr>
<td><strong>Description</strong></td>
<td>If P1.3/P1.4 is pulled up externally to DVCC during power-up the logical HIGH value might not be read correct by the device (ZERO is read instead of ONE).</td>
</tr>
</tbody>
</table>
| **Workaround** | 1) Switch the P1.3/P1.4 Port to logical ZERO after power cycle by:  
   a) Switch critical GPIO to output-low (with series resistance to limit current) or  
   b) Remove external pull up connection to pull GPIO via internal pull-down  
   OR  
   2) Use different GPIOs (not P1.3 & P1.4)  
   OR  
   3) Change the polarity of the logical check in SW (enable internal pull-up resistor for the GPIO and pull the external pin to DVSS) |

<table>
<thead>
<tr>
<th>RTC14</th>
<th>RTC Module</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>Category</strong></td>
<td>Functional</td>
</tr>
<tr>
<td><strong>Function</strong></td>
<td>Polling RTC interrupts may result in a lost interrupt flag</td>
</tr>
<tr>
<td><strong>Description</strong></td>
<td>Polling any RTC interrupt flag mapped to the RTCIV register may result in a missed interrupt if the flags are modified while being read.</td>
</tr>
<tr>
<td><strong>Workaround</strong></td>
<td>Using an interrupt service routine to service flags mapped to the RTCIV register significantly reduces the probability of the issue occurring.</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>TA23</th>
<th>TA Module</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>Category</strong></td>
<td>Functional</td>
</tr>
<tr>
<td><strong>Function</strong></td>
<td>Polling timer interrupts may result in a lost interrupt flag</td>
</tr>
<tr>
<td><strong>Description</strong></td>
<td>Polling any Timer interrupt flag may result in a missed interrupt if the flags are modified while being read.</td>
</tr>
<tr>
<td><strong>Workaround</strong></td>
<td>Using an interrupt service routine to service timer interrupt flags significantly reduces the probability of the issue occurring.</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>TB25</th>
<th>TB Module</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>Category</strong></td>
<td>Functional</td>
</tr>
</tbody>
</table>
TB25 (continued)  **TB Module**

**Function**
In up mode, TBxCCLRn value is immediately transferred to TBxCLn when TBxCCTRn.CLLD bits are set or 0x01 or 0x10

**Description**
IF Timer B is configured for Up mode, AND the compare latch load event (TBxCCTRn.CLLD bits) setting is configured to update TBxCCLRn when TBxR reaches 0, THEN TBxCCLRn will update immediately instead of the described condition.

This is contrary to the user guide description of TBxCCTRn.CLLD = 0x01 or 0x10 modes.

**Workaround**
If user needs to update TBxCCLRn value when TBxR counts to 0 in Timer B up mode:
1. Set TBxCCTRn. CLLD = 0x00
2. Enable the Timer B interrupt (TBIE) in TBxCTL
3. Update TBxCCLRn value within interrupt routine.

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.

USCI36  **USCI Module**

**Category**
Functional

**Function**
UCLKI not usable in I2C master mode

**Description**
When EUSCIB is configured as I2C Master with the external UCLKI as clock source, the UCLKI signal is not available and cannot be used to source I2C clock.

**Workaround**
Use LFXTCLK via ACLK or HFXTCLK via SMCLK as clock source (BRCLK) for I2C in master mode with external clock source.

USCI37  **USCI Module**

**Category**
Functional

**Function**
Reading RXBUF during an active I2C communication might result in unintended bus stalls.

**Description**
The falling edge of SCL bus line is used to set an internal RXBUF-written flag register, which is used to detect a potential RXBUF overflow. If this flag is cleared with a read access from the RXBUF register during a falling edge of SCL, the clear condition might be missed. This could result in an I2C bus stall at the next received byte.

**Workaround**
1. Execute two consecutive reads of RXBUF, if \( t_{SCL} > 4 \times t_{MCLK} \).

or

2. Provoke an I2C bus stall before reading RXBUF. A bus stall can be verified by checking if the clock line low status indicator bit UCSCLLOW is set for at least three USCI bit clock cycles i.e. \( 3 \times t_{BitClock} \).

USCI41  **USCI Module**

**Category**
Functional
**USCI41 (continued) USCI Module**

**Function**
UCBUSY bit of eUSCIA module might not work reliable when device is in SPI mode.

**Description**
When eUSCIA is configured in SPI mode, the UCBUSY bit might get stuck to 1 or start toggling after transmission is completed. This happens in all four combinations of Clock Phase and Clock Polarity options (UCAxCTLW0.UCCKPH & UCAxCTLW0.UCCKPL bits) as well as in Master and Slave mode. There is no data loss or corruption. However the UCBUSY cannot be used in its intended function to check if transmission is completed. Because the UCBUSY bit is stuck to 1 or toggles, the clock request stays enabled and this adds additional current consumption in low power mode operation.

**Workaround**
For correct functional implementation check on transmit or receive interrupt flag UCTXIFG/UCRXIFG instead of UCBUSY to know if the UCAxTXBUF buffer is empty or ready for the next complete character.
To reduce the additional current it is recommended to either reset the SPI module (UCAxCTLW0.UCSWRST) in the UCBxCTLW0 or send a dummy byte 0x00 after the intended SPI transmission is completed.

---

**USCI42 USCI Module**

**Category**
Functional

**Function**
UART asserts UCTXCPTIFG after each byte in multi-byte transmission

**Description**
UCTXCPTIFG flag is triggered at the last stop bit of every UART byte transmission, independently of an empty buffer, when transmitting multiple byte sequences via UART. The erroneous UART behavior occurs with and without DMA transfer.

**Workaround**
None.

---

**USCI44 USCI Module**

**Category**
Functional

**Function**
Differing clock sources may cause UART communication failure

**Description**
When using the USCI_A UART module with differing clock sources for the system clock (MCLK) and the UART source clock (BRCLK), any read or write of the UCAxIFG, UCAxCTLW0, UCAxSTATW, UCAxRXBUF, UCAxTXBUF, UCAxABCTL & UCAxIV registers, while the UCATXIFG or UCARXIFG flag is being set by a UART event could unintentionally clear the UCATXIFG or UCARXIFG. This may result in the UART communication being stalled.

**Workaround**
Workaround 1: Use synchronous clocks to source BRCLK and MCLK. Note that the clock frequencies need not be identical and dividers may be used as long as they are using the same clock source.

Workaround 2: Avoid polling UCAxTXIFG and UCAxRXIFG. Using the standard interrupt service routine to service the interrupt flag significantly reduces access to the USCI registers & hence reduces the probability of this errata occurring. Also, limit all accesses of the UCAxCTLW0, UCAxSTATW, UCAxRXBUF, UCAxTXBUF, UCAxABCTL, UCAxIFG, & UCAxIV registers while transmit or receive operation is ongoing (and UCAxRXIFG or UCAxTXIFG is expected to be set) as this can further reduce the probability of this errata occurring.
**USCI47  USCI Module**

**Category**  Functional

**Function**  eUSCI SPI slave with clock phase UCCKPH = 1

**Description**  The eUSCI SPI operates incorrectly under the following conditions:

1. The eUSCI_A or eUSCI_B module is configured as a SPI slave with clock phase mode UCCKPH = 1

   AND

2. The SPI clock pin is not at the appropriate idle level (low for UCCKPL = 0, high for UCCKPL = 1) when the UCSWRST bit in the UCxxCTLW0 register is cleared.

If both of the above conditions are satisfied, then the following will occur:

- **eUSCI_A**: the SPI will not be able to receive a byte (UCAxRXBUF will not be filled and UCRXIFG will not be set) and SPI slave output data will be wrong (first bit will be missed and data will be shifted).
- **eUSCI_B**: the SPI receives data correctly but the SPI slave output data will be wrong (first byte will be duplicated or replaced by second byte).

**Workaround**  Use clock phase mode UCCKPH = 0 for MSP SPI slave if allowed by the application.

OR

The SPI master must set the clock pin at the appropriate idle level (low for UCCKPL = 0, high for UCCKPL = 1) before SPI slave is reset (UCSWRST bit is cleared).

OR

For eUSCI_A: to detect communication failure condition where UCRXIFG is not set, check both UCRXIFG and UCTXIFG. If UCTXIFG is set twice but UCRXIFG is not set, reset the MSP SPI slave by setting and then clearing the UCSWRST bit, and inform the SPI master to resend the data.

---

**USCI50  USCI Module**

**Category**  Functional

**Function**  Data may not be transmitted correctly from the eUSCI when operating in SPI 4-pin master mode with UCSTEM = 0

**Description**  When the eUSCI is used in SPI 4-pin master mode with UCSTEM = 0 (STE pin used as an input to prevent conflicts with other SPI masters), data that is moved into UCxTXBUF while the UCxSTE input is in the inactive state may not be transmitted correctly. If the eUSCI is used with UCSTEM = 1 (STE pin used to output an enable signal), data is transmitted correctly.

**Workaround**  When using the STE pin in conflict prevention mode (UCSTEM = 0), only move data into UCxTXBUF when UCxSTE is in the active state. If an active transfer is aborted by UCxSTE transitioning to the master-inactive state, the data must be rewritten into UCxTXBUF to be transferred when UCxSTE transitions back to the master-active state.

---

**WDG6  WDG Module**

**Category**  Functional
<table>
<thead>
<tr>
<th>WDG6 (continued)</th>
<th><strong>WDG Module</strong></th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>Function</strong></td>
<td>Clock Fail-Safe feature in LPMx.5</td>
</tr>
<tr>
<td><strong>Description</strong></td>
<td>The watchdog clock fail-safe feature does not prevent the device from going into LPMx.5. As a result, the device enters LPMx.5 state independently of running the watchdog. Note that the watchdog is off in LPMx.5.</td>
</tr>
<tr>
<td><strong>Workaround</strong></td>
<td>None.</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>XOSC13</th>
<th><strong>XOSC Module</strong></th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>Category</strong></td>
<td>Functional</td>
</tr>
<tr>
<td><strong>Function</strong></td>
<td>XT1 in bypass mode does not work with RTC enabled</td>
</tr>
<tr>
<td><strong>Description</strong></td>
<td>When the RTC module is enabled and XT1 is configured in bypass mode to be sourced by an external digital signal, the XT1OFFG flag is set indefinitely, resulting in ACLK defaulting its clock source to VLO instead of XT1.</td>
</tr>
<tr>
<td><strong>Workaround</strong></td>
<td>Do not use RTC module with XT1 in bypass mode with external digital clock source.</td>
</tr>
</tbody>
</table>
# 7 Revision History

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

<table>
<thead>
<tr>
<th>Changes from July 14, 2021 to August 27, 2021</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>• ADC71 was added to the errata documentation</td>
<td>6</td>
</tr>
<tr>
<td>• TB25 was added to the errata documentation</td>
<td>6</td>
</tr>
<tr>
<td>• ADC71 Description was updated</td>
<td>8</td>
</tr>
<tr>
<td>• ADC71 Workaround was updated</td>
<td>8</td>
</tr>
<tr>
<td>• TB25 Description was updated</td>
<td>18</td>
</tr>
<tr>
<td>• TB25 Workaround was updated</td>
<td>18</td>
</tr>
</tbody>
</table>
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