Zephyr API Documentation  3.5.0
A Scalable Open Source RTOS
3.5.0
All Data Structures Files Functions Variables Typedefs Enumerations Enumerator Macros Modules Pages
pm.h
Go to the documentation of this file.
1/*
2 * Copyright (c) 2012-2014 Wind River Systems, Inc.
3 *
4 * SPDX-License-Identifier: Apache-2.0
5 */
6
7#ifndef ZEPHYR_INCLUDE_PM_PM_H_
8#define ZEPHYR_INCLUDE_PM_PM_H_
9
10#include <zephyr/types.h>
11#include <zephyr/sys/slist.h>
12#include <zephyr/pm/state.h>
13#include <zephyr/toolchain.h>
14#include <errno.h>
15#include <stdbool.h>
16
17#ifdef __cplusplus
18extern "C" {
19#endif
20
55 sys_snode_t _node;
60 void (*state_entry)(enum pm_state state);
65 void (*state_exit)(enum pm_state state);
66};
67
68#if defined(CONFIG_PM) || defined(__DOXYGEN__)
81bool pm_state_force(uint8_t cpu, const struct pm_state_info *info);
82
91void pm_notifier_register(struct pm_notifier *notifier);
92
105
116
138
151
156#else /* CONFIG_PM */
157
158static inline void pm_notifier_register(struct pm_notifier *notifier)
159{
160 ARG_UNUSED(notifier);
161}
162
163static inline int pm_notifier_unregister(struct pm_notifier *notifier)
164{
165 ARG_UNUSED(notifier);
166
167 return -ENOSYS;
168}
169
170static inline const struct pm_state_info *pm_state_next_get(uint8_t cpu)
171{
172 ARG_UNUSED(cpu);
173
174 return NULL;
175}
176#endif /* CONFIG_PM */
177
178void z_pm_save_idle_exit(void);
179
180#ifdef __cplusplus
181}
182#endif
183
184#endif /* ZEPHYR_INCLUDE_PM_PM_H_ */
System error numbers.
struct _snode sys_snode_t
Single-linked list node structure.
Definition: slist.h:39
pm_state
Power management state.
Definition: state.h:27
void pm_state_exit_post_ops(enum pm_state state, uint8_t substate_id)
Do any SoC or architecture specific post ops after sleep state exits.
void pm_state_set(enum pm_state state, uint8_t substate_id)
Put processor into a power state.
void pm_notifier_register(struct pm_notifier *notifier)
Register a power management notifier.
bool pm_state_force(uint8_t cpu, const struct pm_state_info *info)
Force usage of given power state.
const struct pm_state_info * pm_state_next_get(uint8_t cpu)
Gets the next power state that will be used.
int pm_notifier_unregister(struct pm_notifier *notifier)
Unregister a power management notifier.
#define ENOSYS
Function not implemented.
Definition: errno.h:83
state
Definition: parser_state.h:29
__UINT8_TYPE__ uint8_t
Definition: stdint.h:88
Power management notifier struct.
Definition: pm.h:54
void(* state_entry)(enum pm_state state)
Application defined function for doing any target specific operations for power state entry.
Definition: pm.h:60
void(* state_exit)(enum pm_state state)
Application defined function for doing any target specific operations for power state exit.
Definition: pm.h:65
Information about a power management state.
Definition: state.h:114
uint8_t substate_id
Some platforms have multiple states that map to one Zephyr power state.
Definition: state.h:141
Macros to abstract toolchain specific capabilities.