2018-03-14 16:13:07 -07:00
/* SPDX-License-Identifier: BSD-3-Clause OR GPL-2.0 */
2005-04-16 15:20:36 -07:00
/******************************************************************************
*
* Name : achware . h - - hardware specific interfaces
*
2023-04-05 15:38:21 +02:00
* Copyright ( C ) 2000 - 2023 , Intel Corp .
2005-04-16 15:20:36 -07:00
*
2018-03-14 16:13:07 -07:00
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2005-04-16 15:20:36 -07:00
# 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 ) ;
2017-09-20 10:00:11 +08:00
acpi_status acpi_hw_read ( u64 * value , struct acpi_generic_address * reg ) ;
2009-06-24 09:44:06 +08:00
2017-09-20 10:00:11 +08:00
acpi_status acpi_hw_write ( u64 value , struct acpi_generic_address * reg ) ;
2009-06-24 09:44:06 +08:00
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 ) ;
2020-09-04 18:27:27 +02:00
acpi_status acpi_hw_validate_io_block ( u64 address , u32 bit_width , u32 count ) ;
2005-04-18 22:49:35 -04:00
/*
* hwgpe - GPE support
*/
2020-09-04 18:27:52 +02:00
acpi_status acpi_hw_gpe_read ( u64 * value , struct acpi_gpe_address * reg ) ;
2020-09-04 18:27:43 +02:00
2020-09-04 18:27:52 +02:00
acpi_status acpi_hw_gpe_write ( u64 value , struct acpi_gpe_address * reg ) ;
2020-09-04 18:27:43 +02:00
2012-08-17 11:10:02 +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
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 ,
2014-10-10 10:39:39 +08:00
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_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
2020-03-25 11:54:29 +01:00
u8 acpi_hw_check_all_gpes ( acpi_handle gpe_skip_device , u32 gpe_skip_number ) ;
2020-02-11 17:52:32 +01:00
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
2018-12-19 22:46:55 +00:00
# ifdef ACPI_PCI_CONFIGURED
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 ) ;
2018-12-19 22:46:55 +00: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 13:22:46 +08:00
2005-08-05 00:44:28 -04:00
# endif /* __ACHWARE_H__ */