aboutsummaryrefslogtreecommitdiff
path: root/gcc/testsuite/gcc.c-torture
diff options
context:
space:
mode:
authorJakub Jelinek <jakub@redhat.com>2022-12-16 10:19:22 +0100
committerJakub Jelinek <jakub@redhat.com>2022-12-16 10:19:22 +0100
commitddcaa60983b50378bde1b7e327086fe0ce101795 (patch)
treedd51d1c19562c5344f193fdbd0d34ba48b25011a /gcc/testsuite/gcc.c-torture
parent711e0acdbb2645f5a8aa89014488c24e89ccb0f7 (diff)
downloadgcc-ddcaa60983b50378bde1b7e327086fe0ce101795.zip
gcc-ddcaa60983b50378bde1b7e327086fe0ce101795.tar.gz
gcc-ddcaa60983b50378bde1b7e327086fe0ce101795.tar.bz2
loop-invariant: Split preheader edge if the preheader bb ends with jump [PR106751]
The RTL loop passes only request simple preheaders, but don't require fallthru preheaders, while move_invariant_reg apparently assumes the latter, that it can just append instruction(s) to the end of the preheader basic block. The following patch fixes that by splitting the preheader edge if the preheader bb ends with a JUMP_INSN (asm goto in this case). Without that we get control flow in the middle of a bb. 2022-12-16 Jakub Jelinek <jakub@redhat.com> PR rtl-optimization/106751 * loop-invariant.cc (move_invariant_reg): If preheader bb ends with a JUMP_INSN, split the preheader edge and emit invariants into the new preheader basic block. * gcc.c-torture/compile/pr106751.c: New test.
Diffstat (limited to 'gcc/testsuite/gcc.c-torture')
-rw-r--r--gcc/testsuite/gcc.c-torture/compile/pr106751.c17
1 files changed, 17 insertions, 0 deletions
diff --git a/gcc/testsuite/gcc.c-torture/compile/pr106751.c b/gcc/testsuite/gcc.c-torture/compile/pr106751.c
new file mode 100644
index 0000000..5fbf93b
--- /dev/null
+++ b/gcc/testsuite/gcc.c-torture/compile/pr106751.c
@@ -0,0 +1,17 @@
+/* PR rtl-optimization/106751 */
+
+int *foo (void);
+
+void
+bar (void)
+{
+ asm goto ("" : : : : lab);
+ __builtin_unreachable ();
+lab:
+ while (1)
+ {
+ int o;
+ asm ("" : "=r" (o) : "g" (1));
+ *foo () = o;
+ }
+}