2011-08-09 11:33:01 +04:00
|
|
|
.\" $NetBSD: acpi.4,v 1.72 2011/08/09 07:33:01 jruoho Exp $
|
2002-04-23 16:01:16 +04:00
|
|
|
.\"
|
2010-04-11 12:58:43 +04:00
|
|
|
.\" Copyright (c) 2002, 2004, 2010 The NetBSD Foundation, Inc.
|
2002-04-23 16:01:16 +04:00
|
|
|
.\" All rights reserved.
|
|
|
|
.\"
|
|
|
|
.\" Redistribution and use in source and binary forms, with or without
|
|
|
|
.\" modification, are permitted provided that the following conditions
|
|
|
|
.\" are met:
|
|
|
|
.\" 1. Redistributions of source code must retain the above copyright
|
|
|
|
.\" notice, this list of conditions and the following disclaimer.
|
|
|
|
.\" 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
.\" notice, this list of conditions and the following disclaimer in the
|
|
|
|
.\" documentation and/or other materials provided with the distribution.
|
|
|
|
.\"
|
|
|
|
.\" THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
|
|
|
|
.\" ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
|
|
|
|
.\" TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
|
|
|
|
.\" PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
|
|
|
|
.\" BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
|
|
|
.\" CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
|
|
|
.\" SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
|
|
|
.\" INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
|
|
|
.\" CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
|
|
|
.\" ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
|
|
.\" POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
.\"
|
2011-07-13 16:22:36 +04:00
|
|
|
.Dd July 13, 2011
|
2002-04-23 16:01:16 +04:00
|
|
|
.Dt ACPI 4
|
|
|
|
.Os
|
|
|
|
.Sh NAME
|
|
|
|
.Nm acpi
|
2003-04-18 21:05:17 +04:00
|
|
|
.Nd Advanced Configuration and Power Interface
|
2002-04-23 16:01:16 +04:00
|
|
|
.Sh SYNOPSIS
|
2011-05-03 13:36:24 +04:00
|
|
|
.Cd acpi0 at mainbus0
|
2002-07-29 07:08:09 +04:00
|
|
|
.Pp
|
2011-05-03 13:36:24 +04:00
|
|
|
.Cd options ACPI_DEBUG
|
|
|
|
.Cd options ACPIVERBOSE
|
|
|
|
.Cd options ACPI_ACTIVATE_DEV
|
|
|
|
.Cd options ACPI_DSDT_OVERRIDE
|
|
|
|
.Cd options ACPI_DSDT_FILE=""
|
|
|
|
.Cd options ACPI_BLACKLIST_YEAR=2000
|
2002-04-23 16:01:16 +04:00
|
|
|
.Sh DESCRIPTION
|
|
|
|
.Nx
|
|
|
|
provides machine-independent bus support for
|
2009-05-17 04:37:53 +04:00
|
|
|
Advanced Configuration and Power Interface
|
|
|
|
.Pq Tn ACPI
|
2004-04-25 07:12:11 +04:00
|
|
|
devices and includes several
|
|
|
|
.Tn ACPI
|
|
|
|
device drivers.
|
2002-07-29 07:08:09 +04:00
|
|
|
.Pp
|
|
|
|
The
|
2004-04-25 07:12:11 +04:00
|
|
|
.Nx
|
|
|
|
implementation of
|
|
|
|
.Tn ACPI
|
|
|
|
integrates Intel's ACPI Component Architecture
|
2009-05-17 04:37:53 +04:00
|
|
|
.Pq Tn ACPI-CA
|
|
|
|
for the OS-independent part.
|
|
|
|
The
|
|
|
|
.Tn ACPI-CA
|
|
|
|
provides OS-neutral
|
|
|
|
.Tn ACPI
|
|
|
|
functionalities such as
|
|
|
|
.Tn ACPI
|
|
|
|
.Tn BIOS
|
|
|
|
table support,
|
|
|
|
an
|
|
|
|
.Tn ACPI
|
|
|
|
event framework and an ACPI Machine Language
|
|
|
|
.Pq Tn AML
|
|
|
|
interpreter.
|
2002-07-29 07:28:07 +04:00
|
|
|
.Pp
|
2004-04-25 07:12:11 +04:00
|
|
|
Options:
|
2006-03-11 14:57:18 +03:00
|
|
|
.Bl -tag -width ACPI_DSDT_FILE__filename_XX -offset 3n
|
|
|
|
.It Dv ACPI_DEBUG
|
2010-06-07 12:39:04 +04:00
|
|
|
Enable various debug facilities.
|
|
|
|
.It Dv ACPIVERBOSE
|
|
|
|
Enable verbose debug messages.
|
2006-03-11 14:57:18 +03:00
|
|
|
.It Dv ACPI_ACTIVATE_DEV
|
2009-05-17 04:37:53 +04:00
|
|
|
Determine if the
|
|
|
|
.Tn ACPI
|
|
|
|
driver should attempt to activate inactive devices.
|
2004-04-25 07:12:11 +04:00
|
|
|
The default is off.
|
2006-03-11 14:57:18 +03:00
|
|
|
.It Dv ACPI_DSDT_OVERRIDE
|
2009-05-17 04:37:53 +04:00
|
|
|
Force a given Differentiated System Description Table
|
|
|
|
.Pq Tn DSDT
|
2010-04-11 12:58:43 +04:00
|
|
|
instead of the version supplied by the
|
|
|
|
.Tn BIOS .
|
2006-03-11 14:57:18 +03:00
|
|
|
Use
|
|
|
|
.Dv ACPI_DSDT_FILE
|
2009-05-17 04:37:53 +04:00
|
|
|
to specify a
|
|
|
|
.Tn DSDT .
|
2006-03-11 14:57:18 +03:00
|
|
|
.It Dv ACPI_DSDT_FILE="filename"
|
|
|
|
If
|
|
|
|
.Dv ACPI_DSDT_FILE
|
|
|
|
is not specified, default to
|
|
|
|
.Dq dsdt.hex
|
2006-03-09 03:34:07 +03:00
|
|
|
in the build directory.
|
2010-09-06 20:01:25 +04:00
|
|
|
.It Dv ACPI_BLACKLIST_YEAR=2000
|
|
|
|
Do not use ACPI with any BIOS made on or before the specified year.
|
2004-04-25 07:12:11 +04:00
|
|
|
.El
|
2010-01-31 15:07:37 +03:00
|
|
|
.Sh SYSCTL SUPPORT
|
|
|
|
Few
|
2008-09-21 15:12:36 +04:00
|
|
|
.Xr sysctl 8
|
2009-05-17 04:37:53 +04:00
|
|
|
variables are directly relevant for
|
2010-04-10 08:49:17 +04:00
|
|
|
.Tn ACPI .
|
2010-04-12 16:21:17 +04:00
|
|
|
.Bl -tag -width "123456" -offset indent
|
2010-01-31 15:07:37 +03:00
|
|
|
.It Ic hw.acpi.root
|
2010-08-08 09:02:59 +04:00
|
|
|
The address of the
|
2009-05-17 04:37:53 +04:00
|
|
|
.Tn ACPI
|
2010-08-08 09:02:59 +04:00
|
|
|
root pointer in system memory.
|
2010-12-31 12:50:14 +03:00
|
|
|
.It Ic hw.acpi.sleep.state
|
|
|
|
The system sleep state.
|
|
|
|
.It Ic hw.acpi.sleep.states
|
|
|
|
A list of system sleep states that the machine supports.
|
2010-04-12 16:21:17 +04:00
|
|
|
The possible values are:
|
|
|
|
.Pp
|
|
|
|
.Bl -tag -width XS1X -offset indent -compact
|
2010-04-10 08:49:17 +04:00
|
|
|
.It S0
|
|
|
|
fully running
|
|
|
|
.It S1
|
|
|
|
power on suspend (CPU and hard disks are off)
|
|
|
|
.It S2
|
|
|
|
similar to S3, usually not implemented
|
|
|
|
.It S3
|
|
|
|
suspend-to-RAM
|
|
|
|
.It S4
|
2010-04-12 16:21:17 +04:00
|
|
|
suspend-to-disk (not supported on
|
|
|
|
.Nx )
|
2010-04-10 08:49:17 +04:00
|
|
|
.It S5
|
|
|
|
power off
|
|
|
|
.El
|
2010-12-31 12:50:14 +03:00
|
|
|
.It Ic hw.acpi.sleep.beep
|
2010-04-12 16:21:17 +04:00
|
|
|
A boolean variable that controls whether the
|
2010-04-10 09:21:41 +04:00
|
|
|
.Tn PC
|
2010-04-12 16:41:36 +04:00
|
|
|
speaker beeps upon resume.
|
2010-12-31 12:50:14 +03:00
|
|
|
.It Ic hw.acpi.sleep.vbios
|
2010-04-12 16:21:17 +04:00
|
|
|
Defines the handling of the graphics card.
|
2009-05-17 04:37:53 +04:00
|
|
|
The supported values are:
|
2010-08-08 09:02:59 +04:00
|
|
|
.Bl -tag -width '2' -offset 2n
|
2008-09-21 15:12:36 +04:00
|
|
|
.It 0
|
2009-05-17 04:37:53 +04:00
|
|
|
No attempt to reset the
|
|
|
|
.Tn VGA
|
|
|
|
controller will be made.
|
2008-09-21 15:12:36 +04:00
|
|
|
.It 1
|
2009-05-17 04:37:53 +04:00
|
|
|
Call the
|
|
|
|
.Tn VGA
|
|
|
|
.Tn BIOS
|
|
|
|
when still in real mode.
|
2008-09-21 15:12:36 +04:00
|
|
|
This can result in direct reboots.
|
|
|
|
In that case, use
|
|
|
|
.Sq 2
|
|
|
|
or
|
|
|
|
.Ic vbetool post
|
|
|
|
from the
|
|
|
|
.Pa pkgsrc/sysutils/vbetool
|
|
|
|
package.
|
|
|
|
.It 2
|
2009-05-17 04:37:53 +04:00
|
|
|
Call the
|
|
|
|
.Tn VGA
|
|
|
|
.Tn BIOS
|
|
|
|
using the in-kernel x86 emulator.
|
|
|
|
.El
|
2010-08-08 09:02:59 +04:00
|
|
|
.Pp
|
|
|
|
If the system has problems in resuming from the
|
|
|
|
.Tn S3
|
|
|
|
state, experimenting with different values may provide a solution.
|
2010-12-31 12:50:14 +03:00
|
|
|
.It Ic hw.acpi.stat.gpe
|
|
|
|
The number of dispatched General Purpose Events
|
|
|
|
.Pq Tn GPEs .
|
|
|
|
.It Ic hw.acpi.stat.sci
|
|
|
|
The number of System Control Interrupts
|
|
|
|
.Pq Tn SCIs .
|
|
|
|
See
|
|
|
|
.Xr acpiec 4
|
|
|
|
for a brief description of both
|
|
|
|
.Tn GPEs
|
|
|
|
and
|
|
|
|
.Tn SCIs .
|
|
|
|
.It Ic hw.acpi.stat.fixed
|
|
|
|
The number of
|
|
|
|
.Dq fixed events .
|
|
|
|
.It Ic hw.acpi.stat.method
|
|
|
|
The number of
|
|
|
|
.Tn ACPI
|
|
|
|
methods executed by the interpreter.
|
2011-01-02 09:20:19 +03:00
|
|
|
.It Ic hw.acpi.power
|
|
|
|
This read-only node describes the
|
|
|
|
.Tn ACPI
|
|
|
|
power state of devices.
|
|
|
|
The values range from
|
|
|
|
.Tn D0
|
|
|
|
.Pq Dq on
|
|
|
|
to
|
|
|
|
.Tn D3
|
|
|
|
.Pq Dq off .
|
|
|
|
.It Ic hw.acpi.wake
|
|
|
|
This node represents devices that can wake the system from the
|
|
|
|
.Tn S3
|
|
|
|
or
|
|
|
|
.Tn S4
|
|
|
|
sleep state.
|
|
|
|
By default,
|
|
|
|
.Xr acpibut 4 ,
|
|
|
|
.Xr acpilid 4 ,
|
|
|
|
and
|
|
|
|
.Xr pckbd 4
|
|
|
|
are allowed to wake the system, provided that the devices are present and
|
|
|
|
the firmware supports wake-up capabilities for the devices.
|
2008-09-21 15:12:36 +04:00
|
|
|
.El
|
2004-04-25 07:12:11 +04:00
|
|
|
.Sh SUPPORTED DEVICES
|
|
|
|
.Nx
|
|
|
|
.Tn ACPI
|
2010-08-08 09:02:59 +04:00
|
|
|
supports several machine-dependent and machine-independent devices,
|
|
|
|
some specific to
|
|
|
|
.Tn ACPI
|
|
|
|
and some configured via it.
|
2010-01-31 15:07:37 +03:00
|
|
|
.Ss Machine-independent devices
|
2010-08-05 21:45:44 +04:00
|
|
|
.Bl -tag -width "thinkpad(4) " -offset indent -compact
|
|
|
|
.It Xr acpiacad 4
|
2004-04-25 07:12:11 +04:00
|
|
|
.Tn ACPI
|
|
|
|
AC adapters.
|
2010-08-05 21:45:44 +04:00
|
|
|
.It Xr acpibat 4
|
2004-04-25 07:12:11 +04:00
|
|
|
.Tn ACPI
|
2010-08-05 21:45:44 +04:00
|
|
|
batteries.
|
|
|
|
.It Xr acpibut 4
|
2004-04-25 07:12:11 +04:00
|
|
|
.Tn ACPI
|
|
|
|
power and sleep buttons.
|
2010-08-05 21:45:44 +04:00
|
|
|
.It Xr acpicpu 4
|
2010-01-25 14:41:10 +03:00
|
|
|
.Tn ACPI
|
2010-08-05 21:45:44 +04:00
|
|
|
processors.
|
|
|
|
.It Xr acpidalb 4
|
2004-04-25 07:12:11 +04:00
|
|
|
.Tn ACPI
|
2010-08-05 21:45:44 +04:00
|
|
|
direction application launch buttons.
|
|
|
|
.It Xr acpiec 4
|
2010-01-25 14:41:10 +03:00
|
|
|
.Tn ACPI
|
2010-08-05 21:45:44 +04:00
|
|
|
embedded controllers.
|
|
|
|
.It Xr acpiecdt 4
|
|
|
|
.Tn ACPI
|
|
|
|
Embedded Controller Boot Resource Table
|
|
|
|
.Pq Tn ECDT .
|
2011-01-09 18:12:33 +03:00
|
|
|
.It Xr acpifan 4
|
|
|
|
.Tn ACPI
|
|
|
|
fans.
|
2010-08-05 21:45:44 +04:00
|
|
|
.It Xr acpilid 4
|
2004-04-25 07:12:11 +04:00
|
|
|
.Tn ACPI
|
|
|
|
lid switches.
|
2011-01-06 00:09:16 +03:00
|
|
|
.It Xr acpipmtr 4
|
|
|
|
.Tn ACPI
|
|
|
|
power meters.
|
2010-08-05 21:45:44 +04:00
|
|
|
.It Xr acpismbus 4
|
2010-02-06 23:11:33 +03:00
|
|
|
.Tn ACPI
|
2011-01-06 00:09:16 +03:00
|
|
|
SMBus via control method interface
|
2010-08-05 21:45:44 +04:00
|
|
|
.Pq Tn CMI .
|
|
|
|
.It Xr acpitz 4
|
2004-04-25 07:12:11 +04:00
|
|
|
.Tn ACPI
|
|
|
|
thermal zones.
|
2010-10-24 12:31:49 +04:00
|
|
|
.It Xr acpivga 4
|
|
|
|
.Tn ACPI
|
|
|
|
display adapter and output devices.
|
2010-08-05 21:45:44 +04:00
|
|
|
.It Xr acpiwmi 4
|
2010-04-10 08:56:26 +04:00
|
|
|
.Tn ACPI
|
|
|
|
support for Windows Management Instrumentation.
|
2011-01-18 00:56:38 +03:00
|
|
|
.It Xr acpiwdrt 4
|
|
|
|
.Tn ACPI
|
|
|
|
watchdogs.
|
2010-08-05 21:45:44 +04:00
|
|
|
.It Xr aibs 4
|
|
|
|
ASUSTeK voltage, temperature and fan sensors.
|
2010-01-25 14:41:10 +03:00
|
|
|
.It asus
|
|
|
|
ASUS laptop hotkeys.
|
2010-08-05 21:45:44 +04:00
|
|
|
.It Xr attimer 4
|
2010-01-25 14:41:10 +03:00
|
|
|
AT Timer.
|
2010-08-05 21:45:44 +04:00
|
|
|
.It Xr com 4
|
2004-04-25 07:12:11 +04:00
|
|
|
NS8250-, NS16450-, and NS16550-based serial ports.
|
2010-08-05 21:45:44 +04:00
|
|
|
.It Xr fdc 4
|
2004-04-25 07:12:11 +04:00
|
|
|
Floppy disk controllers.
|
2010-11-07 17:56:51 +03:00
|
|
|
.It Xr fujitsu 4
|
|
|
|
Fujitsu brightness, pointer, and hotkeys.
|
2011-07-13 16:22:36 +04:00
|
|
|
.It Xr hpacel 4
|
|
|
|
HP 3D DriveGuard accelerometer.
|
2010-08-06 20:44:06 +04:00
|
|
|
.It Xr hpet 4
|
2010-08-05 21:45:44 +04:00
|
|
|
High Precision Event Timer
|
|
|
|
.Pq Tn HPET .
|
|
|
|
.It Xr hpqlb 4
|
2010-01-25 14:41:10 +03:00
|
|
|
HP Quick Launch Buttons.
|
2010-08-05 21:45:44 +04:00
|
|
|
.It Xr joy 4
|
2004-12-02 17:33:31 +03:00
|
|
|
Joystick/Game port interface.
|
2010-08-05 21:45:44 +04:00
|
|
|
.It Xr lpt 4
|
2004-04-25 07:12:11 +04:00
|
|
|
Standard ISA parallel port interface.
|
2010-08-05 21:45:44 +04:00
|
|
|
.It Xr mpu 4
|
2004-12-02 17:33:31 +03:00
|
|
|
Roland MPU-401 (compatible) MIDI UART.
|
2010-08-05 21:45:44 +04:00
|
|
|
.It Xr pcppi 4
|
2005-03-21 22:53:17 +03:00
|
|
|
AT-style speaker sound.
|
2010-08-05 21:45:44 +04:00
|
|
|
.It Xr thinkpad 4
|
2010-01-25 14:41:10 +03:00
|
|
|
IBM/Lenovo ThinkPad laptop device driver.
|
2010-08-05 21:45:44 +04:00
|
|
|
.It Xr ug 4
|
2007-05-08 20:52:24 +04:00
|
|
|
Abit uGuru Hardware monitor.
|
2010-08-05 21:45:44 +04:00
|
|
|
.It Xr vald 4
|
2010-04-25 21:50:13 +04:00
|
|
|
Toshiba Libretto device.
|
2010-08-05 21:45:44 +04:00
|
|
|
.It Xr wb 4
|
2010-01-25 14:41:10 +03:00
|
|
|
Winbond W83L518D Integrated Media Reader.
|
2010-08-05 21:45:44 +04:00
|
|
|
.It Xr wss 4
|
|
|
|
Windows Sound System-compatible sound cards
|
|
|
|
.It Xr ym 4
|
2007-03-14 03:51:06 +03:00
|
|
|
Yamaha OPL3-SA2 and OPL3-SA3 audio device driver.
|
2004-04-25 07:12:11 +04:00
|
|
|
.El
|
|
|
|
.Ss i386-dependent devices
|
2010-08-05 21:45:44 +04:00
|
|
|
.Bl -tag -width "thinkpad(4) " -offset indent -compact
|
|
|
|
.It Xr npx 4
|
2004-04-25 07:12:11 +04:00
|
|
|
i386 numeric processing extension coprocessor.
|
2010-08-05 21:45:44 +04:00
|
|
|
.It Xr pckbc 4
|
2004-04-25 07:12:11 +04:00
|
|
|
PC keyboard controllers.
|
2010-08-05 21:45:44 +04:00
|
|
|
.It Xr sony 4
|
2006-03-25 15:34:16 +03:00
|
|
|
Sony Miscellaneous Controller
|
2010-08-05 21:45:44 +04:00
|
|
|
.It Xr spic 4
|
2004-04-25 07:12:11 +04:00
|
|
|
Sony programmable I/O controller.
|
|
|
|
.El
|
2010-01-31 14:29:31 +03:00
|
|
|
.Sh DEBUGGING
|
2010-04-11 12:58:43 +04:00
|
|
|
Although the situation has become better over the years,
|
|
|
|
.Tn ACPI
|
|
|
|
is typically prone to various errors,
|
|
|
|
ranging from blatant flaws in the firmware to bugs in the implementation.
|
|
|
|
Before anything else, it is a good practice to upgrade the
|
|
|
|
.Tn BIOS
|
|
|
|
to the latest version available from the vendor.
|
|
|
|
.Pp
|
|
|
|
To ease the task of diagnosing and fixing different problems, the
|
2010-01-31 14:29:31 +03:00
|
|
|
.Tn ACPICA
|
|
|
|
reference implementation provides a rich
|
|
|
|
facility of different debugging methods.
|
2010-04-11 12:58:43 +04:00
|
|
|
In
|
2010-01-31 14:29:31 +03:00
|
|
|
.Nx
|
2010-04-11 12:58:43 +04:00
|
|
|
these are generally only available if the kernel has been compiled with the
|
2010-01-31 14:29:31 +03:00
|
|
|
.Tn ACPI_DEBUG
|
|
|
|
option.
|
2010-08-08 09:02:59 +04:00
|
|
|
.Ss Verbose messages
|
|
|
|
The
|
|
|
|
.Tn ACPIVERBOSE
|
|
|
|
compile time option enables some verbose
|
|
|
|
debug messages printed during the system startup.
|
|
|
|
In a
|
|
|
|
.Tn MODULAR
|
|
|
|
(see
|
|
|
|
.Xr options 4 )
|
|
|
|
system, the information can be printed also at runtime,
|
|
|
|
regardless of the presence of
|
|
|
|
.Tn ACPIVERBOSE .
|
|
|
|
To print the messages,
|
|
|
|
.Xr modload 8
|
|
|
|
the
|
|
|
|
.Ic acpiverbose
|
|
|
|
module using the option
|
|
|
|
.Ar -b dump=true .
|
2010-06-07 12:39:04 +04:00
|
|
|
.Ss Custom DSDT
|
2010-04-11 12:58:43 +04:00
|
|
|
.Tn ACPI
|
|
|
|
interprets bytecode known as
|
|
|
|
.Tn ACPI
|
|
|
|
Machine Language
|
|
|
|
.Pq Tn AML ,
|
|
|
|
provided by the
|
|
|
|
.Tn BIOS
|
|
|
|
as a memory image during the system bootstrap.
|
|
|
|
Most of the
|
|
|
|
.Tn AML
|
|
|
|
relevant to
|
|
|
|
.Nm
|
|
|
|
is implemented in the so-called
|
|
|
|
Differentiated System Descriptor Table
|
|
|
|
.Pq Tn DSDT .
|
|
|
|
.Nx
|
|
|
|
provides support for overriding the default
|
|
|
|
.Tn DSDT
|
|
|
|
supplied by the
|
|
|
|
.Tn BIOS .
|
2010-01-31 14:29:31 +03:00
|
|
|
.Pp
|
2010-04-11 12:58:43 +04:00
|
|
|
The following steps can be used to override the
|
|
|
|
.Tn DSDT :
|
|
|
|
.Bl -enum -offset indent
|
|
|
|
.It
|
|
|
|
Dump the raw
|
|
|
|
.Tn DSDT
|
|
|
|
with
|
|
|
|
.Xr acpidump 8 .
|
|
|
|
.It
|
|
|
|
Disassemble the table with
|
|
|
|
.Xr iasl 8 .
|
|
|
|
.It
|
|
|
|
Modify the disassembled table.
|
|
|
|
.It
|
|
|
|
Compile the table with
|
|
|
|
.Xr iasl 8
|
|
|
|
using the option
|
|
|
|
.Ar \-tc .
|
|
|
|
.It
|
|
|
|
Either copy the
|
|
|
|
.Pq Pa *.hex
|
|
|
|
file to
|
|
|
|
.Bd -literal -offset indent
|
|
|
|
src/sys/dev/acpi/acpica/Osd/custom_dsdt.hex
|
|
|
|
.Ed
|
|
|
|
.Pp
|
|
|
|
or use the option
|
|
|
|
.Bd -literal -offset indent
|
|
|
|
ACPI_DSDT_FILE="/some/directory/custom_dsdt.hex"
|
|
|
|
.Ed
|
|
|
|
.Pp
|
|
|
|
in the kernel configuration file.
|
|
|
|
.It
|
|
|
|
Define
|
|
|
|
.Tn ACPI_DSDT_OVERRIDE
|
|
|
|
in the kernel configuration file and rebuild.
|
|
|
|
.El
|
2010-06-07 12:39:04 +04:00
|
|
|
.Ss Debugger
|
2010-04-25 21:50:13 +04:00
|
|
|
The
|
|
|
|
.Tn ACPICA
|
|
|
|
interpreter provides its own debugger for low-level debugging.
|
|
|
|
It can be used to display internal data structures and namespace objects,
|
|
|
|
and to debug the execution of control methods.
|
|
|
|
Single step and breakpoint functionality are available.
|
|
|
|
In
|
|
|
|
.Nx
|
|
|
|
this is integrated to the in-kernel
|
|
|
|
.Xr ddb 4 .
|
|
|
|
In order to enter the
|
|
|
|
.Tn ACPICA
|
|
|
|
debugger from
|
|
|
|
.Xr ddb 4 ,
|
|
|
|
use the command
|
|
|
|
.Ic call
|
|
|
|
with the argument
|
|
|
|
.Ic acpi_osd_debugger .
|
2010-06-07 12:39:04 +04:00
|
|
|
.Ss Debug Output
|
2010-04-11 12:58:43 +04:00
|
|
|
.Nx
|
2010-06-30 11:42:36 +04:00
|
|
|
provides three
|
2010-04-11 12:58:43 +04:00
|
|
|
.Xr sysctl 8
|
|
|
|
variables that control the debug output at runtime.
|
2010-01-31 14:29:31 +03:00
|
|
|
The
|
2010-04-12 16:21:17 +04:00
|
|
|
.Ic hw.acpi.debug.layer
|
2010-06-30 11:42:36 +04:00
|
|
|
variable limits the output to a specific
|
2010-01-31 14:29:31 +03:00
|
|
|
.Tn ACPI
|
|
|
|
layer and the
|
2010-04-12 16:21:17 +04:00
|
|
|
.Ic hw.acpi.debug.level
|
2010-06-30 11:42:36 +04:00
|
|
|
variable controls the debug level.
|
2010-01-31 14:29:31 +03:00
|
|
|
Both
|
2010-03-06 09:25:51 +03:00
|
|
|
.Xr sysctl 8
|
2010-01-31 14:29:31 +03:00
|
|
|
variables are string literals.
|
2010-06-30 11:42:36 +04:00
|
|
|
The third variable is
|
|
|
|
.Ic hw.acpi.debug.object .
|
|
|
|
This is a boolean that controls whether debug messages internal to the
|
|
|
|
.Tn AML
|
|
|
|
are enabled.
|
2010-04-11 12:58:43 +04:00
|
|
|
.Pp
|
2010-06-30 11:42:36 +04:00
|
|
|
For the first two variables, the possible values are:
|
2010-01-31 14:29:31 +03:00
|
|
|
.Bl -column -offset indent \
|
|
|
|
"ACPI_RESOURCE_COMPONENT " "ACPI_RESOURCE_COMPONENT "
|
|
|
|
.It Sy LAYER Ta Sy LEVEL
|
|
|
|
.It Li ACPI_DEBUG_NONE Ta ACPI_DEBUG_NONE
|
2010-02-28 00:12:58 +03:00
|
|
|
.It Ta
|
2010-01-31 14:29:31 +03:00
|
|
|
.It Li ACPI_UTILITIES Ta ACPI_LV_INIT
|
|
|
|
.It Li ACPI_HARDWARE Ta ACPI_LV_DEBUG_OBJECT
|
|
|
|
.It Li ACPI_EVENTS Ta ACPI_LV_INFO
|
|
|
|
.It Li ACPI_TABLES Ta ACPI_LV_ALL_EXCEPTIONS *
|
|
|
|
.It Li ACPI_NAMESPACE Ta
|
|
|
|
.It Li ACPI_PARSER Ta ACPI_LV_INIT_NAMES
|
|
|
|
.It Li ACPI_DISPATCHER Ta ACPI_LV_PARSE
|
|
|
|
.It Li ACPI_EXECUTER Ta ACPI_LV_LOAD
|
|
|
|
.It Li ACPI_RESOURCES Ta ACPI_LV_DISPATCH
|
|
|
|
.It Li ACPI_CA_DEBUGGER Ta ACPI_LV_EXEC
|
|
|
|
.It Li ACPI_OS_SERVICES Ta ACPI_LV_NAMES
|
|
|
|
.It Li ACPI_CA_DISASSEMBLER Ta ACPI_LV_OPREGION
|
|
|
|
.It Li ACPI_COMPILER Ta ACPI_LV_BFIELD
|
|
|
|
.It Li ACPI_TOOLS Ta ACPI_LV_TABLES
|
|
|
|
.It Li ACPI_EXAMPLE Ta ACPI_LV_VALUES
|
|
|
|
.It Li ACPI_DRIVER Ta ACPI_LV_OBJECTS
|
|
|
|
.It Li ACPI_ALL_COMPONENTS * Ta ACPI_LV_RESOURCES
|
2010-02-28 00:12:58 +03:00
|
|
|
.It Ta ACPI_LV_USER_REQUESTS
|
2010-01-31 14:29:31 +03:00
|
|
|
.It Li ACPI_BUS_COMPONENT Ta ACPI_LV_PACKAGE
|
|
|
|
.It Li ACPI_ACAD_COMPONENT Ta ACPI_LV_VERBOSITY1 *
|
|
|
|
.It Li ACPI_BAT_COMPONENT Ta
|
|
|
|
.It Li ACPI_BUTTON_COMPONENT Ta ACPI_LV_ALLOCATIONS
|
|
|
|
.It Li APCI_EC_COMPONENT Ta ACPI_LV_FUNCTIONS
|
|
|
|
.It Li ACPI_LID_COMPONENT Ta ACPI_LV_OPTIMIZATIONS
|
|
|
|
.It Li ACPI_RESOURCE_COMPONENT Ta ACPI_LV_VERBOSITY2 *
|
|
|
|
.It Li ACPI_TZ_COMPONENT Ta
|
2010-10-27 18:39:26 +04:00
|
|
|
.It Li ACPI_DISPLAY_COMPONENT Ta
|
2010-01-31 14:29:31 +03:00
|
|
|
.It Li ACPI_ALL_DRIVERS * Ta ACPI_LV_MUTEX
|
2010-02-28 00:12:58 +03:00
|
|
|
.It Ta ACPI_LV_THREADS
|
|
|
|
.It Ta ACPI_LV_IO
|
|
|
|
.It Ta ACPI_LV_AML_INTERRUPTS
|
2010-01-31 14:29:31 +03:00
|
|
|
.It Li "* This is a compound" Ta ACPI_LV_VERBOSITY3 *
|
|
|
|
.It Li " constant, including" Ta
|
|
|
|
.It Li " all previous elements." Ta ACPI_LV_AML_DISASSEMBLE
|
2010-02-28 00:12:58 +03:00
|
|
|
.It Ta ACPI_LV_VERBOSE_INFO
|
|
|
|
.It Ta ACPI_LV_FULL_TABLES
|
|
|
|
.It Ta ACPI_LV_EVENTS
|
|
|
|
.It Ta ACPI_LV_VERBOSE *
|
2010-01-31 14:29:31 +03:00
|
|
|
.El
|
|
|
|
.Pp
|
|
|
|
In addition, there is
|
|
|
|
.Dv ACPI_DEBUG_DEFAULT
|
|
|
|
that is used by
|
|
|
|
.Tn ACPICA
|
2010-01-31 18:05:20 +03:00
|
|
|
as the default debug level.
|
|
|
|
It includes
|
2010-01-31 14:29:31 +03:00
|
|
|
.Dv ACPI_LV_INIT
|
|
|
|
and
|
|
|
|
.Dv ACPI_LV_DEBUG_OBJECT .
|
|
|
|
.Pp
|
|
|
|
The debug layer can be divided into two groups:
|
|
|
|
the first one is specific to the
|
|
|
|
.Tn ACPICA
|
|
|
|
interpreter and the second one contains the internal
|
|
|
|
.Tn ACPI
|
|
|
|
components of
|
|
|
|
.Nx .
|
|
|
|
The constant
|
|
|
|
.Dv ACPI_ALL_DRIVERS
|
|
|
|
includes all
|
|
|
|
.Nx
|
|
|
|
specific parts.
|
|
|
|
.Pp
|
|
|
|
The
|
|
|
|
.Tn ACPICA
|
|
|
|
interpreter uses several debug levels internally,
|
|
|
|
but the
|
|
|
|
.Nx
|
|
|
|
specific parts are typically limited to
|
|
|
|
.Dv ACPI_LV_DEBUG_OBJECT
|
|
|
|
and
|
2010-09-30 02:38:34 +04:00
|
|
|
.Dv ACPI_LV_INFO .
|
2010-01-31 14:29:31 +03:00
|
|
|
The debug output can be stopped by setting
|
2010-04-12 16:21:17 +04:00
|
|
|
.Ic hw.acpi.debug.level
|
2010-01-31 14:29:31 +03:00
|
|
|
to
|
|
|
|
.Dv ACPI_DEBUG_NONE .
|
2010-06-07 12:39:04 +04:00
|
|
|
.Ss Example
|
2010-01-31 14:29:31 +03:00
|
|
|
As an example, a driver may have defined the component it belongs to and
|
|
|
|
the name of the module:
|
|
|
|
.Bd -literal -offset indent
|
|
|
|
#define _COMPONENT ACPI_BUS_COMPONENT
|
|
|
|
ACPI_MODULE_NAME ("acpi_example")
|
|
|
|
.Ed
|
|
|
|
.Pp
|
|
|
|
The driver may also utilize the debug facility:
|
|
|
|
.Bd -literal -offset indent
|
|
|
|
ACPI_DEBUG_PRINT((ACPI_DB_INFO, "Failed to evaluate _STA\\n"));
|
|
|
|
.Ed
|
|
|
|
.Pp
|
|
|
|
With these options the debug message from the
|
|
|
|
.Dv ACPI_DEBUG_PRINT
|
|
|
|
macro is only visible when
|
2010-04-12 16:21:17 +04:00
|
|
|
.Ic hw.acpi.debug.layer
|
2010-01-31 14:29:31 +03:00
|
|
|
is either
|
|
|
|
.Dv ACPI_BUS_COMPONENT
|
|
|
|
or a compound constant including it, and
|
2010-04-12 16:21:17 +04:00
|
|
|
.Ic hw.acpi.debug.level
|
2010-01-31 14:29:31 +03:00
|
|
|
is
|
|
|
|
.Dv ACPI_LV_INFO
|
|
|
|
or some constant that includes it.
|
|
|
|
Finally, it can be noted that the
|
|
|
|
.Tn ACPI
|
|
|
|
implementation uses the prefix
|
|
|
|
.Dv ACPI_DB ,
|
|
|
|
whereas the debug level
|
2010-03-06 09:25:51 +03:00
|
|
|
.Xr sysctl 8
|
2010-01-31 14:29:31 +03:00
|
|
|
variable is always specified with the prefix
|
|
|
|
.Dv ACPI_LV .
|
2010-06-30 11:42:36 +04:00
|
|
|
.Pp
|
|
|
|
Another example can be mentioned for the use of
|
|
|
|
.Ic hw.acpi.debug.object .
|
|
|
|
The following could appear in an
|
|
|
|
.Tn ASL
|
|
|
|
code:
|
|
|
|
.Bd -literal -offset indent
|
|
|
|
Method(_Q19, 0, NotSerialized)
|
|
|
|
{
|
|
|
|
Store("_Q19 invoked", Debug)
|
|
|
|
Notify(ACAD, 0x80)
|
|
|
|
}
|
|
|
|
.Ed
|
|
|
|
.Pp
|
|
|
|
When
|
|
|
|
.Ic hw.acpi.debug.object
|
|
|
|
is set to 1, the message stored to the debug object
|
|
|
|
is printed every time the method is called by the interpreter.
|
2002-04-23 16:01:16 +04:00
|
|
|
.Sh SEE ALSO
|
2011-01-14 00:12:49 +03:00
|
|
|
.Xr ioapic 4 ,
|
2007-03-21 10:07:03 +03:00
|
|
|
.Xr acpidump 8 ,
|
2010-04-11 12:58:43 +04:00
|
|
|
.Xr amldb 8 ,
|
|
|
|
.Xr iasl 8
|
2004-04-25 07:12:11 +04:00
|
|
|
.Rs
|
2010-01-25 14:02:56 +03:00
|
|
|
.%A Hewlett-Packard Corporation
|
|
|
|
.%A Intel Corporation
|
|
|
|
.%A Microsoft Corporation
|
|
|
|
.%A Phoenix Technologies Ltd.
|
|
|
|
.%A Toshiba Corporation
|
|
|
|
.%T Advanced Configuration and Power Interface Specification
|
|
|
|
.%N Revision 4.0
|
|
|
|
.%D June 16, 2009
|
|
|
|
.%U http://www.acpi.info/spec.htm
|
2004-04-25 07:12:11 +04:00
|
|
|
.Re
|
|
|
|
.Rs
|
2010-01-25 14:02:56 +03:00
|
|
|
.%A Intel Corporation
|
|
|
|
.%T ACPI Component Architecture,
|
|
|
|
.%T Programmer Reference,
|
|
|
|
.%T OS-Independent Subsystem, Debugger, and Utilities
|
|
|
|
.%N Revision 1.27
|
|
|
|
.%D January 20, 2010
|
|
|
|
.%U http://www.acpica.org/download/acpica-reference.pdf
|
2004-04-25 07:12:11 +04:00
|
|
|
.Re
|
2010-01-25 20:21:32 +03:00
|
|
|
.Rs
|
2010-09-04 15:10:16 +04:00
|
|
|
.%A Len Brown
|
|
|
|
.%T ACPI in Linux - Myths vs. Reality
|
|
|
|
.%D June 27-30, 2007
|
2010-10-24 12:31:49 +04:00
|
|
|
.%O Proceedings of the Linux Symposium
|
|
|
|
.%P 65-74
|
2010-09-04 15:10:16 +04:00
|
|
|
.%U http://www.linuxsymposium.org/archives/OLS/Reprints-2007/brown_1-Reprint.pdf
|
|
|
|
.Re
|
|
|
|
.Rs
|
2010-01-25 20:21:32 +03:00
|
|
|
.%A Joerg Sonnenberger
|
|
|
|
.%A Jared D. McNeill
|
|
|
|
.%T Sleeping Beauty - NetBSD on Modern Laptops
|
|
|
|
.%D February 3, 2008
|
|
|
|
.%O Proceedings of AsiaBSDCon 2008
|
2010-10-24 12:31:49 +04:00
|
|
|
.%P 127-134
|
|
|
|
.%U http://2008.asiabsdcon.org/papers/P9A-paper.pdf
|
2010-01-25 20:21:32 +03:00
|
|
|
.Re
|
2011-08-09 11:33:01 +04:00
|
|
|
.Rs
|
|
|
|
.%A Takanori Watanabe
|
|
|
|
.%T ACPI Implementation on FreeBSD
|
|
|
|
.%I USENIX Association
|
|
|
|
.%B Proceedings of the FREENIX Track: 2002 USENIX Annual Technical Conference
|
|
|
|
.%P 121-131
|
|
|
|
.%D June 10-15, 2002
|
|
|
|
.%U http://www.usenix.org/event/usenix02/tech/freenix/full_papers/watanabe/watanabe.pdf
|
|
|
|
.Re
|
2002-04-23 16:01:16 +04:00
|
|
|
.Sh HISTORY
|
|
|
|
The
|
|
|
|
.Nm
|
|
|
|
driver
|
|
|
|
appeared in
|
|
|
|
.Nx 1.6 .
|
2011-01-14 10:11:18 +03:00
|
|
|
.Sh AUTHORS
|
|
|
|
.An -nosplit
|
|
|
|
Authors of the
|
|
|
|
.Nm
|
|
|
|
subsystem include
|
|
|
|
.An Charles M. Hannum ,
|
|
|
|
.An Frank van der Linden ,
|
|
|
|
.An Jared D. McNeill ,
|
|
|
|
.An Jason R. Thorpe ,
|
|
|
|
.An Joerg Sonnenberger ,
|
|
|
|
and
|
|
|
|
.An Jukka Ruohonen ,
|
|
|
|
among others.
|
2002-04-23 16:01:16 +04:00
|
|
|
.Sh BUGS
|
2004-04-25 07:12:11 +04:00
|
|
|
Most of the
|
2002-04-23 16:01:16 +04:00
|
|
|
.Tn ACPI
|
2004-04-25 07:12:11 +04:00
|
|
|
power management functionalities are not implemented.
|