PR/target 52642
authorolegendo <olegendo@138bc75d-0d04-0410-961f-82ee72b054a4>
Wed, 21 Mar 2012 20:19:31 +0000 (20:19 +0000)
committerolegendo <olegendo@138bc75d-0d04-0410-961f-82ee72b054a4>
Wed, 21 Mar 2012 20:19:31 +0000 (20:19 +0000)
* config/sh/sh.c (sh_expand_prologue): Emit blockage at the end of
prologue for unwinder and profiler.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@185616 138bc75d-0d04-0410-961f-82ee72b054a4

gcc/ChangeLog
gcc/config/sh/sh.c

index efa5bfb..fd07ac6 100644 (file)
@@ -1,3 +1,9 @@
+2012-03-21  Kaz Kojima  <kkojima@gcc.gnu.org>
+
+       PR/target 52642
+       * config/sh/sh.c (sh_expand_prologue): Emit blockage at the end of
+       prologue for unwinder and profiler.     
+
 2012-03-21  Andreas Tobler  <andreast@fgznet.ch>
 
        * configure.ac (HAVE_LD_NO_DOT_SYMBOLS): Add powerpc64-*-freebsd*.
index 4b5db67..1bfd89b 100644 (file)
@@ -7239,6 +7239,13 @@ sh_expand_prologue (void)
       emit_insn (gen_shcompact_incoming_args ());
     }
 
+  /* If we are profiling, make sure no instructions are scheduled before
+     the call to mcount.  Similarly if some call instructions are swapped
+     before frame related insns, it'll confuse the unwinder because
+     currently SH has no unwind info for function epilogues.  */
+  if (crtl->profile || flag_exceptions || flag_unwind_tables)
+    emit_insn (gen_blockage ());
+
   if (flag_stack_usage_info)
     current_function_static_stack_size = stack_usage;
 }