summaryrefslogtreecommitdiff
path: root/gnu/egcs/gcc/integrate.c
diff options
context:
space:
mode:
authorMarc Espie <espie@cvs.openbsd.org>2000-09-25 00:33:17 +0000
committerMarc Espie <espie@cvs.openbsd.org>2000-09-25 00:33:17 +0000
commitca0303bd93ded42cd3c56ff95dd955ade41e415f (patch)
tree53555906d21e7433708b18165e2c0029a0751e03 /gnu/egcs/gcc/integrate.c
parent8a7531e06b2c9ad239d5417d7937618823789374 (diff)
Patch from Alexander N. Kabaev <ak03@gte.com>
Fixes GCC GNATS PR 258 and 413.
Diffstat (limited to 'gnu/egcs/gcc/integrate.c')
-rw-r--r--gnu/egcs/gcc/integrate.c27
1 files changed, 25 insertions, 2 deletions
diff --git a/gnu/egcs/gcc/integrate.c b/gnu/egcs/gcc/integrate.c
index 33a96c40f91..4165611e480 100644
--- a/gnu/egcs/gcc/integrate.c
+++ b/gnu/egcs/gcc/integrate.c
@@ -151,6 +151,10 @@ function_cannot_inline_p (fndecl)
if (current_function_contains_functions)
return N_("function with nested functions cannot be inline");
+ if (forced_labels)
+ return
+ N_("function with label addresses used in initializers cannot inline");
+
if (current_function_cannot_inline)
return current_function_cannot_inline;
@@ -425,7 +429,8 @@ initialize_for_inline (fndecl, min_labelno, max_labelno, max_reg, copy)
arg_vector, (rtx) DECL_INITIAL (fndecl),
(rtvec) regno_reg_rtx, regno_pointer_flag,
regno_pointer_align,
- (rtvec) parm_reg_stack_loc);
+ (rtvec) parm_reg_stack_loc,
+ nonlocal_goto_handler_labels);
}
/* Subroutine for `save_for_inline{copying,nocopy}'. Finishes up the
@@ -746,6 +751,15 @@ save_for_inline_copying (fndecl)
REG_NOTES (insn_map[INSN_UID (insn)])
= copy_for_inline (REG_NOTES (insn));
+ /* Now adjust nonlocal_goto_handler_labels list */
+ copy = NULL_RTX;
+ for (insn = nonlocal_goto_handler_labels; insn ; insn = XEXP (insn, 1))
+ if (label_map[CODE_LABEL_NUMBER (XEXP (insn,0))] != NULL_RTX)
+ copy = gen_rtx_EXPR_LIST (VOIDmode,
+ label_map[CODE_LABEL_NUMBER (XEXP (insn,0))],
+ copy);
+ NONLOCAL_GOTO_LABELS_TRAN(head) = copy;
+
NEXT_INSN (last_insn) = NULL;
finish_inline (fndecl, head);
@@ -2130,6 +2144,14 @@ expand_inline_function (fndecl, parms, target, ignore, type,
REG_NOTES (map->insn_map[INSN_UID (insn)]) = tem;
}
+ /* Now copy nonlocal_goto_handler_list from the function being
+ inlined into the current list. */
+ for (insn = NONLOCAL_GOTO_LABELS_TRAN(header); insn ; insn = XEXP (insn, 1))
+ if ( map->label_map[CODE_LABEL_NUMBER (XEXP (insn,0))] != NULL_RTX)
+ nonlocal_goto_handler_labels = gen_rtx_EXPR_LIST (VOIDmode,
+ map->label_map[CODE_LABEL_NUMBER (XEXP (insn,0))],
+ nonlocal_goto_handler_labels);
+
if (local_return_label)
emit_label (local_return_label);
@@ -3402,9 +3424,10 @@ output_inline_function (fndecl)
regno_pointer_align = INLINE_REGNO_POINTER_ALIGN (head);
max_parm_reg = MAX_PARMREG (head);
parm_reg_stack_loc = (rtx *) PARMREG_STACK_LOC (head);
-
+
stack_slot_list = STACK_SLOT_LIST (head);
forced_labels = FORCED_LABELS (head);
+ nonlocal_goto_handler_labels = NONLOCAL_GOTO_LABELS (head);
if (FUNCTION_FLAGS (head) & FUNCTION_FLAGS_HAS_COMPUTED_JUMP)
current_function_has_computed_jump = 1;