

# Wireless Gecko EFR32FG22 Errata



This document contains information on the EFR32FG22 errata. The latest available revision of this device is revision C.

Errata that have been resolved remain documented and can be referenced for previous revisions of this device.

The device data sheet explains how to identify the chip revision, either from package marking or electronically.

Errata effective date: May, 2020.

# 1. Errata Summary

The table below lists all known errata for the EFR32FG22 and all unresolved errata in revision C of the EFR32FG22.

Table 1.1. Errata Overview

| Designator | Designator Title/Problem                                                 |        | Workaround Exists on Revision: |   |
|------------|--------------------------------------------------------------------------|--------|--------------------------------|---|
|            |                                                                          | Exists | В                              | С |
| CMU_E301   | Hard Fault Exiting EM2 or EM3 with Debugger Attached                     | Yes    | х                              | _ |
| CMU_E302   | LFRCO Precision Mode Is Not Functional                                   | No     | х                              | _ |
| CMU_E303   | Outputting the HFXO or HFRCO to a Pin Can Hang the Device in EM2/EM3     | Yes    | Х                              | _ |
| EMU_E301   | Request for Averaged Temperature Reading Can Be Missed                   | Yes    | х                              | _ |
| EMU_E302   | DC-DC is Disabled after a Soft Reset                                     | Yes    | Х                              | _ |
| EMU_E303   | Watchdog Reset Hangs System Entering EM2 or EM3                          | Yes    | Х                              | Х |
| RADIO_E302 | Data Whitening is not Selective                                          | No     | Х                              | Х |
| RADIO_E303 | RAIL packet filters work incorrectly when header is enabled              | Yes    | Х                              | Х |
| TIMER_E301 | Continuous Overflow and Underflow Interrupts in Quadrature Counting Mode | Yes    | Х                              | _ |
| USART_E301 | Possible Data Transmission on Wrong Edge in Synchronous Mode             | Yes    | Х                              | Х |
| USART_E302 | Additional SCLK Pulses are generated in the USART Synchronous Mode       | Yes    | Х                              | Х |
| WDOG_E301  | Clear Command is Lost Upon EM2 Entry                                     | Yes    | х                              | _ |

## 2. Current Errata Descriptions

## 2.1 EMU\_E303 - Watchdog Reset Hangs System Entering EM2 or EM3

## Description of Errata

The chip can hang and require a hard reset (pin or power-on) to recover if

- The system is operating with VSCALE1 core voltage scaling (software has previously written a 1 to the EMU CMD EM01VSCALE1 bit),
- 2. The system is in the process or entering EM2 or EM3 (software has just executed the WFE or WFI instruction with the SLEEP-DEEP bit in the System Control Register set) and
- 3. A Watchdog timeout reset is triggered

#### Affected Conditions / Impacts

Systems operating with core voltage scaling can hang if a Watchdog reset occurs immediately upon EM2 or EM3 entry.

#### Workaround

Systems that keep the Watchdog enabled in low energy modes should, as a matter of good programming practice, service the Watchdog before entering EM2 or EM3. Calling the emlib wdogn\_Feed() function followed by the wdogn\_SyncWait() function (to ensure that the servicing write to the Wdog\_CMD register completes execution) immediately before entering EM2 or EM3 will prevent a Watchdog reset that could possibly hang the system under the specified circumstances.

#### Resolution

There is currently no resolution for this issue.

## 2.2 RADIO\_E302 - Data Whitening is not Selective

#### Description of Errata

Data whitening is not selective. Enabling whitening for only the packet header also whitens the payload, while enabling whitening for only the payload also whitens the packet header.

#### Affected Conditions / Impacts

Radio PHYs that require selective whitening of either only the packet header or the payload will not function correctly.

#### Workaround

There is currently no workaround for this issue.

#### Resolution

There is currently no resolution for this issue.

#### 2.3 RADIO\_E303 - RAIL packet filters work incorrectly when header is enabled

#### Description of Errata

When header is enabled on the radio configurator, RAIL's address filter and 15.4 packet type filter works incorrectly

#### Affected Conditions / Impacts

Packets that should have been filtered will be received.

#### Workaround

Simplicity Studio v4.1.13.6 or later and RAIL v2.8.4 in Flex SDK v2.7.4 will mitigate this issue by using a workaround. The workaround is effective if:

