# CC26xx/CC13xx Power Management Software Developer's

# **Reference Guide**



Literature Number: SWRA486 August 2015



## **Contents**

| 1 | Abbrev                        | riations                                                    | Ę  |  |  |
|---|-------------------------------|-------------------------------------------------------------|----|--|--|
| 2 | Power Management Introduction |                                                             |    |  |  |
| 3 | TI-RTO                        | S Power Modes                                               | 6  |  |  |
|   | 3.1                           | Active Mode                                                 | 6  |  |  |
|   | 3.2                           | Idle Mode                                                   | 7  |  |  |
|   | 3.3                           | Standby Mode                                                | 8  |  |  |
|   | 3.4                           | Shutdown Mode                                               | 13 |  |  |
| 4 | Implem                        | nentation Considerations1                                   | 16 |  |  |
|   | 4.1                           | Device Initializing                                         | 16 |  |  |
|   | 4.2                           | Recharging in Standby                                       |    |  |  |
|   | 4.3                           | Operating the DC/DC Converter                               |    |  |  |
|   | 4.4                           | Configuring Device for External Input Interrupts and Wakeup | 19 |  |  |
|   | 4.5                           | Oscillators                                                 |    |  |  |
|   | 4.6                           | Auxiliary Domain                                            | 22 |  |  |
|   | 4.7                           | RTC                                                         |    |  |  |
|   | 4.8                           | Debugging Through Power Modes                               | 24 |  |  |
|   | 4.9                           | Using Peripherals                                           |    |  |  |
| 5 | Refere                        | nces                                                        |    |  |  |



#### www.ti.com

### **List of Figures**

| 1  | Idle Enter Sequence                                                                              | 7  |
|----|--------------------------------------------------------------------------------------------------|----|
| 2  | Standby Enter Sequence, Part 1                                                                   | 8  |
| 3  | Standby Enter Sequence, Part 2                                                                   | 9  |
| 4  | Standby Enter Sequence, Part 3                                                                   | 10 |
| 5  | Standby Exit Sequence, Part 1                                                                    | 11 |
| 6  | Standby Exit Sequence, Part 2                                                                    | 12 |
| 7  | Shutdown Enter Sequence                                                                          | 14 |
| 8  | trimDevice() function in setup.c                                                                 | 16 |
| 9  | TI-RTOS Initialization                                                                           | 17 |
| 10 | Configure Recharge Settings Before Entering Standby                                              | 18 |
| 11 | Configure Recharge Settings After Exiting Standby                                                | 18 |
| 12 | CCFG Fields For Enabling the DC/DC Converter During Active and Standby Mode                      | 18 |
| 13 | The Voltage Threshold For Turning Off the DC/DC Converter                                        | 18 |
| 14 | The Driverlib Function That Enables and Disables the DC/DC Converter at the Given CCFG Threshold | 19 |
| 15 | Switching from RCOSC_HF to XOSC_HF                                                               | 20 |
| 16 | LF Configuration in ccfg.c                                                                       | 21 |
| 17 | Code for Disabling LF Clock Qualifiers                                                           | 21 |
| 18 | Configuration When Using an External LF Clock Source                                             | 21 |
| 19 | Powering Up the Auxiliary Power Domain                                                           | 22 |
| 20 | Powering Down the Auxiliary Domain                                                               | 22 |
|    | List of Tables                                                                                   |    |
| 1  | Software Configurable Power Modes                                                                | 6  |
| 2  | Sensor Controller/Auxiliary Power Management                                                     | 23 |



# CC26xx/CC13xx Power Management Software Developer's

Power management for the CC26xx/CC13xx family is implemented as part of the TI-RTOS kernel. This document gives an overview of this implementation and what to consider when porting this implementation to another software framework.

This document covers the parts specific to CC26xx/CC13xx but does not cover the generic TI-RTOS kernel implementation. This guide also describes tasks that the software must perform to operate this device safely. Tasks are in bold followed by their descriptions.



www.ti.com Abbreviations

#### 1 Abbreviations

| ADC      | Analog-to-Digital Converter       |
|----------|-----------------------------------|
| AON      | Always-On Domain                  |
| CCFG     | Customer Configuration Flash area |
| CM3      | Cortex-M3, main system controller |
| OSC      | Oscillator                        |
| OSC_DIG  | Digital part of oscillator module |
| PRCM     | Power-Reset-Clock Management      |
| RCOSC_HF | High-frequency RC oscillator      |
| RCOSC_LF | Low frequency RC oscillator       |
| RTC      | Real-Time Clock                   |
| RTOS     | Real Time Operating System        |
| TDC      | Time-to-Digital Converter         |
| TI-RTOS  | TI Real-Time Operating System     |
| TRM      | Technical Reference Manual        |
| WFI      | Wait-For-Interrupt                |
| XOSC_HF  | High-frequency crystal oscillator |
| XOSC_LF  | Low-frequency crystal oscillator  |

#### 2 Power Management Introduction

In the TI-RTOS implementation for CC26xx/CC13xx, power management implements within the RTOS kernel. Because of this implementation, you can write applications without handling power management. The application requires no changes when upgrading to new versions of the kernel with further optimized power management. Handling power management within TI-RTOS occurs by configuring the system to the lowest power mode while supporting the requested resources from the application. The TI-RTOS installation is available at the TI website. This installation includes the source code for handling power management.

TI-RTOS supports the following four power modes:

- Active
- Idle
- Standby
- Shutdown

Section 3 presents the modes in detail. In active and idle mode, all resources on the device are available. The standby and shutdown modes are optimized for power consumption and limited resources are available in these modes. In TI-RTOS, the application does not select which power mode to enter. The kernel selects the power mode based on the next wakeup and which resources the application requests (such as the radio or another peripherals). The application must call only shutdown mode because waking up from shutdown forces a reboot of the system.

The TI-RTOS implementation is explained in is documented within the TI-RTOS installation. This document references the TI-RTOS implementation document but focuses on how to configure the hardware when not using TI-RTOS. The sample code in this document is from the TI-RTOS implementation and the driverlib APIs.



#### 3 TI-RTOS Power Modes

TI-RTOS supports four different power modes, shown in Table 1.

**Table 1. Software Configurable Power Modes** 

