forked from OSchip/llvm-project
Change the chain input of nodes that load the address of a function. This change
enables SelectionDAG::getLoad at MipsISelLowering.cpp:1914 to return a pre-existing node instead of redundantly create a new node every time it is called. llvm-svn: 133811
This commit is contained in:
parent
b5491a6e60
commit
35792089e7
|
@ -1911,7 +1911,7 @@ MipsTargetLowering::LowerCall(SDValue Chain, SDValue Callee,
|
|||
if (LoadSymAddr) {
|
||||
// Load callee address
|
||||
Callee = DAG.getNode(MipsISD::WrapperPIC, dl, MVT::i32, Callee);
|
||||
SDValue LoadValue = DAG.getLoad(MVT::i32, dl, Chain, Callee,
|
||||
SDValue LoadValue = DAG.getLoad(MVT::i32, dl, DAG.getEntryNode(), Callee,
|
||||
MachinePointerInfo::getGOT(),
|
||||
false, false, 0);
|
||||
|
||||
|
@ -1921,9 +1921,6 @@ MipsTargetLowering::LowerCall(SDValue Chain, SDValue Callee,
|
|||
Callee = DAG.getNode(ISD::ADD, dl, MVT::i32, LoadValue, Lo);
|
||||
} else
|
||||
Callee = LoadValue;
|
||||
|
||||
// Use chain output from LoadValue
|
||||
Chain = LoadValue.getValue(1);
|
||||
}
|
||||
|
||||
// copy to T9
|
||||
|
|
|
@ -8,11 +8,9 @@ entry:
|
|||
; CHECK: subu $[[T2:[0-9]+]], $sp, $[[SZ]]
|
||||
; CHECK: addu $sp, $zero, $[[T2]]
|
||||
; CHECK: addiu $[[T3:[0-9]+]], $sp, [[OFF]]
|
||||
; CHECK: lw $25, %call16(foo)($gp)
|
||||
; CHECK: addu $4, $zero, $[[T1]]
|
||||
; CHECK: jalr $25
|
||||
; CHECK: lw $25, %call16(foo)($gp)
|
||||
; CHECK: addu $4, $zero, $[[T3]]
|
||||
; CHECK: lw $[[T4:[0-9]+]], %call16(foo)($gp)
|
||||
; CHECK: addu $25, $zero, $[[T4]]
|
||||
; CHECK: addu $4, $zero, $[[T1]]
|
||||
; CHECK: jalr $25
|
||||
%tmp1 = alloca i8, i32 %size, align 4
|
||||
%add.ptr = getelementptr inbounds i8* %tmp1, i32 5
|
||||
|
|
|
@ -10,8 +10,8 @@ entry:
|
|||
; CHECK: jalr
|
||||
tail call void @ff1(i32 %i, i64 1085102592623924856) nounwind
|
||||
; CHECK: lw $25, %call16(ff2)
|
||||
; CHECK: lw $[[R2:[0-9]+]], 80($sp)
|
||||
; CHECK: lw $[[R3:[0-9]+]], 84($sp)
|
||||
; CHECK: lw $[[R2:[0-9]+]], 88($sp)
|
||||
; CHECK: lw $[[R3:[0-9]+]], 92($sp)
|
||||
; CHECK: addu $4, $zero, $[[R2]]
|
||||
; CHECK: addu $5, $zero, $[[R3]]
|
||||
; CHECK: jalr $25
|
||||
|
|
|
@ -8,7 +8,7 @@ define void @f() nounwind {
|
|||
entry:
|
||||
; CHECK: lui $at, 65534
|
||||
; CHECK: addu $at, $sp, $at
|
||||
; CHECK: addiu $sp, $at, -16
|
||||
; CHECK: addiu $sp, $at, -24
|
||||
; CHECK: .cprestore 65536
|
||||
|
||||
%agg.tmp = alloca %struct.S1, align 1
|
||||
|
|
Loading…
Reference in New Issue