2018-03-15 02:13:07 +03:00
/* SPDX-License-Identifier: BSD-3-Clause OR GPL-2.0 */
2005-04-17 02:20:36 +04:00
/******************************************************************************
*
* Name : achware . h - - hardware specific interfaces
*
2023-04-05 16:38:21 +03:00
* Copyright ( C ) 2000 - 2023 , Intel Corp .
2005-04-17 02:20:36 +04:00
*
2018-03-15 02:13:07 +03:00
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2005-04-17 02:20:36 +04:00
# ifndef __ACHWARE_H__
# define __ACHWARE_H__
2008-12-30 22:01:23 +03:00
/* Values for the _SST predefined method */
2005-04-17 02:20:36 +04:00
2005-04-19 06: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-17 02:20:36 +04:00
2005-04-19 06:49:35 +04:00
/*
* hwacpi - high level functions
*/
2005-08-05 08:44:28 +04:00
acpi_status acpi_hw_set_mode ( u32 mode ) ;
2005-04-17 02:20:36 +04:00
2005-08-05 08:44:28 +04:00
u32 acpi_hw_get_mode ( void ) ;
2005-04-17 02:20:36 +04:00
2005-04-19 06:49:35 +04:00
/*
* hwregs - ACPI Register I / O
*/
2009-06-24 05:44:06 +04:00
acpi_status
acpi_hw_validate_register ( struct acpi_generic_address * reg ,
u8 max_bit_width , u64 * address ) ;
2017-09-20 05:00:11 +03:00
acpi_status acpi_hw_read ( u64 * value , struct acpi_generic_address * reg ) ;
2009-06-24 05:44:06 +04:00
2017-09-20 05:00:11 +03:00
acpi_status acpi_hw_write ( u64 value , struct acpi_generic_address * reg ) ;
2009-06-24 05:44:06 +04:00
2005-08-05 08:44:28 +04:00
struct acpi_bit_register_info * acpi_hw_get_bit_register_info ( u32 register_id ) ;
2005-04-17 02:20:36 +04:00
2009-02-18 09:36:05 +03: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-17 02:20:36 +04:00
2007-09-30 22:39:36 +04:00
acpi_status acpi_hw_register_write ( u32 register_id , u32 value ) ;
2005-04-17 02:20:36 +04:00
2007-02-02 19:48:21 +03:00
acpi_status acpi_hw_clear_acpi_status ( void ) ;
2005-04-17 02:20:36 +04:00
2012-02-14 11:00:53 +04:00
/*
2012-02-14 14:47:42 +04:00
* hwsleep - sleep / wake support ( Legacy sleep registers )
*/
2012-07-27 04:08:54 +04:00
acpi_status acpi_hw_legacy_sleep ( u8 sleep_state ) ;
2012-02-14 14:47:42 +04:00
2012-07-27 04:08:54 +04:00
acpi_status acpi_hw_legacy_wake_prep ( u8 sleep_state ) ;
2012-02-14 14:47:42 +04:00
2012-07-27 04:08:54 +04:00
acpi_status acpi_hw_legacy_wake ( u8 sleep_state ) ;
2012-02-14 14:47:42 +04:00
/*
* hwesleep - sleep / wake support ( Extended FADT - V5 sleep registers )
2012-02-14 11:00:53 +04:00
*/
2012-02-14 14:43:03 +04:00
void acpi_hw_execute_sleep_method ( char * method_name , u32 integer_argument ) ;
2012-02-14 11:00:53 +04:00
2012-07-27 04:08:54 +04:00
acpi_status acpi_hw_extended_sleep ( u8 sleep_state ) ;
2012-02-14 11:00:53 +04:00
2012-07-27 04:08:54 +04:00
acpi_status acpi_hw_extended_wake_prep ( u8 sleep_state ) ;
2012-02-14 11:00:53 +04:00
2012-07-27 04:08:54 +04:00
acpi_status acpi_hw_extended_wake ( u8 sleep_state ) ;
2012-02-14 11:00:53 +04:00
2009-03-19 04:37:47 +03: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 ) ;
2020-09-04 19:27:27 +03:00
acpi_status acpi_hw_validate_io_block ( u64 address , u32 bit_width , u32 count ) ;
2005-04-19 06:49:35 +04:00
/*
* hwgpe - GPE support
*/
2020-09-04 19:27:52 +03:00
acpi_status acpi_hw_gpe_read ( u64 * value , struct acpi_gpe_address * reg ) ;
2020-09-04 19:27:43 +03:00
2020-09-04 19:27:52 +03:00
acpi_status acpi_hw_gpe_write ( u64 value , struct acpi_gpe_address * reg ) ;
2020-09-04 19:27:43 +03:00
2012-08-17 07:10:02 +04:00
u32 acpi_hw_get_gpe_register_bit ( struct acpi_gpe_event_info * gpe_event_info ) ;
2010-06-08 12:48:26 +04:00
2010-06-08 12:49:08 +04:00
acpi_status
2010-12-13 08:39:37 +03:00
acpi_hw_low_set_gpe ( struct acpi_gpe_event_info * gpe_event_info , u32 action ) ;
2008-06-13 04:28:55 +04:00
2005-04-17 02:20:36 +04:00
acpi_status
2005-08-05 08:44:28 +04:00
acpi_hw_disable_gpe_block ( struct acpi_gpe_xrupt_info * gpe_xrupt_info ,
2008-12-30 04:45:17 +03:00
struct acpi_gpe_block_info * gpe_block , void * context ) ;
2005-04-17 02:20:36 +04:00
2005-08-05 08:44:28 +04:00
acpi_status acpi_hw_clear_gpe ( struct acpi_gpe_event_info * gpe_event_info ) ;
2005-04-17 02:20:36 +04:00
acpi_status
2005-08-05 08:44:28 +04:00
acpi_hw_clear_gpe_block ( struct acpi_gpe_xrupt_info * gpe_xrupt_info ,
2008-12-30 04:45:17 +03:00
struct acpi_gpe_block_info * gpe_block , void * context ) ;
2005-04-17 02:20:36 +04:00
acpi_status
2005-08-05 08:44:28 +04:00
acpi_hw_get_gpe_status ( struct acpi_gpe_event_info * gpe_event_info ,
2014-10-10 06:39:39 +04:00
acpi_event_status * event_status ) ;
2005-04-17 02:20:36 +04:00
2005-08-05 08:44:28 +04:00
acpi_status acpi_hw_enable_all_runtime_gpes ( void ) ;
2005-04-17 02:20:36 +04:00
2005-08-05 08:44:28 +04:00
acpi_status acpi_hw_enable_all_wakeup_gpes ( void ) ;
2005-04-17 02:20:36 +04:00
2020-03-25 13:54:29 +03:00
u8 acpi_hw_check_all_gpes ( acpi_handle gpe_skip_device , u32 gpe_skip_number ) ;
2020-02-11 19:52:32 +03:00
2005-04-17 02:20:36 +04:00
acpi_status
2005-08-05 08:44:28 +04:00
acpi_hw_enable_runtime_gpe_block ( struct acpi_gpe_xrupt_info * gpe_xrupt_info ,
2008-12-30 04:45:17 +03:00
struct acpi_gpe_block_info * gpe_block ,
void * context ) ;
2005-04-17 02:20:36 +04:00
2018-12-20 01:46:55 +03:00
# ifdef ACPI_PCI_CONFIGURED
2010-09-15 09:22:46 +04: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 ) ;
2018-12-20 01:46:55 +03:00
# else
static inline acpi_status
acpi_hw_derive_pci_id ( struct acpi_pci_id * pci_id , acpi_handle root_pci_device ,
acpi_handle pci_region )
{
return AE_SUPPORT ;
}
# endif
2010-09-15 09:22:46 +04:00
2005-08-05 08:44:28 +04:00
# endif /* __ACHWARE_H__ */