| B4 - 4 -                                                | Software Configurable Power Modes |                          |                        |                |                |
|---------------------------------------------------------|-----------------------------------|--------------------------|------------------------|----------------|----------------|
| Mode                                                    | Active                            | ldle                     | Standby                | Shutdown       | Reset Pin Held |
| System CPU                                              | Active                            | Off                      | Off                    | Off            | Off            |
| System SRAM                                             | On                                | On                       | Retained               | Off            | Off            |
| Register<br>Retention <sup>(1)</sup>                    | Full                              | Full                     | Partial                | No             | No             |
| VIMS_PD<br>(flash)                                      | On                                | Available                | Off                    | Off            | Off            |
| RFCORE_PD<br>(radio)                                    | Available                         | Available                | Off                    | Off            | Off            |
| SERIAL_PD                                               | Available                         | Available                | Off                    | Off            | Off            |
| PERIPH_PD                                               | Available                         | Available                | Off                    | Off            | Off            |
| Sensor<br>Controller                                    | Available                         | Available                | Available              | Off            | Off            |
| Supply System                                           | On                                | On                       | Duty-cycled            | Off            | Off            |
| Current                                                 | Application dependent             | Application<br>Dependent | Approx. 1 μA           | Approx. 0.1 μA | Approx. 0.1 μA |
| Time from CPU active to ready for Wakeup <sup>(2)</sup> | -                                 | TBD                      | TBD                    | TBD            | _              |
| Wake-up time to CPU active (2)                          | -                                 | 25 µs                    | 300 μs <sup>(1)</sup>  | Approx. 1.5 ms | Approx. 1.5 ms |
| High-speed clock                                        | XOSC_HF or RCOSC_HF               | XOSC_HF or RCOSC_HF      | Off                    | Off            | Off            |
| Low-speed clock                                         | XOSC_LF or RCOSC_LF               | XOSC_LF or<br>RCOSC_LF   | XOSC_LF or<br>RCOSC_LF | Off            | Off            |
| Wakeup on RTC                                           | Available                         | Available                | Available              | Off            | Off            |
| Wakeup on pin edge                                      | Available                         | Available                | Available              | Available      | Off            |
| Wakeup on reset pin                                     | Available                         | Available                | Available              | Available      | Available      |

<sup>(1)</sup> When an emulator or debugger is attached to the device, the wake-up time is approximately 200 μs shorter because the system will not enter true standby.

This section describes how these power modes are implemented in TI-RTOS and how to port TI-RTOS to another software framework.

#### 3.1 Active Mode

In active mode, the CM3 either executes code or waits through a WFI instruction for interrupts. System resources are available in active mode. The CPU power domain, peripherals, and radio may be active. Because the resources on CC26xx/CC13xx are available to the application in this mode, the current consumption depends on which modules are used.

If the CM3 executed a WFI instruction, it can wake up from any enabled interrupt source. The difference between active and idle mode (see Section 3.2) is that the CPU power domain remains on in active mode ensuring a quick wakeup. The wakeup time from idle mode is longer because the CPU power domain must be turned on again.

<sup>(2)</sup> Numbers include TI-RTOS overhead.



#### 3.2 Idle Mode

In idle mode, the CM3 is in deep-sleep after executing the WFI instruction. The CM3 waits for interrupts to wake up. The CPU power domain is off to reduce the current consumption. The CPU power domain increases the wake-up time of approximately 25  $\mu$ s. Consider this increase if the application is timing sensitive. Although the CPU power domain is off, it retains its contents. When waking up from idle mode, the CM3 resumes executing code at the point it left off before entering idle. The state and register contents of the CM3 remain unchanged.

In idle mode, the application program can use system resources, including the high-speed crystal oscillator, the radio, and the peripherals. The CM3 can wake up from any enabled interrupt source. For details on entering idle mode, see Figure 1.

The code for entering idle mode is from the TI-RTOS implementation. Find it at the following path: C:\ti\tirtos\_simplelink\_#\_##\_##\products\bios\_#\_##\_##\_packages\ti\sysbios\family\arm\cc26xx\Pow er\_standbyPolicy.c.

```
* Power off the CPU domain; VIMS will power down if SYSBUS is
 * powered down, and SYSBUS will power down if there are no
 * dependencies
 * NOTE: if radio driver is active it must force SYSBUS enable to
 * allow access to the bus and SRAM
 */
if ((constraints & Power IDLE PD DISALLOW) == 0) {
    /* 1. Configure flash to remain on in IDLE or not */
   if ((constraints & Power NEED FLASH IN IDLE) == 0) {
       HWREG (PRCM BASE + PRCM O PDCTL1VIMS) &= ~PRCM PDCTL1VIMS ON;
   else {
        HWREG(PRCM BASE + PRCM O PDCTL1VIMS) |= PRCM PDCTL1VIMS ON;
    /* 2. Always keep Cache retention on in idle */
   PRCMCacheRetentionEnable();
    /* 3. Turn off the CPU power domain */
   PRCMPowerDomainOff(PRCM DOMAIN CPU);
    /* 4. Ensure any possible outstanding AON writes are completed */
   SysCtrlAonSync();
    /* 5. Enter IDLE */
    PRCMDeepSleep();
```

Figure 1. Idle Enter Sequence

- Configure flash to remain on in IDLE or not— The flash can remain on to support DMA transactions
  from flash or if the RF core needs to access the flash. If the application requires the flash to remain
  available while in idle, set the PRCM:PDCTL1 bit (see CC26xx Technical Reference Manual
  [SWCU117]) before entering idle. If the application does not require flash access while in idle, clear
  this bit for the lowest power consumption.
- 2. Always keep Cache retention on in idle— Always enable the cache retention to ensure faster startup time and easier software implementation. The current consumption caused by retaining the cache in idle is negligible compared to the total idle current consumption.
- 3. **Turn off the CPU power domain** Ensure the CPU power domain is off when the CM3 enters deep-sleep. The CPU power domain is turned off after the CM3 executes the WFI instruction (with the NVIC SLEEP\_DEEP bit set) and enters deep-sleep.



4. **Ensure any possible outstanding AON writes are completed**— If the AON domain has any outstanding writes, the driver must ensure they complete before entering idle. This function call stalls the CM3 execution for up to one SCLK LF period because the AON domain runs on the SCLK LF.