- · Header and payload have the same CRC & whitening configuration.
- · Header and payload have the same whitening configuration, different CRC configuration and header is less than 4 bytes long.

When an incompatible radio configuration setting is used, such as a 4 bytes or longer header length with CRC disabled, RAIL generates a RAIL\_ASSERT\_INVALID\_FILTERING\_CONFIG error upon enabling filtering.

#### Resolution

There is currently no resolution for this issue.

## 2.4 USART\_E301 — Possible Data Transmission on Wrong Edge in Synchronous Mode

#### Description of Errata

The first bit of the new data word is incorrectly transmitted on the leading clock edge of the subsequent data bit and not the trailing clock edge of the current data bit if the USART is configured to operate in synchronous mode with

- 1. USART\_CLKDIV\_DIV = 0 (clock = fHFPERCLK ÷ 2),
- 2. USART CTRL CLKPHA = 0.
- 3. USART\_TIMING\_CSHOLD = 1 and
- 4. Data is loaded into the transmit FIFO (say, by the LDMA) at the exact same time as the USART state machine begins to insert the requested one bit time extension of the chip select hold time (USART\_TIMING\_CSHOLD = 1).

## Affected Conditions / Impacts

Reception of each data bit by the slave is tied to a specific clock edge. Therefore, the late transmission by the master of the first bit of a word may cause the slave to receive the incorrect data, especially if the data setup time for the slave approaches or exceeds one half the shift clock period.

#### Workaround

Because there is no way to specifically time a write to the transmit FIFO such that it does not occur when the USART state machine changes state, use one of the following workarounds to avoid the risk for data corruption described above:

- Set USART\_CLK\_DIV > 0.
- Use USART TIMING CSHOLD = 0 or USART TIMING CSHOLD > 1.
- Use USART\_CTRL\_CLKPHA = 1. This is option is particularly useful with SPI flash memories as many support operation in both the CLKPOL = CLKPHA = 0 and CLKPOL = CLKPHA = 1 modes.

## Resolution

There is currently no resolution for this issue.

## 2.5 USART\_E302 — Additional SCLK Pulses are generated in the USART Synchronous Mode

## Description of Errata

An additional SCLK Pulse is generated for all the data frames except the last frame, when the USART is configured to use Inter Character Spacing (ICS) with CLKPHA = 1 in the synchronous master mode.

## Affected Conditions / Impacts

When the USART is configured to use Inter Character Spacing with CLKPHA = 1 in the synchronous master mode, undesirable SCLK Pulses are generated.

## Workaround

To workaround this issue, set CLKPHA to 0 when the Inter Character Spacing is used with Synchronous Master Mode.

## Resolution

There is currently no resolution for this issue.

## 3. Resolved Errata Descriptions

This section contains previous errata for EFR32FG22 devices.

For errata on the latest revision, refer to the beginning of this document. The device data sheet explains how to identify chip revision, either from package marking or electronically.

#### 3.1 CMU\_E301 - Hard Fault Exiting EM2 or EM3 with Debugger Attached

#### Description of Errata

When waking from EM2 or EM3 with a debugger attached, the CPU clock starts approximately 40 cycles in advance of the ICACHE clock. Because the CPU resumes execution before the ICACHE is ready, the data returned in response to instruction fetches is corrupted, resulting in a hard fault exception.

## Affected Conditions / Impacts

Executing code that resides in flash and wakes from EM2 or EM3 while a debugger is connected causes the system to take a hard fault exception.

#### Workaround

Depending on the functionality required, the hard fault condition can be avoided by:

- Detach the debugger before entering EM2 or EM3. When the debugger is attached, certain high frequency clocks remain active in EM2 or EM3, which is why the the ICACHE clock is delayed relative to the CPU clock upon wake-up. Without the debugger connected, these clocks shutdown when entering EM2 or EM3 and restart together upon wake-up, thus avoiding the data corruption described above. Reconnect the debugger once the system is back in EM0 or EM1.
- Execute the WFI or WFE instruction that places the system in EM2 or EM3 from RAM. Upon wake-up, use a software delay loop to stall for the approximately 40 clock cycles of headstart that the CPU has before the ICACHE restarts.
- As above, execute WFI or WFE from RAM, but, instead of using a software delay, wait for the ICACHE\_STATUS\_PCRUNNING bit
  to change state from 0 to 1. The ICACHE performance counter must first be started by writing a 1 to ICACHE\_CMD\_STARTPC,
  which can be done either when running from flash before entering EM2 or EM3 or when running from RAM after wake-up. Stop the
  performance counter by writing a 1 to ICACHE\_CMD\_STOPPC.

