From 9defc9b7ac96fd51c70aff0e452c753d1f6159b3 Mon Sep 17 00:00:00 2001 From: Richard Henderson Date: Fri, 21 Sep 2001 13:26:44 -0700 Subject: [PATCH] rtl.h (LCT_RETURNS_TWICE): New. * rtl.h (LCT_RETURNS_TWICE): New. * calls.c (emit_call_1): Set current_function_calls_setjmp for ECF_RETURNS_TWICE. (emit_library_call_value_1): Map LCT_RETURNS_TWICE to ECF_RETURNS_TWICE. * except.c (sjlj_emit_function_enter): Use LCT_RETURNS_TWICE for call to setjmp. * unwind-sjlj.c: Invent the setjmp.h declarations if inhibit_libc. * config/stormy16/stormy16.h (DONT_USE_BUILTIN_SETJMP): New. (JMP_BUF_SIZE): New. From-SVN: r45736 --- gcc/ChangeLog | 15 +++++++++++++++ gcc/calls.c | 10 ++++++++-- gcc/config/stormy16/stormy16.h | 4 ++++ gcc/except.c | 2 +- gcc/rtl.h | 3 ++- gcc/unwind-sjlj.c | 5 +++++ 6 files changed, 35 insertions(+), 4 deletions(-) diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 99fff49bf58..414effb1ef6 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,18 @@ +2001-09-21 Richard Henderson + + * rtl.h (LCT_RETURNS_TWICE): New. + * calls.c (emit_call_1): Set current_function_calls_setjmp for + ECF_RETURNS_TWICE. + (emit_library_call_value_1): Map LCT_RETURNS_TWICE + to ECF_RETURNS_TWICE. + * except.c (sjlj_emit_function_enter): Use LCT_RETURNS_TWICE for + call to setjmp. + + * unwind-sjlj.c: Invent the setjmp.h declarations if inhibit_libc. + + * config/stormy16/stormy16.h (DONT_USE_BUILTIN_SETJMP): New. + (JMP_BUF_SIZE): New. + 2001-09-21 Richard Henderson * config/stormy16/stormy16.h (REG_CLASS_FROM_LETTER): Map 'd' diff --git a/gcc/calls.c b/gcc/calls.c index f21160fa61e..f2b1bdb8a45 100644 --- a/gcc/calls.c +++ b/gcc/calls.c @@ -613,8 +613,11 @@ emit_call_1 (funexp, fndecl, funtype, stack_size, rounded_stack_size, REG_NOTES (call_insn)); if (ecf_flags & ECF_RETURNS_TWICE) - REG_NOTES (call_insn) = gen_rtx_EXPR_LIST (REG_SETJMP, const0_rtx, - REG_NOTES (call_insn)); + { + REG_NOTES (call_insn) = gen_rtx_EXPR_LIST (REG_SETJMP, const0_rtx, + REG_NOTES (call_insn)); + current_function_calls_setjmp = 1; + } SIBLING_CALL_P (call_insn) = ((ecf_flags & ECF_SIBCALL) != 0); @@ -3531,6 +3534,9 @@ emit_library_call_value_1 (retval, orgfun, value, fn_type, outmode, nargs, p) case LCT_ALWAYS_RETURN: flags = ECF_ALWAYS_RETURN; break; + case LCT_RETURNS_TWICE: + flags = ECF_RETURNS_TWICE; + break; } fun = orgfun; diff --git a/gcc/config/stormy16/stormy16.h b/gcc/config/stormy16/stormy16.h index 9a62b36cc84..b2e85fa321a 100644 --- a/gcc/config/stormy16/stormy16.h +++ b/gcc/config/stormy16/stormy16.h @@ -4537,6 +4537,10 @@ do { \ instead of inline unwinders and __unwind_function in the non-setjmp case. */ #define DWARF2_UNWIND_INFO 0 +/* Don't use __builtin_setjmp for unwinding, since it's tricky to get + at the high 16 bits of an address. */ +#define DONT_USE_BUILTIN_SETJMP +#define JMP_BUF_SIZE 8 /* Assembler Commands for Alignment. */ diff --git a/gcc/except.c b/gcc/except.c index 0f0b6621e30..4448610757a 100644 --- a/gcc/except.c +++ b/gcc/except.c @@ -2144,7 +2144,7 @@ sjlj_emit_function_enter (dispatch_label) #ifdef DONT_USE_BUILTIN_SETJMP { rtx x, note; - x = emit_library_call_value (setjmp_libfunc, NULL_RTX, LCT_NORMAL, + x = emit_library_call_value (setjmp_libfunc, NULL_RTX, LCT_RETURNS_TWICE, TYPE_MODE (integer_type_node), 1, plus_constant (XEXP (fc, 0), sjlj_fc_jbuf_ofs), Pmode); diff --git a/gcc/rtl.h b/gcc/rtl.h index 7deb964e5a3..d9b9294f33c 100644 --- a/gcc/rtl.h +++ b/gcc/rtl.h @@ -1952,7 +1952,8 @@ enum libcall_type LCT_PURE_MAKE_BLOCK = 4, LCT_NORETURN = 5, LCT_THROW = 6, - LCT_ALWAYS_RETURN = 7 + LCT_ALWAYS_RETURN = 7, + LCT_RETURNS_TWICE = 8 }; extern void emit_library_call PARAMS ((rtx, enum libcall_type, diff --git a/gcc/unwind-sjlj.c b/gcc/unwind-sjlj.c index 0f1d8ba7323..46f30ae1d8f 100644 --- a/gcc/unwind-sjlj.c +++ b/gcc/unwind-sjlj.c @@ -26,8 +26,13 @@ #if USING_SJLJ_EXCEPTIONS #ifdef DONT_USE_BUILTIN_SETJMP +#ifndef inhibit_libc #include #else +typedef void *jmp_buf[JMP_BUF_SIZE]; +extern void longjmp(jmp_buf, int) __attribute__((noreturn)); +#endif +#else #define setjmp __builtin_setjmp #define longjmp __builtin_longjmp #endif