

# 8-Bit MCU Family C8051F85x/86x Errata



This document contains information on the errata of revision C of C8051F85x/86x.

For errata on older revisions, please refer to the errata history for the device. The device data sheet explains how to identify chip revision, either from package marking or electronically.

Errata effective date: September 16, 2016.

## 1. Errata Summary

| Errata | # Designator | Title/Problem                                   | Workaround | Affected | Fixed    |
|--------|--------------|-------------------------------------------------|------------|----------|----------|
|        |              |                                                 | Exists     | Revision | Revision |
| 1      | WDT_E101     | Restrictions on Watchdog Timer Refresh Interval | Yes        | С        | _        |

## 2. Detailed Errata Descriptions

## 2.1 WDT\_E101 – Restrictions on Watchdog Timer Refresh Interval

#### Description of Errata

If the Watchdog Timer (WDT) is enabled, firmware will periodically write an 0xA5 value to the WDTCN register to refresh the timer and prevent the watchdog reset from occurring. However, if firmware writes to WDTCN more than once during the same LFOSC0 clock period, the refresh signal may be canceled, resulting in an unintended watchdog reset when the timer expires.

### Affected Conditions / Impacts

If firmware refreshes the watchdog more than once in the same LFOSC0 clock period, an unexpected watchdog reset can occur.

#### Workaround

Systems using the Watchdog Timer (WDT) should ensure that the WDT is refreshed no more than once per LFOSC0 clock period.

Firmware can do this by using timers to count LFOSC0 clock periods. There are three methods to accomplish this:

1. If Timer 3 is not already in use, set it up to capture on the LFOSC0 clock. In this mode, the value of the Timer 3 reload registers does not matter. Instead, the WDT refresh function should check for the 16-bit timer flag (TF3H) to be set in the reset watchdog function, which indicates that a capture event occurred. If the device has another timer that can capture on the LFOSC0 clock, then that timer may be used instead of Timer 3.

```
void refresh_wdt()
{
    // Only refresh if TF3H is set
    if (TMR3CN0 & (0x80))
    {
        WDTCN = 0xA5;
        TMR3CN0 &= ~(0x80);
    }
}
```

2. If any timer is already in use and is clocked from the LFOSC0 or LFOSC0/8, firmware can check the current count against the previous count to ensure at least one clock period has passed:

```
void refresh_wdt()
{
   static uint16_t last_TMR3 = 0;
   if (last_TMR3 != TMR3)
   {
      // At least 1 LFOSCO falling edge has occurred since the last WDT refresh
      WDTCN = 0xA5;
      last_TMR3 = TMR3;
   }
}
```

3. If the application already has an accurate and reliable time base, use that timer to establish a minimum WDT refresh interval that is longer than one LFOSC0 clock period in duration, similar to method (2) above as appropriate.

See the Knowledge Base article on this errata for more information, including examples of these firmware workarounds: http:// community.silabs.com/t5/8-bit-MCU-Knowledge-Base/WDT-E101-Title/ta-p/177029.

**Note:** The LFOSC0 does not halt while debugging. This can cause the timer overflow flag to be set more quickly than expected when debugging the watchdog refresh function.

### Resolution

There is currently no resolution for this issue.

## 3. Revision History

## 3.1 Revision 0.2

September 16, 2016

Moved UID\_E101 and PKG\_E103 from the errata to the errata history.

Added WDT\_E101.

## 3.2 Revision 0.1

February 10, 2014

Initial release.





## **Simplicity Studio**

One-click access to MCU and wireless tools, documentation, software, source code libraries & more. Available for Windows, Mac and Linux!







Supp

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 and limitation to product information, specifications, and descriptions herein, and does not give warranties as to the accuracy or completeness of the included information. Silicon Labs shall have no liability for the consequences of use of the information supplied herein. This document does not imply or express copyright licenses granted hereunder to design or fabricate any integrated circuits. The products are not designed or authorized to be used within any 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 be used in weapons of mass destruction including (but not limited to) nuclear, biological or chemical weapons, or missiles capable of delivering such weapons.

#### **Trademark Information**

Silicon Laboratories Inc.®, Silicon Laboratories®, Silicon Labs®, SiLabs® and the Silicon Labs logo®, Bluegiga®, Bluegiga Logo®, Clockbuilder®, 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®, SiPHY®, Telegesis, the Telegesis Logo®, USBXpress® and others are trademarks or registered trademarks of Silicon Labs. ARM, CORTEX, Cortex-M3 and THUMB are trademarks or registered trademarks of ARM Holdings. Keil is a registered trademark of ARM Limited. All other products or brand names mentioned herein are trademarks of their respective holders.



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

# http://www.silabs.com