summaryrefslogtreecommitdiff
path: root/gcc/config/nvptx/nvptx.c
diff options
context:
space:
mode:
authornathan <nathan@138bc75d-0d04-0410-961f-82ee72b054a4>2015-12-07 16:08:42 +0000
committernathan <nathan@138bc75d-0d04-0410-961f-82ee72b054a4>2015-12-07 16:08:42 +0000
commit64204dac607f7fd9e5a4539a8935fc70b26e082d (patch)
tree98fef089b3f840adae625184631a383115201687 /gcc/config/nvptx/nvptx.c
parentd0f713f444bd502eaed523b6a26e24922c5fe9f5 (diff)
downloadgcc-64204dac607f7fd9e5a4539a8935fc70b26e082d.tar.gz
gcc/
* config/nvptx/nvptx.c (nvptx_output_call_insn): Emit trap after no return call. gcc/testsuite/ * gcc.target/nvptx/abort.c: New. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@231368 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/config/nvptx/nvptx.c')
-rw-r--r--gcc/config/nvptx/nvptx.c7
1 files changed, 7 insertions, 0 deletions
diff --git a/gcc/config/nvptx/nvptx.c b/gcc/config/nvptx/nvptx.c
index 2dec8467437..6ce8d4b37d5 100644
--- a/gcc/config/nvptx/nvptx.c
+++ b/gcc/config/nvptx/nvptx.c
@@ -1890,6 +1890,13 @@ nvptx_output_call_insn (rtx_insn *insn, rtx result, rtx callee)
}
fprintf (asm_out_file, ";\n");
+ if (find_reg_note (insn, REG_NORETURN, NULL))
+ /* No return functions confuse the PTX JIT, as it doesn't realize
+ the flow control barrier they imply. It can seg fault if it
+ encounters what looks like an unexitable loop. Emit a trailing
+ trap, which it does grok. */
+ fprintf (asm_out_file, "\t\ttrap; // (noreturn)\n");
+
return result != NULL_RTX ? "\tld.param%t0\t%0, [%%retval_in];\n\t}" : "}";
}