Don't use our own incorrect version of isTriviallyDeadInstruction in NewGVN. Fixes PR/31472

llvm-svn: 290549
This commit is contained in:
Daniel Berlin 2016-12-26 18:44:36 +00:00
parent ab547de775
commit b7b850ccf1
2 changed files with 36 additions and 3 deletions

View File

@ -1344,10 +1344,9 @@ void NewGVN::valueNumberMemoryPhi(MemoryPhi *MP) {
// congruence finding, and updating mappings.
void NewGVN::valueNumberInstruction(Instruction *I) {
DEBUG(dbgs() << "Processing instruction " << *I << "\n");
if (I->use_empty() && !I->getType()->isVoidTy()) {
if (isInstructionTriviallyDead(I, TLI)) {
DEBUG(dbgs() << "Skipping unused instruction\n");
if (isInstructionTriviallyDead(I, TLI))
markInstructionForDeletion(I);
markInstructionForDeletion(I);
return;
}
if (!I->isTerminator()) {

View File

@ -0,0 +1,34 @@
; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
; RUN: opt < %s -basicaa -newgvn -S | FileCheck %s
target datalayout = "e-m:o-i64:64-f80:128-n8:16:32:64-S128"
target triple = "x86_64-apple-macosx10.12.0"
;; Ensure the invoke does not accidentally get deleted as unused, just because the value is not used.
; Function Attrs: norecurse ssp uwtable
define i32 @main() personality i8* bitcast (i32 (...)* @__gxx_personality_v0 to i8*){
; CHECK-LABEL: @main(
; CHECK-NEXT: [[TMP1:%.*]] = invoke i32 @foo()
; CHECK-NEXT: to label %good unwind label %bad
; CHECK: good:
; CHECK-NEXT: ret i32 5
; CHECK: bad:
; CHECK-NEXT: [[TMP2:%.*]] = landingpad { i8*, i32
;
%1 = invoke i32 @foo()
to label %good unwind label %bad
good:
; <label>:15: ; preds = %.preheader
ret i32 5
bad:
; <label>:20: ; preds = %15, %.preheader
%2 = landingpad { i8*, i32 }
cleanup
resume { i8*, i32 } %2
}
declare i32 @foo()
declare i32 @__gxx_personality_v0(...)