diff options
author | Lv Zheng <lv.zheng@intel.com> | 2016-05-05 00:58:45 -0400 |
---|---|---|
committer | Rafael J. Wysocki <rafael.j.wysocki@intel.com> | 2016-05-05 09:22:27 -0400 |
commit | 9222aa8234d9f07a70e815ddd3b44a97d673aff5 (patch) | |
tree | b0b8f78a412d8023d28b4f81319894a6aa0d7cb0 | |
parent | b314a172ee968d45f72dffea68ab8af38aa80ded (diff) |
ACPICA: Executer: Introduce a set of macros to handle bit width mask generation
ACPICA commit c23034a3a09d5ed79f1827d51f43cfbccf68ab64
A regression was reported to the shift offset >= width of type.
This patch fixes this issue. BZ 1270.
This is a part of the fix because the order of the patches are modified for
Linux upstream, containing the cleanups for the old code. Lv Zheng.
Link: https://github.com/acpica/acpica/commit/c23034a3
Link: https://bugs.acpica.org/show_bug.cgi?id=1270
Reported-by: Sascha Wildner <swildner@gmail.com>
Signed-off-by: Lv Zheng <lv.zheng@intel.com>
Signed-off-by: Bob Moore <robert.moore@intel.com>
Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
-rw-r--r-- | drivers/acpi/acpica/acmacros.h | 12 | ||||
-rw-r--r-- | drivers/acpi/acpica/exfldio.c | 12 |
2 files changed, 14 insertions, 10 deletions
diff --git a/drivers/acpi/acpica/acmacros.h b/drivers/acpi/acpica/acmacros.h index ecbaabae59e7..a3b95431b7c5 100644 --- a/drivers/acpi/acpica/acmacros.h +++ b/drivers/acpi/acpica/acmacros.h | |||
@@ -270,9 +270,21 @@ | |||
270 | * Bit positions start at zero. | 270 | * Bit positions start at zero. |
271 | * MASK_BITS_ABOVE creates a mask starting AT the position and above | 271 | * MASK_BITS_ABOVE creates a mask starting AT the position and above |
272 | * MASK_BITS_BELOW creates a mask starting one bit BELOW the position | 272 | * MASK_BITS_BELOW creates a mask starting one bit BELOW the position |
273 | * MASK_BITS_ABOVE/BELOW accpets a bit offset to create a mask | ||
274 | * MASK_BITS_ABOVE/BELOW_32/64 accpets a bit width to create a mask | ||
275 | * Note: The ACPI_INTEGER_BIT_SIZE check is used to bypass compiler | ||
276 | * differences with the shift operator | ||
273 | */ | 277 | */ |
274 | #define ACPI_MASK_BITS_ABOVE(position) (~((ACPI_UINT64_MAX) << ((u32) (position)))) | 278 | #define ACPI_MASK_BITS_ABOVE(position) (~((ACPI_UINT64_MAX) << ((u32) (position)))) |
275 | #define ACPI_MASK_BITS_BELOW(position) ((ACPI_UINT64_MAX) << ((u32) (position))) | 279 | #define ACPI_MASK_BITS_BELOW(position) ((ACPI_UINT64_MAX) << ((u32) (position))) |
280 | #define ACPI_MASK_BITS_ABOVE_32(width) ((u32) ACPI_MASK_BITS_ABOVE(width)) | ||
281 | #define ACPI_MASK_BITS_BELOW_32(width) ((u32) ACPI_MASK_BITS_BELOW(width)) | ||
282 | #define ACPI_MASK_BITS_ABOVE_64(width) ((width) == ACPI_INTEGER_BIT_SIZE ? \ | ||
283 | ACPI_UINT64_MAX : \ | ||
284 | ACPI_MASK_BITS_ABOVE(width)) | ||
285 | #define ACPI_MASK_BITS_BELOW_64(width) ((width) == ACPI_INTEGER_BIT_SIZE ? \ | ||
286 | (u64) 0 : \ | ||
287 | ACPI_MASK_BITS_BELOW(width)) | ||
276 | 288 | ||
277 | /* Bitfields within ACPI registers */ | 289 | /* Bitfields within ACPI registers */ |
278 | 290 | ||
diff --git a/drivers/acpi/acpica/exfldio.c b/drivers/acpi/acpica/exfldio.c index 72f917618578..ee76d299b3d0 100644 --- a/drivers/acpi/acpica/exfldio.c +++ b/drivers/acpi/acpica/exfldio.c | |||
@@ -897,17 +897,9 @@ acpi_ex_insert_into_field(union acpi_operand_object *obj_desc, | |||
897 | 897 | ||
898 | access_bit_width = ACPI_MUL_8(obj_desc->common_field.access_byte_width); | 898 | access_bit_width = ACPI_MUL_8(obj_desc->common_field.access_byte_width); |
899 | 899 | ||
900 | /* | 900 | /* Create the bitmasks used for bit insertion */ |
901 | * Create the bitmasks used for bit insertion. | ||
902 | * Note: This if/else is used to bypass compiler differences with the | ||
903 | * shift operator | ||
904 | */ | ||
905 | if (access_bit_width == ACPI_INTEGER_BIT_SIZE) { | ||
906 | width_mask = ACPI_UINT64_MAX; | ||
907 | } else { | ||
908 | width_mask = ACPI_MASK_BITS_ABOVE(access_bit_width); | ||
909 | } | ||
910 | 901 | ||
902 | width_mask = ACPI_MASK_BITS_ABOVE_64(access_bit_width); | ||
911 | mask = width_mask & | 903 | mask = width_mask & |
912 | ACPI_MASK_BITS_BELOW(obj_desc->common_field.start_field_bit_offset); | 904 | ACPI_MASK_BITS_BELOW(obj_desc->common_field.start_field_bit_offset); |
913 | 905 | ||