# **Table of Contents** | Objectives | 3 | |-------------------------------------------------------------------|-------------| | Hardware | 3 | | Software | 3 | | Lab description | 3 | | Power operating | 4 | | Power rails | 4 | | LDO_ENABLE | 4 | | External power supplies using Power Management IC (PMIC) | 4 | | Power configuration | 5 | | Active mode | 5 | | Sleep mode | 6 | | Deep Sleep mode | 6 | | Deep Power Down mode | 6 | | Full Deep Power Down mode | 6 | | Wake up source | 6 | | Timers function during deep sleep and deep power down | 6 | | Peripherals to wake from deep sleep | 7 | | Wake up process | 8 | | RAM partitions and power consumption | 8 | | Core operation in Active Mode | 9 | | Maximum core operation frequencies and minimum core voltage in Ac | tive Mode 9 | | Body Bias | 9 | | Power Lab 1 – Cortex M33 Operating frequency at 0.7V VDDCore | 10 | | MCUXpresso SDK power_manager example | 10 | | PCA9420 and powerlib API | 12 | | Core Frequency | 14 | | MCUXpresso SDK power_manager example | 15 | | Serial Terminal | 16 | | Build the project | 17 | | Run the project | 18 | | Power Lab 2 – Wake from deep sleep using RTC, Pin Interrupt and USART | 21 | |-------------------------------------------------------------------------|----| | RTC wake (high resolution counter) as wake up source | 21 | | Pin Interrupt as wake up source | 22 | | USART as another wake up source | 23 | | Understanding deep sleep parameters that passes to deep sleep power API | 24 | | Build the project | 25 | | Run the project | | | Deep sleep wake by RTC | 27 | | Deep sleep wake by Pin | 28 | | Deep sleep wake by USART | 29 | | Power Lab 3 – Using RTC to wake from deep power down | 30 | | Build the project | 30 | | Run the project | | | Deep power down wake by deep sleep | 32 | | Deep power down wake by reset | 35 | | Measuring nower consumption on VDDCore IP29 | 35 | # **Objectives** In this lab, you will learn: - Utilize the Powerlib for PMIC - Low power modes - Operating modes ## Hardware - NXP MIMXRT685-EVK Rev E - Micro-USB cable - Digital Multimeter - Jumper wire (Female-to-female) - One pin header (Male-to-male) ## Software - Download the latest MCUXpresso IDE version 11.4.0 and above at (<a href="https://mcuxpresso.nxp.com">https://mcuxpresso.nxp.com</a>) - Download the latest SDK 2.10.0 and above for EVK-MIMXRT685 at (<a href="https://mcuxpresso.nxp.com">https://mcuxpresso.nxp.com</a>) - Power management labs - Serial Terminal Console such as Putty, minicom, TeraTerm, etc. # Lab description This lab shows user how to use the RT685 powerlib API functions to achieve desired operating mode and low power modes. # Power operating #### Power rails There are four power rails: - 1.8V Always On VDD\_AO1V8 - 3.3V for IOs USB, and System VDDIO0, VDDIO1, VDDIO2, USB1\_VDD3V3, VDDA\_BIAS - 1.8V for IOS and System VDDIO0, VDDIO1, VDDIO2, VDD1V8, VDDA\_ADC1V8, VDDA\_BIAS - VDDCORE. Only RTC wakeup timers, LDO\_ENABLE, PMC\_PMIC (interrupt and mode pins) and Reset Pin are on VDD\_AO1V8 "Always On" domain when voltage (1.71 – 1.89V) is supplied. #### LDO ENABLE LDO\_ENABLE pin is used to select whether VDDCore is using internal LDO or from external. When LDO\_ENALBE pin is pulled high, VDDCore will be supplied from internal LDO and the LDO is powered from the VDD1V8. When LDO\_ENABLE pin is pulled low, VDDCore will be supplied from external supply. # External power supplies using Power Management IC (PMIC) Using external PMIC provides flexibility to configure the power supply rails as application needs. For example, uSDHC may change the VDDIO rail from 3.3V to 1.8V, or deep sleep power rail configuration. RT685 has a dedicated I<sup>2</sup>C pins to communicate with PMIC, this allows different power configuration for low power modes or different operating mode at certain core voltage. RT685 allows PMIC to wake CM33 from PMIC\_IRQ interrupt pin. The two PMIC\_MODE pins allows CM33 to enter pre-configured PMIC power configuration without going through setup every time via I<sup>2</sup>C. Figure 1 Power rails, LDO\_ENABLE and PMIC connections # Power configuration There are four type of power modes in RT6xx: Active, Sleep, Deep Sleep, Deep Power Down and Full Deep Power Down. The external PMIC referencing the PMIC\_MODE pins from RT685 to provide appropriate power configurations. Table 1 PMIC Mode Pins and Low Power modes | PMIC_MODE[1:0] | 00 | 01 | 10 | 11 | |-----------------|----------------|------------|------------|------------| | Low Power Modes | Active / Sleep | Deep Sleep | Deep Power | Full Deep | | | | | Down | Power Down | #### Active mode The power consumption in Active mode is determined by PSCCTL, PDRUNCFG, clock sources, peripheral clocks and/or CPU operating modes. Figure 2 PSCCTL Figure 3 Power Control RUNCFG or SLEEPCFG #### Sleep mode Clock to the CM33 is gated, execution of instruction is suspended until interrupt occurs. Memories, clocks, and peripherals can be operation, and there are determined by PSCCTL, PDRUNCFG, clock sources, peripheral clocks. Any interrupt can wake up the CM33. # Deep Sleep mode main\_clk and CM33 will be gated to be in Deep Sleep. Memories, certain clocks and certain peripherals can be active are determined by PDSLEEPCFG. #### Deep Power Down mode VDDCore, memories, clocks and peripherals are shutoff except RTC "Always on" Domain. RTC wake-up timers, reset or PMIC interrupt can be used to wake up the system. #### Full Deep Power Down mode VDDCore, VDD1V8, 3V3 power rail, memories, clocks and peripherals are shutoff except RTC on Always on Domain. RTC wake timers, reset or PMIC interrupt can be used to wake up the system. # Wake up source There are many peripherals that can be served as the wake-up function for the deep sleep low power mode. (Refer to STARTEN0 and STARTEN1 of SYSCTL0 in RT685 User Manual) ## Timers function during deep sleep and deep power down Table 2 shows timers' comparison in deep sleep, it also shows which clock source it requires to stay active. RTC is the only timer active during deep power down or full deep power down. Table 2 Timers comparison in low power modes | <del>-</del> | | | | | | | ee | p | SI | | | | | | Deep Power<br>Down | |--------------------------|------------------------------------|-------------------------------------------|----------|----------|----------|----------|-----------|------|-----|------------|---------|------|-------|-------|----------------------------------------------| | Timer | Counter<br>Resolution | Read back<br>counter<br>(Elapsed<br>time) | main_clk | main_pll | aux0_pll | aux1_pll | audio_pll | holk | APB | 48/60m_irc | 16m_irc | mclk | lposc | 32khz | | | Watchdog Timer (WDT) | 24-bit | Yes | ✓ | | | | | | | | | | ✓ | | No | | Micro-tick Timer (uTick) | 31-bit | No | ✓ | | | | | | | | | | ✓ | | No | | Multi-Rate Timer (MRT) | 24-bit | Yes | | | | | | | ✓ | | | | | | No | | Counter Timer (Ctimer) | 32-bit | Yes | ✓ | ✓ | ✓ | ✓ | ✓ | | | ✓ | | | | | No | | SCTimer | 16- or 32-<br>bit | Yes | ✓ | | | | ✓ | | | ✓ | ✓ | ✓ | | | No | | Real_Time Clock (RTC) | 15-<br>(subsec) or<br>32-bit (sec) | | | | | | | | | | | | | ✓ | RTC Timer is on "Always<br>ON" power domain. | | OS Event Timer (OSTimer) | 64-bit | Yes | | | | | | ✓ | | | | | ✓ | ✓ | No | - lposc has ±10% accuracy 16m\_irc has ±3% accuracy 3. 48/60m\_irc has ±1% accuracy 3. 248/60m\_irc has ±1% accuracy 4. 32khz accuracy depends on crystal setup High frequency crystal that input to main\_pll usually is between 10 50ppm # Peripherals to wake from deep sleep The following peripherals can be used as a wake up source for deep sleep: DMA, GPIOs, Flexcomm (SPI, I<sup>2</sup>C, I<sup>2</sup>S, USART), ADC, DMIC, Hypervisor, Secureviolation, HW VAD, RNG, MU, FlexSPI, SDIO, I<sup>3</sup>C, USB, PUF, PowerQuad, Casper, PMIC, and SHA. #### Wake up process T<sub>amb</sub> = 25 °C; using IRC as the system clock. | Symbol | Parameter | Conditions | | Min | Typ[1] | Max | Unit | |-------------------|-----------------|--------------------------------------------------|------------|-----|--------|-----|------| | t <sub>wake</sub> | wake-up | from sleep mode, 250 MHz | [2][3] | - | 1.5 | - | μS | | | time | from sleep mode, 12 MHz | [2][3] | - | 6.2 | - | μS | | t <sub>wake</sub> | wake-up<br>time | from deep-sleep mode | [2][3] | - | 637 | - | μS | | t <sub>wake</sub> | wake-up<br>time | from deep power-down mode using RESETN. | [4] | - | 5.6 | - | ms | | | | from deep power-down mode using PMIC_IRQ_N. | [4] | - | 7 | - | ms | | t <sub>wake</sub> | wake-up<br>time | from full deep power-down mode using RESETN. | <u>[4]</u> | - | 5.6 | - | ms | | | | from full deep power-down mode using PMIC_IRQ_N. | <u>[4]</u> | - | 7.6 | - | ms | Typical ratings are not guaranteed. The values listed are at room temperature (25 °C), nominal supply voltages Figure 4 Wake up time from low power modes # RAM partitions and power consumption - Running advanced-while1 in different partition (2 to 29) - Typical, 1.1V, 25, NBB, 198 MHz(PLL) - All SRAM array/periphery are ON (set in PDRUNCFG2 and PDRUNCFG3) and one partition clocked using AHB\_SRAM\_ACCESS\_DISABLE register. <sup>[2]</sup> The wake-up time measured is the time between when a GPIO input pin is triggered to wake the device up from the low power modes and from when a GPIO output pin is set in the interrupt service routine (ISR) wake-up handler. <sup>[3]</sup> IRC disabled, all peripherals off. PLL disabled. <sup>[4]</sup> Wake up from deep power-down causes the part to go through entire reset process. The wake-up time measured is the time between when the Wake-Up pin is triggered to wake the device up and when a GPIO output pin is set in the reset handler. # Core operation in Active Mode ## Maximum core operation frequencies and minimum core voltage in Active Mode Some power consumption can be achieved by lowing the core voltage and core frequency. Below are the table showing the maximum operation frequencies and minimum voltage. The CPU frequencies show below must have SYSCPUAHBCLKDIV set to 0 (divided by 1). Table 3 Maximum Core frequency and Core Voltage | Maximum Core Frequency | Maximum Core Frequency | Minimum VDD Core | |------------------------|------------------------|------------------| | (-20 °C to +70 °C) | (0 °C to +70 °C) | Voltage | | 65 MHz | 75 MHz | 0.7V | | 140 MHz | 155 MHz | 0.8V | | 210 MHz | 220 MHz | 0.9V | | 270 MHz | 275 MHz | 1.0V | | 300 MHz | 300 MHz | 1.13V | # **Body Bias** CMOS transistors usually have three terminals – a source, gate and drain, it is also common to have a fourth terminal to the body or substrate. The threshold voltage can be affected by voltage source and voltage body. RT685 has three type of body bias: Forward Body Bias (FBB), Reverse Body Bias (RBB) and Normal Body Bias (NBB). Table 4 Body Bias | Body Bias | Description | |-----------|---------------------------------------------------------------------------------------------------------------------------| | FBB | Lower the threshold voltage and allows the device to turn on quickly for high performance, but has higher current leakage | | RBB | Increase the threshold voltage and allows the device to turn on slowly, and it reduces current leakage | | NBB | Source voltage and body voltage are matching | # Power Lab 1 – Cortex M33 Operating frequency at 0.7V VDDCore MCUXpresso SDK power manager example 1. Open the MCUXpresso IDE 11.1.1 or later. Figure 5 MCUXpresso IDE 2. Creating MCUXpresso new workspace. Figure 6 workspace Create a project name and click Launch to continue. 3. Skip this step if SDK 2.7.0 and above is installed. Drag and drop downloaded MCUXpresso SDK to Installed SDKs panel at the bottom of MCUXpresso IDE. Figure 7 Installed SDK 4. Import project. Select and click Import project(s) from file system... link at the bottom left corner panel of IDE. Figure 8 Import project 5. Import project from file system. ${\sf Click}^{{\sf Browse...}} \ {\sf to} \ {\sf select} \ {\sf power\_manager.zip} \ {\sf project.} \ {\sf Select} \ {\sf \_{\tt Next>}} \ {\sf to} \ {\sf go} \ {\sf to} \ {\sf next} \ {\sf step.}$ Figure 9 Board selection 6. Select project to complete the project import. Make sure evkmimxrt685\_power\_manager (evkmimxrt685\_power\_manager/) is selected, then press to complete the import. Figure 10 Select project # PCA9420 and powerlib API 7. SW1\_OUT of PCA9420 and VDDCore VDDCore voltage is connected to SW1\_OUT of PCA9420. Current SW1\_OUT is programmed to output at 1.00V. Figure 11 PCA9420 and VDDCore 8. Understanding PCA9420 MODECFG register and using powerlib API There are 6-bit settings for SW1\_OUT in MODECFG\_0\_0 registers (MODECFG\_0\_0, address 22h). Table 43. SW1 output voltage for Mode Setting 0 000000=0.500V 001110=0.850V Ship mode enable/disable in mode setting 0 0: Device is NOT set in ship mode 000001=0.525V 001111=0.875V 1: Device is set in ship mode 000010=0.550V 010000=0.900V MODESEL0/MODESEL1 Control Selection in mode setting 0: 0: mode control by internal 1°C register bits, MODE0\_12C and/or MODE1\_12C only, signal applied on external MODESEL0/MODESEL1 000011=0.575V 010001=0 925V 000100=0 600V 010010=0.950V 000101=0.625V 010011=0.975V 00001=1.32 000110=0.650V 010100=1.000V 00010=1.35 010101=1.025 [1-bit MTP to set default value] 001000=0.700V 010110=1 050V 00100=1.400 SW1 OUT 0 SW1 output voltage for mode setting 0 (see below 001001=0.725V 010111=1 075V 00101=1 43 [Note: The default value for SW1\_OUT\_0[5:0] is set at 1.00V, but it should be MTP programmable.] 001010=0.750V 011000=1.100V 00110= 001100=0.800V 001101=0.825V 111110=1.5\ Table 5 PCA9420 MODECFG register The BOARD\_SetPmicVoltageForFreq() power API in pmic\_support.c setups desired VDDCore voltage without user provides value in above table. Simply passing Core and DSP frequency (Table 2), the power API will assign appropriate voltage for the VDDCore. ``` void BOARD_SetPmicVoltageForFreq(power_part_temp_range temp_range, uint32_t main_clk_freq, uint32_t dsp_main_clk_freq) power_part_temp_range = { kPartTemp_0C_P70C = 0U or kPartTemp_N20C_P70C = 1U } main_clk_freq or dsp_main_clk_freq range up to 600,000,000 ``` (NOTE: Do NOT use PCA9420\_WriteModeConfigs() to write value over 011010b!!! This will cause permanent damage to the core.) 9. PCA9420 comes with voltage comparator on each rail (LDO1\_OUT, LDO2\_OUT, SW1\_OUT and SW2\_OUT), it compares the actual output voltage against 90% and 110% of its target value. When power-good is enabled, the voltage comparator reports "power-good" status if the nominal voltage is within 90% to 110%. When power-good is disabled, the nominal voltage is set outside the range of 90% to 110%. Current power\_manager example has power-good disabled, when calling <code>BOARD\_SetPmicvoltageForFreq()</code> to set VDDCore at 0.70 V. Actual measurement on VDDCore is approx. 0.74 V. Change the <code>kPCA9420\_PgoodDisabled</code> to <code>kPCA9420\_PgoodEnabled</code> in <code>BOARD\_InitPmic()</code>. This will put the VDDCore close to 0.70 V. #### Core Frequency #### 10. Changing Core frequency Before calling BOARD\_BOOTCIOCKRUN(), the default 48 MHz (FFRO or 48/60m\_irC) CPU frequency is derived from 40/60m\_irc (MAINCLKSELA = 3, MAINCLKSELB = 0, and SYSCPUAHBCLKDIV = 0, see green highlight in Figure 12). Code executes after BOARD\_BOOTCIOCKRUN() sets the CPU to run at 250 MHz from main\_pll\_clk (MAINCLKSELB = 2, and SYSCPUAHBCLKDIV = 1, see orange highlight in Figure 12). The current value from VCO to Main PLL is 528 MHz, the PFD output frequency formula is FPFDn = FSYSPLL\_OUT \* (18 / PFDn). In BOARD\_BOOTCIOCKRUN(), PFD0 is set to 19. main\_clk is 528,000,000 \* (18 / 19) = 500,210,526 Hz. MAINPLLCLKDIV is 0 (divided by 1). However, SYSCPUAHBCLKDIV is divided by 2; therefore, the CPU clock is 500,210,526 / 2 = 250,105,263 Hz. Figure 12 CPU Clock Source Overview We will be focused more on the clock setup at main\_clk (after MAINCLKSELA and MAINCLKSELB). To setup CPU to run less than 65 MHz, the closer frequency it can output is 60 MHz from 48/60m\_IRC. If the CPU clock source from the same clock source tries to change, the CPU clock must switch to another clock source before lowering the CPU clock. For example, the CPU is now using FFRO 48 MHz as clock source, and will be changed to FFRO 60 MHz. The CPU clock must be on another clock source such as SFRO or PLL before the change can be taken place. In this lab example, the FFRO is set to run at 60 MHz from 48 MHz after the CPU is set to use the clock source from main\_clk, then change the CPU clock source to 16m\_irc (SFRO see blue highlight in Figure 12). The CPU frequency is now running at 8 MHz, the SYSCPUAHBCLKDIV is still divided by 2. The flash clock needs to adjust not to exceed core frequency. The flash is using main\_pll\_clk, so 500 MHz divided by 5 will generate 100 MHz flash clock. Switch the flash clock to FFRO with divided by 10 before switch the CPU clock source, this put the flash clock at 6 MHz. Set the SYSCPUAHBCLKDIV to 0 (divided by 1), the CPU frequency is at 16 MHz. Call BOARD\_SetPmicVoltageForFreq() to set VDDCore to 0.70 V. Attach CPU clock source from SFRO to FFRO, the CPU is now running at 60 MHz. Adjust the flash clock again to run from FFRO at 30 MHz. ``` CLOCK_EnableFfroClk(kCLOCK_Ffro60M); BOARD_SetFlexspiClock(3U, 10U); CLOCK_AttachClk(kSFRO_to_MAIN_CLK); /* Let CPU run on ffro before configure SYS PLL. */ CLOCK_SetClkDiv(kCLOCK_DivSysCpuAhbClk, 1U); /* Set SYSCPUAHBCLKDIV divider to value 1 */ BOARD_SetPmicVoltageForFreq(kPartTemp_0C_P70C, 60000000, 0); CLOCK_AttachClk(kFFRO_to_MAIN_CLK); /* Let CPU run on ffro before configure SYS PLL. */ BOARD_SetFlexspiClock(3U, 2U); SystemCoreClock = CLOCK_GetFreq(kCLOCK_CoreSysClk); ``` When using internal LDO, replace <code>BOARD\_SetPmicVoltageForFreq()</code> with <code>POWER\_SetLdoVoltageForFreq()</code>, the parameters are the same as PMIC. Remove **JP29** and change **JP22** to **1-2** as shown in Figure 13 VDDCore and LDO\_Enable locationFigure 13. NOTE: **JP12 1-2 MUST** be shunt when using internal LDO, make sure SW2\_OUT 1.8V is supplied to VDDIO1 for the internal core voltage. **DO NOT** use internal LDO if **JP12 2-3** is shunt. ## MCUXpresso SDK power\_manager example 11. VDDCore and LDO\_ENABLE location | Take an unused jumper as indicated in the image below and | | |--------------------------------------------------------------|--| | place in on 2-3 of JP22. Place multimeter to JP29 to measure | | | VDDCore or place amp meter to JP29 (remove jumper) to | | NOTE: **JP12 1-2 MUST** be shunt when using internal LDO, make sure SW2\_OUT 1.8V is supplied to VDDIO1 for the internal core voltage. **DO NOT** use internal LDO if **JP12 2-3** is shunt. Figure 15 JP12 VDDI01 power source selection 12. Power the board Connects USB micro cable from PC to J5 (LPCLink as indicated in Figure 13). #### Serial Terminal www.nxp.com 13. Open Serial Terminal program such as TeraTerm as shown below. Select serial port listed as Jlink CDC UART Port, and press to occurrence. Figure 16 Select LPC-LINKII serial port Setup the serial port settings, and press ok to continue. Figure 17 Serial port setup ## Build the project 14. Build the example Under the Quickstart Panel at the bottom left, click the Suild under the Build your project. Figure 18 Quickstart Panel - Build At the middle bottom of IDE, the console will show the project built successfully. Figure 19 CDT Build Console ## Run the project 15. Program the application Make sure the SW5 (ISPs) is ON, OFF, ON from left to right. Under the Quickstart Panel at the bottom left, click the \* Debug under the Debug your project. Figure 20 Quickstart Panel - Debug 16. A window will pop up to select debugger connects to the EVK. Select → J-Link LPCXpresso V2 and press → to continue. PUBLIC www.nxp.com Figure 21 Selecting debugger When it is successfully programmed, the program count will be halted at main() as shown in the source window. ``` 🖻 power_manager.c 🖂 🔝 board.h h fsl_clock.h c (gdb[45].pr... 150 /* Init board hardware. */ pca9420_modecfg_t pca9420ModeCfg[4]; 151 uint32_t i; 152 153 /* BE CAUTIOUS TO SET CORRECT VOLTAGE RANGE ACCORDING TO YOUR BOARD/APPLICATION. HARM TO THE SILICON. */ power_pad_vrange_t vrange = {.Vdde0Range = kPadVol_171_198, 157 .Vdde1Range = kPadVol_171_198, /* SD0 voltage is switchable, but in power_manager .Vdde2Range = kPadVol_300_360}; 158 159 160 BOARD InitPins(); 161 162 BOARD BootClockRUN(); 163 BOARD_InitDebugConsole(); CLOCK_EnableFfroClk(kCLOCK_Ffro60M); 166 /* PMIC PCA9420 */ 167 ``` Figure 22 Program counter stops at main() You can continue to run the program by pressing (resume) . Or terminate the debug program by pressing , then press the reset button on the board (see Figure 13). 17. Either continue to run the program from debug or from reset, message will be shown as below. Figure 23 Serial output 18. Press 5 on the Terminal to change the VDDCore to 0.70 V, or press 6 to change the VDDCore to 1.15 V. Place a multimeter on JP29 to measure the voltage change when pressing number 5 or 6 key on the serial terminal. PUBLIC www.nxp.com # Power Lab 2 — Wake from deep sleep using RTC, Pin Interrupt and USART ## RTC wake (high resolution counter) as wake up source 1. Initialize RTC module and enable the RTC wake in STARTEN Enable the RTC output of the RTC oscillator 32,768 Hz. Failure to do so, the RTC counter will not function. After initialize the RTC by calling RTC\_Init(), calls RTC\_StartTimer() to enable the RTC. There are two type of wake-up features in RTC: WAKE and ALARM. WAKE is using 1 khz counter (milli seconds) up to 65.5s (0xFFFF) and ALARM is using RTC counter (seconds) up to 100+ years (0xFFFF\_FFFF). WAKE interrupts are enabled in RTC by calling RTC\_EnableInterrupts(). STARTEN and IRQ will be set when calling EnableDeepSleepIRQ(). #### 2. RTC IRO Handle It is essential to have RTC IRQ to clear the flag after woke up from deep sleep. The flag needs to be cleared in order to avoid deadlock. ``` void RTC_IRQHandler(void) { if (RTC_GetStatusFlags(RTC) & kRTC_WakeupFlag) { /* Clear wake flag */ RTC_ClearStatusFlags(RTC, kRTC_WakeupFlag); } if (RTC_GetStatusFlags(RTC) & kRTC_AlarmFlag) { /* Clear alarm flag */ RTC_ClearStatusFlags(RTC, kRTC_AlarmFlag); } } ``` ``` } /* Add for ARM errata 838869, affects Cortex-M4, Cortex-M4F Store immediate overlapping exception return operation might vector to incorrect interrupt */ #if defined __CORTEX_M && (__CORTEX_M == 4U) __DSB(); #endif } ``` 3. Provides a counter value to RTC to wake from deep sleep. A write to this register will immediately start count down sequence in ms. In the example, 10000 (ms) is passed to RTC\_SetWakeupCount(), the RT685 will wake from deep sleep after 10s. Note: Other timers that described in Timers function during deep sleep and deep power down use similar approach – setup timer IRQ Handle, setup timer clock source with the clock source excludes from deep sleep, set STARTEN and interrupt for the timer, and set time out on the timer before entering deep sleep. ``` static void UTickCallback(void) { } CLOCK_AttachClk(kLPOSC_to_UTICK_CLK); UTICK_Init(UTICK0); UTICK_SetTick(UTICK0, kUTICK_Onetime, 1000000UL - 1, UTickCallback); EnableDeepSleepIRQ(UTICK0_IRQn); POWER_EnterDeepSleep(APP_EXCLUDE_FROM_DEEPSLEEP); ``` #### Pin Interrupt as wake up source GPIO pins can be used as wake up source for deep sleep. Two type of interrupts for GPIO – Pin Interrupt (PINT) or GPIO interrupt. There are a total of 8 Pin Interrupts and 2 GPIO group interrupts in RT685. Current example is using Pin interrupt. During the deep sleep, user can press SW1 user button to wake from deep sleep. ``` static void APP_InitWakeupPin(void) ``` ``` gpio pin config t gpioPinConfigStruct; /* Set SW pin as GPIO input. */ gpioPinConfigStruct.pinDirection = kGPIO_DigitalInput; GPIO_PinInit(APP_USER_WAKEUP_KEY_GPIO, APP_USER_WAKEUP_KEY_PORT, APP_USER_WAKEUP_KEY_PIN, &gpioPinConfigStruct); /* Configure the Input Mux block and connect the trigger source to PinInt channle. */ INPUTMUX Init(INPUTMUX); INPUTMUX_AttachSignal(INPUTMUX, kPINT_PinInt0, APP_USER_WAKEUP_KEY_INPUTMUX_SEL); /* Using channel 0. * INPUTMUX Deinit(INPUTMUX); /* Turnoff clock to inputmux to save power. Clock is only needed to make changes */ /* Configure the interrupt for SW pin. */ PINT_Init(PINT); PINT_PinInterruptConfig(PINT, kPINT_PinInt0, kPINT_PinIntEnableFallEdge, pint_intr_callback); PINT EnableCallback(PINT); /* Enable callbacks for PINT */ EnableDeepSleepIRQ(PIN INTO IRQn); ``` ## USART as another wake up source There are two methods in deep sleep mode for USART. One is using 32 khz (RTC or lp\_32k) runs in async mode, and another is sync mode that requires additional pin for clock to provide from master. In this example, before RT685 goes to deep sleep, enabled the 32 khz clock source in USARTn->CFG. The WAKECLK32KHZSEL selection is assigned USART to use either RTC 32 khz or lp\_32k (derived from 1m\_osc then divided by 32, 1m\_osc must be excluded from deep sleep). This example uses RTC since it is turned on and its accuracy is better than lp\_32k. Next step is to store the BRG and OSR value for baudrate restore before switching to 9600 baudrate. Enable USART Rx Interrupt(s), STARTEN and Flexcomm IRQ before going deep sleep. Any data receive from USART Rx will wake up from deep sleep. Disable the 32k clock and quickly turn off the IRQ to prevent next Rx data to trigger interrupt since the current console output does not use interrupt for serial console. Restore the baud rate from 9600 to 115200. ``` void FLEXCOMM0_IRQHandler(void) { uint8 t data; /* If new data arrived. */ if ((kUSART_RXFifoNotEmptyFlag | kUSART_RXError) & USART_GetStatusFlags(USART0)) { data = USART_ReadByte(USART0); } } ``` ``` /* Add for ARM errata 838869, affects Cortex-M4, Cortex-M4F Store immediate overlapping exception return operation might vector to incorrect interrupt */ #if defined __CORTEX_M && (__CORTEX_M == 4U) DSB(); #endif int main(void) uint32_t i, brg, osr; rtc_datetime_t date; case kPmu_Deep_Sleep: /* Enter deep sleep mode. */ #if POWER_DOWN_PLL_BEFORE_DEEP_SLEEP /* Disable Pll before enter deep sleep mode */ BOARD_DisablePll(); #endif USARTO->CFG |= USART CFG MODE32K MASK; CLKCTL0->WAKECLK32KHZSEL = 0; brg = USART0->BRG; osr = USARTO->OSR; USART0 \rightarrow BRG = 0; USART0 -> OSR = 13; USART_EnableInterrupts(USART0, kUSART_RxLevelInterruptEnable | kUSART_RxErrorInterruptEnable); EnableDeepSleepIRQ(FLEXCOMM0_IRQn); RTC_SetWakeupCount(RTC, 10000); POWER_EnterDeepSleep(APP_EXCLUDE_FROM_DEEPSLEEP); USARTO->CFG &= ~USART_CFG_MODE32K_MASK; DisableIRQ(FLEXCOMM0_IRQn); USARTO->BRG = brg; USARTO->OSR = osr; #if POWER_DOWN_PLL_BEFORE_DEEP_SLEEP /* Restore Pll before enter deep sleep mode */ BOARD_RestorePll(); #endif break: ``` #### Understanding deep sleep parameters that passes to deep sleep power API The power API to enter deep sleep is POWER\_EnterDeepSleep(), the API passes value of array. Parameter 0: RUN/SLEEPCFG Parameter 1: Peripherals RAM Parameter 2: Array RAM partitions Parameter 3: Periphery RAM partitions When the bit is set in the parameter, it will be excluded from deep sleep. For example, FFRO needs to be active during deep sleep, set bit 16 of parameter 0. (SYSCTLO->PDSLEEPCFGO in User Manual). In the example, parameter 1 has FLEXSPI RAM excluded, parameter 2 has 21 array partitions excluded. ``` #define APP_DEEPSLEEP_RUNCFG0 (SYSCTL0_PDSLEEPCFG0_RBB_PD_MASK | SYSCTL0_PDSLEEPCFG0_FFR0_PD_MASK) #define APP_DEEPSLEEP_RAM_APD 0xFFFFF8U #define APP_DEEPSLEEP_RAM_PPD 0x0U #define APP_EXCLUDE_FROM_DEEPSLEEP \ (((const uint32_t[]){APP_DEEPSLEEP_RUNCFG0, \ (SYSCTL0_PDSLEEPCFG1_FLEXSPI_SRAM_APD_MASK | SYSCTL0_PDSLEEPCFG1_FLEXSPI_SRAM_PPD_MASK), \ APP_DEEPSLEEP_RAM_APD, APP_DEEPSLEEP_RAM_PPD})) ``` # Build the project 4. Build the example Under the Quickstart Panel at the bottom left, click the Suild under the Build your project. Figure 24 Quickstart Panel - Build At the middle bottom of IDE, the console will show the project built successfully. Figure 25 CDT Build Console #### Run the project 5. Program the application Make sure the SW5 (ISPs) is ON, OFF, ON from left to right. Under the Quickstart Panel at the bottom left, click the \* Debug under the Debug your project. Figure 26 Quickstart Panel - Debug 6. A window will pop up to select debugger connects to the EVK. Select ☐ J-Link LPCXpresso V2 and press OK to continue. Figure 27 Selecting debugger When it is successfully programmed, the program count will be halted at main() in the source window as shown below. PUBLIC www.nxp.com Figure 28 Program counter stops at main() Terminate the debug program by pressing [ ] , then press the reset button on the board (see Figure 13). NOTE: Do not use debugger when the code is going to perform low power modes. The debugger will shut off during low power modes, this will cause the IDE not response. #### Deep sleep wake by RTC 7. After reset, message will be shown as below. Press 2 on the serial terminal window to enter deep sleep. Figure 29 Deep sleep 8. After wake has elapsed, it will back to the selections. ``` File Edit Setup Control Window Help Power Manager Deno. The "user key" is: Sti Select an option 1. Sleep mode 2. Deep Sleep mode 3. Deep power down mode 4. Full deep power down mode 5. Change core voltage to 0.780 Entering Deep Sleep IPress the user key to wakeupl ... Wakeup. Select an option 1. Sleep mode 2. Deep Sleep mode 3. Deep power down mode 4. Full deep power down mode 5. Change core voltage to 1.150 Let in option 1. Sleep mode 2. Deep Sleep mode 3. Deep power down mode 4. Full deep power down mode 5. Change core voltage to 0.780 6. Change core voltage to 1.150 ``` Figure 30 Deep sleep by RTC # Deep sleep wake by Pin 9. Press 2 again to enter deep sleep, this time using SW1 User button to wake from deep sleep prior to RTC wake (10s). Figure 31 SW1 location 10. After wake, it will back to the selections. ``` Eile Edit Setup Control Window Help 3. Deep power down mode 4. Full deep power down mode 5. Change core voltage to 0.780 6. Change core voltage to 1.150 Entering Deep Sleep IPress the user key to wakeupl ... Wakeup. Select an option 1. Sleep mode 2. Deep Sleep mode 3. Deep power down mode 4. Full deep power down mode 5. Change core voltage to 0.780 6. Change core voltage to 1.150 Entering Deep Sleep IPress the user key to wakeupl ... Entering Deep Sleep IPress the user key to wakeupl ... Entering Deep Sleep IPress the user key to wakeupl ... Pin event occurs Wakeup. Select an option 1. Sleep mode 2. Deep Sleep mode 3. Deep power down mode 4. Full deep power down mode 4. Full deep power down mode 5. Change core voltage to 0.780 6. Change core voltage to 0.780 6. Change core voltage to 0.780 6. Change core voltage to 1.150 ``` Figure 32 Deep sleep by Pin www.nxp.com # Deep sleep wake by USART - 11. Press 2 again to enter deep sleep, this time enter any key on the serial terminal window to wake from deep sleep prior to RTC wake (10s). - 12. After wake, it will back to the selections. ``` M COM10-Tera Term VT File Edit Setup Control Window Help 3. Deep power down mode 4. Full deep power down mode 5. Change core voltage to 0.780 6. Change core voltage to 1.150 Entering Deep Sleep [Press the user key to wakeup] ... Pin event occurs Wakeup. Select an option 1. Sleep mode 2. Deep Sleep mode 2. Deep Sleep mode 4. Full deep power down mode 5. Change core voltage to 0.780 6. Change core voltage to 1.150 Entering Deep Sleep [Press the user key to wakeup] ... Wakeup. Select an option 1. Sleep mode 2. Deep Sleep mode 3. Deep power down mode 4. Full deep power down mode 5. Change core voltage to 1.150 Change core voltage to 0.780 6. Change core voltage to 0.780 6. Change core voltage to 0.780 6. Change core voltage to 0.780 6. Change core voltage to 0.780 ``` Figure 33 Deep sleep wake by USART # Power Lab 3 – Using RTC to wake from deep power down 1. Configure the RTC alarm to wake from deep power down. Append RTC\_CTRL\_ALARMDPD\_EN\_MASK to RTC\_EnableInterrupts(). ``` RTC_StartTimer(RTC); /* enable RTC interrupt */ RTC_EnableInterrupts(RTC, RTC_CTRL_WAKEDPD_EN_MASK | RTC_CTRL_ALARMDPD_EN_MASK); /* Enable RTC wake */ EnableDeepSleepIRQ(RTC_IRQn); ``` 2. Setup RTC time and alarm Setup the date and convert to seconds using RTC\_SetDatetime(). Add 20s to the date.second and pass it to RTC\_SetAlarm(). Or, direct register write using RTC->MATCH = RTC->COUNT + 20; ``` int main(void) /* Init board hardware. */ pca9420_modecfg_t pca9420ModeCfg[4]; uint32_t i; rtc_datetime_t date; case kPmu Deep PowerDown: /* Enter deep power down mode. */ PRINTF( "Press any key to confirm to enter the deep power down mode and wakeup the device by " "reset.\r\n\r\n"); GETCHAR(); date.\underline{year} = 2020; date.month = 4; date.day = 6; date.hour = 9; date.minute = 0; date.second = 0; RTC_SetDatetime(RTC, &date); date.second += 20; RTC_SetAlarm(RTC, &date); POWER_EnterDeepPowerDown(APP_EXCLUDE_FROM_DEEP_POWERDOWN); ``` ## Build the project 3. Build the example Under the Quickstart Panel at the bottom left, click the Suild under the Build your project. Figure 34 Quickstart Panel - Build At the middle bottom of IDE, the console will show the project built successfully. Figure 35 CDT Build Console ## Run the project 4. Program the application Make sure the SW5 (ISPs) is ON, OFF, ON from left to right. Under the Quickstart Panel at the bottom left, click the \* Debug under the Debug your project. Figure 36 Quickstart Panel - Debug 5. A window will pop up to select debugger connects to the EVK. Select ☐ J-Link LPCXpresso V2 and press of to continue. Figure 37 Selecting debugger When it is successfully programmed, the program count will be halted at main() in the source window as shown below. Figure 38 Program counter stops at main() Terminate the debug program by pressing [ ], then press the reset button on the board (see Figure 13). #### Deep power down wake by deep sleep 6. After reset, selection message will show. Press 3 in the serial terminal to enter deep power down. ``` File Edit Setup Control Window Help Power Manager Deno. The "user key" is: SMI Select an option 1. Sleep mode 2. Deep Sleep mode 2. Deep youer down mode 4. Full deep power down mode 5. Change core voltage to 0.7800 6. Change core voltage to 1.150 Entering Deep Powerdown (Reset to wakeup) ... Press any key to confirm to enter the deep power down mode and wakeup the device by reset. ``` Figure 39 Deep sleep 7. Manually reset the flash while in deep power down. Use a female to female jumper wire, one end connects to GND (see Figure 40), one end connects to male to male header. Figure 40 GND point The reason is when RT685 wakes up by RTC from deep power down, the flash is still in previous mode (Quad or Octal). ROM will not be able to access flash content correctly; therefore, RT685 is not able to execute code from flash. There is an GPIO pin connects to nRESET\_OSPI of the reset pin on the SPI flash. User can configure the P2\_12 to be asserted in the OTP. This lab chooses not to use OTP to configure the P2\_12;incorrectly programming the OTP will cause unpredictable behavior. Figure 41 Flash reset pin 8. Locate TP34 or TP33 near the standard SD slot. Figure 42 TP34 - 9. Press any key in the serial terminal to confirm to enter the deep power down mode. - 10. Quickly use the female-to-female jumper wire with male header to touch TP33 or TP34, and untouch it. - 11. When RT685 wake up by RTC and boot up, it will back to the selection. ``` COM10-Tera Term VT File Edit Setup Control Window Help Power Manager Demo. The "user key" is: SW1 Select an option 1. Sleep mode 2. Deep Sleep mode 3. Deep power down mode 4. Full deep power down mode 5. Change core voltage to 0.700 6. Change core voltage to 1.15U Entering Deep Powerdown IReset to wakeupl ... Press any key to confirm to enter the deep power down mode and wakeup the device by reset. Board wake up from deep or full deep power down mode. Power Manager Demo. The "user key" is: SW1 Select an option 1. Sleep mode 2. Deep Sleep mode 3. Deep power down mode 4. Full deep power down mode 5. Change core voltage to 0.700 6. Change core voltage to 1.15U ``` Figure 43 Wake and boot up ## Deep power down wake by reset - 12. Press 3 to enter deep power down. - 13. Press any key to confirm in the serial terminal to enter the deep power down mode. - 14. Press reset to wake from deep power down. Figure 44 Reset button # Measuring power consumption on VDDCore JP29 Different multi-meter has different burden voltage when using the current measurement (mA/A and mA/uA). High end current measurement equipment provides wider range of burden voltage that will not draw current from the VDDCore. Handheld such as Fluke 83 is 0.03V in A, 1.8mV in mA and 100uV in uA, and the resistance between the input terminals is 0.03 ohm for A, 1.8 ohm for mA, and 100 ohm for uA. Assuming 40mA VDDCore is requirement in active mode, 40mA \* 1.8mV = 74mV. The VDDCore is dropped below 1.0V (1.0V – 74mV = 926mV). The solution is to raise the VDDCore voltage from 1.0V to 1.1V before changing the core frequency from FFRO to PLL. Enable SFRO after BOARD\_InitPins() and before ``` BOARD BOOTClockRUN(). It is required for PMIC configuration before BOARD BOOTClockRUN(). void BOARD_ConfigPMICModes(pca9420_modecfg_t *cfg, uint32_t num) assert(cfg); /* Configuration PMIC mode to align with power lib like below: * 0b00 run mode, no special. * 0b01 deep sleep mode, vddcore 0.7V. * 0b10 deep powerdown mode, vddcore off. * 0b11 full deep powerdown mode vdd1v8 a full deep powerdown mode vdd1v8 and vddcore off. */ cfg[0].sw1OutVolt = kPCA9420_Sw1OutVolt1V100; } int main(void) BOARD_InitPins(); /* Configure SFRO clock */ POWER_DisablePD(kPDRUNCFG_PD_SFRO); /* Power on SFRO (16MHz) */ CLOCK_EnableSfroClk(); /* Wait until SFRO stable */ /* PMIC PCA9420 */ BOARD InitPmic(); for (i = 0; i < ARRAY_SIZE(pca9420ModeCfg); i++)</pre> PCA9420_GetDefaultModeConfig(&pca9420ModeCfg[i]); BOARD_ConfigPMICModes(pca9420ModeCfg, ARRAY_SIZE(pca9420ModeCfg)); PCA9420_WriteModeConfigs(&pca9420Handle, kPCA9420_Mode0, &pca9420ModeCfg[0], ARRAY SIZE(pca9420ModeCfg)); BOARD BootClockRUN(); BOARD_InitDebugConsole(); CLOCK_EnableFfroClk(kCLOCK_Ffro60M); POWER_SetPadVolRange(&vrange); } ```