Driver for the LPM peripheral on RA MCUs. This module implements the Low Power Modes Interface.
Overview
The low power modes driver is used to configure and place the device into the desired low power mode. Various sources can be configured to wake from standby, request snooze mode, end snooze mode or end deep standby mode.
Features
The LPM HAL module has the following key features:
- Supports the following low power modes:
- Deep Software Standby mode (On supported MCUs)
- Deep Sleep (On supported MCUs)
- Software Standby mode
- Sleep mode
- Snooze mode (On supported MCUs)
- Supports reducing power consumption when in deep software standby mode through internal power supply control and by resetting the states of I/O ports.
- Supports disabling and enabling the MCU's other hardware peripherals
Configuration
Build Time Configurations for r_lpm
The following build time configurations are defined in fsp_cfg/r_lpm_cfg.h:
Configuration | Options | Default | Description |
Parameter Checking |
-
Default (BSP)
-
Enabled
-
Disabled
| Default (BSP) | If selected code for parameter checking is included in the build. |
Standby Limit |
| Disabled | If enabled, standby configuration only applies in R_LPM_LowPowerModeEnter. Otherwise, standby configuration applies to any WFI call. |
Configurations for Power > Low Power Modes (r_lpm)
This module can be added to the Stacks tab via New Stack > Power > Low Power Modes (r_lpm). Non-secure callable guard functions can be generated for this module by right clicking the module in the RA Configuration tool and checking the "Non-secure Callable" box.
Configuration | Options | Default | Description |
General |
Name | Name must be a valid C symbol | g_lpm0 | Module name. |
Low Power Mode | MCU Specific Options | | Power mode to be entered. |
Output port state in standby and deep standby | MCU Specific Options | | Select the state of output pins during standby. Applies to address output, data output, and other bus control output pins. |
Supply of SOSC clock to peripheral function in standby | MCU Specific Options | | If enabled, SOSC clock is provided to peripheral functions in Software Standby and Snooze modes. |
Startup speed of the HOCO in Standby and Snooze modes | MCU Specific Options | | If enabled, the HOCO enters high-speed startup mode, shortening standby release time, and snooze transition time. |
Flash mode in sleep or snooze | MCU Specific Options | | Select flash mode in sleep mode or in snooze mode. |
Deep Sleep and Standby Options |
Deep Sleep and Standby Options > Snooze Options (Not available on every MCU) |
Snooze Request Source | MCU Specific Options | | Select the event that will enter snooze. |
Snooze End Sources | MCU Specific Options | | Enable wake from snooze from these sources. |
DTC state in Snooze Mode | MCU Specific Options | | Enable wake from snooze from this source. |
Snooze Cancel Source | MCU Specific Options | | Select an interrupt source to cancel snooze. |
Wake Sources | MCU Specific Options | | Enable wake from deep sleep and standby from these Sources. |
Wake Sources 2 | MCU Specific Options | | Enable wake from deep sleep and standby from these Sources. |
RAM Retention Control (Not available on every MCU) |
RAM retention in Standby mode | MCU Specific Options | | Select the memory regions that are retained in standby mode. |
TCM retention in Deep Sleep and Standby modes | MCU Specific Options | | Select if Tightly Coupled Memory (TCM) is retained in deep sleep and standby modes. |
Standby RAM retention in Standby and Deep Standby modes | MCU Specific Options | | Select if Standby RAM is retained in standby and deep standby modes. |
Oscillator LDO Control (Not available on every MCU) |
PLL1 LDO State in standby mode | MCU Specific Options | | Select the state PLL1 LDO state in standby mode. |
PLL2 LDO State in standby mode | MCU Specific Options | | Select the state PLL2 LDO state in standby mode. |
HOCO LDO State in standby mode | MCU Specific Options | | Select the state HOCO LDO state in standby mode. |
Deep Standby Options (Not available on every MCU) |
I/O Port Retention | MCU Specific Options | | Select the state of the IO Pins after exiting deep standby mode. |
Power-Supply Control | MCU Specific Options | | Select the state of the internal power supply in deep standby mode. |
Cancel Sources | MCU Specific Options | | Enable wake from deep standby using these sources. |
Cancel Edges | MCU Specific Options | | Falling edge trigger is default. Select sources to enable wake from deep standby with rising edge. |
Clock Configuration
This module does not have any selectable clock sources.
Pin Configuration
This module does not use I/O pins.
Usage Notes
Sleep Mode
At power on, by default sleep is set as the low-power mode. Sleep mode is the most convenient low-power mode available, as it does not require any special configuration (other than configuring and enabling a suitable interrupt or event to wake the MCU from sleep) to return to normal program-execution mode. The states of the SRAM, the processor registers, and the hardware peripherals are all maintained in sleep mode, and the time needed to enter and wake from sleep is minimal. Any interrupt causes the MCU device to wake from sleep mode, including the SysTick interrupt used by the RTOS scheduler.
Deep Sleep Mode
Deep sleep mode is similar to sleep mode with the exception that DTC and DMAC are stopped, access to TCM memory is not available, and only a subset of interrupts are available for waking the CPU.
Software Standby Mode
In software-standby mode, the CPU, as well as most of the on-chip peripheral functions and all of the internal oscillators, are stopped. The contents of the CPU internal registers and SRAM data, the states of on-chip peripheral functions, and I/O Ports are all retained. Software-standby mode allows significant reduction in power consumption, because most of the oscillators are stopped in this mode. Like sleep mode, standby mode requires an interrupt or event be configured and enabled to wake up.
Snooze Mode
Snooze mode can be used with some MCU peripherals to execute basic tasks while keeping the MCU in a low-power state. Many core peripherals and all clocks can be selected to run during Snooze, allowing for more flexible low-power configuration than Software Standby mode. To enable Snooze, select "Software Standby mode with Snooze mode enabled" for the "Low Power Mode" configuration option. Snooze mode settings (including entry/exit sources) are available under "Standby Options".
Deep Software Standby Mode
The MCU always wakes from Deep Software Standby Mode by going through reset, either by the negation of the reset pin or by one of the wakeup sources configurable in the "Deep Standby Options" configuration group.
The Reset Status Registers can be used to determine if the reset occurred after coming out of deep software standby. For example, R_SYSTEM->RSTSR0_b.DPSRSTF is set to 1 after a deep software standby reset.
I/O Port Retention can be enabled to maintain I/O port configuration across a deep software standby reset. Retention can be cancelled through the R_LPM_IoKeepClear API.
Limitations
Developers should be aware of the following limitations when using the LPM:
- Flash stop (code flash disable) is not supported. See the section "Flash Operation Control Register (FLSTOP)" of the RA2/RA4 Family Hardware User's Manual.
- Reduced SRAM retention area in software standby mode is not supported. See the section "Power Save Memory Control Register (PSMCR)" of the RA4 Hardware User's Manual.
- Only one Snooze Request Source can be used at a time.
- When using Snooze mode with SCI0 RXD as the snooze source the system clock must be HOCO and the MOCO, Main Oscillator and PLL clocks must be turned off.
- If the main oscillator or PLL with main oscillator source is used for the system clock, the wake time from standby mode can be affected by the Main Oscillator Wait Time Setting in the MOSCWTCR register. This register setting is available to be changed through the Main Oscillator Wait Time setting in the CGC module properties. See the "Wakeup Timing and Duration" table in Electrical Characteristics for more information.
- When using the DC-DC regulator (where available), the MCU will temporarily switch to the LDO if Software Standby or Snooze is requested and back again when it is cancelled. Switching to the LDO incurs a 60 microsecond critical section wherein all interrupts AND peripherals are stopped. Switching back to DCDC from the LDO incurs an additional 22 microsecond critical section (peripherals running).
- On RA8, there are delays inserted before and after switching to a lower power mode based on BSP configuration options and current CPUCLK speed. These delays do not disable interrupts for the entire delay as required by the RA8 Hardware Manual. Interrupts should be disabled by the application when possible before sleeping to meet the requirements, or the control of interrupts and the delay should be managed by the user to ensure the requirement is fully met.
Examples
LPM Sleep Example
This is a basic example of minimal use of the LPM in an application. The LPM instance is opened and the configured low-power mode is entered.
void r_lpm_sleep (void)
{
assert(FSP_SUCCESS == err);
assert(FSP_SUCCESS == err);
}
LPM Deep Software Standby Example
void r_lpm_deep_software_standby (void)
{
#if !BSP_MCU_GROUP_RA0E1
if (1U == R_SYSTEM->RSTSR0_b.DPSRSTF)
{
assert(FSP_SUCCESS == err);
}
#endif
err =
R_LPM_Open(&g_lpm_ctrl, &g_lpm_cfg_deep_software_standby);
assert(FSP_SUCCESS == err);
assert(FSP_SUCCESS == err);
assert(FSP_SUCCESS == err);
}
◆ lpm_instance_ctrl_t
struct lpm_instance_ctrl_t |
LPM private control block. DO NOT MODIFY. Initialization occurs when R_LPM_Open() is called.
◆ R_LPM_Open()
Perform any necessary initialization
- Return values
-
FSP_SUCCESS | LPM instance opened |
FSP_ERR_ASSERTION | Null Pointer |
FSP_ERR_ALREADY_OPEN | LPM instance is already open |
FSP_ERR_UNSUPPORTED | This MCU does not support Deep Software Standby |
FSP_ERR_INVALID_ARGUMENT | One of the following:
- Invalid snooze entry source
- Invalid snooze end sources
|
FSP_ERR_INVALID_MODE | One of the following:
- Invalid low power mode
- Invalid DTC option for snooze mode
- Invalid deep standby end sources
- Invalid deep standby end sources edges
- Invalid power supply option for deep standby
- Invalid IO port option for deep standby
- Invalid output port state setting for standby or deep standby
- Invalid sources for wake from standby mode
- Invalid power supply option for standby
- Invalid IO port option for standby
- Invalid standby end sources
- Invalid standby end sources edges
|
◆ R_LPM_LowPowerReconfigure()
Configure a low power mode
NOTE: This function does not enter the low power mode, it only configures parameters of the mode. Execution of the WFI instruction is what causes the low power mode to be entered.
- Return values
-
FSP_SUCCESS | Low power mode successfuly applied |
FSP_ERR_ASSERTION | Null Pointer |
FSP_ERR_NOT_OPEN | LPM instance is not open |
FSP_ERR_UNSUPPORTED | This MCU does not support Deep Software Standby |
FSP_ERR_INVALID_ARGUMENT | One of the following:
- Invalid snooze entry source
- Invalid snooze end sources
|
FSP_ERR_INVALID_MODE | One of the following:
- Invalid low power mode
- Invalid DTC option for snooze mode
- Invalid deep standby end sources
- Invalid deep standby end sources edges
- Invalid power supply option for deep standby
- Invalid IO port option for deep standby
- Invalid output port state setting for standby or deep standby
- Invalid sources for wake from standby mode
- Invalid power supply option for standby
- Invalid IO port option for standby
- Invalid standby end sources
- Invalid standby end sources edges
|
◆ R_LPM_LowPowerModeEnter()
Enter low power mode (sleep/deep sleep/standby/deep standby) using WFI macro.
Function will return after waking from low power mode.
- Return values
-
FSP_SUCCESS | Successful. |
FSP_ERR_ASSERTION | Null pointer. |
FSP_ERR_NOT_OPEN | LPM instance is not open |
FSP_ERR_INVALID_MODE | One of the following:
- HOCO was not system clock when using snooze mode with SCI0/RXD0.
- HOCO was not stable when using snooze mode with SCI0/RXD0.
- MOCO was running when using snooze mode with SCI0/RXD0.
- MAIN OSCILLATOR was running when using snooze mode with SCI0/RXD0.
- PLL was running when using snooze mode with SCI0/RXD0.
- Unable to disable ocillator stop detect when using standby or deep standby.
|
◆ R_LPM_IoKeepClear()
Clear the IOKEEP bit after deep software standby
- Return values
-
FSP_SUCCESS | DPSBYCR_b.IOKEEP bit cleared Successfully. |
FSP_ERR_UNSUPPORTED | Deep standby mode not supported on this MCU. |
◆ R_LPM_Close()
Close the LPM Instance
- Return values
-
FSP_SUCCESS | LPM driver closed |
FSP_ERR_NOT_OPEN | LPM instance is not open |
FSP_ERR_ASSERTION | Null Pointer |