5. **Enter Idle**— Put the CM3 in deep-sleep through the WFI instruction to enter idle. If the wake-up source is the RTC, the software must perform AON synchronization (in Step 4) before reading from the RTC module to ensure the RTC values are updated correctly.

#### 3.3 Standby Mode

In standby mode, the CM3 waits in deep-sleep for interrupts to wake up after executing the WFI instruction. Before entering standby, power down system resources, including the high-frequency oscillator, radio, peripherals, and auxiliary domain. Many system modules have retention in standby including the CM3 (see the *CC26xx Technical Reference Manual* [SWCU117] for details). After waking up from standby, the CM3 resumes executing programs at the point before entering standby.

Because the CC26xx/CC13xx runs on a low-power LDO in standby, most system resources are unavailable in standby. Use the RTC, which runs in standby, to wake up the CM3. The CM3 can wake up on any interrupt-enabled, external input pin.

The application must consider the latency associated with entering and exiting when using standby mode.

If the next wakeup is in less than 1 ms, the TI-RTOS implementation does not enter standby. If the application requires exact timing, consider the latency associated with entering and waking up from standby. The TI-RTOS implementation handles this latency by inserting wake-up event four RTC edges (64  $\mu$ s) earlier than the event to ensure the system powers on in time to service the wake-up event scheduled by the application.

The TI-RTOS standby implementation allows a variation where the cache contents are retained. In standby, the system draws approximately 2 µA more than without retaining the cache. System start-up from standby is typically quicker. The main system RAM should always be retained in standby mode. The main system RAM retention is also the default configuration when the device boots up.

The following code for entering and exiting standby is from the TI-RTOS Power.c implementation: C:\ti\tirtos\_simplelink\_#\_##\_##\products\bios\_#\_##\_##\_packages\ti\sysbios\family\arm\cc26xx\Power.c.

#### 3.3.1 Standby Enter Sequence

```
/* 1. Freeze the IOs on the boundary between MCU and AON */
AONIOCFreezeEnable();

/* 2. If XOSC_HF is active, force it off */
if(OSCClockSourceGet(OSC_SRC_CLK_HF) == OSC_XOSC_HF) {
    xosc_hf_active = TRUE;
    ti_sysbios_family_arm_cc26xx_Power_XOSC_HF(DISABLE);
}

/* 3. Allow AUX to power down */
AONWUCAuxWakeupEvent(AONWUC_AUX_ALLOW_SLEEP);

/* 4. Make sure writes take effect */
SysCtrlAonSync();
```

Figure 2. Standby Enter Sequence, Part 1

Freeze the IOs on the boundary between MCU and AON— Latch (freeze) the input and output pins
to avoid glitches when in standby. When the inputs and outputs are frozen, the current state of the
inputs and outputs is retained while available to trigger wakeup to the CM3. To configure the inputs for
wakeup from standby, see Section 4.4.1.



2. **If XOSC\_HF is active, force it off**— Turn off the high-speed crystal oscillator before entering standby. The hardware turns off the high-speed RC oscillator when entering standby. For details on how to configure the high-speed crystal oscillator, see Section 4.5.1.

- 3. Allow AUX to power down— Disconnect the auxiliary domain from the MCU in standby.
- 4. Make sure writes take effect— Ensure the writes to AON domain complete before continuing.

```
/* 5. Query and save domain states before powering them off */
if (Power_getDependencyCount(DOMAIN_RFCORE)) {
    poweredDomains |= PRCM DOMAIN RFCORE;
if (Power_getDependencyCount(DOMAIN_SERIAL)) {
    poweredDomains |= PRCM DOMAIN SERIAL;
if (Power getDependencyCount(DOMAIN PERIPH)) {
    poweredDomains |= PRCM DOMAIN PERIPH;
/* 6. Gate running deep sleep clocks for Crypto and DMA */
if (Power getDependencyCount(PERIPH CRYPTO)) {
    PRCMPeripheralDeepSleepDisable(
        ti sysbios family arm cc26xx Power db[
            PERIPH CRYPTO].driverlibID);
if (Power getDependencyCount(PERIPH UDMA)) {
    PRCMPeripheralDeepSleepDisable(
        ti_sysbios_family_arm_cc26xx_Power_db[
            PERIPH UDMA].driverlibID);
/* 7. Make sure clock settings take effect */
PRCMLoadSet();
/* 8. Request power off of domains in the MCU voltage domain */
PRCMPowerDomainOff(poweredDomains | PRCM DOMAIN CPU);
/* 9. Request uLDO during standby */
PRCMMcuUldoConfigure(true);
```

Figure 3. Standby Enter Sequence, Part 2

- 5. **Query and save domain states before powering them off** Turn off all power domains before entering standby.
- 6. **Gate running deep sleep clocks for Crypto and DMA** Clear both the crypto and DMA deep-sleep clock enable bits before entering standby. For more information, see the PRCM:VDCTL register.
- 7. Make sure clock settings take effect— Load the clock settings from the PRCM module.
- 8. Request to power off of domains in the MCU voltage domain—Turn off power domains inside the MCU voltage domain.
- Request uLDO during standby— Use this call to request to use the micro-LDO during standby. The system runs off the micro-LDO in standby.



```
/* 10. If don't want retention in standby, disable it now ...
if (retainCache == FALSE) {
   /* 10.1 Get current VIMS mode */
   modeVIMS = VIMSModeGet(VIMS_BASE);
    /* 10.2 Wait if invalidate in progress... */
   while (modeVIMS == VIMS MODE CHANGING) {
       modeVIMS = VIMSModeGet(VIMS BASE);
    /* 10.3 Disable cache RAM retention */
   PRCMCacheRetentionDisable();
    /* 10.4 Turn off the VIMS */
   VIMSModeSet(VIMS BASE, VIMS MODE OFF);
}
/* 11. Setup recharge parameters */
SysCtrlSetRechargeBeforePowerDown (XoscInHighPowerMode);
/* 12. Make sure all writes have taken effect */
SysCtrlAonSync();
/* 13. Invoke deep sleep to go to STANDBY */
PRCMDeepSleep();
```

Figure 4. Standby Enter Sequence, Part 3

