Zephyr API Documentation 4.3.0-rc1
A Scalable Open Source RTOS
Loading...
Searching...
No Matches

System Power Management Policy API. More...

Data Structures

struct  pm_policy_latency_subscription
 Latency change subscription. More...
struct  pm_policy_latency_request
 Latency request. More...
struct  pm_policy_event
 Event. More...

Macros

#define PM_ALL_SUBSTATES   (UINT8_MAX)
 Special value for 'all substates'.

Typedefs

typedef void(* pm_policy_latency_changed_cb_t) (int32_t latency)
 Callback to notify when maximum latency changes.

Functions

void pm_policy_state_lock_get (enum pm_state state, uint8_t substate_id)
 Increase a power state lock counter.
void pm_policy_state_lock_put (enum pm_state state, uint8_t substate_id)
 Decrease a power state lock counter.
void pm_policy_state_all_lock_get (void)
 Request to lock all power states.
void pm_policy_state_all_lock_put (void)
 Release locking of all power states.
void pm_policy_state_constraints_get (struct pm_state_constraints *constraints)
 Apply power state constraints by locking the specified states.
void pm_policy_state_constraints_put (struct pm_state_constraints *constraints)
 Remove power state constraints by unlocking the specified states.
bool pm_policy_state_lock_is_active (enum pm_state state, uint8_t substate_id)
 Check if a power state lock is active (not allowed).
bool pm_policy_state_is_available (enum pm_state state, uint8_t substate_id)
 Check if a power state is available.
bool pm_policy_state_any_active (void)
 Check if any power state can be used.
void pm_policy_event_register (struct pm_policy_event *evt, int64_t uptime_ticks)
 Register an event.
void pm_policy_event_update (struct pm_policy_event *evt, int64_t uptime_ticks)
 Update an event.
void pm_policy_event_unregister (struct pm_policy_event *evt)
 Unregister an event.
bool pm_policy_device_is_disabling_state (const struct device *dev, enum pm_state state, uint8_t substate_id)
 Check if a state will disable a device.
int64_t pm_policy_next_event_ticks (void)
 Returns the ticks until the next event.
void pm_policy_device_power_lock_get (const struct device *dev)
 Increase power state locks.
void pm_policy_device_power_lock_put (const struct device *dev)
 Decrease power state locks.
void pm_policy_latency_request_add (struct pm_policy_latency_request *req, uint32_t value_us)
 Add a new latency requirement.
void pm_policy_latency_request_update (struct pm_policy_latency_request *req, uint32_t value_us)
 Update a latency requirement.
void pm_policy_latency_request_remove (struct pm_policy_latency_request *req)
 Remove a latency requirement.
void pm_policy_latency_changed_subscribe (struct pm_policy_latency_subscription *req, pm_policy_latency_changed_cb_t cb)
 Subscribe to maximum latency changes.
void pm_policy_latency_changed_unsubscribe (struct pm_policy_latency_subscription *req)
 Unsubscribe to maximum latency changes.

Detailed Description

System Power Management Policy API.

Macro Definition Documentation

◆ PM_ALL_SUBSTATES

#define PM_ALL_SUBSTATES   (UINT8_MAX)

#include <zephyr/pm/policy.h>

Special value for 'all substates'.

Typedef Documentation

◆ pm_policy_latency_changed_cb_t

typedef void(* pm_policy_latency_changed_cb_t) (int32_t latency)

#include <zephyr/pm/policy.h>

Callback to notify when maximum latency changes.

Parameters
latencyNew maximum latency. Positive value represents latency in microseconds. SYS_FOREVER_US value lifts the latency constraint. Other values are forbidden.

Function Documentation

◆ pm_policy_device_is_disabling_state()

bool pm_policy_device_is_disabling_state ( const struct device * dev,
enum pm_state state,
uint8_t substate_id )

#include <zephyr/pm/policy.h>

Check if a state will disable a device.

This function allows client code to check if a state will disable a device.

