Add a testcase for r275581
authorDavid Majnemer <david.majnemer@gmail.com>
Tue, 19 Jul 2016 17:52:41 +0000 (17:52 +0000)
committerDavid Majnemer <david.majnemer@gmail.com>
Tue, 19 Jul 2016 17:52:41 +0000 (17:52 +0000)
llvm-svn: 276002

llvm/test/Transforms/Sink/fence.ll [new file with mode: 0644]

diff --git a/llvm/test/Transforms/Sink/fence.ll b/llvm/test/Transforms/Sink/fence.ll
new file mode 100644 (file)
index 0000000..aa237d8
--- /dev/null
@@ -0,0 +1,28 @@
+; RUN: opt -S -sink < %s | FileCheck %s
+target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128"
+target triple = "x86_64-unknown-linux-gnu"
+
+define void @test1(i32* ()*) {
+entry:
+  %1 = call i32* %0() #0
+  fence singlethread seq_cst
+  %2 = load i32, i32* %1, align 4
+  fence singlethread seq_cst
+  %3 = icmp eq i32 %2, 0
+  br i1 %3, label %fail, label %pass
+
+fail:                                             ; preds = %top
+  br label %pass
+
+pass:                                             ; preds = %fail, %top
+  ret void
+}
+
+; CHECK-LABEL: @test1(
+; CHECK:  %[[call:.*]] = call i32* %0()
+; CHECK:  fence singlethread seq_cst
+; CHECK:  load i32, i32* %[[call]], align 4
+; CHECK:  fence singlethread seq_cst
+
+
+attributes #0 = { nounwind readnone }