From 86b5db8c011d96e7b7af0299cc99c942b790499e Mon Sep 17 00:00:00 2001 From: Eli Friedman Date: Thu, 1 Sep 2011 21:21:24 +0000 Subject: [PATCH] Fix an issue with the IR sink pass found by inspection. (I'm not sure anyone is actually using this, but might as well fix it since I found the issue.) git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@138965 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/Transforms/Scalar/Sink.cpp | 13 ++++++------- test/Transforms/Sink/basic.ll | 16 ++++++++++++++++ 2 files changed, 22 insertions(+), 7 deletions(-) diff --git a/lib/Transforms/Scalar/Sink.cpp b/lib/Transforms/Scalar/Sink.cpp index 705f4420490..c83f56c4d2d 100644 --- a/lib/Transforms/Scalar/Sink.cpp +++ b/lib/Transforms/Scalar/Sink.cpp @@ -153,9 +153,13 @@ bool Sinking::ProcessBlock(BasicBlock &BB) { static bool isSafeToMove(Instruction *Inst, AliasAnalysis *AA, SmallPtrSet &Stores) { - if (LoadInst *L = dyn_cast(Inst)) { - if (L->isVolatile()) return false; + if (Inst->mayWriteToMemory()) { + Stores.insert(Inst); + return false; + } + + if (LoadInst *L = dyn_cast(Inst)) { AliasAnalysis::Location Loc = AA->getLocation(L); for (SmallPtrSet::iterator I = Stores.begin(), E = Stores.end(); I != E; ++I) @@ -163,11 +167,6 @@ static bool isSafeToMove(Instruction *Inst, AliasAnalysis *AA, return false; } - if (Inst->mayWriteToMemory()) { - Stores.insert(Inst); - return false; - } - if (isa(Inst) || isa(Inst)) return false; diff --git a/test/Transforms/Sink/basic.ll b/test/Transforms/Sink/basic.ll index 54b7f1369de..81782e9d42c 100644 --- a/test/Transforms/Sink/basic.ll +++ b/test/Transforms/Sink/basic.ll @@ -20,3 +20,19 @@ true: false: ret i32 0 } + +; But don't sink volatile loads... + +; CHECK: @foo2 +; CHECK: volatile load +; CHECK-NEXT: store i32 + +define i32 @foo2(i1 %z) { + %l = volatile load i32* @A + store i32 0, i32* @B + br i1 %z, label %true, label %false +true: + ret i32 %l +false: + ret i32 0 +} -- 2.34.1