blob: c8a3ce5463ef34ab89cbf006a43d2673e3f4a624 [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"
Eugene Zelenkoc5eb8e22017-02-01 22:56:06 +000018#include "llvm/ADT/ArrayRef.h"
19#include "llvm/ADT/SmallVector.h"
Tim Northoverb18ea162016-09-20 15:20:36 +000020#include "llvm/CodeGen/Analysis.h"
Eugene Zelenkoc5eb8e22017-02-01 22:56:06 +000021#include "llvm/CodeGen/CallingConvLower.h"
Quentin Colombetf38015e2016-12-22 21:56:31 +000022#include "llvm/CodeGen/GlobalISel/MachineIRBuilder.h"
Quentin Colombetf38015e2016-12-22 21:56:31 +000023#include "llvm/CodeGen/GlobalISel/Utils.h"
Eugene Zelenkoc5eb8e22017-02-01 22:56:06 +000024#include "llvm/CodeGen/LowLevelType.h"
25#include "llvm/CodeGen/MachineBasicBlock.h"
26#include "llvm/CodeGen/MachineFrameInfo.h"
27#include "llvm/CodeGen/MachineFunction.h"
Quentin Colombetba2a0162016-02-16 19:26:02 +000028#include "llvm/CodeGen/MachineInstrBuilder.h"
Eugene Zelenkoc5eb8e22017-02-01 22:56:06 +000029#include "llvm/CodeGen/MachineMemOperand.h"
30#include "llvm/CodeGen/MachineOperand.h"
Tim Northoverb18ea162016-09-20 15:20:36 +000031#include "llvm/CodeGen/MachineRegisterInfo.h"
Eugene Zelenkoc5eb8e22017-02-01 22:56:06 +000032#include "llvm/CodeGen/MachineValueType.h"
33#include "llvm/CodeGen/ValueTypes.h"
34#include "llvm/IR/Argument.h"
35#include "llvm/IR/Attributes.h"
36#include "llvm/IR/Function.h"
37#include "llvm/IR/Type.h"
38#include "llvm/IR/Value.h"
Tim Northover406024a2016-08-10 21:44:01 +000039#include "llvm/Target/TargetRegisterInfo.h"
40#include "llvm/Target/TargetSubtargetInfo.h"
Eugene Zelenkoc5eb8e22017-02-01 22:56:06 +000041#include <algorithm>
42#include <cassert>
43#include <cstdint>
44#include <iterator>
45
Quentin Colombetba2a0162016-02-16 19:26:02 +000046using namespace llvm;
47
Quentin Colombet789ad562016-04-07 20:47:51 +000048#ifndef LLVM_BUILD_GLOBAL_ISEL
Quentin Colombet6cc73ce2016-04-07 20:49:15 +000049#error "This shouldn't be built without GISel"
Quentin Colombet789ad562016-04-07 20:47:51 +000050#endif
51
Quentin Colombetba2a0162016-02-16 19:26:02 +000052AArch64CallLowering::AArch64CallLowering(const AArch64TargetLowering &TLI)
Eugene Zelenkoc5eb8e22017-02-01 22:56:06 +000053 : CallLowering(&TLI) {}
Quentin Colombetba2a0162016-02-16 19:26:02 +000054
Diana Picusf11f0422016-12-05 10:40:33 +000055struct IncomingArgHandler : public CallLowering::ValueHandler {
Tim Northoverd9433542017-01-17 22:30:10 +000056 IncomingArgHandler(MachineIRBuilder &MIRBuilder, MachineRegisterInfo &MRI,
57 CCAssignFn *AssignFn)
58 : ValueHandler(MIRBuilder, MRI, AssignFn) {}
Tim Northovera5e38fa2016-09-22 13:49:25 +000059
60 unsigned getStackAddress(uint64_t Size, int64_t Offset,
61 MachinePointerInfo &MPO) override {
62 auto &MFI = MIRBuilder.getMF().getFrameInfo();
63 int FI = MFI.CreateFixedObject(Size, Offset, true);
64 MPO = MachinePointerInfo::getFixedStack(MIRBuilder.getMF(), FI);
65 unsigned AddrReg = MRI.createGenericVirtualRegister(LLT::pointer(0, 64));
66 MIRBuilder.buildFrameIndex(AddrReg, FI);
67 return AddrReg;
68 }
69
70 void assignValueToReg(unsigned ValVReg, unsigned PhysReg,
71 CCValAssign &VA) override {
72 markPhysRegUsed(PhysReg);
73 MIRBuilder.buildCopy(ValVReg, PhysReg);
74 // FIXME: assert extension
75 }
76
77 void assignValueToAddress(unsigned ValVReg, unsigned Addr, uint64_t Size,
78 MachinePointerInfo &MPO, CCValAssign &VA) override {
79 auto MMO = MIRBuilder.getMF().getMachineMemOperand(
80 MPO, MachineMemOperand::MOLoad | MachineMemOperand::MOInvariant, Size,
81 0);
82 MIRBuilder.buildLoad(ValVReg, Addr, *MMO);
83 }
84
85 /// How the physical register gets marked varies between formal
86 /// parameters (it's a basic-block live-in), and a call instruction
87 /// (it's an implicit-def of the BL).
88 virtual void markPhysRegUsed(unsigned PhysReg) = 0;
89};
90
91struct FormalArgHandler : public IncomingArgHandler {
Tim Northoverd9433542017-01-17 22:30:10 +000092 FormalArgHandler(MachineIRBuilder &MIRBuilder, MachineRegisterInfo &MRI,
93 CCAssignFn *AssignFn)
94 : IncomingArgHandler(MIRBuilder, MRI, AssignFn) {}
Tim Northovera5e38fa2016-09-22 13:49:25 +000095
96 void markPhysRegUsed(unsigned PhysReg) override {
97 MIRBuilder.getMBB().addLiveIn(PhysReg);
98 }
99};
100
101struct CallReturnHandler : public IncomingArgHandler {
102 CallReturnHandler(MachineIRBuilder &MIRBuilder, MachineRegisterInfo &MRI,
Tim Northoverd9433542017-01-17 22:30:10 +0000103 MachineInstrBuilder MIB, CCAssignFn *AssignFn)
104 : IncomingArgHandler(MIRBuilder, MRI, AssignFn), MIB(MIB) {}
Tim Northovera5e38fa2016-09-22 13:49:25 +0000105
106 void markPhysRegUsed(unsigned PhysReg) override {
107 MIB.addDef(PhysReg, RegState::Implicit);
108 }
109
110 MachineInstrBuilder MIB;
111};
112
Diana Picusf11f0422016-12-05 10:40:33 +0000113struct OutgoingArgHandler : public CallLowering::ValueHandler {
Tim Northovera5e38fa2016-09-22 13:49:25 +0000114 OutgoingArgHandler(MachineIRBuilder &MIRBuilder, MachineRegisterInfo &MRI,
Tim Northoverd9433542017-01-17 22:30:10 +0000115 MachineInstrBuilder MIB, CCAssignFn *AssignFn,
116 CCAssignFn *AssignFnVarArg)
117 : ValueHandler(MIRBuilder, MRI, AssignFn), MIB(MIB),
Tim Northover509091f2017-01-17 22:43:34 +0000118 AssignFnVarArg(AssignFnVarArg), StackSize(0) {}
Tim Northovera5e38fa2016-09-22 13:49:25 +0000119
120 unsigned getStackAddress(uint64_t Size, int64_t Offset,
121 MachinePointerInfo &MPO) override {
122 LLT p0 = LLT::pointer(0, 64);
123 LLT s64 = LLT::scalar(64);
124 unsigned SPReg = MRI.createGenericVirtualRegister(p0);
125 MIRBuilder.buildCopy(SPReg, AArch64::SP);
126
127 unsigned OffsetReg = MRI.createGenericVirtualRegister(s64);
128 MIRBuilder.buildConstant(OffsetReg, Offset);
129
130 unsigned AddrReg = MRI.createGenericVirtualRegister(p0);
131 MIRBuilder.buildGEP(AddrReg, SPReg, OffsetReg);
132
133 MPO = MachinePointerInfo::getStack(MIRBuilder.getMF(), Offset);
Tim Northover509091f2017-01-17 22:43:34 +0000134 StackSize = std::max(StackSize, Size + Offset);
Tim Northovera5e38fa2016-09-22 13:49:25 +0000135 return AddrReg;
136 }
137
138 void assignValueToReg(unsigned ValVReg, unsigned PhysReg,
139 CCValAssign &VA) override {
140 MIB.addUse(PhysReg, RegState::Implicit);
141 unsigned ExtReg = extendRegister(ValVReg, VA);
142 MIRBuilder.buildCopy(PhysReg, ExtReg);
143 }
144
145 void assignValueToAddress(unsigned ValVReg, unsigned Addr, uint64_t Size,
146 MachinePointerInfo &MPO, CCValAssign &VA) override {
147 auto MMO = MIRBuilder.getMF().getMachineMemOperand(
148 MPO, MachineMemOperand::MOStore, Size, 0);
149 MIRBuilder.buildStore(ValVReg, Addr, *MMO);
150 }
151
Eugene Zelenkoc5eb8e22017-02-01 22:56:06 +0000152 bool assignArg(unsigned ValNo, MVT ValVT, MVT LocVT,
153 CCValAssign::LocInfo LocInfo,
154 const CallLowering::ArgInfo &Info,
155 CCState &State) override {
Tim Northoverd9433542017-01-17 22:30:10 +0000156 if (Info.IsFixed)
157 return AssignFn(ValNo, ValVT, LocVT, LocInfo, Info.Flags, State);
158 return AssignFnVarArg(ValNo, ValVT, LocVT, LocInfo, Info.Flags, State);
159 }
160
Tim Northovera5e38fa2016-09-22 13:49:25 +0000161 MachineInstrBuilder MIB;
Tim Northoverd9433542017-01-17 22:30:10 +0000162 CCAssignFn *AssignFnVarArg;
Tim Northover509091f2017-01-17 22:43:34 +0000163 uint64_t StackSize;
Tim Northovera5e38fa2016-09-22 13:49:25 +0000164};
165
Benjamin Kramer061f4a52017-01-13 14:39:03 +0000166void AArch64CallLowering::splitToValueTypes(
167 const ArgInfo &OrigArg, SmallVectorImpl<ArgInfo> &SplitArgs,
168 const DataLayout &DL, MachineRegisterInfo &MRI,
169 const SplitArgTy &PerformArgSplit) const {
Tim Northoverb18ea162016-09-20 15:20:36 +0000170 const AArch64TargetLowering &TLI = *getTLI<AArch64TargetLowering>();
Tim Northover9a467182016-09-21 12:57:45 +0000171 LLVMContext &Ctx = OrigArg.Ty->getContext();
Tim Northoverb18ea162016-09-20 15:20:36 +0000172
173 SmallVector<EVT, 4> SplitVTs;
174 SmallVector<uint64_t, 4> Offsets;
Tim Northover9a467182016-09-21 12:57:45 +0000175 ComputeValueVTs(TLI, DL, OrigArg.Ty, SplitVTs, &Offsets, 0);
Tim Northoverb18ea162016-09-20 15:20:36 +0000176
177 if (SplitVTs.size() == 1) {
Tim Northoverd1fd3832016-12-05 21:25:33 +0000178 // No splitting to do, but we want to replace the original type (e.g. [1 x
179 // double] -> double).
180 SplitArgs.emplace_back(OrigArg.Reg, SplitVTs[0].getTypeForEVT(Ctx),
Tim Northoverd9433542017-01-17 22:30:10 +0000181 OrigArg.Flags, OrigArg.IsFixed);
Tim Northoverb18ea162016-09-20 15:20:36 +0000182 return;
183 }
184
Tim Northover9a467182016-09-21 12:57:45 +0000185 unsigned FirstRegIdx = SplitArgs.size();
Tim Northoverb18ea162016-09-20 15:20:36 +0000186 for (auto SplitVT : SplitVTs) {
Tim Northover9a467182016-09-21 12:57:45 +0000187 // FIXME: set split flags if they're actually used (e.g. i128 on AAPCS).
Tim Northoverb18ea162016-09-20 15:20:36 +0000188 Type *SplitTy = SplitVT.getTypeForEVT(Ctx);
Tim Northover9a467182016-09-21 12:57:45 +0000189 SplitArgs.push_back(
190 ArgInfo{MRI.createGenericVirtualRegister(LLT{*SplitTy, DL}), SplitTy,
Tim Northoverd9433542017-01-17 22:30:10 +0000191 OrigArg.Flags, OrigArg.IsFixed});
Tim Northoverb18ea162016-09-20 15:20:36 +0000192 }
193
194 SmallVector<uint64_t, 4> BitOffsets;
195 for (auto Offset : Offsets)
196 BitOffsets.push_back(Offset * 8);
197
Tim Northover9a467182016-09-21 12:57:45 +0000198 SmallVector<unsigned, 8> SplitRegs;
199 for (auto I = &SplitArgs[FirstRegIdx]; I != SplitArgs.end(); ++I)
200 SplitRegs.push_back(I->Reg);
201
202 PerformArgSplit(SplitRegs, BitOffsets);
Tim Northoverb18ea162016-09-20 15:20:36 +0000203}
204
205bool AArch64CallLowering::lowerReturn(MachineIRBuilder &MIRBuilder,
206 const Value *Val, unsigned VReg) const {
207 MachineFunction &MF = MIRBuilder.getMF();
208 const Function &F = *MF.getFunction();
209
Tim Northover05cc4852016-12-07 21:05:38 +0000210 auto MIB = MIRBuilder.buildInstrNoInsert(AArch64::RET_ReallyLR);
Tim Northoverb18ea162016-09-20 15:20:36 +0000211 assert(((Val && VReg) || (!Val && !VReg)) && "Return value without a vreg");
Tim Northover05cc4852016-12-07 21:05:38 +0000212 bool Success = true;
Tim Northoverb18ea162016-09-20 15:20:36 +0000213 if (VReg) {
Tim Northoverb18ea162016-09-20 15:20:36 +0000214 const AArch64TargetLowering &TLI = *getTLI<AArch64TargetLowering>();
215 CCAssignFn *AssignFn = TLI.CCAssignFnForReturn(F.getCallingConv());
216 MachineRegisterInfo &MRI = MF.getRegInfo();
217 auto &DL = F.getParent()->getDataLayout();
218
Tim Northover9a467182016-09-21 12:57:45 +0000219 ArgInfo OrigArg{VReg, Val->getType()};
220 setArgFlags(OrigArg, AttributeSet::ReturnIndex, DL, F);
221
222 SmallVector<ArgInfo, 8> SplitArgs;
223 splitToValueTypes(OrigArg, SplitArgs, DL, MRI,
Tim Northoverb18ea162016-09-20 15:20:36 +0000224 [&](ArrayRef<unsigned> Regs, ArrayRef<uint64_t> Offsets) {
225 MIRBuilder.buildExtract(Regs, Offsets, VReg);
226 });
227
Tim Northoverd9433542017-01-17 22:30:10 +0000228 OutgoingArgHandler Handler(MIRBuilder, MRI, MIB, AssignFn, AssignFn);
229 Success = handleAssignments(MIRBuilder, SplitArgs, Handler);
Tim Northoverb18ea162016-09-20 15:20:36 +0000230 }
Tim Northover05cc4852016-12-07 21:05:38 +0000231
232 MIRBuilder.insertInstr(MIB);
233 return Success;
Tim Northoverb18ea162016-09-20 15:20:36 +0000234}
235
Tim Northover862758ec2016-09-21 12:57:35 +0000236bool AArch64CallLowering::lowerFormalArguments(MachineIRBuilder &MIRBuilder,
237 const Function &F,
238 ArrayRef<unsigned> VRegs) const {
239 auto &Args = F.getArgumentList();
Tim Northover406024a2016-08-10 21:44:01 +0000240 MachineFunction &MF = MIRBuilder.getMF();
Tim Northoverb18ea162016-09-20 15:20:36 +0000241 MachineBasicBlock &MBB = MIRBuilder.getMBB();
242 MachineRegisterInfo &MRI = MF.getRegInfo();
Tim Northoverb18ea162016-09-20 15:20:36 +0000243 auto &DL = F.getParent()->getDataLayout();
Tim Northover406024a2016-08-10 21:44:01 +0000244
Tim Northover9a467182016-09-21 12:57:45 +0000245 SmallVector<ArgInfo, 8> SplitArgs;
Tim Northoverb18ea162016-09-20 15:20:36 +0000246 unsigned i = 0;
247 for (auto &Arg : Args) {
Tim Northover9a467182016-09-21 12:57:45 +0000248 ArgInfo OrigArg{VRegs[i], Arg.getType()};
249 setArgFlags(OrigArg, i + 1, DL, F);
250 splitToValueTypes(OrigArg, SplitArgs, DL, MRI,
Tim Northoverb18ea162016-09-20 15:20:36 +0000251 [&](ArrayRef<unsigned> Regs, ArrayRef<uint64_t> Offsets) {
252 MIRBuilder.buildSequence(VRegs[i], Regs, Offsets);
253 });
254 ++i;
255 }
256
257 if (!MBB.empty())
258 MIRBuilder.setInstr(*MBB.begin());
Tim Northover406024a2016-08-10 21:44:01 +0000259
260 const AArch64TargetLowering &TLI = *getTLI<AArch64TargetLowering>();
261 CCAssignFn *AssignFn =
262 TLI.CCAssignFnForCall(F.getCallingConv(), /*IsVarArg=*/false);
263
Tim Northoverd9433542017-01-17 22:30:10 +0000264 FormalArgHandler Handler(MIRBuilder, MRI, AssignFn);
265 if (!handleAssignments(MIRBuilder, SplitArgs, Handler))
Tim Northover9a467182016-09-21 12:57:45 +0000266 return false;
Tim Northoverb18ea162016-09-20 15:20:36 +0000267
268 // Move back to the end of the basic block.
269 MIRBuilder.setMBB(MBB);
270
Tim Northover9a467182016-09-21 12:57:45 +0000271 return true;
Tim Northover406024a2016-08-10 21:44:01 +0000272}
273
274bool AArch64CallLowering::lowerCall(MachineIRBuilder &MIRBuilder,
Tim Northover9a467182016-09-21 12:57:45 +0000275 const MachineOperand &Callee,
276 const ArgInfo &OrigRet,
277 ArrayRef<ArgInfo> OrigArgs) const {
Tim Northover406024a2016-08-10 21:44:01 +0000278 MachineFunction &MF = MIRBuilder.getMF();
279 const Function &F = *MF.getFunction();
Tim Northoverb18ea162016-09-20 15:20:36 +0000280 MachineRegisterInfo &MRI = MF.getRegInfo();
281 auto &DL = F.getParent()->getDataLayout();
282
Tim Northover9a467182016-09-21 12:57:45 +0000283 SmallVector<ArgInfo, 8> SplitArgs;
284 for (auto &OrigArg : OrigArgs) {
285 splitToValueTypes(OrigArg, SplitArgs, DL, MRI,
Tim Northoverb18ea162016-09-20 15:20:36 +0000286 [&](ArrayRef<unsigned> Regs, ArrayRef<uint64_t> Offsets) {
Tim Northover9a467182016-09-21 12:57:45 +0000287 MIRBuilder.buildExtract(Regs, Offsets, OrigArg.Reg);
Tim Northoverb18ea162016-09-20 15:20:36 +0000288 });
289 }
Tim Northover406024a2016-08-10 21:44:01 +0000290
Tim Northover406024a2016-08-10 21:44:01 +0000291 // Find out which ABI gets to decide where things go.
292 const AArch64TargetLowering &TLI = *getTLI<AArch64TargetLowering>();
Tim Northoverd9433542017-01-17 22:30:10 +0000293 CCAssignFn *AssignFnFixed =
Tim Northover406024a2016-08-10 21:44:01 +0000294 TLI.CCAssignFnForCall(F.getCallingConv(), /*IsVarArg=*/false);
Tim Northoverd9433542017-01-17 22:30:10 +0000295 CCAssignFn *AssignFnVarArg =
296 TLI.CCAssignFnForCall(F.getCallingConv(), /*IsVarArg=*/true);
Tim Northover406024a2016-08-10 21:44:01 +0000297
Tim Northover509091f2017-01-17 22:43:34 +0000298 auto CallSeqStart = MIRBuilder.buildInstr(AArch64::ADJCALLSTACKDOWN);
299
Tim Northovera5e38fa2016-09-22 13:49:25 +0000300 // Create a temporarily-floating call instruction so we can add the implicit
301 // uses of arg registers.
302 auto MIB = MIRBuilder.buildInstrNoInsert(Callee.isReg() ? AArch64::BLR
303 : AArch64::BL);
Diana Picus116bbab2017-01-13 09:58:52 +0000304 MIB.add(Callee);
Tim Northover406024a2016-08-10 21:44:01 +0000305
306 // Tell the call which registers are clobbered.
307 auto TRI = MF.getSubtarget().getRegisterInfo();
308 MIB.addRegMask(TRI->getCallPreservedMask(MF, F.getCallingConv()));
309
Tim Northovera5e38fa2016-09-22 13:49:25 +0000310 // Do the actual argument marshalling.
311 SmallVector<unsigned, 8> PhysRegs;
Tim Northoverd9433542017-01-17 22:30:10 +0000312 OutgoingArgHandler Handler(MIRBuilder, MRI, MIB, AssignFnFixed,
313 AssignFnVarArg);
314 if (!handleAssignments(MIRBuilder, SplitArgs, Handler))
Tim Northovera5e38fa2016-09-22 13:49:25 +0000315 return false;
316
317 // Now we can add the actual call instruction to the correct basic block.
318 MIRBuilder.insertInstr(MIB);
Tim Northover406024a2016-08-10 21:44:01 +0000319
Quentin Colombetf38015e2016-12-22 21:56:31 +0000320 // If Callee is a reg, since it is used by a target specific
321 // instruction, it must have a register class matching the
322 // constraint of that instruction.
323 if (Callee.isReg())
324 MIB->getOperand(0).setReg(constrainOperandRegClass(
325 MF, *TRI, MRI, *MF.getSubtarget().getInstrInfo(),
326 *MF.getSubtarget().getRegBankInfo(), *MIB, MIB->getDesc(),
327 Callee.getReg(), 0));
328
Tim Northover406024a2016-08-10 21:44:01 +0000329 // Finally we can copy the returned value back into its virtual-register. In
330 // symmetry with the arugments, the physical register must be an
331 // implicit-define of the call instruction.
332 CCAssignFn *RetAssignFn = TLI.CCAssignFnForReturn(F.getCallingConv());
Tim Northover9a467182016-09-21 12:57:45 +0000333 if (OrigRet.Reg) {
334 SplitArgs.clear();
Tim Northoverb18ea162016-09-20 15:20:36 +0000335
336 SmallVector<uint64_t, 8> RegOffsets;
Tim Northover9a467182016-09-21 12:57:45 +0000337 SmallVector<unsigned, 8> SplitRegs;
338 splitToValueTypes(OrigRet, SplitArgs, DL, MRI,
Tim Northoverb18ea162016-09-20 15:20:36 +0000339 [&](ArrayRef<unsigned> Regs, ArrayRef<uint64_t> Offsets) {
340 std::copy(Offsets.begin(), Offsets.end(),
341 std::back_inserter(RegOffsets));
Tim Northover9a467182016-09-21 12:57:45 +0000342 std::copy(Regs.begin(), Regs.end(),
343 std::back_inserter(SplitRegs));
Tim Northoverb18ea162016-09-20 15:20:36 +0000344 });
345
Tim Northoverd9433542017-01-17 22:30:10 +0000346 CallReturnHandler Handler(MIRBuilder, MRI, MIB, RetAssignFn);
347 if (!handleAssignments(MIRBuilder, SplitArgs, Handler))
Tim Northover9a467182016-09-21 12:57:45 +0000348 return false;
Tim Northover406024a2016-08-10 21:44:01 +0000349
Tim Northoverb18ea162016-09-20 15:20:36 +0000350 if (!RegOffsets.empty())
Tim Northover9a467182016-09-21 12:57:45 +0000351 MIRBuilder.buildSequence(OrigRet.Reg, SplitRegs, RegOffsets);
Tim Northoverb18ea162016-09-20 15:20:36 +0000352 }
353
Tim Northover509091f2017-01-17 22:43:34 +0000354 CallSeqStart.addImm(Handler.StackSize);
355 MIRBuilder.buildInstr(AArch64::ADJCALLSTACKUP)
356 .addImm(Handler.StackSize)
357 .addImm(0);
358
Tim Northover406024a2016-08-10 21:44:01 +0000359 return true;
360}