- 10. **If don't want retention in standby, disable it now...** Disable cache retention and turn off the VIMS power domain to achieve lowest power consumption in standby.
  - 10.1 Get current VIMS mode— Read the current VIMS mode.
  - 10.2 Wait if invalidate in progress...— Ensure that the VIMS mode remains the same.
  - 10.3 Disable cache RAM retention— Disable cache RAM retention.
  - 10.4 Turn off the VIMS— Set the VIMS mode to off. The cache is off and the CM3 reads
    instructions from flash.
- 11. **Setup recharge parameters** Configure safe recharge settings used when in standby. A XoscInHighPowerMode flag indicates that the high-frequency crystal oscillator is off in standby.
- 12. Make sure all writes have taken effect— Ensure all AON writes have taken effect.
- 13. **Invoke deep sleep to go to STANDBY** Put the CM3 in deep-sleep through the WFI instruction to enter standby.



#### 3.3.2 Standby Exit Sequence

```
/* 14. If didn't retain cache in standby, re-enable retention now */
if (retainCache == FALSE) {
    VIMSModeSet(VIMS BASE, modeVIMS);
    PRCMCacheRetentionEnable();
/* 15.
 * force power on of AUX to keep it on when system is not
 * sleeping; this also counts as a write to the AON interface
 * ensuring that a following sync of the AON interface will
 * force an update of all registers
 */
AONWUCAuxWakeupEvent (AONWUC AUX WAKEUP);
while(!(AONWUCPowerStatusGet() & AONWUC AUX POWER ON)) {};
/* 16. If XOSC HF was forced off above, initiate switch back */
if (xosc_hf_active == TRUE) {
    ti_sysbios_family_arm_cc26xx_Power_XOSC_HF(ENABLE);
/* 17. Restore power domain states in effect before standby */
PRCMPowerDomainOn (poweredDomains);
while (PRCMPowerDomainStatus(poweredDomains) !=
    PRCM DOMAIN POWER ON) { };
/* 18. Restore deep sleep clocks of Crypto and DMA */
if (Power getDependencyCount(PERIPH CRYPTO)) {
    PRCMPeripheralDeepSleepEnable(
        ti_sysbios_family_arm_cc26xx_Power_db[
            PERIPH CRYPTO].driverlibID);
if (Power_getDependencyCount(PERIPH_UDMA)) {
    PRCMPeripheralDeepSleepEnable(
        ti_sysbios_family_arm_cc26xx_Power_db[
            PERIPH UDMA].driverlibID);
/* 19. Make sure clock settings take effect */
PRCMLoadSet();
```

Figure 5. Standby Exit Sequence, Part 1

- 14. **If didn't retain cache in standby, re-enable retention now** Enable cache after waking up from standby if cache retention was disabled.
- 15. Force power on of AUX to keep it on when system is not sleeping; this also counts as a write to the AON interface ensuring that a following sync of the AON interface will force an update of all registers— To access the OSC\_DIG registers to configure the oscillators, force the auxiliary domain on after waking up from standby.
- 16. **If XOSC\_HF was forced off above, initiate switch back** Turn on the high-speed crystal oscillator if it was enabled before entering standby. For details on how to configure the high-speed crystal oscillator, see Section 4.5.1.
- 17. **Restore power domain states in effect before standby—** Turn on all power domains that were on before entering standby.



18. **Restore deep sleep clocks of Crypto and DMA**— Restore deep-sleep clock settings for Crypto and DMA modules as they were before entering standby.

19. Make sure clock settings take effect— Load clock settings into PRCM for them to take effect.

```
/* 20. Release request for uLDO */
PRCMMcuUldoConfigure(false);
/* 21. Set transition state to EXITING SLEEP */
Power module->state = Power EXITING SLEEP;
/* 22.
 * signal clients registered for early post-sleep notification;
 * this should be used to initialize any timing critical or IO
 * dependent hardware
status = Power notify(postEvent);
/* 23. Disable IO freeze and ensure RTC shadow value is updated */
AONIOCFreezeDisable();
SysCtrlAonSync();
/* 24. Re-enable interrupts */
CPUcpsie();
/* 25. Signal all clients registered for late post-sleep notification */
status = Power notify(postEventLate);
/* 26. Now clear the transition state before re-enabling scheduler */
Power_module->state = Power_ACTIVE;
/* 27. Re-enable Swi scheduling */
Swi restore(swiKev);
/* 28. Adjust recharge parameters */
SysCtrlAdjustRechargeAfterPowerDown();
```

Figure 6. Standby Exit Sequence, Part 2

- 20. **Release request for uLDO** Release the micro-LDO request to disable running on the micro-LDO when entering idle.
- 21. Set transition state to EXITING\_SLEEP— TI-RTOS-specific code
- 22. Signal clients registered for early post-sleep notification; this should be used to initialize any timing critical or IO dependent hardware— Signal peripheral drivers to reinitialize their state because modules without retention lose their contents. TI-RTOS-specific code. For details on which modules have retention, see *CC26xx Technical Reference Manual* (SWCU117).
- 23. **Disable IO freeze and ensure RTC shadow value is updated** Open the input and output latches. Because the peripheral drivers have been reinitialized, inputs and outputs have no glitches.
- 24. Re-enable interrupts— Re-enable interrupts. TI-RTOS-specific code
- 25. **Signal all clients registered for late post-sleep notification** The peripheral drivers do not use this notification. (TI-RTOS-specific code)
- 26. Now clear the transition state before re-enabling scheduler— TI-RTOS-specific code
- 27. Re-enable Swi scheduling— TI-RTOS-specific code



28. **Adjust recharge parameters**— Adjust the recharge settings to optimize power consumption the next time the application enters standby mode.

#### 3.4 Shutdown Mode

In shutdown mode, the CC26xx/CC13xx device shuts off except for the input and output pins. The device can wake up on any input pin (configured through the IOCFGn registers). The system completely re-boots when waking up from shutdown. You can call SysCtrlResetSourceGet() to detect that the device is booting from shutdown. For details on the TI-RTOS implementation of entering shutdown, see Figure 7.



