diff options
| author | Eli Friedman <eli.friedman@gmail.com> | 2012-02-16 00:41:10 +0000 |
|---|---|---|
| committer | Eli Friedman <eli.friedman@gmail.com> | 2012-02-16 00:41:10 +0000 |
| commit | c458885c58495fa235415a97b1a8cc096a8e98c1 (patch) | |
| tree | 889b16dee5d13df8d823a19c3e00a8be01471c8b | |
| parent | 10dbd68bd2c1c0f76262d80fd951e4810c11f061 (diff) | |
| download | bcm5719-llvm-c458885c58495fa235415a97b1a8cc096a8e98c1.tar.gz bcm5719-llvm-c458885c58495fa235415a97b1a8cc096a8e98c1.zip | |
loop-rotate shouldn't hoist alloca instructions out of a loop. Patch by Patrik Hägglund, with slightly modified test. Issue reported by Patrik Hägglund on llvmdev.
llvm-svn: 150642
| -rw-r--r-- | llvm/lib/Transforms/Scalar/LoopRotation.cpp | 3 | ||||
| -rw-r--r-- | llvm/test/Transforms/LoopRotate/alloca.ll | 33 |
2 files changed, 35 insertions, 1 deletions
diff --git a/llvm/lib/Transforms/Scalar/LoopRotation.cpp b/llvm/lib/Transforms/Scalar/LoopRotation.cpp index 7a60ad20474..59aace9e36d 100644 --- a/llvm/lib/Transforms/Scalar/LoopRotation.cpp +++ b/llvm/lib/Transforms/Scalar/LoopRotation.cpp @@ -339,7 +339,8 @@ bool LoopRotate::rotateLoop(Loop *L) { // memory (without proving that the loop doesn't write). if (L->hasLoopInvariantOperands(Inst) && !Inst->mayReadFromMemory() && !Inst->mayWriteToMemory() && - !isa<TerminatorInst>(Inst) && !isa<DbgInfoIntrinsic>(Inst)) { + !isa<TerminatorInst>(Inst) && !isa<DbgInfoIntrinsic>(Inst) && + !isa<AllocaInst>(Inst)) { Inst->moveBefore(LoopEntryBranch); continue; } diff --git a/llvm/test/Transforms/LoopRotate/alloca.ll b/llvm/test/Transforms/LoopRotate/alloca.ll new file mode 100644 index 00000000000..fd217ea8dcf --- /dev/null +++ b/llvm/test/Transforms/LoopRotate/alloca.ll @@ -0,0 +1,33 @@ +; RUN: opt < %s -loop-rotate -S | FileCheck %s + +; Test alloca in -loop-rotate. + +; We expect a different value for %ptr each iteration (according to the +; definition of alloca). I.e. each @use must be paired with an alloca. + +; CHECK: call void @use(i8* % +; CHECK: %ptr = alloca i8 + +@e = global i16 10 + +declare void @use(i8*) + +define void @test() { +entry: + %end = load i16* @e + br label %loop + +loop: + %n.phi = phi i16 [ %n, %loop.fin ], [ 0, %entry ] + %ptr = alloca i8 + %cond = icmp eq i16 %n.phi, %end + br i1 %cond, label %exit, label %loop.fin + +loop.fin: + %n = add i16 %n.phi, 1 + call void @use(i8* %ptr) + br label %loop + +exit: + ret void +} |

