diff options
| author | Eli Friedman <eli.friedman@gmail.com> | 2011-09-01 21:21:24 +0000 | 
|---|---|---|
| committer | Eli Friedman <eli.friedman@gmail.com> | 2011-09-01 21:21:24 +0000 | 
| commit | 71f5c2f1585e4bec0cc676e0476738af999dba70 (patch) | |
| tree | eff379801733307185eee8eba05809c62f5e8659 /llvm | |
| parent | cc6e92892f5e038639e2a7855abad5dc0c37a59e (diff) | |
| download | bcm5719-llvm-71f5c2f1585e4bec0cc676e0476738af999dba70.tar.gz bcm5719-llvm-71f5c2f1585e4bec0cc676e0476738af999dba70.zip  | |
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.)
llvm-svn: 138965
Diffstat (limited to 'llvm')
| -rw-r--r-- | llvm/lib/Transforms/Scalar/Sink.cpp | 13 | ||||
| -rw-r--r-- | llvm/test/Transforms/Sink/basic.ll | 16 | 
2 files changed, 22 insertions, 7 deletions
diff --git a/llvm/lib/Transforms/Scalar/Sink.cpp b/llvm/lib/Transforms/Scalar/Sink.cpp index 705f4420490..c83f56c4d2d 100644 --- a/llvm/lib/Transforms/Scalar/Sink.cpp +++ b/llvm/lib/Transforms/Scalar/Sink.cpp @@ -153,9 +153,13 @@ bool Sinking::ProcessBlock(BasicBlock &BB) {  static bool isSafeToMove(Instruction *Inst, AliasAnalysis *AA,                           SmallPtrSet<Instruction *, 8> &Stores) { -  if (LoadInst *L = dyn_cast<LoadInst>(Inst)) { -    if (L->isVolatile()) return false; +  if (Inst->mayWriteToMemory()) { +    Stores.insert(Inst); +    return false; +  } + +  if (LoadInst *L = dyn_cast<LoadInst>(Inst)) {      AliasAnalysis::Location Loc = AA->getLocation(L);      for (SmallPtrSet<Instruction *, 8>::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<TerminatorInst>(Inst) || isa<PHINode>(Inst))      return false; diff --git a/llvm/test/Transforms/Sink/basic.ll b/llvm/test/Transforms/Sink/basic.ll index 54b7f1369de..81782e9d42c 100644 --- a/llvm/test/Transforms/Sink/basic.ll +++ b/llvm/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 +}  | 

