mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-24 03:33:20 +01:00
Revert "SimplifyCFG: GEPs with just one non-constant index are also cheap."
Yes, there are other types than i8* and GEPs on them can produce an add+multiply. We don't consider that cheap enough to be speculatively executed. llvm-svn: 126481
This commit is contained in:
parent
ed7f556f44
commit
39a5d8596c
@ -247,13 +247,11 @@ static bool DominatesMergePoint(Value *V, BasicBlock *BB,
|
||||
if (PBB->getFirstNonPHIOrDbg() != I)
|
||||
return false;
|
||||
break;
|
||||
case Instruction::GetElementPtr: {
|
||||
// GEPs are cheap if all indices are constant or if there's only one index.
|
||||
GetElementPtrInst *GEP = cast<GetElementPtrInst>(I);
|
||||
if (!GEP->hasAllConstantIndices() && GEP->getNumIndices() > 1)
|
||||
case Instruction::GetElementPtr:
|
||||
// GEPs are cheap if all indices are constant.
|
||||
if (!cast<GetElementPtrInst>(I)->hasAllConstantIndices())
|
||||
return false;
|
||||
break;
|
||||
}
|
||||
case Instruction::Add:
|
||||
case Instruction::Sub:
|
||||
case Instruction::And:
|
||||
|
@ -15,7 +15,7 @@ if.end:
|
||||
ret i8* %x.addr
|
||||
|
||||
; CHECK: @test1
|
||||
; CHECK: %x.addr = select i1 %cmp, i8* %incdec.ptr, i8* %x
|
||||
; CHECK-NOT: select
|
||||
; CHECK: ret i8* %x.addr
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user