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