1.. _resource_mgmt:
2
3Resource Management
4###################
5
6There are various situations where it's necessary to coordinate resource
7use at runtime among multiple clients.  These include power rails,
8clocks, other peripherals, and binary device power management. The
9complexity of properly managing multiple consumers of a device in a
10multithreaded system, especially when transitions may be asynchronous,
11suggests that a shared implementation is desirable.
12
13Zephyr provides managers for several coordination policies.  These
14managers are embedded into services that use them for specific
15functions.
16
17.. contents::
18    :local:
19    :depth: 2
20
21.. _resource_mgmt_onoff:
22
23On-Off Manager
24**************
25
26An on-off manager supports an arbitrary number of clients of a service
27which has a binary state.  Example applications are power rails, clocks,
28and binary device power management.
29
30The manager has the following properties:
31
32* The stable states are off, on, and error.  The service always begins
33  in the off state.  The service may also be in a transition to a given
34  state.
35* The core operations are request (add a dependency) and release (remove
36  a dependency). Supporting operations are reset (to clear an error
37  state) and cancel (to reclaim client data from an in-progress
38  transition).  The service manages the state based on calls to
39  functions that initiate these operations.
40* The service transitions from off to on when first client request is
41  received.
42* The service transitions from on to off when last client release is
43  received.
44* Each service configuration provides functions that implement the
45  transition from off to on, from on to off, and optionally from an
46  error state to off.  Transitions must be invokable from both thread
47  and interrupt context.
48* The request and reset operations are asynchronous using
49  :ref:`async_notification`.  Both operations may be cancelled, but
50  cancellation has no effect on the in-progress transition.
51* Requests to turn on may be queued while a transition to off is in
52  progress: when the service has turned off successfully it will be
53  immediately turned on again (where context allows) and waiting clients
54  notified when the start completes.
55
56Requests are reference counted, but not tracked. That means clients are
57responsible for recording whether their requests were accepted, and for
58initiating a release only if they have previously successfully completed
59a request.  Improper use of the API can cause an active client to be
60shut out, and the manager does not maintain a record of specific clients
61that have been granted a request.
62
63Failures in executing a transition are recorded and inhibit further
64requests or releases until the manager is reset. Pending requests are
65notified (and cancelled) when errors are discovered.
66
67Transition operation completion notifications are provided through
68:ref:`async_notification`.
69
70Clients and other components interested in tracking all service state
71changes, including when a service begins turning off or enters an error
72state, can be informed of state transitions by registering a monitor
73with onoff_monitor_register().  Notification of changes are provided
74before issuing completion notifications associated with the new
75state.
76
77.. note::
78
79   A generic API may be implemented by multiple drivers where the common
80   case is asynchronous.  The on-off client structure may be an
81   appropriate solution for the generic API.  Where drivers that can
82   guarantee synchronous context-independent transitions a driver may
83   use :c:struct:`onoff_sync_service` and its supporting API rather than
84   :c:struct:`onoff_manager`, with only a small reduction in functionality
85   (primarily no support for the monitor API).
86
87.. doxygengroup:: resource_mgmt_onoff_apis
88