aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorLv Zheng <lv.zheng@intel.com>2016-05-05 00:58:45 -0400
committerRafael J. Wysocki <rafael.j.wysocki@intel.com>2016-05-05 09:22:27 -0400
commit9222aa8234d9f07a70e815ddd3b44a97d673aff5 (patch)
treeb0b8f78a412d8023d28b4f81319894a6aa0d7cb0
parentb314a172ee968d45f72dffea68ab8af38aa80ded (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.h12
-rw-r--r--drivers/acpi/acpica/exfldio.c12
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