[llvm] r259854 - Add a test for MemorySSA. NFC.
George Burgess IV via llvm-commits
llvm-commits at lists.llvm.org
Thu Feb 4 16:42:02 PST 2016
Author: gbiv
Date: Thu Feb 4 18:42:02 2016
New Revision: 259854
URL: http://llvm.org/viewvc/llvm-project?rev=259854&view=rev
Log:
Add a test for MemorySSA. NFC.
We don't currently have many tests that deal with operations on multiple
local MemoryLocations. This new test helps out a bit in that regard.
Added:
llvm/trunk/test/Transforms/Util/MemorySSA/multiple-locations.ll
Added: llvm/trunk/test/Transforms/Util/MemorySSA/multiple-locations.ll
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/Transforms/Util/MemorySSA/multiple-locations.ll?rev=259854&view=auto
==============================================================================
--- llvm/trunk/test/Transforms/Util/MemorySSA/multiple-locations.ll (added)
+++ llvm/trunk/test/Transforms/Util/MemorySSA/multiple-locations.ll Thu Feb 4 18:42:02 2016
@@ -0,0 +1,24 @@
+; RUN: opt -basicaa -print-memoryssa -verify-memoryssa -analyze < %s 2>&1 | FileCheck %s
+;
+; Checks that basicAA is doing some amount of disambiguation for us
+
+define i32 @foo(i1 %cond) {
+ %a = alloca i32, align 4
+ %b = alloca i32, align 4
+; CHECK: 1 = MemoryDef(liveOnEntry)
+; CHECK-NEXT: store i32 0
+ store i32 0, i32* %a, align 4
+; CHECK: 2 = MemoryDef(1)
+; CHECK-NEXT: store i32 1
+ store i32 1, i32* %b, align 4
+
+; CHECK: MemoryUse(1)
+; CHECK-NEXT: %1 = load i32
+ %1 = load i32, i32* %a, align 4
+; CHECK: MemoryUse(2)
+; CHECK-NEXT: %2 = load i32
+ %2 = load i32, i32* %b, align 4
+
+ %3 = add i32 %1, %2
+ ret i32 %3
+}
More information about the llvm-commits
mailing list