### AN13530 LPC553x/LPC55S3x Low-power Modes and Wake-up Time Rev. 2 — 4 September 2023

**Application note** 

### **Document Information**

| Information | Content                                                                                                                                                                                               |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Keywords    | AN13530, LPC55S3x/LPC553x, low-power mode, wake-up time                                                                                                                                               |
| Abstract    | This application note introduces various low-power modes of the LPC553x/LPC55S3x series, the software APIs details to enter in the low-power mode, and a wake-up source used for each low-power mode. |



### 1 Introduction

LPC553x/LPC55S3x is an Arm Cortex-M33-based microcontroller for embedded applications. The family offers a rich set of peripherals with a feature of low power consumption. For more details on the LPC553x/LPC55S3x MCU, see LPC5500 Cortex-M33.

This application note introduces various low-power modes of the LPC553x/LPC55S3x series, the software APIs details to enter in the low-power mode, and a wake-up source used for each low-power mode. This document also describes the hardware and software environment as well as a procedure to measure supply current and wake-up time for each low-power mode.

This application note explains:

- All low-power modes in LPC553x/LPC55S3x
- · Entry and wake-up implementations for low-power modes
- Steps to measure current and wake-up time for each low-power mode

### 2 Low-power modes

LPC553x/LPC55S3x supports four reduced power modes: Sleep, Deep sleep, Power down, and Deep power down.

These modes can be activated by power library APIs from the SDK software package.

Power usage is controlled by settings in the register within the SYSCON block, regulator settings controlled via the power library APIs, and the operating mode of the CPU. The following modes are supported in order from maximum to minimum power consumption.

- Section 2.1
- <u>Section 2.2</u>
- Section 2.3
- <u>Section 2.4</u>
- <u>Section 2.5</u>

### 2.1 Active mode

The device is in the Active mode after any chip-level reset. The following reset values determine the default dynamic power consumption:

- Power Management Controller registers, PDRUNCFG0/1 (For details, see "Chapter 36 Power Management Controller" in *LPC553x Reference Manual* (document <u>LPC553xRM</u>))
- SYSCON registers AHBCLKCTRL0/1/2/3 and AUTOCLKGATEOVERRIDE (For details, see "Chapter 7 SYSCON" in *LPC553x Reference Manual* (document <u>LPC553xRM</u>)

In the Active mode, by default, the core logic supply source is the Low Drop-Out Regulator (LDO\_CORE). The user can switch to the DC-DC converter to gain better dynamic power efficiency via a set of functions provided in the power library: POWER SetCorePowerSource(...) and POWER GetCorePowerSource(...).

In the Active mode, it is possible to individually control all the SRAM instances power mode via the function POWER SRAMPowerModeControl(...) provided in the power library.

In the Active mode, when the device is in operation, it is possible to reduce the power consumption of the various peripherals that are not used (temporarily or permanently) by:

- Switching off their functional clock; see SYSCON registers AHBCLKCTRL0/1/2/3
- Activating the "automatic clock gating" feature; see SYSCON register AUTOCLKGATEOVERRIDE

• Switching off the entire module when possible; see Power Management Controller registers PDRUNCFG0 and PDRUNCFG1

The Active mode consumes the highest power among all power modes. All low-power modes can be invoked from this power mode.

### 2.2 Sleep mode

Sleep mode saves some power by stopping the Cortex-M33 CPU execution without affecting peripherals or requiring significant wake-up time. The clock to the CPU is shut off. Peripherals and memories are active and operational. CPU is stopped and execution of instructions is suspended until either a reset or an interrupt occurs.

Peripheral functions, if selected to be clocked in the AHBCLKCTRL registers, continue operation during Sleep mode and can generate interrupts to cause the processor to resume execution. Sleep mode only eliminates dynamic power used by the processor itself, memory systems and related controllers, and internal buses. The processor state and registers, peripheral registers, and internal SRAM values are maintained.

### 2.3 Deep sleep mode

In the Deep sleep mode, the full device remains powered, but flash and ROM are shut down, with the cost of a longer wake-up time compared to the Sleep mode. The system clock to the CPU is disabled as in the Sleep mode. Analog blocks are powered down by default but can be selected to keep running through the power API if needed as wake-up sources. The main clock and all peripheral clocks are disabled.

The Deep sleep mode eliminates power used by the analog peripherals and all dynamic power used by the CPU, its memory systems and related controllers, and internal buses. The CPU state and registers, peripheral registers, and internal SRAM values are maintained, and the logic levels of the pins remain static. All SRAM instances that are not configured to enter in the SRAM Deep sleep low-power mode keep the state they are in before entering the Deep sleep. This means that if a SRAM was in the Active state before entering the Deep sleep, it stays in the Active state during the Deep sleep and therefore it consumes more power.

Selected peripherals, such as GPIO group interrupts (GINT), USB Full speed, Flexcomms (SPI, I2C, USART), Widowed-Watchdog Timer, RTC, standard Counter/Timers can be left running in the Deep sleep mode. The oscillators, such as FRO1M, FRO32K, XTAL32K but also FRO192M (which delivers the 12 MHz and 96 MHz clocks), can also be left running.

Some peripherals can have DMA service during the Deep sleep mode without waking up the entire device.

### 2.4 Power-down mode

The Power-down mode turns off nearly all on-chip power consumption by:

- Eliminating power used by almost all analog modules and
- Shutting down the DC-DC and LDO\_CORE

This eliminates almost all digital peripherals power, with the cost of a longer wake-up time compared to the Deep sleep mode. FRO192M is disabled. The flash memory is also disabled. The clock to the CPU and peripherals is shut down and if not configured, the peripherals in the power domains PD\_SYSTEM and PD\_AO receive no internal clocks. All SRAM instances can be configured to maintain their internal states and all registers lose their internal states except those located in the power domains PD\_SYSTEM and PD\_AO. Any SRAM instance that is not configured to maintain its internal state loses it.

The Cortex-M33 CPU state and some critical peripherals, such as security controller, PRINCE, and analog controller are retained and the logic levels of the pins remain static. GPIO group interrupts (GINTO and GINT1), selected serial peripherals in Flexcomm3 (SPI, I2C, USART), RTC, OS event timers, and analog comparator can be left running to wake up the device.

When a wake-up event occurs, the Cortex-M33 CPU code execution resumes. It is the responsibility of the customer application to reconfigure all modules in the power domain core PD\_CORE (whose states have not been retained, for example all Flexcomm except Flexcomm3, SDMA, Power Quad, DMIC).

### 2.5 Deep Power-down mode

Deep Power-down mode shuts down virtually all on-chip power consumption, but requires a longer wake-up time (compared to the Power-down mode). For maximal power savings, the entire power domains PD\_CORE (CPU, DSP, Flexcomms, SDMA) and PD\_SYSTEM (Reset, Clocks, SYSCON, IOCON) are shut down. Only the Always-on power domain PD\_AO (PMU, PMC, RTC, and OS Event Timer) stays powered. Clocks are shut off to the entire chip device except for the RTC and the OS Event Timer, if they are needed. On wake-up, the device reboots.

During the Deep Power-down mode, the contents of some SRAM can be retained (software configured via the POWER\_EnterDeepPowerDown() low-power API) but registers (other than those in PMC, RTC, and OS Event Timer) are not retained. All functional pins are tri-stated in the Deep Power-down mode, except the 5 wake-up pins and the RESETN pin.

### 2.6 Low-power mode summary

The following table summarizes the power state of the different power domains according to the power modes.

| Power mode         | PD_CORE | PD_<br>SYSTEM | PD_AON | PD_MEM_0                    | PD_MEM_1                    | PD_MEM_2                    |
|--------------------|---------|---------------|--------|-----------------------------|-----------------------------|-----------------------------|
| Active             | ON      | ON            | ON     | ON                          | ON                          | ON                          |
| Sleep              | ON      | ON            | ON     | ON                          | ON                          | ON                          |
| Deep sleep         | ON      | ON            | ON     | Configurable <sup>[1]</sup> | Configurable <sup>[2]</sup> | Configurable <sup>[3]</sup> |
| Power down         | OFF     | ON            | ON     | Configurable                | Configurable                | Configurable                |
| Deep power<br>down | OFF     | OFF           | ON     | Configurable                | Configurable                | Configurable                |

Table 1. Power modes vs Power domains

[1] Depending on whether the RAM\_01 Deep sleep power mode (data retention) is required by the user via the relevant Power API function, this power domain is ON or OFF.

[2] Depending on whether the Deep sleep power mode (data retention) is required for one SRAM instance in this power domain by the user via the relevant Power API function, this power domain is ON or OFF.

[3] Depending on whether the RAM\_00 Deep sleep power mode (data retention) is required by the user via the relevant Power API function, this power domain is ON or OFF.

The following table summarizes the power state of the different peripherals according to the power modes.

| Table 2. Peripherals reduced power mod |
|----------------------------------------|
|----------------------------------------|

| Peripherals |                                     | De                                                    | Device low-power modes |                     |                                |
|-------------|-------------------------------------|-------------------------------------------------------|------------------------|---------------------|--------------------------------|
| Name        | Description                         | Sleep mode                                            | Deep sleep<br>mode     | Power-down<br>mode  | Deep<br>Power-<br>down<br>mode |
| DCDC        | Bulk DC-DC converter                | Same state as in Active mode                          | OFF                    | OFF                 | OFF                            |
| BIAS        | Analog references                   | ON                                                    | ON                     | Software configured | OFF                            |
| BODCORE     | Core logic supply brownout detector | Same state as in Active mode                          | Software configured    | OFF                 | OFF                            |
| AN13530     | All info                            | rmation provided in this document is subject to legal | disclaimers.           | © 2023 N            | XP B.V. All rights reser       |

### Table 2. Peripherals reduced power modes...continued

| Pt.          | eripherals                                                     | De                           | vice low-power      | modes               |                                |
|--------------|----------------------------------------------------------------|------------------------------|---------------------|---------------------|--------------------------------|
| Name         | Description                                                    | Sleep mode                   | Deep sleep<br>mode  | Power-down<br>mode  | Deep<br>Power-<br>down<br>mode |
| BODVDDMAIN   | VDD_MAIN supply<br>brownout detector                           | Same state as in Active mode | Software configured | OFF                 | OFF                            |
| FRO1M        | 1 MHz free running oscillator                                  | ON                           | Software configured | Software configured | Software configured            |
| FRO192M      | High-speed free running oscillator                             | ON                           | Software configured | OFF                 | OFF                            |
| FRO32K       | 32 kHz free running<br>oscillator                              | Same state as in Active mode | Software configured | Software configured | Software configured            |
| XTAL32K      | 32 kHz crystal oscillator                                      | Same state as in Active mode | Software configured | Software configured | Software configured            |
| XTALHF       | High frequency crystal oscillator                              | Same state as in Active mode | Software configured | OFF                 | OFF                            |
| PLL0         | Phase-locked loop<br>module 0                                  | Same state as in Active mode | Software configured | OFF                 | OFF                            |
| PLL1         | Phase-locked loop<br>module 1                                  | Same state as in Active mode | Software configured | OFF                 | OFF                            |
| USBFSPHY     | USB full speed physical interface                              | Same state as in Active mode | Software configured | OFF                 | OFF                            |
| COMP         | Analog comparator                                              | Same state as in Active mode | Software configured | Software configured | OFF                            |
| LDOEFUSEPROG | eFUSE programming low drop-out regulator                       | Same state as in Active mode | Software configured | OFF                 | OFF                            |
| LDOXTALHF    | High frequency crystal<br>oscillator<br>Low drop-out regulator | Same state as in Active mode | Software configured | OFF                 | OFF                            |
| LDOFLASHNV   | Non-volatile flash macro<br>low<br>Drop-out regulator          | ON                           | OFF                 | OFF                 | OFF                            |
| PLL0_SSCG    | PLL0 spread spectrum<br>clock<br>Generator                     | Same state as in Active mode | Software configured | OFF                 | OFF                            |
| HSCMP0       | High-speed comparator 0                                        | Same state as in Active mode | Software configured | OFF                 | OFF                            |
| HSCMP1       | High-speed comparator 1                                        | Same state as in Active mode | Software configured | OFF                 | OFF                            |
| HSCMP2       | High-speed comparator 2                                        | Same state as in Active mode | Software configured | OFF                 | OFF                            |
| OPAMP0       | Operational amplifier 0                                        | Same state as in Active mode | Software configured | OFF                 | OFF                            |

| Peripherals |                                      | Device low-power modes       |                     |                     |                                |
|-------------|--------------------------------------|------------------------------|---------------------|---------------------|--------------------------------|
| Name        | Description                          | Sleep mode                   | Deep sleep<br>mode  | Power-down<br>mode  | Deep<br>Power-<br>down<br>mode |
| OPAMP1      | Operational amplifier 1              | Same state as in Active mode | Software configured | OFF                 | OFF                            |
| OPAMP2      | Operational amplifier 2              | Same state as in Active mode | Software configured | OFF                 | OFF                            |
| VREF        | ADCs/DACs analog<br>reference module | Same state as in Active mode | Software configured | Software configured | OFF                            |
| CMPBIAS     | High-speed comparators biasing       | Same state as in Active mode | Software configured | OFF                 | OFF                            |
| HSCMP0_DAC  | HSCMP0 (internal) DAC                | Same state as in Active mode | Software configured | OFF                 | OFF                            |
| HSCMP1_DAC  | HSCMP1 (internal) DAC                | Same state as in Active mode | Software configured | OFF                 | OFF                            |
| HSCMP2_DAC  | HSCMP2 (internal) DAC                | Same state as in Active mode | Software configured | OFF                 | OFF                            |
| DAC0        | Digital-to-analog converter<br>0     | Same state as in Active mode | Software configured | OFF                 | OFF                            |
| DAC1        | Digital-to-analog converter<br>1     | Same state as in Active mode | Software configured | OFF                 | OFF                            |
| DAC2        | Digital-to-analog converter<br>2     | Same state as in Active mode | Software configured | OFF                 | OFF                            |
| STOP_DAC0   | DAC0 Stop mode                       | Same state as in Active mode | Software configured | OFF                 | OFF                            |
| STOP_DAC1   | DAC1 Stop mode                       | Same state as in Active mode | Software configured | OFF                 | OFF                            |
| STOP_DAC2   | DAC2 Stop mode                       | Same state as in Active mode | Software configured | OFF                 | OFF                            |

### Table 2. Peripherals reduced power modes...continued

### 3 Entering Low-power Modes and Waking up

Power usage is controlled by settings in the register within the SYSCON block, regulator settings controlled by the Power APIs, and the operating mode of the CPU. This application note describes how to enter and wake up from various low-power modes.

### 3.1 Power control API

The power control APIs provide the functions to configure the system for expected performance requirements. The following table lists the power APIs used in the application.

### Table 3. Power API ROM calls

| Function prototype                                                                                                                                                         | API description                                                                                                                                                                                               |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <pre>void POWER_EnterSleep(void);</pre>                                                                                                                                    | The <code>POWER_EnterSleep()</code> API puts the device in the Sleep low-power mode; only the activity of the Arm Cortex-M33 is stopped.                                                                      |
| <pre>void POWER_EnterDeepSleep(uint32_t exclude_<br/>from_pd[2], uint32_t sram_retention_ctrl,<br/>uint32_t wakeup_interrupts[4], uint32_t<br/>hardware_wake_ctrl);</pre>  | The POWER_EnterDeepSleep() API configures the Deep<br>sleep low-power mode. It controls which peripherals are<br>powered up and the SRAM instances low-power mode<br>during Deep sleep.                       |
| <pre>void POWER_EnterPowerDown(uint32_t exclude_<br/>from_pd[1], uint32_t sram_retention_ctrl,<br/>uint32_t wakeup_interrupts[2], uint32_t cpu_<br/>retention_addr);</pre> | The POWER_EnterPowerDown API configures the power<br>down low-power mode. It controls which peripherals are<br>powered up and which SRAM instances are in retention<br>state during power down.               |
| <pre>void POWER_EnterDeepPowerDown(uint32_t exclude_from_pd[1], uint32_t sram_retention_ ctrl, uint32_t wakeup_interrupts[2], uint32_ t wakeup_io_ctrl);</pre>             | The POWER_EnterDeepPowerDown API configures the<br>Deep power down low-power mode. It controls which<br>peripherals are powered up and which SRAM instances are<br>in retention state during Deep power down. |

### 3.1.1 POWER\_EnterSleep

The <code>POWER\_EnterSleep()</code> API puts the device in the Sleep low-power mode; only the activity of the Arm Cortex-M33 is stopped.

The device wakes up from the Sleep mode after:

- any interrupt enabled in the Cortex-M33 Nested Vector Interrupt Controller (NVIC) arrives at the processor
- any chip reset occurs (power-on reset, brownout detector reset, pin reset, and so on)

### Table 4. POWER\_EnterSleep

| Routine            | API description                                |
|--------------------|------------------------------------------------|
| Function Prototype | <pre>void POWER_EnterSleep(void);</pre>        |
| Input Parameter    | None                                           |
| Result             | None                                           |
| Description        | Configures and enters in Sleep low-power mode. |

### 3.1.2 POWER\_EnterDeepSleep

The POWER\_EnterDeepSleep() API configures the Deep sleep low-power mode. It allows controlling which peripherals are powered up and the SRAM instances low-power mode during Deep sleep. It defines which peripheral interrupts can be a wake-up source during Deep sleep.

The POWER\_EnterDeepSleep API switches the CPU and System Bus clock to 12 MHz. It is the responsibility of the user to reconfigure the CPU and System Bus clock after the function returns.

| Routine          | API Description                                                                                                                                                        |  |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|                  | <pre>void POWER_EnterDeepSleep(uint32_t exclude_from_pd[2], uint32_t sram_<br/>retention_ctrl, uint32_t wakeup_interrupts[4], uint32_t hardware_wake_<br/>ctrl);</pre> |  |
| Input Parameters |                                                                                                                                                                        |  |

### Table 5. POWER\_EnterDeepSleep

| Routine                         | API Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|---------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| exclude_from_pd[2]              | Defines which analog peripherals shall not be powered down. It is a 2 x 32 bit-vector, with each bit of the vector corresponding to one module. The definition of the vector is given in <u>Table 6</u> and <u>Table 7</u> , and is aligned with the power_pd_bit_t type definition. For each bit field of the vector:<br>• 0: Module is powered down during Deep sleep.                                                                                                                                                                                                                       |
|                                 | 1: Module is running during Deep sleep.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| <pre>sram_retention_ ctrl</pre> | Defines which SRAM instances shall be put in the SRAM Deep sleep low-power mode during<br>Deep sleep. SRAM instances in the SRAM Deep sleep low-power mode do not lose their<br>content, but they cannot be involved in any DMA transfer during Deep sleep. SRAM instances<br>that are not required to be put in the SRAM Deep sleep low-power mode during Deep sleep<br>keep the state they were in before calling the API, that is:                                                                                                                                                          |
|                                 | • If the SRAM instance was in Active mode, it stays in the Active mode during Deep sleep and after wake-up from Deep sleep. Such SRAM instance can be involved in DMA transfer during Deep sleep.                                                                                                                                                                                                                                                                                                                                                                                              |
|                                 | • If the SRAM instance was in Deep sleep mode, it stays in the SRAM Deep sleep low-power mode during Deep sleep and after wake-up from Deep sleep. Such SRAM instance cannot be involved in DMA transfer during Deep sleep.                                                                                                                                                                                                                                                                                                                                                                    |
|                                 | • If the SRAM instance was in Shutdown mode, it stays in the SRAM Shutdown low-power mode during Deep sleep and after wake-up from Deep sleep. Such SRAM instance cannot be involved in DMA transfer during Deep sleep.                                                                                                                                                                                                                                                                                                                                                                        |
|                                 | The sram_retention_ctrl parameter is a 32-bit vector, with each bit of the vector corresponding to one SRAM instance. The definition of the vector is given in <u>Table 8</u> and is aligned with the power_sram_bit_t type definition. For each bit field of the vector:                                                                                                                                                                                                                                                                                                                      |
|                                 | <ul> <li>0: During Deep sleep, the SRAM instance keeps the state it had before entering Deep sleep.</li> <li>1: During Deep sleep, the SRAM instance is in the SRAM Deep sleep low-power mode (content preserved).</li> </ul>                                                                                                                                                                                                                                                                                                                                                                  |
|                                 | <b>Note:</b> When SDMA transfers are expected to occur during Deep sleep, make sure that the SRAM instances in which the SDMA descriptors and the Peripheral's data are stored are in Active mode during Deep sleep.                                                                                                                                                                                                                                                                                                                                                                           |
| wakeup_interrupts[4]            | Defines which peripheral interrupts can be a wake-up source during Deep sleep. It is a 4 x 32-bit vector, with each bit inside the vector corresponding to one interrupt source. The definition of the vector is given in <u>Table 9</u> , <u>Table 10</u> , <u>Table 11</u> , <u>Table 12</u> and is aligned with the low-power modes wake-up sources (#define WAKEUP_*) #defines definitions. For each bit field of the vector:<br>• 0: The associated peripheral cannot be a wake-up source during Deep sleep.<br>• 1: The associated peripheral can be a wake-up source during Deep sleep. |
| hardware_wake_ctrl              | Provides the possibility for all Flexcomm, High-Speed SPI, all DAC and DMIC to have DMA service during Deep sleep without waking up an entire device. The detailed mapping of the parameter is given in <u>Table 13</u> and is aligned with the definition of #define LOWPOWER_HWWAKE                                                                                                                                                                                                                                                                                                          |
| Result                          | None                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Description                     | Controls which peripherals are powered up and the SRAM instances low-power mode during Deep sleep. Defines which peripheral interrupts can be a wake-up source during Deep sleep.                                                                                                                                                                                                                                                                                                                                                                                                              |

### Table 5. POWER\_EnterDeepSleep...continued

### Table 6. Parameter exclude\_from\_pd[0] definition (1st vector)

| Bit | Symbol  | Description | Value                                                |
|-----|---------|-------------|------------------------------------------------------|
| 1:0 | -       | Reserved    | Must be set to 0                                     |
| 2   | BODCORE | - 5 11 5    | <ul><li>0: Powered down</li><li>1: Running</li></ul> |

AN13530 Application note © 2023 NXP B.V. All rights reserved.

| Bit   | Symbol       | Description                                              | Value                                                |
|-------|--------------|----------------------------------------------------------|------------------------------------------------------|
| 3     | BODVDDMAIN   | VDD_MAIN supply brown-out detector                       | <ul><li>0: Powered down</li><li>1: Running</li></ul> |
| 4     | FRO1M        | 1 MHz free running oscillator                            | <ul><li>0: Powered down</li><li>1: Running</li></ul> |
| 5     | FRO192M      | High-speed free running oscillator                       | <ul><li>0: Powered down</li><li>1: Running</li></ul> |
| 6     | FRO32K       | 32 kHz free running oscillator                           | <ul><li>0: Powered down</li><li>1: Running</li></ul> |
| 7     | XTAL32K      | 32 kHz crystal oscillator                                | <ul><li>0: Powered down</li><li>1: Running</li></ul> |
| 8     | XTALHF       | High-frequency crystal oscillator                        | <ul><li>0: Powered down</li><li>1: Running</li></ul> |
| 9     | PLL0         | Phase-locked loop module 0                               | 0: Powered down     1: Running                       |
| 10    | PLL1         | Phase-locked loop module 1                               | 0: Powered down     1: Running                       |
| 11    | USBFSPHY     | USB full speed physical interface                        | 0: Powered down     1: Running                       |
| 12    | -            | Reserved                                                 | Must be set to 0                                     |
| 13    | COMP         |                                                          | 0: Powered down     1: Running                       |
| 17:14 | -            | Reserved                                                 | Must be set to 0                                     |
| 18    | LDOEFUSEPROG | eFUSE programming low drop-out regulator                 | 0: Powered down     1: Running                       |
| 19    | -            | Reserved                                                 | Must be set to 0                                     |
| 20    | LDOXTALHF    | High-frequency crystal oscillator low drop-out regulator | <ul><li>0: Powered down</li><li>1: Running</li></ul> |
| 22:21 | -            | Reserved                                                 | Must be set to 0                                     |
| 23    | PLL0_SSCG    | PLL0 spread spectrum clock generator                     | <ul><li>0: Powered down</li><li>1: Running</li></ul> |
| 24    | -            | Reserved                                                 | Must be set to 0                                     |
| 25    | HSCMP0       | High-speed comparator 0                                  | 0: Powered down     1: Running                       |
| 26    | HSCMP1       | High-speed comparator 1                                  | 0: Powered down     1: Running                       |
| 27    | HSCMP2       | High-speed comparator 2                                  | 0: Powered down     1: Running                       |
| 28    | OPAMP0       | Operational amplifier 0                                  | 0: Powered down     1: Running                       |
| 29    | OPAMP1       | Operational amplifier 1                                  | <ul><li>0: Powered down</li><li>1: Running</li></ul> |

Table 6. Parameter exclude\_from\_pd[0] definition (1st vector)...continued

AN13530 Application note

| Bit | Symbol | Description                       | Value                                                |
|-----|--------|-----------------------------------|------------------------------------------------------|
| 30  | OPAMP2 | Operational amplifier 2           | <ul><li>0: Powered down</li><li>1: Running</li></ul> |
| 31  | VREF   | ADCs/DACs analog reference module | <ul><li>0: Powered down</li><li>1: Running</li></ul> |

### Table 6. Parameter exclude\_from\_pd[0] definition (1st vector)...continued

### Table 7. Parameter exclude\_from\_pd[1] definition (2nd vector)

| Bit   | Symbol     | Description                    | Value                                                                |
|-------|------------|--------------------------------|----------------------------------------------------------------------|
| 0     | CMPBIAS    | High-speed comparators biasing | O: Powered down     1: Running                                       |
| 1     | HSCMP0_DAC | HSCMP0 (internal) DAC          | <ul><li>0: Powered down</li><li>1: Running</li></ul>                 |
| 2     | HSCMP1_DAC | HSCMP1 (internal) DAC          | <ul><li>0: Powered down</li><li>1: Running</li></ul>                 |
| 3     | HSCMP2_DAC | HSCMP2 (internal) DAC          | 0: Powered down     1: Running                                       |
| 4     | DAC0       | Digital-to-analog converter 0  | <ul><li>0: Powered down</li><li>1: Running</li></ul>                 |
| 5     | DAC1       | Digital-to-analog converter 1  | <ul><li>0: Powered down</li><li>1: Running</li></ul>                 |
| 6     | DAC2       | Digital-to-analog converter 2  | 0: Powered down     1: Running                                       |
| 7     | STOP_DAC0  | DAC0 Stop mode                 | <ul><li>0: Stop mode enabled</li><li>1: Stop mode disabled</li></ul> |
| 8     | STOP_DAC1  | DAC1 Stop mode                 | <ul><li>0: Stop mode enabled</li><li>1: Stop mode disabled</li></ul> |
| 9     | STOP_DAC2  | DAC2 Stop mode                 | <ul><li>0: Stop mode enabled</li><li>1: Stop mode disabled</li></ul> |
| 31:10 | -          | Reserved                       | Must be set to 0                                                     |

### Table 8. Parameter sram\_retention\_ctrl

| Bit | SRAM instance (SRAM size) | Value                                                                                                   |
|-----|---------------------------|---------------------------------------------------------------------------------------------------------|
| 0   | RAM_X0 (16 kB)            | <ul><li>0: Keeps state prior entering Deep sleep</li><li>1: Deep sleep (content preserved)</li></ul>    |
| 1   | RAM_00 (4 kB)             | <ul><li>0: Keeps state prior entering Deep sleep</li><li>1: Deep sleep (content preserved)</li></ul>    |
| 2   | RAM_01 (4 kB)             | <ul><li>0: Keeps state prior entering Deep sleep</li><li>1: Deep sleep (content preserved)</li></ul>    |
| 3   | RAM_02 (4 kB)             | <ul><li>0: Keeps state prior entering Deep sleep</li><li>1: Deep sleep (content preserved)</li></ul>    |
| 4   | RAM_03 (4 kB)             | <ul> <li>0: Keeps state prior entering Deep sleep</li> <li>1: Deep sleep (content preserved)</li> </ul> |

AN13530

10 / 39

| Bit   | SRAM instance (SRAM size) | Value                                                                                                |
|-------|---------------------------|------------------------------------------------------------------------------------------------------|
| 5     | RAM_10 (16 kB)            | <ul><li>0: Keeps state prior entering Deep sleep</li><li>1: Deep sleep (content preserved)</li></ul> |
| 6     | RAM_20 (32 kB)            | <ul><li>0: Keeps state prior entering Deep sleep</li><li>1: Deep sleep (content preserved)</li></ul> |
| 7     | RAM_30 (32 kB)            | <ul><li>0: Keeps state prior entering Deep sleep</li><li>1: Deep sleep (content preserved)</li></ul> |
| 8     | RAM_40 (4 kB)             | <ul><li>0: Keeps state prior entering Deep sleep</li><li>1: Deep sleep (content preserved)</li></ul> |
| 9     | RAM_41 (4 kB)             | <ul><li>0: Keeps state prior entering Deep sleep</li><li>1: Deep sleep (content preserved)</li></ul> |
| 10    | RAM_42 (4 kB)             | <ul><li>0: Keeps state prior entering Deep sleep</li><li>1: Deep sleep (content preserved)</li></ul> |
| 11    | RAM_43 (4 kB)             | <ul><li>0: Keeps state prior entering Deep sleep</li><li>1: Deep sleep (content preserved)</li></ul> |
| 31:12 | Reserved                  | Must be set to 0                                                                                     |

### Table 8. Parameter sram\_retention\_ctrl...continued

### Table 9. Parameter wakeup\_interrupts[0] (1st vector)

| Bit | Symbol      | Description                                             | Value                                                                  |
|-----|-------------|---------------------------------------------------------|------------------------------------------------------------------------|
| 0   | SYS         | Watchdog, brownout Detectors (BOD VDDMAIN and BOD Core) | <ul><li>0: Interrupt disabled</li><li>1: Interrupt enabled</li></ul>   |
| 1   | SDMA0       | SDMA0 controller                                        | <ul><li>0: Interrupt disabled</li><li>1: Interrupt enabled</li></ul>   |
| 2   | GLOBALINT0  | Group GPIO input interrupt 0 (GINT0)                    | <ul><li>0: Interrupt disabled</li><li>1: Interrupt enabled</li></ul>   |
| 3   | GLOBALINT1  | Group GPIO input interrupt 1 (GINT1)                    | <ul><li>0: Interrupt disabled</li><li>1: Interrupt enabled</li></ul>   |
| 4   | GPIO_INT0_0 | Pin interrupt 0 or pattern match engine slice 0 (PINT0) | <ul><li>0: Interrupt disabled</li><li>1: Interrupt enabled</li></ul>   |
| 5   | GPIO_INT0_1 | Pin interrupt 1 or pattern match engine slice 1 (PINT1) | <ul><li>0: Interrupt disabled</li><li>1: Interrupt enabled</li></ul>   |
| 6   | GPIO_INT0_2 | Pin interrupt 2 or pattern match engine slice 2 (PINT2) | <ul><li>0: Interrupt disabled</li><li>1: Interrupt enabled</li></ul>   |
| 7   | GPIO_INT0_3 | Pin interrupt 3 or pattern match engine slice 3 (PINT3) | <ul><li>0: Interrupt disabled</li><li>1: Interrupt enabled</li></ul>   |
| 8   | UTICK       | Micro-tick timer                                        | <ul><li>0: Interrupt disabled</li><li>1: Interrupt enabled</li></ul>   |
| 9   | -           | Reserved                                                | Must be set to 0                                                       |
| 10  | CTIMER0     | Standard counter/timer<br>CTIMER0                       | <ul><li> 0: Interrupt disabled</li><li> 1: Interrupt enabled</li></ul> |
| 11  | CTIMER1     | Standard counter/timer<br>CTIMER1                       | <ul><li> 0: Interrupt disabled</li><li> 1: Interrupt enabled</li></ul> |

| Bit   | Symbol       | Description                                      | Value                                                                  |
|-------|--------------|--------------------------------------------------|------------------------------------------------------------------------|
| 12    | -            | Reserved                                         | Must be set to 0                                                       |
| 13    | CTIMER3      | Standard counter/timer<br>CTIMER3                | <ul><li> 0: Interrupt disabled</li><li> 1: Interrupt enabled</li></ul> |
| 14    | FLEXCOMM0    | Flexcomm Interface 0<br>(USART, SPI, I2C)        | <ul><li> 0: Interrupt disabled</li><li> 1: Interrupt enabled</li></ul> |
| 15    | FLEXCOMM1    | Flexcomm Interface 1<br>(USART, SPI, I2C)        | <ul><li> 0: Interrupt disabled</li><li> 1: Interrupt enabled</li></ul> |
| 16    | FLEXCOMM2    | Flexcomm Interface 2<br>(USART, SPI, I2C)        | <ul><li> 0: Interrupt disabled</li><li> 1: Interrupt enabled</li></ul> |
| 17    | FLEXCOMM3    | Flexcomm Interface 3<br>(USART, SPI, I2C)        | <ul><li> 0: Interrupt disabled</li><li> 1: Interrupt enabled</li></ul> |
| 18    | FLEXCOMM4    | Flexcomm Interface 4<br>(USART, SPI, I2C)        | <ul><li> 0: Interrupt disabled</li><li> 1: Interrupt enabled</li></ul> |
| 19    | FLEXCOMM5    | Flexcomm Interface 5<br>(USART, SPI, I2C)        | <ul><li> 0: Interrupt disabled</li><li> 1: Interrupt enabled</li></ul> |
| 20    | FLEXCOMM6    | Flexcomm Interface 6<br>(USART, SPI, I2C)        | <ul><li> 0: Interrupt disabled</li><li> 1: Interrupt enabled</li></ul> |
| 21    | FLEXCOMM7    | Flexcomm Interface 7<br>(USART, SPI, I2C)        | <ul><li> 0: Interrupt disabled</li><li> 1: Interrupt enabled</li></ul> |
| 23:22 | -            | Reserved                                         | Must be set to 0                                                       |
| 24    | ACMP         | Analog comparator                                | <ul><li> 0: Interrupt disabled</li><li> 1: Interrupt enabled</li></ul> |
| 25    | -            | Reserved                                         | Must be set to 0                                                       |
| 26    | HWVAD        | Hardware voice activity detector                 | <ul><li> 0: Interrupt disabled</li><li> 1: Interrupt enabled</li></ul> |
| 27    | USB0_NEEDCLK | USB full speed                                   | <ul><li> 0: Interrupt disabled</li><li> 1: Interrupt enabled</li></ul> |
| 28    | -            | Reserved                                         | Must be set to 0                                                       |
| 29    | RTC          | Real-time clock (counter event and tamper event) | <ul><li> 0: Interrupt disabled</li><li> 1: Interrupt enabled</li></ul> |
| 31:30 | -            | Reserved                                         | Must be set to 0                                                       |
|       | 1            | 1                                                | 1                                                                      |

Table 9. Parameter wakeup\_interrupts[0] (1st vector)...continued

### Table 10. Parameter wakeup\_interrupts[1] (2nd vector)

| Bit | Symbol      | Description                                             | Value                                                                |
|-----|-------------|---------------------------------------------------------|----------------------------------------------------------------------|
| 0   | GPIO_INT0_4 | Pin interrupt 4 or pattern match engine slice 4 (PINT4) | <ul><li>0: Interrupt disabled</li><li>1: Interrupt enabled</li></ul> |
| 1   | GPIO_INT0_5 | Pin interrupt 5 or pattern match engine slice 5 (PINT5) | <ul><li>0: Interrupt disabled</li><li>1: Interrupt enabled</li></ul> |
| 2   | GPIO_INT0_6 | Pin interrupt 6 or pattern match engine slice 6 (PINT6) | <ul><li>0: Interrupt disabled</li><li>1: Interrupt enabled</li></ul> |

| Bit   | Symbol          | Description                                                                 | Value                                                                  |
|-------|-----------------|-----------------------------------------------------------------------------|------------------------------------------------------------------------|
| 3     | GPIO_INT0_7     | Pin interrupt 7 or pattern match engine slice 7 (PINT7)                     | <ul><li> 0: Interrupt disabled</li><li> 1: Interrupt enabled</li></ul> |
| 4     | CTIMER2         | Standard counter/timer CTIMER2                                              | <ul><li> 0: Interrupt disabled</li><li> 1: Interrupt enabled</li></ul> |
| 5     | CTIMER4         | Standard counter/timer CTIMER4                                              | <ul><li>0: Interrupt disabled</li><li>1: Interrupt enabled</li></ul>   |
| 6     | OS_EVENT_TIMER  | OS Event Timer                                                              | <ul><li>0: Interrupt disabled</li><li>1: Interrupt enabled</li></ul>   |
| 12:7  | -               | Reserved                                                                    | Must be set to 0                                                       |
| 13    | SPIFILTER       | SPI Filter                                                                  | <ul><li> 0: Interrupt disabled</li><li> 1: Interrupt enabled</li></ul> |
| 17:14 | -               | Reserved                                                                    | Must be set to 0                                                       |
| 18    | SEC_GPIO_INT0_0 | Secure Pin interrupt 0 or pattern match engine<br>slice 0<br>(Secure PINT0) | <ul><li>0: Interrupt disabled</li><li>1: Interrupt enabled</li></ul>   |
| 19    | SEC_GPIO_INT0_1 | Secure Pin interrupt 1 or pattern match engine<br>slice 1<br>(Secure PINT1) | <ul><li>0: Interrupt disabled</li><li>1: Interrupt enabled</li></ul>   |
| 25:20 | -               | Reserved                                                                    | Must be set to 0                                                       |
| 26    | SDMA1           | SDMA1 control                                                               | <ul><li>0: Interrupt disabled</li><li>1: Interrupt enabled</li></ul>   |
| 27    | LSPI_HS         | High-Speed SPI                                                              | <ul><li>0: Interrupt disabled</li><li>1: Interrupt enabled</li></ul>   |
| 29:28 | -               | Reserved                                                                    | Must be set to 0                                                       |
| 30    | 13C             | МІРІ ІЗС                                                                    | <ul><li> 0: Interrupt disabled</li><li> 1: Interrupt enabled</li></ul> |
| 31    | -               | Reserved                                                                    | Must be set to 0                                                       |

Table 10. Parameter wakeup\_interrupts[1] (2nd vector)...continued

Table 11. Parameter wakeup\_interrupts[2] (3rd vector)

| Bit   | Symbol | Description                   | Value                                                                  |
|-------|--------|-------------------------------|------------------------------------------------------------------------|
| 1:0   | -      | Reserved                      | Must be set to 0                                                       |
| 2     | -      | Reserved                      | Must be set to 0                                                       |
| 9:3   | -      | Reserved                      | Must be set to 0                                                       |
| 10    | DAC0   | Digital-to-analog converter 0 | <ul><li> 0: Interrupt disabled</li><li> 1: Interrupt enabled</li></ul> |
| 11    | DAC1   | Digital-to-analog converter 1 | <ul><li> 0: Interrupt disabled</li><li> 1: Interrupt enabled</li></ul> |
| 12    | DAC2   | Digital-to-analog converter 2 | <ul><li> 0: Interrupt disabled</li><li> 1: Interrupt enabled</li></ul> |
| 31:13 | -      | Reserved                      | Must be set to 0                                                       |

AN13530 Application note © 2023 NXP B.V. All rights reserved.

## Bit Symbol Description Value 31:0 Reserved Must be set to 0

### Table 13. Parameter hardware\_wake\_ctrl

| Bit  | Symbol                 | Description                                                                                                                                                                                                                                                                                                                                | Value                                            |
|------|------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------|
| 0    | -                      | Reserved                                                                                                                                                                                                                                                                                                                                   | Must be set to 0                                 |
| 1    | HWWAKE_<br>PERIPHERALS | Wake for Flexcomms. Any Flexcomm FIFO reaching the level specified by its own TXLVL causes peripheral clocking to wake up temporarily while the related status is asserted                                                                                                                                                                 | <ul><li>0: Disabled</li><li>1: Enabled</li></ul> |
| 2    | HWWAKE_DMIC            | Wake for Digital Microphone (DMIC). When 1, the DMIC input FIFO reaching the level specified by TRIGLVL of either channel causes peripheral clocking to be enabled temporarily while the DMIC FIFO level is at or above TRIGLVL. This allows DMA to become active to move data out of the DMIC FIFO. Used with LOWPOWER_HWWAKE_PERIPHERALS | <ul><li>0: Disabled</li><li>1: Enabled</li></ul> |
| 3    | HWWAKE_SDMA0           | Wake for SDMA0. SDMA0 being busy causes peripheral clocking to remain running until DMA completes. Used with HWWAKE_PERIPHERALS                                                                                                                                                                                                            | <ul><li>0: Disabled</li><li>1: Enabled</li></ul> |
| 4    | -                      | Reserved                                                                                                                                                                                                                                                                                                                                   | Must be set to 0                                 |
| 5    | HWWAKE_SDMA1           | Wake for SDMA1. SDMA1 being busy causes peripheral clocking to remain running until DMA completes. Used with HWWAKE_PERIPHERALS                                                                                                                                                                                                            | <ul><li>0: Disabled</li><li>1: Enabled</li></ul> |
| 6    | HWWAKE_DAC             | Wake for DAC0, DAC1, DAC2. Any DAC0/1/2 FIFO reaching the level specified by the configuration generates an asynchronous SDMA0 request, and SDMA0 wakes up the bus clock temporarily to transfer data to DAC0/1/2                                                                                                                          | <ul><li>0: Disabled</li><li>1: Enabled</li></ul> |
| 31:7 | -                      | Reserved                                                                                                                                                                                                                                                                                                                                   | Must be set to 0                                 |

### 3.1.3 POWER\_EnterPowerDown

The POWER\_EnterPowerDown API configures the power down low-power mode and allows controlling which peripherals are powered up and which SRAM instances are in retention state during power down.

When a wake-up event occurs, CPU resumes code execution after the call to the low-power API function. However, during power down, a couple of modules lose their states and therefore, they must be reconfigured by the user application.

It is the responsibility of the user to make sure that the SRAM instance(s) containing the application software stacks and variables are preserved during power down.

The POWER\_EnterPowerDown API switches the CPU and System Bus clock to 12 MHz. It is the responsibility of the user to reconfigure the CPU and System Bus clock after the function returns.

During power down, a couple of modules lose their state. It is the responsibility of the user application to reconfigure them if the application requires them.

### Table 14. POWER\_EnterPowerDown

| Routine              | API Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Function Prototype   | <pre>void POWER_EnterPowerDown(uint32_t exclude_from_pd[1], uint32_t sram_<br/>retention_ctrl, uint32_t wakeup_interrupts[2], uint32_t cpu_retention_<br/>addr);</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                      | Input Parameters                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| exclude_from_pd[1]   | <ul> <li>Defines which analog peripherals shall not be powered down. It is a 1 x 32-bit vector, with each bit of the vector corresponding to one module. The definition of the vector is given in <u>Table 15</u>, and is aligned with the power_pd_bit_t type definition. For each bit field of the vector:</li> <li>0: The module is powered down during power down.</li> <li>1: The module is running during power down.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| sram_retention_ctrl  | <ul> <li>Defines which SRAM instances shall preserve their content during power down. The sram_retention_ctrl parameter is a 32-bit vector, with each bit of the vector corresponding to one SRAM instance. The definition of the vector is given in Table 16, and is aligned with the power_sram_bit_t type definition. For each bit field of the vector:</li> <li>0: During power down, the SRAM instance is in the SRAM Shut-down low-power mode (content not preserved).</li> <li>1: During power down, the SRAM instance is in the SRAM Deep sleep low-power mode (content preserved).</li> <li>Note: The SRAM instance, which is used to save Cortex-M33, AHB secure controller and Flash PRINCE modules states, is automatically put in the Deep sleep low-power mode (content</li> </ul>                                                                                                                                                                                    |
| wakeup_interrupts[2] | <ul> <li>preserved) by Low power.</li> <li>Defines which peripheral interrupts can be a wake-up source during power down. It is a 2 x 32-bit vector, with each bit inside the vector corresponding to one interrupt source. The definition of the vector is given in <u>Table 17</u> and <u>Table 18</u>, and is aligned with the Low-power modes wake-up sources (#define WAKEUP_*) #defines definitions. For each bit field of the vector:</li> <li>0: The associated peripheral cannot be a wake-up source during power down</li> <li>1: The associated peripheral can be a wake-up source during power down</li> </ul>                                                                                                                                                                                                                                                                                                                                                          |
|                      | <b>Note:</b> In case Flexcomm3 UART is used as wake-up source, a 32 kHz clock source (either FRO32K or XTAL32K) must be enabled during power down. The unique baud rate supported is 9600 Baud.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| cpu_retention_addr   | <ul> <li>Defines the start address of the area inside SRAM region where the Cortex-M33, AHB secure controller, and Flash PRINCE modules state are saved during power down:</li> <li>Must be word-aligned (address ending by 0x0, 0x4, 0x8, and 0xC)</li> <li>Can be any value: <ul> <li>Between 0x20000000 and 0x200009FC (inside RAM_00)</li> <li>Between 0x20001000 and 0x200019FC (inside RAM_01)</li> <li>Between 0x20002000 and 0x200029FC (inside RAM_02)</li> <li>Between 0x20003000 and 0x200039FC (inside RAM_03)</li> </ul> </li> <li>If the parameter does not meet the boundaries mentioned above, it is set to 0x20000000 (start of RAM_00) by the low-power API.</li> <li>Note: The states of the Cortex-M33, AHB security controller, and PRINCE modules are stored in SRAM from cpu_retention_addr to cpu_retention_addr + 1540 Bytes - 1. Therefore, any user data present in this area before calling the function is overwritten and definitely lost.</li> </ul> |
| Result               | None                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Description          | Controls which peripherals are powered up and which SRAM instances are in retention state during power down. Defines which SRAM instances shall preserve their content during power down.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

| Bit   | Symbol  | Description                       | Value                          |
|-------|---------|-----------------------------------|--------------------------------|
| 3:0   | -       | Reserved                          | Must be set to 0               |
| 4     | FRO1M   | 1 MHz free running oscillator     | O: Powered down     1: Running |
| 5     | -       | Reserved                          | Must be set to 0               |
| 6     | FRO32K  | 32 kHz free running oscillator    | O: Powered down     1: Running |
| 7     | XTAL32K | 32 kHz crystal oscillator         | O: Powered down     1: Running |
| 12:8  | -       | Reserved                          | Must be set to 0               |
| 13    | COMP    | Analog comparator                 | O: Powered down     1: Running |
| 30:14 | -       | Reserved                          | Must be set to 0               |
| 31    | VREF    | ADCs/DACs analog reference module | O: Powered down     1: Running |

### Table 15. Parameter exclude\_from\_pd[0] definition

### Table 16. Parameter sram\_retention\_ctrl

| Bit | SRAM instance (SRAM size) | Value                                                                                            |
|-----|---------------------------|--------------------------------------------------------------------------------------------------|
| 0   | RAM_X0 (16 kB)            | <ul><li>0: Shut Down (content not preserved)</li><li>1: Deep Sleep (content preserved)</li></ul> |
| 1   | RAM_00 (4 kB)             | <ul><li>0: Shut Down (content not preserved)</li><li>1: Deep Sleep (content preserved)</li></ul> |
| 2   | RAM_01 (4 kB)             | <ul><li>0: Shut Down (content not preserved)</li><li>1: Deep Sleep (content preserved)</li></ul> |
| 3   | RAM_02 (4 kB)             | <ul><li>0: Shut Down (content not preserved)</li><li>1: Deep Sleep (content preserved)</li></ul> |
| 4   | RAM_03 (4 kB)             | <ul><li>0: Shut Down (content not preserved)</li><li>1: Deep Sleep (content preserved)</li></ul> |
| 5   | RAM_10 (16 kB)            | <ul><li>0: Shut Down (content not preserved)</li><li>1: Deep Sleep (content preserved)</li></ul> |
| 6   | RAM_20 (32 kB)            | <ul><li>0: Shut Down (content not preserved)</li><li>1: Deep Sleep (content preserved)</li></ul> |
| 7   | RAM_30 (32 kB)            | <ul><li>0: Shut Down (content not preserved)</li><li>1: Deep Sleep (content preserved)</li></ul> |
| 8   | RAM_40 (4 kB)             | <ul><li>0: Shut Down (content not preserved)</li><li>1: Deep Sleep (content preserved)</li></ul> |
| 9   | RAM_41 (4 kB)             | <ul><li>0: Shut Down (content not preserved)</li><li>1: Deep Sleep (content preserved)</li></ul> |
| 10  | RAM_42 (4 kB)             | <ul><li>0: Shut Down (content not preserved)</li><li>1: Deep Sleep (content preserved)</li></ul> |
| 11  | RAM_43 (4 kB)             | <ul><li>0: Shut Down (content not preserved)</li><li>1: Deep Sleep (content preserved)</li></ul> |

© 2023 NXP B.V. All rights reserved.

|       | SRAM instance (SRAM size) |                  |
|-------|---------------------------|------------------|
| 31:12 | Reserved                  | Must be set to 0 |

### Table 40 Devenue for eveny vetention styl

### Table 17. Parameter wakeup\_interrupts[0] (1st vector)

| Bit   | Symbol     | Description                                      | Value                                                                  |
|-------|------------|--------------------------------------------------|------------------------------------------------------------------------|
| 1:0   | -          | Reserved                                         | Must be set to 0                                                       |
| 2     | GLOBALINT0 | Group GPIO input interrupt 0 (GINT0)             | <ul><li> 0: Interrupt disabled</li><li> 1: Interrupt enabled</li></ul> |
| 3     | GLOBALINT1 | Group GPIO input interrupt 1 (GINT1)             | <ul><li> 0: Interrupt disabled</li><li> 1: Interrupt enabled</li></ul> |
| 16:4  | -          | Reserved                                         | Must be set to 0                                                       |
| 17    | FLEXCOMM3  | Any module inside Flexcomm3 (UART, SPI, I2C)     | <ul><li> 0: Interrupt disabled</li><li> 1: Interrupt enabled</li></ul> |
| 23:18 | -          | Reserved                                         | Must be set to 0                                                       |
| 24    | ACMP       | Analog comparator                                | <ul><li> 0: Interrupt disabled</li><li> 1: Interrupt enabled</li></ul> |
| 28:25 | -          | Reserved                                         | Must be set to 0                                                       |
| 29    | RTC        | Real-time clock (counter event and tamper event) | <ul><li> 0: Interrupt disabled</li><li> 1: Interrupt enabled</li></ul> |
| 31:30 | -          | Reserved                                         | Must be set to 0                                                       |

### Table 18. Parameter wakeup\_interrupts[1] (2nd vector)

| Bit  | Symbol  | Description | Value                                                                |
|------|---------|-------------|----------------------------------------------------------------------|
| 5:0  | -       | Reserved    | Must be set to 0                                                     |
| 6    | OSTIMER |             | <ul><li>0: Interrupt disabled</li><li>1: Interrupt enabled</li></ul> |
| 31:7 | -       | Reserved    | Must be set to 0                                                     |

### 3.1.4 POWER\_EnterDeepPowerDown

The POWER EnterDeepPowerDown API configures the Deep power-down low-power mode. It allows controlling which peripherals are powered up and which SRAM instances are in retention state during the Deep power-down.

The POWER EnterDeepPowerDown API switches the CPU and System Bus clock to 12 MHz. It is the responsibility of the user to reconfigure the CPU and System Bus clock after the function has returned (this happens when the Deep power-down state is not entered because an RTC or OS Event Timer interrupt is pending when the API is called. Otherwise, this API never returns).

| Routine            | API Description                                                                                                                                                |  |
|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Function Prototype | <pre>void POWER_EnterDeepPowerDown (uint32_t exclude_from_pd[1], uint32_t sram_retention_ctrl, uint32_t wakeup_interrupts[2], uint32_t wakeup_ io_ctrl);</pre> |  |

Table 19. POWER\_EnterDeepPowerDown

| Routine              | API Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |
|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
|                      | Input Parameters                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |
| exclude_from_pd[1]   | <ul> <li>Defines which analog peripherals shall not be powered down. It is a 1 x 32-bit vector, with each bit of the vector corresponding to one module. The definition of the vector is given in Table 20, and is aligned with the power_pd_bit_t type definition. For each bit field of the vector:</li> <li>0: The module is powered down during Deep power-down.</li> </ul>                                                                                                                                                                                                                                                                                                                            |  |  |  |
|                      | 1: The module is running during Deep power-down.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |
| sram_retention_ctrl  | <ul> <li>Defines which SRAM instances shall preserve their content during Deep power-down.<br/>The sram_retention_ctrl parameter is a 32-bit vector, with each bit of the vector corresponding to one SRAM instance. The definition of the vector is given in <u>Table 21</u>, and is aligned with the power_sram_bit_t type definition. For each bit field of the vector:</li> <li>0: During Deep power-down, the SRAM instance is in the SRAM Shut Down low-power mode (content not preserved).</li> <li>1: During Deep power-down, the SRAM instance is in the SRAM Deep deep low-power mode (content preserved).</li> </ul>                                                                            |  |  |  |
|                      | <b>Note:</b> During SoC boot time, if the FlexSPI or 1-bit SPI is used to load an executable code image from an external flash to internal SRAM, then only the following SRAM instances can be in the SRAM Deep sleep low-power mode (content preserved) during Deep power-down: RAM_00 and RAM_01. Otherwise, the following SRAM instances can be in the SRAM Deep Sleep low-power mode (content preserved) during Deep power-down: RAM_00, RAM_01, RAM_10, RAM_20, RAM_30, RAM_40, RAM_41, RAM_42, and RAM_43. If VDDMAIN power is removed during Deep power-down mode, only RAM_00 SRAM instance can be in the SRAM Deep Sleep low-power mode (content preserved) during the Deep power-down mode.      |  |  |  |
| wakeup_interrupts[2] | <ul> <li>Defines which peripheral interrupts can be executed if they are pending before entering Deep power-down. It is a 2 x 32-bit vector, with each bit inside the vector corresponding to one interrupt source. The definition of the vectors is given in <u>Table 22</u> and <u>Table 23</u>, and is aligned with the low-power modes wake-up sources (#define WAKEUP_*)#defines definitions.</li> <li>For each bit field of the vector:</li> <li>0: The peripheral interrupt handler is not executed, if the interrupt is pending before entering Deep power-down.</li> <li>1: The peripheral interrupt handler is executed, if the interrupt is pending before entering Deep power-down.</li> </ul> |  |  |  |
|                      | Unlike Deep sleep and Power-down modes, in the Deep power-down mode, the wakeup_<br>interrupts parameter has no influence on the ability of the peripheral (RTC or OS Event<br>Timer) to wake up the device from the Deep power-down mode. That is, even if a peripheral<br>interrupt is not enabled via the wakeup_interrupts parameter (wakeup_interrupts[0]<br>= 0 and wakeup_interrupts[1] = 0), the device wakes up from Deep power-down when<br>the peripheral's wake-up event occurs (RTC countdown or tamper events, OS Event Timer<br>countdown).                                                                                                                                                 |  |  |  |
|                      | <b>Note:</b> After wake-up from Deep power-down, the RTC interrupt (if the RTC module is enabled and was the wake-up source) is always pending on the Cortex-M33 Nested Vector Interrupt Controller, but it is executed only if the user enables it directly in the Cortex-M33 Nested Vector Interrupt Controller (after the wake up).                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |
|                      | After wake up from Deep power down, the OS Event Timer interrupt is never pending on to the Cortex-M33 Nested Vector Interrupt Controller even if it is enabled via this <code>wakeup_interrupts prior entering Deep power-down mode.</code>                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |
| wakeup_io_ctrl       | Configures the five wake-up pins that can wake up the device from the Deep power-down mode. The definition of the parameter is given in <u>Table 24</u> , and it is aligned with the wake-up I/ O sources (#define LOWPOWER_WAKEUPIO*) #define definitions.                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |
|                      | <b>Note:</b> During the Deep power-down mode, the five wake-up I/Os are all configured as Input.<br>The user can choose to enable or disable the internal pull-up and pull-down for each wake-                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |

### Table 19. POWER\_EnterDeepPowerDown...continued

| Routine API Description |                                                                                                                                                                                                                                                                                                 |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                         | up I/O individually. After wake up from Deep power-down, the five wake-up I/Os retrieve their default configuration (Input and output disabled, both internal pull-up and pull-down disabled) when the <code>POWER_PowerInit API</code> is called.                                              |
| Result                  | None                                                                                                                                                                                                                                                                                            |
| Description             | Configures the Deep power-down low-power mode. It allows controlling which peripherals are powered up and which SRAM instances are in retention state during Deep power-down. Also, it defines which peripheral interrupts can be executed if they are pending before entering Deep power-down. |

### Table 19. POWER\_EnterDeepPowerDown...continued

### Table 20. Parameter exclude\_from\_pd[0] definition

| Bit  | Symbol  | Description                       | Value                                                |
|------|---------|-----------------------------------|------------------------------------------------------|
| 3:0  | -       | Reserved                          | Must be set to 0                                     |
| 4    | FRO1M   | 1 MHz Free Running<br>Oscillator  | <ul><li>0: Powered down</li><li>1: Running</li></ul> |
| 5    | -       | Reserved                          | Must be set to 0                                     |
| 6    | FRO32K  | 32 kHz Free Running<br>Oscillator | 0: Powered down     1: Running                       |
| 7    | XTAL32K | 32 kHz Crystal Oscillator         | 0: Powered down     1: Running                       |
| 31:8 | -       | Reserved                          | Must be set to 0                                     |

### Table 21. Parameter sram\_retention\_ctrl

| Bit | SRAM instance (SRAM size)           | Value                                                                                            |
|-----|-------------------------------------|--------------------------------------------------------------------------------------------------|
| 0   | Reserved                            | Must be set to 0                                                                                 |
| 1   | RAM_00 (4 kB)                       | <ul><li>0: Shut Down (content not preserved)</li><li>1: Deep sleep (content preserved)</li></ul> |
| 2   | RAM_01 (4 kB)                       | <ul><li>0: Shut Down (content not preserved)</li><li>1: Deep sleep (content preserved)</li></ul> |
| 4:3 | Reserved                            | Must be set to 0                                                                                 |
| 5   | RAM_10 (16 kB) <sup>[1][1]</sup>    | <ul><li>0: Shut Down (content not preserved)</li><li>1: Deep sleep (content preserved)</li></ul> |
| 6   | RAM_20 (32 kB) <sup>[2][1][2]</sup> | <ul><li>0: Shut Down (content not preserved)</li><li>1: Deep sleep (content preserved)</li></ul> |
| 7   | RAM_30 (32 kB) <sup>[1][2]</sup>    | <ul><li>0: Shut Down (content not preserved)</li><li>1: Deep sleep (content preserved)</li></ul> |
| 8   | RAM_40 (4 kB) <sup>[1][2]</sup>     | <ul><li>0: Shut Down (content not preserved)</li><li>1: Deep sleep (content preserved)</li></ul> |
| 9   | RAM_41 (4 kB) <sup>[1][2]</sup>     | <ul><li>0: Shut Down (content not preserved)</li><li>1: Deep sleep (content preserved)</li></ul> |
| 10  | RAM_42 (4 kB) <sup>[1][2]</sup>     | <ul><li>0: Shut Down (content not preserved)</li><li>1: Deep sleep (content preserved)</li></ul> |

# BitSRAM instance (SRAM size)Value11RAM\_43 (4 kB)<sup>[1][2]</sup>• 0: Shut Down (content not preserved)31:12Reserved• 1: Deep sleep (content preserved)31:12ReservedMust be set to 0

### Table 21. Parameter sram\_retention\_ctrl...continued

[1] If VDDMAIN power is removed during Deep power-down mode, this SRAM instance cannot be in SRAM Deep sleep low-power mode (content preserved) during Deep power-down mode.

[2] During SoC Boot time, If the FlexSPI or a 1-bit SPI are used to load an executable code image from an external flash to internal SRAM, then this SRAM instance cannot be in SRAM Deep sleep low-power mode (content preserved) during Deep power-down.

| Bit   | Symbol | Description                           | Value                                                                |
|-------|--------|---------------------------------------|----------------------------------------------------------------------|
| 28:0  | -      | Reserved                              | Must be set to 0                                                     |
| 29    | RTC    | , , , , , , , , , , , , , , , , , , , | <ul><li>0: Interrupt disabled</li><li>1: Interrupt enabled</li></ul> |
| 31:30 | -      | Reserved                              | Must be set to 0                                                     |

### Table 23. Parameter wakeup\_interrupts[1] (2nd vector)

| Bit  | Symbol  | Description | Value                                                                |
|------|---------|-------------|----------------------------------------------------------------------|
| 5:0  | -       | Reserved    | Must be set to 0                                                     |
| 6    | OSTIMER |             | <ul><li>0: Interrupt disabled</li><li>1: Interrupt enabled</li></ul> |
| 31:7 | -       | Reserved    | Must be set to 0                                                     |

### Table 24. Parameter wakeup\_io\_ctrl

| Bit | Symbol      | Description                                                    | Value                                                                                                                 |
|-----|-------------|----------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------|
| 1:0 | MODEWAKEUP0 | Select wake-up pin 0 operating mode during<br>Deep power-down. | <ul> <li>0: Disabled</li> <li>1: Rising edge</li> <li>2: Falling edge</li> <li>3: Rising and falling edges</li> </ul> |
| 3:2 | MODEWAKEUP1 | Select wake-up pin 1 operating mode during<br>Deep power-down. | <ul> <li>0: Disabled</li> <li>1: Rising edge</li> <li>2: Falling edge</li> <li>3: Rising and falling edges</li> </ul> |
| 5:4 | MODEWAKEUP2 | Select wake-up pin 2 operating mode during<br>Deep power-down. | <ul> <li>0: Disabled</li> <li>1: Rising edge</li> <li>2: Falling edge</li> <li>3: Rising and falling edges</li> </ul> |
| 7:6 | MODEWAKEUP3 | Select wake-up pin 3 operating mode during<br>Deep power-down. | <ul> <li>0: Disabled</li> <li>1: Rising edge</li> <li>2: Falling edge</li> <li>3: Rising and falling edges</li> </ul> |
| 9:8 | MODEWAKEUP4 | Select wake-up pin 4 operating mode during<br>Deep power-down. | <ul><li>0: Disabled</li><li>1: Rising edge</li></ul>                                                                  |

© 2023 NXP B.V. All rights reserved.

| Bit   | Symbol                       | Description                                                                                                                                                                                                                                                                                                                                                                                            | Value                                                                                                                                    |
|-------|------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------|
|       |                              |                                                                                                                                                                                                                                                                                                                                                                                                        | <ul><li> 2: Falling edge</li><li> 3: Rising and falling edges</li></ul>                                                                  |
| 19:10 | -                            | Reserved                                                                                                                                                                                                                                                                                                                                                                                               | Must be set to 0                                                                                                                         |
| 20    | DISABLEPULLUPDOWN<br>WAKEUP0 | Disable both pull-up and pull-down for wake-<br>up pin 0 during Deep power-down. When the<br>wake-up pin 0 is enabled (MODEWAKEUP0<br>is not 0) and pull-up or pull-down is enabled<br>(DISABLEPULLUPDOWNWAKEUP0=0),<br>then the state of the pull-up and pull-down is<br>determined by the wake-up pin mode (and<br>not by the field PULLUPDOWNWAKEUP0) as<br>described in <u>Table 25</u> .          | <ul> <li>0: Enable pull-up or pull-<br/>down (see PULLUPDOW<br/>NWAKEUP 0)</li> <li>1: Disable both pull-up and<br/>pull-down</li> </ul> |
| 21    | DISABLEPULLUPDOWN<br>WAKEUP1 | Disable both pull-up and pull-down for wake-<br>up pin 1 during Deep power-down. When<br>wake-up pin 1 is enabled (MODEWAKEUP1<br>is not 0) and pull-up or pull-down is enabled<br>(DISABLEPULLUPDOWNWAKEUP1=0),<br>then the state of the pull-up and pull-down is<br>determined by the wake-up pin mode (and<br>not by the field PULLUPDOWNWAKEUP1) as<br>described in <u>Table 25</u> .              | <ul> <li>0: Enable pull-up or pull-<br/>down (see PULLUPDOW<br/>NWAKEUP 0)</li> <li>1: Disable both pull-up and<br/>pull-down</li> </ul> |
| 22    | DISABLEPULLUPDOWN<br>WAKEUP2 | Disable both pull-up and pull-down for the<br>wake-up pin 2 during Deep power-down. When<br>wake-up pin 2 is enabled (MODEWAKEUP2<br>is not 0) and pull-up or pull-down is enabled<br>(DISABLEPULLUPDOWNWAKEUP2=0),<br>then the state of the pull-up and pull-down is<br>determined by the wake-up pin mode (and<br>not by the field PULLUPDOWNWAKEUP2) as<br>described in <u>Table 25</u> .           | <ul> <li>0: Enable pull-up or pull-<br/>down (see PULLUPDOW<br/>NWAKEUP 0)</li> <li>1: Disable both pull-up and<br/>pull-down</li> </ul> |
| 23    | DISABLEPULLUPDOWN<br>WAKEUP3 | Disable both pull-up and pull-down for the<br>wake-up pin 3 during Deep power-down. When<br>wake-up pin 3 is enabled (MODEWAKEUP3<br>is not 0) and pull-up or pull-down is enabled<br>(DISABLEPULLUPDOWNWAKEUP3=0),<br>then the state of the pull-up and pull-down is<br>determined by the wake-up pin mode (and<br>not by the field PULLUPDOWNWAKEUP3) as<br>described in <u>Table 25</u> .           | <ul> <li>0: Enable pull-up or pull-<br/>down (see PULLUPDOW<br/>NWAKEUP 0)</li> <li>1: Disable both pull-up and<br/>pull-down</li> </ul> |
| 24    | DISABLEPULLUPDOWN<br>WAKEUP4 | <ul> <li>Disable both pull-up and pull-down for wake-up pin 4 during Deep power-down. When wake-up pin 4:</li> <li>is enabled (MODEWAKEUP4 is not 0) AND</li> <li>pull-up or pull-down is enabled<br/>(DISABLEPULLUPDOWNWAKEUP4=0)<br/>then the state of the pull-up and pull-down is determined by the wake-up pin mode (and not by the field PULLUPDOWNWAKEUP4) as described in Table 25.</li> </ul> | <ul> <li>0: Enable pull-up or pull-<br/>down (see PULLUPDOW<br/>NWAKEUP 0)</li> <li>1: Disable both pull-up and<br/>pull-down</li> </ul> |
| 25    | PULLUPDOWNWAKEUP0            | Select pull-up or pull-down for wake-up pin<br>0 during Deep power-down. This field has<br>effect only when wake-up pin 0 is disabled                                                                                                                                                                                                                                                                  | <ul><li>0: Pull-down</li><li>1: Pull-up</li></ul>                                                                                        |
|       |                              |                                                                                                                                                                                                                                                                                                                                                                                                        | © 2023 NXP B.V. All rights reserved                                                                                                      |

### Table 24. Parameter wakeup\_io\_ctrl...continued

| Bit   | Symbol            | Description                                                                                                                                                                                                                                                  | Value                                             |
|-------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------|
|       |                   | (MODEWAKEUP0=0) and when wake-<br>up pin 0 pull-up/pull-down are enabled<br>(DISABLEPULLUPDOWNWAKEUP0=0)                                                                                                                                                     |                                                   |
| 26    | PULLUPDOWNWAKEUP1 | Select pull-up or pull-down for wake-up pin 1<br>during Deep power-down. This field has effect<br>only when wake-up pin 1 is disabled<br>(MODEWAKEUP1=0) and when wake-<br>up pin 1 pull-up/pull-down are enabled<br>(DISABLEPULLUPDOWNWAKEUP1=0)            | <ul><li>0: Pull-down</li><li>1: Pull-up</li></ul> |
| 27    | PULLUPDOWNWAKEUP2 | Select pull-up or pull-down for the wake-up<br>pin 2 during Deep power-down. This field<br>has effect only when the wake-up pin 2 is<br>disabled (MODEWAKEUP2=0) and when<br>wake-up pin 2 pull-up/pull-down are enabled<br>(DISABLEPULLUPDOWNWAKEUP2=0)     | <ul><li>0: Pull-down</li><li>1: Pull-up</li></ul> |
| 28    | PULLUPDOWNWAKEUP3 | Select pull-up or pull-down for the wake-up<br>pin 3 during Deep power-down. This field<br>has effect only when the wake-up pin 3 is<br>disabled (MODEWAKEUP3=0) and when the<br>wake-up pin 3 pull-up/pull-down are enabled<br>(DISABLEPULLUPDOWNWAKEUP3=0) | <ul><li>0: Pull-down</li><li>1: Pull-up</li></ul> |
| 29    | PULLUPDOWNWAKEUP4 | Select pull-up or pull-down for the wake-up<br>pin 4 during Deep power-down. This field<br>has effect only when the wake-up pin 4 is<br>disabled (MODEWAKEUP4=0) and when the<br>wake-up pin 4 pull-up/pull-down are enabled<br>(DISABLEPULLUPDOWNWAKEUP4=0) | <ul><li>0: Pull-down</li><li>1: Pull-up</li></ul> |
| 31:30 | -                 | Reserved                                                                                                                                                                                                                                                     | Must be set to 0                                  |

### Table 25. Pull-up/pull-down configuration

| User Configuration       |                              |                   | Resulting Pull-up/pull-down<br>State |               | Comments                                                                                                                                                                                                                          |  |
|--------------------------|------------------------------|-------------------|--------------------------------------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| DISABLEPULLUPDOWNWAKEUPx | MODEWAKEUPx                  | PULLUPDOWNWAKEUPx | Pull-down state                      | Pull-up state | -                                                                                                                                                                                                                                 |  |
| 0                        | 0 (Disabled)                 | 0 (pull-down)     | Enabled                              | Disabled      | The wake-up pin is disabled (MODEWAKEUP<br>= 0) and both the pull-up/pull-down are not<br>disabled<br>(DISABLEPULLUPDOWNWAKEUP=0). In this<br>case, the pull-up and pull-down states depend<br>on the value of PULLUPDOWNWAKEUPx. |  |
| 0                        | 0 (Disabled)                 | 1 (pull-up)       | Disabled                             | Enabled       |                                                                                                                                                                                                                                   |  |
| 0                        | 1 (Rising edge)              | -                 | Enabled                              | Disabled      | The wake-up pin is enabled (MODEWAKEUP !<br>= 0) and both the pull-up/pull-down are not<br>disabled (DISABLEPULLUPDOWNWAKEUP=0).                                                                                                  |  |
| 0                        | 2 (Falling edge)             | -                 | Disabled                             | Enabled       |                                                                                                                                                                                                                                   |  |
| 0                        | 3 (Rising and falling edges) | -                 | Enabled                              | Disabled      | In this case, the pull-up and pull-down states depend only on the value of MODEWAKEUPx                                                                                                                                            |  |
| 1                        | -                            | -                 | Disabled                             | Disabled      | Both the pull-up and the pull-down are<br>disabled, whatever the values of MODEWA<br>KEUP and PULLUPDOWNNAKEUP. Use this<br>configuration when an external pullup or pull-<br>down resistor is connected on the wake-up<br>pin.   |  |

### 3.2 Sleep mode

Sleep mode saves some power by stopping Cortex-M33 CPU execution without affecting peripherals or requiring significant wake-up time. The clock to the CPU is shut off. Peripherals and memories are active and

AN13530 Application note

operational. The CPU is stopped and execution of instructions is suspended until either a reset or an interrupt occurs.

Peripheral functions, if selected to be clocked in the AHBCLKCTRL registers, continue operation during Sleep mode and can generate interrupts to cause the processor to resume execution. Sleep mode only eliminates dynamic power used by the processor itself, memory systems and related controllers, and internal buses. The processor state and registers, peripheral registers, and internal SRAM values are maintained.

### 3.2.1 Entering Sleep mode

The POWER EnterSleep() API is used to enter the Sleep mode.

```
case kPmu_Sleep: /* Enter sleep mode. */
    POWER_EnterSleep();
    break;
```

### 3.2.2 Waking up from Sleep mode

In this application, a group interrupt generated by the SW3 (USR) switch is used to wake up the device from the Sleep mode. Pin 17 from the Port 0 ( $P0_17$ ) is used as the source of a group interrupt and this pin is pulled low by the pressing the SW3 (USR) switch.

### 3.3 Deep sleep mode

In Deep sleep mode, the full device remained powered, but flash and ROM are shut down, with the cost of a longer wake-up time compared to the Sleep mode. The system clock to the CPU is disabled as in Sleep mode. Analog blocks are powered down by default but can be selected to keep running through the power API if needed as wake-up sources. The main clock and all peripheral clocks are disabled.

Deep sleep mode eliminates power used by analog peripherals and all dynamic power used by the CPU, its memory systems and related controllers, and internal buses. The CPU state and registers, peripheral registers, and internal SRAM values are maintained, and the GPIO logic levels of the pins remain static. All SRAM instances that are not configured to enter in SRAM Deep sleep low-power mode keeps the state they had before entering Deep sleep. This means that if a SRAM was in Active state before entering in Deep sleep, it stays in Active state during Deep sleep and therefore it consumes more power.

Selected peripherals such as GPIO group interrupts (GINT), USB Full Speed, Flexcomms (SPI, I2C, USART), Windowed-Watchdog Timer, RTC, standard Counter/Timers, Micro-tick, RTC alarm, a watchdog timer interrupt/ reset, BOD interrupt/reset and comparator can be left running in Deep sleep mode. The oscillators like the FRO1M, FRO32K, XTAL32K but also the FRO192M (which delivers the 12 MHz and 96 MHz clocks), can also be left running.

Some peripherals can have DMA service during Deep sleep mode without waking up the entire device.

### 3.3.1 Entering Deep sleep mode

The POWER EnterDeepSleep() API is used to enter the Deep sleep mode.

In this application, RAM\_X0 (16 kB), RAM\_00 (4 kB), RAM\_01 (4 kB), RAM\_02 (4 kB), RAM\_03 (4 kB), RAM\_10 (32 kB), RAM\_20 (32 kB), RAM\_30 (16 kB), RAM\_40 (4 kB), RAM\_41 (4 kB), RAM\_42 (4 kB), RAM\_43 (4 kB) are in SRAM Deep Sleep low-power mode during Deep sleep.

```
case kPmu_Deep_Sleep: /* Enter deep sleep mode. */
    POWER_EnterDeepSleep(APP_EXCLUDE_FROM_DEEPSLEEP, 0x0, APP_WAKEUP_FROM_DEEPSLEEP, 0x0);
    break;
```

### 3.3.2 Waking up from Deep sleep mode

In this application, a pin interrupt generated by the SW1 (WK\_TMP) switch is used to wake up the device from the Deep sleep mode.

Pin 18 from Port 1 (P1\_18) is used as the source of a pin interrupt and this pin is pulled low by pressing the SW1 (WK TMP) switch. The same interrupt is enabled in NVIC using the EnableDeepSleepIRQ() API.

### 3.4 Power-down mode

Power-down mode turns off nearly all on-chip power consumption by eliminating power used by all analog modules and by shutting down the DCDC and the LDO\_CORE. This eliminates all digital peripherals power, with the cost of a longer wake-up time compared to Deep sleep mode. FRO192M is disabled. The flash memory is also disabled. The clock to the CPU and peripherals is shut down, and if not configured, the peripherals in the power domains PD\_SYSTEM and PD\_AO receive no internal clocks. All SRAM can be configured to maintain their internal state, and all registers lose their internal states except those located in the power domains PD\_SYSTEM and PD\_AO. Any SRAM instance not configured to maintain its internal state loses it. The Cortex-M33 CPU state and some critical peripherals like the analog controller are retained. The GPIO logic level does not remain static in Power-down mode. All GPIO pin states are logic '0' in Power-down mode. All IOCON registers and peripheral registers related ONLY to Flexcomm3 (SPI, I2C, I2S, USART), GINTOO, RTC, OS event timer, and analog comparator maintain state in Power-down mode. GPIO group interrupts (GINT0 and GINT1), selected serial peripherals in Flexcomm3 (SPI, I2C, USART), RTC, OS event timers, and analog comparator can be left running to wake up the device.

When a wake-up event occurs, the Cortex-M33 CPU code execution resumes from where it has stopped. It is the responsibility of the customer application to re-configure all modules in the power domain core PD\_CORE (whose states have not been retained, for example, all Flexcomm -except Flexcomm3-, SDMA, Power Quad, DMIC, and so on.).

### 3.4.1 Entering Power-down mode

The POWER\_EnterPowerDown() API is used to enter the Power-down mode. In this application, by default, RAM 00 (4 kB), RAM 43 (4 kB) preserve their content during power down.

By changing #define PD\_WAKE\_UP\_SRAM24K from 0 to 1, RAM\_X0 (16 kB), RAM\_00 (4 kB), RAM\_43 (4 kB) preserve their content during power down.

By changing #define PD\_WAKE\_UP\_SRAM128K from 0 to 1, RAM\_X0 (16 kB), RAM\_00 (4 kB), RAM\_01 (4 kB), RAM\_02 (4 kB), RAM\_03 (4 kB), RAM\_10 (32 kB), RAM\_20 (32 kB), RAM\_30 (16 kB), RAM\_40 (4 kB), RAM\_41 (4 kB), RAM\_42 (4 kB), RAM\_43 (4 kB) preserve their content during power down.

### 3.4.2 Waking up from Power-down mode

In this application, a group interrupt or a reset is used to wake up the device from the Power-down mode.

- Pin 17 from the Port 0 (P0\_17) is used as the source of a group interrupt and this pin is pulled low by pressing the SW3 (USR) switch.
- A reset from the RESETN pin is generated by pressing the SW2 (RESET) switch.

### 3.5 Deep power-down mode

Deep power-down mode shuts down virtually all on-chip power consumption but requires a longer wake-up time (compared to Power-down mode). For maximal power savings, the entire power domains PD\_CORE (CPU, DSP, Flexcomms, SDMA, and so on) and PD\_SYSTEM (Reset, Clocks, SYSCON, IOCON, and so on) are shut down. Only the Always-on power domain PD\_AO (PMU, PMC, the RTC, and the OS event timer) stays powered. Clocks are shut off to the entire chip device except for the RTC and the OS event timer if needed.

AN13530

On wake-up, the device reboots. During Deep power-down mode, the contents of some SRAM can be retained (software configured via the POWER\_EnterDeepPowerDown() low-power API), but registers (other than those in the PMC, the RTC, and OS event timer) are not retained. All functional pins are tri-stated in Deep power-down mode, except the 5 wake-up and RESET pins.

### 3.5.1 Entering Deep power-down mode

The POWER EnterDeepPowerDown () API is used to enter the Deep power-down mode.

| <pre>case kPmu_Deep_PowerDown: /* Enter deep power down mode. */ #if DPD WAKE UP SRAM4K</pre> |
|-----------------------------------------------------------------------------------------------|
|                                                                                               |
| #if DPD_WAKE_UP_PIN                                                                           |
| POWER_EnterDeepPowerDown(APP_EXCLUDE_FROM_DEEPPOWERDOWN, kPOWER_SRAM_RAM_00,                  |
| APP WAKEUP FROM DEEPPOWERDOWN, wakeup io ctrl);                                               |
| #else                                                                                         |
| POWER EnterDeepPowerDown (APP EXCLUDE FROM DEEPPOWERDOWN, kPOWER SRAM RAM 00,                 |
| APP WAKEUP FROM DEEPPOWERDOWN, 0);                                                            |
|                                                                                               |
| \$endif                                                                                       |
| #else                                                                                         |
| #if DPD WAKE UP PIN                                                                           |
| POWER EnterDeepPowerDown (APP EXCLUDE FROM DEEPPOWERDOWN, 0,                                  |
| APP WAKEUP FROM DEEPPOWERDOWN, wakeup io ctrl);                                               |
| felse felse                                                                                   |
|                                                                                               |
| POWER_EnterDeepPowerDown (APP_EXCLUDE_FROM_DEEPPOWERDOWN, 0,                                  |
| APP_WAKEUP_FROM_DEEPPOWERDOWN, 0);                                                            |
| #endif                                                                                        |
| #endif                                                                                        |
| break;                                                                                        |

### 3.5.2 Waking up from Deep power-down mode

Wake up from the Deep power-down mode can be done via the wake-up pin, or the RESETN pin. Pin 18 from Port 1 (P1\_18) is used as the source of the wake-up pin and this pin is pulled low by pressing the SW1 (WK\_TMP) switch. A reset from the RESETN pin by pressing SW2 (RESET) switch is used to wake up the device from the Deep power-down mode.

### 4 Low-power mode Demo

This section explains how LPC553x/LPC55S3x can be put into and waken up from the low-power modes.

- To wake up the device from the Sleep mode, configure the GPIO pin (P0\_17) (SW3 (USR)) as the source of a group interrupt.
- To wake up the device from the Deep sleep mode, configure the GPIO pin (P1\_18) (SW1 (WK\_TMP)) as the source of a pin interrupt.
- To wake up the device from the Power-down mode, configure the GPIO pin (P0\_17) (SW3 (USR)) as the source of a group interrupt.
- To wake up the device from the Power-down or Deep power-down mode, assert reset from the RESETN pin by pressing the SW2 (RESET) switch.
- To wake up the device from the Deep power-down mode, configure the GPIO pin (P1\_18) (SW1 (WK\_TMP)) as the source of a wake-up pin.

### 4.1 Software setup

Download and extract the file (SDK\_2\_14\_0\_LPCXpresso55S36.zip) associated with this Application Note. You can use following IDEs to verify the demo application available at SDK\_2\_14\_0\_LPCXpresso55 S36\boards\lpcxpresso55s36\demo apps\power mode switch lpc

- Keil IDE version 5.38 (+ NXP.LPC55S36\_DFP.17.0.0.pack)
- IAR IDE 9.40.1
- MCUXpresso IDE 11.8.0 (available for download at <a href="https://www.nxp.com/design/software/development-software/mcuxpresso-software-and-tools-/mcuxpresso-integrated-development-environment-ide:MCUXpresso-IDE">https://www.nxp.com/design/software/development-software/development-software/development-software/development-environment-ide:MCUXpresso-IDE</a>)

For more details on building and downloading the application, refer *Getting Started with MCUXpresso SDK for LPCXpresso55S36.pdf* located at \SDK\_2\_14\_0\_LPCXpresso55S36.

### 4.2 Hardware setup

The hardware requirements for the LPC553x/LPC55S3x low-power consumption measurement are as follows:

- LPC553x/LPC55S3x evaluation board
- · Digital multimeter for current measurement
- Oscilloscope for wake-up time measurement

For the LPC553x/LPC55S3x low-power consumption measurement, install jumper top to JP33 (R432 as DNP), JP74, and JP75.

- To measure IMCU\_MAIN, remove jumper top from JP28 (R436 as DNP) and connect current meter to JP28 (R436 as DNP).
- To measure IMCU\_VBAT, remove jumper top from JP22 (R435 as DNP) and connect current meter to JP22 (R435 as DNP).
- To measure IMCU\_VDDA, remove jumper top from JP21 (R434 as DNP) and connect current meter to JP21 (R434 as DNP).
- To measure IMCU\_VDD, remove jumper top from JP20 (R433 as DNP) and connect current meter to JP20 (R433 as DNP).

### 4.3 Measuring power in low-power mode

To measure power in the low-power mode:

- 1. When using UART with FTDI:
  - a. Install jumper on JP26.
  - b. Remove jumper from JP12.
  - c. Connect FTDI cable to JP3, as shown in Figure 2.
  - d. Connect current meter to JP28 (IMCU\_MAIN), JP22 (IMCU\_VBAT), JP21 (IMCU\_VDDA), JP20 (IMCU\_VDD) as shown in Figure 1.
  - e. Connect power from J2 to PC through USB cable, as shown in Figure 2.
- 2. When using USB:
  - a. Remove jumper from JP26.
  - b. Install jumper on JP12.
  - c. Use the LPC-Link II UCom port.
  - d. Connect current meter to JP28 (IMCU\_MAIN), JP22 (IMCU\_VBAT), JP21 (IMCU\_VDDA), JP20 (IMCU\_VDD) as shown in Figure 1.
  - e. Connect power and MCU-Link onboard debugger from J1 to PC through USB cable, as shown in Figure 2.

### **NXP Semiconductors**

## AN13530

### LPC553x/LPC55S3x Low-power Modes and Wake-up Time



## AN13530

### LPC553x/LPC55S3x Low-power Modes and Wake-up Time



- 3. Launch a serial terminal application, such as TeraTerm.
- 4. Select the LPC553x/LPC55S3x serial port and configure the following settings for the serial console:
  - 115200 baud rate
  - No parity
  - 8 data bits
  - 1 stop bits
- 5. Reset the board using the SW2 (RESET) switch. The following output appears at the serial terminal.



- Figure 3. Console window
- 6. Take current measurement from the current meter.
  - Note: For details about waking up the device from various low-power modes, see Section 4.
- 7. Repeat steps 5 7 to take next measurements after the device wakes up from the low-power mode.

### 4.4 Measuring wake-up time

The wake-up time for the Sleep mode can be measured between the I/O line ( $P0_17$ ) pulled low (press SW3 (USR) switch to wake up LPC553x/LPC55S3x) and the I/O line ( $P0_22$ ) going high, as this I/O line is pulled high at the second instruction inside the group (SW3) interrupt service routine.

The wake-up time for the Deep sleep mode can be measured between the I/O line ( $P1_{18}$ ) pulled low (on SW1 (WK\_TMP) switch press to wake up the LPC553x/LPC55S3x) and the I/O line ( $P0_{22}$ ) going high, as this I/O line is pulled high at the first instruction inside the pin (SW1) interrupt service routine.

The two wake-up sources for the LPC553x/LPC55S3x Power-down mode are as follows:

- **Group interrupt:** The wake-up time can be measured between I/O line (P0\_17) being pulled low (press SW3 (USR) switch to wake up LPC553x/LPC55S3x) and I/O line (P0\_22) going high, as this I/O line is pulled high at the second instruction inside the group (SW3) interrupt service routine.
- **RESETN pin:** LPC553x/LPC55S3x can wake up by providing low pulse to the RESETN pin, by pressing the SW2 (RESET) switch.

The wake-up time can be measured between the RESETN pin going high (when we press and release SW2 (RESET) switch to wake up LPC553x/LPC55S3x) and I/O line ( $P0_{22}$ ) going high, as this I/O line is pulled high at the 17th instruction inside the reset handler.

The two wake-up sources for the LPC553x/LPC55S3x deep Power down mode are as follows:

- Wake-up pin: The wake-up time can be measured between the I/O line (P1\_18) pulled low (press SW1 (WK\_TMP) switch to wake up LPC553x/LPC55S3x) and I/O line (P0\_22) going high, as this I/O line is pulled high at the 17th instruction inside the reset handler.
- **RESETN pin:** LPC553x/LPC55S3x can wake up by providing low pulse to the RESETN pin, by pressing the SW2 (RESET) switch.

The wake-up time can be measured between the RESETN pin going high (when we press and release the SW2 (RESET) switch to wake up LPC553x/LPC55S3x) and the I/O line ( $P0_{22}$ ) going high, as this I/O line is pulled high at the 17th instruction inside the reset handler.

### 4.4.1 Measuring wake-up time from Sleep mode and Deep sleep mode

To measure the wake-up time from the Sleep or Deep sleep mode:

- 1. Wake up LPC553x/LPC55S3x from the Sleep or Deep sleep mode:
  - To wake up from the Sleep mode, connect P0\_17 (configured as the source of a group interrupt) to an oscilloscope probe as trigger input. P0\_17 can be accessed from JP73.2.
  - To wake up from the Deep sleep mode, connect P1\_18 (configured as the source of a pin interrupt) to an oscilloscope probe as trigger input. P1\_18 can be accessed from R43, R46, C32, SW1 (WK\_TMP).
- 2. Connect P0 22 to another oscilloscope probe. P0 22 can be accessed from J12.8.
- 3. Connect both oscilloscope probes with GND on TP19. Once the connections are done, power up the board by connecting the USB cable between J1 (if using USB with MCU-Link) or J2 (if using UART with FTDI) and PC.
- 4. Select the Sleep or Deep sleep mode as the low-power mode by entering 1 or 2 from the keyboard.
- 5. Wake up LPC553x/LPC55S3x from the Sleep or Deep sleep mode
  - To wake up from the Sleep mode, press the SW3 (USR) switch.
  - To wake up from the Deep sleep mode, press the SW1 (WK TMP) switch.
- 6. Measure wake-up time:
  - For the Sleep mode, measure the time passed on the oscilloscope between the P0\_17 wake-up pin going low to the P0\_22 pin going high as shown in the following figure.

AN13530



Figure 4. Wake-up time measurements for Sleep mode

• For the Deep sleep mode, measure the time passed on the oscilloscope between the P1\_18 wake-up pin going low to the P0\_22 pin going high as shown in the following figure.



Figure 5. Wake-up time measurements for Deep sleep mode

### 4.4.2 Measuring wake-up time from Power-down mode and Deep power-down mode

To measure the wake-up time from the Power down or Deep power-down mode:

- 1. Wake up LPC553x/LPC55S3x from the Power-down or Deep power-down mode:
  - To wake up from the Power-down mode, connect P0\_17 (configured as the source of a group interrupt) to an oscilloscope probe as trigger input. P0\_17 can be accessed from JP73.2. Or, connect the RESETN pin to an oscilloscope probe as trigger input. The RESETN pin can be accessed from J102.6.
  - To wake up from the Deep power-down mode, connect P1\_18 (configured as the source of a wake up pin) to an oscilloscope probe as trigger input. P1\_18 can be accessed from R43, R46, C32, SW1 (WK\_TMP). Or, connect the RESETN pin to an oscilloscope probe as trigger input. The RESETN pin can be accessed from J102.6.
- 2. Connect  $P0_{22}$  to another oscilloscope probe.  $P0_{22}$  can be accessed from J12.8.
- 3. Connect both oscilloscope probes with GND on TP19. Once the connections are done, power up the board by connecting the USB cable between J1 (if using USB with MCU-Link) or J2 (if using UART with FTDI) and PC.
- 4. Select the Power-down or Deep power-down mode as the low-power mode by entering 3 or 4 from the keyboard.
- 5. After entering 3 or 4, press any other key on the keyboard to confirm if LPC553x/LPC55S3x is in the Powerdown or Deep power-down mode.
- 6. Wake up LPC553x/LPC55S3x from the Power-down or Deep power-down mode:
  - To wake up from the Power-down mode, use group interrupt (on SW3 (USR) switch press).

- To wake up from the Deep power-down mode, use the wake-up pin (on SW1 (WK\_TMP) switch press).
- 7. Measure wake-up time:
  - For wake-up from the Power-down mode using group interrupt (on SW3 (USR) switch press), measure time passed on the oscilloscope between the P0\_17 wake-up pin going low to the P0\_22 pin going high as shown in the following figure.



Figure 6. Wake-up time measurement for Power-down Mode using group interrupt

• For wake-up from the Deep power-down mode using the wake-up pin (on SW1 (WK\_TMP) switch press), measure time passed on the oscilloscope between the P0\_18 wake-up pin going low to the P0\_22 pin going high as shown in the following figure.



Figure 7. Wake-up time measurement for Deep power-down mode using wake-up pin

8. Measure wake-up time for wake-up from the Power-down or Deep power-down mode using the RESETN pin (on SW2 (RESET) switch press).

• For wake up from the Power-down mode, measure time passed on the oscilloscope between the RESETN pin going high to the P0 22 pin going high as shown in Figure 7.



Figure 8. Wake-up time measurements for Power-down mode using RESETN pin

• For wake-up from the Deep power-down mode, measure time passed on the oscilloscope between the RESETN pin going high to the P0\_22 pin going high as shown in the following figure.



Figure 9. Wake-up time measurements for Deep power-down mode using RESETN pin

### 4.5 Typical (IAR IDE) low-power mode current and wake-up time

| Low-power<br>mode  | Measurement parameter                                         | Observation      |                                                     |
|--------------------|---------------------------------------------------------------|------------------|-----------------------------------------------------|
|                    |                                                               | Current value    | Wake-up time                                        |
| Sleep              | VDD_MAIN = 3.3 V, 12 MHz                                      | 2.448 mA         | 3.14 µs                                             |
| Deep sleep         | VDD_MAIN = 3.3 V, all RAM retained (128 kB)                   | 97.9 µA          | 74.75 μs                                            |
| Power down         | VDD_MAIN = 3.3 V, RAM_00/RAM_01<br>retained (8 kB)            | 7.7 μA<br>8.1 μA | 405.5 μs (group interrupt)<br>2.947 ms (RESETN pin) |
|                    | VDD_MAIN = 3.3 V, RAM_X0/RAM_00/<br>RAM_01 retained (24 kB)   | 12.2 µA          | 405.3 μs (group interrupt)<br>2.947 ms (RESETN pin) |
|                    | VDD_MAIN = 3.3 V, all RAM retained (128 kB)                   |                  | 404.6 us (group interrupt)<br>2.947 ms (RESETN pin) |
| Deep power<br>down | VDD_MAIN = 3.3 V, RTC disabled,<br>RAM_00 not retained (4 kB) | 1.6 μΑ<br>1.8 μΑ | 2.866 ms (wake-up pin)<br>2.947 ms (RESETN pin)     |
|                    | VDD_MAIN = 3.3 V, RTC disabled,<br>RAM_00 retained (4 kB)     |                  | 2.866 ms (wake-up pin)<br>2.947 ms (RESETN pin)     |

Table 26. Typical (IAR IDE) low-power mode current and wake-up time

### 5 Conclusion

LPC553x/LPC55S3x provide great flexibility and multiple options for the user to achieve low-power consumption with the required wake-up configuration. This flexibility allows a trade-off between power consumption and wake-up speed based on the application requirements of the user.

### 6 Revision history

Table 27 summarizes revisions to this document.

| Table 21. Revision motory |                   |                                                                                                      |  |
|---------------------------|-------------------|------------------------------------------------------------------------------------------------------|--|
| Revision number           | Release date      | Description                                                                                          |  |
| 2                         | 04 September 2023 | <ul> <li>Updated software package</li> <li>Updated <u>Section 4.1</u></li> </ul>                     |  |
| 1                         | 11 May 2022       | Replaced Low-power Modes and Wake-up Time with LPC553x/<br>LPC55S3x Low-power Modes and Wake-up Time |  |
| 0                         | 11 February 2022  | Initial public release                                                                               |  |

## AN13530

### LPC553x/LPC55S3x Low-power Modes and Wake-up Time

#### Legal information 7

### 7.1 Definitions

Draft - A draft status on a document indicates that the content is still under internal review and subject to formal approval, which may result in modifications or additions. NXP Semiconductors does not give any representations or warranties as to the accuracy or completeness of information included in a draft version of a document and shall have no liability for the consequences of use of such information.

### 7.2 Disclaimers

Limited warranty and liability - Information in this document is believed to be accurate and reliable. However, NXP Semiconductors does not give any representations or warranties, expressed or implied, as to the accuracy or completeness of such information and shall have no liability for the consequences of use of such information. NXP Semiconductors takes no responsibility for the content in this document if provided by an information source outside of NXP Semiconductors.

In no event shall NXP Semiconductors be liable for any indirect, incidental, punitive, special or consequential damages (including - without limitation lost profits, lost savings, business interruption, costs related to the removal or replacement of any products or rework charges) whether or not such damages are based on tort (including negligence), warranty, breach of contract or any other legal theory.

Notwithstanding any damages that customer might incur for any reason whatsoever, NXP Semiconductors' aggregate and cumulative liability towards customer for the products described herein shall be limited in accordance with the Terms and conditions of commercial sale of NXP Semiconductors

Right to make changes - NXP Semiconductors reserves the right to make changes to information published in this document, including without limitation specifications and product descriptions, at any time and without notice. This document supersedes and replaces all information supplied prior to the publication hereof.

Suitability for use - NXP Semiconductors products are not designed, authorized or warranted to be suitable for use in life support, life-critical or safety-critical systems or equipment, nor in applications where failure or malfunction of an NXP Semiconductors product can reasonably be expected to result in personal injury, death or severe property or environmental damage. NXP Semiconductors and its suppliers accept no liability for inclusion and/or use of NXP Semiconductors products in such equipment or applications and therefore such inclusion and/or use is at the customer's own risk

Applications — Applications that are described herein for any of these products are for illustrative purposes only. NXP Semiconductors makes no representation or warranty that such applications will be suitable for the specified use without further testing or modification.

Customers are responsible for the design and operation of their applications and products using NXP Semiconductors products, and NXP Semiconductors accepts no liability for any assistance with applications or customer product design. It is customer's sole responsibility to determine whether the NXP Semiconductors product is suitable and fit for the customer's applications and products planned, as well as for the planned application and use of customer's third party customer(s). Customers should provide appropriate design and operating safeguards to minimize the risks associated with their applications and products.

NXP Semiconductors does not accept any liability related to any default, damage, costs or problem which is based on any weakness or default in the customer's applications or products, or the application or use by customer's third party customer(s). Customer is responsible for doing all necessary testing for the customer's applications and products using NXP Semiconductors products in order to avoid a default of the applications and the products or of the application or use by customer's third party customer(s). NXP does not accept any liability in this respect.

Terms and conditions of commercial sale - NXP Semiconductors products are sold subject to the general terms and conditions of commercial sale, as published at http://www.nxp.com/profile/terms, unless otherwise agreed in a valid written individual agreement. In case an individual agreement is concluded only the terms and conditions of the respective agreement shall apply. NXP Semiconductors hereby expressly objects to applying the customer's general terms and conditions with regard to the purchase of NXP Semiconductors products by customer.

Export control — This document as well as the item(s) described herein may be subject to export control regulations. Export might require a prior authorization from competent authorities.

Suitability for use in non-automotive qualified products - Unless this data sheet expressly states that this specific NXP Semiconductors product is automotive qualified, the product is not suitable for automotive use. It is neither qualified nor tested in accordance with automotive testing or application requirements. NXP Semiconductors accepts no liability for inclusion and/or use of non-automotive qualified products in automotive equipment or applications.

In the event that customer uses the product for design-in and use in automotive applications to automotive specifications and standards, customer (a) shall use the product without NXP Semiconductors' warranty of the product for such automotive applications, use and specifications, and (b) whenever customer uses the product for automotive applications beyond NXP Semiconductors' specifications such use shall be solely at customer's own risk, and (c) customer fully indemnifies NXP Semiconductors for any liability, damages or failed product claims resulting from customer design and use of the product for automotive applications beyond NXP Semiconductors' standard warranty and NXP Semiconductors' product specifications.

Translations — A non-English (translated) version of a document, including the legal information in that document, is for reference only. The English version shall prevail in case of any discrepancy between the translated and English versions.

Security - Customer understands that all NXP products may be subject to unidentified vulnerabilities or may support established security standards or specifications with known limitations. Customer is responsible for the design and operation of its applications and products throughout their lifecycles to reduce the effect of these vulnerabilities on customer's applications and products. Customer's responsibility also extends to other open and/or proprietary technologies supported by NXP products for use in customer's applications. NXP accepts no liability for any vulnerability. Customer should regularly check security updates from NXP and follow up appropriately. Customer shall select products with security features that best meet rules, regulations, and standards of the intended application and make the ultimate design decisions regarding its products and is solely responsible for compliance with all legal, regulatory, and security related requirements concerning its products, regardless of any information or support that may be provided by NXP.

NXP has a Product Security Incident Response Team (PSIRT) (reachable at PSIRT@nxp.com) that manages the investigation, reporting, and solution release to security vulnerabilities of NXP products.

NXP B.V. - NXP B.V. is not an operating company and it does not distribute or sell products.

### 7.3 Trademarks

Notice: All referenced brands, product names, service names, and trademarks are the property of their respective owners.

NXP — wordmark and logo are trademarks of NXP B.V.

AN13530

AMBA, Arm, Arm7, Arm7TDMI, Arm9, Arm11, Artisan, big.LITTLE, Cordio, CoreLink, CoreSight, Cortex, DesignStart, DynamIQ, Jazelle, Keil, Mali, Mbed, Mbed Enabled, NEON, POP, RealView, SecurCore, Socrates, Thumb, TrustZone, ULINK, ULINK2, ULINK-ME, ULINK-PLUS, ULINKpro, µVision, Versatile — are trademarks and/or registered trademarks of Arm Limited (or its subsidiaries or affiliates) in the US and/or elsewhere. The related technology may be protected by any or all of patents, copyrights, designs and trade secrets. All rights reserved.

## AN13530

### LPC553x/LPC55S3x Low-power Modes and Wake-up Time

### Contents

| 1     | Introduction                             | 2   |
|-------|------------------------------------------|-----|
| 2     | Low-power modes                          | 2   |
| 2.1   | Active mode                              | 2   |
| 2.2   | Sleep mode                               | 3   |
| 2.3   | Deep sleep mode                          |     |
| 2.4   | Power-down mode                          |     |
| 2.5   | Deep Power-down mode                     | 4   |
| 2.6   | Low-power mode summary                   | 4   |
| 3     | Entering Low-power Modes and Waking      |     |
|       | up                                       | 6   |
| 3.1   | Power control API                        |     |
| 3.1.1 | POWER_EnterSleep                         |     |
| 3.1.2 | POWER_EnterDeepSleep                     |     |
| 3.1.3 | POWER_EnterPowerDown                     |     |
| 3.1.4 | POWER_EnterDeepPowerDown                 |     |
| 3.2   | Sleep mode                               |     |
| 3.2.1 | Entering Sleep mode                      |     |
| 3.2.2 | Waking up from Sleep mode                |     |
| 3.3   | Deep sleep mode                          |     |
| 3.3.1 | Entering Deep sleep mode                 |     |
| 3.3.2 | Waking up from Deep sleep mode           |     |
| 3.4   | Power-down mode                          |     |
| 3.4.1 | Entering Power-down mode                 |     |
| 3.4.2 | Waking up from Power-down mode           |     |
| 3.5   | Deep power-down mode                     |     |
| 3.5.1 | Entering Deep power-down mode            |     |
| 3.5.2 | Waking up from Deep power-down mode      |     |
| 4     | Low-power mode Demo                      |     |
| 4.1   | Software setup                           |     |
| 4.2   | Hardware setup                           |     |
| 4.3   | Measuring power in low-power mode        |     |
| 4.4   | Measuring wake-up time                   | 29  |
| 4.4.1 | Measuring wake-up time from Sleep mode   | ~~  |
| 4.4.0 | and Deep sleep mode                      | 29  |
| 4.4.2 | Measuring wake-up time from Power-down   | ~ 4 |
|       | mode and Deep power-down mode            | 31  |
| 4.5   | Typical (IAR IDE) low-power mode current | 0-  |
| -     | and wake-up time                         |     |
| 5     | Conclusion                               |     |
| 6     | Revision history                         |     |
| 7     | Legal information                        | 37  |

Please be aware that important notices concerning this document and the product(s) described herein, have been included in section 'Legal information'.

### © 2023 NXP B.V.

All rights reserved.

For more information, please visit: http://www.nxp.com