From 100d81d443fd03ca6450907bf3eaa559b66a4801 Mon Sep 17 00:00:00 2001 From: Jason Merrill <jason@yorick.cygnus.com> Date: Fri, 12 Dec 1997 09:23:52 +0000 Subject: [PATCH] except.c (call_get_eh_context): Don't mess with sequences. * except.c (call_get_eh_context): Don't mess with sequences. (emit_eh_context): Include the call in the sequence here. From-SVN: r17070 --- gcc/ChangeLog | 5 +++++ gcc/except.c | 20 +++++--------------- 2 files changed, 10 insertions(+), 15 deletions(-) diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 87793b7d0454..dcac2906451d 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,8 @@ +Fri Dec 12 01:19:48 1997 Jason Merrill <jason@yorick.cygnus.com> + + * except.c (call_get_eh_context): Don't mess with sequences. + (emit_eh_context): Include the call in the sequence here. + 1997-12-11 Paul Eggert <eggert@twinsun.com> * collect2.c (write_c_file_glob): Allocate initial frame object diff --git a/gcc/except.c b/gcc/except.c index 95f8b2ceb994..dbba31b445be 100644 --- a/gcc/except.c +++ b/gcc/except.c @@ -707,15 +707,13 @@ add_partial_entry (handler) pop_obstacks (); } -/* Emit code to get EH context to current function. Should only be used - by emit_eh_context. */ +/* Emit code to get EH context to current function. */ static rtx call_get_eh_context () { static tree fn; tree expr; - rtx ehc, reg, insns; if (fn == NULL_TREE) { @@ -741,16 +739,7 @@ call_get_eh_context () expr, NULL_TREE, NULL_TREE); TREE_SIDE_EFFECTS (expr) = 1; - start_sequence (); - ehc = expand_expr (expr, NULL_RTX, VOIDmode, 0); - reg = copy_to_reg (ehc); - - insns = get_insns (); - end_sequence (); - - emit_insns_before (insns, get_first_nonparm_insn ()); - - return reg; + return copy_to_reg (expand_expr (expr, NULL_RTX, VOIDmode, 0)); } /* Get a reference to the EH context. @@ -1678,11 +1667,12 @@ emit_eh_context () { rtx insns; - /* If this is the first use insn, emit the call. */ + start_sequence (); + + /* If this is the first use insn, emit the call here. */ if (ehc == 0) ehc = call_get_eh_context (); - start_sequence (); emit_move_insn (XEXP (reg, 0), ehc); insns = get_insns (); end_sequence (); -- GitLab