aboutsummaryrefslogtreecommitdiff
path: root/gcc/function.c
diff options
context:
space:
mode:
authorJakub Jelinek <jakub@redhat.com>2014-03-03 08:25:50 +0100
committerJakub Jelinek <jakub@gcc.gnu.org>2014-03-03 08:25:50 +0100
commit79c7fda6d56eea84a95df8ea67387b4cf972e9de (patch)
treed6a8ebe478c2d5333110bafe9cc7ce6fe4dcbb45 /gcc/function.c
parent715a5c85f7db0146b2df19452958e26d15d6eab8 (diff)
downloadgcc-79c7fda6d56eea84a95df8ea67387b4cf972e9de.zip
gcc-79c7fda6d56eea84a95df8ea67387b4cf972e9de.tar.gz
gcc-79c7fda6d56eea84a95df8ea67387b4cf972e9de.tar.bz2
re PR middle-end/60175 (ICE on gcc.dg/asan/nosanitize-and-inline.c)
PR middle-end/60175 * function.c (expand_function_end): Don't emit clobber_return_register sequence if clobber_after is a BARRIER. * cfgexpand.c (construct_exit_block): Append instructions before return_label to prev_bb. From-SVN: r208267
Diffstat (limited to 'gcc/function.c')
-rw-r--r--gcc/function.c21
1 files changed, 12 insertions, 9 deletions
diff --git a/gcc/function.c b/gcc/function.c
index b43e67f..e67d3c1 100644
--- a/gcc/function.c
+++ b/gcc/function.c
@@ -5156,17 +5156,20 @@ expand_function_end (void)
crtl->return_rtx = outgoing;
}
- /* Emit the actual code to clobber return register. */
- {
- rtx seq;
+ /* Emit the actual code to clobber return register. Don't emit
+ it if clobber_after is a barrier, then the previous basic block
+ certainly doesn't fall thru into the exit block. */
+ if (!BARRIER_P (clobber_after))
+ {
+ rtx seq;
- start_sequence ();
- clobber_return_register ();
- seq = get_insns ();
- end_sequence ();
+ start_sequence ();
+ clobber_return_register ();
+ seq = get_insns ();
+ end_sequence ();
- emit_insn_after (seq, clobber_after);
- }
+ emit_insn_after (seq, clobber_after);
+ }
/* Output the label for the naked return from the function. */
if (naked_return_label)