[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