```
/* 1. Switch to RCOSC HF and RCOSC LF */
OSCInterfaceEnable();
if (OSCClockSourceGet (OSC SRC CLK HF) != OSC RCOSC HF) {
    OSCClockSourceSet(OSC SRC CLK HF | OSC SRC CLK MF,
        OSC RCOSC HF);
    while (!OSCHfSourceReady());
    OSCHfSourceSwitch();
}
OSCInterfaceDisable();
/* 2. Make sure DMA and CRYTO clocks are off in deep-sleep */
PRCMPeripheralDeepSleepDisable(PRCM PERIPH CRYPTO);
PRCMPeripheralDeepSleepDisable(PRCM PERIPH UDMA);
PRCMLoadSet();
while(!PRCMLoadGet()){};
/* 3. Power OFF AUX and disconnect from bus */
AUXWUCPowerCtrl(AUX_WUC_POWER_OFF);
/* 4. Remove AUX force ON */
HWREG (AON WUC BASE + AON WUC O AUXCTL) &=
    ~AON WUC AUXCTL AUX FORCE ON;
/*
 * reset AON event source IDs to avoid pending events powering
 * on MCU/AUX
HWREG (AON EVENT BASE + AON EVENT O MCUWUSEL) = 0x3F3F3F3F;
HWREG (AON EVENT BASE + AON EVENT O AUXWUSEL) = 0x003F3F3F;
 * 6.
 * enable shutdown - this latches the IOs, so configuration of
 * IOCFGx registers must be done prior to this
 */
AONWUCShutDownEnable();
/* 7. Sync AON */
SysCtrlAonSync();
/* 8. Wait until AUX powered off */
while (AONWUCPowerStatusGet() & AONWUC AUX POWER ON);
/* 9. Request to power off MCU when go to deep sleep */
PRCMMcuPowerOff();
/* 10. Turn off power domains inside MCU VD (BUS, FL BUS, RFC, CPU) */
PRCMPowerDomainOff(PRCM_DOMAIN_RFCORE | PRCM_DOMAIN_SERIAL |
    PRCM DOMAIN PERIPH | PRCM DOMAIN CPU | PRCM DOMAIN VIMS);
/* 11. Deep sleep to activate shutdown */
PRCMDeepSleep();
```

Figure 7. Shutdown Enter Sequence



- 1. **Switch to RCOSC\_HF** Switch to high-speed RC oscillator.
- 2. Make sure DMA and CRYTO clocks are off before entering shutdown— Ensure the DMA and crypto deep-sleep clocks are turned off.
- 3. Power OFF AUX and disconnect from bus— Configure the auxiliary domain.
- 4. Remove AUX force ON— Request to power off the auxiliary domain.
- 5. Reset AON event source IDs to avoid pending events powering on MCU/AUX— Ensure no events from AON prevent the device from entering shutdown.
- 6. Enable shutdown this latches the IOs, so configuration of IOCFGx registers must be done prior to this— Configure shutdown mode. Because this function also latches the inputs and outputs, configure any input and output (such as configuring which inputs and outputs to wake up on) before executing this function.
- 7. Sync AON— Ensure AON configurations take effect.
- 8. Wait until AUX powered off— Ensure the auxiliary domain is off.
- 9. Request to power off MCU when go to deep sleep— Request to power off the MCU voltage domain when CM3 enters deep-sleep.
- 10. Turn off power domains inside MCU VD (BUS, FL\_BUS, RFC, CPU)— Turn off power domains inside the MCU voltage domain.
- 11. **Deep sleep to activate shutdown** Enter deep-sleep by executing WFI instruction. WFI instruction shuts down the system. Because the CM3 reboots when waking up, no instructions execute after the PRCMDeepSleep() function.

When waking up from a shutdown, the device reboots. The input and output state is retained through shutdown to avoid glitches. Software using the shutdown-power mode calls SysCtrlResetSourceGet() early in the application to check the wake-up source. If the device wakes up from a shutdown, the application restores the configuration of the input and output registers before opening to latches to avoid glitches. Write AON\_SYSCTL:SLEEPCTL[0] to 1 to unlatch the inputs and outputs.



#### 4 Implementation Considerations

This section describes important details to consider when writing software for the CC26xx/CC13xx family.

#### 4.1 Device Initializing

#### 4.1.1 Low-Level Initializing

The application must call trimDevice() in setup.c (available in the driverlib software package) after booting. This function trims the different modules on the device not completed by ROM boot code. This trimming is required for the device to operate safely. This code runs again after coming out of shutdown because the CM3 reboots. The CM3 does not reboot when coming out of standby or idle.

Figure 8. trimDevice() function in setup.c

#### NOTE

A check exists in the trimDevice() function to ensure the correct version of driverlib is on the device. If this check fails, the device spins in an infinite loop to indicate that the compiled software library is unsupported by the given device.



#### 4.1.2 TI-RTOS Initializating

For more information on the device initialization by TI-RTOS, see Figure 9.

Figure 9. TI-RTOS Initialization

- 1. **Make sure all code is compiled with the same version of driverlib** Ensure that the TI-RTOS implementation is built with the same version of driverlib as the rest of the application.
- 2. **Set standby disallow constraint pending LF clock qualifier disabling** TI-RTOS-specific code to ensure the application enters standby after the LF clock source selected in CCFG is selected and stable. Disable the LF clock qualifiers after selecting the LF clock source.



#### 4.2 Recharging in Standby

When the device is in the standby power mode, the hardware turns off the internal DC/DC converter and LDOs to save power. The device must wake up periodically to recharge the internal voltages to retain the chip state. Before entering standby, you must configure these recharge settings. For more details on these settings, see Figure 10. Because the recharge settings reside in the AON domain, the application must AON sync after writing the recharge settings to ensure they take effect before entering standby.

```
/* setup recharge parameters */
SysCtrlSetRechargeBeforePowerDown(XoscInHighPowerMode);
/* make sure all writes have taken effect */
SysCtrlAonSync();
```

Figure 10. Configure Recharge Settings Before Entering Standby

After the device wakes up from standby mode, set the recharge parameters through the call in Figure 11 to optimize the current consumption the next time the device enters standby. After waking up from standby, software must AON sync before adjusting the recharge settings to ensure the settings are correctly updated.

```
/* make sure AON registers have been updated */
SysCtrlAonSync();
/* adjust recharge parameters */
SysCtrlAdjustRechargeAfterPowerDown();
```

Figure 11. Configure Recharge Settings After Exiting Standby

#### 4.3 Operating the DC/DC Converter

