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 341da177e4SLinus Torvalds #define ACPI_BUS_COMPONENT 0x00010000 351da177e4SLinus Torvalds #define ACPI_SYSTEM_COMPONENT 0x02000000 361da177e4SLinus Torvalds 371da177e4SLinus Torvalds /* _HID definitions */ 381da177e4SLinus Torvalds 39bb095854SZhang Rui #define ACPI_POWER_HID "power_resource" 4011bf04c4SAlexey Starikovskiy #define ACPI_PROCESSOR_HID "ACPI0007" 41bb095854SZhang Rui #define ACPI_SYSTEM_HID "acpi_system" 42bb095854SZhang Rui #define ACPI_THERMAL_HID "thermal" 43bb095854SZhang Rui #define ACPI_BUTTON_HID_POWERF "button_power" 44bb095854SZhang Rui #define ACPI_BUTTON_HID_SLEEPF "button_sleep" 45bb095854SZhang Rui #define ACPI_VIDEO_HID "video" 46bb095854SZhang Rui #define ACPI_BAY_HID "bay" 471da177e4SLinus Torvalds /* -------------------------------------------------------------------------- 481da177e4SLinus Torvalds PCI 491da177e4SLinus Torvalds -------------------------------------------------------------------------- */ 501da177e4SLinus Torvalds 511da177e4SLinus Torvalds #define ACPI_PCI_COMPONENT 0x00400000 521da177e4SLinus Torvalds 531da177e4SLinus Torvalds /* ACPI PCI Interrupt Link (pci_link.c) */ 541da177e4SLinus Torvalds 551da177e4SLinus Torvalds int acpi_irq_penalty_init(void); 5650eca3ebSBob Moore int acpi_pci_link_allocate_irq(acpi_handle handle, int index, int *triggering, 5750eca3ebSBob Moore int *polarity, char **name); 5887bec66bSDavid Shaohua Li int acpi_pci_link_free_irq(acpi_handle handle); 591da177e4SLinus Torvalds 601da177e4SLinus Torvalds /* ACPI PCI Interrupt Routing (pci_irq.c) */ 611da177e4SLinus Torvalds 621da177e4SLinus Torvalds int acpi_pci_irq_add_prt(acpi_handle handle, int segment, int bus); 631da177e4SLinus Torvalds void acpi_pci_irq_del_prt(int segment, int bus); 641da177e4SLinus Torvalds 651da177e4SLinus Torvalds /* ACPI PCI Device Binding (pci_bind.c) */ 661da177e4SLinus Torvalds 671da177e4SLinus Torvalds struct pci_bus; 681da177e4SLinus Torvalds 694ce448e5SRajesh Shah acpi_status acpi_get_pci_id(acpi_handle handle, struct acpi_pci_id *id); 701da177e4SLinus Torvalds int acpi_pci_bind(struct acpi_device *device); 711da177e4SLinus Torvalds int acpi_pci_unbind(struct acpi_device *device); 724be44fcdSLen Brown int acpi_pci_bind_root(struct acpi_device *device, struct acpi_pci_id *id, 734be44fcdSLen Brown struct pci_bus *bus); 741da177e4SLinus Torvalds 751da177e4SLinus Torvalds /* Arch-defined function to add a bus to the system */ 761da177e4SLinus Torvalds 774be44fcdSLen Brown struct pci_bus *pci_acpi_scan_root(struct acpi_device *device, int domain, 784be44fcdSLen Brown int bus); 791da177e4SLinus Torvalds 801da177e4SLinus Torvalds /* -------------------------------------------------------------------------- 811da177e4SLinus Torvalds Power Resource 821da177e4SLinus Torvalds -------------------------------------------------------------------------- */ 831da177e4SLinus Torvalds 841da177e4SLinus Torvalds #ifdef CONFIG_ACPI_POWER 851da177e4SLinus Torvalds int acpi_enable_wakeup_device_power(struct acpi_device *dev); 861da177e4SLinus Torvalds int acpi_disable_wakeup_device_power(struct acpi_device *dev); 871da177e4SLinus Torvalds int acpi_power_get_inferred_state(struct acpi_device *device); 881da177e4SLinus Torvalds int acpi_power_transition(struct acpi_device *device, int state); 891da177e4SLinus Torvalds #endif 901da177e4SLinus Torvalds 911da177e4SLinus Torvalds /* -------------------------------------------------------------------------- 921da177e4SLinus Torvalds Embedded Controller 931da177e4SLinus Torvalds -------------------------------------------------------------------------- */ 941da177e4SLinus Torvalds #ifdef CONFIG_ACPI_EC 951da177e4SLinus Torvalds int acpi_ec_ecdt_probe(void); 961da177e4SLinus Torvalds #endif 971da177e4SLinus Torvalds 981da177e4SLinus Torvalds /* -------------------------------------------------------------------------- 991da177e4SLinus Torvalds Processor 1001da177e4SLinus Torvalds -------------------------------------------------------------------------- */ 1011da177e4SLinus Torvalds 1021da177e4SLinus Torvalds #define ACPI_PROCESSOR_LIMIT_NONE 0x00 1031da177e4SLinus Torvalds #define ACPI_PROCESSOR_LIMIT_INCREMENT 0x01 1041da177e4SLinus Torvalds #define ACPI_PROCESSOR_LIMIT_DECREMENT 0x02 1051da177e4SLinus Torvalds 1061da177e4SLinus Torvalds int acpi_processor_set_thermal_limit(acpi_handle handle, int type); 1071da177e4SLinus Torvalds 108fb9802faSLuming Yu /* -------------------------------------------------------------------------- 109fb9802faSLuming Yu Hot Keys 110fb9802faSLuming Yu -------------------------------------------------------------------------- */ 111fb9802faSLuming Yu 112fb9802faSLuming Yu extern int acpi_specific_hotkey_enabled; 1131da177e4SLinus Torvalds 114c8f7a62cSLen Brown /*-------------------------------------------------------------------------- 115c8f7a62cSLen Brown Dock Station 116c8f7a62cSLen Brown -------------------------------------------------------------------------- */ 117c8f7a62cSLen Brown #if defined(CONFIG_ACPI_DOCK) || defined(CONFIG_ACPI_DOCK_MODULE) 118c8f7a62cSLen Brown extern int is_dock_device(acpi_handle handle); 119c8f7a62cSLen Brown extern int register_dock_notifier(struct notifier_block *nb); 120c8f7a62cSLen Brown extern void unregister_dock_notifier(struct notifier_block *nb); 121c8f7a62cSLen Brown extern int register_hotplug_dock_device(acpi_handle handle, 122c8f7a62cSLen Brown acpi_notify_handler handler, void *context); 123c8f7a62cSLen Brown extern void unregister_hotplug_dock_device(acpi_handle handle); 124c8f7a62cSLen Brown #else 125c8f7a62cSLen Brown #define is_dock_device(h) (0) 126c8f7a62cSLen Brown #define register_dock_notifier(nb) (-ENODEV) 127c8f7a62cSLen Brown #define unregister_dock_notifier(nb) do { } while(0) 128c8f7a62cSLen Brown #define register_hotplug_dock_device(h1, h2, c) (-ENODEV) 129c8f7a62cSLen Brown #define unregister_hotplug_dock_device(h) do { } while(0) 130c8f7a62cSLen Brown #endif 131*aafbcd16SAlexey Starikovskiy 132*aafbcd16SAlexey Starikovskiy /*-------------------------------------------------------------------------- 133*aafbcd16SAlexey Starikovskiy Suspend/Resume 134*aafbcd16SAlexey Starikovskiy -------------------------------------------------------------------------- */ 135*aafbcd16SAlexey Starikovskiy #ifdef CONFIG_ACPI_SLEEP 136*aafbcd16SAlexey Starikovskiy extern int acpi_sleep_init(void); 137*aafbcd16SAlexey Starikovskiy #else 138*aafbcd16SAlexey Starikovskiy #define acpi_sleep_init() do {} while (0) 139*aafbcd16SAlexey Starikovskiy #endif 140*aafbcd16SAlexey Starikovskiy 1411da177e4SLinus Torvalds #endif /*__ACPI_DRIVERS_H__*/ 142