11da177e4SLinus Torvalds /* 21da177e4SLinus Torvalds * acpi_drivers.h ($Revision: 31 $) 31da177e4SLinus Torvalds * 41da177e4SLinus Torvalds * Copyright (C) 2001, 2002 Andy Grover <andrew.grover@intel.com> 51da177e4SLinus Torvalds * Copyright (C) 2001, 2002 Paul Diefenbaugh <paul.s.diefenbaugh@intel.com> 61da177e4SLinus Torvalds * 71da177e4SLinus Torvalds * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ 81da177e4SLinus Torvalds * 91da177e4SLinus Torvalds * This program is free software; you can redistribute it and/or modify 101da177e4SLinus Torvalds * it under the terms of the GNU General Public License as published by 111da177e4SLinus Torvalds * the Free Software Foundation; either version 2 of the License, or (at 121da177e4SLinus Torvalds * your option) any later version. 131da177e4SLinus Torvalds * 141da177e4SLinus Torvalds * This program is distributed in the hope that it will be useful, but 151da177e4SLinus Torvalds * WITHOUT ANY WARRANTY; without even the implied warranty of 161da177e4SLinus Torvalds * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 171da177e4SLinus Torvalds * General Public License for more details. 181da177e4SLinus Torvalds * 191da177e4SLinus Torvalds * You should have received a copy of the GNU General Public License along 201da177e4SLinus Torvalds * with this program; if not, write to the Free Software Foundation, Inc., 211da177e4SLinus Torvalds * 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA. 221da177e4SLinus Torvalds * 231da177e4SLinus Torvalds * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ 241da177e4SLinus Torvalds */ 251da177e4SLinus Torvalds 261da177e4SLinus Torvalds #ifndef __ACPI_DRIVERS_H__ 271da177e4SLinus Torvalds #define __ACPI_DRIVERS_H__ 281da177e4SLinus Torvalds 291da177e4SLinus Torvalds #include <linux/acpi.h> 301da177e4SLinus Torvalds #include <acpi/acpi_bus.h> 311da177e4SLinus Torvalds 321da177e4SLinus Torvalds #define ACPI_MAX_STRING 80 331da177e4SLinus Torvalds 34bdd72799SBjorn Helgaas /* 35bdd72799SBjorn Helgaas * Please update drivers/acpi/debug.c and Documentation/acpi/debug.txt 36bdd72799SBjorn Helgaas * if you add to this list. 37bdd72799SBjorn Helgaas */ 381da177e4SLinus Torvalds #define ACPI_BUS_COMPONENT 0x00010000 3989595b8fSBjorn Helgaas #define ACPI_AC_COMPONENT 0x00020000 4089595b8fSBjorn Helgaas #define ACPI_BATTERY_COMPONENT 0x00040000 4189595b8fSBjorn Helgaas #define ACPI_BUTTON_COMPONENT 0x00080000 4244342f9eSBjorn Helgaas #define ACPI_SBS_COMPONENT 0x00100000 4389595b8fSBjorn Helgaas #define ACPI_FAN_COMPONENT 0x00200000 4489595b8fSBjorn Helgaas #define ACPI_PCI_COMPONENT 0x00400000 4589595b8fSBjorn Helgaas #define ACPI_POWER_COMPONENT 0x00800000 4689595b8fSBjorn Helgaas #define ACPI_CONTAINER_COMPONENT 0x01000000 471da177e4SLinus Torvalds #define ACPI_SYSTEM_COMPONENT 0x02000000 4889595b8fSBjorn Helgaas #define ACPI_THERMAL_COMPONENT 0x04000000 4989595b8fSBjorn Helgaas #define ACPI_MEMORY_DEVICE_COMPONENT 0x08000000 5044342f9eSBjorn Helgaas #define ACPI_VIDEO_COMPONENT 0x10000000 5144342f9eSBjorn Helgaas #define ACPI_PROCESSOR_COMPONENT 0x20000000 521da177e4SLinus Torvalds 538c8eb78fSThomas Renninger /* 548c8eb78fSThomas Renninger * _HID definitions 558c8eb78fSThomas Renninger * HIDs must conform to ACPI spec(6.1.4) 568c8eb78fSThomas Renninger * Linux specific HIDs do not apply to this and begin with LNX: 578c8eb78fSThomas Renninger */ 581da177e4SLinus Torvalds 598c8eb78fSThomas Renninger #define ACPI_POWER_HID "LNXPOWER" 60b9417f84SBjorn Helgaas #define ACPI_PROCESSOR_OBJECT_HID "LNXCPU" 618c8eb78fSThomas Renninger #define ACPI_SYSTEM_HID "LNXSYSTM" 628c8eb78fSThomas Renninger #define ACPI_THERMAL_HID "LNXTHERM" 638c8eb78fSThomas Renninger #define ACPI_BUTTON_HID_POWERF "LNXPWRBN" 648c8eb78fSThomas Renninger #define ACPI_BUTTON_HID_SLEEPF "LNXSLPBN" 658c8eb78fSThomas Renninger #define ACPI_VIDEO_HID "LNXVIDEO" 668c8eb78fSThomas Renninger #define ACPI_BAY_HID "LNXIOBAY" 67a340af14SFrank Seidel #define ACPI_DOCK_HID "LNXDOCK" 68222e82acSDarrick J. Wong /* Quirk for broken IBM BIOSes */ 69222e82acSDarrick J. Wong #define ACPI_SMBUS_IBM_HID "SMBUSIBM" 708c8eb78fSThomas Renninger 7146ec8598SBjorn Helgaas /* 7246ec8598SBjorn Helgaas * For fixed hardware buttons, we fabricate acpi_devices with HID 7346ec8598SBjorn Helgaas * ACPI_BUTTON_HID_POWERF or ACPI_BUTTON_HID_SLEEPF. Fixed hardware 7446ec8598SBjorn Helgaas * signals only an event; it doesn't supply a notification value. 7546ec8598SBjorn Helgaas * To allow drivers to treat notifications from fixed hardware the 7646ec8598SBjorn Helgaas * same as those from real devices, we turn the events into this 7746ec8598SBjorn Helgaas * notification value. 7846ec8598SBjorn Helgaas */ 7946ec8598SBjorn Helgaas #define ACPI_FIXED_HARDWARE_EVENT 0x100 8046ec8598SBjorn Helgaas 811da177e4SLinus Torvalds /* -------------------------------------------------------------------------- 821da177e4SLinus Torvalds PCI 831da177e4SLinus Torvalds -------------------------------------------------------------------------- */ 841da177e4SLinus Torvalds 851da177e4SLinus Torvalds 861da177e4SLinus Torvalds /* ACPI PCI Interrupt Link (pci_link.c) */ 871da177e4SLinus Torvalds 881da177e4SLinus Torvalds int acpi_irq_penalty_init(void); 8950eca3ebSBob Moore int acpi_pci_link_allocate_irq(acpi_handle handle, int index, int *triggering, 9050eca3ebSBob Moore int *polarity, char **name); 9187bec66bSDavid Shaohua Li int acpi_pci_link_free_irq(acpi_handle handle); 921da177e4SLinus Torvalds 931da177e4SLinus Torvalds /* ACPI PCI Interrupt Routing (pci_irq.c) */ 941da177e4SLinus Torvalds 95859a3f86SAlexander Chiang int acpi_pci_irq_add_prt(acpi_handle handle, struct pci_bus *bus); 96d9efae36SAlexander Chiang void acpi_pci_irq_del_prt(struct pci_bus *bus); 971da177e4SLinus Torvalds 981da177e4SLinus Torvalds /* ACPI PCI Device Binding (pci_bind.c) */ 991da177e4SLinus Torvalds 1001da177e4SLinus Torvalds struct pci_bus; 1011da177e4SLinus Torvalds 1022f7bbcebSAlexander Chiang struct pci_dev *acpi_get_pci_dev(acpi_handle); 103499650deSAlexander Chiang int acpi_pci_bind_root(struct acpi_device *device); 1041da177e4SLinus Torvalds 1051da177e4SLinus Torvalds /* Arch-defined function to add a bus to the system */ 1061da177e4SLinus Torvalds 10757283776SBjorn Helgaas struct pci_bus *pci_acpi_scan_root(struct acpi_pci_root *root); 1087bc5e3f2SBjorn Helgaas void pci_acpi_crs_quirks(void); 1091da177e4SLinus Torvalds 1101da177e4SLinus Torvalds /* -------------------------------------------------------------------------- 1111da177e4SLinus Torvalds Processor 1121da177e4SLinus Torvalds -------------------------------------------------------------------------- */ 1131da177e4SLinus Torvalds 1141da177e4SLinus Torvalds #define ACPI_PROCESSOR_LIMIT_NONE 0x00 1151da177e4SLinus Torvalds #define ACPI_PROCESSOR_LIMIT_INCREMENT 0x01 1161da177e4SLinus Torvalds #define ACPI_PROCESSOR_LIMIT_DECREMENT 0x02 1171da177e4SLinus Torvalds 118fb9802faSLuming Yu /*-------------------------------------------------------------------------- 119c8f7a62cSLen Brown Dock Station 120c8f7a62cSLen Brown -------------------------------------------------------------------------- */ 1211253f7aaSShaohua Li struct acpi_dock_ops { 1221253f7aaSShaohua Li acpi_notify_handler handler; 1231253f7aaSShaohua Li acpi_notify_handler uevent; 1241253f7aaSShaohua Li }; 1251253f7aaSShaohua Li 126c8f7a62cSLen Brown #if defined(CONFIG_ACPI_DOCK) || defined(CONFIG_ACPI_DOCK_MODULE) 127c8f7a62cSLen Brown extern int is_dock_device(acpi_handle handle); 128c8f7a62cSLen Brown extern int register_dock_notifier(struct notifier_block *nb); 129c8f7a62cSLen Brown extern void unregister_dock_notifier(struct notifier_block *nb); 130c8f7a62cSLen Brown extern int register_hotplug_dock_device(acpi_handle handle, 1319c8b04beSVasiliy Kulikov const struct acpi_dock_ops *ops, 132fd350943SLen Brown void *context); 133c8f7a62cSLen Brown extern void unregister_hotplug_dock_device(acpi_handle handle); 134c8f7a62cSLen Brown #else 135d94d3dffSAndrew Morton static inline int is_dock_device(acpi_handle handle) 136d94d3dffSAndrew Morton { 137d94d3dffSAndrew Morton return 0; 138d94d3dffSAndrew Morton } 139d94d3dffSAndrew Morton static inline int register_dock_notifier(struct notifier_block *nb) 140d94d3dffSAndrew Morton { 141d94d3dffSAndrew Morton return -ENODEV; 142d94d3dffSAndrew Morton } 143d94d3dffSAndrew Morton static inline void unregister_dock_notifier(struct notifier_block *nb) 144d94d3dffSAndrew Morton { 145d94d3dffSAndrew Morton } 146d94d3dffSAndrew Morton static inline int register_hotplug_dock_device(acpi_handle handle, 147*c1056b42SBart Van Assche const struct acpi_dock_ops *ops, 148fd350943SLen Brown void *context) 149d94d3dffSAndrew Morton { 150d94d3dffSAndrew Morton return -ENODEV; 151d94d3dffSAndrew Morton } 152d94d3dffSAndrew Morton static inline void unregister_hotplug_dock_device(acpi_handle handle) 153d94d3dffSAndrew Morton { 154d94d3dffSAndrew Morton } 155c8f7a62cSLen Brown #endif 156aafbcd16SAlexey Starikovskiy 1571da177e4SLinus Torvalds #endif /*__ACPI_DRIVERS_H__*/ 158