[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