The CC26xx/CC13xx device family has an on-chip DC/DC converter which enables low-power applications. The DC/DC converter is enabled by trimDevice() based on the CCFG fields in Figure 12, and has a separate enable field for operating in active and standby modes (the hardware periodically recharges in standby mode). When the device operates in external regulator mode, disable the DC/DC converter during active and standby/recharge modes.

Figure 12. CCFG Fields For Enabling the DC/DC Converter During Active and Standby Mode

Because the DC/DC converter only operates with optimum efficiency at high VDDS voltages, turn off the DC/DC converter when VDDS decreases. To configure the voltage threshold to turn off the DC/DC converter, use the CCFG field in Figure 13. Do not modify this voltage threshold.

```
#define SET_CCFG_MODE_CONF_1_ALT_DCDC_VMIN 0x8 // 2.25V
```

Figure 13. The Voltage Threshold For Turning Off the DC/DC Converter



The application uses the function in Figure 14, the threshold configured in the CCFG field, to decide when to turn off the DC/DC converter. The application calls this function at periodic intervals. This function also turns on the DC/DC converter if the voltage exceeds the threshold (for example, when the battery is recharging).

```
/* Check operating conditions, optimally choose DCDC versus GLDO */
SysCtrl DCDC VoltageConditionalControl();
```

Figure 14. The Driverlib Function That Enables and Disables the DC/DC Converter at the Given CCFG
Threshold

#### 4.4 Configuring Device for External Input Interrupts and Wakeup

#### 4.4.1 Interrupt and Wake-up from Active, Idle, and Standby

Configuring the device for external input interrupts and wakeups from active, idle, and standby power modes is a 3-step process (see PINCC26XX.c for reference).

- 1. Enable the INT EDGE DETECT interrupt to the CM3.
- Enable wakeup from standby on an input by configuring one of the four available wakeup sources in AON\_EVENT:MCUWUSEL to wake up on any PAD (0x20). (TI-RTOS uses AON\_EVENT:MCUWUSEL.WU1\_EV.)
- 3. Enable the individual DIO interrupts by configuring the IOCFGn[18:16] bits.

If multiple input and output pins are enabled for interrupt, software reads the GPIO:EVFLAGS31\_0 to decode which input pin triggered the interrupt. Write 1 to the corresponding GPIO:EVFLAGS31\_0 to clear the interrupt.

#### 4.4.2 Wakeup from Shutdown Mode

Configuring the IOCFGn[28:27] bits to configure the device to wake up from shutdown on an external input and output. The device reboots when waking up from shutdown.



#### 4.5 Oscillators

#### 4.5.1 High-Frequency Oscillators

The CC26xx/CC13xx boots with the 48-MHz high-speed RC oscillator that clocks the CM3. When using the radio, switch the main system clock to the high-speed crystal oscillator. The code in Figure 15 shows how to change to the high-speed crystal oscillator (see the functions in driverlib modules osc.h/osc.c).

```
/* 1. Set HF clock source to be XOSC_HF */
OSCHF_TurnOnXosc();
/* 2. Polling implementation of switching to XOSC_HF */
do
{
    /* 3. Perform other tasks while the XOSC_HF is starting up */
    /* ... */
}while(!OSCHF_AttemptToSwitchToXosc());
/* 4. The system clock is now XOSC_HF */
```

Figure 15. Switching from RCOSC\_HF to XOSC\_HF

**NOTE:** The high-speed crystal oscillator does not start immediately and the application can perform other tasks running on the RCOSC\_HF while the XOSC\_HF starts.

To optimize power consumption, another function gives the application an estimate of the length of the next XOSC\_HF startup. The start-up time depends on the following three factors:

- How long the XOSC HF has been off
- The operational parameters of the crystal
- The frequency of the RCOSC\_HF

The OSCHF\_GetStartupTime(uint32\_t timeUntilWakeupInMs) returns an estimate of the expected XOSC\_HF start-up time, depending on how long the XOSC\_HF has been off. For example, the application can use this information to schedule wakeups and ensure that the XOSC\_HF starts up before using the radio and transmitting a packet.

**NOTE:** You must enable the RTC for this functionality to work because the oscillator driver uses the RTC to calculate the start-up time.

You must turn off the XOSC\_HF before entering standby or shutdown. To turn off the XOSC\_HF, call OSCHF\_SwitchToRcOscTurnOffXosc().

**NOTE:** You cannot switch to the RCOSC\_HF before you have switched to the XOSC\_HF. Aborting a switch to XOSC\_HF is not supported.



#### 4.5.2 Low-Frequency Oscillators

Modify the customer configuration area to select the low-frequency clock source. The application must ensure that the LF clock source selected in CCFG is selected and stable before entering standby mode. The LF clock source on which the device is running can be read through the driverlib function OSCClockSourceGet(...). For the configuration settings in CCFG, see Figure 16.

Figure 16. LF Configuration in ccfg.c

When the device running on the selected LF clock source as specified in CCFG, you must disable the LF clock qualifier circuitry before entering standby for the first time. Set bits OSC\_DIG:CTL0[29:28] as in Figure 17.

```
/* Disable the LF clock qualifiers */
DDI16BitfieldWrite(
   AUX_DDI0_OSC_BASE,
   DDI_0_OSC_O_CTL0,
   DDI_0_OSC_CTL0_BYPASS_XOSC_LF_CLK_QUAL_M | DDI_0_OSC_CTL0_BYPASS_RCOSC_LF_CLK_QUAL_M,
   DDI_0_OSC_CTL0_BYPASS_RCOSC_LF_CLK_QUAL_S,
   0x3);
```

Figure 17. Code for Disabling LF Clock Qualifiers

If the application wants to use an external LF clock source, another MCU can apply the LF clock to any input and output pin.

- 1. Configure the chosen input and output and the RTC increment value as in Figure 18.
- 2. Apply when trimDevice() runs.

An RTC increment value of 0x800000 corresponds to a frequency of 32.768 kHz. See AON RTC:SUBSECINC for further details.

```
// DIO number if using external LF clock
#define SET_CCFG_EXT_LF_CLK_DIO 0x01
// RTC increment representing the external LF clock frequency
#define SET_CCFG_EXT_LF_CLK_RTC_INCREMENT 0x800000
```

Figure 18. Configuration When Using an External LF Clock Source

#### 4.5.3 RC Oscillator Calibration

