NetBSD-5.0.2/sys/dev/acpi/acpireg.h

/*	$NetBSD: acpireg.h,v 1.5 2005/12/11 12:21:02 christos Exp $	*/

/*
 * Copyright 2001 Wasabi Systems, Inc.
 * All rights reserved.
 *
 * Written by Jason R. Thorpe for Wasabi Systems, Inc.
 *
 * 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.
 * 3. All advertising materials mentioning features or use of this software
 *    must display the following acknowledgement:
 *	This product includes software developed for the NetBSD Project by
 *	Wasabi Systems, Inc.
 * 4. The name of Wasabi Systems, Inc. may not be used to endorse
 *    or promote products derived from this software without specific prior
 *    written permission.
 *
 * THIS SOFTWARE IS PROVIDED BY WASABI SYSTEMS, INC. ``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 WASABI SYSTEMS, INC
 * 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.
 */

/*
 * This file defines various ACPI event messages, etc.
 */

/*
 * 5.6.3: Device Object Notifications
 */

/* Device Object Notification Types */
#define	ACPI_NOTIFY_BusCheck		0x00
#define	ACPI_NOTIFY_DeviceCheck		0x01
#define	ACPI_NOTIFY_DeviceWake		0x02
#define	ACPI_NOTIFY_EjectRequest	0x03
#define	ACPI_NOTIFY_DeviceCheckLight	0x04
#define	ACPI_NOTIFY_FrquencyMismatch	0x05
#define	ACPI_NOTIFY_BusModeMismatch	0x06
#define	ACPI_NOTIFY_PowerFault		0x07
				/*	0x08 - 0x7f	reserved */

/* Control Method Battery Device Notification Types */
#define	ACPI_NOTIFY_BatteryStatusChanged	0x80
#define	ACPI_NOTIFY_BatteryInformationChanged	0x81

/* Power Source Object Notification Types */
#define	ACPI_NOTIFY_PowerSourceStatusChanged	0x80

/* Thermal Zone Object Notication Types */
#define	ACPI_NOTIFY_ThermalZoneStatusChanged	0x80
#define	ACPI_NOTIFY_ThermalZoneTripPointsChanged 0x81
#define	ACPI_NOTIFY_DeviceListsChanged		0x82

/* Control Method Power Button Notification Types */
#define	ACPI_NOTIFY_S0PowerButtonPressed	0x80

/* Control Method Sleep Button Notification Types */
#define	ACPI_NOTIFY_S0SleepButtonPressed	0x80

/* Control Method Lid Notification Types */
#define	ACPI_NOTIFY_LidStatusChanged		0x80

/* Processor Device Notification Values */
#define	ACPI_NOTIFY_PerformancePresentCapabilitiesChanged 0x80
#define	ACPI_NOTIFY_CStatesChanged		0x81

/*
 * 6: Configuration
 *
 * 6.1: Device Identification Objects
 *
 *	_ADR	Object that evaluates to a device's address on
 *		its parent bus.
 *
 *	_CID	Object that evaluates to a device's Plug and Play
 *		compatible ID list.
 *
 *	_DDN	Object that associates a logical software name
 *		(for example, COM1) with a device.
 *
 *	_HID	Object that evaluates to a device's Plug and Play
 *		hardware ID.
 *
 *	_SUN	Objcet that evaluates to the slot-unique ID number
 *		for a slot.
 *
 *	_STR	Object that contains a Unicode identifier for a device.
 *
 *	_UID	Object that specifies a device's unique persistent ID,
 *		or a control method that generates it.
 */

/*
 * 6.1.1: _ADR (Address)
 *
 *	EISA		EISA slot numnber 0-f
 *
 *	Floppy Bus	Drive select values used for programming
 *			the floppy controller to access the
 *			specified INT13 unit number.  The _ADR
 *			objects should be sorted based on drive
 *			select encoding from 0-3.
 *
 *	IDE controller	0 - primary channel, 1 - secondary channel
 *
 *	IDE channel	0 - master drive, 1 - slave drive
 *
 *	PCI		High word - Device #, Low word - Function #
 *			0xffff == all functions on a device
 *
 *	PCMCIA		Socket #; 0 == first socket
 *
 *	PC Card		Socket #; 0 == first socket
 *
 *	SMBus		Lowest slave address
 *
 *	USB Root Hub	Only one child of the host controller, must
 *			have an _ADR of 0.
 *
 *	USB ports	port number
 */
#define	ACPI_ADR_PCI_DEV(x)	(((x) >> 16) & 0xffff)
#define	ACPI_ADR_PCI_FUNC(x)	((x) & 0xffff)
#define	ACPI_ADR_PCI_ALLFUNCS	0xffff

/*
 * 6.1.2: _CID (Compatible ID)
 */

