aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBernd Schmidt <bernds@redhat.co.uk>2001-01-12 16:33:07 +0000
committerBernd Schmidt <bernds@gcc.gnu.org>2001-01-12 16:33:07 +0000
commit9173f5bea61c3fe5fc5bdd68168e459b56142604 (patch)
tree70584f14e5fbe28d949fec4c18f8f9553fb8e16e
parent227604b93cb2bfb858dcb80a13ace912c27df3b4 (diff)
Avoid scheduling set of frame pointer across other insns
From-SVN: r38945
-rw-r--r--gcc/ChangeLog5
-rw-r--r--gcc/expr.c7
2 files changed, 12 insertions, 0 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index a67412aec5a..9c84b0974f8 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,8 @@
+2001-01-12 Bernd Schmidt <bernds@redhat.co.uk>
+
+ * expr.c (expand_builtin_setjmp_receiver): Emit a scheduling barrier
+ as last insn.
+
2001-01-11 Bernd Schmidt <bernds@redhat.co.uk>
* version.c: Bump.
diff --git a/gcc/expr.c b/gcc/expr.c
index 3624f77b233..6499e6bc8ff 100644
--- a/gcc/expr.c
+++ b/gcc/expr.c
@@ -8664,6 +8664,13 @@ expand_builtin_setjmp_receiver (receiver_label)
{
; /* Nothing */
}
+
+ /* @@@ This is a kludge. Not all machine descriptions define a blockage
+ insn, but we must not allow the code we just generated to be reordered
+ by scheduling. Specifically, the update of the frame pointer must
+ happen immediately, not later. So emit an ASM_INPUT to act as blockage
+ insn. */
+ emit_insn (gen_rtx_ASM_INPUT (VOIDmode, ""));
}