diff --git a/gcc/ChangeLog b/gcc/ChangeLog index fcb1623cc3089b3208aeecc2c6917a5f1a870829..bb89350e4d485794167b694d7b5b53081328dd68 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2008-03-15 Paul Brook <paul@codesourcery.com> + + * 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 <paul@codesourcery.com> * config/arm/arm.c (arm_rtx_costs_1): Add costs for ARMv6 value diff --git a/gcc/config/arm/arm.c b/gcc/config/arm/arm.c index 4fb0a0d1f1ee50326c81b0d99eb2aab23dc4b515..43a3078278d6a9d94b3b0a621967bd512783431d 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