## Resolution

This issue is resolved in revision C devices.

## 3.2 CMU\_E302 - LFRCO Precision Mode Is Not Functional

## Description of Errata

The precision mode of the LFRCO is not functional.

## Affected Conditions / Impacts

It is not possible to use the LFRCO in precision mode as a replacement for a 32.768 kHz crystal.

#### Workaround

There is currently no workaround for this issue. Use the LFXO and a suitable 32.768 kHz crystal in applications with such requirements.

## Resolution

This issue is resolved in revision C devices.

## 3.3 CMU\_E303 — Outputting the HFXO or HFRCO to a Pin Can Hang the Device in EM2/EM3

#### Description of Errata

The device hangs when attempting to enter EM2 or EM3 while the HFXO or HFRCO is driven on one of the CLKOUT pins without a debugger connected.

#### Affected Conditions / Impacts

It is not possible to enter EM2 or EM3 when the HFXO or HFRCO is driven on one of the CLKOUT pins nor will an interrupt wake the device that has hung in this way.

#### Workaround

Deselect the HFXO or HFRCO on any CLKOUT pins before entering EM2 or EM3. For example, to de-select the HFXO or HFRCO on pin PC03, add the following function call before entering EM2 or EM3:

CMU\_ClkOutPinConfig(0, cmuSelect\_Disabled, 0, gpioPortC, 3);

#### Resolution

This issue is resolved in revision C devices.

## 3.4 EMU\_E301 – Request for Averaged Temperature Reading Can Be Missed

#### Description of Errata

Depending on the system clock frequency, the request for a hardware-averaged temperature reading is sometimes not captured, and the state machine that generates the averaged reading is never started.

#### Affected Conditions / Impacts

Because the averaging state machine is never started, the EMU\_IF\_TEMPAVIF flag is never set, and any code that depends on the averaged reading is not going to execute.

#### Workaround

Subsequent EMU register accesses will cause the temperature averaging request to be recognized, so the simplest solution to ensure this is to use the following code sequence:

EMU->CMD\_SET = EMU\_CMD\_TEMPAVGREQ;
while (!(EMU->STATUS & EMU\_STATUS\_TEMPAVGACTIVE));

#### Resolution

This issue is resolved in revision C devices.

## 3.5 EMU\_E302 - DC-DC is Disabled after a Soft Reset

## Description of Errata

The DC-DC converter stops regulating after a soft reset until it is re-enabled.

## Affected Conditions / Impacts

When disabled, the DC-DC operates in bypass mode. Supplies connected to the DC-DC output will be powered at the VREGIN voltage which increases current consumption, until the DC-DC is re-enabled.

#### Workaround

On devices prior to revision C, firmware must re-enable the DC-DC after a soft reset.

#### Resolution

This issue has been resolved. Revision C devices with PRODREV greater than or equal to 1 will not have this issue.

## 3.6 TIMER\_E301 — Continuous Overflow and Underflow Interrupts in Quadrature Counting Mode

## Description of Errata

When the TIMER is configured to operate in quadrature decoder mode with the overflow interrupt enabled and the counter value (TIMER\_CNT) reaches the top value (TIMER\_TOP), the overflow interrupt is requested contiunously even if the interrupt flag (TIMER\_IF\_OF) is cleared. Similarly, if the underflow interrupt is enabled and the counter value reaches zero, the underflow interrupt is requested contiunously even if the interrupt flag (TIMER\_IF\_UF) is cleared. Only after the counter value has incremented or decremented so that the overflow or underflow condition no longer applies can the interrupt be cleared.

## Affected Conditions / Impacts

Because the counter is clocked by its CC0 and CC1 inputs in quadrature decoder mode and not the prescaled HFPERCLK, overflow and underflow events remain latched as long TIMER\_CNT remains at the value that triggered the overflow or underflow condition. Until the counter is no longer in the overflow or underflow condition, it is not possible to clear the associated interrupt flag.

## Workaround

Short of disabling the relevant interrupts, the simplest workaround is to manually increment or decrement TIMER\_CNT so that the overflow or underflow condition no longer exists. Insert the following or similar code in the interrupt handler for the timer in question (TIMER0 in this case) to do this:

