[llvm] a999895 - [RewriteStatepointsForGC] Add a test exposing an incorrect assertion
Daniil Suchkov via llvm-commits
llvm-commits at lists.llvm.org
Wed Feb 16 16:23:49 PST 2022
Author: Daniil Suchkov
Date: 2022-02-17T00:22:46Z
New Revision: a99989529eac2a96fec4b3b59cee6d2f7ab22a92
URL: https://github.com/llvm/llvm-project/commit/a99989529eac2a96fec4b3b59cee6d2f7ab22a92
DIFF: https://github.com/llvm/llvm-project/commit/a99989529eac2a96fec4b3b59cee6d2f7ab22a92.diff
LOG: [RewriteStatepointsForGC] Add a test exposing an incorrect assertion
Added:
llvm/test/Transforms/RewriteStatepointsForGC/phi-vector-bitcast.ll
Modified:
Removed:
################################################################################
diff --git a/llvm/test/Transforms/RewriteStatepointsForGC/phi-vector-bitcast.ll b/llvm/test/Transforms/RewriteStatepointsForGC/phi-vector-bitcast.ll
new file mode 100644
index 0000000000000..6f69234cc993e
--- /dev/null
+++ b/llvm/test/Transforms/RewriteStatepointsForGC/phi-vector-bitcast.ll
@@ -0,0 +1,28 @@
+; XFAIL: *
+; REQUIRES: asserts
+; RUN: opt < %s -disable-output -passes=rewrite-statepoints-for-gc
+
+; We shouldn't crash when we encounter a vector phi with more than one input
+; from the same predecessor.
+define void @foo(<2 x i8 addrspace(1)*> %arg1, i32 %arg2, i1 %arg3, <2 x i64 addrspace(1)*> %arg4) gc "statepoint-example" personality i32* null {
+bb:
+ %tmp = bitcast <2 x i8 addrspace(1)*> %arg1 to <2 x i64 addrspace(1)*>
+ switch i32 %arg2, label %bb2 [
+ i32 1, label %bb4
+ i32 2, label %bb4
+ ]
+
+bb2: ; preds = %bb
+ br i1 %arg3, label %bb8, label %bb4
+
+bb4: ; preds = %bb2, %bb, %bb
+ %tmp5 = phi <2 x i64 addrspace(1)*> [ %tmp, %bb ], [ %tmp, %bb ], [ %arg4, %bb2 ]
+ call void @bar()
+ %tmp6 = extractelement <2 x i64 addrspace(1)*> %tmp5, i32 1
+ ret void
+
+bb8: ; preds = %bb2
+ ret void
+}
+
+declare void @bar()
More information about the llvm-commits
mailing list