mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2025-01-19 12:24:34 +08:00
ACPICA: Fix for implicit result conversion for the ToXXX functions
ACPICA commit e1342c9f2dde37a67e916099658b65984ef8a434 Implicit result conversion was incorrectly disabled for the following functions: FromBCD ToBCD ToDecimalString ToHexString ToInteger ToBuffer Link: https://github.com/acpica/acpica/commit/e1342c9f Signed-off-by: Bob Moore <robert.moore@intel.com> Signed-off-by: Lv Zheng <lv.zheng@intel.com> Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
This commit is contained in:
parent
57707a9a77
commit
74e30f96ad
@ -249,7 +249,7 @@
|
|||||||
#define ARGI_FIELD_OP ARGI_INVALID_OPCODE
|
#define ARGI_FIELD_OP ARGI_INVALID_OPCODE
|
||||||
#define ARGI_FIND_SET_LEFT_BIT_OP ARGI_LIST2 (ARGI_INTEGER, ARGI_TARGETREF)
|
#define ARGI_FIND_SET_LEFT_BIT_OP ARGI_LIST2 (ARGI_INTEGER, ARGI_TARGETREF)
|
||||||
#define ARGI_FIND_SET_RIGHT_BIT_OP ARGI_LIST2 (ARGI_INTEGER, ARGI_TARGETREF)
|
#define ARGI_FIND_SET_RIGHT_BIT_OP ARGI_LIST2 (ARGI_INTEGER, ARGI_TARGETREF)
|
||||||
#define ARGI_FROM_BCD_OP ARGI_LIST2 (ARGI_INTEGER, ARGI_FIXED_TARGET)
|
#define ARGI_FROM_BCD_OP ARGI_LIST2 (ARGI_INTEGER, ARGI_TARGETREF)
|
||||||
#define ARGI_IF_OP ARGI_INVALID_OPCODE
|
#define ARGI_IF_OP ARGI_INVALID_OPCODE
|
||||||
#define ARGI_INCREMENT_OP ARGI_LIST1 (ARGI_TARGETREF)
|
#define ARGI_INCREMENT_OP ARGI_LIST1 (ARGI_TARGETREF)
|
||||||
#define ARGI_INDEX_FIELD_OP ARGI_INVALID_OPCODE
|
#define ARGI_INDEX_FIELD_OP ARGI_INVALID_OPCODE
|
||||||
@ -313,12 +313,12 @@
|
|||||||
#define ARGI_SUBTRACT_OP ARGI_LIST3 (ARGI_INTEGER, ARGI_INTEGER, ARGI_TARGETREF)
|
#define ARGI_SUBTRACT_OP ARGI_LIST3 (ARGI_INTEGER, ARGI_INTEGER, ARGI_TARGETREF)
|
||||||
#define ARGI_THERMAL_ZONE_OP ARGI_INVALID_OPCODE
|
#define ARGI_THERMAL_ZONE_OP ARGI_INVALID_OPCODE
|
||||||
#define ARGI_TIMER_OP ARG_NONE
|
#define ARGI_TIMER_OP ARG_NONE
|
||||||
#define ARGI_TO_BCD_OP ARGI_LIST2 (ARGI_INTEGER, ARGI_FIXED_TARGET)
|
#define ARGI_TO_BCD_OP ARGI_LIST2 (ARGI_INTEGER, ARGI_TARGETREF)
|
||||||
#define ARGI_TO_BUFFER_OP ARGI_LIST2 (ARGI_COMPUTEDATA,ARGI_FIXED_TARGET)
|
#define ARGI_TO_BUFFER_OP ARGI_LIST2 (ARGI_COMPUTEDATA,ARGI_TARGETREF)
|
||||||
#define ARGI_TO_DEC_STR_OP ARGI_LIST2 (ARGI_COMPUTEDATA,ARGI_FIXED_TARGET)
|
#define ARGI_TO_DEC_STR_OP ARGI_LIST2 (ARGI_COMPUTEDATA,ARGI_TARGETREF)
|
||||||
#define ARGI_TO_HEX_STR_OP ARGI_LIST2 (ARGI_COMPUTEDATA,ARGI_FIXED_TARGET)
|
#define ARGI_TO_HEX_STR_OP ARGI_LIST2 (ARGI_COMPUTEDATA,ARGI_TARGETREF)
|
||||||
#define ARGI_TO_INTEGER_OP ARGI_LIST2 (ARGI_COMPUTEDATA,ARGI_FIXED_TARGET)
|
#define ARGI_TO_INTEGER_OP ARGI_LIST2 (ARGI_COMPUTEDATA,ARGI_TARGETREF)
|
||||||
#define ARGI_TO_STRING_OP ARGI_LIST3 (ARGI_BUFFER, ARGI_INTEGER, ARGI_FIXED_TARGET)
|
#define ARGI_TO_STRING_OP ARGI_LIST3 (ARGI_BUFFER, ARGI_INTEGER, ARGI_TARGETREF)
|
||||||
#define ARGI_UNLOAD_OP ARGI_LIST1 (ARGI_DDBHANDLE)
|
#define ARGI_UNLOAD_OP ARGI_LIST1 (ARGI_DDBHANDLE)
|
||||||
#define ARGI_VAR_PACKAGE_OP ARGI_LIST1 (ARGI_INTEGER)
|
#define ARGI_VAR_PACKAGE_OP ARGI_LIST1 (ARGI_INTEGER)
|
||||||
#define ARGI_WAIT_OP ARGI_LIST2 (ARGI_EVENT, ARGI_INTEGER)
|
#define ARGI_WAIT_OP ARGI_LIST2 (ARGI_EVENT, ARGI_INTEGER)
|
||||||
|
@ -277,9 +277,23 @@
|
|||||||
#define ARGI_DEVICE_REF 0x0D
|
#define ARGI_DEVICE_REF 0x0D
|
||||||
#define ARGI_REFERENCE 0x0E
|
#define ARGI_REFERENCE 0x0E
|
||||||
#define ARGI_TARGETREF 0x0F /* Target, subject to implicit conversion */
|
#define ARGI_TARGETREF 0x0F /* Target, subject to implicit conversion */
|
||||||
#define ARGI_FIXED_TARGET 0x10 /* Target, no implicit conversion */
|
#define ARGI_SIMPLE_TARGET 0x10 /* Name, Local, Arg -- no implicit conversion */
|
||||||
#define ARGI_SIMPLE_TARGET 0x11 /* Name, Local, Arg -- no implicit conversion */
|
#define ARGI_STORE_TARGET 0x11 /* Target for store is TARGETREF + package objects */
|
||||||
#define ARGI_STORE_TARGET 0x12 /* Target for store is TARGETREF + package objects */
|
/*
|
||||||
|
* #define ARGI_FIXED_TARGET 0x10 Target, no implicit conversion
|
||||||
|
*
|
||||||
|
* Removed 10/2016. ARGI_FIXED_TARGET was used for these operators:
|
||||||
|
* from_BCD
|
||||||
|
* to_BCD
|
||||||
|
* to_decimal_string
|
||||||
|
* to_hex_string
|
||||||
|
* to_integer
|
||||||
|
* to_buffer
|
||||||
|
* The purpose of this type was to disable "implicit result conversion",
|
||||||
|
* but this was incorrect per the ACPI spec and other ACPI implementations.
|
||||||
|
* These operators now have the target operand defined as a normal
|
||||||
|
* ARGI_TARGETREF.
|
||||||
|
*/
|
||||||
|
|
||||||
/* Multiple/complex types */
|
/* Multiple/complex types */
|
||||||
|
|
||||||
|
@ -592,7 +592,6 @@ acpi_ex_convert_to_target_type(acpi_object_type destination_type,
|
|||||||
*/
|
*/
|
||||||
switch (GET_CURRENT_ARG_TYPE(walk_state->op_info->runtime_args)) {
|
switch (GET_CURRENT_ARG_TYPE(walk_state->op_info->runtime_args)) {
|
||||||
case ARGI_SIMPLE_TARGET:
|
case ARGI_SIMPLE_TARGET:
|
||||||
case ARGI_FIXED_TARGET:
|
|
||||||
case ARGI_INTEGER_REF: /* Handles Increment, Decrement cases */
|
case ARGI_INTEGER_REF: /* Handles Increment, Decrement cases */
|
||||||
|
|
||||||
switch (destination_type) {
|
switch (destination_type) {
|
||||||
|
@ -305,7 +305,6 @@ acpi_ex_resolve_operands(u16 opcode,
|
|||||||
case ARGI_OBJECT_REF:
|
case ARGI_OBJECT_REF:
|
||||||
case ARGI_DEVICE_REF:
|
case ARGI_DEVICE_REF:
|
||||||
case ARGI_TARGETREF: /* Allows implicit conversion rules before store */
|
case ARGI_TARGETREF: /* Allows implicit conversion rules before store */
|
||||||
case ARGI_FIXED_TARGET: /* No implicit conversion before store to target */
|
|
||||||
case ARGI_SIMPLE_TARGET: /* Name, Local, or arg - no implicit conversion */
|
case ARGI_SIMPLE_TARGET: /* Name, Local, or arg - no implicit conversion */
|
||||||
case ARGI_STORE_TARGET:
|
case ARGI_STORE_TARGET:
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user