xref: /freebsd/share/man/man4/acpi_hp.4 (revision fa9896e082a1046ff4fbc75fcba4d18d1f2efc19)
1df849145SRui Paulo.\" Copyright (c) 2009 Michael Gmelin
2df849145SRui Paulo.\" All rights reserved.
3df849145SRui Paulo.\"
4df849145SRui Paulo.\" Redistribution and use in source and binary forms, with or without
5df849145SRui Paulo.\" modification, are permitted provided that the following conditions
6df849145SRui Paulo.\" are met:
7df849145SRui Paulo.\" 1. Redistributions of source code must retain the above copyright
8df849145SRui Paulo.\"    notice, this list of conditions and the following disclaimer.
9df849145SRui Paulo.\" 2. Redistributions in binary form must reproduce the above copyright
10df849145SRui Paulo.\"    notice, this list of conditions and the following disclaimer in the
11df849145SRui Paulo.\"    documentation and/or other materials provided with the distribution.
12df849145SRui Paulo.\"
13df849145SRui Paulo.\" THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
14df849145SRui Paulo.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
15df849145SRui Paulo.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
16df849145SRui Paulo.\" ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
17df849145SRui Paulo.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
18df849145SRui Paulo.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
19df849145SRui Paulo.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
20df849145SRui Paulo.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
21df849145SRui Paulo.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
22df849145SRui Paulo.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
23df849145SRui Paulo.\" SUCH DAMAGE.
24df849145SRui Paulo.\"
2510b942e5SXin LI.Dd June 19, 2015
26891acefeSGavin Atkinson.Dt ACPI_HP 4
27df849145SRui Paulo.Os
28df849145SRui Paulo.Sh NAME
29df849145SRui Paulo.Nm acpi_hp
30df849145SRui Paulo.Nd "ACPI extras driver for HP laptops"
31df849145SRui Paulo.Sh SYNOPSIS
32df849145SRui PauloTo compile this driver into the kernel,
33df849145SRui Pauloplace the following line in your
34df849145SRui Paulokernel configuration file:
35df849145SRui Paulo.Bd -ragged -offset indent
36df849145SRui Paulo.Cd "device acpi_hp"
37df849145SRui Paulo.Ed
38df849145SRui Paulo.Pp
39df849145SRui PauloAlternatively, to load the driver as a
40df849145SRui Paulomodule at boot time, place the following line in
41df849145SRui Paulo.Xr loader.conf 5 :
42df849145SRui Paulo.Bd -literal -offset indent
43df849145SRui Pauloacpi_hp_load="YES"
44df849145SRui Paulo.Ed
45df849145SRui Paulo.Sh DESCRIPTION
46df849145SRui PauloThe
47df849145SRui Paulo.Nm
48df849145SRui Paulodriver provides support for ACPI-controlled features found on HP laptops
4910b942e5SXin LIthat use a WMI enabled BIOS (e.g., HP Compaq 8510p and 6510p).
50df849145SRui Paulo.Pp
51df849145SRui PauloThe main purpose of this driver is to provide an interface,
52df849145SRui Pauloaccessible via
53df849145SRui Paulo.Xr sysctl 8 ,
54df849145SRui Paulo.Xr devd 8 and
55df849145SRui Paulo.Xr devfs 8 ,
56df849145SRui Paulothrough which applications can determine and change the status of
57df849145SRui Paulovarious laptop components and BIOS settings.
5810b942e5SXin LI.Ss Xr devd 8 Events
59df849145SRui PauloDevd events received by
60df849145SRui Paulo.Xr devd 8
61df849145SRui Pauloprovide the following information:
62df849145SRui Paulo.Pp
63df849145SRui Paulo.Bl -tag -width "subsystem" -offset indent -compact
64df849145SRui Paulo.It system
65df849145SRui Paulo.Qq Li ACPI
66df849145SRui Paulo.It subsystem
67df849145SRui Paulo.Qq Li HP
68df849145SRui Paulo.It type
69df849145SRui PauloThe source of the event in the ACPI namespace.
70df849145SRui PauloThe value depends on the model.
71df849145SRui Paulo.It notify
72df849145SRui PauloEvent code (see below).
73df849145SRui Paulo.El
74df849145SRui Paulo.Pp
75df849145SRui PauloEvent codes:
76df849145SRui Paulo.Pp
77df849145SRui Paulo.Bl -tag -width "0xc0" -offset indent -compact
78df849145SRui Paulo.It Li 0xc0
79df849145SRui PauloWLAN on air status changed to 0 (not on air)
80df849145SRui Paulo.It Li 0xc1
81df849145SRui PauloWLAN on air status changed to 1 (on air)
82df849145SRui Paulo.It Li 0xd0
83df849145SRui PauloBluetooth on air status changed to 0 (not on air)
84df849145SRui Paulo.It Li 0xd1
85df849145SRui PauloBluetooth on air status changed to 1 (on air)
86df849145SRui Paulo.It Li 0xe0
87df849145SRui PauloWWAN on air status changed to 0 (not on air)
88df849145SRui Paulo.It Li 0xe1
89df849145SRui PauloWWAN on air status changed to 1 (on air)
90df849145SRui Paulo.El
9110b942e5SXin LI.Ss Xr devfs 8 Device
929e760f25SRui PauloYou can read /dev/hpcmi to see your current BIOS settings.
939e760f25SRui PauloThe detail level can be adjusted by setting the sysctl
94df849145SRui Paulo.Va cmi_detail
95df849145SRui Pauloas described below.
96df849145SRui Paulo.Sh SYSCTL VARIABLES
97df849145SRui PauloThe following sysctls are currently implemented:
98df849145SRui Paulo.Ss WLAN:
99df849145SRui Paulo.Bl -tag -width indent
100df849145SRui Paulo.It Va dev.acpi_hp.0.wlan_enabled
101df849145SRui PauloToggle WLAN chip activity.
102df849145SRui Paulo.It Va dev.acpi_hp.0.wlan_radio
103df849145SRui Paulo(read-only)
104df849145SRui PauloWLAN radio status (controlled by hardware switch)
105df849145SRui Paulo.It Va dev.acpi_hp.0.wlan_on_air
106df849145SRui Paulo(read-only)
107df849145SRui PauloWLAN on air (chip enabled, hardware switch enabled + enabled in BIOS)
108df849145SRui Paulo.It Va dev.acpi_hp.0.wlan_enabled_if_radio_on
109df849145SRui PauloIf set to 1, the WLAN chip will be enabled if the radio is turned on
110df849145SRui Paulo.It Va dev.acpi_hp.0.wlan_disable_if_radio_off
111df849145SRui PauloIf set to 1, the WLAN chip will be disabled if the radio is turned off
112df849145SRui Paulo.El
113df849145SRui Paulo.Ss Bluetooth:
114df849145SRui Paulo.Bl -tag -width indent
115df849145SRui Paulo.It Va dev.acpi_hp.0.bt_enabled
116df849145SRui PauloToggle Bluetooth chip activity.
117df849145SRui Paulo.It Va dev.acpi_hp.0.bt_radio
118df849145SRui Paulo(read-only)
119df849145SRui PauloBluetooth radio status (controlled by hardware switch)
120df849145SRui Paulo.It Va dev.acpi_hp.0.bt_on_air
121df849145SRui Paulo(read-only)
122df849145SRui PauloBluetooth on air (chip enabled, hardware switch enabled + enabled in BIOS)
123df849145SRui Paulo.It Va dev.acpi_hp.0.bt_enabled_if_radio_on
124df849145SRui PauloIf set to 1, the Bluetooth chip will be enabled if the radio is turned on
125df849145SRui Paulo.It Va dev.acpi_hp.0.bt_disable_if_radio_off
126df849145SRui PauloIf set to 1, the Bluetooth chip will be disabled if the radio is turned off
127df849145SRui Paulo.El
128df849145SRui Paulo.Ss WWAN:
129df849145SRui Paulo.Bl -tag -width indent
130df849145SRui Paulo.It Va dev.acpi_hp.0.wwan_enabled
131df849145SRui PauloToggle WWAN chip activity.
132df849145SRui Paulo.It Va dev.acpi_hp.0.wwan_radio
133df849145SRui Paulo(read-only)
134df849145SRui PauloWWAN radio status (controlled by hardware switch)
135df849145SRui Paulo.It Va dev.acpi_hp.0.wwan_on_air
136df849145SRui Paulo(read-only)
137df849145SRui PauloWWAN on air (chip enabled, hardware switch enabled + enabled in BIOS)
138df849145SRui Paulo.It Va dev.acpi_hp.0.wwan_enabled_if_radio_on
139df849145SRui PauloIf set to 1, the WWAN chip will be enabled if the radio is turned on
140df849145SRui Paulo.It Va dev.acpi_hp.0.wwan_disable_if_radio_off
141df849145SRui PauloIf set to 1, the WWAN chip will be disabled if the radio is turned off
142df849145SRui Paulo.El
143df849145SRui Paulo.Ss Misc:
144df849145SRui Paulo.Bl -tag -width indent
145df849145SRui Paulo.It Va dev.acpi_hp.0.als_enabled
146df849145SRui PauloToggle ambient light sensor (ALS)
147df849145SRui Paulo.It Va dev.acpi_hp.0.display
148df849145SRui Paulo(read-only)
149df849145SRui PauloDisplay status (bitmask)
150df849145SRui Paulo.It Va dev.acpi_hp.0.hdd_temperature
151df849145SRui Paulo(read-only)
152df849145SRui PauloHDD temperature
153df849145SRui Paulo.It Va dev.acpi_hp.0.is_docked
154df849145SRui Paulo(read-only)
155df849145SRui PauloDocking station status (1 if docked)
156df849145SRui Paulo.It Va dev.acpi_hp.0.cmi_detail
157df849145SRui PauloBitmask to control detail level in /dev/hpcmi output (values can be ORed).
158df849145SRui Paulo.Bl -tag -width "0x01" -offset indent -compact
159df849145SRui Paulo.It Li 0x01
160df849145SRui PauloShow path component of BIOS setting
161df849145SRui Paulo.It Li 0x02
162df849145SRui PauloShow a list of valid options for the BIOS setting
163df849145SRui Paulo.It Li 0x04
164df849145SRui PauloShow additional flags of BIOS setting (ReadOnly etc.)
1650f73b657SRui Paulo.It Li 0x08
1669e760f25SRui PauloQuery highest BIOS entry instance.
1679e760f25SRui PauloThis is broken on many HP models and therefore disabled by default.
168df849145SRui Paulo.El
1699e760f25SRui Paulo.It Va dev.acpi_hp.0.verbose
1709e760f25SRui Paulo(read-only)
1719e760f25SRui PauloSet verbosity level
172df849145SRui Paulo.El
173df849145SRui Paulo.Pp
174df849145SRui PauloDefaults for these sysctls can be set in
175df849145SRui Paulo.Xr sysctl.conf 5 .
1769e760f25SRui Paulo.Sh HARDWARE
1779e760f25SRui PauloThe
1789e760f25SRui Paulo.Nm
1799e760f25SRui Paulodriver has been reported to support the following hardware:
1809e760f25SRui Paulo.Pp
1819e760f25SRui Paulo.Bl -bullet -compact
1829e760f25SRui Paulo.It
1839e760f25SRui PauloHP Compaq 8510p
1849e760f25SRui Paulo.It
1859e760f25SRui PauloHP Compaq nx7300
1869e760f25SRui Paulo.El
1879e760f25SRui Paulo.Pp
1889e760f25SRui PauloIt should work on most HP laptops that feature a WMI enabled BIOS.
189df849145SRui Paulo.Sh FILES
190df849145SRui Paulo.Bl -tag -width ".Pa /dev/hpcmi"
191df849145SRui Paulo.It Pa /dev/hpcmi
192df849145SRui PauloInterface to read BIOS settings
193df849145SRui Paulo.El
194df849145SRui Paulo.Sh EXAMPLES
195df849145SRui PauloThe following can be added to
196df849145SRui Paulo.Xr devd.conf 5
19710b942e5SXin LIin order disable the LAN interface when WLAN on air and reenable if it is not:
198df849145SRui Paulo.Bd -literal -offset indent
199df849145SRui Paulonotify 0 {
200df849145SRui Paulo	match "system"          "ACPI";
201df849145SRui Paulo	match "subsystem"       "HP";
202df849145SRui Paulo	match "notify"          "0xc0";
203df849145SRui Paulo	action                  "ifconfig em0 up";
204df849145SRui Paulo};
205df849145SRui Paulo
206df849145SRui Paulonotify 0 {
207df849145SRui Paulo	match "system"          "ACPI";
208df849145SRui Paulo	match "subsystem"       "HP";
209df849145SRui Paulo	match "notify"          "0xc1";
210df849145SRui Paulo	action                  "ifconfig em0 down";
211df849145SRui Paulo};
212df849145SRui Paulo.Ed
213df849145SRui Paulo.Pp
214df849145SRui PauloEnable the ambient light sensor:
215df849145SRui Paulo.Bd -literal -offset indent
216df849145SRui Paulosysctl dev.acpi_hp.0.als_enabled=1
217df849145SRui Paulo.Ed
218df849145SRui Paulo.Pp
219df849145SRui PauloEnable Bluetooth:
220df849145SRui Paulo.Bd -literal -offset indent
221df849145SRui Paulosysctl dev.acpi_hp.0.bt_enabled=1
222df849145SRui Paulo.Ed
223df849145SRui Paulo.Pp
224df849145SRui PauloGet BIOS settings:
225df849145SRui Paulo.Bd -literal -offset indent
226df849145SRui Paulocat /dev/hpcmi
227df849145SRui Paulo
228df849145SRui PauloSerial Port                                Disable
229df849145SRui PauloInfrared Port                              Enable
230df849145SRui PauloParallel Port                              Disable
231df849145SRui PauloFlash Media Reader                         Disable
232df849145SRui PauloUSB Ports including Express Card slot      Enable
233df849145SRui Paulo1394 Port                                  Enable
234df849145SRui PauloCardbus Slot                               Disable
235df849145SRui PauloExpress Card Slot                          Disable
236df849145SRui Paulo(...)
237df849145SRui Paulo.Ed
238df849145SRui Paulo.Pp
239df849145SRui PauloSet maximum detail level for /dev/hpcmi output:
240df849145SRui Paulo.Bd -literal -offset indent
241df849145SRui Paulosysctl dev.acpi_hp.0.cmi_detail=7
242df849145SRui Paulo.Ed
243df849145SRui Paulo.Sh SEE ALSO
244df849145SRui Paulo.Xr acpi 4 ,
245df849145SRui Paulo.Xr acpi_wmi 4 ,
246df849145SRui Paulo.Xr sysctl.conf 5 ,
247df849145SRui Paulo.Xr devd 8 ,
248df849145SRui Paulo.Xr devfs 8 ,
249df849145SRui Paulo.Xr sysctl 8
250df849145SRui Paulo.Sh HISTORY
251df849145SRui PauloThe
252df849145SRui Paulo.Nm
253df849145SRui Paulodevice driver first appeared in
25474997661SRui Paulo.Fx 8.0 .
255df849145SRui Paulo.Sh AUTHORS
256df849145SRui Paulo.An -nosplit
257df849145SRui PauloThe
258df849145SRui Paulo.Nm
259df849145SRui Paulodriver was written by
2606c899950SBaptiste Daroussin.An Michael Gmelin Aq Mt freebsd@grem.de .
261df849145SRui Paulo.Pp
262df849145SRui PauloIt has been inspired by hp-wmi driver, which implements a subset of these
263df849145SRui Paulofeatures (hotkeys) on Linux.
264df849145SRui Paulo.Bl -tag -width indent
265df849145SRui Paulo.It HP CMI whitepaper:
266*ec1e597aSWolfram Schneiderhttps://h20331.www2.hp.com/Hpsub/downloads/cmi_whitepaper.pdf
267df849145SRui Paulo.It wmi-hp for Linux:
268*ec1e597aSWolfram Schneiderhttps://www.kernel.org
269df849145SRui Paulo.It WMI and ACPI:
270df849145SRui Paulohttp://www.microsoft.com/whdc/system/pnppwr/wmi/wmi-acpi.mspx
271df849145SRui Paulo.El
272df849145SRui Paulo.Pp
273df849145SRui PauloThis manual page was written by
2746c899950SBaptiste Daroussin.An Michael Gmelin Aq Mt freebsd@grem.de .
275df849145SRui Paulo.Sh BUGS
27674997661SRui PauloThis driver is experimental and has only been tested on i386 on an
277df849145SRui PauloHP Compaq 8510p which featured all supported wireless devices (WWAN/BT/WLAN).
278df849145SRui PauloExpect undefined results when operating on different hardware.
279df849145SRui Paulo.Pp
28010b942e5SXin LILoading the driver is slow.
28110b942e5SXin LIReading from
28210b942e5SXin LI.Pa /dev/hpcmi
28310b942e5SXin LIis even slower.
284df849145SRui Paulo.Pp
285df849145SRui PauloAdditional features like HP specific sensor readings or writing BIOS
286df849145SRui Paulosettings are not supported.
287