+2016-06-11 Segher Boessenkool <segher@kernel.crashing.org>
+
+ PR middle-end/71310
+ * fold-const.c (optimize_bit_field_compare): Don't try to use
+ word_mode unconditionally for reading the bit field, look at
+ DECL_BIT_FIELD_REPRESENTATIVE instead.
+
2016-06-11 Kugan Vivekanandarajah <kuganv@linaro.org>
PR middle-end/71478
return 0;
}
+ /* Don't use a larger mode for reading the bit field than we will
+ use in other places accessing the bit field. */
+ machine_mode largest_mode = word_mode;
+ if (TREE_CODE (lhs) == COMPONENT_REF)
+ {
+ tree field = TREE_OPERAND (lhs, 1);
+ tree repr = DECL_BIT_FIELD_REPRESENTATIVE (field);
+ if (repr)
+ largest_mode = DECL_MODE (repr);
+ }
+
/* See if we can find a mode to refer to this field. We should be able to,
but fail if we can't. */
nmode = get_best_mode (lbitsize, lbitpos, 0, 0,
const_p ? TYPE_ALIGN (TREE_TYPE (linner))
: MIN (TYPE_ALIGN (TREE_TYPE (linner)),
TYPE_ALIGN (TREE_TYPE (rinner))),
- word_mode, false);
+ largest_mode, false);
if (nmode == VOIDmode)
return 0;
+2016-06-11 Segher Boessenkool <segher@kernel.crashing.org>
+
+ PR middle-end/71310
+ * gcc.target/powerpc/pr71310.c: New testcase.
+
2016-06-11 Kugan Vivekanandarajah <kuganv@linaro.org>
PR middle-end/71478
--- /dev/null
+/* { dg-do compile { target { powerpc*-*-* } } } */
+/* { dg-options "-O2" } */
+
+/* { dg-final { scan-assembler-not {\mld} } } */
+/* { dg-final { scan-assembler-not {\mlwz} } } */
+/* { dg-final { scan-assembler-times {\mlbz} 2 } } */
+
+struct mmu_gather {
+ long end;
+ int fullmm : 1;
+};
+
+void __tlb_reset_range(struct mmu_gather *p1)
+{
+ if (p1->fullmm)
+ p1->end = 0;
+}
+
+void tlb_gather_mmu(struct mmu_gather *p1)
+{
+ p1->fullmm = 1;
+ __tlb_reset_range(p1);
+}