LLVM 23.0.0git
TargetSubtargetInfo.h
Go to the documentation of this file.
1//===- llvm/CodeGen/TargetSubtargetInfo.h - Target Information --*- 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 describes the subtarget options of a Target machine.
10//
11//===----------------------------------------------------------------------===//
12
13#ifndef LLVM_CODEGEN_TARGETSUBTARGETINFO_H
14#define LLVM_CODEGEN_TARGETSUBTARGETINFO_H
15
16#include "llvm/ADT/ArrayRef.h"
17#include "llvm/ADT/DenseMap.h"
19#include "llvm/ADT/StringRef.h"
23#include "llvm/IR/GlobalValue.h"
27#include <memory>
28#include <vector>
29
30namespace llvm {
31
32class APInt;
33class MachineFunction;
35class CallLowering;
36class GlobalValue;
39struct InstrStage;
41class LegalizerInfo;
43class MachineInstr;
49class SDep;
51class SUnit;
53class TargetInstrInfo;
54class TargetLowering;
55class MCRegisterClass;
59class Triple;
60struct SchedRegion;
61
62//===----------------------------------------------------------------------===//
63///
64/// TargetSubtargetInfo - Generic base class for all target subtargets. All
65/// Target-specific options that control code generation and printing should
66/// be exposed through a TargetSubtargetInfo-derived class.
67///
69protected: // Can only create subclasses...
70 TargetSubtargetInfo(const Triple &TT, StringRef CPU, StringRef TuneCPU,
74 const MCWriteProcResEntry *WPR,
75 const MCWriteLatencyEntry *WL,
76 const MCReadAdvanceEntry *RA, const InstrStage *IS,
77 const unsigned *OC, const unsigned *FP);
78
79public:
80 // AntiDepBreakMode - Type of anti-dependence breaking that should
81 // be performed before post-RA scheduling.
82 using AntiDepBreakMode = enum { ANTIDEP_NONE, ANTIDEP_CRITICAL, ANTIDEP_ALL };
84
89
90 virtual bool isXRaySupported() const { return false; }
91
92 /// \returns true if the target intrinsic \p IntrinsicID is supported by this
93 /// subtarget.
94 bool isIntrinsicSupported(unsigned IntrinsicID) const;
95
96 // Interfaces to the major aspects of target machine information:
97 //
98 // -- Instruction opcode and operand information
99 // -- Pipelines and scheduling information
100 // -- Stack frame information
101 // -- Selection DAG lowering information
102 // -- Call lowering information
103 //
104 // N.B. These objects may change during compilation. It's not safe to cache
105 // them between functions.
106 virtual const TargetInstrInfo *getInstrInfo() const { return nullptr; }
107 virtual const TargetFrameLowering *getFrameLowering() const {
108 return nullptr;
109 }
110 virtual const TargetLowering *getTargetLowering() const { return nullptr; }
112 return nullptr;
113 }
114 virtual const CallLowering *getCallLowering() const { return nullptr; }
115
117 return nullptr;
118 }
119
120 // FIXME: This lets targets specialize the selector by subtarget (which lets
121 // us do things like a dedicated avx512 selector). However, we might want
122 // to also specialize selectors by MachineFunction, which would let us be
123 // aware of optsize/optnone and such.
125 return nullptr;
126 }
127
128 /// Target can subclass this hook to select a different DAG scheduler.
131 return nullptr;
132 }
133
134 virtual const LegalizerInfo *getLegalizerInfo() const { return nullptr; }
135
136 /// Return the target's register information.
137 virtual const TargetRegisterInfo *getRegisterInfo() const = 0;
138
139 /// If the information for the register banks is available, return it.
140 /// Otherwise return nullptr.
141 virtual const RegisterBankInfo *getRegBankInfo() const { return nullptr; }
142
143 /// getInstrItineraryData - Returns instruction itinerary data for the target
144 /// or specific subtarget.
146 return nullptr;
147 }
148
149 /// Configure the LibcallLoweringInfo for this subtarget. The libcalls will be
150 /// pre-configured with defaults based on RuntimeLibcallsInfo. This may be
151 /// used to override those decisions, such as disambiguating alternative
152 /// implementations.
153 virtual void initLibcallLoweringInfo(LibcallLoweringInfo &Info) const {}
154
155 /// Resolve a SchedClass at runtime, where SchedClass identifies an
156 /// MCSchedClassDesc with the isVariant property. This may return the ID of
157 /// another variant SchedClass, but repeated invocation must quickly terminate
158 /// in a nonvariant SchedClass.
159 virtual unsigned resolveSchedClass(unsigned SchedClass,
160 const MachineInstr *MI,
161 const TargetSchedModel *SchedModel) const {
162 return 0;
163 }
164
165 /// Returns true if MI is a dependency breaking zero-idiom instruction for the
166 /// subtarget.
167 ///
168 /// This function also sets bits in Mask related to input operands that
169 /// are not in a data dependency relationship. There is one bit for each
170 /// machine operand; implicit operands follow explicit operands in the bit
171 /// representation used for Mask. An empty (i.e. a mask with all bits
172 /// cleared) means: data dependencies are "broken" for all the explicit input
173 /// machine operands of MI.
174 virtual bool isZeroIdiom(const MachineInstr *MI, APInt &Mask) const {
175 return false;
176 }
177
178 /// Returns true if MI is a dependency breaking instruction for the subtarget.
179 ///
180 /// Similar in behavior to `isZeroIdiom`. However, it knows how to identify
181 /// all dependency breaking instructions (i.e. not just zero-idioms).
182 ///
183 /// As for `isZeroIdiom`, this method returns a mask of "broken" dependencies.
184 /// (See method `isZeroIdiom` for a detailed description of Mask).
185 virtual bool isDependencyBreaking(const MachineInstr *MI, APInt &Mask) const {
186 return isZeroIdiom(MI, Mask);
187 }
188
189 /// Returns true if MI is a candidate for move elimination.
190 ///
191 /// A candidate for move elimination may be optimized out at register renaming
192 /// stage. Subtargets can specify the set of optimizable moves by
193 /// instantiating tablegen class `IsOptimizableRegisterMove` (see
194 /// llvm/Target/TargetInstrPredicate.td).
195 ///
196 /// SubtargetEmitter is responsible for processing all the definitions of class
197 /// IsOptimizableRegisterMove, and auto-generate an override for this method.
198 virtual bool isOptimizableRegisterMove(const MachineInstr *MI) const {
199 return false;
200 }
201
202 /// True if the subtarget should run MachineScheduler after aggressive
203 /// coalescing.
204 ///
205 /// This currently replaces the SelectionDAG scheduler with the "source" order
206 /// scheduler (though see below for an option to turn this off and use the
207 /// TargetLowering preference). It does not yet disable the postRA scheduler.
208 virtual bool enableMachineScheduler() const;
209
210 /// True if the machine scheduler should disable the TLI preference
211 /// for preRA scheduling with the source level scheduler.
212 virtual bool enableMachineSchedDefaultSched() const { return true; }
213
214 /// True if the subtarget should run MachinePipeliner
215 virtual bool enableMachinePipeliner() const { return true; };
216
217 /// True if the subtarget should run WindowScheduler.
218 virtual bool enableWindowScheduler() const { return true; }
219
220 /// True if the subtarget should enable joining global copies.
221 ///
222 /// By default this is enabled if the machine scheduler is enabled, but
223 /// can be overridden.
224 virtual bool enableJoinGlobalCopies() const;
225
226 /// Hack to bring up option. This should be unconditionally true, all targets
227 /// should enable it and delete this.
228 virtual bool enableTerminalRule() const { return false; }
229
230 /// True if the subtarget should run a scheduler after register allocation.
231 ///
232 /// By default this queries the PostRAScheduling bit in the scheduling model
233 /// which is the preferred way to influence this.
234 virtual bool enablePostRAScheduler() const;
235
236 /// True if the subtarget should run a machine scheduler after register
237 /// allocation.
238 virtual bool enablePostRAMachineScheduler() const;
239
240 /// True if the subtarget should run the atomic expansion pass.
241 virtual bool enableAtomicExpand() const;
242
243 /// True if the subtarget should run the indirectbr expansion pass.
244 virtual bool enableIndirectBrExpand() const;
245
246 /// Override generic scheduling policy within a region.
247 ///
248 /// This is a convenient way for targets that don't provide any custom
249 /// scheduling heuristics (no custom MachineSchedStrategy) to make
250 /// changes to the generic scheduling policy.
252 const SchedRegion &Region) const {}
253
254 /// Override generic post-ra scheduling policy within a region.
255 ///
256 /// This is a convenient way for targets that don't provide any custom
257 /// scheduling heuristics (no custom MachineSchedStrategy) to make
258 /// changes to the generic post-ra scheduling policy.
259 /// Note that some options like tracking register pressure won't take effect
260 /// in post-ra scheduling.
262 const SchedRegion &Region) const {}
263
264 // Perform target-specific adjustments to the latency of a schedule
265 // dependency.
266 // If a pair of operands is associated with the schedule dependency, DefOpIdx
267 // and UseOpIdx are the indices of the operands in Def and Use, respectively.
268 // Otherwise, either may be -1.
269 virtual void adjustSchedDependency(SUnit *Def, int DefOpIdx, SUnit *Use,
270 int UseOpIdx, SDep &Dep,
271 const TargetSchedModel *SchedModel) const {
272 }
273
274 // For use with PostRAScheduling: get the anti-dependence breaking that should
275 // be performed before post-RA scheduling.
276 virtual AntiDepBreakMode getAntiDepBreakMode() const { return ANTIDEP_NONE; }
277
278 // For use with PostRAScheduling: in CriticalPathRCs, return any register
279 // classes that should only be considered for anti-dependence breaking if they
280 // are on the critical path.
281 virtual void getCriticalPathRCs(RegClassVector &CriticalPathRCs) const {
282 return CriticalPathRCs.clear();
283 }
284
285 // Provide an ordered list of schedule DAG mutations for the post-RA
286 // scheduler.
287 virtual void getPostRAMutations(
288 std::vector<std::unique_ptr<ScheduleDAGMutation>> &Mutations) const {
289 }
290
291 // Provide an ordered list of schedule DAG mutations for the machine
292 // pipeliner.
293 virtual void getSMSMutations(
294 std::vector<std::unique_ptr<ScheduleDAGMutation>> &Mutations) const {
295 }
296
297 /// Default to DFA for resource management, return false when target will use
298 /// ProcResource in InstrSchedModel instead.
299 virtual bool useDFAforSMS() const { return true; }
300
301 // For use with PostRAScheduling: get the minimum optimization level needed
302 // to enable post-RA scheduling.
306
307 /// True if the subtarget should run the local reassignment
308 /// heuristic of the register allocator.
309 /// This heuristic may be compile time intensive, \p OptLevel provides
310 /// a finer grain to tune the register allocator.
311 virtual bool enableRALocalReassignment(CodeGenOptLevel OptLevel) const;
312
313 /// Enable use of alias analysis during code generation (during MI
314 /// scheduling, DAGCombine, etc.).
315 virtual bool useAA() const;
316
317 /// \brief Sink addresses into blocks using GEP instructions rather than
318 /// pointer casts and arithmetic.
319 virtual bool addrSinkUsingGEPs() const {
320 return useAA();
321 }
322
323 /// Enable the use of the early if conversion pass.
324 virtual bool enableEarlyIfConversion() const { return false; }
325
326 /// Return PBQPConstraint(s) for the target.
327 ///
328 /// Override to provide custom PBQP constraints.
329 virtual std::unique_ptr<PBQPRAConstraint> getCustomPBQPConstraints() const {
330 return nullptr;
331 }
332
333 /// Enable tracking of subregister liveness in register allocator.
334 /// Please use MachineRegisterInfo::subRegLivenessEnabled() instead where
335 /// possible.
336 virtual bool enableSubRegLiveness() const { return false; }
337
338 /// This is called after a .mir file was loaded.
339 virtual void mirFileLoaded(MachineFunction &MF) const;
340
341 /// True if the register allocator should use the allocation orders exactly as
342 /// written in the tablegen descriptions, false if it should allocate
343 /// the specified physical register later if is it callee-saved.
345 MCRegister PhysReg) const {
346 return false;
347 }
348
349 /// Classify a global function reference. This mainly used to fetch target
350 /// special flags for lowering a function address. For example mark a function
351 /// call should be plt or pc-related addressing.
352 virtual unsigned char
354 return 0;
355 }
356
357 /// Enable spillage copy elimination in MachineCopyPropagation pass. This
358 /// helps removing redundant copies generated by register allocator when
359 /// handling complex eviction chains.
360 virtual bool enableSpillageCopyElimination() const { return false; }
361
362 /// Get the list of MacroFusion predicates.
363 virtual std::vector<MacroFusionPredTy> getMacroFusions() const { return {}; };
364
365 /// Whether the target has instructions where an early-clobber result
366 /// operand cannot overlap with an undef input operand.
368 // Conservatively assume such instructions exist by default.
369 return true;
370 }
371
372 virtual bool isRegisterReservedByUser(Register R) const { return false; }
373
374 /// Target features to ignore for inline compatibility check.
375 virtual const FeatureBitset &getInlineIgnoreFeatures() const = 0;
376 /// Target features where the callee may have an additional feature,
377 /// instead of the caller.
378 virtual const FeatureBitset &getInlineInverseFeatures() const = 0;
379 /// Target features where all mismatches prevent inlining.
380 virtual const FeatureBitset &getInlineMustMatchFeatures() const = 0;
381
382private:
383 /// Lazy, incrementally-populated cache for isIntrinsicSupported().
384 mutable DenseMap<unsigned, bool> IntrinsicSupportCache;
385};
386} // end namespace llvm
387
388#endif // LLVM_CODEGEN_TARGETSUBTARGETINFO_H
#define LLVM_ABI
Definition Compiler.h:215
This file defines the DenseMap class.
IRTranslator LLVM IR MI
static bool enablePostRAScheduler(const TargetSubtargetInfo &ST, CodeGenOptLevel OptLevel)
SI optimize exec mask operations pre RA
This file defines the SmallVector class.
Class for arbitrary precision integers.
Definition APInt.h:78
Represent a constant reference to an array (0 or more elements consecutively in memory),...
Definition ArrayRef.h:40
Container class for subtarget features.
Itinerary data supplied by a subtarget to be used by a target.
Tracks which library functions to use for a particular subtarget.
MCRegisterClass - Base class of TargetRegisterClass.
Wrapper class representing physical registers. Should be passed by value.
Definition MCRegister.h:41
MCSubtargetInfo(const MCSubtargetInfo &)=default
Representation of each machine instruction.
Holds all the information related to register banks.
ScheduleDAGSDNodes *(*)(SelectionDAGISel *, CodeGenOptLevel) FunctionPassCtor
Wrapper class representing virtual and physical registers.
Definition Register.h:20
Scheduling dependency.
Definition ScheduleDAG.h:52
Scheduling unit. This is a node in the scheduling DAG.
Mutate the DAG as a postpass after normal DAG building.
Targets can subclass this to parameterize the SelectionDAG lowering and instruction selection process...
This class consists of common code factored out of the SmallVector class to reduce code duplication b...
Represent a constant reference to a string, i.e.
Definition StringRef.h:56
Information about stack frame layout on the target.
TargetInstrInfo - Interface to description of machine instruction set.
This class defines information used to lower LLVM code to legal SelectionDAG operators that the targe...
TargetRegisterInfo base class - We assume that the target defines a static array of TargetRegisterDes...
Provide an instruction scheduling machine model to CodeGen passes.
virtual unsigned char classifyGlobalFunctionReference(const GlobalValue *GV) const
Classify a global function reference.
virtual bool requiresDisjointEarlyClobberAndUndef() const
Whether the target has instructions where an early-clobber result operand cannot overlap with an unde...
enum { ANTIDEP_NONE, ANTIDEP_CRITICAL, ANTIDEP_ALL } AntiDepBreakMode
SmallVectorImpl< const TargetRegisterClass * > RegClassVector
virtual std::vector< MacroFusionPredTy > getMacroFusions() const
Get the list of MacroFusion predicates.
virtual const SelectionDAGTargetInfo * getSelectionDAGInfo() const
virtual void overridePostRASchedPolicy(MachineSchedPolicy &Policy, const SchedRegion &Region) const
Override generic post-ra scheduling policy within a region.
virtual const FeatureBitset & getInlineMustMatchFeatures() const =0
Target features where all mismatches prevent inlining.
virtual const InlineAsmLowering * getInlineAsmLowering() const
virtual void overrideSchedPolicy(MachineSchedPolicy &Policy, const SchedRegion &Region) const
Override generic scheduling policy within a region.
virtual void initLibcallLoweringInfo(LibcallLoweringInfo &Info) const
Configure the LibcallLoweringInfo for this subtarget.
virtual bool isRegisterReservedByUser(Register R) const
virtual std::unique_ptr< PBQPRAConstraint > getCustomPBQPConstraints() const
Return PBQPConstraint(s) for the target.
virtual void getCriticalPathRCs(RegClassVector &CriticalPathRCs) const
virtual CodeGenOptLevel getOptLevelToEnablePostRAScheduler() const
TargetSubtargetInfo(const Triple &TT, StringRef CPU, StringRef TuneCPU, StringRef FS, ArrayRef< StringRef > PN, ArrayRef< SubtargetFeatureKV > PF, ArrayRef< SubtargetSubTypeKV > PD, const MCWriteProcResEntry *WPR, const MCWriteLatencyEntry *WL, const MCReadAdvanceEntry *RA, const InstrStage *IS, const unsigned *OC, const unsigned *FP)
virtual RegisterScheduler::FunctionPassCtor getDAGScheduler(CodeGenOptLevel) const
Target can subclass this hook to select a different DAG scheduler.
virtual bool enableSpillageCopyElimination() const
Enable spillage copy elimination in MachineCopyPropagation pass.
virtual bool isDependencyBreaking(const MachineInstr *MI, APInt &Mask) const
Returns true if MI is a dependency breaking instruction for the subtarget.
virtual const CallLowering * getCallLowering() const
virtual bool isXRaySupported() const
virtual const RegisterBankInfo * getRegBankInfo() const
If the information for the register banks is available, return it.
virtual bool useAA() const
Enable use of alias analysis during code generation (during MI scheduling, DAGCombine,...
TargetSubtargetInfo(const TargetSubtargetInfo &)=delete
virtual InstructionSelector * getInstructionSelector() const
virtual AntiDepBreakMode getAntiDepBreakMode() const
virtual bool enableWindowScheduler() const
True if the subtarget should run WindowScheduler.
virtual void getPostRAMutations(std::vector< std::unique_ptr< ScheduleDAGMutation > > &Mutations) const
virtual void getSMSMutations(std::vector< std::unique_ptr< ScheduleDAGMutation > > &Mutations) const
virtual bool ignoreCSRForAllocationOrder(const MachineFunction &MF, MCRegister PhysReg) const
True if the register allocator should use the allocation orders exactly as written in the tablegen de...
virtual bool enableMachinePipeliner() const
True if the subtarget should run MachinePipeliner.
virtual const LegalizerInfo * getLegalizerInfo() const
virtual bool useDFAforSMS() const
Default to DFA for resource management, return false when target will use ProcResource in InstrSchedM...
virtual void adjustSchedDependency(SUnit *Def, int DefOpIdx, SUnit *Use, int UseOpIdx, SDep &Dep, const TargetSchedModel *SchedModel) const
virtual const TargetFrameLowering * getFrameLowering() const
virtual bool isOptimizableRegisterMove(const MachineInstr *MI) const
Returns true if MI is a candidate for move elimination.
virtual const TargetInstrInfo * getInstrInfo() const
virtual bool isZeroIdiom(const MachineInstr *MI, APInt &Mask) const
Returns true if MI is a dependency breaking zero-idiom instruction for the subtarget.
virtual const TargetRegisterInfo * getRegisterInfo() const =0
Return the target's register information.
virtual bool enableMachineSchedDefaultSched() const
True if the machine scheduler should disable the TLI preference for preRA scheduling with the source ...
virtual bool enableSubRegLiveness() const
Enable tracking of subregister liveness in register allocator.
virtual const FeatureBitset & getInlineInverseFeatures() const =0
Target features where the callee may have an additional feature, instead of the caller.
virtual const TargetLowering * getTargetLowering() const
virtual bool addrSinkUsingGEPs() const
Sink addresses into blocks using GEP instructions rather than pointer casts and arithmetic.
virtual const InstrItineraryData * getInstrItineraryData() const
getInstrItineraryData - Returns instruction itinerary data for the target or specific subtarget.
virtual const FeatureBitset & getInlineIgnoreFeatures() const =0
Target features to ignore for inline compatibility check.
virtual bool enableTerminalRule() const
Hack to bring up option.
virtual unsigned resolveSchedClass(unsigned SchedClass, const MachineInstr *MI, const TargetSchedModel *SchedModel) const
Resolve a SchedClass at runtime, where SchedClass identifies an MCSchedClassDesc with the isVariant p...
TargetSubtargetInfo & operator=(const TargetSubtargetInfo &)=delete
virtual bool enableEarlyIfConversion() const
Enable the use of the early if conversion pass.
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
This is an optimization pass for GlobalISel generic memory operations.
CodeGenOptLevel
Code generation optimization level.
Definition CodeGen.h:82
@ Default
-O2, -Os, -Oz
Definition CodeGen.h:85
MCRegisterClass TargetRegisterClass
Definition FastISel.h:58
These values represent a non-pipelined step in the execution of an instruction.
Specify the number of cycles allowed after instruction issue before a particular use operand reads it...
Definition MCSchedule.h:114
Specify the latency in cpu cycles for a particular scheduling class and def index.
Definition MCSchedule.h:97
Identify one of the processor resource kinds consumed by a particular scheduling class for the specif...
Definition MCSchedule.h:74
Define a generic scheduling policy for targets that don't provide their own MachineSchedStrategy.
A region of an MBB for scheduling.