diff options
author | Hauke Mehrtens <hauke@hauke-m.de> | 2016-07-13 12:19:42 +0200 |
---|---|---|
committer | Hauke Mehrtens <hauke@hauke-m.de> | 2016-07-13 23:04:18 +0200 |
commit | 2d3917d5b58281a6f440d57c7ededd43fb82f166 (patch) | |
tree | 68b34e5d33b5d704d2327872fb1712f5e783f8f9 /toolchain/gcc/patches/5.4.0/040-fix-mips-ICE-PR-68400.patch | |
parent | 05cc72944c29300f7af29ea364063b0f24c42e18 (diff) | |
download | upstream-2d3917d5b58281a6f440d57c7ededd43fb82f166.tar.gz upstream-2d3917d5b58281a6f440d57c7ededd43fb82f166.tar.bz2 upstream-2d3917d5b58281a6f440d57c7ededd43fb82f166.zip |
gcc: update gcc to version 5.4.0
The removed patches are already integrated in upstream gcc.
Signed-off-by: Hauke Mehrtens <hauke@hauke-m.de>
Diffstat (limited to 'toolchain/gcc/patches/5.4.0/040-fix-mips-ICE-PR-68400.patch')
-rw-r--r-- | toolchain/gcc/patches/5.4.0/040-fix-mips-ICE-PR-68400.patch | 23 |
1 files changed, 23 insertions, 0 deletions
diff --git a/toolchain/gcc/patches/5.4.0/040-fix-mips-ICE-PR-68400.patch b/toolchain/gcc/patches/5.4.0/040-fix-mips-ICE-PR-68400.patch new file mode 100644 index 0000000000..e88af34032 --- /dev/null +++ b/toolchain/gcc/patches/5.4.0/040-fix-mips-ICE-PR-68400.patch @@ -0,0 +1,23 @@ +--- a/gcc/config/mips/mips.c ++++ b/gcc/config/mips/mips.c +@@ -8001,9 +8001,17 @@ mask_low_and_shift_p (machine_mode mode, + bool + and_operands_ok (machine_mode mode, rtx op1, rtx op2) + { +- return (memory_operand (op1, mode) +- ? and_load_operand (op2, mode) +- : and_reg_operand (op2, mode)); ++ if (!memory_operand (op1, mode)) ++ return and_reg_operand (op2, mode); ++ ++ if (!and_load_operand (op2, mode)) ++ return false; ++ ++ if (!TARGET_MIPS16 || si_mask_operand(op2, mode)) ++ return true; ++ ++ op1 = XEXP (op1, 0); ++ return !(REG_P (op1) && REGNO (op1) == STACK_POINTER_REGNUM); + } + + /* The canonical form of a mask-low-and-shift-left operation is |