summaryrefslogtreecommitdiffstats
path: root/toolchain/gcc/patches/5.4.0/040-fix-mips-ICE-PR-68400.patch
blob: e88af34032513b7df2aa58d2fc3108f9afabf3ec (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
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