mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-26 04:40:38 +00:00
Don't use our own incorrect version of isTriviallyDeadInstruction in NewGVN. Fixes PR/31472
llvm-svn: 290549
This commit is contained in:
parent
ab547de775
commit
b7b850ccf1
@ -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()) {
|
||||
|
34
test/Transforms/NewGVN/pr31472.ll
Normal file
34
test/Transforms/NewGVN/pr31472.ll
Normal 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(...)
|
Loading…
Reference in New Issue
Block a user