2 .\" Copyright (c) 2001 Sun Microsystems, Inc. All Rights Reserved.
3 .\" The contents of this file are subject to the terms of the Common Development and Distribution License (the "License"). You may not use this file except in compliance with the License.
4 .\" You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE or http://www.opensolaris.org/os/licensing. See the License for the specific language governing permissions and limitations under the License.
5 .\" When distributing Covered Code, include this CDDL HEADER in each file and include the License file at usr/src/OPENSOLARIS.LICENSE. If applicable, add the following below this CDDL HEADER, with the fields enclosed by brackets "[]" replaced with your own identifying information: Portions Copyright [yyyy] [name of copyright owner]
6 .TH PM 7D "Sep 20, 1999"
8 pm \- Power Management driver
18 The Power Management ( \fBpm\fR) driver provides an interface for applications
19 to configure devices within the system for Power Management. The interface is
20 provided through \fBioctl\fR(2) commands. The \fBpm\fR driver may be accessed
22 .SS "Power Management Framework"
25 The Power Management framework model allows the system to be viewed as a
26 collection of devices. Each device is a collection of components that comprise
27 the smallest power manageable units. The device driver controls the definition
28 of a device's power manageable components.
31 A component can either be \fBbusy\fR or \fBidle\fR at the current power level.
32 Normally, the Power Management framework takes an \fBidle\fR component to the
33 next lower power level. The Power Management framework uses two factors to
34 determine this transition: the component must have been idle for at least the
35 threshold time, and the device to which the component belongs must satisfy any
36 dependency requirements. A dependency occurs when a device requires another
37 device to be power managed before it can be power managed. Dependencies occur
38 on a per device basis: when a dependency exists, no components of a device may
39 be managed unless all the devices it depends upon are first power managed.
42 Using the commands below, an application may take control of the Power
43 Management of a device from the Power Management framework driver and manage
44 the transition of device power levels directly.
47 For this set of ioctl commands, \fIarg\fR (see \fBioctl\fR(2)) points to a
48 structure of type \fBpm_req\fR defined in <\fBsys/pm.h\fR>:
52 typedef struct pm_req {
53 char *physpath; /* physical path of device */
54 /* to configure. See libdevinfo(3LIB) */
55 int component; /* device component */
56 int value; /* power level, threshold value, or count */
57 void *data; /* command-dependent variable-sized data */
58 size_t datasize; /* size of data buffer */
65 The fields should contain the following data:
72 Pointer to the physical path of a device. See \fBlibdevinfo\fR(3LIB). For
73 example, for the device \fB/devices/pseudo/pm@0:pm\fR the \fIphyspath\fR value
74 would be \fB/pseudo/pm@0\fR.
83 Non-negative integer specifying which component is being configured. The
84 numbering starts at zero.
93 Non-negative integer specifying the threshold value in seconds or the desired
94 power level, or the number of levels being specified.
103 Pointer to a buffer which contains or receives variable-sized data, such as the
104 name of a device upon which this device has a dependency.
113 Size of the data buffer.
118 Not all fields are used in each command.
122 \fB\fBPM_DIRECT_PM\fR\fR
126 The device named by \fIphyspath\fR is disabled from being power managed by the
127 framework. The caller will power manage the device directly using the
128 \fBPM_DIRECT_NOTIFY\fR, \fBPM_GET_TIME_IDLE\fR and \fBPM_GET_CURRENT_POWER\fR,
129 \fBPM_GET_FULL_POWER\fR and \fBPM_SET_CURRENT_POWER\fR commands. If the device
130 needs to have its power level changed either because its driver calls
131 \fBpm_raise_power\fR(9F), \fBpm_lower_power\fR(9F), or
132 \fBpm_power_has_changed\fR(9F) or because the device is the parent of another
133 device that is changing power level or a device that this device depends on is
134 changing power level, then the power level change of the device will be blocked
135 and the caller will be notified as described below for the
136 \fBPM_DIRECT_NOTIFY\fR command.
145 Device already disabled for Power Management by framework.
154 Caller is neither superuser nor effective group ID of 0.
162 \fB\fBPM_RELEASE_DIRECT_PM\fR\fR
166 The device named by \fIphyspath\fR (which must have been the target of a
167 \fBPM_DIRECT_PM\fR command) is re-enabled for Power Management by the
177 Device component out of range.
185 \fB\fBPM_DIRECT_NOTIFY \fR\fBPM_DIRECT_NOTIFY_WAIT\fR\fR
189 These commands allow the process that is directly power managing a device to be
190 notified of events that could change the power level of the device. When such
191 an event occurs, this command returns information about the event.
193 \fIarg\fR (see \fBioctl\fR(2)) points to a structure of type
194 \fBpm_state_change\fR defined in \fB<sys/pm.h>\fR:
198 typedef struct pm_state_change {
199 char *physpath; /* device which has changed state */
200 int component; /* which component changed state */
201 #if defined(_BIG_ENDIAN)
202 ushort_t flags; /* PSC_EVENT_LOST, PSC_ALL_LOWEST */
203 ushort_t event; /* type of event */
205 ushort_t event; /* type of event *
206 ushort_t flags; /* PSC_EVENT_LOST, PSC_ALL_LOWEST */
208 time_t timestamp; /* time of state change */+
209 int old_level; /* power level changing from */
210 int new_level; /* power level changing to */
211 size_t size; /* size of buffer physpath points to */
216 When an event occurs, the struct pointed to by \fIarg\fR is filled in. If the
217 event type is \fBPSC_PENDING_CHANGE\fR, then the information in the rest of the
218 struct describes an action that the framework would have taken if the device
219 were not directly power managed by the caller. The caller is responsible for
220 completing the indicated level changes using \fBPM_SET_CURRENT_POWER\fR below.
222 An event type of \fBPSC_HAS_CHANGED\fR indicates that the driver for the
223 directly power managed device has called \fBpm_power_has_changed\fR(9F) due to
224 the device changing power on its own. It is provided to allow the caller to
225 track the power state of the device.
227 The system keeps events in a circular buffer. If the buffer overflow, the
228 oldest events are lost and when the event that next follows a lost event is
229 retrieved it will have PSC_EVENT_LOST set in flags.
231 \fBPM_DIRECT_NOTIFY\fR returns \fBEWOULDBLOCK\fR if no event is pending, and
232 \fBPM_DIRECT_NOTIFY_WAIT\fR blocks until an event is available.
234 \fBpm\fR also supports the \fBpoll\fR(2) interface. When an event is pending a
235 \fBpoll\fR(2) call that includes a file descriptor for \fB/dev/pm\fR and that
236 has \fBPOLLIN \fR or \fBPOLLRDNORM \fR set in its event mask will return.
242 \fB\fBPM_SET_CURRENT_POWER\fR\fR
246 Component \fIcomponent\fR of the device named by \fIphyspath\fR (which must
247 contain the physical path of a device against which the process has issued a
248 \fBPM_DIRECT_PM\fR command) is set to power level \fIvalue. \fRIf all
249 components of the device named by \fIphyspath\fR were at level 0, \fIvalue\fR
250 is non-zero and some device has a dependency on this device, then all
251 components of that device will be brought to full power before this command
252 returns. Similarly, if the parent of the target device is powered off, then it
253 will be brought up as needed before this command returns. When
254 PM_SET_CURRENT_POWER is issued against a device, the resulting power change is
255 included in the event list for PM_DIRECT_NOTIFY.
264 Device component out of range, or power level < 0.
273 Failed to power device or its ancestors or the devices on which this device has
274 dependency or their ancestors. Note that this may not indicate a failure, the
275 device driver may have rejected the command as inappropriate because the
276 component has become busy.
285 Caller has not previously issued a successful \fBPM_DIRECT_PM\fR command
294 \fB\fBPM_GET_FULL_POWER\fR\fR
298 The highest supported power level of component \fIcomponent\fR of the device
299 named by \fIphyspath\fR is returned.
305 \fB\fBPM_GET_CURRENT_POWER\fR\fR
309 The current power level of component \fIcomponent\fR of the device named by
310 \fIphyspath\fR is returned.
319 Device component power level is not currently known.
327 \fB\fBPM_GET_TIME_IDLE\fR\fR
331 \fBPM_GET_TIME_IDLE\fR returns the number of seconds that component
332 \fIcomponent\fR of the device named by \fIphyspath\fR has been idle. If the
333 device is not idle, then \fB0\fR is returned.
335 Note that because the state of the device may change between the time the
336 process issues the \fBPM_GET_TIME_IDLE\fR command and the time the process
337 issues a \fBPM_SET_CURRENT_POWER\fR command to reduce the power level of an
338 idle component, the process must be prepared to deal with a
339 \fBPM_SET_CURRENT_POWER\fR command returning failure because the driver has
340 rejected the command as inappropriate because the device component has become
341 busy. This can be differentiated from other types of failures by issuing the
342 \fBPM_GET_TIME_IDLE\fR command again to see if the component has become busy.
348 Upon error, the commands will return \fB\(mi1\fR, and set \fIerrno\fR. In
349 addition to the error codes listed above by command, the following error codes
350 are common to all commands:
357 Bad address passed in as argument.
366 Device is not power manageable, or device is not configured.
375 Too many opens attempted.
381 See \fBattributes\fR(5) for descriptions of the following attributes:
389 ATTRIBUTE TYPE ATTRIBUTE VALUE
391 Interface stability Unstable
397 \fBpmconfig\fR(1M), \fBIntro\fR(2), \fBioctl\fR(2), \fBlibdevinfo\fR(3LIB),
398 \fBpower.conf\fR(4), \fBattributes\fR(5), \fBattach\fR(9E), \fBdetach\fR(9E),
399 \fBpower\fR(9E), \fBpm_busy_component\fR(9F), \fBpm_idle_component\fR(9F),
400 \fBpm_lower_power\fR(9F), \fBpm_power_has_changed\fR(9F),
401 \fBpm_raise_power\fR(9F)
404 \fIWriting Device Drivers\fR