Both the RCOSC\_HF and RCOSC\_LF frequency shift when the temperature changes and the oscillators age. Calibrate these oscillators periodically against the XOSC\_HF.

Calibrating the RCOSC\_HF gives more accurate timing when running the system off this clock and starts up the XOSC\_HF faster. Calibrating the RCOSC\_LF gives more accurate timing for the RTC when in standby. If the RCOSC\_LF is unused by the application, calibrating this oscillator is unnecessary.



The auxiliary domain contains a TDC you can use to calibrate these oscillators against the XOSC\_HF. TI-RTOS contains an implementation of calibrating both the RCOSC\_HF and RCOSC\_LF and can be a reference for those who must calibrate RC oscillators without TI-RTOS. The following implementation is in the TI-RTOS installation:

C:\ti\tirtos\_simplelink\_#\_##\_##\products\bios\_#\_##\_##\packages\ti\sysbios\family\arm\cc26xx\Pow er calibrateRCOSC.c.

#### 4.6 Auxiliary Domain

Turn on the auxiliary domain for the CM3 to access the modules in the auxiliary domain, including the OSC\_DIG registers to configure the oscillators. Power off the auxilliary domain before entering standby and shutdown. For further details, see Section 3 on entering and exiting power modes.

#### 4.6.1 Powering on the Auxiliary Domain

The auxiliary domain is forced-on through the calls in Figure 19. Until you turn on the domain, the application should not access any modules inside the auxiliary domain or OSC\_DIG. The application may complete other tasks while waiting for the auxiliary domain to power up, which takes approximately 50 µs.

```
/* force power on of AUX to keep it on when system is not
 * sleeping; this also counts as a write to the AON interface
 * ensuring that a following sync of the AON interface will
 * force an update of all registers
 */
AONWUCAuxWakeupEvent(AONWUC_AUX_WAKEUP);
while(!(AONWUCPowerStatusGet() & AONWUC_AUX_POWER_ON)) {};
```

Figure 19. Powering Up the Auxiliary Power Domain

#### 4.6.2 Powering Down the Auxiliary Domain

The CM3 must release the auxiliary force-on before entering standby and shutdown (not required when entering idle) as in Figure 20. If the sensor controller is running when AONWUCAuxWakeupEvent(...) function is called, the auxiliary domain remains on until the sensor controller idles. The system enters standby.

```
/* allow AUX to power down */
AONWUCAuxWakeupEvent(AONWUC_AUX_ALLOW_SLEEP);
/* make sure writes take effect */
SysCtrlAonSync();
```

Figure 20. Powering Down the Auxiliary Domain



#### 4.6.3 Managing the Sensor Controller and the Auxiliary Domain Power

The sensor controller power management is independent of the system power modes in Section 3. The CM3 can force on the auxiliary domain (which contains the sensor controller) to access modules in the auxiliary domain or the oscillators.

The sensor controller is either active or standby where it executes code or waits for events. When the sensor controller is standing by, it can wake up and execute code and re-enter standby independently of the system state excluding shutdown. The sensor controller may take the rest of the system out of either idle or standby by configuring AON\_EVENT:MCUWUSEL[29:24] to use the AUX\_SWEV1. When the system state is shutdown, the sensor controller is unavailable. The sensor controller studio software uses AON\_EVENT:AUXWUSEL[5:0] to wake up the sensor controller from standby using the RTC\_CH2\_DLY event.



Table 2. Sensor Controller/Auxiliary Power Management

| System State | Available Sensor Controller States                                |
|--------------|-------------------------------------------------------------------|
| Active       | Active or standby                                                 |
| Idle         | Active or standby. Sensor controller can wake system from idle.   |
| Standby      | Active or standby. Sensor controller can wake system from standby |
| Shutdown     | Not available                                                     |

#### 4.6.4 Sharing Resources Between the Sensor Controller and the CM3

You can access several resources like the OSC\_DIG, the TDC, and ADC on the CC26xx/CC13xx from both the sensor controller and the CM3. To ensure these accesses are correctly arbitrated on the bus, the CM3 should always access these modules through driverlib, which has this arbitration support built in.

If the CM3 and the sensor controller access the same resources, protect them using the auxiliary semaphore module. This module has eight semaphores reserved for protecting-shared resources in the auxiliary domain.

The convention is as follows:

- SMPH0 protects Adi/Ddi bus. This semaphore is built into CC26xxware/CC13xxware implementations.
- SMPH1 protects the TDC. The application enforces this.
- SMPH2 protects the ADC. The application enforces this.

For details on how to use the auxiliary semaphores, see the AUX SMPH registers.

#### 4.7 RTC

The RTC is clocked from the low-frequency oscillator. The RTC can generate timed events to the CM3 and wake the device from idle or standby.