Parameters
devDevice reference.
stateThe state to check on whether it disables the device.
substate_idThe substate to check on whether it disables the device.
Return values
trueif the state disables the device
falseif the state does not disable the device

◆ pm_policy_device_power_lock_get()

void pm_policy_device_power_lock_get ( const struct device * dev)

#include <zephyr/pm/policy.h>

Increase power state locks.

Set power state locks in all power states that disable power in the given device.

Parameters
devDevice reference.
See also
pm_policy_device_power_lock_put()
pm_policy_state_lock_get()

◆ pm_policy_device_power_lock_put()

void pm_policy_device_power_lock_put ( const struct device * dev)

#include <zephyr/pm/policy.h>

Decrease power state locks.

Remove power state locks in all power states that disable power in the given device.

Parameters
devDevice reference.
See also
pm_policy_device_power_lock_get()
pm_policy_state_lock_put()

◆ pm_policy_event_register()

void pm_policy_event_register ( struct pm_policy_event * evt,
int64_t uptime_ticks )

#include <zephyr/pm/policy.h>

Register an event.

Events in the power-management policy context are defined as any source that will wake up the system at a known time in the future. By registering such event, the policy manager will be able to decide whether certain power states are worth entering or not.

CPU is woken up before the time passed in cycle to minimize event handling latency. Once woken up, the CPU will be kept awake until the event has been handled, which is signaled by pm_policy_event_unregister() or moving event into the future using pm_policy_event_update().

Parameters
evtEvent.
uptime_ticksWhen the event will occur, in uptime ticks.
See also
pm_policy_event_unregister()

◆ pm_policy_event_unregister()

void pm_policy_event_unregister ( struct pm_policy_event * evt)

#include <zephyr/pm/policy.h>

Unregister an event.

Parameters
evtEvent.
See also
pm_policy_event_register

◆ pm_policy_event_update()

void pm_policy_event_update ( struct pm_policy_event * evt,
int64_t uptime_ticks )

#include <zephyr/pm/policy.h>

Update an event.

This shortcut allows for moving the time an event will occur without the need for an unregister + register cycle.

Parameters
evtEvent.
uptime_ticksWhen the event will occur, in uptime ticks.
See also
pm_policy_event_register

◆ pm_policy_latency_changed_subscribe()

void pm_policy_latency_changed_subscribe ( struct pm_policy_latency_subscription * req,
pm_policy_latency_changed_cb_t cb )

#include <zephyr/pm/policy.h>

Subscribe to maximum latency changes.

Parameters
reqSubscription request.
cbCallback function (NULL to disable).

◆ pm_policy_latency_changed_unsubscribe()

void pm_policy_latency_changed_unsubscribe ( struct pm_policy_latency_subscription * req)

#include <zephyr/pm/policy.h>

Unsubscribe to maximum latency changes.

Parameters
reqSubscription request.

◆ pm_policy_latency_request_add()

void pm_policy_latency_request_add ( struct pm_policy_latency_request * req,
uint32_t value_us )

#include <zephyr/pm/policy.h>

Add a new latency requirement.

The system will not enter any power state that would make the system to exceed the given latency value.

Parameters
reqLatency request.
value_usMaximum allowed latency in microseconds.

◆ pm_policy_latency_request_remove()

void pm_policy_latency_request_remove ( struct pm_policy_latency_request * req)

#include <zephyr/pm/policy.h>

Remove a latency requirement.

Parameters
reqLatency request.

◆ pm_policy_latency_request_update()

void pm_policy_latency_request_update ( struct pm_policy_latency_request * req,
uint32_t value_us )

#include <zephyr/pm/policy.h>

Update a latency requirement.

Parameters
reqLatency request.
value_usNew maximum allowed latency in microseconds.

◆ pm_policy_next_event_ticks()

int64_t pm_policy_next_event_ticks ( void )

#include <zephyr/pm/policy.h>

Returns the ticks until the next event.

If an event is registred, it will return the number of ticks until the next event, if the "next"/"oldest" registered event is in the past, it will return 0. Otherwise it returns -1.

