mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-06-24 08:24:33 +00:00
Don't duplicate the work done by a gep into a "bitcast" if the gep has
more than one use. Fixes PR10322. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@134883 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@ -785,6 +785,14 @@ Instruction *InstCombiner::visitGetElementPtrInst(GetElementPtrInst &GEP) {
|
|||||||
// getelementptr instructions into a single instruction.
|
// getelementptr instructions into a single instruction.
|
||||||
//
|
//
|
||||||
if (GEPOperator *Src = dyn_cast<GEPOperator>(PtrOp)) {
|
if (GEPOperator *Src = dyn_cast<GEPOperator>(PtrOp)) {
|
||||||
|
|
||||||
|
// If this GEP has only 0 indices, it is the same pointer as
|
||||||
|
// Src. If Src is not a trivial GEP too, don't combine
|
||||||
|
// the indices.
|
||||||
|
if (GEP.hasAllZeroIndices() && !Src->hasAllZeroIndices() &&
|
||||||
|
!Src->hasOneUse())
|
||||||
|
return 0;
|
||||||
|
|
||||||
// Note that if our source is a gep chain itself that we wait for that
|
// Note that if our source is a gep chain itself that we wait for that
|
||||||
// chain to be resolved before we perform this transformation. This
|
// chain to be resolved before we perform this transformation. This
|
||||||
// avoids us creating a TON of code in some cases.
|
// avoids us creating a TON of code in some cases.
|
||||||
|
@ -456,3 +456,19 @@ define i32* @test38(i32* %I, i32 %n) {
|
|||||||
; CHECK: = sext i32 %n to i64
|
; CHECK: = sext i32 %n to i64
|
||||||
; CHECK: %A = getelementptr i32* %I, i64 %
|
; CHECK: %A = getelementptr i32* %I, i64 %
|
||||||
}
|
}
|
||||||
|
|
||||||
|
; Test that we don't duplicate work when the second gep is a "bitcast".
|
||||||
|
%pr10322_t = type { i8* }
|
||||||
|
declare void @pr10322_f2(%pr10322_t*)
|
||||||
|
declare void @pr10322_f3(i8**)
|
||||||
|
define void @pr10322_f1(%pr10322_t* %foo) {
|
||||||
|
entry:
|
||||||
|
%arrayidx8 = getelementptr inbounds %pr10322_t* %foo, i64 2
|
||||||
|
call void @pr10322_f2(%pr10322_t* %arrayidx8) nounwind
|
||||||
|
%tmp2 = getelementptr inbounds %pr10322_t* %arrayidx8, i64 0, i32 0
|
||||||
|
call void @pr10322_f3(i8** %tmp2) nounwind
|
||||||
|
ret void
|
||||||
|
|
||||||
|
; CHECK: @pr10322_f1
|
||||||
|
; CHECK: %tmp2 = getelementptr inbounds %pr10322_t* %arrayidx8, i64 0, i32 0
|
||||||
|
}
|
||||||
|
Reference in New Issue
Block a user