diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 9e386f7593389b9215bf4f949bd5a04b47214e45..9006383293e17c981f5ac42f73d611940aa057dd 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2017-05-19 Segher Boessenkool <segher@kernel.crashing.org> + + * config/rs6000/rs6000.md (splitter to load of -1 and mask): Don't + use this splitter if two add or or instructions would also work for + the constant we want to generate. + 2017-05-19 Richard Biener <rguenther@suse.de> PR build/80821 diff --git a/gcc/config/rs6000/rs6000.md b/gcc/config/rs6000/rs6000.md index 26baaaf1524106764fe171355ef95c2f2bcd98dc..799d786edfedb98729add9e4e5f36257397aec66 100644 --- a/gcc/config/rs6000/rs6000.md +++ b/gcc/config/rs6000/rs6000.md @@ -8732,6 +8732,7 @@ (match_operand:DI 1 "const_int_operand"))] "TARGET_POWERPC64 && num_insns_constant (operands[1], DImode) > 1 + && !IN_RANGE (INTVAL (operands[1]), -0x80000000, 0xffffffff) && rs6000_is_valid_and_mask (operands[1], DImode)" [(set (match_dup 0) (const_int -1))