Return values
>0If next registered event is in the future
0If next registered event is now or in the past
-1Otherwise

◆ pm_policy_state_all_lock_get()

void pm_policy_state_all_lock_get ( void )

#include <zephyr/pm/policy.h>

Request to lock all power states.

Requests use a reference counter.

◆ pm_policy_state_all_lock_put()

void pm_policy_state_all_lock_put ( void )

#include <zephyr/pm/policy.h>

Release locking of all power states.

◆ pm_policy_state_any_active()

bool pm_policy_state_any_active ( void )

#include <zephyr/pm/policy.h>

Check if any power state can be used.

Function allows to quickly check if any power state is available and exit suspend operation early.

Return values
trueif any power state is active.
falseif all power states are unavailable.

◆ pm_policy_state_constraints_get()

void pm_policy_state_constraints_get ( struct pm_state_constraints * constraints)

#include <zephyr/pm/policy.h>

Apply power state constraints by locking the specified states.

This function locks all power states specified in the union of all constraints in the provided constraint list. Each constraint in the set contributes to determining which power states should be locked (not allowed), by increasing a reference count just as if pm_policy_state_lock_get was called on each constraints' states individually.

Parameters
constraintsPointer to the power state constraints set to apply.
See also
pm_policy_state_constraints_put()

◆ pm_policy_state_constraints_put()

void pm_policy_state_constraints_put ( struct pm_state_constraints * constraints)

#include <zephyr/pm/policy.h>

Remove power state constraints by unlocking the specified states.

This function unlocks all power states that were previously locked by a corresponding call to pm_policy_state_constraints_get() with the same constraint set. The function decreases the lock counter for each affected power state specified in the union of all constraints in the list, just as if pm_policy_state_put was called on all the constraints' states individually.

Parameters
constraintsPointer to the power state constraints set to remove.
See also
pm_policy_state_constraints_get()

◆ pm_policy_state_is_available()

bool pm_policy_state_is_available ( enum pm_state state,
uint8_t substate_id )

#include <zephyr/pm/policy.h>

Check if a power state is available.

It is unavailable if locked or latency requirement cannot be fulfilled in that state.

Parameters
statePower state.
substate_idPower substate ID. Use PM_ALL_SUBSTATES to affect all the substates in the given power state.
Return values
trueif power state is active.
falseif power state is not active.

◆ pm_policy_state_lock_get()

void pm_policy_state_lock_get ( enum pm_state state,
uint8_t substate_id )

#include <zephyr/pm/policy.h>

Increase a power state lock counter.

A power state will not be allowed on the first call of pm_policy_state_lock_get(). Subsequent calls will just increase a reference count, thus meaning this API can be safely used concurrently. A state will be allowed again after pm_policy_state_lock_put() is called as many times as pm_policy_state_lock_get().

Note that the PM_STATE_ACTIVE state is always allowed, so calling this API with PM_STATE_ACTIVE will have no effect.

Parameters
statePower state.
substate_idPower substate ID. Use PM_ALL_SUBSTATES to affect all the substates in the given power state.
See also
pm_policy_state_lock_put()

◆ pm_policy_state_lock_is_active()

bool pm_policy_state_lock_is_active ( enum pm_state state,
uint8_t substate_id )

#include <zephyr/pm/policy.h>

Check if a power state lock is active (not allowed).

Parameters
statePower state.
substate_idPower substate ID. Use PM_ALL_SUBSTATES to affect all the substates in the given power state.
Return values
trueif power state lock is active.
falseif power state lock is not active.

◆ pm_policy_state_lock_put()

void pm_policy_state_lock_put ( enum pm_state state,
uint8_t substate_id )

#include <zephyr/pm/policy.h>

Decrease a power state lock counter.

Parameters
statePower state.
substate_idPower substate ID. Use PM_ALL_SUBSTATES to affect all the substates in the given power state.
See also
pm_policy_state_lock_get()