1.\" 2.\" Copyright (c) 2001 Michael Smith 3.\" All rights reserved. 4.\" 5.\" Redistribution and use in source and binary forms, with or without 6.\" modification, are permitted provided that the following conditions 7.\" are met: 8.\" 1. Redistributions of source code must retain the above copyright 9.\" notice, this list of conditions and the following disclaimer. 10.\" 2. Redistributions in binary form must reproduce the above copyright 11.\" notice, this list of conditions and the following disclaimer in the 12.\" documentation and/or other materials provided with the distribution. 13.\" 14.\" THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND 15.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 16.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 17.\" ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 18.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 19.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 20.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 21.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 22.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 23.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 24.\" SUCH DAMAGE. 25.\" 26.\" $FreeBSD$ 27.\" 28.Dd July 2, 2001 29.Dt ACPI 4 30.Os 31.Sh NAME 32.Nm acpi 33.Nd Advanced Configuration and Power Management support 34.Sh SYNOPSIS 35.Cd device acpica 36.Pp 37.Cd options ACPI_DEBUG 38.Sh DESCRIPTION 39The 40.Nm 41driver provides support for the Intel/Microsoft/Compaq/Toshiba ACPI 42standard. 43This support includes platform hardware discovery (superseding the 44PnP and PCI BIOS), as well as power management (superseding APM) and 45other features. 46ACPI core support is provided by the ACPI CA reference implementation 47from Intel. 48.Pp 49Note that the 50.Nm 51driver is automatically loaded by the bootloader, and should not normally 52be compiled into the kernel. 53.Sh ENVIRONMENT 54This support is still experimental, and thus there are many debugging 55and tuning options which are managed via the kernel environment 56space, and set in the 57.Xr loader 8 58before booting the kernel. 59.Pp 60Debugging is separated between layers and levels, where a layer is 61a portion of the ACPI subsystem, and a level is a particular kind 62of debugging output. 63.Pp 64Both layers and levels are specified as a whitespace-separated list of 65tokens, with layers listed in 66.Va debug.acpi.layer 67and levels in 68.Va debug.acpi.level . 69The supported layers are: 70.Pp 71.Bl -item -offset indent -compact 72.It 73.Li ACPI_UTILITIES 74.It 75.Li ACPI_HARDWARE 76.It 77.Li ACPI_EVENTS 78.It 79.Li ACPI_TABLES 80.It 81.Li ACPI_NAMESPACE 82.It 83.Li ACPI_PARSER 84.It 85.Li ACPI_DISPATCHER 86.It 87.Li ACPI_EXECUTER 88.It 89.Li ACPI_RESOURCES 90.It 91.Li ACPI_DEBUGGER 92.It 93.Li ACPI_OS_SERVICES 94.It 95.Li ACPI_BUS 96.It 97.Li ACPI_SYSTEM 98.It 99.Li ACPI_POWER 100.It 101.Li ACPI_EC 102.It 103.Li ACPI_AC_ADAPTER 104.It 105.Li ACPI_BATTERY 106.It 107.Li ACPI_BUTTON 108.It 109.Li ACPI_PROCESSOR 110.It 111.Li ACPI_THERMAL 112.It 113.Li ACPI_FAN 114.It 115.Li ACPI_ALL_COMPONENTS 116.El 117.Pp 118The supported levels are: 119.Pp 120.Bl -item -offset indent -compact 121.It 122.Li ACPI_LV_OK 123.It 124.Li ACPI_LV_INFO 125.It 126.Li ACPI_LV_WARN 127.It 128.Li ACPI_LV_ERROR 129.It 130.Li ACPI_LV_FATAL 131.It 132.Li ACPI_LV_DEBUG_OBJECT 133.It 134.Li ACPI_LV_ALL_EXCEPTIONS 135.It 136.Li ACPI_LV_THREADS 137.It 138.Li ACPI_LV_PARSE 139.It 140.Li ACPI_LV_DISPATCH 141.It 142.Li ACPI_LV_LOAD 143.It 144.Li ACPI_LV_EXEC 145.It 146.Li ACPI_LV_NAMES 147.It 148.Li ACPI_LV_OPREGION 149.It 150.Li ACPI_LV_BFIELD 151.It 152.Li ACPI_LV_TRASH 153.It 154.Li ACPI_LV_TABLES 155.It 156.Li ACPI_LV_FUNCTIONS 157.It 158.Li ACPI_LV_VALUES 159.It 160.Li ACPI_LV_OBJECTS 161.It 162.Li ACPI_LV_ALLOCATIONS 163.It 164.Li ACPI_LV_RESOURCES 165.It 166.Li ACPI_LV_IO 167.It 168.Li ACPI_LV_INTERRUPTS 169.It 170.Li ACPI_LV_USER_REQUESTS 171.It 172.Li ACPI_LV_PACKAGE 173.It 174.Li ACPI_LV_MUTEX 175.It 176.Li ACPI_LV_INIT 177.It 178.Li ACPI_LV_ALL 179.It 180.Li ACPI_DB_AML_DISASSEMBLE 181.It 182.Li ACPI_DB_VERBOSE_INFO 183.It 184.Li ACPI_DB_FULL_TABLES 185.It 186.Li ACPI_DB_EVENTS 187.It 188.Li ACPI_DB_VERBOSE 189.El 190.Pp 191Selection of the appropriate layer and level values is important 192to avoid massive amounts of debugging output. 193Check the code to see which you need. 194.Pp 195Debugging output by the ACPI CA subsystem is prefixed with the 196module name in lowercase, followed by a source line number. 197Output from the 198.Fx Ns -local 199code follows the same format, but 200the module name is uppercased. 201.Pp 202The 203.Nm 204driver comprises a set of drivers, which may be selectively disabled 205in case of problems. 206To disable a sub-driver, list it in the kernel 207environment variable 208.Va debug.acpi.disable . 209.Pp 210ACPI sub-devices and features that can be disabled: 211.Bl -tag -width processor 212.It Li bus 213.Pq Vt feature 214Probes and attaches subdevices. 215Disabling will avoid scanning the ACPI namespace entirely. 216.It Li children 217.Pq Vt feature 218Attaches standard ACPI sub-drivers and devices enumerated in the 219ACPI namespace. 220Disabling this has a similar effect to disabling 221.Dq Li bus , 222except that the 223ACPI namespace will still be scanned. 224.It Li button 225.Pq Vt device 226Supports ACPI button devices (typically power and sleep buttons). 227.It Li ec 228.Pq Vt device 229Supports the ACPI Embedded Controller interface, used to 230communicate with embedded platform controllers. 231.It Li isa 232.Pq Vt device 233Supports an ISA bus bridge defined in the ACPI namespace, 234typically as a child of a PCI bus. 235.It Li lid 236.Pq Vt device 237Supports an ACPI laptop lid switch, which typically puts a 238system to sleep. 239.It Li pci 240.Pq Vt device 241Supports Host to PCI bridges. 242.It Li processor 243.Pq Vt device 244Supports CPU power-saving and speed-setting functions. 245.It Li thermal 246.Pq Vt device 247Supports system cooling and heat management. 248.It Li timer 249.Pq Vt device 250Implements a timecounter using the ACPI fixed-frequency timer. 251.El 252.Pp 253It is also possible to avoid portions of the ACPI namespace which 254may be causing problems, by listing the full path of the root of 255the region to be avoided in the kernel environment variable 256.Va debug.acpi.avoid . 257The object and all of its children will be ignored during the 258bus/children scan of the namespace. 259The ACPI CA code will still 260know about the avoided region. 261.Sh OVERRIDING YOUR BIOS BYTECODE 262ACPI interprets bytecode named AML, ACPI Machine Language, provided by the BIOS 263vendor as a memory image at boot time. Sometimes the AML code contains 264a problem that does not appeared in Microsoft implementation. 265So we provide a way to override it with your own AML code. 266.Pp 267In order to load your AML code, 268you must edit 269.Pa /boot/loader.conf 270and 271include the following lines. 272.Bd -literal -offset indent 273acpi_dsdt_load="YES" 274acpi_dsdt_name="/boot/acpi_dsdt.aml" #You may change the name. 275.Ed 276.Pp 277In order to prepare your AML code, you will require 278.Xr acpidump 8 , 279.Xr iasl 1 280in devel/acpicatools port, and some ACPI knowledge. 281.Sh COMPATIBILITY 282ACPI is only found/supported on Intel platforms (i386/IA32 and IA64). 283.Sh SEE ALSO 284.Xr config 8 , 285.Xr loader.conf 5 , 286.Xr acpidump 8 , 287.Xr acpi 9 288.Rs 289.%A Compaq Computer Corporation 290.%A Intel Corporation 291.%A Microsoft Corporation 292.%A Phoenix Technologies Ltd. 293.%A Toshiba Corporation 294.%D July 27 2000 295.%T "Advanced Configuration and Power Interface Specification" 296.%O http://acpi.info/spec.htm 297.Re 298.Sh AUTHORS 299.An -nosplit 300The ACPI CA subsystem is developed and maintained by 301Intel Architecture Labs. 302.Pp 303The following people made notable contributions to the ACPI subsystem 304in 305.Fx : 306.An Michael Smith Aq msmith@FreeBSD.org , 307.An Takanori Watanabe Aq takawata@jp.FreeBSD.org , 308.An Mitsuru IWASAKI Aq iwasaki@jp.FreeBSD.org , 309.An Munehiro Matsuda , 310the ACPI-jp mailing list at 311.Aq acpi-jp@jp.FreeBSD.org , 312and many other contributors. 313.Pp 314This manual page was written by 315.An Michael Smith Aq msmith@FreeBSD.org . 316.Sh BUGS 317The kernel device is 318.Cd device acpica 319for historical reasons. 320.Pp 321If the 322.Nm 323driver is loaded as a module when it is already linked as part of the 324kernel, odd things may happen. 325