2005-04-16 15:20:36 -07:00
/******************************************************************************
*
* Name : achware . h - - hardware specific interfaces
*
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
/*
2012-01-12 13:27:23 +08:00
* Copyright ( C ) 2000 - 2012 , Intel Corp .
2005-04-16 15:20:36 -07: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 ,
* without modification .
* 2. Redistributions in binary form must reproduce at minimum a disclaimer
* substantially similar to the " NO WARRANTY " disclaimer below
* ( " Disclaimer " ) and any redistribution must be conditioned upon
* including a substantially similar Disclaimer requirement for further
* binary redistribution .
* 3. Neither the names of the above - listed copyright holders nor the names
* of any contributors may be used to endorse or promote products derived
* from this software without specific prior written permission .
*
* Alternatively , this software may be distributed under the terms of the
* GNU General Public License ( " GPL " ) version 2 as published by the Free
* Software Foundation .
*
* NO WARRANTY
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
* " AS IS " AND ANY EXPRESS OR IMPLIED WARRANTIES , INCLUDING , BUT NOT
* LIMITED TO , THE IMPLIED WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR
* A PARTICULAR PURPOSE ARE DISCLAIMED . IN NO EVENT SHALL THE COPYRIGHT
* HOLDERS OR CONTRIBUTORS BE LIABLE FOR 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 DAMAGES .
*/
# ifndef __ACHWARE_H__
# define __ACHWARE_H__
2008-12-31 03:01:23 +08:00
/* Values for the _SST predefined method */
2005-04-16 15:20:36 -07:00
2005-04-18 22:49:35 -04:00
# define ACPI_SST_INDICATOR_OFF 0
# define ACPI_SST_WORKING 1
# define ACPI_SST_WAKING 2
# define ACPI_SST_SLEEPING 3
# define ACPI_SST_SLEEP_CONTEXT 4
2005-04-16 15:20:36 -07:00
2005-04-18 22:49:35 -04:00
/*
* hwacpi - high level functions
*/
2005-08-05 00:44:28 -04:00
acpi_status acpi_hw_set_mode ( u32 mode ) ;
2005-04-16 15:20:36 -07:00
2005-08-05 00:44:28 -04:00
u32 acpi_hw_get_mode ( void ) ;
2005-04-16 15:20:36 -07:00
2005-04-18 22:49:35 -04:00
/*
* hwregs - ACPI Register I / O
*/
2009-06-24 09:44:06 +08:00
acpi_status
acpi_hw_validate_register ( struct acpi_generic_address * reg ,
u8 max_bit_width , u64 * address ) ;
acpi_status acpi_hw_read ( u32 * value , struct acpi_generic_address * reg ) ;
acpi_status acpi_hw_write ( u32 value , struct acpi_generic_address * reg ) ;
2005-08-05 00:44:28 -04:00
struct acpi_bit_register_info * acpi_hw_get_bit_register_info ( u32 register_id ) ;
2005-04-16 15:20:36 -07:00
2009-02-18 14:36:05 +08:00
acpi_status acpi_hw_write_pm1_control ( u32 pm1a_control , u32 pm1b_control ) ;
acpi_status acpi_hw_register_read ( u32 register_id , u32 * return_value ) ;
2005-04-16 15:20:36 -07:00
2007-09-30 22:39:36 +04:00
acpi_status acpi_hw_register_write ( u32 register_id , u32 value ) ;
2005-04-16 15:20:36 -07:00
2007-02-02 19:48:21 +03:00
acpi_status acpi_hw_clear_acpi_status ( void ) ;
2005-04-16 15:20:36 -07:00
2012-02-14 15:00:53 +08:00
/*
2012-02-14 18:47:42 +08:00
* hwsleep - sleep / wake support ( Legacy sleep registers )
*/
2012-07-26 20:08:54 -04:00
acpi_status acpi_hw_legacy_sleep ( u8 sleep_state ) ;
2012-02-14 18:47:42 +08:00
2012-07-26 20:08:54 -04:00
acpi_status acpi_hw_legacy_wake_prep ( u8 sleep_state ) ;
2012-02-14 18:47:42 +08:00
2012-07-26 20:08:54 -04:00
acpi_status acpi_hw_legacy_wake ( u8 sleep_state ) ;
2012-02-14 18:47:42 +08:00
/*
* hwesleep - sleep / wake support ( Extended FADT - V5 sleep registers )
2012-02-14 15:00:53 +08:00
*/
2012-02-14 18:43:03 +08:00
void acpi_hw_execute_sleep_method ( char * method_name , u32 integer_argument ) ;
2012-02-14 15:00:53 +08:00
2012-07-26 20:08:54 -04:00
acpi_status acpi_hw_extended_sleep ( u8 sleep_state ) ;
2012-02-14 15:00:53 +08:00
2012-07-26 20:08:54 -04:00
acpi_status acpi_hw_extended_wake_prep ( u8 sleep_state ) ;
2012-02-14 15:00:53 +08:00
2012-07-26 20:08:54 -04:00
acpi_status acpi_hw_extended_wake ( u8 sleep_state ) ;
2012-02-14 15:00:53 +08:00
2009-03-19 09:37:47 +08:00
/*
* hwvalid - Port I / O with validation
*/
acpi_status acpi_hw_read_port ( acpi_io_address address , u32 * value , u32 width ) ;
acpi_status acpi_hw_write_port ( acpi_io_address address , u32 value , u32 width ) ;
2005-04-18 22:49:35 -04:00
/*
* hwgpe - GPE support
*/
2010-07-01 10:07:17 +08:00
u32 acpi_hw_get_gpe_register_bit ( struct acpi_gpe_event_info * gpe_event_info ,
2010-06-08 10:48:26 +02:00
struct acpi_gpe_register_info * gpe_register_info ) ;
2010-06-08 10:49:08 +02:00
acpi_status
2010-12-13 13:39:37 +08:00
acpi_hw_low_set_gpe ( struct acpi_gpe_event_info * gpe_event_info , u32 action ) ;
2008-06-13 08:28:55 +08:00
2005-04-16 15:20:36 -07:00
acpi_status
2005-08-05 00:44:28 -04:00
acpi_hw_disable_gpe_block ( struct acpi_gpe_xrupt_info * gpe_xrupt_info ,
2008-12-30 09:45:17 +08:00
struct acpi_gpe_block_info * gpe_block , void * context ) ;
2005-04-16 15:20:36 -07:00
2005-08-05 00:44:28 -04:00
acpi_status acpi_hw_clear_gpe ( struct acpi_gpe_event_info * gpe_event_info ) ;
2005-04-16 15:20:36 -07:00
acpi_status
2005-08-05 00:44:28 -04:00
acpi_hw_clear_gpe_block ( struct acpi_gpe_xrupt_info * gpe_xrupt_info ,
2008-12-30 09:45:17 +08:00
struct acpi_gpe_block_info * gpe_block , void * context ) ;
2005-04-16 15:20:36 -07:00
acpi_status
2005-08-05 00:44:28 -04:00
acpi_hw_get_gpe_status ( struct acpi_gpe_event_info * gpe_event_info ,
acpi_event_status * event_status ) ;
2005-04-16 15:20:36 -07:00
2005-08-05 00:44:28 -04:00
acpi_status acpi_hw_disable_all_gpes ( void ) ;
2005-04-16 15:20:36 -07:00
2005-08-05 00:44:28 -04:00
acpi_status acpi_hw_enable_all_runtime_gpes ( void ) ;
2005-04-16 15:20:36 -07:00
2005-08-05 00:44:28 -04:00
acpi_status acpi_hw_enable_all_wakeup_gpes ( void ) ;
2005-04-16 15:20:36 -07:00
acpi_status
2005-08-05 00:44:28 -04:00
acpi_hw_enable_runtime_gpe_block ( struct acpi_gpe_xrupt_info * gpe_xrupt_info ,
2008-12-30 09:45:17 +08:00
struct acpi_gpe_block_info * gpe_block ,
void * context ) ;
2005-04-16 15:20:36 -07:00
2010-09-15 13:22:46 +08:00
/*
* hwpci - PCI configuration support
*/
acpi_status
acpi_hw_derive_pci_id ( struct acpi_pci_id * pci_id ,
acpi_handle root_pci_device , acpi_handle pci_region ) ;
2005-08-05 00:44:28 -04:00
# endif /* __ACHWARE_H__ */