/*
 * 6.1.3: _DDN (Device Name)
 */

/*
 * 6.1.4: _HID (Hardware ID)
 */

/*
 * 6.1.5: _STR (String)
 */

/*
 * 6.1.6: _SUN (Slot User Number)
 */

/*
 * 6.1.7: _UID (Unique ID)
 */

/*
 * 6.2: Device Configuration Objects
 *
 *	_CRS	Object that specifies a device's *current* resource
 *		settings, or a control method that generates such
 *		an object.
 *
 *	_DIS	Control method that disables a device.
 *
 *	_DMA	Object that specifies a device's *current* resources
 *		for DMA transactions.
 *
 *	_FIX	Object used to provide correlation between the
 *		fixed-hardware register blocks defined in the FADT
 *		and the devices that implement these fixed-hardware
 *		registers.
 *
 *	_HPP	Object that specifies the cache-line size, latency
 *		timer, SERR enable, and PERR enable values to be
 *		used when configuring a PCI device inserted into
 *		a hot-plug slot or initial configuration of a PCI
 *		device at system boot.
 *
 *	_MAT	Object that evaluates to a buffer of MADT APIC
 *		structure entries.
 *
 *	_PRS	An object that specifies a device's *possible*
 *		resource settings, or a control method that
 *		generates such an object.
 *
 *	_PRT	Object that specifies the PCI interrupt routing
 *		table.
 *
 *	_PXM	Object that specifies a proximity domain for a device.
 *
 *	_SRS	Control method that sets a device's settings.
 */

/*
 * 6.2.1: _CRS (Current Resource Settings)
 */

/*
 * 6.2.2: _DIS (Disable)
 */

/*
 * 6.2.3: _DMA (Direct Memory AccesS)
 */

/*
 * 6.2.4: _FIX (Fixed Register Resource Provider)
 */

/*
 * 6.2.5: _HPP (Hot Plug Parameters)
 */

/*
 * 6.2.6: _MAT (Multiple APIC Table Entry)
 */

/*
 * 6.2.7: _PRS (Possible Resource Settings)
 */

/*
 * 6.2.8: _PRT (PCI Routing Table)
 */

/*
 * 6.2.9: _PXM (Proximity)
 */

/*
 * 6.2.10: _SRS (Set Resource Settings)
 */

/*
 * 6.3: Device Insertion and Removal Objects
 *
 *	_EDL	Object that evaluates to a package of namespace
 *		references of device objects that depend on
 *		the device containing _EDL.  Whenever the named
 *		devices is ejected, OSPM ejects all dependent
 *		devices.
 *
 *	_EJD	Object that evaluates to the name of a device object
 *		on which a device depends.  Whenever the named
 *		device is ejected, the dependent device must receive
 *		an ejection notification.
 *
 *	_EJx	Control method that ejects a device.
 *
 *	_LCK	Control method that locks or unlocks a device.
 *
 *	_RMV	Object that indicates that the given device is
 *		removable.
 *
 *	_STA	Control method that returns a device's status.
 */

/*
 * 6.3.1: _EDL (Eject Device List)
 */

/*
 * 6.3.2: _EJD (Ejection Dependent Device)
 */

/*
 * 6.3.3: _EJx (Eject)
 *
 *	x	Indicates sleeping state at which device
 *		can be ejected.
 */

/*
 * 6.3.4: _LCK (Lock)
 */

/*
 * 6.3.5: _RMV (Remove)
 */

/*
 * 6.3.6: _STA (Status) for device insertion/removal
 */
#define	ACPI_STA_DEV_PRESENT	0x00000001	/* device present */
#define	ACPI_STA_DEV_ENABLED	0x00000002	/* enabled (decoding res.) */
#define	ACPI_STA_DEV_SHOW	0x00000004	/* show device in UI */
#define	ACPI_STA_DEV_OK		0x00000008	/* functioning properly */
#define	ACPI_STA_DEV_BATT	0x00000010	/* battery present */

/*
 * 6.4: Resource Data Types for ACPI
 *
 *	Used by the _CRS, _PRS, and _SRS methods.
 */

/*
 * 7.1.4: _STA (Status) for power resource current state
 */
#define	ACPI_STA_POW_OFF	0		/* power resource off */
#define	ACPI_STA_POW_ON		1		/* power resource on */

/*
 * ACPI driver components
 */

#define	ACPI_BUS_COMPONENT	0x00010000
#define	ACPI_ACAD_COMPONENT	0x00020000
#define	ACPI_BAT_COMPONENT	0x00040000
#define	ACPI_BUTTON_COMPONENT	0x00080000
#define	ACPI_EC_COMPONENT	0x00100000
#define	ACPI_LID_COMPONENT	0x00200000
#define	ACPI_RESOURCE_COMPONENT	0x00400000