[llvm] 99dcee6 - [MemorySSA] Add test for select with cross-iteration dependency (NFC)
Nikita Popov via llvm-commits
llvm-commits at lists.llvm.org
Fri Oct 14 02:03:14 PDT 2022
Author: Nikita Popov
Date: 2022-10-14T11:03:02+02:00
New Revision: 99dcee6f504bcc84ca816febca72ad8b7281fe30
URL: https://github.com/llvm/llvm-project/commit/99dcee6f504bcc84ca816febca72ad8b7281fe30
DIFF: https://github.com/llvm/llvm-project/commit/99dcee6f504bcc84ca816febca72ad8b7281fe30.diff
LOG: [MemorySSA] Add test for select with cross-iteration dependency (NFC)
This is currently miscompiled.
Added:
llvm/test/Analysis/MemorySSA/select-loop-dep.ll
Modified:
Removed:
################################################################################
diff --git a/llvm/test/Analysis/MemorySSA/select-loop-dep.ll b/llvm/test/Analysis/MemorySSA/select-loop-dep.ll
new file mode 100644
index 0000000000000..3fb988a0f4d17
--- /dev/null
+++ b/llvm/test/Analysis/MemorySSA/select-loop-dep.ll
@@ -0,0 +1,30 @@
+; RUN: opt -passes='print<memoryssa>' -disable-output < %s 2>&1 | FileCheck %s
+
+; FIXME: The %sel2 load should be MemoryUse(4), because it loads the value
+; stored by the %sel1 store on the previous iteration.
+; CHECK: 1 = MemoryDef(liveOnEntry)
+; CHECK-NEXT: store i32 1, ptr %a1, align 4
+; CHECK: 2 = MemoryDef(1)
+; CHECK-NEXT: store i32 2, ptr %a2, align 4
+; CHECK: 4 = MemoryPhi({entry,2},{loop,3})
+; CHECK-NEXT: %c = phi i1 [ true, %entry ], [ false, %loop ]
+; CHECK: 3 = MemoryDef(4)
+; CHECK-NEXT: store i32 0, ptr %sel1, align 4
+; CHECK: MemoryUse(2)
+; CHECK-NEXT: %v = load i32, ptr %sel2, align 4
+define void @test() {
+entry:
+ %a1 = alloca i32
+ %a2 = alloca i32
+ store i32 1, ptr %a1
+ store i32 2, ptr %a2
+ br label %loop
+
+loop:
+ %c = phi i1 [ true, %entry ], [ false, %loop ]
+ %sel1 = select i1 %c, ptr %a1, ptr %a2
+ store i32 0, ptr %sel1
+ %sel2 = select i1 %c, ptr %a2, ptr %a1
+ %v = load i32, ptr %sel2
+ br label %loop
+}
More information about the llvm-commits
mailing list