From 80efdb6af52e8d0c24ab70537cf81a6b0a17f95e Mon Sep 17 00:00:00 2001 From: Paul Brook Date: Sun, 16 Mar 2008 00:58:57 +0000 Subject: [PATCH] arm.c (arm_unwind_emit): Suppress unused unwinding annotations. 2008-03-15 Paul Brook gcc/ * config/arm/arm.c (arm_unwind_emit): Suppress unused unwinding annotations. (arm_output_fn_unwind): Mark functions that can not be unwound. From-SVN: r133266 --- gcc/ChangeLog | 6 ++++++ gcc/config/arm/arm.c | 17 ++++++++++++++++- 2 files changed, 22 insertions(+), 1 deletion(-) diff --git a/gcc/ChangeLog b/gcc/ChangeLog index fcb1623..bb89350 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,5 +1,11 @@ 2008-03-15 Paul Brook + * config/arm/arm.c (arm_unwind_emit): Suppress unused unwinding + annotations. + (arm_output_fn_unwind): Mark functions that can not be unwound. + +2008-03-15 Paul Brook + * config/arm/arm.c (arm_rtx_costs_1): Add costs for ARMv6 value extension instructions. diff --git a/gcc/config/arm/arm.c b/gcc/config/arm/arm.c index 4fb0a0d..43a3078 100644 --- a/gcc/config/arm/arm.c +++ b/gcc/config/arm/arm.c @@ -18633,6 +18633,11 @@ arm_unwind_emit (FILE * asm_out_file, rtx insn) if (!ARM_EABI_UNWIND_TABLES) return; + if (!(flag_unwind_tables || cfun->uses_eh_lsda) + && (TREE_NOTHROW (current_function_decl) + || cfun->all_throwers_are_sibcalls)) + return; + if (GET_CODE (insn) == NOTE || !RTX_FRAME_RELATED_P (insn)) return; @@ -18713,7 +18718,17 @@ arm_output_fn_unwind (FILE * f, bool prologue) if (prologue) fputs ("\t.fnstart\n", f); else - fputs ("\t.fnend\n", f); + { + /* If this function will never be unwound, then mark it as such. + The came condition is used in arm_unwind_emit to suppress + the frame annotations. */ + if (!(flag_unwind_tables || cfun->uses_eh_lsda) + && (TREE_NOTHROW (current_function_decl) + || cfun->all_throwers_are_sibcalls)) + fputs("\t.cantunwind\n", f); + + fputs ("\t.fnend\n", f); + } } static bool -- 2.7.4