xref: /freebsd/share/man/man4/acpi.4 (revision c4f6a2a9e1b1879b618c436ab4f56ff75c73a0f5)
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.
264Sometimes, the AML code contains
265a problem that does not appear in the Microsoft implementation.
266So we provide a way to override it with your own AML code.
267.Pp
268In order to load your AML code,
269you must edit
270.Pa /boot/loader.conf
271and
272include the following lines.
273.Bd -literal -offset indent
274acpi_dsdt_load="YES"
275acpi_dsdt_name="/boot/acpi_dsdt.aml" #You may change the name.
276.Ed
277.Pp
278In order to prepare your AML code, you will need the
279.Xr acpidump 8
280and
281.Xr iasl 1
282utilities from the
283.Pa devel/acpicatools
284port, and some ACPI knowledge.
285.Sh COMPATIBILITY
286ACPI is only found/supported on Intel platforms (i386/IA32 and IA64).
287.Sh SEE ALSO
288.Xr loader.conf 5 ,
289.Xr acpidump 8 ,
290.Xr config 8 ,
291.Xr acpi 9
292.Rs
293.%A "Compaq Computer Corporation"
294.%A "Intel Corporation"
295.%A "Microsoft Corporation"
296.%A "Phoenix Technologies Ltd."
297.%A "Toshiba Corporation"
298.%D July 27 2000
299.%T "Advanced Configuration and Power Interface Specification"
300.%O http://acpi.info/spec.htm
301.Re
302.Sh AUTHORS
303.An -nosplit
304The ACPI CA subsystem is developed and maintained by
305Intel Architecture Labs.
306.Pp
307The following people made notable contributions to the ACPI subsystem
308in
309.Fx :
310.An Michael Smith Aq msmith@FreeBSD.org ,
311.An Takanori Watanabe Aq takawata@jp.FreeBSD.org ,
312.An Mitsuru IWASAKI Aq iwasaki@jp.FreeBSD.org ,
313.An Munehiro Matsuda ,
314the ACPI-jp mailing list at
315.Aq acpi-jp@jp.FreeBSD.org ,
316and many other contributors.
317.Pp
318This manual page was written by
319.An Michael Smith Aq msmith@FreeBSD.org .
320.Sh BUGS
321The kernel device is
322.Cd device acpica
323for historical reasons.
324.Pp
325If the
326.Nm
327driver is loaded as a module when it is already linked as part of the
328kernel, odd things may happen.
329