LLVM 23.0.0git
AArch64Subtarget.h
Go to the documentation of this file.
1//===--- AArch64Subtarget.h - Define Subtarget for the AArch64 -*- C++ -*--===//
2//
3// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4// See https://llvm.org/LICENSE.txt for license information.
5// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6//
7//===----------------------------------------------------------------------===//
8//
9// This file declares the AArch64 specific subclass of TargetSubtarget.
10//
11//===----------------------------------------------------------------------===//
12
13#ifndef LLVM_LIB_TARGET_AARCH64_AARCH64SUBTARGET_H
14#define LLVM_LIB_TARGET_AARCH64_AARCH64SUBTARGET_H
15
17#include "AArch64ISelLowering.h"
18#include "AArch64InstrInfo.h"
19#include "AArch64PointerAuth.h"
20#include "AArch64RegisterInfo.h"
28#include "llvm/IR/DataLayout.h"
30
31#define GET_SUBTARGETINFO_HEADER
32#include "AArch64GenSubtargetInfo.inc"
33
34namespace llvm {
35class GlobalValue;
36class StringRef;
37
39public:
42#define ARM_PROCESSOR_FAMILY(ENUM) ENUM,
43#include "llvm/TargetParser/AArch64TargetParserDef.inc"
44#undef ARM_PROCESSOR_FAMILY
45 };
46
47protected:
48 /// ARMProcFamily - ARM processor family: Cortex-A53, Cortex-A57, and others.
50
51 // Enable 64-bit vectorization in SLP.
53
54// Bool members corresponding to the SubtargetFeatures defined in tablegen
55#define GET_SUBTARGETINFO_MACRO(ATTRIBUTE, DEFAULT, GETTER) \
56 bool ATTRIBUTE = DEFAULT;
57#include "AArch64GenSubtargetInfo.inc"
58
63 // Default scatter/gather overhead.
64 unsigned ScatterOverhead = 10;
65 unsigned GatherOverhead = 10;
68 unsigned MaxPrefetchIterationsAhead = UINT_MAX;
73 unsigned MaxJumpTableSize = 0;
74 unsigned FixedLoadLatency = 0;
75
76 // ReserveXRegister[i] - X#i is not available as a general purpose register.
78
79 // ReserveXRegisterForRA[i] - X#i is not available for register allocator.
81
82 // CustomCallUsedXRegister[i] - X#i call saved.
84
86
89 std::optional<unsigned> StreamingHazardSize;
93 unsigned VScaleForTuning = 1;
95
97
98 /// TargetTriple - What processor and OS we're targeting.
100
105
106 /// GlobalISel related APIs.
107 std::unique_ptr<CallLowering> CallLoweringInfo;
108 std::unique_ptr<InlineAsmLowering> InlineAsmLoweringInfo;
109 std::unique_ptr<InstructionSelector> InstSelector;
110 std::unique_ptr<LegalizerInfo> Legalizer;
111 std::unique_ptr<RegisterBankInfo> RegBankInfo;
112
113private:
114 /// initializeSubtargetDependencies - Initializes using CPUString and the
115 /// passed in feature string so that we can use initializer lists for
116 /// subtarget initialization.
117 AArch64Subtarget &initializeSubtargetDependencies(StringRef FS,
118 StringRef CPUString,
119 StringRef TuneCPUString,
120 bool HasMinSize);
121
122 /// Initialize properties based on the selected processor family.
123 void initializeProperties(bool HasMinSize);
124
125public:
126 /// This constructor initializes the data members to match that
127 /// of the specified triple.
128 AArch64Subtarget(const Triple &TT, StringRef CPU, StringRef TuneCPU,
129 StringRef FS, const TargetMachine &TM, bool LittleEndian,
130 unsigned MinSVEVectorSizeInBitsOverride = 0,
131 unsigned MaxSVEVectorSizeInBitsOverride = 0,
132 bool IsStreaming = false, bool IsStreamingCompatible = false,
133 bool HasMinSize = false,
135
136// Getters for SubtargetFeatures defined in tablegen
137#define GET_SUBTARGETINFO_MACRO(ATTRIBUTE, DEFAULT, GETTER) \
138 bool GETTER() const { return ATTRIBUTE; }
139#include "AArch64GenSubtargetInfo.inc"
140
142 return &TSInfo;
143 }
144 const AArch64FrameLowering *getFrameLowering() const override {
145 return &FrameLowering;
146 }
147 const AArch64TargetLowering *getTargetLowering() const override {
148 return &TLInfo;
149 }
150 const AArch64InstrInfo *getInstrInfo() const override { return &InstrInfo; }
151 const AArch64RegisterInfo *getRegisterInfo() const override {
152 return &getInstrInfo()->getRegisterInfo();
153 }
154 const CallLowering *getCallLowering() const override;
155 const InlineAsmLowering *getInlineAsmLowering() const override;
157 const LegalizerInfo *getLegalizerInfo() const override;
158 const RegisterBankInfo *getRegBankInfo() const override;
159 const Triple &getTargetTriple() const { return TargetTriple; }
160 bool enableMachineScheduler() const override { return true; }
161 bool enablePostRAScheduler() const override { return usePostRAScheduler(); }
162 bool enableSubRegLiveness() const override { return EnableSubregLiveness; }
163 bool enableSpillageCopyElimination() const override { return true; }
164
165 bool enableMachinePipeliner() const override;
166 bool useDFAforSMS() const override { return false; }
167
168 /// Returns ARM processor family.
169 /// Avoid this function! CPU specifics should be kept local to this class
170 /// and preferably modeled with SubtargetFeatures or properties in
171 /// initializeProperties().
173 return ARMProcFamily;
174 }
175
176 /// Returns true if the processor is an Apple M-series or aligned A-series
177 /// (A14 or newer).
178 bool isAppleMLike() const {
179 switch (ARMProcFamily) {
180 case AppleA14:
181 case AppleA15:
182 case AppleA16:
183 case AppleA17:
184 case AppleM4:
185 case AppleM5:
186 return true;
187 default:
188 return false;
189 }
190 }
191
192 bool isXRaySupported() const override { return true; }
193
194 /// Returns true if the function has a streaming body.
195 bool isStreaming() const { return IsStreaming; }
196
197 /// Returns true if the function has a streaming-compatible body.
199
200 /// Returns the size of memory region that if accessed by both the CPU and
201 /// the SME unit could result in a hazard. 0 = disabled.
202 unsigned getStreamingHazardSize() const {
203 return StreamingHazardSize.value_or(
204 !hasSMEFA64() && hasSME() && hasSVE() ? 1024 : 0);
205 }
206
207 /// Returns true if the target has NEON and the function at runtime is known
208 /// to have NEON enabled (e.g. the function is known not to be in streaming-SVE
209 /// mode, which disables NEON instructions).
210 bool isNeonAvailable() const {
211 return hasNEON() &&
212 (hasSMEFA64() || (!isStreaming() && !isStreamingCompatible()));
213 }
214
215 /// Returns true if the target has SVE and can use the full range of SVE
216 /// instructions, for example because it knows the function is known not to be
217 /// in streaming-SVE mode or when the target has FEAT_FA64 enabled.
218 bool isSVEAvailable() const {
219 return hasSVE() &&
220 (hasSMEFA64() || (!isStreaming() && !isStreamingCompatible()));
221 }
222
223 /// Returns true if the target has access to the streaming-compatible subset
224 /// of SVE instructions.
225 bool isStreamingSVEAvailable() const { return hasSME() && isStreaming(); }
226
227 /// Returns true if the target has access to either the full range of SVE
228 /// instructions, or the streaming-compatible subset of SVE instructions.
230 return hasSVE() || isStreamingSVEAvailable();
231 }
232
233 /// Returns true if the target has access to either the full range of SVE
234 /// instructions, or the streaming-compatible subset of SVE instructions
235 /// available to SME2.
237 return isSVEAvailable() || (isSVEorStreamingSVEAvailable() && hasSME2());
238 }
239
241 // Don't assume any minimum vector size when PSTATE.SM may not be 0, because
242 // we don't yet support streaming-compatible codegen support that we trust
243 // is safe for functions that may be executed in streaming-SVE mode.
244 // By returning '0' here, we disable vectorization.
245 if (!isSVEAvailable() && !isNeonAvailable())
246 return 0;
248 }
249
250 bool isXRegisterReserved(size_t i) const { return ReserveXRegister[i]; }
251 bool isXRegisterReservedForRA(size_t i) const { return ReserveXRegisterForRA[i]; }
252 unsigned getNumXRegisterReserved() const {
253 BitVector AllReservedX(AArch64::GPR64commonRegClass.getNumRegs());
254 AllReservedX |= ReserveXRegister;
255 AllReservedX |= ReserveXRegisterForRA;
256 return AllReservedX.count();
257 }
258 bool isLRReservedForRA() const { return ReserveLRForRA; }
259 bool isXRegCustomCalleeSaved(size_t i) const {
260 return CustomCallSavedXRegs[i];
261 }
262 bool hasCustomCallingConv() const { return CustomCallSavedXRegs.any(); }
263
264 /// Return true if the CPU supports any kind of instruction fusion.
265 bool hasFusion() const {
266 return hasArithmeticBccFusion() || hasArithmeticCbzFusion() ||
267 hasFuseAES() || hasFuseArithmeticLogic() || hasFuseCmpCSel() ||
268 hasFuseFCmpFCSel() || hasFuseCmpCSet() || hasFuseAdrpAdd() ||
269 hasFuseLiterals();
270 }
271
274 }
275 unsigned getMaxInterleaveFactor() const { return MaxInterleaveFactor; }
276 unsigned getVectorInsertExtractBaseCost() const;
277 unsigned getCacheLineSize() const override { return CacheLineSize; }
278 unsigned getScatterOverhead() const { return ScatterOverhead; }
279 unsigned getGatherOverhead() const { return GatherOverhead; }
280 unsigned getPrefetchDistance() const override { return PrefetchDistance; }
281 unsigned getMinPrefetchStride(unsigned NumMemAccesses,
282 unsigned NumStridedMemAccesses,
283 unsigned NumPrefetches,
284 bool HasCall) const override {
285 return MinPrefetchStride;
286 }
287 unsigned getMaxPrefetchIterationsAhead() const override {
289 }
294
297 }
298
299 unsigned getMaximumJumpTableSize() const { return MaxJumpTableSize; }
300 unsigned getMinimumJumpTableEntries() const {
302 }
303
304 unsigned getFixedLoadLatency() const { return FixedLoadLatency; }
305
306 /// CPU has TBI (top byte of addresses is ignored during HW address
307 /// translation) and OS enables it.
309
310 bool isLittleEndian() const { return IsLittle; }
311
312 bool isTargetDarwin() const { return TargetTriple.isOSDarwin(); }
313 bool isTargetIOS() const { return TargetTriple.isiOS(); }
314 bool isTargetLinux() const { return TargetTriple.isOSLinux(); }
315 bool isTargetWindows() const { return TargetTriple.isOSWindows(); }
316 bool isTargetAndroid() const { return TargetTriple.isAndroid(); }
317 bool isTargetFuchsia() const { return TargetTriple.isOSFuchsia(); }
318 bool isWindowsArm64EC() const { return TargetTriple.isWindowsArm64EC(); }
319 bool isLFI() const { return TargetTriple.isLFI(); }
320
321 bool isTargetCOFF() const { return TargetTriple.isOSBinFormatCOFF(); }
322 bool isTargetELF() const { return TargetTriple.isOSBinFormatELF(); }
323 bool isTargetMachO() const { return TargetTriple.isOSBinFormatMachO(); }
324
325 bool isTargetILP32() const {
326 return TargetTriple.isArch32Bit() ||
327 TargetTriple.getEnvironment() == Triple::GNUILP32;
328 }
329
330 bool useAA() const override;
331
332 bool addrSinkUsingGEPs() const override {
333 // Keeping GEPs inbounds is important for exploiting AArch64
334 // addressing-modes in ILP32 mode.
335 return useAA() || isTargetILP32();
336 }
337
338 bool useSmallAddressing() const {
339 switch (TLInfo.getTargetMachine().getCodeModel()) {
341 // Kernel is currently allowed only for Fuchsia targets,
342 // where it is the same as Small for almost all purposes.
343 case CodeModel::Small:
344 return true;
345 default:
346 return false;
347 }
348 }
349
350 /// Returns whether the operating system makes it safer to store sensitive
351 /// values in x16 and x17 as opposed to other registers.
352 bool isX16X17Safer() const;
353
354 /// ParseSubtargetFeatures - Parses features string setting specified
355 /// subtarget options. Definition of function is auto generated by tblgen.
357
358 /// ClassifyGlobalReference - Find the target operand flags that describe
359 /// how a global value should be referenced for the current subtarget.
360 unsigned ClassifyGlobalReference(const GlobalValue *GV,
361 const TargetMachine &TM) const;
362
364 const TargetMachine &TM) const;
365
366 /// This function is design to compatible with the function def in other
367 /// targets and escape build error about the virtual function def in base
368 /// class TargetSubtargetInfo. Updeate me if AArch64 target need to use it.
369 unsigned char
371 return 0;
372 }
373
375 const SchedRegion &Region) const override;
376
377 void adjustSchedDependency(SUnit *Def, int DefOpIdx, SUnit *Use, int UseOpIdx,
378 SDep &Dep,
379 const TargetSchedModel *SchedModel) const override;
380
381 bool enableEarlyIfConversion() const override;
382
383 std::unique_ptr<PBQPRAConstraint> getCustomPBQPConstraints() const override;
384
385 bool isCallingConvWin64(CallingConv::ID CC, bool IsVarArg) const {
386 switch (CC) {
387 case CallingConv::C:
391 return isTargetWindows();
393 return IsVarArg && isTargetWindows();
395 return true;
396 default:
397 return false;
398 }
399 }
400
401 /// Return whether FrameLowering should always set the "extended frame
402 /// present" bit in FP, or set it based on a symbol in the runtime.
404 // Older OS versions (particularly system unwinders) are confused by the
405 // Swift extended frame, so when building code that might be run on them we
406 // must dynamically query the concurrency library to determine whether
407 // extended frames should be flagged as present.
408 const Triple &TT = getTargetTriple();
409
410 unsigned Major = TT.getOSVersion().getMajor();
411 switch(TT.getOS()) {
412 default:
413 return false;
414 case Triple::IOS:
415 case Triple::TvOS:
416 return Major < 15;
417 case Triple::WatchOS:
418 return Major < 8;
419 case Triple::MacOSX:
420 case Triple::Darwin:
421 return Major < 12;
422 }
423 }
424
425 void mirFileLoaded(MachineFunction &MF) const override;
426
427 // Return the known range for the bit length of SVE data registers. A value
428 // of 0 means nothing is known about that particular limit beyond what's
429 // implied by the architecture.
430 unsigned getMaxSVEVectorSizeInBits() const {
432 "Tried to get SVE vector length without SVE support!");
434 }
435
436 unsigned getMinSVEVectorSizeInBits() const {
438 "Tried to get SVE vector length without SVE support!");
440 }
441
442 // Return the known bit length of SVE data registers. A value of 0 means the
443 // length is unknown beyond what's implied by the architecture.
444 unsigned getSVEVectorSizeInBits() const {
446 "Tried to get SVE vector length without SVE support!");
449 return 0;
450 }
451
452 // Return the known bit length of SVE predicate registers. A value of 0 means
453 // the length is unknown beyond what's implied by the architecture.
454 unsigned getSVEPredicateSizeInBits() const {
455 return getSVEVectorSizeInBits() / 8;
456 }
457
460 return false;
461
462 // Prefer NEON unless larger SVE registers are available.
463 return !isNeonAvailable() || getMinSVEVectorSizeInBits() >= 256;
464 }
465
468 return false;
471 }
472
473 unsigned getVScaleForTuning() const { return VScaleForTuning; }
474
478
479 /// Returns true to use the addvl/inc/dec instructions, as opposed to separate
480 /// add + cnt instructions.
481 bool useScalarIncVL() const;
482
486
487 /// Choose a method of checking LR before performing a tail call.
490
491 /// Compute the integer discriminator for a given BlockAddress constant, if
492 /// blockaddress signing is enabled, or std::nullopt otherwise.
493 /// Blockaddress signing is controlled by the function attribute
494 /// "ptrauth-indirect-gotos" on the parent function.
495 /// Note that this assumes the discriminator is independent of the indirect
496 /// goto branch site itself, i.e., it's the same for all BlockAddresses in
497 /// a function.
498 std::optional<uint16_t>
500
501 bool enableAggressiveInterleaving() const { return AggressiveInterleaving; }
502};
503} // End llvm namespace
504
505#endif
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
This file describes how to lower LLVM calls to machine code calls.
This file describes how to lower LLVM inline asm to machine code INLINEASM.
Interface for Targets to specify which operations they can successfully select and how the others sho...
const AArch64RegisterInfo & getRegisterInfo() const
getRegisterInfo - TargetInstrInfo is a superset of MRegister info.
const AArch64SelectionDAGInfo * getSelectionDAGInfo() const override
const CallLowering * getCallLowering() const override
const AArch64RegisterInfo * getRegisterInfo() const override
bool enableSRLTSubregToRegMitigation() const
bool enableSpillageCopyElimination() const override
bool isNeonAvailable() const
Returns true if the target has NEON and the function at runtime is known to have NEON enabled (e....
TailFoldingOpts DefaultSVETFOpts
unsigned getMinPrefetchStride(unsigned NumMemAccesses, unsigned NumStridedMemAccesses, unsigned NumPrefetches, bool HasCall) const override
bool addrSinkUsingGEPs() const override
std::unique_ptr< InstructionSelector > InstSelector
bool enableAggressiveInterleaving() const
ARMProcFamilyEnum ARMProcFamily
ARMProcFamily - ARM processor family: Cortex-A53, Cortex-A57, and others.
unsigned getMinimumJumpTableEntries() const
std::unique_ptr< RegisterBankInfo > RegBankInfo
bool useSVEForFixedLengthVectors(EVT VT) const
const AArch64InstrInfo * getInstrInfo() const override
bool hasFusion() const
Return true if the CPU supports any kind of instruction fusion.
AArch64SelectionDAGInfo TSInfo
unsigned getMaximumJumpTableSize() const
std::optional< unsigned > StreamingHazardSize
AArch64FrameLowering FrameLowering
bool enableEarlyIfConversion() const override
const InlineAsmLowering * getInlineAsmLowering() const override
unsigned getCacheLineSize() const override
unsigned getFixedLoadLatency() const
unsigned getVectorInsertExtractBaseCost() const
bool enableMachinePipeliner() const override
ARMProcFamilyEnum getProcFamily() const
Returns ARM processor family.
std::unique_ptr< CallLowering > CallLoweringInfo
GlobalISel related APIs.
std::optional< uint16_t > getPtrAuthBlockAddressDiscriminatorIfEnabled(const Function &ParentFn) const
Compute the integer discriminator for a given BlockAddress constant, if blockaddress signing is enabl...
unsigned getGatherOverhead() const
bool isXRegisterReservedForRA(size_t i) const
unsigned getNumXRegisterReserved() const
unsigned classifyGlobalFunctionReference(const GlobalValue *GV, const TargetMachine &TM) const
bool useAA() const override
bool isStreamingSVEAvailable() const
Returns true if the target has access to the streaming-compatible subset of SVE instructions.
const AArch64TargetLowering * getTargetLowering() const override
Align getPrefLoopAlignment() const
Align getPrefFunctionAlignment() const
unsigned getMaxBytesForLoopAlignment() const
bool isNonStreamingSVEorSME2Available() const
Returns true if the target has access to either the full range of SVE instructions,...
bool supportsAddressTopByteIgnored() const
CPU has TBI (top byte of addresses is ignored during HW address translation) and OS enables it.
unsigned getMaxInterleaveFactor() const
void overrideSchedPolicy(MachineSchedPolicy &Policy, const SchedRegion &Region) const override
unsigned char classifyGlobalFunctionReference(const GlobalValue *GV) const override
This function is design to compatible with the function def in other targets and escape build error a...
const Triple & getTargetTriple() const
unsigned getStreamingHazardSize() const
Returns the size of memory region that if accessed by both the CPU and the SME unit could result in a...
bool isStreamingCompatible() const
Returns true if the function has a streaming-compatible body.
bool isXRegCustomCalleeSaved(size_t i) const
void adjustSchedDependency(SUnit *Def, int DefOpIdx, SUnit *Use, int UseOpIdx, SDep &Dep, const TargetSchedModel *SchedModel) const override
void mirFileLoaded(MachineFunction &MF) const override
Triple TargetTriple
TargetTriple - What processor and OS we're targeting.
InstructionSelector * getInstructionSelector() const override
bool isSVEorStreamingSVEAvailable() const
Returns true if the target has access to either the full range of SVE instructions,...
bool enableSubRegLiveness() const override
TailFoldingOpts getSVETailFoldingDefaultOpts() const
bool useSVEForFixedLengthVectors() const
unsigned ClassifyGlobalReference(const GlobalValue *GV, const TargetMachine &TM) const
ClassifyGlobalReference - Find the target operand flags that describe how a global value should be re...
void ParseSubtargetFeatures(StringRef CPU, StringRef TuneCPU, StringRef FS)
ParseSubtargetFeatures - Parses features string setting specified subtarget options.
unsigned getSVEPredicateSizeInBits() const
unsigned getMinVectorRegisterBitWidth() const
bool isStreaming() const
Returns true if the function has a streaming body.
bool isX16X17Safer() const
Returns whether the operating system makes it safer to store sensitive values in x16 and x17 as oppos...
unsigned getSVEVectorSizeInBits() const
bool isXRegisterReserved(size_t i) const
unsigned getMaxPrefetchIterationsAhead() const override
bool useScalarIncVL() const
Returns true to use the addvl/inc/dec instructions, as opposed to separate add + cnt instructions.
bool useDFAforSMS() const override
const LegalizerInfo * getLegalizerInfo() const override
bool enableMachineScheduler() const override
unsigned getScatterOverhead() const
bool enablePostRAScheduler() const override
AArch64Subtarget(const Triple &TT, StringRef CPU, StringRef TuneCPU, StringRef FS, const TargetMachine &TM, bool LittleEndian, unsigned MinSVEVectorSizeInBitsOverride=0, unsigned MaxSVEVectorSizeInBitsOverride=0, bool IsStreaming=false, bool IsStreamingCompatible=false, bool HasMinSize=false, bool EnableSRLTSubregToRegMitigation=false)
This constructor initializes the data members to match that of the specified triple.
std::unique_ptr< PBQPRAConstraint > getCustomPBQPConstraints() const override
unsigned getEpilogueVectorizationMinVF() const
unsigned getMaxSVEVectorSizeInBits() const
bool isCallingConvWin64(CallingConv::ID CC, bool IsVarArg) const
unsigned getVScaleForTuning() const
unsigned getMinSVEVectorSizeInBits() const
AArch64PAuth::AuthCheckMethod getAuthenticatedLRCheckMethod(const MachineFunction &MF) const
Choose a method of checking LR before performing a tail call.
AArch64InstrInfo InstrInfo
AArch64TargetLowering TLInfo
const RegisterBankInfo * getRegBankInfo() const override
std::unique_ptr< LegalizerInfo > Legalizer
std::unique_ptr< InlineAsmLowering > InlineAsmLoweringInfo
bool isAppleMLike() const
Returns true if the processor is an Apple M-series or aligned A-series (A14 or newer).
bool isXRaySupported() const override
bool isSVEAvailable() const
Returns true if the target has SVE and can use the full range of SVE instructions,...
bool hasCustomCallingConv() const
const AArch64FrameLowering * getFrameLowering() const override
bool swiftAsyncContextIsDynamicallySet() const
Return whether FrameLowering should always set the "extended framepresent" bit in FP,...
unsigned getPrefetchDistance() const override
size_type count() const
Returns the number of bits which are set.
Definition BitVector.h:181
Holds all the information related to register banks.
Scheduling dependency.
Definition ScheduleDAG.h:51
Scheduling unit. This is a node in the scheduling DAG.
Represent a constant reference to a string, i.e.
Definition StringRef.h:56
Primary interface to the complete machine description for the target machine.
Provide an instruction scheduling machine model to CodeGen passes.
Triple - Helper class for working with autoconf configuration names.
Definition Triple.h:47
A Use represents the edge between a Value definition and its users.
Definition Use.h:35
AuthCheckMethod
Variants of check performed on an authenticated pointer.
static constexpr unsigned SVEBitsPerBlock
unsigned ID
LLVM IR allows to use arbitrary numbers as calling convention identifiers.
Definition CallingConv.h:24
@ Swift
Calling convention for Swift.
Definition CallingConv.h:69
@ Fast
Attempts to make calls as fast as possible (e.g.
Definition CallingConv.h:41
@ PreserveNone
Used for runtime calls that preserves none general registers.
Definition CallingConv.h:90
@ Win64
The C convention as implemented on Windows/x86-64 and AArch64.
@ SwiftTail
This follows the Swift calling convention in how arguments are passed but guarantees tail calls will ...
Definition CallingConv.h:87
@ C
The default llvm calling convention, compatible with C.
Definition CallingConv.h:34
This is an optimization pass for GlobalISel generic memory operations.
TailFoldingOpts
An enum to describe what types of loops we should attempt to tail-fold: Disabled: None Reductions: Lo...
This struct is a compact representation of a valid (non-zero power of two) alignment.
Definition Alignment.h:39
Extended Value Type.
Definition ValueTypes.h:35
uint64_t getFixedSizeInBits() const
Return the size of the specified fixed width value type in bits.
Definition ValueTypes.h:404
bool isFixedLengthVector() const
Definition ValueTypes.h:199
Define a generic scheduling policy for targets that don't provide their own MachineSchedStrategy.
A region of an MBB for scheduling.