1 /*
2  * Copyright (c) 2015 Intel Corporation.
3  *
4  * SPDX-License-Identifier: Apache-2.0
5  */
6 
7 #ifndef ZEPHYR_INCLUDE_PM_DEVICE_H_
8 #define ZEPHYR_INCLUDE_PM_DEVICE_H_
9 
10 #include <zephyr/device.h>
11 #include <zephyr/kernel.h>
12 #include <zephyr/sys/atomic.h>
13 #include <zephyr/sys/iterable_sections.h>
14 
15 #ifdef __cplusplus
16 extern "C" {
17 #endif
18 
19 /**
20  * @brief Device Power Management API
21  * @defgroup subsys_pm_device Device
22  * @ingroup subsys_pm
23  * @{
24  */
25 
26 /** @cond INTERNAL_HIDDEN */
27 
28 struct device;
29 
30 /** @brief Device PM flags. */
31 enum pm_device_flag {
32 	/** Indicate if the device is busy or not. */
33 	PM_DEVICE_FLAG_BUSY,
34 	/** Indicate if the device failed to power up. */
35 	PM_DEVICE_FLAG_TURN_ON_FAILED,
36 	/** Indicate if the device has claimed a power domain */
37 	PM_DEVICE_FLAG_PD_CLAIMED,
38 	/**
39 	 * Indicates whether or not the device is capable of waking the system
40 	 * up.
41 	 */
42 	PM_DEVICE_FLAG_WS_CAPABLE,
43 	/** Indicates if the device is being used as wakeup source. */
44 	PM_DEVICE_FLAG_WS_ENABLED,
45 	/** Indicates if device runtime is enabled  */
46 	PM_DEVICE_FLAG_RUNTIME_ENABLED,
47 	/** Indicates if the device is used as a power domain */
48 	PM_DEVICE_FLAG_PD,
49 	/** Indicates if device runtime PM should be automatically enabled */
50 	PM_DEVICE_FLAG_RUNTIME_AUTO,
51 	/** Indicates that device runtime PM supports suspending and resuming from any context. */
52 	PM_DEVICE_FLAG_ISR_SAFE,
53 };
54 
55 /** @endcond */
56 
57 /** @brief Flag indicating that runtime PM API for the device can be called from any context.
58  *
59  * If @ref PM_DEVICE_ISR_SAFE flag is used for device definition, it indicates that PM actions
60  * are synchronous and can be executed from any context. This approach can be used for cases where
61  * suspending and resuming is short as it is executed in the critical section. This mode requires
62  * less resources (~80 byte less RAM) and allows to use device runtime PM from any context
63  * (including interrupts).
64  */
65 #define PM_DEVICE_ISR_SAFE 1
66 
67 /** @brief Device power states. */
68 enum pm_device_state {
69 	/** Device is in active or regular state. */
70 	PM_DEVICE_STATE_ACTIVE,
71 	/**
72 	 * Device is suspended.
73 	 *
74 	 * @note
75 	 *     Device context may be lost.
76 	 */
77 	PM_DEVICE_STATE_SUSPENDED,
78 	/** Device is being suspended. */
79 	PM_DEVICE_STATE_SUSPENDING,
80 	/**
81 	 * Device is turned off (power removed).
82 	 *
83 	 * @note
84 	 *     Device context is lost.
85 	 */
86 	PM_DEVICE_STATE_OFF
87 };
88 
89 /** @brief Device PM actions. */
90 enum pm_device_action {
91 	/** Suspend. */
92 	PM_DEVICE_ACTION_SUSPEND,
93 	/** Resume. */
94 	PM_DEVICE_ACTION_RESUME,
95 	/**
96 	 * Turn off.
97 	 * @note
98 	 *     Action triggered only by a power domain.
99 	 */
100 	PM_DEVICE_ACTION_TURN_OFF,
101 	/**
102 	 * Turn on.
103 	 * @note
104 	 *     Action triggered only by a power domain.
105 	 */
106 	PM_DEVICE_ACTION_TURN_ON,
107 };
108 
109 /**
110  * @brief Device PM action callback.
111  *
112  * @param dev Device instance.
113  * @param action Requested action.
114  *
115  * @retval 0 If successful.
116  * @retval -ENOTSUP If the requested action is not supported.
117  * @retval Errno Other negative errno on failure.
118  */
119 typedef int (*pm_device_action_cb_t)(const struct device *dev,
120 				     enum pm_device_action action);
121 
122 /**
123  * @brief Device PM action failed callback
124  *
125  * @param dev Device that failed the action.
126  * @param err Return code of action failure.
127  *
128  * @return True to continue iteration, false to halt iteration.
129  */
130 typedef bool (*pm_device_action_failed_cb_t)(const struct device *dev,
131 					 int err);
132 
133 /**
134  * @brief Device PM info
135  *
136  * Structure holds fields which are common for two PM devices: generic and
137  * synchronous.
138  */
139 struct pm_device_base {
140 	/** Device PM status flags. */
141 	atomic_t flags;
142 	/** Device power state */
143 	enum pm_device_state state;
144 	/** Device PM action callback */
145 	pm_device_action_cb_t action_cb;
146 #if defined(CONFIG_PM_DEVICE_RUNTIME) || defined(__DOXYGEN__)
147 	/** Device usage count */
148 	uint32_t usage;
149 #endif /* CONFIG_PM_DEVICE_RUNTIME */
150 #ifdef CONFIG_PM_DEVICE_POWER_DOMAIN
151 	/** Power Domain it belongs */
152 	const struct device *domain;
153 #endif /* CONFIG_PM_DEVICE_POWER_DOMAIN */
154 };
155 
156 /**
157  * @brief Runtime PM info for device with generic PM.
158  *
159  * Generic PM involves suspending and resuming operations which can be blocking,
160  * long lasting or asynchronous. Runtime PM API is limited when used from
161  * interrupt context.
162  */
163 struct pm_device {
164 	/** Base info. */
165 	struct pm_device_base base;
166 #if defined(CONFIG_PM_DEVICE_RUNTIME) || defined(__DOXYGEN__)
167 	/** Pointer to the device */
168 	const struct device *dev;
169 	/** Lock to synchronize the get/put operations */
170 	struct k_sem lock;
171 	/** Event var to listen to the sync request events */
172 	struct k_event event;
173 	/** Work object for asynchronous calls */
174 	struct k_work_delayable work;
175 #endif /* CONFIG_PM_DEVICE_RUNTIME */
176 };
177 
178 /**
179  * @brief Runtime PM info for device with synchronous PM.
180  *
181  * Synchronous PM can be used with devices which suspend and resume operations can
182  * be performed in the critical section as they are short and non-blocking.
183  * Runtime PM API can be used from any context in that case.
184  */
185 struct pm_device_isr {
186 	/** Base info. */
187 	struct pm_device_base base;
188 #if defined(CONFIG_PM_DEVICE_RUNTIME) || defined(__DOXYGEN__)
189 	/** Lock to synchronize the synchronous get/put operations */
190 	struct k_spinlock lock;
191 #endif
192 };
193 
194 /* Base part must be the first element. */
195 BUILD_ASSERT(offsetof(struct pm_device, base) == 0);
196 BUILD_ASSERT(offsetof(struct pm_device_isr, base) == 0);
197 
198 /** @cond INTERNAL_HIDDEN */
199 
200 #ifdef CONFIG_PM_DEVICE_RUNTIME
201 #define Z_PM_DEVICE_RUNTIME_INIT(obj)			\
202 	.lock = Z_SEM_INITIALIZER(obj.lock, 1, 1),	\
203 	.event = Z_EVENT_INITIALIZER(obj.event),
204 #else
205 #define Z_PM_DEVICE_RUNTIME_INIT(obj)
206 #endif /* CONFIG_PM_DEVICE_RUNTIME */
207 
208 #ifdef CONFIG_PM_DEVICE_POWER_DOMAIN
209 #define	Z_PM_DEVICE_POWER_DOMAIN_INIT(_node_id)			\
210 	.domain = DEVICE_DT_GET_OR_NULL(DT_PHANDLE(_node_id,	\
211 				   power_domains)),
212 #else
213 #define Z_PM_DEVICE_POWER_DOMAIN_INIT(obj)
214 #endif /* CONFIG_PM_DEVICE_POWER_DOMAIN */
215 
216 /**
217  * @brief Utility macro to initialize #pm_device_base flags
218  *
219  * @param node_id Devicetree node for the initialized device (can be invalid).
220  */
221 #define Z_PM_DEVICE_FLAGS(node_id)					 \
222 	(COND_CODE_1(							 \
223 		 DT_NODE_EXISTS(node_id),				 \
224 		 ((DT_PROP_OR(node_id, wakeup_source, 0)		 \
225 			 << PM_DEVICE_FLAG_WS_CAPABLE) |		 \
226 		  (DT_PROP_OR(node_id, zephyr_pm_device_runtime_auto, 0) \
227 			 << PM_DEVICE_FLAG_RUNTIME_AUTO) |		 \
228 		  (DT_NODE_HAS_COMPAT(node_id, power_domain) <<		 \
229 			 PM_DEVICE_FLAG_PD)),				 \
230 		 (0)))
231 
232 /**
233  * @brief Utility macro to initialize #pm_device.
234  *
235  * @note #DT_PROP_OR is used to retrieve the wakeup_source property because
236  * it may not be defined on all devices.
237  *
238  * @param obj Name of the #pm_device_base structure being initialized.
239  * @param node_id Devicetree node for the initialized device (can be invalid).
240  * @param pm_action_cb Device PM control callback function.
241  * @param _flags Additional flags passed to the structure.
242  */
243 #define Z_PM_DEVICE_BASE_INIT(obj, node_id, pm_action_cb, _flags)	     \
244 	{								     \
245 		.flags = ATOMIC_INIT(Z_PM_DEVICE_FLAGS(node_id) | (_flags)), \
246 		.state = PM_DEVICE_STATE_ACTIVE,			     \
247 		.action_cb = pm_action_cb,				     \
248 		Z_PM_DEVICE_POWER_DOMAIN_INIT(node_id)			     \
249 	}
250 
251 /**
252  * @brief Utility macro to initialize #pm_device_rt.
253  *
254  * @note #DT_PROP_OR is used to retrieve the wakeup_source property because
255  * it may not be defined on all devices.
256  *
257  * @param obj Name of the #pm_device_base structure being initialized.
258  * @param node_id Devicetree node for the initialized device (can be invalid).
259  * @param pm_action_cb Device PM control callback function.
260  */
261 #define Z_PM_DEVICE_INIT(obj, node_id, pm_action_cb, isr_safe)			\
262 	{									\
263 		.base = Z_PM_DEVICE_BASE_INIT(obj, node_id, pm_action_cb,	\
264 				isr_safe ? BIT(PM_DEVICE_FLAG_ISR_SAFE) : 0),	\
265 		COND_CODE_1(isr_safe, (), (Z_PM_DEVICE_RUNTIME_INIT(obj)))	\
266 	}
267 
268 /**
269  * Get the name of device PM resources.
270  *
271  * @param dev_id Device id.
272  */
273 #define Z_PM_DEVICE_NAME(dev_id) _CONCAT(__pm_device_, dev_id)
274 
275 #ifdef CONFIG_PM
276 /**
277  * @brief Define device PM slot.
278  *
279  * This macro defines a pointer to a device in the pm_device_slots region.
280  * When invoked for each device with PM, it will effectively result in a device
281  * pointer array with the same size of the actual devices with PM enabled. This
282  * is used internally by the PM subsystem to keep track of suspended devices
283  * during system power transitions.
284  *
285  * @param dev_id Device id.
286  */
287 #define Z_PM_DEVICE_DEFINE_SLOT(dev_id)					\
288 	static STRUCT_SECTION_ITERABLE_ALTERNATE(pm_device_slots, device, \
289 			_CONCAT(__pm_slot_, dev_id))
290 #else
291 #define Z_PM_DEVICE_DEFINE_SLOT(dev_id)
292 #endif /* CONFIG_PM */
293 
294 #ifdef CONFIG_PM_DEVICE
295 /**
296  * Define device PM resources for the given node identifier.
297  *
298  * @param node_id Node identifier (DT_INVALID_NODE if not a DT device).
299  * @param dev_id Device id.
300  * @param pm_action_cb PM control callback.
301  */
302 #define Z_PM_DEVICE_DEFINE(node_id, dev_id, pm_action_cb, isr_safe)		\
303 	Z_PM_DEVICE_DEFINE_SLOT(dev_id);					\
304 	static struct COND_CODE_1(isr_safe, (pm_device_isr), (pm_device))	\
305 		Z_PM_DEVICE_NAME(dev_id) =					\
306 		Z_PM_DEVICE_INIT(Z_PM_DEVICE_NAME(dev_id), node_id,		\
307 				 pm_action_cb, isr_safe)
308 
309 /**
310  * Get a reference to the device PM resources.
311  *
312  * @param dev_id Device id.
313  */
314 #define Z_PM_DEVICE_GET(dev_id) ((struct pm_device_base *)&Z_PM_DEVICE_NAME(dev_id))
315 
316 #else
317 #define Z_PM_DEVICE_DEFINE(node_id, dev_id, pm_action_cb, isr_safe)
318 #define Z_PM_DEVICE_GET(dev_id) NULL
319 #endif /* CONFIG_PM_DEVICE */
320 
321 /** @endcond */
322 
323 /**
324  * Define device PM resources for the given device name.
325  *
326  * @note This macro is a no-op if @kconfig{CONFIG_PM_DEVICE} is not enabled.
327  *
328  * @param dev_id Device id.
329  * @param pm_action_cb PM control callback.
330  * @param ... Optional flag to indicate that ISR safe. Use @ref PM_DEVICE_ISR_SAFE or 0.
331  *
332  * @see #PM_DEVICE_DT_DEFINE, #PM_DEVICE_DT_INST_DEFINE
333  */
334 #define PM_DEVICE_DEFINE(dev_id, pm_action_cb, ...)			\
335 	Z_PM_DEVICE_DEFINE(DT_INVALID_NODE, dev_id, pm_action_cb,	\
336 			COND_CODE_1(IS_EMPTY(__VA_ARGS__), (0), (__VA_ARGS__)))
337 
338 /**
339  * Define device PM resources for the given node identifier.
340  *
341  * @note This macro is a no-op if @kconfig{CONFIG_PM_DEVICE} is not enabled.
342  *
343  * @param node_id Node identifier.
344  * @param pm_action_cb PM control callback.
345  * @param ... Optional flag to indicate that device is isr_ok. Use @ref PM_DEVICE_ISR_SAFE or 0.
346  *
347  * @see #PM_DEVICE_DT_INST_DEFINE, #PM_DEVICE_DEFINE
348  */
349 #define PM_DEVICE_DT_DEFINE(node_id, pm_action_cb, ...) \
350 	Z_PM_DEVICE_DEFINE(node_id, Z_DEVICE_DT_DEV_ID(node_id), pm_action_cb, \
351 			COND_CODE_1(IS_EMPTY(__VA_ARGS__), (0), (__VA_ARGS__)))
352 
353 /**
354  * Define device PM resources for the given instance.
355  *
356  * @note This macro is a no-op if @kconfig{CONFIG_PM_DEVICE} is not enabled.
357  *
358  * @param idx Instance index.
359  * @param pm_action_cb PM control callback.
360  * @param ... Optional flag to indicate that device is isr_ok. Use @ref PM_DEVICE_ISR_SAFE or 0.
361  *
362  * @see #PM_DEVICE_DT_DEFINE, #PM_DEVICE_DEFINE
363  */
364 #define PM_DEVICE_DT_INST_DEFINE(idx, pm_action_cb, ...)		\
365 	Z_PM_DEVICE_DEFINE(DT_DRV_INST(idx),				\
366 			   Z_DEVICE_DT_DEV_ID(DT_DRV_INST(idx)),	\
367 			   pm_action_cb,				\
368 			   COND_CODE_1(IS_EMPTY(__VA_ARGS__), (0), (__VA_ARGS__)))
369 
370 /**
371  * @brief Obtain a reference to the device PM resources for the given device.
372  *
373  * @param dev_id Device id.
374  *
375  * @return Reference to the device PM resources (NULL if device
376  * @kconfig{CONFIG_PM_DEVICE} is disabled).
377  */
378 #define PM_DEVICE_GET(dev_id) \
379 	Z_PM_DEVICE_GET(dev_id)
380 
381 /**
382  * @brief Obtain a reference to the device PM resources for the given node.
383  *
384  * @param node_id Node identifier.
385  *
386  * @return Reference to the device PM resources (NULL if device
387  * @kconfig{CONFIG_PM_DEVICE} is disabled).
388  */
389 #define PM_DEVICE_DT_GET(node_id) \
390 	PM_DEVICE_GET(Z_DEVICE_DT_DEV_ID(node_id))
391 
392 /**
393  * @brief Obtain a reference to the device PM resources for the given instance.
394  *
395  * @param idx Instance index.
396  *
397  * @return Reference to the device PM resources (NULL if device
398  * @kconfig{CONFIG_PM_DEVICE} is disabled).
399  */
400 #define PM_DEVICE_DT_INST_GET(idx) \
401 	PM_DEVICE_DT_GET(DT_DRV_INST(idx))
402 
403 /**
404  * @brief Get name of device PM state
405  *
406  * @param state State id which name should be returned
407  */
408 const char *pm_device_state_str(enum pm_device_state state);
409 
410 /**
411  * @brief Run a pm action on a device.
412  *
413  * This function calls the device PM control callback so that the device does
414  * the necessary operations to execute the given action.
415  *
416  * @param dev Device instance.
417  * @param action Device pm action.
418  *
419  * @retval 0 If successful.
420  * @retval -ENOTSUP If requested state is not supported.
421  * @retval -EALREADY If device is already at the requested state.
422  * @retval -EBUSY If device is changing its state.
423  * @retval -ENOSYS If device does not support PM.
424  * @retval -EPERM If device has power state locked.
425  * @retval Errno Other negative errno on failure.
426  */
427 int pm_device_action_run(const struct device *dev,
428 		enum pm_device_action action);
429 
430 /**
431  * @brief Run a pm action on all children of a device.
432  *
433  * This function calls all child devices PM control callback so that the device
434  * does the necessary operations to execute the given action.
435  *
436  * @param dev Device instance.
437  * @param action Device pm action.
438  * @param failure_cb Function to call if a child fails the action, can be NULL.
439  */
440 void pm_device_children_action_run(const struct device *dev,
441 		enum pm_device_action action,
442 		pm_device_action_failed_cb_t failure_cb);
443 
444 #if defined(CONFIG_PM_DEVICE) || defined(__DOXYGEN__)
445 /**
446  * @brief Obtain the power state of a device.
447  *
448  * @param dev Device instance.
449  * @param state Pointer where device power state will be stored.
450  *
451  * @retval 0 If successful.
452  * @retval -ENOSYS If device does not implement power management.
453  */
454 int pm_device_state_get(const struct device *dev,
455 			enum pm_device_state *state);
456 
457 /**
458  * @brief Initialize a device state to #PM_DEVICE_STATE_SUSPENDED.
459  *
460  * By default device state is initialized to #PM_DEVICE_STATE_ACTIVE. However
461  * in order to save power some drivers may choose to only initialize the device
462  * to the suspended state, or actively put the device into the suspended state.
463  * This function can therefore be used to notify the PM subsystem that the
464  * device is in #PM_DEVICE_STATE_SUSPENDED instead of the default.
465  *
466  * @param dev Device instance.
467  */
pm_device_init_suspended(const struct device * dev)468 static inline void pm_device_init_suspended(const struct device *dev)
469 {
470 	struct pm_device_base *pm = dev->pm_base;
471 
472 	pm->state = PM_DEVICE_STATE_SUSPENDED;
473 }
474 
475 /**
476  * @brief Initialize a device state to #PM_DEVICE_STATE_OFF.
477  *
478  * By default device state is initialized to #PM_DEVICE_STATE_ACTIVE. In
479  * general, this makes sense because the device initialization function will
480  * resume and configure a device, leaving it operational. However, when power
481  * domains are enabled, the device may be connected to a switchable power
482  * source, in which case it won't be powered at boot. This function can
483  * therefore be used to notify the PM subsystem that the device is in
484  * #PM_DEVICE_STATE_OFF instead of the default.
485  *
486  * @param dev Device instance.
487  */
pm_device_init_off(const struct device * dev)488 static inline void pm_device_init_off(const struct device *dev)
489 {
490 	struct pm_device_base *pm = dev->pm_base;
491 
492 	pm->state = PM_DEVICE_STATE_OFF;
493 }
494 
495 /**
496  * @brief Mark a device as busy.
497  *
498  * Devices marked as busy will not be suspended when the system goes into
499  * low-power states. This can be useful if, for example, the device is in the
500  * middle of a transaction.
501  *
502  * @param dev Device instance.
503  *
504  * @see pm_device_busy_clear()
505  */
506 void pm_device_busy_set(const struct device *dev);
507 
508 /**
509  * @brief Clear a device busy status.
510  *
511  * @param dev Device instance.
512  *
513  * @see pm_device_busy_set()
514  */
515 void pm_device_busy_clear(const struct device *dev);
516 
517 /**
518  * @brief Check if any device is busy.
519  *
520  * @retval false If no device is busy
521  * @retval true If one or more devices are busy
522  */
523 bool pm_device_is_any_busy(void);
524 
525 /**
526  * @brief Check if a device is busy.
527  *
528  * @param dev Device instance.
529  *
530  * @retval false If the device is not busy
531  * @retval true If the device is busy
532  */
533 bool pm_device_is_busy(const struct device *dev);
534 
535 /**
536  * @brief Enable or disable a device as a wake up source.
537  *
538  * A device marked as a wake up source will not be suspended when the system
539  * goes into low-power modes, thus allowing to use it as a wake up source for
540  * the system.
541  *
542  * @param dev Device instance.
543  * @param enable @c true to enable or @c false to disable
544  *
545  * @retval true If the wakeup source was successfully enabled.
546  * @retval false If the wakeup source was not successfully enabled.
547  */
548 bool pm_device_wakeup_enable(const struct device *dev, bool enable);
549 
550 /**
551  * @brief Check if a device is enabled as a wake up source.
552  *
553  * @param dev Device instance.
554  *
555  * @retval true if the wakeup source is enabled.
556  * @retval false if the wakeup source is not enabled.
557  */
558 bool pm_device_wakeup_is_enabled(const struct device *dev);
559 
560 /**
561  * @brief Check if a device is wake up capable
562  *
563  * @param dev Device instance.
564  *
565  * @retval true If the device is wake up capable.
566  * @retval false If the device is not wake up capable.
567  */
568 bool pm_device_wakeup_is_capable(const struct device *dev);
569 
570 /**
571  * @brief Check if the device is on a switchable power domain.
572  *
573  * @param dev Device instance.
574  *
575  * @retval true If device is on a switchable power domain.
576  * @retval false If device is not on a switchable power domain.
577  */
578 bool pm_device_on_power_domain(const struct device *dev);
579 
580 /**
581  * @brief Add a device to a power domain.
582  *
583  * This function adds a device to a given power domain.
584  *
585  * @param dev Device to be added to the power domain.
586  * @param domain Power domain.
587  *
588  * @retval 0 If successful.
589  * @retval -EALREADY If device is already part of the power domain.
590  * @retval -ENOSYS If the application was built without power domain support.
591  * @retval -ENOSPC If there is no space available in the power domain to add the device.
592  */
593 int pm_device_power_domain_add(const struct device *dev,
594 			       const struct device *domain);
595 
596 /**
597  * @brief Remove a device from a power domain.
598  *
599  * This function removes a device from a given power domain.
600  *
601  * @param dev Device to be removed from the power domain.
602  * @param domain Power domain.
603  *
604  * @retval 0 If successful.
605  * @retval -ENOSYS If the application was built without power domain support.
606  * @retval -ENOENT If device is not in the given domain.
607  */
608 int pm_device_power_domain_remove(const struct device *dev,
609 				  const struct device *domain);
610 
611 /**
612  * @brief Check if the device is currently powered.
613  *
614  * @param dev Device instance.
615  *
616  * @retval true If device is currently powered, or is assumed to be powered
617  * (i.e. it does not support PM or is not under a PM domain)
618  * @retval false If device is not currently powered
619  */
620 bool pm_device_is_powered(const struct device *dev);
621 
622 /**
623  * @brief Setup a device driver into the lowest valid power mode
624  *
625  * This helper function is intended to be called at the end of a driver
626  * init function to automatically setup the device into the lowest power
627  * mode. It assumes that the device has been configured as if it is in
628  * @ref PM_DEVICE_STATE_OFF, or @ref PM_DEVICE_STATE_SUSPENDED if device can
629  * never be powered off.
630  *
631  * @param dev Device instance.
632  * @param action_cb Device PM control callback function.
633  * @retval 0 On success.
634  * @retval -errno Error code from @a action_cb on failure.
635  */
636 int pm_device_driver_init(const struct device *dev, pm_device_action_cb_t action_cb);
637 
638 #else
pm_device_state_get(const struct device * dev,enum pm_device_state * state)639 static inline int pm_device_state_get(const struct device *dev,
640 				      enum pm_device_state *state)
641 {
642 	ARG_UNUSED(dev);
643 
644 	*state = PM_DEVICE_STATE_ACTIVE;
645 
646 	return 0;
647 }
648 
pm_device_init_suspended(const struct device * dev)649 static inline void pm_device_init_suspended(const struct device *dev)
650 {
651 	ARG_UNUSED(dev);
652 }
pm_device_init_off(const struct device * dev)653 static inline void pm_device_init_off(const struct device *dev)
654 {
655 	ARG_UNUSED(dev);
656 }
pm_device_busy_set(const struct device * dev)657 static inline void pm_device_busy_set(const struct device *dev)
658 {
659 	ARG_UNUSED(dev);
660 }
pm_device_busy_clear(const struct device * dev)661 static inline void pm_device_busy_clear(const struct device *dev)
662 {
663 	ARG_UNUSED(dev);
664 }
pm_device_is_any_busy(void)665 static inline bool pm_device_is_any_busy(void) { return false; }
pm_device_is_busy(const struct device * dev)666 static inline bool pm_device_is_busy(const struct device *dev)
667 {
668 	ARG_UNUSED(dev);
669 	return false;
670 }
pm_device_wakeup_enable(const struct device * dev,bool enable)671 static inline bool pm_device_wakeup_enable(const struct device *dev,
672 					   bool enable)
673 {
674 	ARG_UNUSED(dev);
675 	ARG_UNUSED(enable);
676 	return false;
677 }
pm_device_wakeup_is_enabled(const struct device * dev)678 static inline bool pm_device_wakeup_is_enabled(const struct device *dev)
679 {
680 	ARG_UNUSED(dev);
681 	return false;
682 }
pm_device_wakeup_is_capable(const struct device * dev)683 static inline bool pm_device_wakeup_is_capable(const struct device *dev)
684 {
685 	ARG_UNUSED(dev);
686 	return false;
687 }
pm_device_on_power_domain(const struct device * dev)688 static inline bool pm_device_on_power_domain(const struct device *dev)
689 {
690 	ARG_UNUSED(dev);
691 	return false;
692 }
693 
pm_device_power_domain_add(const struct device * dev,const struct device * domain)694 static inline int pm_device_power_domain_add(const struct device *dev,
695 					     const struct device *domain)
696 {
697 	ARG_UNUSED(dev);
698 	ARG_UNUSED(domain);
699 	return -ENOSYS;
700 }
701 
pm_device_power_domain_remove(const struct device * dev,const struct device * domain)702 static inline int pm_device_power_domain_remove(const struct device *dev,
703 						const struct device *domain)
704 {
705 	ARG_UNUSED(dev);
706 	ARG_UNUSED(domain);
707 	return -ENOSYS;
708 }
709 
pm_device_is_powered(const struct device * dev)710 static inline bool pm_device_is_powered(const struct device *dev)
711 {
712 	ARG_UNUSED(dev);
713 	return true;
714 }
715 
pm_device_driver_init(const struct device * dev,pm_device_action_cb_t action_cb)716 static inline int pm_device_driver_init(const struct device *dev, pm_device_action_cb_t action_cb)
717 {
718 	int rc;
719 
720 	/* When power management is not enabled, all drivers should initialise to active state */
721 	rc = action_cb(dev, PM_DEVICE_ACTION_TURN_ON);
722 	if ((rc < 0) && (rc != -ENOTSUP)) {
723 		return rc;
724 	}
725 
726 	rc = action_cb(dev, PM_DEVICE_ACTION_RESUME);
727 	if (rc < 0) {
728 		return rc;
729 	}
730 
731 	return 0;
732 }
733 
734 #endif /* CONFIG_PM_DEVICE */
735 
736 /** @} */
737 
738 #ifdef __cplusplus
739 }
740 #endif
741 
742 #endif
743