diff options
author | Felix Fietkau <nbd@openwrt.org> | 2015-11-18 00:57:22 +0000 |
---|---|---|
committer | Felix Fietkau <nbd@openwrt.org> | 2015-11-18 00:57:22 +0000 |
commit | a357c33469b0d6dd4f78e5e45195fbca9af05a0f (patch) | |
tree | 9a336a46861372541ee65d3f01c0b6e88edcd592 /toolchain | |
parent | 4f2f5aa55aef252877199df18379747cfccbde2d (diff) | |
download | master-187ad058-a357c33469b0d6dd4f78e5e45195fbca9af05a0f.tar.gz master-187ad058-a357c33469b0d6dd4f78e5e45195fbca9af05a0f.tar.bz2 master-187ad058-a357c33469b0d6dd4f78e5e45195fbca9af05a0f.zip |
gcc: fix internal compiler error on MIPS with MIPS16 enabled (triggered by libpcap)
Signed-off-by: Felix Fietkau <nbd@openwrt.org>
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@47494 3c298f89-4303-0410-b956-a3cf2f4a3e73
Diffstat (limited to 'toolchain')
-rw-r--r-- | toolchain/gcc/patches/5.2.0/040-fix-mips-ICE-PR-68400.patch | 23 | ||||
-rw-r--r-- | toolchain/gcc/patches/5.2.0/930-fix-mips-noexecstack.patch | 2 |
2 files changed, 24 insertions, 1 deletions
diff --git a/toolchain/gcc/patches/5.2.0/040-fix-mips-ICE-PR-68400.patch b/toolchain/gcc/patches/5.2.0/040-fix-mips-ICE-PR-68400.patch new file mode 100644 index 0000000000..e88af34032 --- /dev/null +++ b/toolchain/gcc/patches/5.2.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 diff --git a/toolchain/gcc/patches/5.2.0/930-fix-mips-noexecstack.patch b/toolchain/gcc/patches/5.2.0/930-fix-mips-noexecstack.patch index 4bb126eb99..c05844d2e4 100644 --- a/toolchain/gcc/patches/5.2.0/930-fix-mips-noexecstack.patch +++ b/toolchain/gcc/patches/5.2.0/930-fix-mips-noexecstack.patch @@ -48,7 +48,7 @@ sellcey@mips.com --- a/gcc/config/mips/mips.c +++ b/gcc/config/mips/mips.c -@@ -19621,6 +19621,9 @@ mips_lra_p (void) +@@ -19629,6 +19629,9 @@ mips_lra_p (void) #undef TARGET_LRA_P #define TARGET_LRA_P mips_lra_p |