Home | History | Annotate | Line # | Download | only in sys
      1 /*	$NetBSD: power.h,v 1.23 2022/05/28 10:36:23 andvar Exp $	*/
      2 
      3 /*
      4  * Copyright (c) 2003 Wasabi Systems, Inc.
      5  * All rights reserved.
      6  *
      7  * Written by Jason R. Thorpe for Wasabi Systems, Inc.
      8  *
      9  * Redistribution and use in source and binary forms, with or without
     10  * modification, are permitted provided that the following conditions
     11  * are met:
     12  * 1. Redistributions of source code must retain the above copyright
     13  *    notice, this list of conditions and the following disclaimer.
     14  * 2. Redistributions in binary form must reproduce the above copyright
     15  *    notice, this list of conditions and the following disclaimer in the
     16  *    documentation and/or other materials provided with the distribution.
     17  * 3. All advertising materials mentioning features or use of this software
     18  *    must display the following acknowledgement:
     19  *      This product includes software developed for the NetBSD Project by
     20  *      Wasabi Systems, Inc.
     21  * 4. The name of Wasabi Systems, Inc. may not be used to endorse
     22  *    or promote products derived from this software without specific prior
     23  *    written permission.
     24  *
     25  * THIS SOFTWARE IS PROVIDED BY WASABI SYSTEMS, INC. ``AS IS'' AND
     26  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
     27  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
     28  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL WASABI SYSTEMS, INC
     29  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
     30  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
     31  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
     32  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
     33  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
     34  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
     35  * POSSIBILITY OF SUCH DAMAGE.
     36  */
     37 
     38 /*
     39  * Definitions for power management.
     40  */
     41 
     42 #ifndef _SYS_POWER_H_
     43 #define	_SYS_POWER_H_
     44 
     45 #include <sys/ioccom.h>
     46 
     47 #ifndef _KERNEL
     48 #include <stdint.h>
     49 #endif
     50 
     51 /*
     52  * Power Switches:
     53  *
     54  * Power switches are devices on the system that are used by the system
     55  * operator to cause certain types of power management events to happen.
     56  * This may be the closing of a laptop lid, the pressing of a power button,
     57  * or some other type of user-initiated hardware event.
     58  *
     59  * We define the following types of power switches:
     60  *
     61  *	Power button		This is the "on/off" button on a system,
     62  *				or another button which provides a similar
     63  *				function.  If there is no power management
     64  *				daemon present, an event on this button will
     65  *				cause a semi-graceful shutdown of the system
     66  *				to occur.  This kind of button doesn't keep
     67  *				state; we only know (care) if an event occurs.
     68  *
     69  *	Reset button		This is the "reset" button on a system, or
     70  *				another button which provides a similar
     71  *				function.  If there is no power management
     72  *				daemon present, an event on this button will
     73  *				cause a semi-graceful reboot of the system
     74  *				to occur.  This kind of button doesn't keep
     75  *				state; we only know (care) if an event occurs.
     76  *
     77  *	Sleep button		This is a button which is dedicated to a
     78  *				"sleep" function.  This kind of button doesn't
     79  *				keep state; we only know (care) if an event
     80  *				occurs.
     81  *
     82  *	Lid switch		This is e.g. the lid of a laptop.  This kind
     83  *				of switch has state.  We know if it is open
     84  *				or closed.
     85  *
     86  *	Radio switch		This is e.g. the switch of the transmitter
     87  * 				of a wifi interface. We know if it is
     88  *				on or off.
     89  *
     90  */
     91 
     92 #define	PSWITCH_TYPE_POWER	0	/* power button */
     93 #define	PSWITCH_TYPE_SLEEP	1	/* sleep button */
     94 #define	PSWITCH_TYPE_LID	2	/* lid switch */
     95 #define	PSWITCH_TYPE_RESET	3	/* reset button */
     96 #define	PSWITCH_TYPE_ACADAPTER	4	/* AC adapter presence */
     97 #define	PSWITCH_TYPE_HOTKEY	5	/* hotkey button */
     98 #define		PSWITCH_HK_DISPLAY_CYCLE	"display-cycle"
     99 #define		PSWITCH_HK_LOCK_SCREEN		"lock-screen"
    100 #define		PSWITCH_HK_BATTERY_INFO		"battery-info"
    101 #define		PSWITCH_HK_EJECT_BUTTON		"eject-button"
    102 #define		PSWITCH_HK_ZOOM_BUTTON		"zoom-button"
    103 #define		PSWITCH_HK_VENDOR_BUTTON	"vendor-button"
    104 #ifndef THINKPAD_NORMAL_HOTKEYS
    105 #define		PSWITCH_HK_FNF1_BUTTON		"fnf1-button"
    106 #define		PSWITCH_HK_WIRELESS_BUTTON	"wireless-button"
    107 #define		PSWITCH_HK_WWAN_BUTTON		"wWAN-button"
    108 #define		PSWITCH_HK_POINTER_BUTTON	"pointer-button"
    109 #define		PSWITCH_HK_FNF10_BUTTON		"fnf10-button"
    110 #define		PSWITCH_HK_FNF11_BUTTON		"fnf11-button"
    111 #define		PSWITCH_HK_BRIGHTNESS_UP	"brightness-up"
    112 #define		PSWITCH_HK_BRIGHTNESS_DOWN	"brightness-down"
    113 #define		PSWITCH_HK_THINKLIGHT		"thinklight"
    114 #define		PSWITCH_HK_VOLUME_UP		"volume-up"
    115 #define		PSWITCH_HK_VOLUME_DOWN		"volume-down"
    116 #define		PSWITCH_HK_VOLUME_MUTE		"volume-mute"
    117 #define		PSWITCH_HK_STAR_BUTTON		"star-button"
    118 #define		PSWITCH_HK_SCISSORS_BUTTON	"scissors-button"
    119 #define		PSWITCH_HK_BLUETOOTH_BUTTON	"bluetooth-button"
    120 #define		PSWITCH_HK_KEYBOARD_BUTTON	"keyboard-button"
    121 #endif /* THINKPAD_NORMAL_HOTKEYS */
    122 #define	PSWITCH_TYPE_RADIO	6	/* radio switch */
    123 
    124 #define	PSWITCH_EVENT_PRESSED	0	/* button pressed, lid closed, AC off */
    125 #define	PSWITCH_EVENT_RELEASED	1	/* button released, lid open, AC on */
    126 
    127 /*
    128  * This structure describes the state of a power switch.
    129  */
    130 struct pswitch_state {
    131 	char	psws_name[16];		/* power switch name */
    132 	int32_t	psws_type;		/* type of switch (qualifier) */
    133 	int32_t	psws_state;		/* state of the switch/event */
    134 };
    135 
    136 /*
    137  * envsys(4) events:
    138  *
    139  * envsys events are sent by the sysmon envsys framework when
    140  * a warning or critical condition happens in a sensor.
    141  *
    142  * We define the following types of envsys events:
    143  *
    144  *	sensor temperature	To handle temperature sensors.
    145  *
    146  *	sensor voltage		To handle voltage sensors (AC/DC).
    147  *
    148  *	sensor power		To handle power sensors (W/Ampere).
    149  *
    150  *	sensor resistance	To handle resistance sensors (Ohms).
    151  *
    152  *	sensor battery		To handle battery sensors (Ah/Wh).
    153  *
    154  *	sensor fan		To handle fan sensors.
    155  *
    156  *	sensor drive		To handle drive sensors.
    157  *
    158  * 	sensor indicator	To handle indicator/integer sensors.
    159  */
    160 
    161 #define PENVSYS_TYPE_TEMP		10
    162 #define PENVSYS_TYPE_VOLTAGE		11
    163 #define PENVSYS_TYPE_POWER		12
    164 #define PENVSYS_TYPE_RESISTANCE 	13
    165 #define PENVSYS_TYPE_BATTERY		14
    166 #define PENVSYS_TYPE_FAN		15
    167 #define PENVSYS_TYPE_DRIVE		16
    168 #define PENVSYS_TYPE_INDICATOR		17
    169 
    170 /*
    171  * The following events apply for temperatures, power, resistance,
    172  * voltages, battery and fan sensors:
    173  *
    174  * 	PENVSYS_EVENT_CRITICAL		A critical limit.
    175  *
    176  * 	PENVSYS_EVENT_CRITOVER		A critical over limit.
    177  *
    178  * 	PENVSYS_EVENT_CRITUNDER		A critical under limit.
    179  *
    180  * 	PENVSYS_EVENT_WARNOVER		A warning under limit.
    181  *
    182  * 	PENVSYS_EVENT_WARNUNDER		A warning over limit.
    183  *
    184  * The folowing event applies to all sensors, when the state is
    185  * valid or the warning or critical limit is not valid anymore:
    186  *
    187  * 	PENVSYS_EVENT_NORMAL		Normal state in the sensor.
    188  */
    189 
    190 #define PENVSYS_EVENT_NORMAL 		90
    191 #define PENVSYS_EVENT_CRITICAL 		100
    192 #define PENVSYS_EVENT_CRITOVER 		110
    193 #define PENVSYS_EVENT_CRITUNDER 	120
    194 #define PENVSYS_EVENT_WARNOVER 		130
    195 #define PENVSYS_EVENT_WARNUNDER 	140
    196 
    197 /*
    198  * The following events apply for battery sensors:
    199  *
    200  * 	PENVSYS_EVENT_BATT_CRIT		User critical capacity.
    201  *
    202  *	PENVSYS_EVENT_BATT_WARN		User warning capacity.
    203  *
    204  *	PENVSYS_EVENT_BATT_HIGH		User high capacity.
    205  *
    206  *	PENVSYS_EVENT_BATT_MAX		User maximum capacity.
    207  *
    208  * 	PENVSYS_EVENT_LOW_POWER		AC Adapter is OFF and all batteries
    209  * 					are discharged.
    210  */
    211 
    212 #define PENVSYS_EVENT_BATT_CRIT		170
    213 #define PENVSYS_EVENT_BATT_WARN		175
    214 #define PENVSYS_EVENT_BATT_HIGH		177
    215 #define PENVSYS_EVENT_BATT_MAX		178
    216 #define PENVSYS_EVENT_LOW_POWER		180
    217 
    218 /*
    219  * The following event apply for battery state and drive sensors:
    220  *
    221  * 	PENVSYS_EVENT_STATE_CHANGED	State has changed.
    222  *
    223  */
    224 #define PENVSYS_EVENT_STATE_CHANGED 	190
    225 
    226 /*
    227  * The following events are used internally to associate multiple
    228  * external states with a single event monitor
    229  */
    230 #define PENVSYS_EVENT_LIMITS		200
    231 #define PENVSYS_EVENT_CAPACITY		210
    232 
    233 /*
    234  * The following pseudo-event is used to force refreshing of a
    235  * sensor that provides rnd(4) entropy, even if the sensor is not
    236  * otherwise being monitored.
    237  */
    238 #define PENVSYS_EVENT_NULL		220
    239 
    240 /*
    241  * This structure defines the properties of an envsys event.
    242  */
    243 struct penvsys_state {
    244 	char	pes_dvname[16];		/* device name */
    245 	char	pes_sensname[32];	/* sensor name */
    246 	char	pes_statedesc[64];	/* sensor state description */
    247 	int32_t	pes_type;		/* envsys power type */
    248 };
    249 
    250 /*
    251  * Power management event messages:
    252  *
    253  * We ensure that a message is always exactly 32 bytes long, so that
    254  * userland doesn't need to issue multiple reads to get a single event.
    255  */
    256 #define	POWER_EVENT_MSG_SIZE	32
    257 
    258 #define	POWER_EVENT_SWITCH_STATE_CHANGE		0
    259 #define POWER_EVENT_ENVSYS_STATE_CHANGE		1
    260 
    261 typedef struct power_event {
    262 	int32_t		pev_type;	/* power event type */
    263 	union {
    264 		int32_t	 _pev_d_space[(POWER_EVENT_MSG_SIZE /
    265 				       sizeof(int32_t)) - 1];
    266 
    267 		/*
    268 		 * This field is used for:
    269 		 *
    270 		 * 	POWER_EVENT_SWITCH_STATE_CHANGE
    271 		 */
    272 		struct pswitch_state _pev_d_switch;
    273 	} _pev_data;
    274 } power_event_t;
    275 
    276 #define pev_switch	_pev_data._pev_d_switch
    277 
    278 #define POWER_EVENT_RECVDICT	_IOWR('P', 1, struct plistref)
    279 
    280 /*
    281  * POWER_IOC_GET_TYPE:
    282  *
    283  *	Get the power management back-end type.
    284  */
    285 struct power_type {
    286 	char	power_type[32];
    287 };
    288 #define	POWER_IOC_GET_TYPE	_IOR('P', 0, struct power_type)
    289 
    290 #ifdef _KERNEL
    291 /*
    292  * so the kernel can provide binary compat for applications
    293  * built when POWER_IOC_GET_TYPE was incorrectly defined as:
    294  */
    295 #define	POWER_IOC_GET_TYPE_WITH_LOSSAGE _IOR('P', 0, sizeof(struct power_type))
    296 #endif
    297 
    298 #endif /* _SYS_POWER_H_ */
    299