forked from OSchip/llvm-project
Fix call instruction operands in ARMFastISel.
The ARM BL and BLX instructions don't have predicate operands, but the thumb variants tBL and tBLX do. The argument registers should be added as implicit uses. llvm-svn: 162593
This commit is contained in:
parent
b50cf8b30f
commit
e6afde59db
|
@ -2212,25 +2212,17 @@ bool ARMFastISel::ARMEmitLibcall(const Instruction *I, RTLIB::Libcall Call) {
|
|||
unsigned CallOpc = ARMSelectCallOp(EnableARMLongCalls);
|
||||
MachineInstrBuilder MIB = BuildMI(*FuncInfo.MBB, FuncInfo.InsertPt,
|
||||
DL, TII.get(CallOpc));
|
||||
if (isThumb2) {
|
||||
// Explicitly adding the predicate here.
|
||||
// BL / BLX don't take a predicate, but tBL / tBLX do.
|
||||
if (isThumb2)
|
||||
AddDefaultPred(MIB);
|
||||
if (EnableARMLongCalls)
|
||||
MIB.addReg(CalleeReg);
|
||||
else
|
||||
MIB.addExternalSymbol(TLI.getLibcallName(Call));
|
||||
} else {
|
||||
if (EnableARMLongCalls)
|
||||
MIB.addReg(CalleeReg);
|
||||
else
|
||||
MIB.addExternalSymbol(TLI.getLibcallName(Call));
|
||||
if (EnableARMLongCalls)
|
||||
MIB.addReg(CalleeReg);
|
||||
else
|
||||
MIB.addExternalSymbol(TLI.getLibcallName(Call));
|
||||
|
||||
// Explicitly adding the predicate here.
|
||||
AddDefaultPred(MIB);
|
||||
}
|
||||
// Add implicit physical register uses to the call.
|
||||
for (unsigned i = 0, e = RegArgs.size(); i != e; ++i)
|
||||
MIB.addReg(RegArgs[i]);
|
||||
MIB.addReg(RegArgs[i], RegState::Implicit);
|
||||
|
||||
// Add a register mask with the call-preserved registers.
|
||||
// Proper defs for return values will be added by setPhysRegsDeadExcept().
|
||||
|
@ -2358,30 +2350,20 @@ bool ARMFastISel::SelectCall(const Instruction *I,
|
|||
unsigned CallOpc = ARMSelectCallOp(UseReg);
|
||||
MachineInstrBuilder MIB = BuildMI(*FuncInfo.MBB, FuncInfo.InsertPt,
|
||||
DL, TII.get(CallOpc));
|
||||
if(isThumb2) {
|
||||
// Explicitly adding the predicate here.
|
||||
AddDefaultPred(MIB);
|
||||
if (UseReg)
|
||||
MIB.addReg(CalleeReg);
|
||||
else if (!IntrMemName)
|
||||
MIB.addGlobalAddress(GV, 0, 0);
|
||||
else
|
||||
MIB.addExternalSymbol(IntrMemName, 0);
|
||||
} else {
|
||||
if (UseReg)
|
||||
MIB.addReg(CalleeReg);
|
||||
else if (!IntrMemName)
|
||||
MIB.addGlobalAddress(GV, 0, 0);
|
||||
else
|
||||
MIB.addExternalSymbol(IntrMemName, 0);
|
||||
|
||||
// Explicitly adding the predicate here.
|
||||
// ARM calls don't take a predicate, but tBL / tBLX do.
|
||||
if(isThumb2)
|
||||
AddDefaultPred(MIB);
|
||||
}
|
||||
if (UseReg)
|
||||
MIB.addReg(CalleeReg);
|
||||
else if (!IntrMemName)
|
||||
MIB.addGlobalAddress(GV, 0, 0);
|
||||
else
|
||||
MIB.addExternalSymbol(IntrMemName, 0);
|
||||
|
||||
// Add implicit physical register uses to the call.
|
||||
for (unsigned i = 0, e = RegArgs.size(); i != e; ++i)
|
||||
MIB.addReg(RegArgs[i]);
|
||||
MIB.addReg(RegArgs[i], RegState::Implicit);
|
||||
|
||||
// Add a register mask with the call-preserved registers.
|
||||
// Proper defs for return values will be added by setPhysRegsDeadExcept().
|
||||
|
|
Loading…
Reference in New Issue