blob: f781ecb8997f4253dfe156beff267ec99e229d51 [file] [log] [blame]
Eugene Zelenkoc5eb8e22017-02-01 22:56:06 +00001//===--- AArch64CallLowering.cpp - Call lowering --------------------------===//
Quentin Colombetba2a0162016-02-16 19:26:02 +00002//
3// The LLVM Compiler Infrastructure
4//
5// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9///
10/// \file
11/// This file implements the lowering of LLVM calls to machine code calls for
12/// GlobalISel.
13///
14//===----------------------------------------------------------------------===//
15
16#include "AArch64CallLowering.h"
17#include "AArch64ISelLowering.h"
Tim Northovere9600d82017-02-08 17:57:27 +000018#include "AArch64MachineFunctionInfo.h"
19#include "AArch64Subtarget.h"
Eugene Zelenkoc5eb8e22017-02-01 22:56:06 +000020#include "llvm/ADT/ArrayRef.h"
21#include "llvm/ADT/SmallVector.h"
Tim Northoverb18ea162016-09-20 15:20:36 +000022#include "llvm/CodeGen/Analysis.h"
Eugene Zelenkoc5eb8e22017-02-01 22:56:06 +000023#include "llvm/CodeGen/CallingConvLower.h"
Quentin Colombetf38015e2016-12-22 21:56:31 +000024#include "llvm/CodeGen/GlobalISel/MachineIRBuilder.h"
Quentin Colombetf38015e2016-12-22 21:56:31 +000025#include "llvm/CodeGen/GlobalISel/Utils.h"
Eugene Zelenkoc5eb8e22017-02-01 22:56:06 +000026#include "llvm/CodeGen/LowLevelType.h"
27#include "llvm/CodeGen/MachineBasicBlock.h"
28#include "llvm/CodeGen/MachineFrameInfo.h"
29#include "llvm/CodeGen/MachineFunction.h"
Quentin Colombetba2a0162016-02-16 19:26:02 +000030#include "llvm/CodeGen/MachineInstrBuilder.h"
Eugene Zelenkoc5eb8e22017-02-01 22:56:06 +000031#include "llvm/CodeGen/MachineMemOperand.h"
32#include "llvm/CodeGen/MachineOperand.h"
Tim Northoverb18ea162016-09-20 15:20:36 +000033#include "llvm/CodeGen/MachineRegisterInfo.h"
Eugene Zelenkoc5eb8e22017-02-01 22:56:06 +000034#include "llvm/CodeGen/MachineValueType.h"
35#include "llvm/CodeGen/ValueTypes.h"
36#include "llvm/IR/Argument.h"
37#include "llvm/IR/Attributes.h"
38#include "llvm/IR/Function.h"
39#include "llvm/IR/Type.h"
40#include "llvm/IR/Value.h"
Tim Northover406024a2016-08-10 21:44:01 +000041#include "llvm/Target/TargetRegisterInfo.h"
42#include "llvm/Target/TargetSubtargetInfo.h"
Eugene Zelenkoc5eb8e22017-02-01 22:56:06 +000043#include <algorithm>
44#include <cassert>
45#include <cstdint>
46#include <iterator>
47
Quentin Colombetba2a0162016-02-16 19:26:02 +000048using namespace llvm;
49
Quentin Colombet789ad562016-04-07 20:47:51 +000050#ifndef LLVM_BUILD_GLOBAL_ISEL
Quentin Colombet6cc73ce2016-04-07 20:49:15 +000051#error "This shouldn't be built without GISel"
Quentin Colombet789ad562016-04-07 20:47:51 +000052#endif
53
Quentin Colombetba2a0162016-02-16 19:26:02 +000054AArch64CallLowering::AArch64CallLowering(const AArch64TargetLowering &TLI)
Eugene Zelenkoc5eb8e22017-02-01 22:56:06 +000055 : CallLowering(&TLI) {}
Quentin Colombetba2a0162016-02-16 19:26:02 +000056
Diana Picusf11f0422016-12-05 10:40:33 +000057struct IncomingArgHandler : public CallLowering::ValueHandler {
Tim Northoverd9433542017-01-17 22:30:10 +000058 IncomingArgHandler(MachineIRBuilder &MIRBuilder, MachineRegisterInfo &MRI,
59 CCAssignFn *AssignFn)
Tim Northovere9600d82017-02-08 17:57:27 +000060 : ValueHandler(MIRBuilder, MRI, AssignFn), StackUsed(0) {}
Tim Northovera5e38fa2016-09-22 13:49:25 +000061
62 unsigned getStackAddress(uint64_t Size, int64_t Offset,
63 MachinePointerInfo &MPO) override {
64 auto &MFI = MIRBuilder.getMF().getFrameInfo();
65 int FI = MFI.CreateFixedObject(Size, Offset, true);
66 MPO = MachinePointerInfo::getFixedStack(MIRBuilder.getMF(), FI);
67 unsigned AddrReg = MRI.createGenericVirtualRegister(LLT::pointer(0, 64));
68 MIRBuilder.buildFrameIndex(AddrReg, FI);
Tim Northovere9600d82017-02-08 17:57:27 +000069 StackUsed = std::max(StackUsed, Size + Offset);
Tim Northovera5e38fa2016-09-22 13:49:25 +000070 return AddrReg;
71 }
72
73 void assignValueToReg(unsigned ValVReg, unsigned PhysReg,
74 CCValAssign &VA) override {
75 markPhysRegUsed(PhysReg);
76 MIRBuilder.buildCopy(ValVReg, PhysReg);
77 // FIXME: assert extension
78 }
79
80 void assignValueToAddress(unsigned ValVReg, unsigned Addr, uint64_t Size,
81 MachinePointerInfo &MPO, CCValAssign &VA) override {
82 auto MMO = MIRBuilder.getMF().getMachineMemOperand(
83 MPO, MachineMemOperand::MOLoad | MachineMemOperand::MOInvariant, Size,
84 0);
85 MIRBuilder.buildLoad(ValVReg, Addr, *MMO);
86 }
87
88 /// How the physical register gets marked varies between formal
89 /// parameters (it's a basic-block live-in), and a call instruction
90 /// (it's an implicit-def of the BL).
91 virtual void markPhysRegUsed(unsigned PhysReg) = 0;
Tim Northovere9600d82017-02-08 17:57:27 +000092
93 uint64_t StackUsed;
Tim Northovera5e38fa2016-09-22 13:49:25 +000094};
95
96struct FormalArgHandler : public IncomingArgHandler {
Tim Northoverd9433542017-01-17 22:30:10 +000097 FormalArgHandler(MachineIRBuilder &MIRBuilder, MachineRegisterInfo &MRI,
98 CCAssignFn *AssignFn)
99 : IncomingArgHandler(MIRBuilder, MRI, AssignFn) {}
Tim Northovera5e38fa2016-09-22 13:49:25 +0000100
101 void markPhysRegUsed(unsigned PhysReg) override {
102 MIRBuilder.getMBB().addLiveIn(PhysReg);
103 }
104};
105
106struct CallReturnHandler : public IncomingArgHandler {
107 CallReturnHandler(MachineIRBuilder &MIRBuilder, MachineRegisterInfo &MRI,
Tim Northoverd9433542017-01-17 22:30:10 +0000108 MachineInstrBuilder MIB, CCAssignFn *AssignFn)
109 : IncomingArgHandler(MIRBuilder, MRI, AssignFn), MIB(MIB) {}
Tim Northovera5e38fa2016-09-22 13:49:25 +0000110
111 void markPhysRegUsed(unsigned PhysReg) override {
112 MIB.addDef(PhysReg, RegState::Implicit);
113 }
114
115 MachineInstrBuilder MIB;
116};
117
Diana Picusf11f0422016-12-05 10:40:33 +0000118struct OutgoingArgHandler : public CallLowering::ValueHandler {
Tim Northovera5e38fa2016-09-22 13:49:25 +0000119 OutgoingArgHandler(MachineIRBuilder &MIRBuilder, MachineRegisterInfo &MRI,
Tim Northoverd9433542017-01-17 22:30:10 +0000120 MachineInstrBuilder MIB, CCAssignFn *AssignFn,
121 CCAssignFn *AssignFnVarArg)
122 : ValueHandler(MIRBuilder, MRI, AssignFn), MIB(MIB),
Tim Northover509091f2017-01-17 22:43:34 +0000123 AssignFnVarArg(AssignFnVarArg), StackSize(0) {}
Tim Northovera5e38fa2016-09-22 13:49:25 +0000124
125 unsigned getStackAddress(uint64_t Size, int64_t Offset,
126 MachinePointerInfo &MPO) override {
127 LLT p0 = LLT::pointer(0, 64);
128 LLT s64 = LLT::scalar(64);
129 unsigned SPReg = MRI.createGenericVirtualRegister(p0);
130 MIRBuilder.buildCopy(SPReg, AArch64::SP);
131
132 unsigned OffsetReg = MRI.createGenericVirtualRegister(s64);
133 MIRBuilder.buildConstant(OffsetReg, Offset);
134
135 unsigned AddrReg = MRI.createGenericVirtualRegister(p0);
136 MIRBuilder.buildGEP(AddrReg, SPReg, OffsetReg);
137
138 MPO = MachinePointerInfo::getStack(MIRBuilder.getMF(), Offset);
139 return AddrReg;
140 }
141
142 void assignValueToReg(unsigned ValVReg, unsigned PhysReg,
143 CCValAssign &VA) override {
144 MIB.addUse(PhysReg, RegState::Implicit);
145 unsigned ExtReg = extendRegister(ValVReg, VA);
146 MIRBuilder.buildCopy(PhysReg, ExtReg);
147 }
148
149 void assignValueToAddress(unsigned ValVReg, unsigned Addr, uint64_t Size,
150 MachinePointerInfo &MPO, CCValAssign &VA) override {
151 auto MMO = MIRBuilder.getMF().getMachineMemOperand(
152 MPO, MachineMemOperand::MOStore, Size, 0);
153 MIRBuilder.buildStore(ValVReg, Addr, *MMO);
154 }
155
Eugene Zelenkoc5eb8e22017-02-01 22:56:06 +0000156 bool assignArg(unsigned ValNo, MVT ValVT, MVT LocVT,
157 CCValAssign::LocInfo LocInfo,
158 const CallLowering::ArgInfo &Info,
159 CCState &State) override {
Tim Northovere80d6d12017-03-02 15:34:18 +0000160 bool Res;
Tim Northoverd9433542017-01-17 22:30:10 +0000161 if (Info.IsFixed)
Tim Northovere80d6d12017-03-02 15:34:18 +0000162 Res = AssignFn(ValNo, ValVT, LocVT, LocInfo, Info.Flags, State);
163 else
164 Res = AssignFnVarArg(ValNo, ValVT, LocVT, LocInfo, Info.Flags, State);
165
166 StackSize = State.getNextStackOffset();
167 return Res;
Tim Northoverd9433542017-01-17 22:30:10 +0000168 }
169
Tim Northovera5e38fa2016-09-22 13:49:25 +0000170 MachineInstrBuilder MIB;
Tim Northoverd9433542017-01-17 22:30:10 +0000171 CCAssignFn *AssignFnVarArg;
Tim Northover509091f2017-01-17 22:43:34 +0000172 uint64_t StackSize;
Tim Northovera5e38fa2016-09-22 13:49:25 +0000173};
174
Benjamin Kramer061f4a52017-01-13 14:39:03 +0000175void AArch64CallLowering::splitToValueTypes(
176 const ArgInfo &OrigArg, SmallVectorImpl<ArgInfo> &SplitArgs,
177 const DataLayout &DL, MachineRegisterInfo &MRI,
178 const SplitArgTy &PerformArgSplit) const {
Tim Northoverb18ea162016-09-20 15:20:36 +0000179 const AArch64TargetLowering &TLI = *getTLI<AArch64TargetLowering>();
Tim Northover9a467182016-09-21 12:57:45 +0000180 LLVMContext &Ctx = OrigArg.Ty->getContext();
Tim Northoverb18ea162016-09-20 15:20:36 +0000181
182 SmallVector<EVT, 4> SplitVTs;
183 SmallVector<uint64_t, 4> Offsets;
Tim Northover9a467182016-09-21 12:57:45 +0000184 ComputeValueVTs(TLI, DL, OrigArg.Ty, SplitVTs, &Offsets, 0);
Tim Northoverb18ea162016-09-20 15:20:36 +0000185
186 if (SplitVTs.size() == 1) {
Tim Northoverd1fd3832016-12-05 21:25:33 +0000187 // No splitting to do, but we want to replace the original type (e.g. [1 x
188 // double] -> double).
189 SplitArgs.emplace_back(OrigArg.Reg, SplitVTs[0].getTypeForEVT(Ctx),
Tim Northoverd9433542017-01-17 22:30:10 +0000190 OrigArg.Flags, OrigArg.IsFixed);
Tim Northoverb18ea162016-09-20 15:20:36 +0000191 return;
192 }
193
Tim Northover9a467182016-09-21 12:57:45 +0000194 unsigned FirstRegIdx = SplitArgs.size();
Tim Northoverb18ea162016-09-20 15:20:36 +0000195 for (auto SplitVT : SplitVTs) {
Tim Northover9a467182016-09-21 12:57:45 +0000196 // FIXME: set split flags if they're actually used (e.g. i128 on AAPCS).
Tim Northoverb18ea162016-09-20 15:20:36 +0000197 Type *SplitTy = SplitVT.getTypeForEVT(Ctx);
Tim Northover9a467182016-09-21 12:57:45 +0000198 SplitArgs.push_back(
Daniel Sanders52b4ce72017-03-07 23:20:35 +0000199 ArgInfo{MRI.createGenericVirtualRegister(getLLTForType(*SplitTy, DL)),
200 SplitTy, OrigArg.Flags, OrigArg.IsFixed});
Tim Northoverb18ea162016-09-20 15:20:36 +0000201 }
202
Tim Northoverc2c545b2017-03-06 23:50:28 +0000203 for (unsigned i = 0; i < Offsets.size(); ++i)
204 PerformArgSplit(SplitArgs[FirstRegIdx + i].Reg, Offsets[i] * 8);
Tim Northoverb18ea162016-09-20 15:20:36 +0000205}
206
207bool AArch64CallLowering::lowerReturn(MachineIRBuilder &MIRBuilder,
208 const Value *Val, unsigned VReg) const {
209 MachineFunction &MF = MIRBuilder.getMF();
210 const Function &F = *MF.getFunction();
211
Tim Northover05cc4852016-12-07 21:05:38 +0000212 auto MIB = MIRBuilder.buildInstrNoInsert(AArch64::RET_ReallyLR);
Tim Northoverb18ea162016-09-20 15:20:36 +0000213 assert(((Val && VReg) || (!Val && !VReg)) && "Return value without a vreg");
Tim Northover05cc4852016-12-07 21:05:38 +0000214 bool Success = true;
Tim Northoverb18ea162016-09-20 15:20:36 +0000215 if (VReg) {
Tim Northoverb18ea162016-09-20 15:20:36 +0000216 const AArch64TargetLowering &TLI = *getTLI<AArch64TargetLowering>();
217 CCAssignFn *AssignFn = TLI.CCAssignFnForReturn(F.getCallingConv());
218 MachineRegisterInfo &MRI = MF.getRegInfo();
219 auto &DL = F.getParent()->getDataLayout();
220
Tim Northover9a467182016-09-21 12:57:45 +0000221 ArgInfo OrigArg{VReg, Val->getType()};
222 setArgFlags(OrigArg, AttributeSet::ReturnIndex, DL, F);
223
224 SmallVector<ArgInfo, 8> SplitArgs;
225 splitToValueTypes(OrigArg, SplitArgs, DL, MRI,
Tim Northoverc2c545b2017-03-06 23:50:28 +0000226 [&](unsigned Reg, uint64_t Offset) {
227 MIRBuilder.buildExtract(Reg, VReg, Offset);
Tim Northoverb18ea162016-09-20 15:20:36 +0000228 });
229
Tim Northoverd9433542017-01-17 22:30:10 +0000230 OutgoingArgHandler Handler(MIRBuilder, MRI, MIB, AssignFn, AssignFn);
231 Success = handleAssignments(MIRBuilder, SplitArgs, Handler);
Tim Northoverb18ea162016-09-20 15:20:36 +0000232 }
Tim Northover05cc4852016-12-07 21:05:38 +0000233
234 MIRBuilder.insertInstr(MIB);
235 return Success;
Tim Northoverb18ea162016-09-20 15:20:36 +0000236}
237
Tim Northover862758ec2016-09-21 12:57:35 +0000238bool AArch64CallLowering::lowerFormalArguments(MachineIRBuilder &MIRBuilder,
239 const Function &F,
240 ArrayRef<unsigned> VRegs) const {
Tim Northover406024a2016-08-10 21:44:01 +0000241 MachineFunction &MF = MIRBuilder.getMF();
Tim Northoverb18ea162016-09-20 15:20:36 +0000242 MachineBasicBlock &MBB = MIRBuilder.getMBB();
243 MachineRegisterInfo &MRI = MF.getRegInfo();
Tim Northoverb18ea162016-09-20 15:20:36 +0000244 auto &DL = F.getParent()->getDataLayout();
Tim Northover406024a2016-08-10 21:44:01 +0000245
Tim Northover9a467182016-09-21 12:57:45 +0000246 SmallVector<ArgInfo, 8> SplitArgs;
Tim Northoverb18ea162016-09-20 15:20:36 +0000247 unsigned i = 0;
Reid Kleckner45707d42017-03-16 22:59:15 +0000248 for (auto &Arg : F.args()) {
Tim Northover9a467182016-09-21 12:57:45 +0000249 ArgInfo OrigArg{VRegs[i], Arg.getType()};
250 setArgFlags(OrigArg, i + 1, DL, F);
Tim Northoverc2c545b2017-03-06 23:50:28 +0000251 bool Split = false;
252 LLT Ty = MRI.getType(VRegs[i]);
253 unsigned Dst = VRegs[i];
254
Tim Northover9a467182016-09-21 12:57:45 +0000255 splitToValueTypes(OrigArg, SplitArgs, DL, MRI,
Tim Northoverc2c545b2017-03-06 23:50:28 +0000256 [&](unsigned Reg, uint64_t Offset) {
257 if (!Split) {
258 Split = true;
259 Dst = MRI.createGenericVirtualRegister(Ty);
260 MIRBuilder.buildUndef(Dst);
261 }
262 unsigned Tmp = MRI.createGenericVirtualRegister(Ty);
263 MIRBuilder.buildInsert(Tmp, Dst, Reg, Offset);
264 Dst = Tmp;
Tim Northoverb18ea162016-09-20 15:20:36 +0000265 });
Tim Northoverc2c545b2017-03-06 23:50:28 +0000266
267 if (Dst != VRegs[i])
268 MIRBuilder.buildCopy(VRegs[i], Dst);
Tim Northoverb18ea162016-09-20 15:20:36 +0000269 ++i;
270 }
271
272 if (!MBB.empty())
273 MIRBuilder.setInstr(*MBB.begin());
Tim Northover406024a2016-08-10 21:44:01 +0000274
275 const AArch64TargetLowering &TLI = *getTLI<AArch64TargetLowering>();
276 CCAssignFn *AssignFn =
277 TLI.CCAssignFnForCall(F.getCallingConv(), /*IsVarArg=*/false);
278
Tim Northoverd9433542017-01-17 22:30:10 +0000279 FormalArgHandler Handler(MIRBuilder, MRI, AssignFn);
280 if (!handleAssignments(MIRBuilder, SplitArgs, Handler))
Tim Northover9a467182016-09-21 12:57:45 +0000281 return false;
Tim Northoverb18ea162016-09-20 15:20:36 +0000282
Tim Northovere9600d82017-02-08 17:57:27 +0000283 if (F.isVarArg()) {
284 if (!MF.getSubtarget<AArch64Subtarget>().isTargetDarwin()) {
285 // FIXME: we need to reimplement saveVarArgsRegisters from
286 // AArch64ISelLowering.
287 return false;
288 }
289
290 // We currently pass all varargs at 8-byte alignment.
291 uint64_t StackOffset = alignTo(Handler.StackUsed, 8);
292
293 auto &MFI = MIRBuilder.getMF().getFrameInfo();
294 AArch64FunctionInfo *FuncInfo = MF.getInfo<AArch64FunctionInfo>();
295 FuncInfo->setVarArgsStackIndex(MFI.CreateFixedObject(4, StackOffset, true));
296 }
297
Tim Northoverb18ea162016-09-20 15:20:36 +0000298 // Move back to the end of the basic block.
299 MIRBuilder.setMBB(MBB);
300
Tim Northover9a467182016-09-21 12:57:45 +0000301 return true;
Tim Northover406024a2016-08-10 21:44:01 +0000302}
303
304bool AArch64CallLowering::lowerCall(MachineIRBuilder &MIRBuilder,
Diana Picusd79253a2017-03-20 14:40:18 +0000305 CallingConv::ID CallConv,
Tim Northover9a467182016-09-21 12:57:45 +0000306 const MachineOperand &Callee,
307 const ArgInfo &OrigRet,
308 ArrayRef<ArgInfo> OrigArgs) const {
Tim Northover406024a2016-08-10 21:44:01 +0000309 MachineFunction &MF = MIRBuilder.getMF();
310 const Function &F = *MF.getFunction();
Tim Northoverb18ea162016-09-20 15:20:36 +0000311 MachineRegisterInfo &MRI = MF.getRegInfo();
312 auto &DL = F.getParent()->getDataLayout();
313
Tim Northover9a467182016-09-21 12:57:45 +0000314 SmallVector<ArgInfo, 8> SplitArgs;
315 for (auto &OrigArg : OrigArgs) {
316 splitToValueTypes(OrigArg, SplitArgs, DL, MRI,
Tim Northoverc2c545b2017-03-06 23:50:28 +0000317 [&](unsigned Reg, uint64_t Offset) {
318 MIRBuilder.buildExtract(Reg, OrigArg.Reg, Offset);
Tim Northoverb18ea162016-09-20 15:20:36 +0000319 });
320 }
Tim Northover406024a2016-08-10 21:44:01 +0000321
Tim Northover406024a2016-08-10 21:44:01 +0000322 // Find out which ABI gets to decide where things go.
323 const AArch64TargetLowering &TLI = *getTLI<AArch64TargetLowering>();
Tim Northoverd9433542017-01-17 22:30:10 +0000324 CCAssignFn *AssignFnFixed =
Diana Picusd79253a2017-03-20 14:40:18 +0000325 TLI.CCAssignFnForCall(CallConv, /*IsVarArg=*/false);
Tim Northoverd9433542017-01-17 22:30:10 +0000326 CCAssignFn *AssignFnVarArg =
Diana Picusd79253a2017-03-20 14:40:18 +0000327 TLI.CCAssignFnForCall(CallConv, /*IsVarArg=*/true);
Tim Northover406024a2016-08-10 21:44:01 +0000328
Tim Northover509091f2017-01-17 22:43:34 +0000329 auto CallSeqStart = MIRBuilder.buildInstr(AArch64::ADJCALLSTACKDOWN);
330
Tim Northovera5e38fa2016-09-22 13:49:25 +0000331 // Create a temporarily-floating call instruction so we can add the implicit
332 // uses of arg registers.
333 auto MIB = MIRBuilder.buildInstrNoInsert(Callee.isReg() ? AArch64::BLR
334 : AArch64::BL);
Diana Picus116bbab2017-01-13 09:58:52 +0000335 MIB.add(Callee);
Tim Northover406024a2016-08-10 21:44:01 +0000336
337 // Tell the call which registers are clobbered.
338 auto TRI = MF.getSubtarget().getRegisterInfo();
339 MIB.addRegMask(TRI->getCallPreservedMask(MF, F.getCallingConv()));
340
Tim Northovera5e38fa2016-09-22 13:49:25 +0000341 // Do the actual argument marshalling.
342 SmallVector<unsigned, 8> PhysRegs;
Tim Northoverd9433542017-01-17 22:30:10 +0000343 OutgoingArgHandler Handler(MIRBuilder, MRI, MIB, AssignFnFixed,
344 AssignFnVarArg);
345 if (!handleAssignments(MIRBuilder, SplitArgs, Handler))
Tim Northovera5e38fa2016-09-22 13:49:25 +0000346 return false;
347
348 // Now we can add the actual call instruction to the correct basic block.
349 MIRBuilder.insertInstr(MIB);
Tim Northover406024a2016-08-10 21:44:01 +0000350
Quentin Colombetf38015e2016-12-22 21:56:31 +0000351 // If Callee is a reg, since it is used by a target specific
352 // instruction, it must have a register class matching the
353 // constraint of that instruction.
354 if (Callee.isReg())
355 MIB->getOperand(0).setReg(constrainOperandRegClass(
356 MF, *TRI, MRI, *MF.getSubtarget().getInstrInfo(),
357 *MF.getSubtarget().getRegBankInfo(), *MIB, MIB->getDesc(),
358 Callee.getReg(), 0));
359
Tim Northover406024a2016-08-10 21:44:01 +0000360 // Finally we can copy the returned value back into its virtual-register. In
361 // symmetry with the arugments, the physical register must be an
362 // implicit-define of the call instruction.
363 CCAssignFn *RetAssignFn = TLI.CCAssignFnForReturn(F.getCallingConv());
Tim Northover9a467182016-09-21 12:57:45 +0000364 if (OrigRet.Reg) {
365 SplitArgs.clear();
Tim Northoverb18ea162016-09-20 15:20:36 +0000366
367 SmallVector<uint64_t, 8> RegOffsets;
Tim Northover9a467182016-09-21 12:57:45 +0000368 SmallVector<unsigned, 8> SplitRegs;
369 splitToValueTypes(OrigRet, SplitArgs, DL, MRI,
Tim Northoverc2c545b2017-03-06 23:50:28 +0000370 [&](unsigned Reg, uint64_t Offset) {
371 RegOffsets.push_back(Offset);
372 SplitRegs.push_back(Reg);
Tim Northoverb18ea162016-09-20 15:20:36 +0000373 });
374
Tim Northoverd9433542017-01-17 22:30:10 +0000375 CallReturnHandler Handler(MIRBuilder, MRI, MIB, RetAssignFn);
376 if (!handleAssignments(MIRBuilder, SplitArgs, Handler))
Tim Northover9a467182016-09-21 12:57:45 +0000377 return false;
Tim Northover406024a2016-08-10 21:44:01 +0000378
Tim Northoverb18ea162016-09-20 15:20:36 +0000379 if (!RegOffsets.empty())
Tim Northover9a467182016-09-21 12:57:45 +0000380 MIRBuilder.buildSequence(OrigRet.Reg, SplitRegs, RegOffsets);
Tim Northoverb18ea162016-09-20 15:20:36 +0000381 }
382
Tim Northover509091f2017-01-17 22:43:34 +0000383 CallSeqStart.addImm(Handler.StackSize);
384 MIRBuilder.buildInstr(AArch64::ADJCALLSTACKUP)
385 .addImm(Handler.StackSize)
386 .addImm(0);
387
Tim Northover406024a2016-08-10 21:44:01 +0000388 return true;
389}