[llvm] r245543 - Revert "[DSE] Enable removal of lifetime intrinsics in terminating blocks"
Bjorn Steinbrink via llvm-commits
llvm-commits at lists.llvm.org
Thu Aug 20 01:58:47 PDT 2015
Author: bsteinbr
Date: Thu Aug 20 03:58:47 2015
New Revision: 245543
URL: http://llvm.org/viewvc/llvm-project?rev=245543&view=rev
Log:
Revert "[DSE] Enable removal of lifetime intrinsics in terminating blocks"
Modified:
llvm/trunk/lib/Transforms/Scalar/DeadStoreElimination.cpp
llvm/trunk/test/Transforms/DeadStoreElimination/lifetime.ll
Modified: llvm/trunk/lib/Transforms/Scalar/DeadStoreElimination.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Transforms/Scalar/DeadStoreElimination.cpp?rev=245543&r1=245542&r2=245543&view=diff
==============================================================================
--- llvm/trunk/lib/Transforms/Scalar/DeadStoreElimination.cpp (original)
+++ llvm/trunk/lib/Transforms/Scalar/DeadStoreElimination.cpp Thu Aug 20 03:58:47 2015
@@ -788,33 +788,15 @@ bool DSE::handleEndBlock(BasicBlock &BB)
const DataLayout &DL = BB.getModule()->getDataLayout();
- // becomes false once lifetime intrinsics are observable or useful for stack
- // coloring
- bool canRemoveLifetimeIntrinsics = true;
-
// Scan the basic block backwards
for (BasicBlock::iterator BBI = BB.end(); BBI != BB.begin(); ){
--BBI;
- Value *V = nullptr;
- if (canRemoveLifetimeIntrinsics)
- if (IntrinsicInst *II = dyn_cast<IntrinsicInst>(BBI))
- switch (II->getIntrinsicID()) {
- default: break;
- case Intrinsic::lifetime_start:
- case Intrinsic::lifetime_end:
- V = II->getArgOperand(1);
- break;
- }
-
- if (!V && hasMemoryWrite(BBI, *TLI) && isRemovable(BBI))
- V = getStoredPointerOperand(BBI);
-
- // If we found a store, check to see if it points into a dead stack value.
- if (V) {
+ // If we find a store, check to see if it points into a dead stack value.
+ if (hasMemoryWrite(BBI, *TLI) && isRemovable(BBI)) {
// See through pointer-to-pointer bitcasts
SmallVector<Value *, 4> Pointers;
- GetUnderlyingObjects(V, Pointers, DL);
+ GetUnderlyingObjects(getStoredPointerOperand(BBI), Pointers, DL);
// Stores to stack values are valid candidates for removal.
bool AllDead = true;
@@ -862,15 +844,6 @@ bool DSE::handleEndBlock(BasicBlock &BB)
continue;
}
- if (IntrinsicInst *II = dyn_cast<IntrinsicInst>(BBI))
- if (II->getIntrinsicID() == Intrinsic::lifetime_start) {
- // We found a lifetime start for a live object, which we could not
- // remove. So we must stop removing lifetime intrinsics from this block
- // because they're useful for stack coloring again
- canRemoveLifetimeIntrinsics = false;
- continue;
- }
-
if (auto CS = CallSite(BBI)) {
// Remove allocation function calls from the list of dead stack objects;
// there can't be any references before the definition.
Modified: llvm/trunk/test/Transforms/DeadStoreElimination/lifetime.ll
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/Transforms/DeadStoreElimination/lifetime.ll?rev=245543&r1=245542&r2=245543&view=diff
==============================================================================
--- llvm/trunk/test/Transforms/DeadStoreElimination/lifetime.ll (original)
+++ llvm/trunk/test/Transforms/DeadStoreElimination/lifetime.ll Thu Aug 20 03:58:47 2015
@@ -5,16 +5,14 @@ target datalayout = "E-p:64:64:64-a0:0:8
declare void @llvm.lifetime.start(i64, i8* nocapture) nounwind
declare void @llvm.lifetime.end(i64, i8* nocapture) nounwind
declare void @llvm.memset.p0i8.i8(i8* nocapture, i8, i8, i32, i1) nounwind
-declare void @callee(i8*)
define void @test1() {
; CHECK-LABEL: @test1(
%A = alloca i8
store i8 0, i8* %A ;; Written to by memset
-; CHECK-NOT: store
call void @llvm.lifetime.end(i64 1, i8* %A)
-; CHECK-NOT: lifetime.end
+; CHECK: lifetime.end
call void @llvm.memset.p0i8.i8(i8* %A, i8 0, i8 -1, i32 0, i1 false)
; CHECK-NOT: memset
@@ -24,7 +22,7 @@ define void @test1() {
}
define void @test2(i32* %P) {
-; CHECK-LABEL: test2
+; CHECK: test2
%Q = getelementptr i32, i32* %P, i32 1
%R = bitcast i32* %Q to i8*
call void @llvm.lifetime.start(i64 4, i8* %R)
@@ -36,51 +34,4 @@ define void @test2(i32* %P) {
ret void
}
-define void @test3(i8*) {
-; CHECK-LABEL: test3
- %a = alloca i8
- call void @llvm.lifetime.start(i64 1, i8* %a)
-; CHECK-NOT: lifetime.start
- call void @llvm.lifetime.end(i64 1, i8* %a)
-; CHECK-NOT: lifetime.end
- call void @llvm.lifetime.start(i64 1, i8* undef)
-; CHECK-NOT: lifetime.start
- call void @llvm.lifetime.end(i64 1, i8* undef)
-; CHECK-NOT: lifetime.end
- ret void
-}
-
-define void @test4(i8*) {
-; CHECK-LABEL: test4
- %a = alloca i8
- call void @llvm.lifetime.start(i64 1, i8* %a)
-; CHECK: lifetime.start
- call void @llvm.lifetime.end(i64 1, i8* %a)
-; CHECK: lifetime.end
- call void @llvm.lifetime.start(i64 1, i8* %0)
-; CHECK: lifetime.start
- call void @llvm.lifetime.end(i64 1, i8* %0)
-; CHECK: lifetime.end
- call void @llvm.lifetime.start(i64 1, i8* %a)
-; CHECK-NOT: lifetime.start
- call void @llvm.lifetime.end(i64 1, i8* %a)
-; CHECK-NOT: lifetime.end
- ret void
-}
-define void @test5() {
-; CHECK-LABEL: test5
- %a = alloca i8
- %b = alloca i8
- call void @llvm.lifetime.start(i64 1, i8* %a)
-; CHECK: lifetime.start
- call void @llvm.lifetime.end(i64 1, i8* %a)
-; CHECK: lifetime.end
- call void @llvm.lifetime.start(i64 1, i8* %b)
-; CHECK: lifetime.start
- call void @callee(i8* %b)
-; CHECK: call void @callee
- call void @llvm.lifetime.end(i64 1, i8* %b)
-; CHECK-NOT: lifetime.end
- ret void
-}
More information about the llvm-commits
mailing list