2012-08-17 10:51:47 +08:00
/******************************************************************************
*
* Module Name : utxfinit - External interfaces for ACPICA initialization
*
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
/*
2016-01-15 08:17:03 +08:00
* Copyright ( C ) 2000 - 2016 , Intel Corp .
2012-08-17 10:51:47 +08: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 .
*/
2013-10-29 09:29:51 +08:00
# define EXPORT_ACPI_INTERFACES
2012-08-17 10:51:47 +08:00
# include <acpi/acpi.h>
# include "accommon.h"
# include "acevents.h"
# include "acnamesp.h"
# include "acdebug.h"
# include "actables.h"
# define _COMPONENT ACPI_UTILITIES
ACPI_MODULE_NAME ( " utxfinit " )
2014-11-27 14:26:07 +08:00
/* For acpi_exec only */
void ae_do_object_overrides ( void ) ;
2012-08-17 10:51:47 +08:00
/*******************************************************************************
*
* FUNCTION : acpi_initialize_subsystem
*
* PARAMETERS : None
*
* RETURN : Status
*
* DESCRIPTION : Initializes all global variables . This is the first function
* called , so any early initialization belongs here .
*
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2014-11-27 14:26:07 +08:00
2013-10-31 09:31:24 +08:00
acpi_status __init acpi_initialize_subsystem ( void )
2012-08-17 10:51:47 +08:00
{
acpi_status status ;
ACPI_FUNCTION_TRACE ( acpi_initialize_subsystem ) ;
acpi_gbl_startup_flags = ACPI_SUBSYSTEM_INITIALIZE ;
ACPI_DEBUG_EXEC ( acpi_ut_init_stack_ptr_trace ( ) ) ;
/* Initialize the OS-Dependent layer */
status = acpi_os_initialize ( ) ;
if ( ACPI_FAILURE ( status ) ) {
ACPI_EXCEPTION ( ( AE_INFO , status , " During OSL initialization " ) ) ;
return_ACPI_STATUS ( status ) ;
}
/* Initialize all globals used by the subsystem */
status = acpi_ut_init_globals ( ) ;
if ( ACPI_FAILURE ( status ) ) {
ACPI_EXCEPTION ( ( AE_INFO , status ,
" During initialization of globals " ) ) ;
return_ACPI_STATUS ( status ) ;
}
/* Create the default mutex objects */
status = acpi_ut_mutex_initialize ( ) ;
if ( ACPI_FAILURE ( status ) ) {
ACPI_EXCEPTION ( ( AE_INFO , status ,
" During Global Mutex creation " ) ) ;
return_ACPI_STATUS ( status ) ;
}
/*
* Initialize the namespace manager and
* the root of the namespace tree
*/
status = acpi_ns_root_initialize ( ) ;
if ( ACPI_FAILURE ( status ) ) {
ACPI_EXCEPTION ( ( AE_INFO , status ,
" During Namespace initialization " ) ) ;
return_ACPI_STATUS ( status ) ;
}
/* Initialize the global OSI interfaces list with the static names */
status = acpi_ut_initialize_interfaces ( ) ;
if ( ACPI_FAILURE ( status ) ) {
ACPI_EXCEPTION ( ( AE_INFO , status ,
" During OSI interfaces initialization " ) ) ;
return_ACPI_STATUS ( status ) ;
}
2014-01-08 13:44:38 +08:00
return_ACPI_STATUS ( AE_OK ) ;
2012-08-17 10:51:47 +08:00
}
2013-10-29 09:30:10 +08:00
ACPI_EXPORT_SYMBOL_INIT ( acpi_initialize_subsystem )
2012-08-17 10:51:47 +08:00
/*******************************************************************************
*
* FUNCTION : acpi_enable_subsystem
*
* PARAMETERS : flags - Init / enable Options
*
* RETURN : Status
*
* DESCRIPTION : Completes the subsystem initialization including hardware .
* Puts system into ACPI mode if it isn ' t already .
*
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2013-10-31 09:31:24 +08:00
acpi_status __init acpi_enable_subsystem ( u32 flags )
2012-08-17 10:51:47 +08:00
{
acpi_status status = AE_OK ;
ACPI_FUNCTION_TRACE ( acpi_enable_subsystem ) ;
2015-12-29 14:01:53 +08:00
/*
* The early initialization phase is complete . The namespace is loaded ,
* and we can now support address spaces other than Memory , I / O , and
* PCI_Config .
*/
acpi_gbl_early_initialization = FALSE ;
2012-08-17 10:51:47 +08:00
# if (!ACPI_REDUCED_HARDWARE)
/* Enable ACPI mode */
if ( ! ( flags & ACPI_NO_ACPI_ENABLE ) ) {
ACPI_DEBUG_PRINT ( ( ACPI_DB_EXEC ,
" [Init] Going into ACPI mode \n " ) ) ;
acpi_gbl_original_mode = acpi_hw_get_mode ( ) ;
status = acpi_enable ( ) ;
if ( ACPI_FAILURE ( status ) ) {
ACPI_WARNING ( ( AE_INFO , " AcpiEnable failed " ) ) ;
return_ACPI_STATUS ( status ) ;
}
}
/*
* Obtain a permanent mapping for the FACS . This is required for the
* Global Lock and the Firmware Waking Vector
*/
2015-07-01 14:43:26 +08:00
if ( ! ( flags & ACPI_NO_FACS_INIT ) ) {
status = acpi_tb_initialize_facs ( ) ;
if ( ACPI_FAILURE ( status ) ) {
ACPI_WARNING ( ( AE_INFO , " Could not map the FACS table " ) ) ;
return_ACPI_STATUS ( status ) ;
}
2012-08-17 10:51:47 +08:00
}
/*
* Initialize ACPI Event handling ( Fixed and General Purpose )
*
* Note1 : We must have the hardware and events initialized before we can
* execute any control methods safely . Any control method can require
* ACPI hardware support , so the hardware must be fully initialized before
* any method execution !
*
* Note2 : Fixed events are initialized and enabled here . GPEs are
* initialized , but cannot be enabled until after the hardware is
* completely initialized ( SCI and global_lock activated ) and the various
* initialization control methods are run ( _REG , _STA , _INI ) on the
* entire namespace .
*/
if ( ! ( flags & ACPI_NO_EVENT_INIT ) ) {
ACPI_DEBUG_PRINT ( ( ACPI_DB_EXEC ,
" [Init] Initializing ACPI events \n " ) ) ;
status = acpi_ev_initialize_events ( ) ;
if ( ACPI_FAILURE ( status ) ) {
return_ACPI_STATUS ( status ) ;
}
}
/*
* Install the SCI handler and Global Lock handler . This completes the
* hardware initialization .
*/
if ( ! ( flags & ACPI_NO_HANDLER_INIT ) ) {
ACPI_DEBUG_PRINT ( ( ACPI_DB_EXEC ,
" [Init] Installing SCI/GL handlers \n " ) ) ;
status = acpi_ev_install_xrupt_handlers ( ) ;
if ( ACPI_FAILURE ( status ) ) {
return_ACPI_STATUS ( status ) ;
}
}
# endif /* !ACPI_REDUCED_HARDWARE */
return_ACPI_STATUS ( status ) ;
}
2013-10-29 09:30:10 +08:00
ACPI_EXPORT_SYMBOL_INIT ( acpi_enable_subsystem )
2012-08-17 10:51:47 +08:00
/*******************************************************************************
*
* FUNCTION : acpi_initialize_objects
*
* PARAMETERS : flags - Init / enable Options
*
* RETURN : Status
*
* DESCRIPTION : Completes namespace initialization by initializing device
* objects and executing AML code for Regions , buffers , etc .
*
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2013-10-31 09:31:24 +08:00
acpi_status __init acpi_initialize_objects ( u32 flags )
2012-08-17 10:51:47 +08:00
{
acpi_status status = AE_OK ;
ACPI_FUNCTION_TRACE ( acpi_initialize_objects ) ;
2014-11-27 14:26:07 +08:00
# ifdef ACPI_EXEC_APP
/*
* This call implements the " initialization file " option for acpi_exec .
* This is the precise point that we want to perform the overrides .
*/
ae_do_object_overrides ( ) ;
# endif
2012-08-17 10:51:47 +08:00
/*
* Execute any module - level code that was detected during the table load
* phase . Although illegal since ACPI 2.0 , there are many machines that
* contain this type of code . Each block of detected executable AML code
* outside of any control method is wrapped with a temporary control
* method object and placed on a global list . The methods on this list
* are executed below .
2015-12-29 14:04:19 +08:00
*
* This case executes the module - level code for all tables only after
* all of the tables have been loaded . It is a legacy option and is
* not compatible with other ACPI implementations . See acpi_ns_load_table .
2012-08-17 10:51:47 +08:00
*/
2015-12-29 14:04:19 +08:00
if ( acpi_gbl_group_module_level_code ) {
acpi_ns_exec_module_code_list ( ) ;
2012-08-17 10:51:47 +08:00
ACPICA / Interpreter: Fix a regression triggered because of wrong Linux ECDT support
It is reported that the following commit triggers regressions:
Linux commit: efaed9be998b5ae0afb7458e057e5f4402b43fa0
ACPICA commit: 31178590dde82368fdb0f6b0e466b6c0add96c57
Subject: ACPICA: Events: Enhance acpi_ev_execute_reg_method() to
ensure no _REG evaluations can happen during OS early boot
stages
This is because that the ECDT support is not corrected in Linux, and Linux
requires to execute _REG for ECDT (though this sounds so wrong), we need to
ensure acpi_gbl_namespace_initialized is set before ECDT probing in order
for _REG to be executed. Since we have to move
"acpi_gbl_namespace_initialized = TRUE" to the initialization step
happening before ECDT probing, acpi_load_tables() is the best candidate for
now. Thus this patch fixes the regression by doing so.
But if the ECDT support is fixed, Linux will not execute _REG for ECDT, and
ECDT probing will happen before acpi_load_tables(). At that time, we still
want to ensure acpi_gbl_namespace_initialized is set after executing
acpi_ns_initialize_objects() (under the condition of
acpi_gbl_group_module_level_code = FALSE), this patch also moves
acpi_ns_initialize_objects() to acpi_load_tables() accordingly.
Since acpi_ns_initialize_objects() doesn't seem to be skippable, this
patch also removes ACPI_NO_OBJECT_INIT for the one invoked in
acpi_load_tables(). And since the default region handlers should always be
installed before loading the tables, this patch also removes useless
acpi_gbl_group_module_level_code check accordingly. Reported by Chris
Bainbridge, Fixed by Lv Zheng.
Fixes: efaed9be998b (ACPICA: Events: Enhance acpi_ev_execute_reg_method() to ensure no _REG evaluations can happen during OS early boot stages)
Reported-and-tested-by: Chris Bainbridge <chris.bainbridge@gmail.com>
Signed-off-by: Lv Zheng <lv.zheng@intel.com>
Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
2016-03-10 10:54:29 +08:00
/*
* Initialize the objects that remain uninitialized . This
* runs the executable AML that may be part of the
* declaration of these objects :
* operation_regions , buffer_fields , Buffers , and Packages .
*/
if ( ! ( flags & ACPI_NO_OBJECT_INIT ) ) {
status = acpi_ns_initialize_objects ( ) ;
if ( ACPI_FAILURE ( status ) ) {
return_ACPI_STATUS ( status ) ;
}
2012-08-17 10:51:47 +08:00
}
}
/*
2016-02-19 14:17:15 +08:00
* Initialize all device / region objects in the namespace . This runs
* the device _STA and _INI methods and region _REG methods .
2012-08-17 10:51:47 +08:00
*/
2016-02-19 14:17:15 +08:00
if ( ! ( flags & ( ACPI_NO_DEVICE_INIT | ACPI_NO_ADDRESS_SPACE_INIT ) ) ) {
status = acpi_ns_initialize_devices ( flags ) ;
2012-08-17 10:51:47 +08:00
if ( ACPI_FAILURE ( status ) ) {
return_ACPI_STATUS ( status ) ;
}
}
/*
* Empty the caches ( delete the cached objects ) on the assumption that
* the table load filled them up more than they will be at runtime - -
* thus wasting non - paged memory .
*/
status = acpi_purge_cached_objects ( ) ;
acpi_gbl_startup_flags | = ACPI_INITIALIZED_OK ;
return_ACPI_STATUS ( status ) ;
}
2013-10-29 09:30:10 +08:00
ACPI_EXPORT_SYMBOL_INIT ( acpi_initialize_objects )