summaryrefslogtreecommitdiff
path: root/packages/gcc/gcc-4.2.3/fix-ICE-in-arm_unwind_emit_set.diff
blob: 568e15abffcad83b873ea4cf3eccfd162115feef (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
--- trunk/gcc/config/arm/arm.c	2006/09/19 13:18:27	117055
+++ trunk/gcc/config/arm/arm.c	2006/09/19 13:19:24	117056
@@ -15415,6 +15415,15 @@
 	  /* Move from sp to reg.  */
 	  asm_fprintf (asm_out_file, "\t.movsp %r\n", REGNO (e0));
 	}
+     else if (GET_CODE (e1) == PLUS
+	      && GET_CODE (XEXP (e1, 0)) == REG
+	      && REGNO (XEXP (e1, 0)) == SP_REGNUM
+	      && GET_CODE (XEXP (e1, 1)) == CONST_INT)
+	{
+	  /* Set reg to offset from sp.  */
+	  asm_fprintf (asm_out_file, "\t.movsp %r, #%d\n",
+		       REGNO (e0), (int)INTVAL(XEXP (e1, 1)));
+	}
       else
 	abort ();
       break;