```
uint32 intflags = TIMER_IntGet(TIMER0);

if (intFlags & TIMER_IEN_OF)
   TIMER0->CNT += 1;

if (intFlags & TIMER_IEN_UF)
   TIMER0->CNT -= 1;
```

It may be necessary for firmware to account for this adjustment in calculations that include the counter value.

#### Resolution

This issue is resolved in revision C devices.

#### 3.7 WDOG\_E301 - Clear Command is Lost Upon EM2 Entry

## Description of Errata

If the device enters EM2, while the clear command is still being synchronized, the Watchdog counter may not be cleared as expected.

#### Affected Conditions / Impacts

Because the averaging state machine is never started, the EMU\_IF\_TEMPAVIF flag is never set, and any code that depends on the averaged reading is not going to execute.

## Workaround

Wait for WDOG\_SYNCBUSY\_CMD to clear before entering EM2.

Note that WDOG can be clocked from one of the low-frequency clock sources and will require additional time to enter EM2 when implementing this workaround.

#### Resolution

This issue is resolved in revision C devices.

## 4. Revision History

## Revision 0.4

May, 2020

• Added RADIO\_E303 and USART\_E302.

## Revision 0.3

January, 2020

Added EMU\_E303 and RADIO\_E302.

## Revision 0.2

October, 2019

- · Updated to product revision C.
- Added CMU\_E303, EMU\_E302, TIMER\_E301 and WDOG\_E301.
- Resolved CMU\_E301, CMU\_E302 and EMU\_E301
- Migrated to new errata document format.

## Revision 0.1

July, 2019

· Initial release.





loT Portfolio www.silabs.com/loT



**SW/HW** <u>www.silabs.com/simplicity</u>



Quality www.silabs.com/quality



Support and Community community.silabs.com

#### Disclaimer

Silicon Labs intends to provide customers with the latest, accurate, and in-depth documentation of all peripherals and modules available for system and software implementers using or intending to use the Silicon Labs products. Characterization data, available modules and peripherals, memory sizes and memory addresses refer to each specific device, and "Typical" parameters provided can and do vary in different applications. Application examples described herein are for illustrative purposes only. Silicon Labs reserves the right to make changes without further notice to the product information, specifications, and descriptions herein, and does not give warranties as to the accuracy or completeness of the included information. Without prior notification, Silicon Labs may update product firmware during the manufacturing process for security or reliability reasons. Such changes will not alter the specifications or the performance of the product. Silicon Labs shall have no liability for the consequences of use of the information supplied in this document. This document does not imply or expressly grant any license to design or fabricate any integrated circuits. The products are not designed or authorized to be used within any FDA Class III devices, applications for which FDA premarket approval is required, or Life Support Systems without the specific written consent of Silicon Labs. A "Life Support System" is any product or system intended to support or sustain life and/or health, which, if it fails, can be reasonably expected to result in significant personal injury or death. Silicon Labs products are not designed or authorized for military applications. Silicon Labs products shall under no circumstances be used in weapons of mass destruction including (but not limited to) nuclear, biological or chemical weapons, or missiles capable of delivering such weapons. Silicon Labs disclaims all express and implied warranties and shall not be responsible or liable for any injuries or damages related to use of a Silicon Labs

#### Trademark Information

Silicon Laboratories Inc.®, Silicon Laboratories®, Silicon Labs®, Silabs® and the Silicon Labs logo®, Bluegiga®, Bluegiga®, Bluegiga®, CockBuilder®, CMEMS®, DSPLL®, EFM®, EFM32®, EFR, Ember®, Energy Micro, Energy Micro logo and combinations thereof, "the world's most energy friendly microcontrollers", Ember®, EZLink®, EZRadio®, EZRadio®, Gecko®, Gecko OS, Studio, ISOmodem®, Precision32®, ProSLIC®, Simplicity Studio®, SiPHY®, Telegesis, the Telegesis Logo®, USBXpress®, Zentri, the Zentri logo and Zentri DMX, Z-Wave®, and others are trademarks or registered trademarks of Silicon Labs. ARM, CORTEX, Cortex-M3 and THUMB are trademarks or registered trademarks of the Wi-Fi alliance. All other products or brand names mentioned herein are trademarks of their respective holders.



Silicon Laboratories Inc. 400 West Cesar Chavez Austin, TX 78701