aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorKaz Kojima <kkojima@gcc.gnu.org>2012-03-21 20:19:31 +0000
committerOleg Endo <olegendo@gcc.gnu.org>2012-03-21 20:19:31 +0000
commit6c5bfec01b00cdba798a01e25a38c3f211c32b2b (patch)
tree95b619449df10fe2da08648e140784df8f69ceea /gcc
parenta26f86dcb1fd70f7136deb3964443bef528db516 (diff)
downloadgcc-6c5bfec01b00cdba798a01e25a38c3f211c32b2b.zip
gcc-6c5bfec01b00cdba798a01e25a38c3f211c32b2b.tar.gz
gcc-6c5bfec01b00cdba798a01e25a38c3f211c32b2b.tar.bz2
PR/target 52642
PR/target 52642 * config/sh/sh.c (sh_expand_prologue): Emit blockage at the end of prologue for unwinder and profiler. From-SVN: r185616
Diffstat (limited to 'gcc')
-rw-r--r--gcc/ChangeLog6
-rw-r--r--gcc/config/sh/sh.c7
2 files changed, 13 insertions, 0 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index efa5bfb..fd07ac6 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -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*.
diff --git a/gcc/config/sh/sh.c b/gcc/config/sh/sh.c
index 4b5db67..1bfd89b 100644
--- a/gcc/config/sh/sh.c
+++ b/gcc/config/sh/sh.c
@@ -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;
}