Merge branch 'acpica' of git://git.kernel.org/pub/scm/linux/kernel/git/lenb/linux-acpi-2.6
* 'acpica' of git://git.kernel.org/pub/scm/linux/kernel/git/lenb/linux-acpi-2.6: ACPI: replace acpi_integer by u64 ACPICA: Update version to 20100121. ACPICA: Remove unused uint32_struct type ACPICA: Disassembler: Remove obsolete "Integer64" field in parse object ACPICA: Remove obsolete ACPI_INTEGER (acpi_integer) type ACPICA: Predefined name repair: fix NULL package elements ACPICA: AcpiGetDevices: Eliminate unnecessary _STA calls ACPICA: Update all ACPICA copyrights and signons to 2010 ACPICA: Update for new gcc-4 warning options
This commit is contained in:
commit
bc53515413
167 changed files with 721 additions and 603 deletions
|
@ -77,7 +77,7 @@ static void aml_nfw_execute(struct ia64_nfw_context *c)
|
||||||
c->arg[4], c->arg[5], c->arg[6], c->arg[7]);
|
c->arg[4], c->arg[5], c->arg[6], c->arg[7]);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void aml_nfw_read_arg(u8 *offset, u32 bit_width, acpi_integer *value)
|
static void aml_nfw_read_arg(u8 *offset, u32 bit_width, u64 *value)
|
||||||
{
|
{
|
||||||
switch (bit_width) {
|
switch (bit_width) {
|
||||||
case 8:
|
case 8:
|
||||||
|
@ -95,7 +95,7 @@ static void aml_nfw_read_arg(u8 *offset, u32 bit_width, acpi_integer *value)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void aml_nfw_write_arg(u8 *offset, u32 bit_width, acpi_integer *value)
|
static void aml_nfw_write_arg(u8 *offset, u32 bit_width, u64 *value)
|
||||||
{
|
{
|
||||||
switch (bit_width) {
|
switch (bit_width) {
|
||||||
case 8:
|
case 8:
|
||||||
|
@ -114,7 +114,7 @@ static void aml_nfw_write_arg(u8 *offset, u32 bit_width, acpi_integer *value)
|
||||||
}
|
}
|
||||||
|
|
||||||
static acpi_status aml_nfw_handler(u32 function, acpi_physical_address address,
|
static acpi_status aml_nfw_handler(u32 function, acpi_physical_address address,
|
||||||
u32 bit_width, acpi_integer *value, void *handler_context,
|
u32 bit_width, u64 *value, void *handler_context,
|
||||||
void *region_context)
|
void *region_context)
|
||||||
{
|
{
|
||||||
struct ia64_nfw_context *context = handler_context;
|
struct ia64_nfw_context *context = handler_context;
|
||||||
|
|
|
@ -806,7 +806,7 @@ static int find_psb_table(struct powernow_k8_data *data)
|
||||||
static void powernow_k8_acpi_pst_values(struct powernow_k8_data *data,
|
static void powernow_k8_acpi_pst_values(struct powernow_k8_data *data,
|
||||||
unsigned int index)
|
unsigned int index)
|
||||||
{
|
{
|
||||||
acpi_integer control;
|
u64 control;
|
||||||
|
|
||||||
if (!data->acpi_data.state_count || (cpu_family == CPU_HW_PSTATE))
|
if (!data->acpi_data.state_count || (cpu_family == CPU_HW_PSTATE))
|
||||||
return;
|
return;
|
||||||
|
@ -824,7 +824,7 @@ static int powernow_k8_cpu_init_acpi(struct powernow_k8_data *data)
|
||||||
{
|
{
|
||||||
struct cpufreq_frequency_table *powernow_table;
|
struct cpufreq_frequency_table *powernow_table;
|
||||||
int ret_val = -ENODEV;
|
int ret_val = -ENODEV;
|
||||||
acpi_integer control, status;
|
u64 control, status;
|
||||||
|
|
||||||
if (acpi_processor_register_performance(&data->acpi_data, data->cpu)) {
|
if (acpi_processor_register_performance(&data->acpi_data, data->cpu)) {
|
||||||
dprintk("register performance failed: bad ACPI data\n");
|
dprintk("register performance failed: bad ACPI data\n");
|
||||||
|
@ -948,7 +948,7 @@ static int fill_powernow_table_fidvid(struct powernow_k8_data *data,
|
||||||
u32 fid;
|
u32 fid;
|
||||||
u32 vid;
|
u32 vid;
|
||||||
u32 freq, index;
|
u32 freq, index;
|
||||||
acpi_integer status, control;
|
u64 status, control;
|
||||||
|
|
||||||
if (data->exttype) {
|
if (data->exttype) {
|
||||||
status = data->acpi_data.states[i].status;
|
status = data->acpi_data.states[i].status;
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
@ -133,8 +133,7 @@ acpi_status acpi_ev_initialize_op_regions(void);
|
||||||
acpi_status
|
acpi_status
|
||||||
acpi_ev_address_space_dispatch(union acpi_operand_object *region_obj,
|
acpi_ev_address_space_dispatch(union acpi_operand_object *region_obj,
|
||||||
u32 function,
|
u32 function,
|
||||||
u32 region_offset,
|
u32 region_offset, u32 bit_width, u64 *value);
|
||||||
u32 bit_width, acpi_integer * value);
|
|
||||||
|
|
||||||
acpi_status
|
acpi_status
|
||||||
acpi_ev_attach_region(union acpi_operand_object *handler_obj,
|
acpi_ev_attach_region(union acpi_operand_object *handler_obj,
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
@ -129,18 +129,17 @@ acpi_ex_common_buffer_setup(union acpi_operand_object *obj_desc,
|
||||||
|
|
||||||
acpi_status
|
acpi_status
|
||||||
acpi_ex_write_with_update_rule(union acpi_operand_object *obj_desc,
|
acpi_ex_write_with_update_rule(union acpi_operand_object *obj_desc,
|
||||||
acpi_integer mask,
|
u64 mask,
|
||||||
acpi_integer field_value,
|
u64 field_value, u32 field_datum_byte_offset);
|
||||||
u32 field_datum_byte_offset);
|
|
||||||
|
|
||||||
void
|
void
|
||||||
acpi_ex_get_buffer_datum(acpi_integer * datum,
|
acpi_ex_get_buffer_datum(u64 *datum,
|
||||||
void *buffer,
|
void *buffer,
|
||||||
u32 buffer_length,
|
u32 buffer_length,
|
||||||
u32 byte_granularity, u32 buffer_offset);
|
u32 byte_granularity, u32 buffer_offset);
|
||||||
|
|
||||||
void
|
void
|
||||||
acpi_ex_set_buffer_datum(acpi_integer merged_datum,
|
acpi_ex_set_buffer_datum(u64 merged_datum,
|
||||||
void *buffer,
|
void *buffer,
|
||||||
u32 buffer_length,
|
u32 buffer_length,
|
||||||
u32 byte_granularity, u32 buffer_offset);
|
u32 byte_granularity, u32 buffer_offset);
|
||||||
|
@ -168,8 +167,7 @@ acpi_ex_insert_into_field(union acpi_operand_object *obj_desc,
|
||||||
|
|
||||||
acpi_status
|
acpi_status
|
||||||
acpi_ex_access_region(union acpi_operand_object *obj_desc,
|
acpi_ex_access_region(union acpi_operand_object *obj_desc,
|
||||||
u32 field_datum_byte_offset,
|
u32 field_datum_byte_offset, u64 *value, u32 read_write);
|
||||||
acpi_integer * value, u32 read_write);
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* exmisc - misc support routines
|
* exmisc - misc support routines
|
||||||
|
@ -193,16 +191,14 @@ acpi_ex_do_concatenate(union acpi_operand_object *obj_desc,
|
||||||
|
|
||||||
acpi_status
|
acpi_status
|
||||||
acpi_ex_do_logical_numeric_op(u16 opcode,
|
acpi_ex_do_logical_numeric_op(u16 opcode,
|
||||||
acpi_integer integer0,
|
u64 integer0, u64 integer1, u8 *logical_result);
|
||||||
acpi_integer integer1, u8 * logical_result);
|
|
||||||
|
|
||||||
acpi_status
|
acpi_status
|
||||||
acpi_ex_do_logical_op(u16 opcode,
|
acpi_ex_do_logical_op(u16 opcode,
|
||||||
union acpi_operand_object *operand0,
|
union acpi_operand_object *operand0,
|
||||||
union acpi_operand_object *operand1, u8 * logical_result);
|
union acpi_operand_object *operand1, u8 *logical_result);
|
||||||
|
|
||||||
acpi_integer
|
u64 acpi_ex_do_math_op(u16 opcode, u64 operand0, u64 operand1);
|
||||||
acpi_ex_do_math_op(u16 opcode, acpi_integer operand0, acpi_integer operand1);
|
|
||||||
|
|
||||||
acpi_status acpi_ex_create_mutex(struct acpi_walk_state *walk_state);
|
acpi_status acpi_ex_create_mutex(struct acpi_walk_state *walk_state);
|
||||||
|
|
||||||
|
@ -278,7 +274,7 @@ acpi_status
|
||||||
acpi_ex_system_do_notify_op(union acpi_operand_object *value,
|
acpi_ex_system_do_notify_op(union acpi_operand_object *value,
|
||||||
union acpi_operand_object *obj_desc);
|
union acpi_operand_object *obj_desc);
|
||||||
|
|
||||||
acpi_status acpi_ex_system_do_suspend(acpi_integer time);
|
acpi_status acpi_ex_system_do_suspend(u64 time);
|
||||||
|
|
||||||
acpi_status acpi_ex_system_do_stall(u32 time);
|
acpi_status acpi_ex_system_do_stall(u32 time);
|
||||||
|
|
||||||
|
@ -461,9 +457,9 @@ void acpi_ex_acquire_global_lock(u32 rule);
|
||||||
|
|
||||||
void acpi_ex_release_global_lock(u32 rule);
|
void acpi_ex_release_global_lock(u32 rule);
|
||||||
|
|
||||||
void acpi_ex_eisa_id_to_string(char *dest, acpi_integer compressed_id);
|
void acpi_ex_eisa_id_to_string(char *dest, u64 compressed_id);
|
||||||
|
|
||||||
void acpi_ex_integer_to_string(char *dest, acpi_integer value);
|
void acpi_ex_integer_to_string(char *dest, u64 value);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* exregion - default op_region handlers
|
* exregion - default op_region handlers
|
||||||
|
@ -472,7 +468,7 @@ acpi_status
|
||||||
acpi_ex_system_memory_space_handler(u32 function,
|
acpi_ex_system_memory_space_handler(u32 function,
|
||||||
acpi_physical_address address,
|
acpi_physical_address address,
|
||||||
u32 bit_width,
|
u32 bit_width,
|
||||||
acpi_integer * value,
|
u64 *value,
|
||||||
void *handler_context,
|
void *handler_context,
|
||||||
void *region_context);
|
void *region_context);
|
||||||
|
|
||||||
|
@ -480,35 +476,35 @@ acpi_status
|
||||||
acpi_ex_system_io_space_handler(u32 function,
|
acpi_ex_system_io_space_handler(u32 function,
|
||||||
acpi_physical_address address,
|
acpi_physical_address address,
|
||||||
u32 bit_width,
|
u32 bit_width,
|
||||||
acpi_integer * value,
|
u64 *value,
|
||||||
void *handler_context, void *region_context);
|
void *handler_context, void *region_context);
|
||||||
|
|
||||||
acpi_status
|
acpi_status
|
||||||
acpi_ex_pci_config_space_handler(u32 function,
|
acpi_ex_pci_config_space_handler(u32 function,
|
||||||
acpi_physical_address address,
|
acpi_physical_address address,
|
||||||
u32 bit_width,
|
u32 bit_width,
|
||||||
acpi_integer * value,
|
u64 *value,
|
||||||
void *handler_context, void *region_context);
|
void *handler_context, void *region_context);
|
||||||
|
|
||||||
acpi_status
|
acpi_status
|
||||||
acpi_ex_cmos_space_handler(u32 function,
|
acpi_ex_cmos_space_handler(u32 function,
|
||||||
acpi_physical_address address,
|
acpi_physical_address address,
|
||||||
u32 bit_width,
|
u32 bit_width,
|
||||||
acpi_integer * value,
|
u64 *value,
|
||||||
void *handler_context, void *region_context);
|
void *handler_context, void *region_context);
|
||||||
|
|
||||||
acpi_status
|
acpi_status
|
||||||
acpi_ex_pci_bar_space_handler(u32 function,
|
acpi_ex_pci_bar_space_handler(u32 function,
|
||||||
acpi_physical_address address,
|
acpi_physical_address address,
|
||||||
u32 bit_width,
|
u32 bit_width,
|
||||||
acpi_integer * value,
|
u64 *value,
|
||||||
void *handler_context, void *region_context);
|
void *handler_context, void *region_context);
|
||||||
|
|
||||||
acpi_status
|
acpi_status
|
||||||
acpi_ex_embedded_controller_space_handler(u32 function,
|
acpi_ex_embedded_controller_space_handler(u32 function,
|
||||||
acpi_physical_address address,
|
acpi_physical_address address,
|
||||||
u32 bit_width,
|
u32 bit_width,
|
||||||
acpi_integer * value,
|
u64 *value,
|
||||||
void *handler_context,
|
void *handler_context,
|
||||||
void *region_context);
|
void *region_context);
|
||||||
|
|
||||||
|
@ -516,14 +512,14 @@ acpi_status
|
||||||
acpi_ex_sm_bus_space_handler(u32 function,
|
acpi_ex_sm_bus_space_handler(u32 function,
|
||||||
acpi_physical_address address,
|
acpi_physical_address address,
|
||||||
u32 bit_width,
|
u32 bit_width,
|
||||||
acpi_integer * value,
|
u64 *value,
|
||||||
void *handler_context, void *region_context);
|
void *handler_context, void *region_context);
|
||||||
|
|
||||||
acpi_status
|
acpi_status
|
||||||
acpi_ex_data_table_space_handler(u32 function,
|
acpi_ex_data_table_space_handler(u32 function,
|
||||||
acpi_physical_address address,
|
acpi_physical_address address,
|
||||||
u32 bit_width,
|
u32 bit_width,
|
||||||
acpi_integer * value,
|
u64 *value,
|
||||||
void *handler_context, void *region_context);
|
void *handler_context, void *region_context);
|
||||||
|
|
||||||
#endif /* __INTERP_H__ */
|
#endif /* __INTERP_H__ */
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
@ -374,6 +374,7 @@ union acpi_predefined_info {
|
||||||
struct acpi_predefined_data {
|
struct acpi_predefined_data {
|
||||||
char *pathname;
|
char *pathname;
|
||||||
const union acpi_predefined_info *predefined;
|
const union acpi_predefined_info *predefined;
|
||||||
|
union acpi_operand_object *parent_package;
|
||||||
u32 flags;
|
u32 flags;
|
||||||
u8 node_flags;
|
u8 node_flags;
|
||||||
};
|
};
|
||||||
|
@ -651,8 +652,7 @@ struct acpi_opcode_info {
|
||||||
};
|
};
|
||||||
|
|
||||||
union acpi_parse_value {
|
union acpi_parse_value {
|
||||||
acpi_integer integer; /* Integer constant (Up to 64 bits) */
|
u64 integer; /* Integer constant (Up to 64 bits) */
|
||||||
struct uint64_struct integer64; /* Structure overlay for 2 32-bit Dwords */
|
|
||||||
u32 size; /* bytelist or field size */
|
u32 size; /* bytelist or field size */
|
||||||
char *string; /* NULL terminated string */
|
char *string; /* NULL terminated string */
|
||||||
u8 *buffer; /* buffer or string */
|
u8 *buffer; /* buffer or string */
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
@ -272,8 +272,8 @@
|
||||||
* MASK_BITS_ABOVE creates a mask starting AT the position and above
|
* MASK_BITS_ABOVE creates a mask starting AT the position and above
|
||||||
* MASK_BITS_BELOW creates a mask starting one bit BELOW the position
|
* MASK_BITS_BELOW creates a mask starting one bit BELOW the position
|
||||||
*/
|
*/
|
||||||
#define ACPI_MASK_BITS_ABOVE(position) (~((ACPI_INTEGER_MAX) << ((u32) (position))))
|
#define ACPI_MASK_BITS_ABOVE(position) (~((ACPI_UINT64_MAX) << ((u32) (position))))
|
||||||
#define ACPI_MASK_BITS_BELOW(position) ((ACPI_INTEGER_MAX) << ((u32) (position)))
|
#define ACPI_MASK_BITS_BELOW(position) ((ACPI_UINT64_MAX) << ((u32) (position)))
|
||||||
|
|
||||||
/* Bitfields within ACPI registers */
|
/* Bitfields within ACPI registers */
|
||||||
|
|
||||||
|
@ -414,16 +414,16 @@
|
||||||
acpi_ut_ptr_exit (ACPI_DEBUG_PARAMETERS, (u8 *) _s); \
|
acpi_ut_ptr_exit (ACPI_DEBUG_PARAMETERS, (u8 *) _s); \
|
||||||
return (_s); })
|
return (_s); })
|
||||||
#define return_VALUE(s) ACPI_DO_WHILE0 ({ \
|
#define return_VALUE(s) ACPI_DO_WHILE0 ({ \
|
||||||
register acpi_integer _s = (s); \
|
register u64 _s = (s); \
|
||||||
acpi_ut_value_exit (ACPI_DEBUG_PARAMETERS, _s); \
|
acpi_ut_value_exit (ACPI_DEBUG_PARAMETERS, _s); \
|
||||||
return (_s); })
|
return (_s); })
|
||||||
#define return_UINT8(s) ACPI_DO_WHILE0 ({ \
|
#define return_UINT8(s) ACPI_DO_WHILE0 ({ \
|
||||||
register u8 _s = (u8) (s); \
|
register u8 _s = (u8) (s); \
|
||||||
acpi_ut_value_exit (ACPI_DEBUG_PARAMETERS, (acpi_integer) _s); \
|
acpi_ut_value_exit (ACPI_DEBUG_PARAMETERS, (u64) _s); \
|
||||||
return (_s); })
|
return (_s); })
|
||||||
#define return_UINT32(s) ACPI_DO_WHILE0 ({ \
|
#define return_UINT32(s) ACPI_DO_WHILE0 ({ \
|
||||||
register u32 _s = (u32) (s); \
|
register u32 _s = (u32) (s); \
|
||||||
acpi_ut_value_exit (ACPI_DEBUG_PARAMETERS, (acpi_integer) _s); \
|
acpi_ut_value_exit (ACPI_DEBUG_PARAMETERS, (u64) _s); \
|
||||||
return (_s); })
|
return (_s); })
|
||||||
#else /* Use original less-safe macros */
|
#else /* Use original less-safe macros */
|
||||||
|
|
||||||
|
@ -434,7 +434,7 @@
|
||||||
acpi_ut_ptr_exit (ACPI_DEBUG_PARAMETERS, (u8 *) (s)); \
|
acpi_ut_ptr_exit (ACPI_DEBUG_PARAMETERS, (u8 *) (s)); \
|
||||||
return((s)); })
|
return((s)); })
|
||||||
#define return_VALUE(s) ACPI_DO_WHILE0 ({ \
|
#define return_VALUE(s) ACPI_DO_WHILE0 ({ \
|
||||||
acpi_ut_value_exit (ACPI_DEBUG_PARAMETERS, (acpi_integer) (s)); \
|
acpi_ut_value_exit (ACPI_DEBUG_PARAMETERS, (u64) (s)); \
|
||||||
return((s)); })
|
return((s)); })
|
||||||
#define return_UINT8(s) return_VALUE(s)
|
#define return_UINT8(s) return_VALUE(s)
|
||||||
#define return_UINT32(s) return_VALUE(s)
|
#define return_UINT32(s) return_VALUE(s)
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
@ -286,6 +286,17 @@ acpi_status
|
||||||
acpi_ns_repair_package_list(struct acpi_predefined_data *data,
|
acpi_ns_repair_package_list(struct acpi_predefined_data *data,
|
||||||
union acpi_operand_object **obj_desc_ptr);
|
union acpi_operand_object **obj_desc_ptr);
|
||||||
|
|
||||||
|
acpi_status
|
||||||
|
acpi_ns_repair_null_element(struct acpi_predefined_data *data,
|
||||||
|
u32 expected_btypes,
|
||||||
|
u32 package_index,
|
||||||
|
union acpi_operand_object **return_object_ptr);
|
||||||
|
|
||||||
|
void
|
||||||
|
acpi_ns_remove_null_elements(struct acpi_predefined_data *data,
|
||||||
|
u8 package_type,
|
||||||
|
union acpi_operand_object *obj_desc);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* nsrepair2 - Return object repair for specific
|
* nsrepair2 - Return object repair for specific
|
||||||
* predefined methods/objects
|
* predefined methods/objects
|
||||||
|
@ -296,11 +307,6 @@ acpi_ns_complex_repairs(struct acpi_predefined_data *data,
|
||||||
acpi_status validate_status,
|
acpi_status validate_status,
|
||||||
union acpi_operand_object **return_object_ptr);
|
union acpi_operand_object **return_object_ptr);
|
||||||
|
|
||||||
void
|
|
||||||
acpi_ns_remove_null_elements(struct acpi_predefined_data *data,
|
|
||||||
u8 package_type,
|
|
||||||
union acpi_operand_object *obj_desc);
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* nssearch - Namespace searching and entry
|
* nssearch - Namespace searching and entry
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
@ -111,7 +111,7 @@ ACPI_OBJECT_COMMON_HEADER};
|
||||||
|
|
||||||
struct acpi_object_integer {
|
struct acpi_object_integer {
|
||||||
ACPI_OBJECT_COMMON_HEADER u8 fill[3]; /* Prevent warning on some compilers */
|
ACPI_OBJECT_COMMON_HEADER u8 fill[3]; /* Prevent warning on some compilers */
|
||||||
acpi_integer value;
|
u64 value;
|
||||||
};
|
};
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
@ -134,7 +134,7 @@ char *acpi_ut_get_region_name(u8 space_id);
|
||||||
|
|
||||||
char *acpi_ut_get_event_name(u32 event_id);
|
char *acpi_ut_get_event_name(u32 event_id);
|
||||||
|
|
||||||
char acpi_ut_hex_to_ascii_char(acpi_integer integer, u32 position);
|
char acpi_ut_hex_to_ascii_char(u64 integer, u32 position);
|
||||||
|
|
||||||
u8 acpi_ut_valid_object_type(acpi_object_type type);
|
u8 acpi_ut_valid_object_type(acpi_object_type type);
|
||||||
|
|
||||||
|
@ -279,8 +279,7 @@ acpi_ut_status_exit(u32 line_number,
|
||||||
void
|
void
|
||||||
acpi_ut_value_exit(u32 line_number,
|
acpi_ut_value_exit(u32 line_number,
|
||||||
const char *function_name,
|
const char *function_name,
|
||||||
const char *module_name,
|
const char *module_name, u32 component_id, u64 value);
|
||||||
u32 component_id, acpi_integer value);
|
|
||||||
|
|
||||||
void
|
void
|
||||||
acpi_ut_ptr_exit(u32 line_number,
|
acpi_ut_ptr_exit(u32 line_number,
|
||||||
|
@ -324,7 +323,7 @@ acpi_ut_evaluate_object(struct acpi_namespace_node *prefix_node,
|
||||||
acpi_status
|
acpi_status
|
||||||
acpi_ut_evaluate_numeric_object(char *object_name,
|
acpi_ut_evaluate_numeric_object(char *object_name,
|
||||||
struct acpi_namespace_node *device_node,
|
struct acpi_namespace_node *device_node,
|
||||||
acpi_integer *value);
|
u64 *value);
|
||||||
|
|
||||||
acpi_status
|
acpi_status
|
||||||
acpi_ut_execute_STA(struct acpi_namespace_node *device_node, u32 *status_flags);
|
acpi_ut_execute_STA(struct acpi_namespace_node *device_node, u32 *status_flags);
|
||||||
|
@ -437,14 +436,12 @@ void acpi_ut_delete_generic_state(union acpi_generic_state *state);
|
||||||
* utmath
|
* utmath
|
||||||
*/
|
*/
|
||||||
acpi_status
|
acpi_status
|
||||||
acpi_ut_divide(acpi_integer in_dividend,
|
acpi_ut_divide(u64 in_dividend,
|
||||||
acpi_integer in_divisor,
|
u64 in_divisor, u64 *out_quotient, u64 *out_remainder);
|
||||||
acpi_integer * out_quotient, acpi_integer * out_remainder);
|
|
||||||
|
|
||||||
acpi_status
|
acpi_status
|
||||||
acpi_ut_short_divide(acpi_integer in_dividend,
|
acpi_ut_short_divide(u64 in_dividend,
|
||||||
u32 divisor,
|
u32 divisor, u64 *out_quotient, u32 *out_remainder);
|
||||||
acpi_integer * out_quotient, u32 * out_remainder);
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* utmisc
|
* utmisc
|
||||||
|
@ -474,8 +471,7 @@ acpi_name acpi_ut_repair_name(char *name);
|
||||||
|
|
||||||
u8 acpi_ut_valid_acpi_char(char character, u32 position);
|
u8 acpi_ut_valid_acpi_char(char character, u32 position);
|
||||||
|
|
||||||
acpi_status
|
acpi_status acpi_ut_strtoul64(char *string, u32 base, u64 * ret_integer);
|
||||||
acpi_ut_strtoul64(char *string, u32 base, acpi_integer * ret_integer);
|
|
||||||
|
|
||||||
void ACPI_INTERNAL_VAR_XFACE
|
void ACPI_INTERNAL_VAR_XFACE
|
||||||
acpi_ut_predefined_warning(const char *module_name,
|
acpi_ut_predefined_warning(const char *module_name,
|
||||||
|
|
|
@ -7,7 +7,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
@ -220,7 +220,7 @@ acpi_ds_get_field_names(struct acpi_create_field_info *info,
|
||||||
union acpi_parse_object *arg)
|
union acpi_parse_object *arg)
|
||||||
{
|
{
|
||||||
acpi_status status;
|
acpi_status status;
|
||||||
acpi_integer position;
|
u64 position;
|
||||||
|
|
||||||
ACPI_FUNCTION_TRACE_PTR(ds_get_field_names, info);
|
ACPI_FUNCTION_TRACE_PTR(ds_get_field_names, info);
|
||||||
|
|
||||||
|
@ -240,8 +240,8 @@ acpi_ds_get_field_names(struct acpi_create_field_info *info,
|
||||||
switch (arg->common.aml_opcode) {
|
switch (arg->common.aml_opcode) {
|
||||||
case AML_INT_RESERVEDFIELD_OP:
|
case AML_INT_RESERVEDFIELD_OP:
|
||||||
|
|
||||||
position = (acpi_integer) info->field_bit_position
|
position = (u64) info->field_bit_position
|
||||||
+ (acpi_integer) arg->common.value.size;
|
+ (u64) arg->common.value.size;
|
||||||
|
|
||||||
if (position > ACPI_UINT32_MAX) {
|
if (position > ACPI_UINT32_MAX) {
|
||||||
ACPI_ERROR((AE_INFO,
|
ACPI_ERROR((AE_INFO,
|
||||||
|
@ -305,8 +305,8 @@ acpi_ds_get_field_names(struct acpi_create_field_info *info,
|
||||||
|
|
||||||
/* Keep track of bit position for the next field */
|
/* Keep track of bit position for the next field */
|
||||||
|
|
||||||
position = (acpi_integer) info->field_bit_position
|
position = (u64) info->field_bit_position
|
||||||
+ (acpi_integer) arg->common.value.size;
|
+ (u64) arg->common.value.size;
|
||||||
|
|
||||||
if (position > ACPI_UINT32_MAX) {
|
if (position > ACPI_UINT32_MAX) {
|
||||||
ACPI_ERROR((AE_INFO,
|
ACPI_ERROR((AE_INFO,
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
******************************************************************************/
|
******************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
@ -684,7 +684,7 @@ acpi_ds_init_object_from_op(struct acpi_walk_state *walk_state,
|
||||||
|
|
||||||
case AML_ONES_OP:
|
case AML_ONES_OP:
|
||||||
|
|
||||||
obj_desc->integer.value = ACPI_INTEGER_MAX;
|
obj_desc->integer.value = ACPI_UINT64_MAX;
|
||||||
|
|
||||||
/* Truncate value if we are executing from a 32-bit ACPI table */
|
/* Truncate value if we are executing from a 32-bit ACPI table */
|
||||||
|
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
******************************************************************************/
|
******************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
@ -329,7 +329,7 @@ acpi_ev_execute_reg_method(union acpi_operand_object *region_obj, u32 function)
|
||||||
* region_offset - Where in the region to read or write
|
* region_offset - Where in the region to read or write
|
||||||
* bit_width - Field width in bits (8, 16, 32, or 64)
|
* bit_width - Field width in bits (8, 16, 32, or 64)
|
||||||
* Value - Pointer to in or out value, must be
|
* Value - Pointer to in or out value, must be
|
||||||
* full 64-bit acpi_integer
|
* a full 64-bit integer
|
||||||
*
|
*
|
||||||
* RETURN: Status
|
* RETURN: Status
|
||||||
*
|
*
|
||||||
|
@ -341,8 +341,7 @@ acpi_ev_execute_reg_method(union acpi_operand_object *region_obj, u32 function)
|
||||||
acpi_status
|
acpi_status
|
||||||
acpi_ev_address_space_dispatch(union acpi_operand_object *region_obj,
|
acpi_ev_address_space_dispatch(union acpi_operand_object *region_obj,
|
||||||
u32 function,
|
u32 function,
|
||||||
u32 region_offset,
|
u32 region_offset, u32 bit_width, u64 *value)
|
||||||
u32 bit_width, acpi_integer * value)
|
|
||||||
{
|
{
|
||||||
acpi_status status;
|
acpi_status status;
|
||||||
acpi_adr_space_handler handler;
|
acpi_adr_space_handler handler;
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
@ -168,7 +168,7 @@ acpi_ev_pci_config_region_setup(acpi_handle handle,
|
||||||
void *handler_context, void **region_context)
|
void *handler_context, void **region_context)
|
||||||
{
|
{
|
||||||
acpi_status status = AE_OK;
|
acpi_status status = AE_OK;
|
||||||
acpi_integer pci_value;
|
u64 pci_value;
|
||||||
struct acpi_pci_id *pci_id = *region_context;
|
struct acpi_pci_id *pci_id = *region_context;
|
||||||
union acpi_operand_object *handler_obj;
|
union acpi_operand_object *handler_obj;
|
||||||
struct acpi_namespace_node *parent_node;
|
struct acpi_namespace_node *parent_node;
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
******************************************************************************/
|
******************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
@ -284,7 +284,7 @@ static acpi_status
|
||||||
acpi_ex_region_read(union acpi_operand_object *obj_desc, u32 length, u8 *buffer)
|
acpi_ex_region_read(union acpi_operand_object *obj_desc, u32 length, u8 *buffer)
|
||||||
{
|
{
|
||||||
acpi_status status;
|
acpi_status status;
|
||||||
acpi_integer value;
|
u64 value;
|
||||||
u32 region_offset = 0;
|
u32 region_offset = 0;
|
||||||
u32 i;
|
u32 i;
|
||||||
|
|
||||||
|
@ -490,7 +490,11 @@ acpi_ex_load_op(union acpi_operand_object *obj_desc,
|
||||||
|
|
||||||
status = acpi_tb_add_table(&table_desc, &table_index);
|
status = acpi_tb_add_table(&table_desc, &table_index);
|
||||||
if (ACPI_FAILURE(status)) {
|
if (ACPI_FAILURE(status)) {
|
||||||
goto cleanup;
|
|
||||||
|
/* Delete allocated table buffer */
|
||||||
|
|
||||||
|
acpi_tb_delete_table(&table_desc);
|
||||||
|
return_ACPI_STATUS(status);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -533,13 +537,6 @@ acpi_ex_load_op(union acpi_operand_object *obj_desc,
|
||||||
acpi_gbl_table_handler_context);
|
acpi_gbl_table_handler_context);
|
||||||
}
|
}
|
||||||
|
|
||||||
cleanup:
|
|
||||||
if (ACPI_FAILURE(status)) {
|
|
||||||
|
|
||||||
/* Delete allocated table buffer */
|
|
||||||
|
|
||||||
acpi_tb_delete_table(&table_desc);
|
|
||||||
}
|
|
||||||
return_ACPI_STATUS(status);
|
return_ACPI_STATUS(status);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
@ -51,8 +51,7 @@ ACPI_MODULE_NAME("exconvrt")
|
||||||
|
|
||||||
/* Local prototypes */
|
/* Local prototypes */
|
||||||
static u32
|
static u32
|
||||||
acpi_ex_convert_to_ascii(acpi_integer integer,
|
acpi_ex_convert_to_ascii(u64 integer, u16 base, u8 *string, u8 max_length);
|
||||||
u16 base, u8 * string, u8 max_length);
|
|
||||||
|
|
||||||
/*******************************************************************************
|
/*******************************************************************************
|
||||||
*
|
*
|
||||||
|
@ -75,7 +74,7 @@ acpi_ex_convert_to_integer(union acpi_operand_object *obj_desc,
|
||||||
{
|
{
|
||||||
union acpi_operand_object *return_desc;
|
union acpi_operand_object *return_desc;
|
||||||
u8 *pointer;
|
u8 *pointer;
|
||||||
acpi_integer result;
|
u64 result;
|
||||||
u32 i;
|
u32 i;
|
||||||
u32 count;
|
u32 count;
|
||||||
acpi_status status;
|
acpi_status status;
|
||||||
|
@ -155,7 +154,7 @@ acpi_ex_convert_to_integer(union acpi_operand_object *obj_desc,
|
||||||
* Little endian is used, meaning that the first byte of the buffer
|
* Little endian is used, meaning that the first byte of the buffer
|
||||||
* is the LSB of the integer
|
* is the LSB of the integer
|
||||||
*/
|
*/
|
||||||
result |= (((acpi_integer) pointer[i]) << (i * 8));
|
result |= (((u64) pointer[i]) << (i * 8));
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
@ -285,10 +284,9 @@ acpi_ex_convert_to_buffer(union acpi_operand_object *obj_desc,
|
||||||
******************************************************************************/
|
******************************************************************************/
|
||||||
|
|
||||||
static u32
|
static u32
|
||||||
acpi_ex_convert_to_ascii(acpi_integer integer,
|
acpi_ex_convert_to_ascii(u64 integer, u16 base, u8 *string, u8 data_width)
|
||||||
u16 base, u8 * string, u8 data_width)
|
|
||||||
{
|
{
|
||||||
acpi_integer digit;
|
u64 digit;
|
||||||
u32 i;
|
u32 i;
|
||||||
u32 j;
|
u32 j;
|
||||||
u32 k = 0;
|
u32 k = 0;
|
||||||
|
@ -531,10 +529,9 @@ acpi_ex_convert_to_string(union acpi_operand_object * obj_desc,
|
||||||
* (separated by commas or spaces)
|
* (separated by commas or spaces)
|
||||||
*/
|
*/
|
||||||
for (i = 0; i < obj_desc->buffer.length; i++) {
|
for (i = 0; i < obj_desc->buffer.length; i++) {
|
||||||
new_buf += acpi_ex_convert_to_ascii((acpi_integer)
|
new_buf += acpi_ex_convert_to_ascii((u64) obj_desc->
|
||||||
obj_desc->buffer.
|
buffer.pointer[i],
|
||||||
pointer[i], base,
|
base, new_buf, 1);
|
||||||
new_buf, 1);
|
|
||||||
*new_buf++ = separator; /* each separated by a comma or space */
|
*new_buf++ = separator; /* each separated by a comma or space */
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
@ -130,7 +130,7 @@ acpi_ex_read_data_from_field(struct acpi_walk_state *walk_state,
|
||||||
/* Call the region handler for the read */
|
/* Call the region handler for the read */
|
||||||
|
|
||||||
status = acpi_ex_access_region(obj_desc, 0,
|
status = acpi_ex_access_region(obj_desc, 0,
|
||||||
ACPI_CAST_PTR(acpi_integer,
|
ACPI_CAST_PTR(u64,
|
||||||
buffer_desc->
|
buffer_desc->
|
||||||
buffer.pointer),
|
buffer.pointer),
|
||||||
function);
|
function);
|
||||||
|
@ -141,7 +141,7 @@ acpi_ex_read_data_from_field(struct acpi_walk_state *walk_state,
|
||||||
/*
|
/*
|
||||||
* Allocate a buffer for the contents of the field.
|
* Allocate a buffer for the contents of the field.
|
||||||
*
|
*
|
||||||
* If the field is larger than the size of an acpi_integer, create
|
* If the field is larger than the current integer width, create
|
||||||
* a BUFFER to hold it. Otherwise, use an INTEGER. This allows
|
* a BUFFER to hold it. Otherwise, use an INTEGER. This allows
|
||||||
* the use of arithmetic operators on the returned value if the
|
* the use of arithmetic operators on the returned value if the
|
||||||
* field size is equal or smaller than an Integer.
|
* field size is equal or smaller than an Integer.
|
||||||
|
@ -306,8 +306,7 @@ acpi_ex_write_data_to_field(union acpi_operand_object *source_desc,
|
||||||
* same buffer)
|
* same buffer)
|
||||||
*/
|
*/
|
||||||
status = acpi_ex_access_region(obj_desc, 0,
|
status = acpi_ex_access_region(obj_desc, 0,
|
||||||
(acpi_integer *) buffer,
|
(u64 *) buffer, function);
|
||||||
function);
|
|
||||||
acpi_ex_release_global_lock(obj_desc->common_field.field_flags);
|
acpi_ex_release_global_lock(obj_desc->common_field.field_flags);
|
||||||
|
|
||||||
*result_desc = buffer_desc;
|
*result_desc = buffer_desc;
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
@ -55,11 +55,10 @@ ACPI_MODULE_NAME("exfldio")
|
||||||
static acpi_status
|
static acpi_status
|
||||||
acpi_ex_field_datum_io(union acpi_operand_object *obj_desc,
|
acpi_ex_field_datum_io(union acpi_operand_object *obj_desc,
|
||||||
u32 field_datum_byte_offset,
|
u32 field_datum_byte_offset,
|
||||||
acpi_integer * value, u32 read_write);
|
u64 *value, u32 read_write);
|
||||||
|
|
||||||
static u8
|
static u8
|
||||||
acpi_ex_register_overflow(union acpi_operand_object *obj_desc,
|
acpi_ex_register_overflow(union acpi_operand_object *obj_desc, u64 value);
|
||||||
acpi_integer value);
|
|
||||||
|
|
||||||
static acpi_status
|
static acpi_status
|
||||||
acpi_ex_setup_region(union acpi_operand_object *obj_desc,
|
acpi_ex_setup_region(union acpi_operand_object *obj_desc,
|
||||||
|
@ -212,7 +211,7 @@ acpi_ex_setup_region(union acpi_operand_object *obj_desc,
|
||||||
* field_datum_byte_offset - Byte offset of this datum within the
|
* field_datum_byte_offset - Byte offset of this datum within the
|
||||||
* parent field
|
* parent field
|
||||||
* Value - Where to store value (must at least
|
* Value - Where to store value (must at least
|
||||||
* the size of acpi_integer)
|
* 64 bits)
|
||||||
* Function - Read or Write flag plus other region-
|
* Function - Read or Write flag plus other region-
|
||||||
* dependent flags
|
* dependent flags
|
||||||
*
|
*
|
||||||
|
@ -224,8 +223,7 @@ acpi_ex_setup_region(union acpi_operand_object *obj_desc,
|
||||||
|
|
||||||
acpi_status
|
acpi_status
|
||||||
acpi_ex_access_region(union acpi_operand_object *obj_desc,
|
acpi_ex_access_region(union acpi_operand_object *obj_desc,
|
||||||
u32 field_datum_byte_offset,
|
u32 field_datum_byte_offset, u64 *value, u32 function)
|
||||||
acpi_integer * value, u32 function)
|
|
||||||
{
|
{
|
||||||
acpi_status status;
|
acpi_status status;
|
||||||
union acpi_operand_object *rgn_desc;
|
union acpi_operand_object *rgn_desc;
|
||||||
|
@ -317,8 +315,7 @@ acpi_ex_access_region(union acpi_operand_object *obj_desc,
|
||||||
******************************************************************************/
|
******************************************************************************/
|
||||||
|
|
||||||
static u8
|
static u8
|
||||||
acpi_ex_register_overflow(union acpi_operand_object *obj_desc,
|
acpi_ex_register_overflow(union acpi_operand_object *obj_desc, u64 value)
|
||||||
acpi_integer value)
|
|
||||||
{
|
{
|
||||||
|
|
||||||
if (obj_desc->common_field.bit_length >= ACPI_INTEGER_BIT_SIZE) {
|
if (obj_desc->common_field.bit_length >= ACPI_INTEGER_BIT_SIZE) {
|
||||||
|
@ -329,7 +326,7 @@ acpi_ex_register_overflow(union acpi_operand_object *obj_desc,
|
||||||
return (FALSE);
|
return (FALSE);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (value >= ((acpi_integer) 1 << obj_desc->common_field.bit_length)) {
|
if (value >= ((u64) 1 << obj_desc->common_field.bit_length)) {
|
||||||
/*
|
/*
|
||||||
* The Value is larger than the maximum value that can fit into
|
* The Value is larger than the maximum value that can fit into
|
||||||
* the register.
|
* the register.
|
||||||
|
@ -362,11 +359,10 @@ acpi_ex_register_overflow(union acpi_operand_object *obj_desc,
|
||||||
|
|
||||||
static acpi_status
|
static acpi_status
|
||||||
acpi_ex_field_datum_io(union acpi_operand_object *obj_desc,
|
acpi_ex_field_datum_io(union acpi_operand_object *obj_desc,
|
||||||
u32 field_datum_byte_offset,
|
u32 field_datum_byte_offset, u64 *value, u32 read_write)
|
||||||
acpi_integer * value, u32 read_write)
|
|
||||||
{
|
{
|
||||||
acpi_status status;
|
acpi_status status;
|
||||||
acpi_integer local_value;
|
u64 local_value;
|
||||||
|
|
||||||
ACPI_FUNCTION_TRACE_U32(ex_field_datum_io, field_datum_byte_offset);
|
ACPI_FUNCTION_TRACE_U32(ex_field_datum_io, field_datum_byte_offset);
|
||||||
|
|
||||||
|
@ -439,8 +435,8 @@ acpi_ex_field_datum_io(union acpi_operand_object *obj_desc,
|
||||||
* the register
|
* the register
|
||||||
*/
|
*/
|
||||||
if (acpi_ex_register_overflow(obj_desc->bank_field.bank_obj,
|
if (acpi_ex_register_overflow(obj_desc->bank_field.bank_obj,
|
||||||
(acpi_integer) obj_desc->
|
(u64) obj_desc->bank_field.
|
||||||
bank_field.value)) {
|
value)) {
|
||||||
return_ACPI_STATUS(AE_AML_REGISTER_LIMIT);
|
return_ACPI_STATUS(AE_AML_REGISTER_LIMIT);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -481,8 +477,8 @@ acpi_ex_field_datum_io(union acpi_operand_object *obj_desc,
|
||||||
* the register
|
* the register
|
||||||
*/
|
*/
|
||||||
if (acpi_ex_register_overflow(obj_desc->index_field.index_obj,
|
if (acpi_ex_register_overflow(obj_desc->index_field.index_obj,
|
||||||
(acpi_integer) obj_desc->
|
(u64) obj_desc->index_field.
|
||||||
index_field.value)) {
|
value)) {
|
||||||
return_ACPI_STATUS(AE_AML_REGISTER_LIMIT);
|
return_ACPI_STATUS(AE_AML_REGISTER_LIMIT);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -512,7 +508,7 @@ acpi_ex_field_datum_io(union acpi_operand_object *obj_desc,
|
||||||
status =
|
status =
|
||||||
acpi_ex_extract_from_field(obj_desc->index_field.
|
acpi_ex_extract_from_field(obj_desc->index_field.
|
||||||
data_obj, value,
|
data_obj, value,
|
||||||
sizeof(acpi_integer));
|
sizeof(u64));
|
||||||
} else {
|
} else {
|
||||||
/* Write the datum to the data_register */
|
/* Write the datum to the data_register */
|
||||||
|
|
||||||
|
@ -523,7 +519,7 @@ acpi_ex_field_datum_io(union acpi_operand_object *obj_desc,
|
||||||
status =
|
status =
|
||||||
acpi_ex_insert_into_field(obj_desc->index_field.
|
acpi_ex_insert_into_field(obj_desc->index_field.
|
||||||
data_obj, value,
|
data_obj, value,
|
||||||
sizeof(acpi_integer));
|
sizeof(u64));
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
@ -571,13 +567,12 @@ acpi_ex_field_datum_io(union acpi_operand_object *obj_desc,
|
||||||
|
|
||||||
acpi_status
|
acpi_status
|
||||||
acpi_ex_write_with_update_rule(union acpi_operand_object *obj_desc,
|
acpi_ex_write_with_update_rule(union acpi_operand_object *obj_desc,
|
||||||
acpi_integer mask,
|
u64 mask,
|
||||||
acpi_integer field_value,
|
u64 field_value, u32 field_datum_byte_offset)
|
||||||
u32 field_datum_byte_offset)
|
|
||||||
{
|
{
|
||||||
acpi_status status = AE_OK;
|
acpi_status status = AE_OK;
|
||||||
acpi_integer merged_value;
|
u64 merged_value;
|
||||||
acpi_integer current_value;
|
u64 current_value;
|
||||||
|
|
||||||
ACPI_FUNCTION_TRACE_U32(ex_write_with_update_rule, mask);
|
ACPI_FUNCTION_TRACE_U32(ex_write_with_update_rule, mask);
|
||||||
|
|
||||||
|
@ -587,7 +582,7 @@ acpi_ex_write_with_update_rule(union acpi_operand_object *obj_desc,
|
||||||
|
|
||||||
/* If the mask is all ones, we don't need to worry about the update rule */
|
/* If the mask is all ones, we don't need to worry about the update rule */
|
||||||
|
|
||||||
if (mask != ACPI_INTEGER_MAX) {
|
if (mask != ACPI_UINT64_MAX) {
|
||||||
|
|
||||||
/* Decode the update rule */
|
/* Decode the update rule */
|
||||||
|
|
||||||
|
@ -678,8 +673,8 @@ acpi_ex_extract_from_field(union acpi_operand_object *obj_desc,
|
||||||
void *buffer, u32 buffer_length)
|
void *buffer, u32 buffer_length)
|
||||||
{
|
{
|
||||||
acpi_status status;
|
acpi_status status;
|
||||||
acpi_integer raw_datum;
|
u64 raw_datum;
|
||||||
acpi_integer merged_datum;
|
u64 merged_datum;
|
||||||
u32 field_offset = 0;
|
u32 field_offset = 0;
|
||||||
u32 buffer_offset = 0;
|
u32 buffer_offset = 0;
|
||||||
u32 buffer_tail_bits;
|
u32 buffer_tail_bits;
|
||||||
|
@ -804,10 +799,10 @@ acpi_ex_insert_into_field(union acpi_operand_object *obj_desc,
|
||||||
void *buffer, u32 buffer_length)
|
void *buffer, u32 buffer_length)
|
||||||
{
|
{
|
||||||
acpi_status status;
|
acpi_status status;
|
||||||
acpi_integer mask;
|
u64 mask;
|
||||||
acpi_integer width_mask;
|
u64 width_mask;
|
||||||
acpi_integer merged_datum;
|
u64 merged_datum;
|
||||||
acpi_integer raw_datum = 0;
|
u64 raw_datum = 0;
|
||||||
u32 field_offset = 0;
|
u32 field_offset = 0;
|
||||||
u32 buffer_offset = 0;
|
u32 buffer_offset = 0;
|
||||||
u32 buffer_tail_bits;
|
u32 buffer_tail_bits;
|
||||||
|
@ -855,7 +850,7 @@ acpi_ex_insert_into_field(union acpi_operand_object *obj_desc,
|
||||||
* shift operator
|
* shift operator
|
||||||
*/
|
*/
|
||||||
if (obj_desc->common_field.access_bit_width == ACPI_INTEGER_BIT_SIZE) {
|
if (obj_desc->common_field.access_bit_width == ACPI_INTEGER_BIT_SIZE) {
|
||||||
width_mask = ACPI_INTEGER_MAX;
|
width_mask = ACPI_UINT64_MAX;
|
||||||
} else {
|
} else {
|
||||||
width_mask =
|
width_mask =
|
||||||
ACPI_MASK_BITS_ABOVE(obj_desc->common_field.
|
ACPI_MASK_BITS_ABOVE(obj_desc->common_field.
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
@ -409,8 +409,7 @@ acpi_ex_do_concatenate(union acpi_operand_object *operand0,
|
||||||
*
|
*
|
||||||
******************************************************************************/
|
******************************************************************************/
|
||||||
|
|
||||||
acpi_integer
|
u64 acpi_ex_do_math_op(u16 opcode, u64 integer0, u64 integer1)
|
||||||
acpi_ex_do_math_op(u16 opcode, acpi_integer integer0, acpi_integer integer1)
|
|
||||||
{
|
{
|
||||||
|
|
||||||
ACPI_FUNCTION_ENTRY();
|
ACPI_FUNCTION_ENTRY();
|
||||||
|
@ -498,8 +497,7 @@ acpi_ex_do_math_op(u16 opcode, acpi_integer integer0, acpi_integer integer1)
|
||||||
|
|
||||||
acpi_status
|
acpi_status
|
||||||
acpi_ex_do_logical_numeric_op(u16 opcode,
|
acpi_ex_do_logical_numeric_op(u16 opcode,
|
||||||
acpi_integer integer0,
|
u64 integer0, u64 integer1, u8 *logical_result)
|
||||||
acpi_integer integer1, u8 * logical_result)
|
|
||||||
{
|
{
|
||||||
acpi_status status = AE_OK;
|
acpi_status status = AE_OK;
|
||||||
u8 local_result = FALSE;
|
u8 local_result = FALSE;
|
||||||
|
@ -564,8 +562,8 @@ acpi_ex_do_logical_op(u16 opcode,
|
||||||
union acpi_operand_object *operand1, u8 * logical_result)
|
union acpi_operand_object *operand1, u8 * logical_result)
|
||||||
{
|
{
|
||||||
union acpi_operand_object *local_operand1 = operand1;
|
union acpi_operand_object *local_operand1 = operand1;
|
||||||
acpi_integer integer0;
|
u64 integer0;
|
||||||
acpi_integer integer1;
|
u64 integer1;
|
||||||
u32 length0;
|
u32 length0;
|
||||||
u32 length1;
|
u32 length1;
|
||||||
acpi_status status = AE_OK;
|
acpi_status status = AE_OK;
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
@ -261,8 +261,8 @@ acpi_status acpi_ex_opcode_1A_1T_1R(struct acpi_walk_state *walk_state)
|
||||||
union acpi_operand_object *return_desc2 = NULL;
|
union acpi_operand_object *return_desc2 = NULL;
|
||||||
u32 temp32;
|
u32 temp32;
|
||||||
u32 i;
|
u32 i;
|
||||||
acpi_integer power_of_ten;
|
u64 power_of_ten;
|
||||||
acpi_integer digit;
|
u64 digit;
|
||||||
|
|
||||||
ACPI_FUNCTION_TRACE_STR(ex_opcode_1A_1T_1R,
|
ACPI_FUNCTION_TRACE_STR(ex_opcode_1A_1T_1R,
|
||||||
acpi_ps_get_opcode_name(walk_state->opcode));
|
acpi_ps_get_opcode_name(walk_state->opcode));
|
||||||
|
@ -362,7 +362,7 @@ acpi_status acpi_ex_opcode_1A_1T_1R(struct acpi_walk_state *walk_state)
|
||||||
/* Sum the digit into the result with the current power of 10 */
|
/* Sum the digit into the result with the current power of 10 */
|
||||||
|
|
||||||
return_desc->integer.value +=
|
return_desc->integer.value +=
|
||||||
(((acpi_integer) temp32) * power_of_ten);
|
(((u64) temp32) * power_of_ten);
|
||||||
|
|
||||||
/* Shift to next BCD digit */
|
/* Shift to next BCD digit */
|
||||||
|
|
||||||
|
@ -392,7 +392,7 @@ acpi_status acpi_ex_opcode_1A_1T_1R(struct acpi_walk_state *walk_state)
|
||||||
* remainder from above
|
* remainder from above
|
||||||
*/
|
*/
|
||||||
return_desc->integer.value |=
|
return_desc->integer.value |=
|
||||||
(((acpi_integer) temp32) << ACPI_MUL_4(i));
|
(((u64) temp32) << ACPI_MUL_4(i));
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Overflow if there is any data left in Digit */
|
/* Overflow if there is any data left in Digit */
|
||||||
|
@ -439,7 +439,7 @@ acpi_status acpi_ex_opcode_1A_1T_1R(struct acpi_walk_state *walk_state)
|
||||||
|
|
||||||
/* The object exists in the namespace, return TRUE */
|
/* The object exists in the namespace, return TRUE */
|
||||||
|
|
||||||
return_desc->integer.value = ACPI_INTEGER_MAX;
|
return_desc->integer.value = ACPI_UINT64_MAX;
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
|
@ -589,7 +589,7 @@ acpi_status acpi_ex_opcode_1A_0T_1R(struct acpi_walk_state *walk_state)
|
||||||
union acpi_operand_object *return_desc = NULL;
|
union acpi_operand_object *return_desc = NULL;
|
||||||
acpi_status status = AE_OK;
|
acpi_status status = AE_OK;
|
||||||
u32 type;
|
u32 type;
|
||||||
acpi_integer value;
|
u64 value;
|
||||||
|
|
||||||
ACPI_FUNCTION_TRACE_STR(ex_opcode_1A_0T_1R,
|
ACPI_FUNCTION_TRACE_STR(ex_opcode_1A_0T_1R,
|
||||||
acpi_ps_get_opcode_name(walk_state->opcode));
|
acpi_ps_get_opcode_name(walk_state->opcode));
|
||||||
|
@ -610,7 +610,7 @@ acpi_status acpi_ex_opcode_1A_0T_1R(struct acpi_walk_state *walk_state)
|
||||||
* return_desc->Integer.Value is initially == 0 (FALSE) from above.
|
* return_desc->Integer.Value is initially == 0 (FALSE) from above.
|
||||||
*/
|
*/
|
||||||
if (!operand[0]->integer.value) {
|
if (!operand[0]->integer.value) {
|
||||||
return_desc->integer.value = ACPI_INTEGER_MAX;
|
return_desc->integer.value = ACPI_UINT64_MAX;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
@ -282,7 +282,7 @@ acpi_status acpi_ex_opcode_2A_1T_1R(struct acpi_walk_state *walk_state)
|
||||||
{
|
{
|
||||||
union acpi_operand_object **operand = &walk_state->operands[0];
|
union acpi_operand_object **operand = &walk_state->operands[0];
|
||||||
union acpi_operand_object *return_desc = NULL;
|
union acpi_operand_object *return_desc = NULL;
|
||||||
acpi_integer index;
|
u64 index;
|
||||||
acpi_status status = AE_OK;
|
acpi_status status = AE_OK;
|
||||||
acpi_size length;
|
acpi_size length;
|
||||||
|
|
||||||
|
@ -584,7 +584,7 @@ acpi_status acpi_ex_opcode_2A_0T_1R(struct acpi_walk_state *walk_state)
|
||||||
* Default is FALSE (zero)
|
* Default is FALSE (zero)
|
||||||
*/
|
*/
|
||||||
if (logical_result) {
|
if (logical_result) {
|
||||||
return_desc->integer.value = ACPI_INTEGER_MAX;
|
return_desc->integer.value = ACPI_UINT64_MAX;
|
||||||
}
|
}
|
||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
@ -148,7 +148,7 @@ acpi_status acpi_ex_opcode_3A_1T_1R(struct acpi_walk_state *walk_state)
|
||||||
union acpi_operand_object *return_desc = NULL;
|
union acpi_operand_object *return_desc = NULL;
|
||||||
char *buffer = NULL;
|
char *buffer = NULL;
|
||||||
acpi_status status = AE_OK;
|
acpi_status status = AE_OK;
|
||||||
acpi_integer index;
|
u64 index;
|
||||||
acpi_size length;
|
acpi_size length;
|
||||||
|
|
||||||
ACPI_FUNCTION_TRACE_STR(ex_opcode_3A_1T_1R,
|
ACPI_FUNCTION_TRACE_STR(ex_opcode_3A_1T_1R,
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
@ -218,7 +218,7 @@ acpi_status acpi_ex_opcode_6A_0T_1R(struct acpi_walk_state * walk_state)
|
||||||
union acpi_operand_object **operand = &walk_state->operands[0];
|
union acpi_operand_object **operand = &walk_state->operands[0];
|
||||||
union acpi_operand_object *return_desc = NULL;
|
union acpi_operand_object *return_desc = NULL;
|
||||||
acpi_status status = AE_OK;
|
acpi_status status = AE_OK;
|
||||||
acpi_integer index;
|
u64 index;
|
||||||
union acpi_operand_object *this_element;
|
union acpi_operand_object *this_element;
|
||||||
|
|
||||||
ACPI_FUNCTION_TRACE_STR(ex_opcode_6A_0T_1R,
|
ACPI_FUNCTION_TRACE_STR(ex_opcode_6A_0T_1R,
|
||||||
|
@ -253,9 +253,9 @@ acpi_status acpi_ex_opcode_6A_0T_1R(struct acpi_walk_state * walk_state)
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Create an integer for the return value */
|
/* Create an integer for the return value */
|
||||||
/* Default return value is ACPI_INTEGER_MAX if no match found */
|
/* Default return value is ACPI_UINT64_MAX if no match found */
|
||||||
|
|
||||||
return_desc = acpi_ut_create_integer_object(ACPI_INTEGER_MAX);
|
return_desc = acpi_ut_create_integer_object(ACPI_UINT64_MAX);
|
||||||
if (!return_desc) {
|
if (!return_desc) {
|
||||||
status = AE_NO_MEMORY;
|
status = AE_NO_MEMORY;
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
@ -270,7 +270,7 @@ acpi_status acpi_ex_opcode_6A_0T_1R(struct acpi_walk_state * walk_state)
|
||||||
*
|
*
|
||||||
* Upon finding a match, the loop will terminate via "break" at
|
* Upon finding a match, the loop will terminate via "break" at
|
||||||
* the bottom. If it terminates "normally", match_value will be
|
* the bottom. If it terminates "normally", match_value will be
|
||||||
* ACPI_INTEGER_MAX (Ones) (its initial value) indicating that no
|
* ACPI_UINT64_MAX (Ones) (its initial value) indicating that no
|
||||||
* match was found.
|
* match was found.
|
||||||
*/
|
*/
|
||||||
for (; index < operand[0]->package.count; index++) {
|
for (; index < operand[0]->package.count; index++) {
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
@ -70,7 +70,7 @@ acpi_status
|
||||||
acpi_ex_system_memory_space_handler(u32 function,
|
acpi_ex_system_memory_space_handler(u32 function,
|
||||||
acpi_physical_address address,
|
acpi_physical_address address,
|
||||||
u32 bit_width,
|
u32 bit_width,
|
||||||
acpi_integer * value,
|
u64 *value,
|
||||||
void *handler_context, void *region_context)
|
void *handler_context, void *region_context)
|
||||||
{
|
{
|
||||||
acpi_status status = AE_OK;
|
acpi_status status = AE_OK;
|
||||||
|
@ -115,8 +115,7 @@ acpi_ex_system_memory_space_handler(u32 function,
|
||||||
* Hardware does not support non-aligned data transfers, we must verify
|
* Hardware does not support non-aligned data transfers, we must verify
|
||||||
* the request.
|
* the request.
|
||||||
*/
|
*/
|
||||||
(void)acpi_ut_short_divide((acpi_integer) address, length, NULL,
|
(void)acpi_ut_short_divide((u64) address, length, NULL, &remainder);
|
||||||
&remainder);
|
|
||||||
if (remainder != 0) {
|
if (remainder != 0) {
|
||||||
return_ACPI_STATUS(AE_AML_ALIGNMENT);
|
return_ACPI_STATUS(AE_AML_ALIGNMENT);
|
||||||
}
|
}
|
||||||
|
@ -128,10 +127,9 @@ acpi_ex_system_memory_space_handler(u32 function,
|
||||||
* 2) Address beyond the current mapping?
|
* 2) Address beyond the current mapping?
|
||||||
*/
|
*/
|
||||||
if ((address < mem_info->mapped_physical_address) ||
|
if ((address < mem_info->mapped_physical_address) ||
|
||||||
(((acpi_integer) address + length) > ((acpi_integer)
|
(((u64) address + length) > ((u64)
|
||||||
mem_info->
|
mem_info->mapped_physical_address +
|
||||||
mapped_physical_address +
|
mem_info->mapped_length))) {
|
||||||
mem_info->mapped_length))) {
|
|
||||||
/*
|
/*
|
||||||
* The request cannot be resolved by the current memory mapping;
|
* The request cannot be resolved by the current memory mapping;
|
||||||
* Delete the existing mapping and create a new one.
|
* Delete the existing mapping and create a new one.
|
||||||
|
@ -193,8 +191,7 @@ acpi_ex_system_memory_space_handler(u32 function,
|
||||||
* access
|
* access
|
||||||
*/
|
*/
|
||||||
logical_addr_ptr = mem_info->mapped_logical_address +
|
logical_addr_ptr = mem_info->mapped_logical_address +
|
||||||
((acpi_integer) address -
|
((u64) address - (u64) mem_info->mapped_physical_address);
|
||||||
(acpi_integer) mem_info->mapped_physical_address);
|
|
||||||
|
|
||||||
ACPI_DEBUG_PRINT((ACPI_DB_INFO,
|
ACPI_DEBUG_PRINT((ACPI_DB_INFO,
|
||||||
"System-Memory (width %d) R/W %d Address=%8.8X%8.8X\n",
|
"System-Memory (width %d) R/W %d Address=%8.8X%8.8X\n",
|
||||||
|
@ -215,19 +212,19 @@ acpi_ex_system_memory_space_handler(u32 function,
|
||||||
*value = 0;
|
*value = 0;
|
||||||
switch (bit_width) {
|
switch (bit_width) {
|
||||||
case 8:
|
case 8:
|
||||||
*value = (acpi_integer) ACPI_GET8(logical_addr_ptr);
|
*value = (u64) ACPI_GET8(logical_addr_ptr);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 16:
|
case 16:
|
||||||
*value = (acpi_integer) ACPI_GET16(logical_addr_ptr);
|
*value = (u64) ACPI_GET16(logical_addr_ptr);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 32:
|
case 32:
|
||||||
*value = (acpi_integer) ACPI_GET32(logical_addr_ptr);
|
*value = (u64) ACPI_GET32(logical_addr_ptr);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 64:
|
case 64:
|
||||||
*value = (acpi_integer) ACPI_GET64(logical_addr_ptr);
|
*value = (u64) ACPI_GET64(logical_addr_ptr);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
|
@ -291,7 +288,7 @@ acpi_status
|
||||||
acpi_ex_system_io_space_handler(u32 function,
|
acpi_ex_system_io_space_handler(u32 function,
|
||||||
acpi_physical_address address,
|
acpi_physical_address address,
|
||||||
u32 bit_width,
|
u32 bit_width,
|
||||||
acpi_integer * value,
|
u64 *value,
|
||||||
void *handler_context, void *region_context)
|
void *handler_context, void *region_context)
|
||||||
{
|
{
|
||||||
acpi_status status = AE_OK;
|
acpi_status status = AE_OK;
|
||||||
|
@ -350,7 +347,7 @@ acpi_status
|
||||||
acpi_ex_pci_config_space_handler(u32 function,
|
acpi_ex_pci_config_space_handler(u32 function,
|
||||||
acpi_physical_address address,
|
acpi_physical_address address,
|
||||||
u32 bit_width,
|
u32 bit_width,
|
||||||
acpi_integer * value,
|
u64 *value,
|
||||||
void *handler_context, void *region_context)
|
void *handler_context, void *region_context)
|
||||||
{
|
{
|
||||||
acpi_status status = AE_OK;
|
acpi_status status = AE_OK;
|
||||||
|
@ -425,7 +422,7 @@ acpi_status
|
||||||
acpi_ex_cmos_space_handler(u32 function,
|
acpi_ex_cmos_space_handler(u32 function,
|
||||||
acpi_physical_address address,
|
acpi_physical_address address,
|
||||||
u32 bit_width,
|
u32 bit_width,
|
||||||
acpi_integer * value,
|
u64 *value,
|
||||||
void *handler_context, void *region_context)
|
void *handler_context, void *region_context)
|
||||||
{
|
{
|
||||||
acpi_status status = AE_OK;
|
acpi_status status = AE_OK;
|
||||||
|
@ -457,7 +454,7 @@ acpi_status
|
||||||
acpi_ex_pci_bar_space_handler(u32 function,
|
acpi_ex_pci_bar_space_handler(u32 function,
|
||||||
acpi_physical_address address,
|
acpi_physical_address address,
|
||||||
u32 bit_width,
|
u32 bit_width,
|
||||||
acpi_integer * value,
|
u64 *value,
|
||||||
void *handler_context, void *region_context)
|
void *handler_context, void *region_context)
|
||||||
{
|
{
|
||||||
acpi_status status = AE_OK;
|
acpi_status status = AE_OK;
|
||||||
|
@ -489,7 +486,7 @@ acpi_status
|
||||||
acpi_ex_data_table_space_handler(u32 function,
|
acpi_ex_data_table_space_handler(u32 function,
|
||||||
acpi_physical_address address,
|
acpi_physical_address address,
|
||||||
u32 bit_width,
|
u32 bit_width,
|
||||||
acpi_integer * value,
|
u64 *value,
|
||||||
void *handler_context, void *region_context)
|
void *handler_context, void *region_context)
|
||||||
{
|
{
|
||||||
ACPI_FUNCTION_TRACE(ex_data_table_space_handler);
|
ACPI_FUNCTION_TRACE(ex_data_table_space_handler);
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -7,7 +7,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
@ -193,7 +193,7 @@ acpi_status acpi_ex_system_do_stall(u32 how_long)
|
||||||
*
|
*
|
||||||
******************************************************************************/
|
******************************************************************************/
|
||||||
|
|
||||||
acpi_status acpi_ex_system_do_suspend(acpi_integer how_long)
|
acpi_status acpi_ex_system_do_suspend(u64 how_long)
|
||||||
{
|
{
|
||||||
ACPI_FUNCTION_ENTRY();
|
ACPI_FUNCTION_ENTRY();
|
||||||
|
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
@ -67,7 +67,7 @@
|
||||||
ACPI_MODULE_NAME("exutils")
|
ACPI_MODULE_NAME("exutils")
|
||||||
|
|
||||||
/* Local prototypes */
|
/* Local prototypes */
|
||||||
static u32 acpi_ex_digits_needed(acpi_integer value, u32 base);
|
static u32 acpi_ex_digits_needed(u64 value, u32 base);
|
||||||
|
|
||||||
#ifndef ACPI_NO_METHOD_EXECUTION
|
#ifndef ACPI_NO_METHOD_EXECUTION
|
||||||
/*******************************************************************************
|
/*******************************************************************************
|
||||||
|
@ -230,7 +230,7 @@ void acpi_ex_truncate_for32bit_table(union acpi_operand_object *obj_desc)
|
||||||
* We are running a method that exists in a 32-bit ACPI table.
|
* We are running a method that exists in a 32-bit ACPI table.
|
||||||
* Truncate the value to 32 bits by zeroing out the upper 32-bit field
|
* Truncate the value to 32 bits by zeroing out the upper 32-bit field
|
||||||
*/
|
*/
|
||||||
obj_desc->integer.value &= (acpi_integer) ACPI_UINT32_MAX;
|
obj_desc->integer.value &= (u64) ACPI_UINT32_MAX;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -327,14 +327,14 @@ void acpi_ex_release_global_lock(u32 field_flags)
|
||||||
*
|
*
|
||||||
******************************************************************************/
|
******************************************************************************/
|
||||||
|
|
||||||
static u32 acpi_ex_digits_needed(acpi_integer value, u32 base)
|
static u32 acpi_ex_digits_needed(u64 value, u32 base)
|
||||||
{
|
{
|
||||||
u32 num_digits;
|
u32 num_digits;
|
||||||
acpi_integer current_value;
|
u64 current_value;
|
||||||
|
|
||||||
ACPI_FUNCTION_TRACE(ex_digits_needed);
|
ACPI_FUNCTION_TRACE(ex_digits_needed);
|
||||||
|
|
||||||
/* acpi_integer is unsigned, so we don't worry about a '-' prefix */
|
/* u64 is unsigned, so we don't worry about a '-' prefix */
|
||||||
|
|
||||||
if (value == 0) {
|
if (value == 0) {
|
||||||
return_UINT32(1);
|
return_UINT32(1);
|
||||||
|
@ -370,7 +370,7 @@ static u32 acpi_ex_digits_needed(acpi_integer value, u32 base)
|
||||||
*
|
*
|
||||||
******************************************************************************/
|
******************************************************************************/
|
||||||
|
|
||||||
void acpi_ex_eisa_id_to_string(char *out_string, acpi_integer compressed_id)
|
void acpi_ex_eisa_id_to_string(char *out_string, u64 compressed_id)
|
||||||
{
|
{
|
||||||
u32 swapped_id;
|
u32 swapped_id;
|
||||||
|
|
||||||
|
@ -394,10 +394,10 @@ void acpi_ex_eisa_id_to_string(char *out_string, acpi_integer compressed_id)
|
||||||
(char)(0x40 + (((unsigned long)swapped_id >> 26) & 0x1F));
|
(char)(0x40 + (((unsigned long)swapped_id >> 26) & 0x1F));
|
||||||
out_string[1] = (char)(0x40 + ((swapped_id >> 21) & 0x1F));
|
out_string[1] = (char)(0x40 + ((swapped_id >> 21) & 0x1F));
|
||||||
out_string[2] = (char)(0x40 + ((swapped_id >> 16) & 0x1F));
|
out_string[2] = (char)(0x40 + ((swapped_id >> 16) & 0x1F));
|
||||||
out_string[3] = acpi_ut_hex_to_ascii_char((acpi_integer)swapped_id, 12);
|
out_string[3] = acpi_ut_hex_to_ascii_char((u64) swapped_id, 12);
|
||||||
out_string[4] = acpi_ut_hex_to_ascii_char((acpi_integer)swapped_id, 8);
|
out_string[4] = acpi_ut_hex_to_ascii_char((u64) swapped_id, 8);
|
||||||
out_string[5] = acpi_ut_hex_to_ascii_char((acpi_integer)swapped_id, 4);
|
out_string[5] = acpi_ut_hex_to_ascii_char((u64) swapped_id, 4);
|
||||||
out_string[6] = acpi_ut_hex_to_ascii_char((acpi_integer)swapped_id, 0);
|
out_string[6] = acpi_ut_hex_to_ascii_char((u64) swapped_id, 0);
|
||||||
out_string[7] = 0;
|
out_string[7] = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -418,7 +418,7 @@ void acpi_ex_eisa_id_to_string(char *out_string, acpi_integer compressed_id)
|
||||||
*
|
*
|
||||||
******************************************************************************/
|
******************************************************************************/
|
||||||
|
|
||||||
void acpi_ex_integer_to_string(char *out_string, acpi_integer value)
|
void acpi_ex_integer_to_string(char *out_string, u64 value)
|
||||||
{
|
{
|
||||||
u32 count;
|
u32 count;
|
||||||
u32 digits_needed;
|
u32 digits_needed;
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
@ -224,7 +224,7 @@ acpi_hw_get_gpe_status(struct acpi_gpe_event_info * gpe_event_info,
|
||||||
|
|
||||||
status = acpi_hw_read(&in_byte, &gpe_register_info->status_address);
|
status = acpi_hw_read(&in_byte, &gpe_register_info->status_address);
|
||||||
if (ACPI_FAILURE(status)) {
|
if (ACPI_FAILURE(status)) {
|
||||||
goto unlock_and_exit;
|
return (status);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (register_bit & in_byte) {
|
if (register_bit & in_byte) {
|
||||||
|
@ -234,9 +234,7 @@ acpi_hw_get_gpe_status(struct acpi_gpe_event_info * gpe_event_info,
|
||||||
/* Set return value */
|
/* Set return value */
|
||||||
|
|
||||||
(*event_status) = local_event_status;
|
(*event_status) = local_event_status;
|
||||||
|
return (AE_OK);
|
||||||
unlock_and_exit:
|
|
||||||
return (status);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/******************************************************************************
|
/******************************************************************************
|
||||||
|
|
|
@ -7,7 +7,7 @@
|
||||||
******************************************************************************/
|
******************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
@ -140,7 +140,7 @@ acpi_get_timer_duration(u32 start_ticks, u32 end_ticks, u32 * time_elapsed)
|
||||||
{
|
{
|
||||||
acpi_status status;
|
acpi_status status;
|
||||||
u32 delta_ticks;
|
u32 delta_ticks;
|
||||||
acpi_integer quotient;
|
u64 quotient;
|
||||||
|
|
||||||
ACPI_FUNCTION_TRACE(acpi_get_timer_duration);
|
ACPI_FUNCTION_TRACE(acpi_get_timer_duration);
|
||||||
|
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2009, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
******************************************************************************/
|
******************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
******************************************************************************/
|
******************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
******************************************************************************/
|
******************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
******************************************************************************/
|
******************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
******************************************************************************/
|
******************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
@ -231,6 +231,7 @@ acpi_ns_check_predefined_names(struct acpi_namespace_node *node,
|
||||||
* Note: Package may have been newly created by call above.
|
* Note: Package may have been newly created by call above.
|
||||||
*/
|
*/
|
||||||
if ((*return_object_ptr)->common.type == ACPI_TYPE_PACKAGE) {
|
if ((*return_object_ptr)->common.type == ACPI_TYPE_PACKAGE) {
|
||||||
|
data->parent_package = *return_object_ptr;
|
||||||
status = acpi_ns_check_package(data, return_object_ptr);
|
status = acpi_ns_check_package(data, return_object_ptr);
|
||||||
if (ACPI_FAILURE(status)) {
|
if (ACPI_FAILURE(status)) {
|
||||||
goto exit;
|
goto exit;
|
||||||
|
@ -710,6 +711,7 @@ acpi_ns_check_package_list(struct acpi_predefined_data *data,
|
||||||
for (i = 0; i < count; i++) {
|
for (i = 0; i < count; i++) {
|
||||||
sub_package = *elements;
|
sub_package = *elements;
|
||||||
sub_elements = sub_package->package.elements;
|
sub_elements = sub_package->package.elements;
|
||||||
|
data->parent_package = sub_package;
|
||||||
|
|
||||||
/* Each sub-object must be of type Package */
|
/* Each sub-object must be of type Package */
|
||||||
|
|
||||||
|
@ -721,6 +723,7 @@ acpi_ns_check_package_list(struct acpi_predefined_data *data,
|
||||||
|
|
||||||
/* Examine the different types of expected sub-packages */
|
/* Examine the different types of expected sub-packages */
|
||||||
|
|
||||||
|
data->parent_package = sub_package;
|
||||||
switch (package->ret_info.type) {
|
switch (package->ret_info.type) {
|
||||||
case ACPI_PTYPE2:
|
case ACPI_PTYPE2:
|
||||||
case ACPI_PTYPE2_PKG_COUNT:
|
case ACPI_PTYPE2_PKG_COUNT:
|
||||||
|
@ -800,7 +803,7 @@ acpi_ns_check_package_list(struct acpi_predefined_data *data,
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* First element is the (Integer) count of elements, including
|
* First element is the (Integer) count of elements, including
|
||||||
* the count field.
|
* the count field (the ACPI name is num_elements)
|
||||||
*/
|
*/
|
||||||
status = acpi_ns_check_object_type(data, sub_elements,
|
status = acpi_ns_check_object_type(data, sub_elements,
|
||||||
ACPI_RTYPE_INTEGER,
|
ACPI_RTYPE_INTEGER,
|
||||||
|
@ -822,6 +825,16 @@ acpi_ns_check_package_list(struct acpi_predefined_data *data,
|
||||||
expected_count = package->ret_info.count1;
|
expected_count = package->ret_info.count1;
|
||||||
goto package_too_small;
|
goto package_too_small;
|
||||||
}
|
}
|
||||||
|
if (expected_count == 0) {
|
||||||
|
/*
|
||||||
|
* Either the num_entries element was originally zero or it was
|
||||||
|
* a NULL element and repaired to an Integer of value zero.
|
||||||
|
* In either case, repair it by setting num_entries to be the
|
||||||
|
* actual size of the subpackage.
|
||||||
|
*/
|
||||||
|
expected_count = sub_package->package.count;
|
||||||
|
(*sub_elements)->integer.value = expected_count;
|
||||||
|
}
|
||||||
|
|
||||||
/* Check the type of each sub-package element */
|
/* Check the type of each sub-package element */
|
||||||
|
|
||||||
|
@ -945,10 +958,18 @@ acpi_ns_check_object_type(struct acpi_predefined_data *data,
|
||||||
char type_buffer[48]; /* Room for 5 types */
|
char type_buffer[48]; /* Room for 5 types */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* If we get a NULL return_object here, it is a NULL package element,
|
* If we get a NULL return_object here, it is a NULL package element.
|
||||||
* and this is always an error.
|
* Since all extraneous NULL package elements were removed earlier by a
|
||||||
|
* call to acpi_ns_remove_null_elements, this is an unexpected NULL element.
|
||||||
|
* We will attempt to repair it.
|
||||||
*/
|
*/
|
||||||
if (!return_object) {
|
if (!return_object) {
|
||||||
|
status = acpi_ns_repair_null_element(data, expected_btypes,
|
||||||
|
package_index,
|
||||||
|
return_object_ptr);
|
||||||
|
if (ACPI_SUCCESS(status)) {
|
||||||
|
return (AE_OK); /* Repair was successful */
|
||||||
|
}
|
||||||
goto type_error_exit;
|
goto type_error_exit;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1000,27 +1021,25 @@ acpi_ns_check_object_type(struct acpi_predefined_data *data,
|
||||||
|
|
||||||
/* Is the object one of the expected types? */
|
/* Is the object one of the expected types? */
|
||||||
|
|
||||||
if (!(return_btype & expected_btypes)) {
|
if (return_btype & expected_btypes) {
|
||||||
|
|
||||||
/* Type mismatch -- attempt repair of the returned object */
|
/* For reference objects, check that the reference type is correct */
|
||||||
|
|
||||||
status = acpi_ns_repair_object(data, expected_btypes,
|
if (return_object->common.type == ACPI_TYPE_LOCAL_REFERENCE) {
|
||||||
package_index,
|
status = acpi_ns_check_reference(data, return_object);
|
||||||
return_object_ptr);
|
|
||||||
if (ACPI_SUCCESS(status)) {
|
|
||||||
return (AE_OK); /* Repair was successful */
|
|
||||||
}
|
}
|
||||||
goto type_error_exit;
|
|
||||||
|
return (status);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* For reference objects, check that the reference type is correct */
|
/* Type mismatch -- attempt repair of the returned object */
|
||||||
|
|
||||||
if (return_object->common.type == ACPI_TYPE_LOCAL_REFERENCE) {
|
status = acpi_ns_repair_object(data, expected_btypes,
|
||||||
status = acpi_ns_check_reference(data, return_object);
|
package_index, return_object_ptr);
|
||||||
|
if (ACPI_SUCCESS(status)) {
|
||||||
|
return (AE_OK); /* Repair was successful */
|
||||||
}
|
}
|
||||||
|
|
||||||
return (status);
|
|
||||||
|
|
||||||
type_error_exit:
|
type_error_exit:
|
||||||
|
|
||||||
/* Create a string with all expected types for this predefined object */
|
/* Create a string with all expected types for this predefined object */
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2009, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
@ -45,6 +45,7 @@
|
||||||
#include "accommon.h"
|
#include "accommon.h"
|
||||||
#include "acnamesp.h"
|
#include "acnamesp.h"
|
||||||
#include "acinterp.h"
|
#include "acinterp.h"
|
||||||
|
#include "acpredef.h"
|
||||||
|
|
||||||
#define _COMPONENT ACPI_NAMESPACE
|
#define _COMPONENT ACPI_NAMESPACE
|
||||||
ACPI_MODULE_NAME("nsrepair")
|
ACPI_MODULE_NAME("nsrepair")
|
||||||
|
@ -71,6 +72,12 @@ ACPI_MODULE_NAME("nsrepair")
|
||||||
* Buffer -> Package of Integers
|
* Buffer -> Package of Integers
|
||||||
* Package -> Package of one Package
|
* Package -> Package of one Package
|
||||||
*
|
*
|
||||||
|
* Additional possible repairs:
|
||||||
|
*
|
||||||
|
* Optional/unnecessary NULL package elements removed
|
||||||
|
* Required package elements that are NULL replaced by Integer/String/Buffer
|
||||||
|
* Incorrect standalone package wrapped with required outer package
|
||||||
|
*
|
||||||
******************************************************************************/
|
******************************************************************************/
|
||||||
/* Local prototypes */
|
/* Local prototypes */
|
||||||
static acpi_status
|
static acpi_status
|
||||||
|
@ -504,6 +511,172 @@ acpi_ns_convert_to_package(union acpi_operand_object *original_object,
|
||||||
return (AE_OK);
|
return (AE_OK);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*******************************************************************************
|
||||||
|
*
|
||||||
|
* FUNCTION: acpi_ns_repair_null_element
|
||||||
|
*
|
||||||
|
* PARAMETERS: Data - Pointer to validation data structure
|
||||||
|
* expected_btypes - Object types expected
|
||||||
|
* package_index - Index of object within parent package (if
|
||||||
|
* applicable - ACPI_NOT_PACKAGE_ELEMENT
|
||||||
|
* otherwise)
|
||||||
|
* return_object_ptr - Pointer to the object returned from the
|
||||||
|
* evaluation of a method or object
|
||||||
|
*
|
||||||
|
* RETURN: Status. AE_OK if repair was successful.
|
||||||
|
*
|
||||||
|
* DESCRIPTION: Attempt to repair a NULL element of a returned Package object.
|
||||||
|
*
|
||||||
|
******************************************************************************/
|
||||||
|
|
||||||
|
acpi_status
|
||||||
|
acpi_ns_repair_null_element(struct acpi_predefined_data *data,
|
||||||
|
u32 expected_btypes,
|
||||||
|
u32 package_index,
|
||||||
|
union acpi_operand_object **return_object_ptr)
|
||||||
|
{
|
||||||
|
union acpi_operand_object *return_object = *return_object_ptr;
|
||||||
|
union acpi_operand_object *new_object;
|
||||||
|
|
||||||
|
ACPI_FUNCTION_NAME(ns_repair_null_element);
|
||||||
|
|
||||||
|
/* No repair needed if return object is non-NULL */
|
||||||
|
|
||||||
|
if (return_object) {
|
||||||
|
return (AE_OK);
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Attempt to repair a NULL element of a Package object. This applies to
|
||||||
|
* predefined names that return a fixed-length package and each element
|
||||||
|
* is required. It does not apply to variable-length packages where NULL
|
||||||
|
* elements are allowed, especially at the end of the package.
|
||||||
|
*/
|
||||||
|
if (expected_btypes & ACPI_RTYPE_INTEGER) {
|
||||||
|
|
||||||
|
/* Need an Integer - create a zero-value integer */
|
||||||
|
|
||||||
|
new_object = acpi_ut_create_integer_object(0);
|
||||||
|
} else if (expected_btypes & ACPI_RTYPE_STRING) {
|
||||||
|
|
||||||
|
/* Need a String - create a NULL string */
|
||||||
|
|
||||||
|
new_object = acpi_ut_create_string_object(0);
|
||||||
|
} else if (expected_btypes & ACPI_RTYPE_BUFFER) {
|
||||||
|
|
||||||
|
/* Need a Buffer - create a zero-length buffer */
|
||||||
|
|
||||||
|
new_object = acpi_ut_create_buffer_object(0);
|
||||||
|
} else {
|
||||||
|
/* Error for all other expected types */
|
||||||
|
|
||||||
|
return (AE_AML_OPERAND_TYPE);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!new_object) {
|
||||||
|
return (AE_NO_MEMORY);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Set the reference count according to the parent Package object */
|
||||||
|
|
||||||
|
new_object->common.reference_count =
|
||||||
|
data->parent_package->common.reference_count;
|
||||||
|
|
||||||
|
ACPI_DEBUG_PRINT((ACPI_DB_REPAIR,
|
||||||
|
"%s: Converted NULL package element to expected %s at index %u\n",
|
||||||
|
data->pathname,
|
||||||
|
acpi_ut_get_object_type_name(new_object),
|
||||||
|
package_index));
|
||||||
|
|
||||||
|
*return_object_ptr = new_object;
|
||||||
|
data->flags |= ACPI_OBJECT_REPAIRED;
|
||||||
|
return (AE_OK);
|
||||||
|
}
|
||||||
|
|
||||||
|
/******************************************************************************
|
||||||
|
*
|
||||||
|
* FUNCTION: acpi_ns_remove_null_elements
|
||||||
|
*
|
||||||
|
* PARAMETERS: Data - Pointer to validation data structure
|
||||||
|
* package_type - An acpi_return_package_types value
|
||||||
|
* obj_desc - A Package object
|
||||||
|
*
|
||||||
|
* RETURN: None.
|
||||||
|
*
|
||||||
|
* DESCRIPTION: Remove all NULL package elements from packages that contain
|
||||||
|
* a variable number of sub-packages. For these types of
|
||||||
|
* packages, NULL elements can be safely removed.
|
||||||
|
*
|
||||||
|
*****************************************************************************/
|
||||||
|
|
||||||
|
void
|
||||||
|
acpi_ns_remove_null_elements(struct acpi_predefined_data *data,
|
||||||
|
u8 package_type,
|
||||||
|
union acpi_operand_object *obj_desc)
|
||||||
|
{
|
||||||
|
union acpi_operand_object **source;
|
||||||
|
union acpi_operand_object **dest;
|
||||||
|
u32 count;
|
||||||
|
u32 new_count;
|
||||||
|
u32 i;
|
||||||
|
|
||||||
|
ACPI_FUNCTION_NAME(ns_remove_null_elements);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* PTYPE1 packages contain no subpackages.
|
||||||
|
* PTYPE2 packages contain a variable number of sub-packages. We can
|
||||||
|
* safely remove all NULL elements from the PTYPE2 packages.
|
||||||
|
*/
|
||||||
|
switch (package_type) {
|
||||||
|
case ACPI_PTYPE1_FIXED:
|
||||||
|
case ACPI_PTYPE1_VAR:
|
||||||
|
case ACPI_PTYPE1_OPTION:
|
||||||
|
return;
|
||||||
|
|
||||||
|
case ACPI_PTYPE2:
|
||||||
|
case ACPI_PTYPE2_COUNT:
|
||||||
|
case ACPI_PTYPE2_PKG_COUNT:
|
||||||
|
case ACPI_PTYPE2_FIXED:
|
||||||
|
case ACPI_PTYPE2_MIN:
|
||||||
|
case ACPI_PTYPE2_REV_FIXED:
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
count = obj_desc->package.count;
|
||||||
|
new_count = count;
|
||||||
|
|
||||||
|
source = obj_desc->package.elements;
|
||||||
|
dest = source;
|
||||||
|
|
||||||
|
/* Examine all elements of the package object, remove nulls */
|
||||||
|
|
||||||
|
for (i = 0; i < count; i++) {
|
||||||
|
if (!*source) {
|
||||||
|
new_count--;
|
||||||
|
} else {
|
||||||
|
*dest = *source;
|
||||||
|
dest++;
|
||||||
|
}
|
||||||
|
source++;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Update parent package if any null elements were removed */
|
||||||
|
|
||||||
|
if (new_count < count) {
|
||||||
|
ACPI_DEBUG_PRINT((ACPI_DB_REPAIR,
|
||||||
|
"%s: Found and removed %u NULL elements\n",
|
||||||
|
data->pathname, (count - new_count)));
|
||||||
|
|
||||||
|
/* NULL terminate list and update the package count */
|
||||||
|
|
||||||
|
*dest = NULL;
|
||||||
|
obj_desc->package.count = new_count;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/*******************************************************************************
|
/*******************************************************************************
|
||||||
*
|
*
|
||||||
* FUNCTION: acpi_ns_repair_package_list
|
* FUNCTION: acpi_ns_repair_package_list
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2009, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
@ -45,7 +45,6 @@
|
||||||
#include <acpi/acpi.h>
|
#include <acpi/acpi.h>
|
||||||
#include "accommon.h"
|
#include "accommon.h"
|
||||||
#include "acnamesp.h"
|
#include "acnamesp.h"
|
||||||
#include "acpredef.h"
|
|
||||||
|
|
||||||
#define _COMPONENT ACPI_NAMESPACE
|
#define _COMPONENT ACPI_NAMESPACE
|
||||||
ACPI_MODULE_NAME("nsrepair2")
|
ACPI_MODULE_NAME("nsrepair2")
|
||||||
|
@ -93,7 +92,7 @@ acpi_ns_check_sorted_list(struct acpi_predefined_data *data,
|
||||||
u32 sort_index,
|
u32 sort_index,
|
||||||
u8 sort_direction, char *sort_key_name);
|
u8 sort_direction, char *sort_key_name);
|
||||||
|
|
||||||
static acpi_status
|
static void
|
||||||
acpi_ns_sort_list(union acpi_operand_object **elements,
|
acpi_ns_sort_list(union acpi_operand_object **elements,
|
||||||
u32 count, u32 index, u8 sort_direction);
|
u32 count, u32 index, u8 sort_direction);
|
||||||
|
|
||||||
|
@ -443,7 +442,6 @@ acpi_ns_check_sorted_list(struct acpi_predefined_data *data,
|
||||||
union acpi_operand_object *obj_desc;
|
union acpi_operand_object *obj_desc;
|
||||||
u32 i;
|
u32 i;
|
||||||
u32 previous_value;
|
u32 previous_value;
|
||||||
acpi_status status;
|
|
||||||
|
|
||||||
ACPI_FUNCTION_NAME(ns_check_sorted_list);
|
ACPI_FUNCTION_NAME(ns_check_sorted_list);
|
||||||
|
|
||||||
|
@ -494,19 +492,15 @@ acpi_ns_check_sorted_list(struct acpi_predefined_data *data,
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* The list must be sorted in the specified order. If we detect a
|
* The list must be sorted in the specified order. If we detect a
|
||||||
* discrepancy, issue a warning and sort the entire list
|
* discrepancy, sort the entire list.
|
||||||
*/
|
*/
|
||||||
if (((sort_direction == ACPI_SORT_ASCENDING) &&
|
if (((sort_direction == ACPI_SORT_ASCENDING) &&
|
||||||
(obj_desc->integer.value < previous_value)) ||
|
(obj_desc->integer.value < previous_value)) ||
|
||||||
((sort_direction == ACPI_SORT_DESCENDING) &&
|
((sort_direction == ACPI_SORT_DESCENDING) &&
|
||||||
(obj_desc->integer.value > previous_value))) {
|
(obj_desc->integer.value > previous_value))) {
|
||||||
status =
|
acpi_ns_sort_list(return_object->package.elements,
|
||||||
acpi_ns_sort_list(return_object->package.elements,
|
outer_element_count, sort_index,
|
||||||
outer_element_count, sort_index,
|
sort_direction);
|
||||||
sort_direction);
|
|
||||||
if (ACPI_FAILURE(status)) {
|
|
||||||
return (status);
|
|
||||||
}
|
|
||||||
|
|
||||||
data->flags |= ACPI_OBJECT_REPAIRED;
|
data->flags |= ACPI_OBJECT_REPAIRED;
|
||||||
|
|
||||||
|
@ -523,89 +517,6 @@ acpi_ns_check_sorted_list(struct acpi_predefined_data *data,
|
||||||
return (AE_OK);
|
return (AE_OK);
|
||||||
}
|
}
|
||||||
|
|
||||||
/******************************************************************************
|
|
||||||
*
|
|
||||||
* FUNCTION: acpi_ns_remove_null_elements
|
|
||||||
*
|
|
||||||
* PARAMETERS: Data - Pointer to validation data structure
|
|
||||||
* package_type - An acpi_return_package_types value
|
|
||||||
* obj_desc - A Package object
|
|
||||||
*
|
|
||||||
* RETURN: None.
|
|
||||||
*
|
|
||||||
* DESCRIPTION: Remove all NULL package elements from packages that contain
|
|
||||||
* a variable number of sub-packages.
|
|
||||||
*
|
|
||||||
*****************************************************************************/
|
|
||||||
|
|
||||||
void
|
|
||||||
acpi_ns_remove_null_elements(struct acpi_predefined_data *data,
|
|
||||||
u8 package_type,
|
|
||||||
union acpi_operand_object *obj_desc)
|
|
||||||
{
|
|
||||||
union acpi_operand_object **source;
|
|
||||||
union acpi_operand_object **dest;
|
|
||||||
u32 count;
|
|
||||||
u32 new_count;
|
|
||||||
u32 i;
|
|
||||||
|
|
||||||
ACPI_FUNCTION_NAME(ns_remove_null_elements);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* PTYPE1 packages contain no subpackages.
|
|
||||||
* PTYPE2 packages contain a variable number of sub-packages. We can
|
|
||||||
* safely remove all NULL elements from the PTYPE2 packages.
|
|
||||||
*/
|
|
||||||
switch (package_type) {
|
|
||||||
case ACPI_PTYPE1_FIXED:
|
|
||||||
case ACPI_PTYPE1_VAR:
|
|
||||||
case ACPI_PTYPE1_OPTION:
|
|
||||||
return;
|
|
||||||
|
|
||||||
case ACPI_PTYPE2:
|
|
||||||
case ACPI_PTYPE2_COUNT:
|
|
||||||
case ACPI_PTYPE2_PKG_COUNT:
|
|
||||||
case ACPI_PTYPE2_FIXED:
|
|
||||||
case ACPI_PTYPE2_MIN:
|
|
||||||
case ACPI_PTYPE2_REV_FIXED:
|
|
||||||
break;
|
|
||||||
|
|
||||||
default:
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
count = obj_desc->package.count;
|
|
||||||
new_count = count;
|
|
||||||
|
|
||||||
source = obj_desc->package.elements;
|
|
||||||
dest = source;
|
|
||||||
|
|
||||||
/* Examine all elements of the package object, remove nulls */
|
|
||||||
|
|
||||||
for (i = 0; i < count; i++) {
|
|
||||||
if (!*source) {
|
|
||||||
new_count--;
|
|
||||||
} else {
|
|
||||||
*dest = *source;
|
|
||||||
dest++;
|
|
||||||
}
|
|
||||||
source++;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Update parent package if any null elements were removed */
|
|
||||||
|
|
||||||
if (new_count < count) {
|
|
||||||
ACPI_DEBUG_PRINT((ACPI_DB_REPAIR,
|
|
||||||
"%s: Found and removed %u NULL elements\n",
|
|
||||||
data->pathname, (count - new_count)));
|
|
||||||
|
|
||||||
/* NULL terminate list and update the package count */
|
|
||||||
|
|
||||||
*dest = NULL;
|
|
||||||
obj_desc->package.count = new_count;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/******************************************************************************
|
/******************************************************************************
|
||||||
*
|
*
|
||||||
* FUNCTION: acpi_ns_sort_list
|
* FUNCTION: acpi_ns_sort_list
|
||||||
|
@ -615,15 +526,16 @@ acpi_ns_remove_null_elements(struct acpi_predefined_data *data,
|
||||||
* Index - Sort by which package element
|
* Index - Sort by which package element
|
||||||
* sort_direction - Ascending or Descending sort
|
* sort_direction - Ascending or Descending sort
|
||||||
*
|
*
|
||||||
* RETURN: Status
|
* RETURN: None
|
||||||
*
|
*
|
||||||
* DESCRIPTION: Sort the objects that are in a package element list.
|
* DESCRIPTION: Sort the objects that are in a package element list.
|
||||||
*
|
*
|
||||||
* NOTE: Assumes that all NULL elements have been removed from the package.
|
* NOTE: Assumes that all NULL elements have been removed from the package,
|
||||||
|
* and that all elements have been verified to be of type Integer.
|
||||||
*
|
*
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
static acpi_status
|
static void
|
||||||
acpi_ns_sort_list(union acpi_operand_object **elements,
|
acpi_ns_sort_list(union acpi_operand_object **elements,
|
||||||
u32 count, u32 index, u8 sort_direction)
|
u32 count, u32 index, u8 sort_direction)
|
||||||
{
|
{
|
||||||
|
@ -652,6 +564,4 @@ acpi_ns_sort_list(union acpi_operand_object **elements,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return (AE_OK);
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
******************************************************************************/
|
******************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
******************************************************************************/
|
******************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
@ -562,25 +562,20 @@ acpi_ns_get_device_callback(acpi_handle obj_handle,
|
||||||
return (AE_BAD_PARAMETER);
|
return (AE_BAD_PARAMETER);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Run _STA to determine if device is present */
|
/*
|
||||||
|
* First, filter based on the device HID and CID.
|
||||||
status = acpi_ut_execute_STA(node, &flags);
|
*
|
||||||
if (ACPI_FAILURE(status)) {
|
* 01/2010: For this case where a specific HID is requested, we don't
|
||||||
return (AE_CTRL_DEPTH);
|
* want to run _STA until we have an actual HID match. Thus, we will
|
||||||
}
|
* not unnecessarily execute _STA on devices for which the caller
|
||||||
|
* doesn't care about. Previously, _STA was executed unconditionally
|
||||||
if (!(flags & ACPI_STA_DEVICE_PRESENT) &&
|
* on all devices found here.
|
||||||
!(flags & ACPI_STA_DEVICE_FUNCTIONING)) {
|
*
|
||||||
/*
|
* A side-effect of this change is that now we will continue to search
|
||||||
* Don't examine the children of the device only when the
|
* for a matching HID even under device trees where the parent device
|
||||||
* device is neither present nor functional. See ACPI spec,
|
* would have returned a _STA that indicates it is not present or
|
||||||
* description of _STA for more information.
|
* not functioning (thus aborting the search on that branch).
|
||||||
*/
|
*/
|
||||||
return (AE_CTRL_DEPTH);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Filter based on device HID & CID */
|
|
||||||
|
|
||||||
if (info->hid != NULL) {
|
if (info->hid != NULL) {
|
||||||
status = acpi_ut_execute_HID(node, &hid);
|
status = acpi_ut_execute_HID(node, &hid);
|
||||||
if (status == AE_NOT_FOUND) {
|
if (status == AE_NOT_FOUND) {
|
||||||
|
@ -620,6 +615,25 @@ acpi_ns_get_device_callback(acpi_handle obj_handle,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Run _STA to determine if device is present */
|
||||||
|
|
||||||
|
status = acpi_ut_execute_STA(node, &flags);
|
||||||
|
if (ACPI_FAILURE(status)) {
|
||||||
|
return (AE_CTRL_DEPTH);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!(flags & ACPI_STA_DEVICE_PRESENT) &&
|
||||||
|
!(flags & ACPI_STA_DEVICE_FUNCTIONING)) {
|
||||||
|
/*
|
||||||
|
* Don't examine the children of the device only when the
|
||||||
|
* device is neither present nor functional. See ACPI spec,
|
||||||
|
* description of _STA for more information.
|
||||||
|
*/
|
||||||
|
return (AE_CTRL_DEPTH);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* We have a valid device, invoke the user function */
|
||||||
|
|
||||||
status = info->user_function(obj_handle, nesting_level, info->context,
|
status = info->user_function(obj_handle, nesting_level, info->context,
|
||||||
return_value);
|
return_value);
|
||||||
return (status);
|
return (status);
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
******************************************************************************/
|
******************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
@ -403,7 +403,7 @@ acpi_ps_get_next_simple_arg(struct acpi_parse_state *parser_state,
|
||||||
/* Get 1 byte from the AML stream */
|
/* Get 1 byte from the AML stream */
|
||||||
|
|
||||||
opcode = AML_BYTE_OP;
|
opcode = AML_BYTE_OP;
|
||||||
arg->common.value.integer = (acpi_integer) * aml;
|
arg->common.value.integer = (u64) *aml;
|
||||||
length = 1;
|
length = 1;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2000 - 2008, Intel Corp.
|
* Copyright (C) 2000 - 2010, Intel Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|
Some files were not shown because too many files have changed in this diff Show more
Loading…
Reference in a new issue