The TI-RTOS implementation is available in the Timer.c source file in the TI-RTOS installation:

 $C:\ti{tirtos\_simplelink}_{\#}$ # $$ \cccenter{fisher} $$ C:\ti{tirtos\_simplelink}_{\#}$ # $$ \cccenter{fisher} $$ r.c. $$ c. $$ \cccenter{fisher} $$ C:\ti{tirtos\_simplelink}_{\#}$ # $$ \cccenter{fisher} $$ \cccenter{fish$ 

#### 4.7.1 Initializing RTC

The Timer\_start (Timer\_Object \*obj) TI-RTOS function initializes, resets the RTC, and configures channel 0 to generate interrupts to the CM3. The CM3 uses channel 0 because channel 1 is reserved for the RF core and channel 2 is reserved for the sensor controller.



#### 4.7.2 Configuring RTC Compare Events

The Timer\_periodicStub(UArg arg) function clears a pending RTC interrupt, sets a new compare value, and calls the appropriate clock tick function. Be careful when configuring a new compare value if the new value is near, because clearing an RTC event takes precedence over setting an event.

Implementation suggestion 1 (perform the AON sync after clearing the event):

- 1. Clear a pending event (AONRTCEventClear(AON\_RTC\_CH0)).
- 2. AON sync (SysCtrlAonSync()) to ensure the event is cleared and no longer active.
- 3. Set a new compare value. If the new compare value is now or up to 1 second in the past, the event triggers immediately.

Implementation suggestion 2 (TI-RTOS implementation):

- Clear a pending event (AONRTCEventClear(AON\_RTC\_CH0)).
- 2. Set a new compare value adding a margin of four RTC edges (64 µs) to the compare value to ensure the event clears before the new compare value generates an interrupt.

#### 4.8 Debugging Through Power Modes

When debugging software that enters and exits power modes with an emulator attached, the timing is slightly different than when running without an emulator attached. In active mode, the CPU power domain is always on, and the timing is the same. In idle, standby, and shutdown, the CPU power domain remains on when an emulator is attached to keep the debug session active. The wakeup time from these power modes is shorter than if an emulator is not attached to the target.

#### 4.9 Using Peripherals

Peripheral drivers are part of the TI-RTOS installation. The CC26xx/CC13xx implementation is at the following path: C:\ti\tirtos\_simplelink\_#\_## ###\packages\ti\drivers

For generic peripherals such as UART, SPI, and I<sup>2</sup>C, TI-RTOS provides a common API for easy migration between different TI architectures.

The CC26xx/CC13xx specific drivers are documented in Doxygen format. This format explains how to use the drivers. The CC26xx power-management document is distributed in the TI-RTOS installation. *Power Management for CC26xx SimpleLink Wireless MCU User's Guide* (SPRUI20) also explains how the TI-RTOS drivers interact with the power management part of the kernel.

The following rules apply when using any peripheral:

- Only use a peripheral in active or idle power modes. In standby and shutdown, you must turn off the
  peripheral and its power domain.
- Before accessing a peripheral, do the following:
  - 1. Turn on the power domain that contains the peripheral.
  - 2. Enable the run clock for the peripheral through the PRCM registers.
- Reconfigure a peripheral before opening the input and output latches when exiting standby to avoid input and output glitches.

#### 5 References

- TI-RTOS download path: www.ti.com/tool/ti-rtos
- Power Management for CC26xx SimpleLink Wireless MCU User's Guide (SPRUI20):
   C:/ti/tirtos\_simplelink\_#\_##\_###\_docs/Power\_Management\_CC26xx.pdf
- CC26xx Technical Reference Manual (SWCU117)

#### IMPORTANT NOTICE

Texas Instruments Incorporated and its subsidiaries (TI) reserve the right to make corrections, enhancements, improvements and other changes to its semiconductor products and services per JESD46, latest issue, and to discontinue any product or service per JESD48, latest issue. Buyers should obtain the latest relevant information before placing orders and should verify that such information is current and complete. All semiconductor products (also referred to herein as "components") are sold subject to TI's terms and conditions of sale supplied at the time of order acknowledgment.

TI warrants performance of its components to the specifications applicable at the time of sale, in accordance with the warranty in TI's terms and conditions of sale of semiconductor products. Testing and other quality control techniques are used to the extent TI deems necessary to support this warranty. Except where mandated by applicable law, testing of all parameters of each component is not necessarily performed.

TI assumes no liability for applications assistance or the design of Buyers' products. Buyers are responsible for their products and applications using TI components. To minimize the risks associated with Buyers' products and applications, Buyers should provide adequate design and operating safeguards.

TI does not warrant or represent that any license, either express or implied, is granted under any patent right, copyright, mask work right, or other intellectual property right relating to any combination, machine, or process in which TI components or services are used. Information published by TI regarding third-party products or services does not constitute a license to use such products or services or a warranty or endorsement thereof. Use of such information may require a license from a third party under the patents or other intellectual property of the third party, or a license from TI under the patents or other intellectual property of TI.

Reproduction of significant portions of TI information in TI data books or data sheets is permissible only if reproduction is without alteration and is accompanied by all associated warranties, conditions, limitations, and notices. TI is not responsible or liable for such altered documentation. Information of third parties may be subject to additional restrictions.

Resale of TI components or services with statements different from or beyond the parameters stated by TI for that component or service voids all express and any implied warranties for the associated TI component or service and is an unfair and deceptive business practice. TI is not responsible or liable for any such statements.

Buyer acknowledges and agrees that it is solely responsible for compliance with all legal, regulatory and safety-related requirements concerning its products, and any use of TI components in its applications, notwithstanding any applications-related information or support that may be provided by TI. Buyer represents and agrees that it has all the necessary expertise to create and implement safeguards which anticipate dangerous consequences of failures, monitor failures and their consequences, lessen the likelihood of failures that might cause harm and take appropriate remedial actions. Buyer will fully indemnify TI and its representatives against any damages arising out of the use of any TI components in safety-critical applications.

In some cases, TI components may be promoted specifically to facilitate safety-related applications. With such components, TI's goal is to help enable customers to design and create their own end-product solutions that meet applicable functional safety standards and requirements. Nonetheless, such components are subject to these terms.

No TI components are authorized for use in FDA Class III (or similar life-critical medical equipment) unless authorized officers of the parties have executed a special agreement specifically governing such use.

Only those TI components which TI has specifically designated as military grade or "enhanced plastic" are designed and intended for use in military/aerospace applications or environments. Buyer acknowledges and agrees that any military or aerospace use of TI components which have *not* been so designated is solely at the Buyer's risk, and that Buyer is solely responsible for compliance with all legal and regulatory requirements in connection with such use.

TI has specifically designated certain components as meeting ISO/TS16949 requirements, mainly for automotive use. In any case of use of non-designated products, TI will not be responsible for any failure to meet ISO/TS16949.

#### Products Applications

logic.ti.com

Audio www.ti.com/audio Automotive and Transportation www.ti.com/automotive amplifier.ti.com Communications and Telecom www.ti.com/communications **Amplifiers Data Converters** dataconverter.ti.com Computers and Peripherals www.ti.com/computers **DLP® Products** www.dlp.com Consumer Electronics www.ti.com/consumer-apps DSP dsp.ti.com **Energy and Lighting** www.ti.com/energy Clocks and Timers www.ti.com/clocks Industrial www.ti.com/industrial Interface interface.ti.com Medical www.ti.com/medical

Power Mgmt power.ti.com Space, Avionics and Defense www.ti.com/space-avionics-defense

Security

www.ti.com/security

Microcontrollers <u>microcontroller.ti.com</u> Video and Imaging <u>www.ti.com/video</u>

RFID www.ti-rfid.com

Logic

OMAP Applications Processors www.ti.com/omap TI E2E Community e2e.ti.com

Wireless Connectivity <u>www.ti.com/wirelessconnectivity</u>