LLVM 23.0.0git
SelectionDAG.h
Go to the documentation of this file.
1//===- llvm/CodeGen/SelectionDAG.h - InstSelection DAG ----------*- 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 SelectionDAG class, and transitively defines the
10// SDNode class and subclasses.
11//
12//===----------------------------------------------------------------------===//
13
14#ifndef LLVM_CODEGEN_SELECTIONDAG_H
15#define LLVM_CODEGEN_SELECTIONDAG_H
16
17#include "llvm/ADT/ArrayRef.h"
18#include "llvm/ADT/DenseMap.h"
19#include "llvm/ADT/DenseSet.h"
20#include "llvm/ADT/FoldingSet.h"
22#include "llvm/ADT/StringMap.h"
23#include "llvm/ADT/ilist.h"
24#include "llvm/ADT/iterator.h"
35#include "llvm/IR/DebugLoc.h"
36#include "llvm/IR/Metadata.h"
46#include <cassert>
47#include <cstdint>
48#include <functional>
49#include <map>
50#include <set>
51#include <string>
52#include <tuple>
53#include <utility>
54#include <vector>
55
56namespace llvm {
57
58class DIExpression;
59class DILabel;
60class DIVariable;
61class Function;
62class Pass;
63class Type;
64template <class GraphType> struct GraphTraits;
65template <typename T, unsigned int N> class SmallSetVector;
66template <typename T, typename Enable> struct FoldingSetTrait;
67class BatchAAResults;
68class BlockAddress;
70class Constant;
71class ConstantFP;
72class ConstantInt;
73class DataLayout;
74struct fltSemantics;
76class FunctionVarLocs;
77class GlobalValue;
78struct KnownBits;
79class LLVMContext;
83class MCSymbol;
86class SDDbgValue;
87class SDDbgOperand;
88class SDDbgLabel;
89class SelectionDAG;
92class TargetLowering;
93class TargetMachine;
95class Value;
96
97template <typename T> class GenericSSAContext;
99template <typename T> class GenericUniformityInfo;
101
103 friend struct FoldingSetTrait<SDVTListNode>;
104
105 /// A reference to an Interned FoldingSetNodeID for this node.
106 /// The Allocator in SelectionDAG holds the data.
107 /// SDVTList contains all types which are frequently accessed in SelectionDAG.
108 /// The size of this list is not expected to be big so it won't introduce
109 /// a memory penalty.
110 FoldingSetNodeIDRef FastID;
111 const EVT *VTs;
112 unsigned int NumVTs;
113 /// The hash value for SDVTList is fixed, so cache it to avoid
114 /// hash calculation.
115 unsigned HashValue;
116
117public:
118 SDVTListNode(const FoldingSetNodeIDRef ID, const EVT *VT, unsigned int Num) :
119 FastID(ID), VTs(VT), NumVTs(Num) {
120 HashValue = ID.ComputeHash();
121 }
122
124 SDVTList result = {VTs, NumVTs};
125 return result;
126 }
127};
128
129/// Specialize FoldingSetTrait for SDVTListNode
130/// to avoid computing temp FoldingSetNodeID and hash value.
131template<> struct FoldingSetTrait<SDVTListNode> : DefaultFoldingSetTrait<SDVTListNode> {
132 static void Profile(const SDVTListNode &X, FoldingSetNodeID& ID) {
133 ID = X.FastID;
134 }
135
136 static bool Equals(const SDVTListNode &X, const FoldingSetNodeID &ID,
137 unsigned IDHash, FoldingSetNodeID &TempID) {
138 if (X.HashValue != IDHash)
139 return false;
140 return ID == X.FastID;
141 }
142
143 static unsigned ComputeHash(const SDVTListNode &X, FoldingSetNodeID &TempID) {
144 return X.HashValue;
145 }
146};
147
148template <> struct ilist_alloc_traits<SDNode> {
149 static void deleteNode(SDNode *) {
150 llvm_unreachable("ilist_traits<SDNode> shouldn't see a deleteNode call!");
151 }
152};
153
154/// Keeps track of dbg_value information through SDISel. We do
155/// not build SDNodes for these so as not to perturb the generated code;
156/// instead the info is kept off to the side in this structure. Each SDNode may
157/// have one or more associated dbg_value entries. This information is kept in
158/// DbgValMap.
159/// Byval parameters are handled separately because they don't use alloca's,
160/// which busts the normal mechanism. There is good reason for handling all
161/// parameters separately: they may not have code generated for them, they
162/// should always go at the beginning of the function regardless of other code
163/// motion, and debug info for them is potentially useful even if the parameter
164/// is unused. Right now only byval parameters are handled separately.
166 BumpPtrAllocator Alloc;
168 SmallVector<SDDbgValue*, 32> ByvalParmDbgValues;
171 DbgValMapType DbgValMap;
172
173public:
174 SDDbgInfo() = default;
175 SDDbgInfo(const SDDbgInfo &) = delete;
176 SDDbgInfo &operator=(const SDDbgInfo &) = delete;
177
178 LLVM_ABI void add(SDDbgValue *V, bool isParameter);
179
180 void add(SDDbgLabel *L) { DbgLabels.push_back(L); }
181
182 /// Invalidate all DbgValues attached to the node and remove
183 /// it from the Node-to-DbgValues map.
184 LLVM_ABI void erase(const SDNode *Node);
185
186 void clear() {
187 DbgValMap.clear();
188 DbgValues.clear();
189 ByvalParmDbgValues.clear();
190 DbgLabels.clear();
191 Alloc.Reset();
192 }
193
194 BumpPtrAllocator &getAlloc() { return Alloc; }
195
196 bool empty() const {
197 return DbgValues.empty() && ByvalParmDbgValues.empty() && DbgLabels.empty();
198 }
199
201 auto I = DbgValMap.find(Node);
202 if (I != DbgValMap.end())
203 return I->second;
204 return ArrayRef<SDDbgValue*>();
205 }
206
209
210 DbgIterator DbgBegin() { return DbgValues.begin(); }
211 DbgIterator DbgEnd() { return DbgValues.end(); }
212 DbgIterator ByvalParmDbgBegin() { return ByvalParmDbgValues.begin(); }
213 DbgIterator ByvalParmDbgEnd() { return ByvalParmDbgValues.end(); }
214 DbgLabelIterator DbgLabelBegin() { return DbgLabels.begin(); }
215 DbgLabelIterator DbgLabelEnd() { return DbgLabels.end(); }
216};
217
218LLVM_ABI void checkForCycles(const SelectionDAG *DAG, bool force = false);
219
220/// This is used to represent a portion of an LLVM function in a low-level
221/// Data Dependence DAG representation suitable for instruction selection.
222/// This DAG is constructed as the first step of instruction selection in order
223/// to allow implementation of machine specific optimizations
224/// and code simplifications.
225///
226/// The representation used by the SelectionDAG is a target-independent
227/// representation, which has some similarities to the GCC RTL representation,
228/// but is significantly more simple, powerful, and is a graph form instead of a
229/// linear form.
230///
232 const TargetMachine &TM;
233 const SelectionDAGTargetInfo *TSI = nullptr;
234 const TargetLowering *TLI = nullptr;
235 const TargetLibraryInfo *LibInfo = nullptr;
236 const RTLIB::RuntimeLibcallsInfo *RuntimeLibcallInfo = nullptr;
237 const LibcallLoweringInfo *Libcalls = nullptr;
238
239 const FunctionVarLocs *FnVarLocs = nullptr;
240 MachineFunction *MF;
241 MachineFunctionAnalysisManager *MFAM = nullptr;
242 Pass *SDAGISelPass = nullptr;
243 LLVMContext *Context;
244 CodeGenOptLevel OptLevel;
245
246 UniformityInfo *UA = nullptr;
247 FunctionLoweringInfo * FLI = nullptr;
248
249 /// The function-level optimization remark emitter. Used to emit remarks
250 /// whenever manipulating the DAG.
252
253 ProfileSummaryInfo *PSI = nullptr;
254 BlockFrequencyInfo *BFI = nullptr;
255 MachineModuleInfo *MMI = nullptr;
256
257 /// Extended EVTs used for single value VTLists.
258 std::set<EVT, EVT::compareRawBits> EVTs;
259
260 /// List of non-single value types.
261 FoldingSet<SDVTListNode> VTListMap;
262
263 /// Pool allocation for misc. objects that are created once per SelectionDAG.
264 BumpPtrAllocator Allocator;
265
266 /// The starting token.
267 SDNode EntryNode;
268
269 /// The root of the entire DAG.
270 SDValue Root;
271
272 /// A linked list of nodes in the current DAG.
273 ilist<SDNode> AllNodes;
274
275 /// The AllocatorType for allocating SDNodes. We use
276 /// pool allocation with recycling.
277 using NodeAllocatorType = RecyclingAllocator<BumpPtrAllocator, SDNode,
278 sizeof(LargestSDNode),
279 alignof(MostAlignedSDNode)>;
280
281 /// Pool allocation for nodes.
282 NodeAllocatorType NodeAllocator;
283
284 /// This structure is used to memoize nodes, automatically performing
285 /// CSE with existing nodes when a duplicate is requested.
286 FoldingSet<SDNode> CSEMap;
287
288 /// Pool allocation for machine-opcode SDNode operands.
289 BumpPtrAllocator OperandAllocator;
290 ArrayRecycler<SDUse> OperandRecycler;
291
292 /// Tracks dbg_value and dbg_label information through SDISel.
293 SDDbgInfo *DbgInfo;
294
295 using CallSiteInfo = MachineFunction::CallSiteInfo;
296 using CalledGlobalInfo = MachineFunction::CalledGlobalInfo;
297
298 struct NodeExtraInfo {
299 CallSiteInfo CSInfo;
300 MDNode *HeapAllocSite = nullptr;
301 MDNode *PCSections = nullptr;
302 MDNode *MMRA = nullptr;
303 CalledGlobalInfo CalledGlobal{};
304 bool NoMerge = false;
305 };
306 /// Out-of-line extra information for SDNodes.
308
309 /// PersistentId counter to be used when inserting the next
310 /// SDNode to this SelectionDAG. We do not place that under
311 /// `#if LLVM_ENABLE_ABI_BREAKING_CHECKS` intentionally because
312 /// it adds unneeded complexity without noticeable
313 /// benefits (see discussion with @thakis in D120714).
314 uint16_t NextPersistentId = 0;
315
316public:
317 /// Clients of various APIs that cause global effects on
318 /// the DAG can optionally implement this interface. This allows the clients
319 /// to handle the various sorts of updates that happen.
320 ///
321 /// A DAGUpdateListener automatically registers itself with DAG when it is
322 /// constructed, and removes itself when destroyed in RAII fashion.
326
328 : Next(D.UpdateListeners), DAG(D) {
329 DAG.UpdateListeners = this;
330 }
331
333 assert(DAG.UpdateListeners == this &&
334 "DAGUpdateListeners must be destroyed in LIFO order");
335 DAG.UpdateListeners = Next;
336 }
337
338 /// The node N that was deleted and, if E is not null, an
339 /// equivalent node E that replaced it.
340 virtual void NodeDeleted(SDNode *N, SDNode *E);
341
342 /// The node N that was updated.
343 virtual void NodeUpdated(SDNode *N);
344
345 /// The node N that was inserted.
346 virtual void NodeInserted(SDNode *N);
347 };
348
350 std::function<void(SDNode *, SDNode *)> Callback;
351
355
356 void NodeDeleted(SDNode *N, SDNode *E) override { Callback(N, E); }
357
358 private:
359 virtual void anchor();
360 };
361
363 std::function<void(SDNode *)> Callback;
364
368
369 void NodeInserted(SDNode *N) override { Callback(N); }
370
371 private:
372 virtual void anchor();
373 };
374
375 /// Help to insert SDNodeFlags automatically in transforming. Use
376 /// RAII to save and resume flags in current scope.
378 SelectionDAG &DAG;
379 SDNodeFlags Flags;
380 FlagInserter *LastInserter;
381
382 public:
384 : DAG(SDAG), Flags(Flags),
385 LastInserter(SDAG.getFlagInserter()) {
386 SDAG.setFlagInserter(this);
387 }
390
391 FlagInserter(const FlagInserter &) = delete;
393 ~FlagInserter() { DAG.setFlagInserter(LastInserter); }
394
395 SDNodeFlags getFlags() const { return Flags; }
396 };
397
398 /// When true, additional steps are taken to
399 /// ensure that getConstant() and similar functions return DAG nodes that
400 /// have legal types. This is important after type legalization since
401 /// any illegally typed nodes generated after this point will not experience
402 /// type legalization.
404
405private:
406 /// DAGUpdateListener is a friend so it can manipulate the listener stack.
407 friend struct DAGUpdateListener;
408
409 /// Linked list of registered DAGUpdateListener instances.
410 /// This stack is maintained by DAGUpdateListener RAII.
411 DAGUpdateListener *UpdateListeners = nullptr;
412
413 /// Implementation of setSubgraphColor.
414 /// Return whether we had to truncate the search.
415 bool setSubgraphColorHelper(SDNode *N, const char *Color,
416 DenseSet<SDNode *> &visited,
417 int level, bool &printed);
418
419 template <typename SDNodeT, typename... ArgTypes>
420 SDNodeT *newSDNode(ArgTypes &&... Args) {
421 return new (NodeAllocator.template Allocate<SDNodeT>())
422 SDNodeT(std::forward<ArgTypes>(Args)...);
423 }
424
425 /// Build a synthetic SDNodeT with the given args and extract its subclass
426 /// data as an integer (e.g. for use in a folding set).
427 ///
428 /// The args to this function are the same as the args to SDNodeT's
429 /// constructor, except the second arg (assumed to be a const DebugLoc&) is
430 /// omitted.
431 template <typename SDNodeT, typename... ArgTypes>
432 static uint16_t getSyntheticNodeSubclassData(unsigned IROrder,
433 ArgTypes &&... Args) {
434 // The compiler can reduce this expression to a constant iff we pass an
435 // empty DebugLoc. Thankfully, the debug location doesn't have any bearing
436 // on the subclass data.
437 return SDNodeT(IROrder, DebugLoc(), std::forward<ArgTypes>(Args)...)
438 .getRawSubclassData();
439 }
440
441 template <typename SDNodeTy>
442 static uint16_t getSyntheticNodeSubclassData(unsigned Opc, unsigned Order,
443 SDVTList VTs, EVT MemoryVT,
444 MachineMemOperand *MMO) {
445 return SDNodeTy(Opc, Order, DebugLoc(), VTs, MemoryVT, MMO)
446 .getRawSubclassData();
447 }
448
449 template <typename SDNodeTy>
450 static uint16_t getSyntheticNodeSubclassData(
451 unsigned Opc, unsigned Order, SDVTList VTs, EVT MemoryVT,
452 PointerUnion<MachineMemOperand *, MachineMemOperand **> MemRefs) {
453 return SDNodeTy(Opc, Order, DebugLoc(), VTs, MemoryVT, MemRefs)
454 .getRawSubclassData();
455 }
456
457 void createOperands(SDNode *Node, ArrayRef<SDValue> Vals);
458
459 void removeOperands(SDNode *Node) {
460 if (!Node->OperandList)
461 return;
462 OperandRecycler.deallocate(
464 Node->OperandList);
465 Node->NumOperands = 0;
466 Node->OperandList = nullptr;
467 }
468 void CreateTopologicalOrder(std::vector<SDNode*>& Order);
469
470public:
471 // Maximum depth for recursive analysis such as computeKnownBits, etc.
472 static constexpr unsigned MaxRecursionDepth = 6;
473
474 // Returns the maximum steps for SDNode->hasPredecessor() like searches.
475 LLVM_ABI static unsigned getHasPredecessorMaxSteps();
476
478 SelectionDAG(const SelectionDAG &) = delete;
481
482 /// Prepare this SelectionDAG to process code in the given MachineFunction.
484 Pass *PassPtr, const TargetLibraryInfo *LibraryInfo,
485 const LibcallLoweringInfo *LibcallsInfo,
488 FunctionVarLocs const *FnVarLocs);
489
492 const TargetLibraryInfo *LibraryInfo,
493 const LibcallLoweringInfo *LibcallsInfo, UniformityInfo *UA,
495 MachineModuleInfo &MMI, FunctionVarLocs const *FnVarLocs) {
496 init(NewMF, NewORE, nullptr, LibraryInfo, LibcallsInfo, UA, PSIin, BFIin,
497 MMI, FnVarLocs);
498 MFAM = &AM;
499 }
500
502 FLI = FuncInfo;
503 }
504
505 /// Clear state and free memory necessary to make this
506 /// SelectionDAG ready to process a new block.
507 LLVM_ABI void clear();
508
509 MachineFunction &getMachineFunction() const { return *MF; }
510 const Pass *getPass() const { return SDAGISelPass; }
512
513 CodeGenOptLevel getOptLevel() const { return OptLevel; }
514 const DataLayout &getDataLayout() const { return MF->getDataLayout(); }
515 const TargetMachine &getTarget() const { return TM; }
516 const TargetSubtargetInfo &getSubtarget() const { return MF->getSubtarget(); }
517 template <typename STC> const STC &getSubtarget() const {
518 return MF->getSubtarget<STC>();
519 }
520 const TargetLowering &getTargetLoweringInfo() const { return *TLI; }
521 const TargetLibraryInfo &getLibInfo() const { return *LibInfo; }
522
523 const LibcallLoweringInfo &getLibcalls() const { return *Libcalls; }
524
526 return *RuntimeLibcallInfo;
527 }
528
529 const SelectionDAGTargetInfo &getSelectionDAGInfo() const { return *TSI; }
530 const UniformityInfo *getUniformityInfo() const { return UA; }
531 /// Returns the result of the AssignmentTrackingAnalysis pass if it's
532 /// available, otherwise return nullptr.
533 const FunctionVarLocs *getFunctionVarLocs() const { return FnVarLocs; }
534 LLVMContext *getContext() const { return Context; }
535 OptimizationRemarkEmitter &getORE() const { return *ORE; }
536 ProfileSummaryInfo *getPSI() const { return PSI; }
537 BlockFrequencyInfo *getBFI() const { return BFI; }
538 MachineModuleInfo *getMMI() const { return MMI; }
539
540 FlagInserter *getFlagInserter() { return Inserter; }
541 void setFlagInserter(FlagInserter *FI) { Inserter = FI; }
542
543 /// Just dump dot graph to a user-provided path and title.
544 /// This doesn't open the dot viewer program and
545 /// helps visualization when outside debugging session.
546 /// FileName expects absolute path. If provided
547 /// without any path separators then the file
548 /// will be created in the current directory.
549 /// Error will be emitted if the path is insane.
550#if !defined(NDEBUG) || defined(LLVM_ENABLE_DUMP)
551 LLVM_DUMP_METHOD void dumpDotGraph(const Twine &FileName, const Twine &Title);
552#endif
553
554 /// Pop up a GraphViz/gv window with the DAG rendered using 'dot'.
555 LLVM_ABI void viewGraph(const std::string &Title);
556 LLVM_ABI void viewGraph();
557
558#if LLVM_ENABLE_ABI_BREAKING_CHECKS
559 std::map<const SDNode *, std::string> NodeGraphAttrs;
560#endif
561
562 /// Clear all previously defined node graph attributes.
563 /// Intended to be used from a debugging tool (eg. gdb).
565
566 /// Set graph attributes for a node. (eg. "color=red".)
567 LLVM_ABI void setGraphAttrs(const SDNode *N, const char *Attrs);
568
569 /// Get graph attributes for a node. (eg. "color=red".)
570 /// Used from getNodeAttributes.
571 LLVM_ABI std::string getGraphAttrs(const SDNode *N) const;
572
573 /// Convenience for setting node color attribute.
574 LLVM_ABI void setGraphColor(const SDNode *N, const char *Color);
575
576 /// Convenience for setting subgraph color attribute.
577 LLVM_ABI void setSubgraphColor(SDNode *N, const char *Color);
578
580
581 allnodes_const_iterator allnodes_begin() const { return AllNodes.begin(); }
582 allnodes_const_iterator allnodes_end() const { return AllNodes.end(); }
583
585
586 allnodes_iterator allnodes_begin() { return AllNodes.begin(); }
587 allnodes_iterator allnodes_end() { return AllNodes.end(); }
588
590 return AllNodes.size();
591 }
592
599
600 /// Return the root tag of the SelectionDAG.
601 const SDValue &getRoot() const { return Root; }
602
603 /// Return the token chain corresponding to the entry of the function.
605 return SDValue(const_cast<SDNode *>(&EntryNode), 0);
606 }
607
608 /// Set the current root tag of the SelectionDAG.
609 ///
611 assert((!N.getNode() || N.getValueType() == MVT::Other) &&
612 "DAG root value is not a chain!");
613 if (N.getNode())
614 checkForCycles(N.getNode(), this);
615 Root = N;
616 if (N.getNode())
617 checkForCycles(this);
618 return Root;
619 }
620
621#if !defined(NDEBUG) && LLVM_ENABLE_ABI_BREAKING_CHECKS
622 void VerifyDAGDivergence();
623#endif
624
625 /// This iterates over the nodes in the SelectionDAG, folding
626 /// certain types of nodes together, or eliminating superfluous nodes. The
627 /// Level argument controls whether Combine is allowed to produce nodes and
628 /// types that are illegal on the target.
629 LLVM_ABI void Combine(CombineLevel Level, BatchAAResults *BatchAA,
630 CodeGenOptLevel OptLevel);
631
632 /// This transforms the SelectionDAG into a SelectionDAG that
633 /// only uses types natively supported by the target.
634 /// Returns "true" if it made any changes.
635 ///
636 /// Note that this is an involved process that may invalidate pointers into
637 /// the graph.
638 LLVM_ABI bool LegalizeTypes();
639
640 /// This transforms the SelectionDAG into a SelectionDAG that is
641 /// compatible with the target instruction selector, as indicated by the
642 /// TargetLowering object.
643 ///
644 /// Note that this is an involved process that may invalidate pointers into
645 /// the graph.
646 LLVM_ABI void Legalize();
647
648 /// Transforms a SelectionDAG node and any operands to it into a node
649 /// that is compatible with the target instruction selector, as indicated by
650 /// the TargetLowering object.
651 ///
652 /// \returns true if \c N is a valid, legal node after calling this.
653 ///
654 /// This essentially runs a single recursive walk of the \c Legalize process
655 /// over the given node (and its operands). This can be used to incrementally
656 /// legalize the DAG. All of the nodes which are directly replaced,
657 /// potentially including N, are added to the output parameter \c
658 /// UpdatedNodes so that the delta to the DAG can be understood by the
659 /// caller.
660 ///
661 /// When this returns false, N has been legalized in a way that make the
662 /// pointer passed in no longer valid. It may have even been deleted from the
663 /// DAG, and so it shouldn't be used further. When this returns true, the
664 /// N passed in is a legal node, and can be immediately processed as such.
665 /// This may still have done some work on the DAG, and will still populate
666 /// UpdatedNodes with any new nodes replacing those originally in the DAG.
668 SmallSetVector<SDNode *, 16> &UpdatedNodes);
669
670 /// This transforms the SelectionDAG into a SelectionDAG
671 /// that only uses vector math operations supported by the target. This is
672 /// necessary as a separate step from Legalize because unrolling a vector
673 /// operation can introduce illegal types, which requires running
674 /// LegalizeTypes again.
675 ///
676 /// This returns true if it made any changes; in that case, LegalizeTypes
677 /// is called again before Legalize.
678 ///
679 /// Note that this is an involved process that may invalidate pointers into
680 /// the graph.
682
683 /// This method deletes all unreachable nodes in the SelectionDAG.
685
686 /// Remove the specified node from the system. This node must
687 /// have no referrers.
689
690 /// Return an SDVTList that represents the list of values specified.
693 LLVM_ABI SDVTList getVTList(EVT VT1, EVT VT2, EVT VT3);
694 LLVM_ABI SDVTList getVTList(EVT VT1, EVT VT2, EVT VT3, EVT VT4);
696
697 //===--------------------------------------------------------------------===//
698 // Node creation methods.
699
700 /// Create a ConstantSDNode wrapping a constant value.
701 /// If VT is a vector type, the constant is splatted into a BUILD_VECTOR.
702 ///
703 /// If only legal types can be produced, this does the necessary
704 /// transformations (e.g., if the vector element type is illegal).
705 /// @{
707 bool isTarget = false, bool isOpaque = false);
708 LLVM_ABI SDValue getConstant(const APInt &Val, const SDLoc &DL, EVT VT,
709 bool isTarget = false, bool isOpaque = false);
710
711 LLVM_ABI SDValue getSignedConstant(int64_t Val, const SDLoc &DL, EVT VT,
712 bool isTarget = false,
713 bool isOpaque = false);
714
716 bool IsTarget = false,
717 bool IsOpaque = false);
718
719 LLVM_ABI SDValue getConstant(const ConstantInt &Val, const SDLoc &DL, EVT VT,
720 bool isTarget = false, bool isOpaque = false);
722 bool isTarget = false);
724 const SDLoc &DL);
726 const SDLoc &DL);
728 bool isTarget = false);
729
731 bool isOpaque = false) {
732 return getConstant(Val, DL, VT, true, isOpaque);
733 }
734 SDValue getTargetConstant(const APInt &Val, const SDLoc &DL, EVT VT,
735 bool isOpaque = false) {
736 return getConstant(Val, DL, VT, true, isOpaque);
737 }
739 bool isOpaque = false) {
740 return getConstant(Val, DL, VT, true, isOpaque);
741 }
742 SDValue getSignedTargetConstant(int64_t Val, const SDLoc &DL, EVT VT,
743 bool isOpaque = false) {
744 return getSignedConstant(Val, DL, VT, true, isOpaque);
745 }
746
747 /// Create a true or false constant of type \p VT using the target's
748 /// BooleanContent for type \p OpVT.
749 LLVM_ABI SDValue getBoolConstant(bool V, const SDLoc &DL, EVT VT, EVT OpVT);
750 /// @}
751
752 /// Create a ConstantFPSDNode wrapping a constant value.
753 /// If VT is a vector type, the constant is splatted into a BUILD_VECTOR.
754 ///
755 /// If only legal types can be produced, this does the necessary
756 /// transformations (e.g., if the vector element type is illegal).
757 /// The forms that take a double should only be used for simple constants
758 /// that can be exactly represented in VT. No checks are made.
759 /// @{
760 LLVM_ABI SDValue getConstantFP(double Val, const SDLoc &DL, EVT VT,
761 bool isTarget = false);
762 LLVM_ABI SDValue getConstantFP(const APFloat &Val, const SDLoc &DL, EVT VT,
763 bool isTarget = false);
764 LLVM_ABI SDValue getConstantFP(const ConstantFP &V, const SDLoc &DL, EVT VT,
765 bool isTarget = false);
766 SDValue getTargetConstantFP(double Val, const SDLoc &DL, EVT VT) {
767 return getConstantFP(Val, DL, VT, true);
768 }
769 SDValue getTargetConstantFP(const APFloat &Val, const SDLoc &DL, EVT VT) {
770 return getConstantFP(Val, DL, VT, true);
771 }
773 return getConstantFP(Val, DL, VT, true);
774 }
775 /// @}
776
778 EVT VT, int64_t offset = 0,
779 bool isTargetGA = false,
780 unsigned TargetFlags = 0);
782 int64_t offset = 0, unsigned TargetFlags = 0) {
783 return getGlobalAddress(GV, DL, VT, offset, true, TargetFlags);
784 }
786 LLVM_ABI SDValue getFrameIndex(int FI, EVT VT, bool isTarget = false);
788 return getFrameIndex(FI, VT, true);
789 }
790 LLVM_ABI SDValue getJumpTable(int JTI, EVT VT, bool isTarget = false,
791 unsigned TargetFlags = 0);
792 SDValue getTargetJumpTable(int JTI, EVT VT, unsigned TargetFlags = 0) {
793 return getJumpTable(JTI, VT, true, TargetFlags);
794 }
796 const SDLoc &DL);
798 MaybeAlign Align = std::nullopt,
799 int Offs = 0, bool isT = false,
800 unsigned TargetFlags = 0);
802 MaybeAlign Align = std::nullopt, int Offset = 0,
803 unsigned TargetFlags = 0) {
804 return getConstantPool(C, VT, Align, Offset, true, TargetFlags);
805 }
807 MaybeAlign Align = std::nullopt,
808 int Offs = 0, bool isT = false,
809 unsigned TargetFlags = 0);
811 MaybeAlign Align = std::nullopt, int Offset = 0,
812 unsigned TargetFlags = 0) {
813 return getConstantPool(C, VT, Align, Offset, true, TargetFlags);
814 }
815 // When generating a branch to a BB, we don't in general know enough
816 // to provide debug info for the BB at that time, so keep this one around.
818 LLVM_ABI SDValue getExternalSymbol(const char *Sym, EVT VT);
819 LLVM_ABI SDValue getExternalSymbol(RTLIB::LibcallImpl LCImpl, EVT VT);
820 LLVM_ABI SDValue getTargetExternalSymbol(const char *Sym, EVT VT,
821 unsigned TargetFlags = 0);
822 LLVM_ABI SDValue getTargetExternalSymbol(RTLIB::LibcallImpl LCImpl, EVT VT,
823 unsigned TargetFlags = 0);
824
826
830 LLVM_ABI SDValue getEHLabel(const SDLoc &dl, SDValue Root, MCSymbol *Label);
831 LLVM_ABI SDValue getLabelNode(unsigned Opcode, const SDLoc &dl, SDValue Root,
832 MCSymbol *Label);
834 int64_t Offset = 0, bool isTarget = false,
835 unsigned TargetFlags = 0);
837 int64_t Offset = 0, unsigned TargetFlags = 0) {
838 return getBlockAddress(BA, VT, Offset, true, TargetFlags);
839 }
840
842 SDValue N) {
843 return getNode(ISD::CopyToReg, dl, MVT::Other, Chain,
844 getRegister(Reg, N.getValueType()), N);
845 }
846
847 // This version of the getCopyToReg method takes an extra operand, which
848 // indicates that there is potentially an incoming glue value (if Glue is not
849 // null) and that there should be a glue result.
851 SDValue Glue) {
852 SDVTList VTs = getVTList(MVT::Other, MVT::Glue);
853 SDValue Ops[] = { Chain, getRegister(Reg, N.getValueType()), N, Glue };
854 return getNode(ISD::CopyToReg, dl, VTs,
855 ArrayRef(Ops, Glue.getNode() ? 4 : 3));
856 }
857
858 // Similar to last getCopyToReg() except parameter Reg is a SDValue
860 SDValue Glue) {
861 SDVTList VTs = getVTList(MVT::Other, MVT::Glue);
862 SDValue Ops[] = { Chain, Reg, N, Glue };
863 return getNode(ISD::CopyToReg, dl, VTs,
864 ArrayRef(Ops, Glue.getNode() ? 4 : 3));
865 }
866
868 SDVTList VTs = getVTList(VT, MVT::Other);
869 SDValue Ops[] = { Chain, getRegister(Reg, VT) };
870 return getNode(ISD::CopyFromReg, dl, VTs, Ops);
871 }
872
873 // This version of the getCopyFromReg method takes an extra operand, which
874 // indicates that there is potentially an incoming glue value (if Glue is not
875 // null) and that there should be a glue result.
877 SDValue Glue) {
878 SDVTList VTs = getVTList(VT, MVT::Other, MVT::Glue);
879 SDValue Ops[] = { Chain, getRegister(Reg, VT), Glue };
880 return getNode(ISD::CopyFromReg, dl, VTs,
881 ArrayRef(Ops, Glue.getNode() ? 3 : 2));
882 }
883
885
886 /// Return an ISD::VECTOR_SHUFFLE node. The number of elements in VT,
887 /// which must be a vector type, must match the number of mask elements
888 /// NumElts. An integer mask element equal to -1 is treated as undefined.
890 SDValue N2, ArrayRef<int> Mask);
891
892 /// Return an ISD::BUILD_VECTOR node. The number of elements in VT,
893 /// which must be a vector type, must match the number of operands in Ops.
894 /// The operands must have the same type as (or, for integers, a type wider
895 /// than) VT's element type.
897 // VerifySDNode (via InsertNode) checks BUILD_VECTOR later.
898 return getNode(ISD::BUILD_VECTOR, DL, VT, Ops);
899 }
900
901 /// Return an ISD::BUILD_VECTOR node. The number of elements in VT,
902 /// which must be a vector type, must match the number of operands in Ops.
903 /// The operands must have the same type as (or, for integers, a type wider
904 /// than) VT's element type.
906 // VerifySDNode (via InsertNode) checks BUILD_VECTOR later.
907 return getNode(ISD::BUILD_VECTOR, DL, VT, Ops);
908 }
909
910 /// Return a splat ISD::BUILD_VECTOR node, consisting of Op splatted to all
911 /// elements. VT must be a vector type. Op's type must be the same as (or,
912 /// for integers, a type wider than) VT's element type.
914 // VerifySDNode (via InsertNode) checks BUILD_VECTOR later.
915 if (Op.isUndef()) {
916 assert((VT.getVectorElementType() == Op.getValueType() ||
917 (VT.isInteger() &&
918 VT.getVectorElementType().bitsLE(Op.getValueType()))) &&
919 "A splatted value must have a width equal or (for integers) "
920 "greater than the vector element type!");
921 return getNode(ISD::UNDEF, SDLoc(), VT);
922 }
923
925 return getNode(ISD::BUILD_VECTOR, DL, VT, Ops);
926 }
927
928 // Return a splat ISD::SPLAT_VECTOR node, consisting of Op splatted to all
929 // elements.
931 if (Op.isUndef()) {
932 assert((VT.getVectorElementType() == Op.getValueType() ||
933 (VT.isInteger() &&
934 VT.getVectorElementType().bitsLE(Op.getValueType()))) &&
935 "A splatted value must have a width equal or (for integers) "
936 "greater than the vector element type!");
937 return getNode(ISD::UNDEF, SDLoc(), VT);
938 }
939 return getNode(ISD::SPLAT_VECTOR, DL, VT, Op);
940 }
941
942 /// Returns a node representing a splat of one value into all lanes
943 /// of the provided vector type. This is a utility which returns
944 /// either a BUILD_VECTOR or SPLAT_VECTOR depending on the
945 /// scalability of the desired vector type.
947 assert(VT.isVector() && "Can't splat to non-vector type");
948 return VT.isScalableVector() ?
950 }
951
952 /// Returns a vector of type ResVT whose elements contain the linear sequence
953 /// <0, Step, Step * 2, Step * 3, ...>
955 const APInt &StepVal);
956
957 /// Returns a vector of type ResVT whose elements contain the linear sequence
958 /// <0, 1, 2, 3, ...>
959 LLVM_ABI SDValue getStepVector(const SDLoc &DL, EVT ResVT);
960
961 /// Returns an ISD::VECTOR_SHUFFLE node semantically equivalent to
962 /// the shuffle node in input but with swapped operands.
963 ///
964 /// Example: shuffle A, B, <0,5,2,7> -> shuffle B, A, <4,1,6,3>
966
967 /// Extract element at \p Idx from \p Vec. See EXTRACT_VECTOR_ELT
968 /// description for result type handling.
970 unsigned Idx) {
971 return getNode(ISD::EXTRACT_VECTOR_ELT, DL, VT, Vec,
973 }
974
975 /// Insert \p Elt into \p Vec at offset \p Idx. See INSERT_VECTOR_ELT
976 /// description for element type handling.
978 unsigned Idx) {
979 return getNode(ISD::INSERT_VECTOR_ELT, DL, Vec.getValueType(), Vec, Elt,
981 }
982
983 /// Insert \p SubVec at the \p Idx element of \p Vec.
985 unsigned Idx) {
986 return getNode(ISD::INSERT_SUBVECTOR, DL, Vec.getValueType(), Vec, SubVec,
988 }
989
990 /// Return the \p VT typed sub-vector of \p Vec at \p Idx
992 unsigned Idx) {
993 return getNode(ISD::EXTRACT_SUBVECTOR, DL, VT, Vec,
995 }
996
997 /// Convert Op, which must be of float type, to the
998 /// float type VT, by either extending or rounding (by truncation).
1000
1001 /// Convert Op, which must be a STRICT operation of float type, to the
1002 /// float type VT, by either extending or rounding (by truncation).
1003 LLVM_ABI std::pair<SDValue, SDValue>
1005
1006 /// Convert *_EXTEND_VECTOR_INREG to *_EXTEND opcode.
1007 static unsigned getOpcode_EXTEND(unsigned Opcode) {
1008 switch (Opcode) {
1009 case ISD::ANY_EXTEND:
1011 return ISD::ANY_EXTEND;
1012 case ISD::ZERO_EXTEND:
1014 return ISD::ZERO_EXTEND;
1015 case ISD::SIGN_EXTEND:
1017 return ISD::SIGN_EXTEND;
1018 }
1019 llvm_unreachable("Unknown opcode");
1020 }
1021
1022 /// Convert *_EXTEND to *_EXTEND_VECTOR_INREG opcode.
1023 static unsigned getOpcode_EXTEND_VECTOR_INREG(unsigned Opcode) {
1024 switch (Opcode) {
1025 case ISD::ANY_EXTEND:
1028 case ISD::ZERO_EXTEND:
1031 case ISD::SIGN_EXTEND:
1034 }
1035 llvm_unreachable("Unknown opcode");
1036 }
1037
1038 /// Convert Op, which must be of integer type, to the
1039 /// integer type VT, by either any-extending or truncating it.
1041
1042 /// Convert Op, which must be of integer type, to the
1043 /// integer type VT, by either sign-extending or truncating it.
1045
1046 /// Convert Op, which must be of integer type, to the
1047 /// integer type VT, by either zero-extending or truncating it.
1049
1050 /// Convert Op, which must be of integer type, to the
1051 /// integer type VT, by either any/sign/zero-extending (depending on IsAny /
1052 /// IsSigned) or truncating it.
1054 EVT VT, unsigned Opcode) {
1055 switch(Opcode) {
1056 case ISD::ANY_EXTEND:
1057 return getAnyExtOrTrunc(Op, DL, VT);
1058 case ISD::ZERO_EXTEND:
1059 return getZExtOrTrunc(Op, DL, VT);
1060 case ISD::SIGN_EXTEND:
1061 return getSExtOrTrunc(Op, DL, VT);
1062 }
1063 llvm_unreachable("Unsupported opcode");
1064 }
1065
1066 /// Convert Op, which must be of integer type, to the
1067 /// integer type VT, by either sign/zero-extending (depending on IsSigned) or
1068 /// truncating it.
1069 SDValue getExtOrTrunc(bool IsSigned, SDValue Op, const SDLoc &DL, EVT VT) {
1070 return IsSigned ? getSExtOrTrunc(Op, DL, VT) : getZExtOrTrunc(Op, DL, VT);
1071 }
1072
1073 /// Convert Op, which must be of integer type, to the
1074 /// integer type VT, by first bitcasting (from potential vector) to
1075 /// corresponding scalar type then either any-extending or truncating it.
1077 EVT VT);
1078
1079 /// Convert Op, which must be of integer type, to the
1080 /// integer type VT, by first bitcasting (from potential vector) to
1081 /// corresponding scalar type then either sign-extending or truncating it.
1083
1084 /// Convert Op, which must be of integer type, to the
1085 /// integer type VT, by first bitcasting (from potential vector) to
1086 /// corresponding scalar type then either zero-extending or truncating it.
1088
1089 /// Return the expression required to zero extend the Op
1090 /// value assuming it was the smaller SrcTy value.
1092
1093 /// Return the expression required to zero extend the Op
1094 /// value assuming it was the smaller SrcTy value.
1096 const SDLoc &DL, EVT VT);
1097
1098 /// Convert Op, which must be of integer type, to the integer type VT, by
1099 /// either truncating it or performing either zero or sign extension as
1100 /// appropriate extension for the pointer's semantics.
1102
1103 /// Return the expression required to extend the Op as a pointer value
1104 /// assuming it was the smaller SrcTy value. This may be either a zero extend
1105 /// or a sign extend.
1107
1108 /// Convert Op, which must be of integer type, to the integer type VT,
1109 /// by using an extension appropriate for the target's
1110 /// BooleanContent for type OpVT or truncating it.
1112 EVT OpVT);
1113
1114 /// Create negative operation as (SUB 0, Val).
1115 LLVM_ABI SDValue getNegative(SDValue Val, const SDLoc &DL, EVT VT);
1116
1117 /// Create a bitwise NOT operation as (XOR Val, -1).
1118 LLVM_ABI SDValue getNOT(const SDLoc &DL, SDValue Val, EVT VT);
1119
1120 /// Create a logical NOT operation as (XOR Val, BooleanOne).
1121 LLVM_ABI SDValue getLogicalNOT(const SDLoc &DL, SDValue Val, EVT VT);
1122
1123 /// Create a vector-predicated logical NOT operation as (VP_XOR Val,
1124 /// BooleanOne, Mask, EVL).
1126 SDValue EVL, EVT VT);
1127
1128 /// Convert a vector-predicated Op, which must be an integer vector, to the
1129 /// vector-type VT, by performing either vector-predicated zext or truncating
1130 /// it. The Op will be returned as-is if Op and VT are vectors containing
1131 /// integer with same width.
1133 SDValue Mask, SDValue EVL);
1134
1135 /// Convert a vector-predicated Op, which must be of integer type, to the
1136 /// vector-type integer type VT, by either truncating it or performing either
1137 /// vector-predicated zero or sign extension as appropriate extension for the
1138 /// pointer's semantics. This function just redirects to getVPZExtOrTrunc
1139 /// right now.
1141 SDValue Mask, SDValue EVL);
1142
1143 /// Returns sum of the base pointer and offset.
1144 /// Unlike getObjectPtrOffset this does not set NoUnsignedWrap and InBounds by
1145 /// default.
1148 const SDNodeFlags Flags = SDNodeFlags());
1151 const SDNodeFlags Flags = SDNodeFlags());
1152
1153 /// Create an add instruction with appropriate flags when used for
1154 /// addressing some offset of an object. i.e. if a load is split into multiple
1155 /// components, create an add nuw (or ptradd nuw inbounds) from the base
1156 /// pointer to the offset.
1161
1163 // The object itself can't wrap around the address space, so it shouldn't be
1164 // possible for the adds of the offsets to the split parts to overflow.
1165 return getMemBasePlusOffset(
1167 }
1168
1169 /// Return a new CALLSEQ_START node, that starts new call frame, in which
1170 /// InSize bytes are set up inside CALLSEQ_START..CALLSEQ_END sequence and
1171 /// OutSize specifies part of the frame set up prior to the sequence.
1173 const SDLoc &DL) {
1174 SDVTList VTs = getVTList(MVT::Other, MVT::Glue);
1175 SDValue Ops[] = { Chain,
1176 getIntPtrConstant(InSize, DL, true),
1177 getIntPtrConstant(OutSize, DL, true) };
1178 return getNode(ISD::CALLSEQ_START, DL, VTs, Ops);
1179 }
1180
1181 /// Return a new CALLSEQ_END node, which always must have a
1182 /// glue result (to ensure it's not CSE'd).
1183 /// CALLSEQ_END does not have a useful SDLoc.
1185 SDValue InGlue, const SDLoc &DL) {
1186 SDVTList NodeTys = getVTList(MVT::Other, MVT::Glue);
1188 Ops.push_back(Chain);
1189 Ops.push_back(Op1);
1190 Ops.push_back(Op2);
1191 if (InGlue.getNode())
1192 Ops.push_back(InGlue);
1193 return getNode(ISD::CALLSEQ_END, DL, NodeTys, Ops);
1194 }
1195
1197 SDValue Glue, const SDLoc &DL) {
1198 return getCALLSEQ_END(
1199 Chain, getIntPtrConstant(Size1, DL, /*isTarget=*/true),
1200 getIntPtrConstant(Size2, DL, /*isTarget=*/true), Glue, DL);
1201 }
1202
1203 /// Return true if the result of this operation is always undefined.
1204 LLVM_ABI bool isUndef(unsigned Opcode, ArrayRef<SDValue> Ops);
1205
1206 /// Return an UNDEF node. UNDEF does not have a useful SDLoc.
1208 return getNode(ISD::UNDEF, SDLoc(), VT);
1209 }
1210
1211 /// Return a POISON node. POISON does not have a useful SDLoc.
1213
1214 /// Return a node that represents the runtime scaling 'MulImm * RuntimeVL'.
1215 LLVM_ABI SDValue getVScale(const SDLoc &DL, EVT VT, APInt MulImm);
1216
1218
1220
1221 /// Return a vector with the first 'Len' lanes set to true and remaining lanes
1222 /// set to false. The mask's ValueType is the same as when comparing vectors
1223 /// of type VT.
1225 ElementCount Len);
1226
1227 /// Return a GLOBAL_OFFSET_TABLE node. This does not have a useful SDLoc.
1231
1232 /// Gets or creates the specified node.
1233 ///
1234 LLVM_ABI SDValue getNode(unsigned Opcode, const SDLoc &DL, EVT VT,
1236 LLVM_ABI SDValue getNode(unsigned Opcode, const SDLoc &DL, EVT VT,
1237 ArrayRef<SDValue> Ops, const SDNodeFlags Flags);
1238 LLVM_ABI SDValue getNode(unsigned Opcode, const SDLoc &DL,
1240 const SDNodeFlags Flags);
1241 LLVM_ABI SDValue getNode(unsigned Opcode, const SDLoc &DL, SDVTList VTList,
1242 ArrayRef<SDValue> Ops, const SDNodeFlags Flags);
1243
1244 // Use flags from current flag inserter.
1245 LLVM_ABI SDValue getNode(unsigned Opcode, const SDLoc &DL, EVT VT,
1247 LLVM_ABI SDValue getNode(unsigned Opcode, const SDLoc &DL,
1249 LLVM_ABI SDValue getNode(unsigned Opcode, const SDLoc &DL, SDVTList VTList,
1251 LLVM_ABI SDValue getNode(unsigned Opcode, const SDLoc &DL, EVT VT,
1252 SDValue Operand);
1253 LLVM_ABI SDValue getNode(unsigned Opcode, const SDLoc &DL, EVT VT, SDValue N1,
1254 SDValue N2);
1255 LLVM_ABI SDValue getNode(unsigned Opcode, const SDLoc &DL, EVT VT, SDValue N1,
1256 SDValue N2, SDValue N3);
1257
1258 // Specialize based on number of operands.
1259 LLVM_ABI SDValue getNode(unsigned Opcode, const SDLoc &DL, EVT VT);
1260 LLVM_ABI SDValue getNode(unsigned Opcode, const SDLoc &DL, EVT VT,
1261 SDValue Operand, const SDNodeFlags Flags);
1262 LLVM_ABI SDValue getNode(unsigned Opcode, const SDLoc &DL, EVT VT, SDValue N1,
1263 SDValue N2, const SDNodeFlags Flags);
1264 LLVM_ABI SDValue getNode(unsigned Opcode, const SDLoc &DL, EVT VT, SDValue N1,
1265 SDValue N2, SDValue N3, const SDNodeFlags Flags);
1266 LLVM_ABI SDValue getNode(unsigned Opcode, const SDLoc &DL, EVT VT, SDValue N1,
1267 SDValue N2, SDValue N3, SDValue N4);
1268 LLVM_ABI SDValue getNode(unsigned Opcode, const SDLoc &DL, EVT VT, SDValue N1,
1269 SDValue N2, SDValue N3, SDValue N4,
1270 const SDNodeFlags Flags);
1271 LLVM_ABI SDValue getNode(unsigned Opcode, const SDLoc &DL, EVT VT, SDValue N1,
1272 SDValue N2, SDValue N3, SDValue N4, SDValue N5);
1273 LLVM_ABI SDValue getNode(unsigned Opcode, const SDLoc &DL, EVT VT, SDValue N1,
1274 SDValue N2, SDValue N3, SDValue N4, SDValue N5,
1275 const SDNodeFlags Flags);
1276
1277 // Specialize again based on number of operands for nodes with a VTList
1278 // rather than a single VT.
1279 LLVM_ABI SDValue getNode(unsigned Opcode, const SDLoc &DL, SDVTList VTList);
1280 LLVM_ABI SDValue getNode(unsigned Opcode, const SDLoc &DL, SDVTList VTList,
1281 SDValue N);
1282 LLVM_ABI SDValue getNode(unsigned Opcode, const SDLoc &DL, SDVTList VTList,
1283 SDValue N1, SDValue N2);
1284 LLVM_ABI SDValue getNode(unsigned Opcode, const SDLoc &DL, SDVTList VTList,
1285 SDValue N1, SDValue N2, SDValue N3);
1286 LLVM_ABI SDValue getNode(unsigned Opcode, const SDLoc &DL, SDVTList VTList,
1287 SDValue N1, SDValue N2, SDValue N3, SDValue N4);
1288 LLVM_ABI SDValue getNode(unsigned Opcode, const SDLoc &DL, SDVTList VTList,
1289 SDValue N1, SDValue N2, SDValue N3, SDValue N4,
1290 SDValue N5);
1291
1292 /// Compute a TokenFactor to force all the incoming stack arguments to be
1293 /// loaded from the stack. This is used in tail call lowering to protect
1294 /// stack arguments from being clobbered.
1296
1297 /// Lower a memccpy operation into a target library call and return the
1298 /// resulting chain and call result as SelectionDAG SDValues.
1299 LLVM_ABI std::pair<SDValue, SDValue>
1300 getMemccpy(SDValue Chain, const SDLoc &dl, SDValue Dst, SDValue Src,
1301 SDValue C, SDValue Size, const CallInst *CI);
1302
1303 /// Lower a memcmp operation into a target library call and return the
1304 /// resulting chain and call result as SelectionDAG SDValues.
1305 LLVM_ABI std::pair<SDValue, SDValue> getMemcmp(SDValue Chain, const SDLoc &dl,
1306 SDValue Dst, SDValue Src,
1307 SDValue Size,
1308 const CallInst *CI);
1309
1310 /// Lower a strcmp operation into a target library call and return the
1311 /// resulting chain and call result as SelectionDAG SDValues.
1312 LLVM_ABI std::pair<SDValue, SDValue> getStrcmp(SDValue Chain, const SDLoc &dl,
1313 SDValue S0, SDValue S1,
1314 const CallInst *CI);
1315
1316 /// Lower a strcpy operation into a target library call and return the
1317 /// resulting chain and call result as SelectionDAG SDValues.
1318 LLVM_ABI std::pair<SDValue, SDValue> getStrcpy(SDValue Chain, const SDLoc &dl,
1319 SDValue Dst, SDValue Src,
1320 const CallInst *CI);
1321
1322 /// Lower a strlen operation into a target library call and return the
1323 /// resulting chain and call result as SelectionDAG SDValues.
1324 LLVM_ABI std::pair<SDValue, SDValue>
1325 getStrlen(SDValue Chain, const SDLoc &dl, SDValue Src, const CallInst *CI);
1326
1327 /// Lower a strstr operation into a target library call and return the
1328 /// resulting chain and call result as SelectionDAG SDValues.
1329 LLVM_ABI std::pair<SDValue, SDValue> getStrstr(SDValue Chain, const SDLoc &dl,
1330 SDValue S0, SDValue S1,
1331 const CallInst *CI);
1332
1333 /* \p CI if not null is the memset call being lowered.
1334 * \p OverrideTailCall is an optional parameter that can be used to override
1335 * the tail call optimization decision. */
1336 LLVM_ABI SDValue getMemcpy(SDValue Chain, const SDLoc &dl, SDValue Dst,
1337 SDValue Src, SDValue Size, Align Alignment,
1338 bool isVol, bool AlwaysInline, const CallInst *CI,
1339 std::optional<bool> OverrideTailCall,
1340 MachinePointerInfo DstPtrInfo,
1341 MachinePointerInfo SrcPtrInfo,
1342 const AAMDNodes &AAInfo = AAMDNodes(),
1343 BatchAAResults *BatchAA = nullptr);
1344
1345 /* \p CI if not null is the memset call being lowered.
1346 * \p OverrideTailCall is an optional parameter that can be used to override
1347 * the tail call optimization decision. */
1348 LLVM_ABI SDValue getMemmove(SDValue Chain, const SDLoc &dl, SDValue Dst,
1349 SDValue Src, SDValue Size, Align Alignment,
1350 bool isVol, const CallInst *CI,
1351 std::optional<bool> OverrideTailCall,
1352 MachinePointerInfo DstPtrInfo,
1353 MachinePointerInfo SrcPtrInfo,
1354 const AAMDNodes &AAInfo = AAMDNodes(),
1355 BatchAAResults *BatchAA = nullptr);
1356
1357 LLVM_ABI SDValue getMemset(SDValue Chain, const SDLoc &dl, SDValue Dst,
1358 SDValue Src, SDValue Size, Align Alignment,
1359 bool isVol, bool AlwaysInline, const CallInst *CI,
1360 MachinePointerInfo DstPtrInfo,
1361 const AAMDNodes &AAInfo = AAMDNodes());
1362
1363 LLVM_ABI SDValue getAtomicMemcpy(SDValue Chain, const SDLoc &dl, SDValue Dst,
1364 SDValue Src, SDValue Size, Type *SizeTy,
1365 unsigned ElemSz, bool isTailCall,
1366 MachinePointerInfo DstPtrInfo,
1367 MachinePointerInfo SrcPtrInfo);
1368
1369 LLVM_ABI SDValue getAtomicMemmove(SDValue Chain, const SDLoc &dl, SDValue Dst,
1370 SDValue Src, SDValue Size, Type *SizeTy,
1371 unsigned ElemSz, bool isTailCall,
1372 MachinePointerInfo DstPtrInfo,
1373 MachinePointerInfo SrcPtrInfo);
1374
1375 LLVM_ABI SDValue getAtomicMemset(SDValue Chain, const SDLoc &dl, SDValue Dst,
1376 SDValue Value, SDValue Size, Type *SizeTy,
1377 unsigned ElemSz, bool isTailCall,
1378 MachinePointerInfo DstPtrInfo);
1379
1380 /// Helper function to make it easier to build SetCC's if you just have an
1381 /// ISD::CondCode instead of an SDValue.
1383 ISD::CondCode Cond, SDValue Chain = SDValue(),
1384 bool IsSignaling = false, SDNodeFlags Flags = {}) {
1385 assert(LHS.getValueType().isVector() == RHS.getValueType().isVector() &&
1386 "Vector/scalar operand type mismatch for setcc");
1387 assert(LHS.getValueType().isVector() == VT.isVector() &&
1388 "Vector/scalar result type mismatch for setcc");
1390 "Cannot create a setCC of an invalid node.");
1391 if (Chain)
1392 return getNode(IsSignaling ? ISD::STRICT_FSETCCS : ISD::STRICT_FSETCC, DL,
1393 {VT, MVT::Other}, {Chain, LHS, RHS, getCondCode(Cond)},
1394 Flags);
1395 return getNode(ISD::SETCC, DL, VT, LHS, RHS, getCondCode(Cond), Flags);
1396 }
1397
1398 /// Helper function to make it easier to build VP_SETCCs if you just have an
1399 /// ISD::CondCode instead of an SDValue.
1401 ISD::CondCode Cond, SDValue Mask, SDValue EVL) {
1402 assert(LHS.getValueType().isVector() && RHS.getValueType().isVector() &&
1403 "Cannot compare scalars");
1405 "Cannot create a setCC of an invalid node.");
1406 return getNode(ISD::VP_SETCC, DL, VT, LHS, RHS, getCondCode(Cond), Mask,
1407 EVL);
1408 }
1409
1410 /// Helper function to make it easier to build Select's if you just have
1411 /// operands and don't want to check for vector.
1413 SDValue RHS, SDNodeFlags Flags = SDNodeFlags()) {
1414 assert(LHS.getValueType() == VT && RHS.getValueType() == VT &&
1415 "Cannot use select on differing types");
1416 auto Opcode = Cond.getValueType().isVector() ? ISD::VSELECT : ISD::SELECT;
1417 return getNode(Opcode, DL, VT, Cond, LHS, RHS, Flags);
1418 }
1419
1420 /// Helper function to make it easier to build SelectCC's if you just have an
1421 /// ISD::CondCode instead of an SDValue.
1423 SDValue False, ISD::CondCode Cond,
1424 SDNodeFlags Flags = SDNodeFlags()) {
1425 return getNode(ISD::SELECT_CC, DL, True.getValueType(), LHS, RHS, True,
1426 False, getCondCode(Cond), Flags);
1427 }
1428
1429 /// Try to simplify a select/vselect into 1 of its operands or a constant.
1431
1432 /// Try to simplify a shift into 1 of its operands or a constant.
1434
1435 /// Try to simplify a floating-point binary operation into 1 of its operands
1436 /// or a constant.
1437 LLVM_ABI SDValue simplifyFPBinop(unsigned Opcode, SDValue X, SDValue Y,
1438 SDNodeFlags Flags);
1439
1440 /// VAArg produces a result and token chain, and takes a pointer
1441 /// and a source value as input.
1442 LLVM_ABI SDValue getVAArg(EVT VT, const SDLoc &dl, SDValue Chain, SDValue Ptr,
1443 SDValue SV, unsigned Align);
1444
1445 /// Gets a node for an atomic cmpxchg op. There are two
1446 /// valid Opcodes. ISD::ATOMIC_CMO_SWAP produces the value loaded and a
1447 /// chain result. ISD::ATOMIC_CMP_SWAP_WITH_SUCCESS produces the value loaded,
1448 /// a success flag (initially i1), and a chain.
1449 LLVM_ABI SDValue getAtomicCmpSwap(unsigned Opcode, const SDLoc &dl, EVT MemVT,
1450 SDVTList VTs, SDValue Chain, SDValue Ptr,
1451 SDValue Cmp, SDValue Swp,
1452 MachineMemOperand *MMO);
1453
1454 /// Gets a node for an atomic op, produces result (if relevant)
1455 /// and chain and takes 2 operands.
1456 LLVM_ABI SDValue getAtomic(unsigned Opcode, const SDLoc &dl, EVT MemVT,
1457 SDValue Chain, SDValue Ptr, SDValue Val,
1458 MachineMemOperand *MMO);
1459
1460 /// Gets a node for an atomic op, produces result and chain and takes N
1461 /// operands.
1462 LLVM_ABI SDValue getAtomic(unsigned Opcode, const SDLoc &dl, EVT MemVT,
1464 MachineMemOperand *MMO,
1466
1468 EVT MemVT, EVT VT, SDValue Chain, SDValue Ptr,
1469 MachineMemOperand *MMO);
1470
1471 /// Creates a MemIntrinsicNode that may produce a
1472 /// result and takes a list of operands. Opcode may be INTRINSIC_VOID,
1473 /// INTRINSIC_W_CHAIN, or a target-specific memory-referencing opcode
1474 // (see `SelectionDAGTargetInfo::isTargetMemoryOpcode`).
1476 unsigned Opcode, const SDLoc &dl, SDVTList VTList, ArrayRef<SDValue> Ops,
1477 EVT MemVT, MachinePointerInfo PtrInfo, Align Alignment,
1481 const AAMDNodes &AAInfo = AAMDNodes());
1482
1484 unsigned Opcode, const SDLoc &dl, SDVTList VTList, ArrayRef<SDValue> Ops,
1485 EVT MemVT, MachinePointerInfo PtrInfo,
1486 MaybeAlign Alignment = std::nullopt,
1490 const AAMDNodes &AAInfo = AAMDNodes()) {
1491 // Ensure that codegen never sees alignment 0
1492 return getMemIntrinsicNode(Opcode, dl, VTList, Ops, MemVT, PtrInfo,
1493 Alignment.value_or(getEVTAlign(MemVT)), Flags,
1494 Size, AAInfo);
1495 }
1496
1497 LLVM_ABI SDValue getMemIntrinsicNode(unsigned Opcode, const SDLoc &dl,
1499 EVT MemVT, MachineMemOperand *MMO);
1500
1501 /// getMemIntrinsicNode - Creates a MemIntrinsicNode with multiple MMOs.
1502 LLVM_ABI SDValue getMemIntrinsicNode(unsigned Opcode, const SDLoc &dl,
1504 EVT MemVT,
1506
1507 /// Creates a LifetimeSDNode that starts (`IsStart==true`) or ends
1508 /// (`IsStart==false`) the lifetime of the `FrameIndex`.
1509 LLVM_ABI SDValue getLifetimeNode(bool IsStart, const SDLoc &dl, SDValue Chain,
1510 int FrameIndex);
1511
1512 /// Creates a PseudoProbeSDNode with function GUID `Guid` and
1513 /// the index of the block `Index` it is probing, as well as the attributes
1514 /// `attr` of the probe.
1516 uint64_t Guid, uint64_t Index,
1517 uint32_t Attr);
1518
1519 /// Create a MERGE_VALUES node from the given operands.
1521
1522 /// Loads are not normal binary operators: their result type is not
1523 /// determined by their operands, and they produce a value AND a token chain.
1524 ///
1525 /// This function will set the MOLoad flag on MMOFlags, but you can set it if
1526 /// you want. The MOStore flag must not be set.
1528 EVT VT, const SDLoc &dl, SDValue Chain, SDValue Ptr,
1529 MachinePointerInfo PtrInfo, MaybeAlign Alignment = MaybeAlign(),
1531 const AAMDNodes &AAInfo = AAMDNodes(), const MDNode *Ranges = nullptr);
1532 LLVM_ABI SDValue getLoad(EVT VT, const SDLoc &dl, SDValue Chain, SDValue Ptr,
1533 MachineMemOperand *MMO);
1535 getExtLoad(ISD::LoadExtType ExtType, const SDLoc &dl, EVT VT, SDValue Chain,
1536 SDValue Ptr, MachinePointerInfo PtrInfo, EVT MemVT,
1537 MaybeAlign Alignment = MaybeAlign(),
1539 const AAMDNodes &AAInfo = AAMDNodes());
1540 LLVM_ABI SDValue getExtLoad(ISD::LoadExtType ExtType, const SDLoc &dl, EVT VT,
1541 SDValue Chain, SDValue Ptr, EVT MemVT,
1542 MachineMemOperand *MMO);
1543 LLVM_ABI SDValue getIndexedLoad(SDValue OrigLoad, const SDLoc &dl,
1547 ISD::MemIndexedMode AM, ISD::LoadExtType ExtType, EVT VT, const SDLoc &dl,
1548 SDValue Chain, SDValue Ptr, SDValue Offset, MachinePointerInfo PtrInfo,
1549 EVT MemVT, Align Alignment,
1551 const AAMDNodes &AAInfo = AAMDNodes(), const MDNode *Ranges = nullptr);
1553 ISD::MemIndexedMode AM, ISD::LoadExtType ExtType, EVT VT, const SDLoc &dl,
1554 SDValue Chain, SDValue Ptr, SDValue Offset, MachinePointerInfo PtrInfo,
1555 EVT MemVT, MaybeAlign Alignment = MaybeAlign(),
1557 const AAMDNodes &AAInfo = AAMDNodes(), const MDNode *Ranges = nullptr) {
1558 // Ensures that codegen never sees a None Alignment.
1559 return getLoad(AM, ExtType, VT, dl, Chain, Ptr, Offset, PtrInfo, MemVT,
1560 Alignment.value_or(getEVTAlign(MemVT)), MMOFlags, AAInfo,
1561 Ranges);
1562 }
1564 EVT VT, const SDLoc &dl, SDValue Chain, SDValue Ptr,
1565 SDValue Offset, EVT MemVT, MachineMemOperand *MMO);
1566
1567 /// Helper function to build ISD::STORE nodes.
1568 ///
1569 /// This function will set the MOStore flag on MMOFlags, but you can set it if
1570 /// you want. The MOLoad and MOInvariant flags must not be set.
1571
1573 getStore(SDValue Chain, const SDLoc &dl, SDValue Val, SDValue Ptr,
1574 MachinePointerInfo PtrInfo, Align Alignment,
1576 const AAMDNodes &AAInfo = AAMDNodes());
1577 inline SDValue
1578 getStore(SDValue Chain, const SDLoc &dl, SDValue Val, SDValue Ptr,
1579 MachinePointerInfo PtrInfo, MaybeAlign Alignment = MaybeAlign(),
1581 const AAMDNodes &AAInfo = AAMDNodes()) {
1582 return getStore(Chain, dl, Val, Ptr, PtrInfo,
1583 Alignment.value_or(getEVTAlign(Val.getValueType())),
1584 MMOFlags, AAInfo);
1585 }
1586 LLVM_ABI SDValue getStore(SDValue Chain, const SDLoc &dl, SDValue Val,
1587 SDValue Ptr, MachineMemOperand *MMO);
1589 getTruncStore(SDValue Chain, const SDLoc &dl, SDValue Val, SDValue Ptr,
1590 MachinePointerInfo PtrInfo, EVT SVT, Align Alignment,
1592 const AAMDNodes &AAInfo = AAMDNodes());
1593 inline SDValue
1594 getTruncStore(SDValue Chain, const SDLoc &dl, SDValue Val, SDValue Ptr,
1595 MachinePointerInfo PtrInfo, EVT SVT,
1596 MaybeAlign Alignment = MaybeAlign(),
1598 const AAMDNodes &AAInfo = AAMDNodes()) {
1599 return getTruncStore(Chain, dl, Val, Ptr, PtrInfo, SVT,
1600 Alignment.value_or(getEVTAlign(SVT)), MMOFlags,
1601 AAInfo);
1602 }
1603 LLVM_ABI SDValue getTruncStore(SDValue Chain, const SDLoc &dl, SDValue Val,
1604 SDValue Ptr, EVT SVT, MachineMemOperand *MMO);
1605 LLVM_ABI SDValue getIndexedStore(SDValue OrigStore, const SDLoc &dl,
1608 LLVM_ABI SDValue getStore(SDValue Chain, const SDLoc &dl, SDValue Val,
1609 SDValue Ptr, SDValue Offset, EVT SVT,
1611 bool IsTruncating = false);
1612
1614 EVT VT, const SDLoc &dl, SDValue Chain,
1615 SDValue Ptr, SDValue Offset, SDValue Mask,
1616 SDValue EVL, MachinePointerInfo PtrInfo, EVT MemVT,
1617 Align Alignment, MachineMemOperand::Flags MMOFlags,
1618 const AAMDNodes &AAInfo,
1619 const MDNode *Ranges = nullptr,
1620 bool IsExpanding = false);
1621 inline SDValue
1623 const SDLoc &dl, SDValue Chain, SDValue Ptr, SDValue Offset,
1624 SDValue Mask, SDValue EVL, MachinePointerInfo PtrInfo, EVT MemVT,
1625 MaybeAlign Alignment = MaybeAlign(),
1627 const AAMDNodes &AAInfo = AAMDNodes(),
1628 const MDNode *Ranges = nullptr, bool IsExpanding = false) {
1629 // Ensures that codegen never sees a None Alignment.
1630 return getLoadVP(AM, ExtType, VT, dl, Chain, Ptr, Offset, Mask, EVL,
1631 PtrInfo, MemVT, Alignment.value_or(getEVTAlign(MemVT)),
1632 MMOFlags, AAInfo, Ranges, IsExpanding);
1633 }
1635 EVT VT, const SDLoc &dl, SDValue Chain,
1636 SDValue Ptr, SDValue Offset, SDValue Mask,
1637 SDValue EVL, EVT MemVT, MachineMemOperand *MMO,
1638 bool IsExpanding = false);
1639 LLVM_ABI SDValue getLoadVP(EVT VT, const SDLoc &dl, SDValue Chain,
1640 SDValue Ptr, SDValue Mask, SDValue EVL,
1641 MachinePointerInfo PtrInfo, MaybeAlign Alignment,
1642 MachineMemOperand::Flags MMOFlags,
1643 const AAMDNodes &AAInfo,
1644 const MDNode *Ranges = nullptr,
1645 bool IsExpanding = false);
1646 LLVM_ABI SDValue getLoadVP(EVT VT, const SDLoc &dl, SDValue Chain,
1647 SDValue Ptr, SDValue Mask, SDValue EVL,
1648 MachineMemOperand *MMO, bool IsExpanding = false);
1650 ISD::LoadExtType ExtType, const SDLoc &dl, EVT VT, SDValue Chain,
1651 SDValue Ptr, SDValue Mask, SDValue EVL, MachinePointerInfo PtrInfo,
1652 EVT MemVT, MaybeAlign Alignment, MachineMemOperand::Flags MMOFlags,
1653 const AAMDNodes &AAInfo, bool IsExpanding = false);
1655 EVT VT, SDValue Chain, SDValue Ptr,
1656 SDValue Mask, SDValue EVL, EVT MemVT,
1657 MachineMemOperand *MMO,
1658 bool IsExpanding = false);
1659 LLVM_ABI SDValue getIndexedLoadVP(SDValue OrigLoad, const SDLoc &dl,
1662 LLVM_ABI SDValue getStoreVP(SDValue Chain, const SDLoc &dl, SDValue Val,
1663 SDValue Ptr, SDValue Offset, SDValue Mask,
1664 SDValue EVL, EVT MemVT, MachineMemOperand *MMO,
1665 ISD::MemIndexedMode AM, bool IsTruncating = false,
1666 bool IsCompressing = false);
1667 LLVM_ABI SDValue getTruncStoreVP(SDValue Chain, const SDLoc &dl, SDValue Val,
1668 SDValue Ptr, SDValue Mask, SDValue EVL,
1669 MachinePointerInfo PtrInfo, EVT SVT,
1670 Align Alignment,
1671 MachineMemOperand::Flags MMOFlags,
1672 const AAMDNodes &AAInfo,
1673 bool IsCompressing = false);
1674 LLVM_ABI SDValue getTruncStoreVP(SDValue Chain, const SDLoc &dl, SDValue Val,
1675 SDValue Ptr, SDValue Mask, SDValue EVL,
1676 EVT SVT, MachineMemOperand *MMO,
1677 bool IsCompressing = false);
1678 LLVM_ABI SDValue getIndexedStoreVP(SDValue OrigStore, const SDLoc &dl,
1681
1683 ISD::MemIndexedMode AM, ISD::LoadExtType ExtType, EVT VT, const SDLoc &DL,
1684 SDValue Chain, SDValue Ptr, SDValue Offset, SDValue Stride, SDValue Mask,
1685 SDValue EVL, EVT MemVT, MachineMemOperand *MMO, bool IsExpanding = false);
1687 SDValue Ptr, SDValue Stride, SDValue Mask,
1688 SDValue EVL, MachineMemOperand *MMO,
1689 bool IsExpanding = false);
1691 const SDLoc &DL, EVT VT, SDValue Chain,
1692 SDValue Ptr, SDValue Stride,
1693 SDValue Mask, SDValue EVL, EVT MemVT,
1694 MachineMemOperand *MMO,
1695 bool IsExpanding = false);
1697 SDValue Val, SDValue Ptr, SDValue Offset,
1698 SDValue Stride, SDValue Mask, SDValue EVL,
1699 EVT MemVT, MachineMemOperand *MMO,
1701 bool IsTruncating = false,
1702 bool IsCompressing = false);
1704 SDValue Val, SDValue Ptr,
1705 SDValue Stride, SDValue Mask,
1706 SDValue EVL, EVT SVT,
1707 MachineMemOperand *MMO,
1708 bool IsCompressing = false);
1709
1710 LLVM_ABI SDValue getGatherVP(SDVTList VTs, EVT VT, const SDLoc &dl,
1712 ISD::MemIndexType IndexType);
1713 LLVM_ABI SDValue getScatterVP(SDVTList VTs, EVT VT, const SDLoc &dl,
1715 ISD::MemIndexType IndexType);
1716
1717 LLVM_ABI SDValue getMaskedLoad(EVT VT, const SDLoc &dl, SDValue Chain,
1719 SDValue Src0, EVT MemVT,
1721 ISD::LoadExtType, bool IsExpanding = false);
1725 LLVM_ABI SDValue getMaskedStore(SDValue Chain, const SDLoc &dl, SDValue Val,
1727 EVT MemVT, MachineMemOperand *MMO,
1729 bool IsTruncating = false,
1730 bool IsCompressing = false);
1731 LLVM_ABI SDValue getIndexedMaskedStore(SDValue OrigStore, const SDLoc &dl,
1734 LLVM_ABI SDValue getMaskedGather(SDVTList VTs, EVT MemVT, const SDLoc &dl,
1736 MachineMemOperand *MMO,
1737 ISD::MemIndexType IndexType,
1738 ISD::LoadExtType ExtTy);
1739 LLVM_ABI SDValue getMaskedScatter(SDVTList VTs, EVT MemVT, const SDLoc &dl,
1741 MachineMemOperand *MMO,
1742 ISD::MemIndexType IndexType,
1743 bool IsTruncating = false);
1744 LLVM_ABI SDValue getMaskedHistogram(SDVTList VTs, EVT MemVT, const SDLoc &dl,
1746 MachineMemOperand *MMO,
1747 ISD::MemIndexType IndexType);
1748 LLVM_ABI SDValue getLoadFFVP(EVT VT, const SDLoc &DL, SDValue Chain,
1749 SDValue Ptr, SDValue Mask, SDValue EVL,
1750 MachineMemOperand *MMO);
1751
1752 LLVM_ABI SDValue getGetFPEnv(SDValue Chain, const SDLoc &dl, SDValue Ptr,
1753 EVT MemVT, MachineMemOperand *MMO);
1754 LLVM_ABI SDValue getSetFPEnv(SDValue Chain, const SDLoc &dl, SDValue Ptr,
1755 EVT MemVT, MachineMemOperand *MMO);
1756
1757 /// Construct a node to track a Value* through the backend.
1759
1760 /// Return an MDNodeSDNode which holds an MDNode.
1761 LLVM_ABI SDValue getMDNode(const MDNode *MD);
1762
1763 /// Return a bitcast using the SDLoc of the value operand, and casting to the
1764 /// provided type. Use getNode to set a custom SDLoc.
1766
1767 /// Return an AddrSpaceCastSDNode.
1768 LLVM_ABI SDValue getAddrSpaceCast(const SDLoc &dl, EVT VT, SDValue Ptr,
1769 unsigned SrcAS, unsigned DestAS);
1770
1771 /// Return a freeze using the SDLoc of the value operand.
1773
1774 /// Return a freeze of V if any of the demanded elts may be undef or poison.
1775 /// \p Kind can be used to selectively freeze poison and/or undef bits only.
1777 getFreeze(SDValue V, const APInt &DemandedElts,
1779
1780 /// Return an AssertAlignSDNode.
1782
1783 /// Swap N1 and N2 if Opcode is a commutative binary opcode
1784 /// and the canonical form expects the opposite order.
1785 LLVM_ABI void canonicalizeCommutativeBinop(unsigned Opcode, SDValue &N1,
1786 SDValue &N2) const;
1787
1788 /// Return the specified value casted to
1789 /// the target's desired shift amount type.
1791
1792 /// Expand the specified \c ISD::VAARG node as the Legalize pass would.
1794
1795 /// Expand the specified \c ISD::VACOPY node as the Legalize pass would.
1797
1798 /// Return a GlobalAddress of the function from the current module with
1799 /// name matching the given ExternalSymbol. Additionally can provide the
1800 /// matched function.
1801 /// Panic if the function doesn't exist.
1803 SDValue Op, Function **TargetFunction = nullptr);
1804
1805 /// *Mutate* the specified node in-place to have the
1806 /// specified operands. If the resultant node already exists in the DAG,
1807 /// this does not modify the specified node, instead it returns the node that
1808 /// already exists. If the resultant node does not exist in the DAG, the
1809 /// input node is returned. As a degenerate case, if you specify the same
1810 /// input operands as the node already has, the input node is returned.
1814 SDValue Op3);
1816 SDValue Op3, SDValue Op4);
1818 SDValue Op3, SDValue Op4, SDValue Op5);
1820
1821 /// Creates a new TokenFactor containing \p Vals. If \p Vals contains 64k
1822 /// values or more, move values into new TokenFactors in 64k-1 blocks, until
1823 /// the final TokenFactor has less than 64k operands.
1826
1827 /// *Mutate* the specified machine node's memory references to the provided
1828 /// list.
1831
1832 // Calculate divergence of node \p N based on its operands.
1834
1835 // Propagates the change in divergence to users
1837
1838 /// These are used for target selectors to *mutate* the
1839 /// specified node to have the specified return type, Target opcode, and
1840 /// operands. Note that target opcodes are stored as
1841 /// ~TargetOpcode in the node opcode field. The resultant node is returned.
1842 LLVM_ABI SDNode *SelectNodeTo(SDNode *N, unsigned MachineOpc, EVT VT);
1843 LLVM_ABI SDNode *SelectNodeTo(SDNode *N, unsigned MachineOpc, EVT VT,
1844 SDValue Op1);
1845 LLVM_ABI SDNode *SelectNodeTo(SDNode *N, unsigned MachineOpc, EVT VT,
1846 SDValue Op1, SDValue Op2);
1847 LLVM_ABI SDNode *SelectNodeTo(SDNode *N, unsigned MachineOpc, EVT VT,
1848 SDValue Op1, SDValue Op2, SDValue Op3);
1849 LLVM_ABI SDNode *SelectNodeTo(SDNode *N, unsigned MachineOpc, EVT VT,
1851 LLVM_ABI SDNode *SelectNodeTo(SDNode *N, unsigned MachineOpc, EVT VT1,
1852 EVT VT2);
1853 LLVM_ABI SDNode *SelectNodeTo(SDNode *N, unsigned MachineOpc, EVT VT1,
1855 LLVM_ABI SDNode *SelectNodeTo(SDNode *N, unsigned MachineOpc, EVT VT1,
1856 EVT VT2, EVT VT3, ArrayRef<SDValue> Ops);
1857 LLVM_ABI SDNode *SelectNodeTo(SDNode *N, unsigned MachineOpc, EVT VT1,
1858 EVT VT2, SDValue Op1, SDValue Op2);
1859 LLVM_ABI SDNode *SelectNodeTo(SDNode *N, unsigned MachineOpc, SDVTList VTs,
1861
1862 /// This *mutates* the specified node to have the specified
1863 /// return type, opcode, and operands.
1864 LLVM_ABI SDNode *MorphNodeTo(SDNode *N, unsigned Opc, SDVTList VTs,
1866
1867 /// Mutate the specified strict FP node to its non-strict equivalent,
1868 /// unlinking the node from its chain and dropping the metadata arguments.
1869 /// The node must be a strict FP node.
1871
1872 /// These are used for target selectors to create a new node
1873 /// with specified return type(s), MachineInstr opcode, and operands.
1874 ///
1875 /// Note that getMachineNode returns the resultant node. If there is already
1876 /// a node of the specified opcode and operands, it returns that node instead
1877 /// of the current one.
1878 LLVM_ABI MachineSDNode *getMachineNode(unsigned Opcode, const SDLoc &dl,
1879 EVT VT);
1880 LLVM_ABI MachineSDNode *getMachineNode(unsigned Opcode, const SDLoc &dl,
1881 EVT VT, SDValue Op1);
1882 LLVM_ABI MachineSDNode *getMachineNode(unsigned Opcode, const SDLoc &dl,
1883 EVT VT, SDValue Op1, SDValue Op2);
1884 LLVM_ABI MachineSDNode *getMachineNode(unsigned Opcode, const SDLoc &dl,
1885 EVT VT, SDValue Op1, SDValue Op2,
1886 SDValue Op3);
1887 LLVM_ABI MachineSDNode *getMachineNode(unsigned Opcode, const SDLoc &dl,
1889 LLVM_ABI MachineSDNode *getMachineNode(unsigned Opcode, const SDLoc &dl,
1890 EVT VT1, EVT VT2, SDValue Op1,
1891 SDValue Op2);
1892 LLVM_ABI MachineSDNode *getMachineNode(unsigned Opcode, const SDLoc &dl,
1893 EVT VT1, EVT VT2, SDValue Op1,
1894 SDValue Op2, SDValue Op3);
1895 LLVM_ABI MachineSDNode *getMachineNode(unsigned Opcode, const SDLoc &dl,
1896 EVT VT1, EVT VT2,
1898 LLVM_ABI MachineSDNode *getMachineNode(unsigned Opcode, const SDLoc &dl,
1899 EVT VT1, EVT VT2, EVT VT3, SDValue Op1,
1900 SDValue Op2);
1901 LLVM_ABI MachineSDNode *getMachineNode(unsigned Opcode, const SDLoc &dl,
1902 EVT VT1, EVT VT2, EVT VT3, SDValue Op1,
1903 SDValue Op2, SDValue Op3);
1904 LLVM_ABI MachineSDNode *getMachineNode(unsigned Opcode, const SDLoc &dl,
1905 EVT VT1, EVT VT2, EVT VT3,
1907 LLVM_ABI MachineSDNode *getMachineNode(unsigned Opcode, const SDLoc &dl,
1908 ArrayRef<EVT> ResultTys,
1910 LLVM_ABI MachineSDNode *getMachineNode(unsigned Opcode, const SDLoc &dl,
1912
1913 /// A convenience function for creating TargetInstrInfo::EXTRACT_SUBREG nodes.
1914 LLVM_ABI SDValue getTargetExtractSubreg(int SRIdx, const SDLoc &DL, EVT VT,
1915 SDValue Operand);
1916
1917 /// A convenience function for creating TargetInstrInfo::INSERT_SUBREG nodes.
1918 LLVM_ABI SDValue getTargetInsertSubreg(int SRIdx, const SDLoc &DL, EVT VT,
1919 SDValue Operand, SDValue Subreg);
1920
1921 /// Get the specified node if it's already available, or else return NULL.
1922 LLVM_ABI SDNode *getNodeIfExists(unsigned Opcode, SDVTList VTList,
1924 const SDNodeFlags Flags,
1925 bool AllowCommute = false);
1926 LLVM_ABI SDNode *getNodeIfExists(unsigned Opcode, SDVTList VTList,
1928 bool AllowCommute = false);
1929
1930 /// Check if a node exists without modifying its flags.
1931 LLVM_ABI bool doesNodeExist(unsigned Opcode, SDVTList VTList,
1933
1934 /// Creates a SDDbgValue node.
1936 SDNode *N, unsigned R, bool IsIndirect,
1937 const DebugLoc &DL, unsigned O);
1938
1939 /// Creates a constant SDDbgValue node.
1941 const Value *C, const DebugLoc &DL,
1942 unsigned O);
1943
1944 /// Creates a FrameIndex SDDbgValue node.
1946 DIExpression *Expr, unsigned FI,
1947 bool IsIndirect,
1948 const DebugLoc &DL, unsigned O);
1949
1950 /// Creates a FrameIndex SDDbgValue node.
1952 DIExpression *Expr, unsigned FI,
1953 ArrayRef<SDNode *> Dependencies,
1954 bool IsIndirect,
1955 const DebugLoc &DL, unsigned O);
1956
1957 /// Creates a VReg SDDbgValue node.
1959 Register VReg, bool IsIndirect,
1960 const DebugLoc &DL, unsigned O);
1961
1962 /// Creates a SDDbgValue node from a list of locations.
1965 ArrayRef<SDNode *> Dependencies,
1966 bool IsIndirect, const DebugLoc &DL,
1967 unsigned O, bool IsVariadic);
1968
1969 /// Creates a SDDbgLabel node.
1971 unsigned O);
1972
1973 /// Transfer debug values from one node to another, while optionally
1974 /// generating fragment expressions for split-up values. If \p InvalidateDbg
1975 /// is set, debug values are invalidated after they are transferred.
1977 unsigned OffsetInBits = 0,
1978 unsigned SizeInBits = 0,
1979 bool InvalidateDbg = true);
1980
1981 /// Remove the specified node from the system. If any of its
1982 /// operands then becomes dead, remove them as well. Inform UpdateListener
1983 /// for each node deleted.
1985
1986 /// This method deletes the unreachable nodes in the
1987 /// given list, and any nodes that become unreachable as a result.
1989
1990 /// Modify anything using 'From' to use 'To' instead.
1991 /// This can cause recursive merging of nodes in the DAG. Use the first
1992 /// version if 'From' is known to have a single result, use the second
1993 /// if you have two nodes with identical results (or if 'To' has a superset
1994 /// of the results of 'From'), use the third otherwise.
1995 ///
1996 /// These methods all take an optional UpdateListener, which (if not null) is
1997 /// informed about nodes that are deleted and modified due to recursive
1998 /// changes in the dag.
1999 ///
2000 /// These functions only replace all existing uses. It's possible that as
2001 /// these replacements are being performed, CSE may cause the From node
2002 /// to be given new uses. These new uses of From are left in place, and
2003 /// not automatically transferred to To.
2004 ///
2006 LLVM_ABI void ReplaceAllUsesWith(SDNode *From, SDNode *To);
2007 LLVM_ABI void ReplaceAllUsesWith(SDNode *From, const SDValue *To);
2008
2009 /// Replace any uses of From with To, leaving
2010 /// uses of other values produced by From.getNode() alone.
2012
2013 /// Like ReplaceAllUsesOfValueWith, but for multiple values at once.
2014 /// This correctly handles the case where
2015 /// there is an overlap between the From values and the To values.
2017 const SDValue *To, unsigned Num);
2018
2019 /// If an existing load has uses of its chain, create a token factor node with
2020 /// that chain and the new memory node's chain and update users of the old
2021 /// chain to the token factor. This ensures that the new memory node will have
2022 /// the same relative memory dependency position as the old load. Returns the
2023 /// new merged load chain.
2025 SDValue NewMemOpChain);
2026
2027 /// If an existing load has uses of its chain, create a token factor node with
2028 /// that chain and the new memory node's chain and update users of the old
2029 /// chain to the token factor. This ensures that the new memory node will have
2030 /// the same relative memory dependency position as the old load. Returns the
2031 /// new merged load chain.
2033 SDValue NewMemOp);
2034
2035 /// Get all the nodes in their topological order without modifying any states.
2037 SmallVectorImpl<const SDNode *> &SortedNodes) const;
2038
2039 /// Topological-sort the AllNodes list and a
2040 /// assign a unique node id for each node in the DAG based on their
2041 /// topological order. Returns the number of nodes.
2043
2044 /// Move node N in the AllNodes list to be immediately
2045 /// before the given iterator Position. This may be used to update the
2046 /// topological ordering when the list of nodes is modified.
2048 AllNodes.insert(Position, AllNodes.remove(N));
2049 }
2050
2051 /// Add a dbg_value SDNode. If SD is non-null that means the
2052 /// value is produced by SD.
2053 LLVM_ABI void AddDbgValue(SDDbgValue *DB, bool isParameter);
2054
2055 /// Add a dbg_label SDNode.
2057
2058 /// Get the debug values which reference the given SDNode.
2060 return DbgInfo->getSDDbgValues(SD);
2061 }
2062
2063public:
2064 /// Return true if there are any SDDbgValue nodes associated
2065 /// with this SelectionDAG.
2066 bool hasDebugValues() const { return !DbgInfo->empty(); }
2067
2068 SDDbgInfo::DbgIterator DbgBegin() const { return DbgInfo->DbgBegin(); }
2069 SDDbgInfo::DbgIterator DbgEnd() const { return DbgInfo->DbgEnd(); }
2070
2072 return DbgInfo->ByvalParmDbgBegin();
2073 }
2075 return DbgInfo->ByvalParmDbgEnd();
2076 }
2077
2079 return DbgInfo->DbgLabelBegin();
2080 }
2082 return DbgInfo->DbgLabelEnd();
2083 }
2084
2085 /// To be invoked on an SDNode that is slated to be erased. This
2086 /// function mirrors \c llvm::salvageDebugInfo.
2088
2089 /// Dump the textual format of this DAG. Nodes are not sorted.
2090 /// Note that we overload it instead of using default value so that it is
2091 /// convenient to be called from debuggers.
2092 LLVM_ABI void dump() const;
2093
2094 /// Dump the textual format of this DAG. Print nodes in sorted orders if \p
2095 /// Sorted is true.
2096 LLVM_ABI void dump(bool Sorted) const;
2097
2098 /// In most cases this function returns the ABI alignment for a given type,
2099 /// except for illegal vector types where the alignment exceeds that of the
2100 /// stack. In such cases we attempt to break the vector down to a legal type
2101 /// and return the ABI alignment for that instead.
2102 LLVM_ABI Align getReducedAlign(EVT VT, bool UseABI);
2103
2104 /// Create a stack temporary based on the size in bytes and the alignment
2106
2107 /// Create a stack temporary, suitable for holding the specified value type.
2108 /// If minAlign is specified, the slot size will have at least that alignment.
2109 LLVM_ABI SDValue CreateStackTemporary(EVT VT, unsigned minAlign = 1);
2110
2111 /// Create a stack temporary suitable for holding either of the specified
2112 /// value types.
2114
2115 LLVM_ABI SDValue FoldSymbolOffset(unsigned Opcode, EVT VT,
2116 const GlobalAddressSDNode *GA,
2117 const SDNode *N2);
2118
2119 LLVM_ABI SDValue FoldConstantArithmetic(unsigned Opcode, const SDLoc &DL,
2121 SDNodeFlags Flags = SDNodeFlags());
2122
2123 /// Fold floating-point operations when all operands are constants and/or
2124 /// undefined.
2125 LLVM_ABI SDValue foldConstantFPMath(unsigned Opcode, const SDLoc &DL, EVT VT,
2127
2128 /// Fold BUILD_VECTOR of constants/undefs to the destination type
2129 /// BUILD_VECTOR of constants/undefs elements.
2131 const SDLoc &DL, EVT DstEltVT);
2132
2133 /// Constant fold a setcc to true or false.
2135 const SDLoc &dl, SDNodeFlags Flags = {});
2136
2137 /// Return true if the sign bit of Op is known to be zero.
2138 /// We use this predicate to simplify operations downstream.
2139 LLVM_ABI bool SignBitIsZero(SDValue Op, unsigned Depth = 0) const;
2140
2141 /// Return true if the sign bit of Op is known to be zero, for a
2142 /// floating-point value.
2143 LLVM_ABI bool SignBitIsZeroFP(SDValue Op, unsigned Depth = 0) const;
2144
2145 /// Return true if 'Op & Mask' is known to be zero. We
2146 /// use this predicate to simplify operations downstream. Op and Mask are
2147 /// known to be the same type.
2148 LLVM_ABI bool MaskedValueIsZero(SDValue Op, const APInt &Mask,
2149 unsigned Depth = 0) const;
2150
2151 /// Return true if 'Op & Mask' is known to be zero in DemandedElts. We
2152 /// use this predicate to simplify operations downstream. Op and Mask are
2153 /// known to be the same type.
2154 LLVM_ABI bool MaskedValueIsZero(SDValue Op, const APInt &Mask,
2155 const APInt &DemandedElts,
2156 unsigned Depth = 0) const;
2157
2158 /// Return true if 'Op' is known to be zero in DemandedElts. We
2159 /// use this predicate to simplify operations downstream.
2160 LLVM_ABI bool MaskedVectorIsZero(SDValue Op, const APInt &DemandedElts,
2161 unsigned Depth = 0) const;
2162
2163 /// Return true if '(Op & Mask) == Mask'.
2164 /// Op and Mask are known to be the same type.
2165 LLVM_ABI bool MaskedValueIsAllOnes(SDValue Op, const APInt &Mask,
2166 unsigned Depth = 0) const;
2167
2168 /// For each demanded element of a vector, see if it is known to be zero.
2170 const APInt &DemandedElts,
2171 unsigned Depth = 0) const;
2172
2173 /// Determine which bits of Op are known to be either zero or one and return
2174 /// them in Known. For vectors, the known bits are those that are shared by
2175 /// every vector element.
2176 /// Targets can implement the computeKnownBitsForTargetNode method in the
2177 /// TargetLowering class to allow target nodes to be understood.
2178 LLVM_ABI KnownBits computeKnownBits(SDValue Op, unsigned Depth = 0) const;
2179
2180 /// Determine which bits of Op are known to be either zero or one and return
2181 /// them in Known. The DemandedElts argument allows us to only collect the
2182 /// known bits that are shared by the requested vector elements.
2183 /// Targets can implement the computeKnownBitsForTargetNode method in the
2184 /// TargetLowering class to allow target nodes to be understood.
2185 LLVM_ABI KnownBits computeKnownBits(SDValue Op, const APInt &DemandedElts,
2186 unsigned Depth = 0) const;
2187
2188 /// Determine the possible constant range of an integer or vector of integers.
2189 LLVM_ABI ConstantRange computeConstantRange(SDValue Op, bool ForSigned,
2190 unsigned Depth = 0) const;
2191
2192 /// Determine the possible constant range of an integer or vector of integers.
2193 /// The DemandedElts argument allows us to only collect the known ranges that
2194 /// are shared by the requested vector elements.
2196 const APInt &DemandedElts,
2197 bool ForSigned,
2198 unsigned Depth = 0) const;
2199
2200 /// Combine constant ranges from computeConstantRange() and
2201 /// computeKnownBits().
2203 SDValue Op, bool ForSigned, unsigned Depth = 0) const;
2204
2205 /// Combine constant ranges from computeConstantRange() and
2206 /// computeKnownBits(). The DemandedElts argument allows us to only collect
2207 /// the known ranges that are shared by the requested vector elements.
2209 SDValue Op, const APInt &DemandedElts, bool ForSigned,
2210 unsigned Depth = 0) const;
2211
2212 /// Used to represent the possible overflow behavior of an operation.
2213 /// Never: the operation cannot overflow.
2214 /// Always: the operation will always overflow.
2215 /// Sometime: the operation may or may not overflow.
2221
2222 /// Determine if the result of the signed addition of 2 nodes can overflow.
2224 SDValue N1) const;
2225
2226 /// Determine if the result of the unsigned addition of 2 nodes can overflow.
2228 SDValue N1) const;
2229
2230 /// Determine if the result of the addition of 2 nodes can overflow.
2232 SDValue N1) const {
2233 return IsSigned ? computeOverflowForSignedAdd(N0, N1)
2235 }
2236
2237 /// Determine if the result of the addition of 2 nodes can never overflow.
2238 bool willNotOverflowAdd(bool IsSigned, SDValue N0, SDValue N1) const {
2239 return computeOverflowForAdd(IsSigned, N0, N1) == OFK_Never;
2240 }
2241
2242 /// Determine if the result of the signed sub of 2 nodes can overflow.
2244 SDValue N1) const;
2245
2246 /// Determine if the result of the unsigned sub of 2 nodes can overflow.
2248 SDValue N1) const;
2249
2250 /// Determine if the result of the sub of 2 nodes can overflow.
2252 SDValue N1) const {
2253 return IsSigned ? computeOverflowForSignedSub(N0, N1)
2255 }
2256
2257 /// Determine if the result of the sub of 2 nodes can never overflow.
2258 bool willNotOverflowSub(bool IsSigned, SDValue N0, SDValue N1) const {
2259 return computeOverflowForSub(IsSigned, N0, N1) == OFK_Never;
2260 }
2261
2262 /// Determine if the result of the signed mul of 2 nodes can overflow.
2264 SDValue N1) const;
2265
2266 /// Determine if the result of the unsigned mul of 2 nodes can overflow.
2268 SDValue N1) const;
2269
2270 /// Determine if the result of the mul of 2 nodes can overflow.
2272 SDValue N1) const {
2273 return IsSigned ? computeOverflowForSignedMul(N0, N1)
2275 }
2276
2277 /// Determine if the result of the mul of 2 nodes can never overflow.
2278 bool willNotOverflowMul(bool IsSigned, SDValue N0, SDValue N1) const {
2279 return computeOverflowForMul(IsSigned, N0, N1) == OFK_Never;
2280 }
2281
2282 /// Returns true if \p V is an identity element of Opc with Flags.
2283 /// When OperandNo is 0, it checks that V is a left identity. Otherwise, it
2284 /// checks that V is a right identity.
2285 LLVM_ABI bool isIdentityElement(unsigned Opc, SDNodeFlags Flags, SDValue V,
2286 unsigned OperandNo, unsigned Depth = 0) const;
2287
2288 /// Returns true if the demanded vector elements of \p V is an identity
2289 /// element of Opc with Flags. When OperandNo is 0, it checks that V is a left
2290 /// identity. Otherwise, it checks that V is a right identity.
2291 LLVM_ABI bool isIdentityElement(unsigned Opc, SDNodeFlags Flags, SDValue V,
2292 const APInt &DemandedElts, unsigned OperandNo,
2293 unsigned Depth = 0) const;
2294
2295 /// Test if the given value is known to have exactly one bit set. This differs
2296 /// from computeKnownBits in that it doesn't necessarily determine which bit
2297 /// is set. If 'OrZero' is set, then return true if the given value is either
2298 /// a power of two or zero.
2299 LLVM_ABI bool isKnownToBeAPowerOfTwo(SDValue Val, bool OrZero = false,
2300 unsigned Depth = 0) const;
2301
2302 /// Test if the given value is known to have exactly one bit set. This differs
2303 /// from computeKnownBits in that it doesn't necessarily determine which bit
2304 /// is set. The DemandedElts argument allows us to only collect the minimum
2305 /// sign bits of the requested vector elements. If 'OrZero' is set, then
2306 /// return true if the given value is either a power of two or zero.
2307 LLVM_ABI bool isKnownToBeAPowerOfTwo(SDValue Val, const APInt &DemandedElts,
2308 bool OrZero = false,
2309 unsigned Depth = 0) const;
2310
2311 /// Test if the given _fp_ value is known to be an integer power-of-2, either
2312 /// positive or negative.
2313 LLVM_ABI bool isKnownToBeAPowerOfTwoFP(SDValue Val, unsigned Depth = 0) const;
2314
2315 /// Return the number of times the sign bit of the register is replicated into
2316 /// the other bits. We know that at least 1 bit is always equal to the sign
2317 /// bit (itself), but other cases can give us information. For example,
2318 /// immediately after an "SRA X, 2", we know that the top 3 bits are all equal
2319 /// to each other, so we return 3. Targets can implement the
2320 /// ComputeNumSignBitsForTarget method in the TargetLowering class to allow
2321 /// target nodes to be understood.
2322 LLVM_ABI unsigned ComputeNumSignBits(SDValue Op, unsigned Depth = 0) const;
2323
2324 /// Return the number of times the sign bit of the register is replicated into
2325 /// the other bits. We know that at least 1 bit is always equal to the sign
2326 /// bit (itself), but other cases can give us information. For example,
2327 /// immediately after an "SRA X, 2", we know that the top 3 bits are all equal
2328 /// to each other, so we return 3. The DemandedElts argument allows
2329 /// us to only collect the minimum sign bits of the requested vector elements.
2330 /// Targets can implement the ComputeNumSignBitsForTarget method in the
2331 /// TargetLowering class to allow target nodes to be understood.
2332 LLVM_ABI unsigned ComputeNumSignBits(SDValue Op, const APInt &DemandedElts,
2333 unsigned Depth = 0) const;
2334
2335 /// Get the upper bound on bit size for this Value \p Op as a signed integer.
2336 /// i.e. x == sext(trunc(x to MaxSignedBits) to bitwidth(x)).
2337 /// Similar to the APInt::getSignificantBits function.
2338 /// Helper wrapper to ComputeNumSignBits.
2340 unsigned Depth = 0) const;
2341
2342 /// Get the upper bound on bit size for this Value \p Op as a signed integer.
2343 /// i.e. x == sext(trunc(x to MaxSignedBits) to bitwidth(x)).
2344 /// Similar to the APInt::getSignificantBits function.
2345 /// Helper wrapper to ComputeNumSignBits.
2347 const APInt &DemandedElts,
2348 unsigned Depth = 0) const;
2349
2350 /// Return true if this function can prove that \p Op is never poison
2351 /// and, \p Kind can be used to track poison and/or undef bits.
2354 unsigned Depth = 0) const;
2355
2356 /// Return true if this function can prove that \p Op is never poison
2357 /// and, \p Kind can be used to track poison and/or undef bits. The
2358 /// DemandedElts argument limits the check to the requested vector elements.
2360 SDValue Op, const APInt &DemandedElts,
2362 unsigned Depth = 0) const;
2363
2364 /// Return true if this function can prove that \p Op is never poison.
2369
2370 /// Return true if this function can prove that \p Op is never poison. The
2371 /// DemandedElts argument limits the check to the requested vector elements.
2372 bool isGuaranteedNotToBePoison(SDValue Op, const APInt &DemandedElts,
2373 unsigned Depth = 0) const {
2374 return isGuaranteedNotToBeUndefOrPoison(Op, DemandedElts,
2376 }
2377
2378 /// Return true if Op can create undef or poison from non-undef & non-poison
2379 /// operands. The DemandedElts argument limits the check to the requested
2380 /// vector elements.
2381 ///
2382 /// \p ConsiderFlags controls whether poison producing flags on the
2383 /// instruction are considered. This can be used to see if the instruction
2384 /// could still introduce undef or poison even without poison generating flags
2385 /// which might be on the instruction. (i.e. could the result of
2386 /// Op->dropPoisonGeneratingFlags() still create poison or undef)
2387 LLVM_ABI bool
2388 canCreateUndefOrPoison(SDValue Op, const APInt &DemandedElts,
2390 bool ConsiderFlags = true, unsigned Depth = 0) const;
2391
2392 /// Return true if Op can create undef or poison from non-undef & non-poison
2393 /// operands.
2394 ///
2395 /// \p ConsiderFlags controls whether poison producing flags on the
2396 /// instruction are considered. This can be used to see if the instruction
2397 /// could still introduce undef or poison even without poison generating flags
2398 /// which might be on the instruction. (i.e. could the result of
2399 /// Op->dropPoisonGeneratingFlags() still create poison or undef)
2400 LLVM_ABI bool
2403 bool ConsiderFlags = true, unsigned Depth = 0) const;
2404
2405 /// Return true if the specified operand is an ISD::OR or ISD::XOR node
2406 /// that can be treated as an ISD::ADD node.
2407 /// or(x,y) == add(x,y) iff haveNoCommonBitsSet(x,y)
2408 /// xor(x,y) == add(x,y) iff isMinSignedConstant(y) && !NoWrap
2409 /// If \p NoWrap is true, this will not match ISD::XOR.
2410 LLVM_ABI bool isADDLike(SDValue Op, bool NoWrap = false) const;
2411
2412 /// Return true if the specified operand is an ISD::ADD with a ConstantSDNode
2413 /// on the right-hand side, or if it is an ISD::OR with a ConstantSDNode that
2414 /// is guaranteed to have the same semantics as an ADD. This handles the
2415 /// equivalence:
2416 /// X|Cst == X+Cst iff X&Cst = 0.
2418
2419 /// Determine floating-point class information about \p Op. For vectors, the
2420 /// known FP classes are those shared by every demanded vector element.
2421 /// \p InterestedClasses is a hint for which FP classes we care about;
2422 /// the implementation may bail out early if it can determine that
2423 /// none of the interested classes are possible.
2425 FPClassTest InterestedClasses,
2426 unsigned Depth = 0) const;
2427
2428 /// Determine floating-point class information about \p Op. The
2429 /// DemandedElts argument allows us to only collect the known FP classes
2430 /// that are shared by the requested vector elements.
2431 /// \p InterestedClasses is a hint for which FP classes we care about.
2433 const APInt &DemandedElts,
2434 FPClassTest InterestedClasses,
2435 unsigned Depth = 0) const;
2436
2437 /// Test whether the given SDValue (or all elements of it, if it is a
2438 /// vector) is known to never be NaN in \p DemandedElts. If \p SNaN is true,
2439 /// returns if \p Op is known to never be a signaling NaN (it may still be a
2440 /// qNaN).
2441 LLVM_ABI bool isKnownNeverNaN(SDValue Op, const APInt &DemandedElts,
2442 bool SNaN = false, unsigned Depth = 0) const;
2443
2444 /// Test whether the given SDValue (or all elements of it, if it is a
2445 /// vector) is known to never be NaN. If \p SNaN is true, returns if \p Op is
2446 /// known to never be a signaling NaN (it may still be a qNaN).
2447 LLVM_ABI bool isKnownNeverNaN(SDValue Op, bool SNaN = false,
2448 unsigned Depth = 0) const;
2449
2450 /// \returns true if \p Op is known to never be a signaling NaN in \p
2451 /// DemandedElts.
2452 bool isKnownNeverSNaN(SDValue Op, const APInt &DemandedElts,
2453 unsigned Depth = 0) const {
2454 return isKnownNeverNaN(Op, DemandedElts, true, Depth);
2455 }
2456
2457 /// \returns true if \p Op is known to never be a signaling NaN.
2458 bool isKnownNeverSNaN(SDValue Op, unsigned Depth = 0) const {
2459 return isKnownNeverNaN(Op, true, Depth);
2460 }
2461
2462 /// Test whether the given floating point SDValue (or all elements of it, if
2463 /// it is a vector) is known to never be interpretable as zero in \p
2464 /// DemandedElts.
2465 LLVM_ABI bool isKnownNeverLogicalZero(SDValue Op, const APInt &DemandedElts,
2466 unsigned Depth = 0) const;
2467
2468 /// Test whether the given floating point SDValue (or all elements of it, if
2469 /// it is a vector) is known to never be interpretable as zero.
2470 LLVM_ABI bool isKnownNeverLogicalZero(SDValue Op, unsigned Depth = 0) const;
2471
2472 /// Test whether the given SDValue is known to contain non-zero value(s).
2473 LLVM_ABI bool isKnownNeverZero(SDValue Op, unsigned Depth = 0) const;
2474
2475 /// Test whether the given SDValue is known to contain non-zero value(s).
2476 /// The DemandedElts argument limits the check to the requested vector
2477 /// elements.
2478 LLVM_ABI bool isKnownNeverZero(SDValue Op, const APInt &DemandedElts,
2479 unsigned Depth = 0) const;
2480
2481 /// Test whether the given float value is known to be positive. +0.0, +inf and
2482 /// +nan are considered positive, -0.0, -inf and -nan are not.
2484
2485 /// Check if a use of a float value is insensitive to signed zeros.
2486 LLVM_ABI bool canIgnoreSignBitOfZero(const SDUse &Use) const;
2487
2488 /// Check if \p Op has no-signed-zeros, or all users (limited to checking two
2489 /// for compile-time performance) are insensitive to signed zeros.
2491
2492 /// Test whether two SDValues are known to compare equal. This
2493 /// is true if they are the same value, or if one is negative zero and the
2494 /// other positive zero.
2495 LLVM_ABI bool isEqualTo(SDValue A, SDValue B) const;
2496
2497 /// Return true if A and B have no common bits set. As an example, this can
2498 /// allow an 'add' to be transformed into an 'or'.
2500
2501 /// Test whether \p V has a splatted value for all the demanded elements.
2502 ///
2503 /// On success \p UndefElts will indicate the elements that have UNDEF
2504 /// values instead of the splat value, this is only guaranteed to be correct
2505 /// for \p DemandedElts.
2506 ///
2507 /// NOTE: The function will return true for a demanded splat of UNDEF values.
2508 LLVM_ABI bool isSplatValue(SDValue V, const APInt &DemandedElts,
2509 APInt &UndefElts, unsigned Depth = 0) const;
2510
2511 /// Test whether \p V has a splatted value.
2512 LLVM_ABI bool isSplatValue(SDValue V, bool AllowUndefs = false) const;
2513
2514 /// If V is a splatted value, return the source vector and its splat index.
2515 LLVM_ABI SDValue getSplatSourceVector(SDValue V, int &SplatIndex);
2516
2517 /// If V is a splat vector, return its scalar source operand by extracting
2518 /// that element from the source vector. If LegalTypes is true, this method
2519 /// may only return a legally-typed splat value. If it cannot legalize the
2520 /// splatted value it will return SDValue().
2521 LLVM_ABI SDValue getSplatValue(SDValue V, bool LegalTypes = false);
2522
2523 /// If a SHL/SRA/SRL node \p V has shift amounts that are all less than the
2524 /// element bit-width of the shift node, return the valid constant range.
2525 LLVM_ABI std::optional<ConstantRange>
2526 getValidShiftAmountRange(SDValue V, const APInt &DemandedElts,
2527 unsigned Depth) const;
2528
2529 /// If a SHL/SRA/SRL node \p V has a uniform shift amount
2530 /// that is less than the element bit-width of the shift node, return it.
2531 LLVM_ABI std::optional<unsigned>
2532 getValidShiftAmount(SDValue V, const APInt &DemandedElts,
2533 unsigned Depth = 0) const;
2534
2535 /// If a SHL/SRA/SRL node \p V has a uniform shift amount
2536 /// that is less than the element bit-width of the shift node, return it.
2537 LLVM_ABI std::optional<unsigned>
2538 getValidShiftAmount(SDValue V, unsigned Depth = 0) const;
2539
2540 /// If a SHL/SRA/SRL node \p V has shift amounts that are all less than the
2541 /// element bit-width of the shift node, return the minimum possible value.
2542 LLVM_ABI std::optional<unsigned>
2543 getValidMinimumShiftAmount(SDValue V, const APInt &DemandedElts,
2544 unsigned Depth = 0) const;
2545
2546 /// If a SHL/SRA/SRL node \p V has shift amounts that are all less than the
2547 /// element bit-width of the shift node, return the minimum possible value.
2548 LLVM_ABI std::optional<unsigned>
2549 getValidMinimumShiftAmount(SDValue V, unsigned Depth = 0) const;
2550
2551 /// If a SHL/SRA/SRL node \p V has shift amounts that are all less than the
2552 /// element bit-width of the shift node, return the maximum possible value.
2553 LLVM_ABI std::optional<unsigned>
2554 getValidMaximumShiftAmount(SDValue V, const APInt &DemandedElts,
2555 unsigned Depth = 0) const;
2556
2557 /// If a SHL/SRA/SRL node \p V has shift amounts that are all less than the
2558 /// element bit-width of the shift node, return the maximum possible value.
2559 LLVM_ABI std::optional<unsigned>
2560 getValidMaximumShiftAmount(SDValue V, unsigned Depth = 0) const;
2561
2562 /// Match a binop + shuffle pyramid that represents a horizontal reduction
2563 /// over the elements of a vector starting from the EXTRACT_VECTOR_ELT node /p
2564 /// Extract. The reduction must use one of the opcodes listed in /p
2565 /// CandidateBinOps and on success /p BinOp will contain the matching opcode.
2566 /// Returns the vector that is being reduced on, or SDValue() if a reduction
2567 /// was not matched. If \p AllowPartials is set then in the case of a
2568 /// reduction pattern that only matches the first few stages, the extracted
2569 /// subvector of the start of the reduction is returned.
2571 ArrayRef<ISD::NodeType> CandidateBinOps,
2572 bool AllowPartials = false);
2573
2574 /// Utility function used by legalize and lowering to
2575 /// "unroll" a vector operation by splitting out the scalars and operating
2576 /// on each element individually. If the ResNE is 0, fully unroll the vector
2577 /// op. If ResNE is less than the width of the vector op, unroll up to ResNE.
2578 /// If the ResNE is greater than the width of the vector op, unroll the
2579 /// vector op and fill the end of the resulting vector with UNDEFS.
2580 LLVM_ABI SDValue UnrollVectorOp(SDNode *N, unsigned ResNE = 0);
2581
2582 /// Like UnrollVectorOp(), but for the [US](ADD|SUB|MUL)O family of opcodes.
2583 /// This is a separate function because those opcodes have two results.
2584 LLVM_ABI std::pair<SDValue, SDValue>
2585 UnrollVectorOverflowOp(SDNode *N, unsigned ResNE = 0);
2586
2587 /// Return true if loads are next to each other and can be
2588 /// merged. Check that both are nonvolatile and if LD is loading
2589 /// 'Bytes' bytes from a location that is 'Dist' units away from the
2590 /// location that the 'Base' load is loading from.
2592 unsigned Bytes, int Dist) const;
2593
2594 /// Infer alignment of a load / store address. Return std::nullopt if it
2595 /// cannot be inferred.
2597
2598 /// Split the scalar node with EXTRACT_ELEMENT using the provided VTs and
2599 /// return the low/high part.
2600 LLVM_ABI std::pair<SDValue, SDValue> SplitScalar(const SDValue &N,
2601 const SDLoc &DL,
2602 const EVT &LoVT,
2603 const EVT &HiVT);
2604
2605 /// Compute the VTs needed for the low/hi parts of a type
2606 /// which is split (or expanded) into two not necessarily identical pieces.
2607 LLVM_ABI std::pair<EVT, EVT> GetSplitDestVTs(const EVT &VT) const;
2608
2609 /// Compute the VTs needed for the low/hi parts of a type, dependent on an
2610 /// enveloping VT that has been split into two identical pieces. Sets the
2611 /// HisIsEmpty flag when hi type has zero storage size.
2612 LLVM_ABI std::pair<EVT, EVT> GetDependentSplitDestVTs(const EVT &VT,
2613 const EVT &EnvVT,
2614 bool *HiIsEmpty) const;
2615
2616 /// Split the vector with EXTRACT_SUBVECTOR using the provided
2617 /// VTs and return the low/high part.
2618 LLVM_ABI std::pair<SDValue, SDValue> SplitVector(const SDValue &N,
2619 const SDLoc &DL,
2620 const EVT &LoVT,
2621 const EVT &HiVT);
2622
2623 /// Split the vector with EXTRACT_SUBVECTOR and return the low/high part.
2624 std::pair<SDValue, SDValue> SplitVector(const SDValue &N, const SDLoc &DL) {
2625 EVT LoVT, HiVT;
2626 std::tie(LoVT, HiVT) = GetSplitDestVTs(N.getValueType());
2627 return SplitVector(N, DL, LoVT, HiVT);
2628 }
2629
2630 /// Split the explicit vector length parameter of a VP operation.
2631 LLVM_ABI std::pair<SDValue, SDValue> SplitEVL(SDValue N, EVT VecVT,
2632 const SDLoc &DL);
2633
2634 /// Split the node's operand with EXTRACT_SUBVECTOR and
2635 /// return the low/high part.
2636 std::pair<SDValue, SDValue> SplitVectorOperand(const SDNode *N, unsigned OpNo)
2637 {
2638 return SplitVector(N->getOperand(OpNo), SDLoc(N));
2639 }
2640
2641 /// Widen the vector up to the next power of two using INSERT_SUBVECTOR.
2642 LLVM_ABI SDValue WidenVector(const SDValue &N, const SDLoc &DL);
2643
2644 /// Append the extracted elements from Start to Count out of the vector Op in
2645 /// Args. If Count is 0, all of the elements will be extracted. The extracted
2646 /// elements will have type EVT if it is provided, and otherwise their type
2647 /// will be Op's element type.
2650 unsigned Start = 0, unsigned Count = 0,
2651 EVT EltVT = EVT());
2652
2653 /// Compute the default alignment value for the given type.
2654 LLVM_ABI Align getEVTAlign(EVT MemoryVT) const;
2655
2656 /// Test whether the given value is a constant int or similar node.
2657 LLVM_ABI bool
2659 bool AllowOpaques = true) const;
2660
2661 /// Test whether the given value is a constant FP or similar node.
2663
2664 /// \returns true if \p N is any kind of constant or build_vector of
2665 /// constants, int or float. If a vector, it may not necessarily be a splat.
2670
2671 /// Check if a value \op N is a constant using the target's BooleanContent for
2672 /// its type.
2673 LLVM_ABI std::optional<bool> isBoolConstant(SDValue N) const;
2674
2675 /// Set CallSiteInfo to be associated with Node.
2676 void addCallSiteInfo(const SDNode *Node, CallSiteInfo &&CallInfo) {
2677 SDEI[Node].CSInfo = std::move(CallInfo);
2678 }
2679 /// Return CallSiteInfo associated with Node, or a default if none exists.
2680 CallSiteInfo getCallSiteInfo(const SDNode *Node) {
2681 auto I = SDEI.find(Node);
2682 return I != SDEI.end() ? std::move(I->second).CSInfo : CallSiteInfo();
2683 }
2684 /// Set HeapAllocSite to be associated with Node.
2686 SDEI[Node].HeapAllocSite = MD;
2687 }
2688 /// Return HeapAllocSite associated with Node, or nullptr if none exists.
2690 auto I = SDEI.find(Node);
2691 return I != SDEI.end() ? I->second.HeapAllocSite : nullptr;
2692 }
2693 /// Set PCSections to be associated with Node.
2694 void addPCSections(const SDNode *Node, MDNode *MD) {
2695 SDEI[Node].PCSections = MD;
2696 }
2697 /// Set MMRAMetadata to be associated with Node.
2698 void addMMRAMetadata(const SDNode *Node, MDNode *MMRA) {
2699 SDEI[Node].MMRA = MMRA;
2700 }
2701 /// Return PCSections associated with Node, or nullptr if none exists.
2703 auto It = SDEI.find(Node);
2704 return It != SDEI.end() ? It->second.PCSections : nullptr;
2705 }
2706 /// Return the MMRA MDNode associated with Node, or nullptr if none
2707 /// exists.
2709 auto It = SDEI.find(Node);
2710 return It != SDEI.end() ? It->second.MMRA : nullptr;
2711 }
2712 /// Set CalledGlobal to be associated with Node.
2713 void addCalledGlobal(const SDNode *Node, const GlobalValue *GV,
2714 unsigned OpFlags) {
2715 SDEI[Node].CalledGlobal = {GV, OpFlags};
2716 }
2717 /// Return CalledGlobal associated with Node, or a nullopt if none exists.
2718 std::optional<CalledGlobalInfo> getCalledGlobal(const SDNode *Node) {
2719 auto I = SDEI.find(Node);
2720 return I != SDEI.end()
2721 ? std::make_optional(std::move(I->second).CalledGlobal)
2722 : std::nullopt;
2723 }
2724 /// Set NoMergeSiteInfo to be associated with Node if NoMerge is true.
2725 void addNoMergeSiteInfo(const SDNode *Node, bool NoMerge) {
2726 if (NoMerge)
2727 SDEI[Node].NoMerge = NoMerge;
2728 }
2729 /// Return NoMerge info associated with Node.
2730 bool getNoMergeSiteInfo(const SDNode *Node) const {
2731 auto I = SDEI.find(Node);
2732 return I != SDEI.end() ? I->second.NoMerge : false;
2733 }
2734
2735 /// Copy extra info associated with one node to another.
2736 LLVM_ABI void copyExtraInfo(SDNode *From, SDNode *To);
2737
2738 /// Return the current function's default denormal handling kind for the given
2739 /// floating point type.
2741 return MF->getDenormalMode(VT.getFltSemantics());
2742 }
2743
2744 LLVM_ABI bool shouldOptForSize() const;
2745
2746 /// Get the (commutative) identity element for the given opcode, if it exists.
2747 LLVM_ABI SDValue getIdentityElement(unsigned Opcode, const SDLoc &DL, EVT VT,
2748 SDNodeFlags Flags);
2749
2750 /// Get an expression that implements a partial multiply-subtract reduction.
2751 /// In practice this means that parts of the expression are negated, e.g.
2752 ///
2753 /// partial_reduce_fmls acc, lhs, rhs
2754 /// <=> partial_reduce_fmla acc, lhs, -rhs
2755 ///
2756 /// partial_reduce_umls acc, lhs, rhs
2757 /// <=> -partial_reduce_umla -acc, lhs, rhs
2758 SDValue getPartialReduceMLS(unsigned Opc, const SDLoc &DL, SDValue Acc,
2760
2761 /// Some opcodes may create immediate undefined behavior when used with some
2762 /// values (integer division-by-zero for example). Therefore, these operations
2763 /// are not generally safe to move around or change.
2764 bool isSafeToSpeculativelyExecute(unsigned Opcode) const {
2765 switch (Opcode) {
2766 case ISD::SDIV:
2767 case ISD::SREM:
2768 case ISD::SDIVREM:
2769 case ISD::UDIV:
2770 case ISD::UREM:
2771 case ISD::UDIVREM:
2772 return false;
2773 default:
2774 return true;
2775 }
2776 }
2777
2778 /// Check if the provided node is save to speculatively executed given its
2779 /// current arguments. So, while `udiv` the opcode is not safe to
2780 /// speculatively execute, a given `udiv` node may be if the denominator is
2781 /// known nonzero.
2783 switch (N->getOpcode()) {
2784 case ISD::UDIV:
2785 return isKnownNeverZero(N->getOperand(1));
2786 default:
2787 return isSafeToSpeculativelyExecute(N->getOpcode());
2788 }
2789 }
2790
2791 LLVM_ABI SDValue makeStateFunctionCall(unsigned LibFunc, SDValue Ptr,
2792 SDValue InChain, const SDLoc &DLoc);
2793
2794private:
2795#ifndef NDEBUG
2796 void verifyNode(SDNode *N) const;
2797#endif
2798 void InsertNode(SDNode *N);
2799 bool RemoveNodeFromCSEMaps(SDNode *N);
2800 void AddModifiedNodeToCSEMaps(SDNode *N);
2801 SDNode *FindModifiedNodeSlot(SDNode *N, SDValue Op, void *&InsertPos);
2802 SDNode *FindModifiedNodeSlot(SDNode *N, SDValue Op1, SDValue Op2,
2803 void *&InsertPos);
2804 SDNode *FindModifiedNodeSlot(SDNode *N, ArrayRef<SDValue> Ops,
2805 void *&InsertPos);
2806 SDNode *UpdateSDLocOnMergeSDNode(SDNode *N, const SDLoc &loc);
2807
2808 void DeleteNodeNotInCSEMaps(SDNode *N);
2809 void DeallocateNode(SDNode *N);
2810
2811 void allnodes_clear();
2812
2813 /// Look up the node specified by ID in CSEMap. If it exists, return it. If
2814 /// not, return the insertion token that will make insertion faster. This
2815 /// overload is for nodes other than Constant or ConstantFP, use the other one
2816 /// for those.
2817 SDNode *FindNodeOrInsertPos(const FoldingSetNodeID &ID, void *&InsertPos);
2818
2819 /// Look up the node specified by ID in CSEMap. If it exists, return it. If
2820 /// not, return the insertion token that will make insertion faster. Performs
2821 /// additional processing for constant nodes.
2822 SDNode *FindNodeOrInsertPos(const FoldingSetNodeID &ID, const SDLoc &DL,
2823 void *&InsertPos);
2824
2825 /// Maps to auto-CSE operations.
2826 std::vector<CondCodeSDNode*> CondCodeNodes;
2827
2828 std::vector<SDNode*> ValueTypeNodes;
2829 std::map<EVT, SDNode*, EVT::compareRawBits> ExtendedValueTypeNodes;
2830 StringMap<SDNode*> ExternalSymbols;
2831
2832 std::map<std::pair<std::string, unsigned>, SDNode *> TargetExternalSymbols;
2834
2835 FlagInserter *Inserter = nullptr;
2836};
2837
2838template <> struct GraphTraits<SelectionDAG*> : public GraphTraits<SDNode*> {
2840
2842 return nodes_iterator(G->allnodes_begin());
2843 }
2844
2846 return nodes_iterator(G->allnodes_end());
2847 }
2848};
2849
2850} // end namespace llvm
2851
2852#endif // LLVM_CODEGEN_SELECTIONDAG_H
return SDValue()
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
This file defines the StringMap class.
constexpr LLT S1
AMDGPU Uniform Intrinsic Combine
MachineBasicBlock & MBB
MachineBasicBlock MachineBasicBlock::iterator DebugLoc DL
This file defines the BumpPtrAllocator interface.
#define X(NUM, ENUM, NAME)
Definition ELF.h:853
static GCRegistry::Add< ErlangGC > A("erlang", "erlang-compatible garbage collector")
static GCRegistry::Add< StatepointGC > D("statepoint-example", "an example strategy for statepoint")
static GCRegistry::Add< CoreCLRGC > E("coreclr", "CoreCLR-compatible GC")
static GCRegistry::Add< OcamlGC > B("ocaml", "ocaml 3.10-compatible GC")
#define LLVM_ABI
Definition Compiler.h:213
#define LLVM_DUMP_METHOD
Mark debug helper function definitions like dump() that should not be stripped from debug builds.
Definition Compiler.h:661
@ CallSiteInfo
This file defines the DenseMap class.
This file defines the DenseSet and SmallDenseSet classes.
This file defines a hash set that can be used to remove duplication of nodes in a graph.
const AbstractManglingParser< Derived, Alloc >::OperatorInfo AbstractManglingParser< Derived, Alloc >::Ops[]
#define I(x, y, z)
Definition MD5.cpp:57
#define G(x, y, z)
Definition MD5.cpp:55
Register Reg
This file contains the declarations for metadata subclasses.
const SmallVectorImpl< MachineOperand > & Cond
This file defines the SmallVector class.
static TableGen::Emitter::Opt Y("gen-skeleton-entry", EmitSkeleton, "Generate example skeleton entry")
static void removeOperands(MachineInstr &MI, unsigned i)
This file contains the UndefPoisonKind enum and helper functions.
Value * RHS
Value * LHS
Class for arbitrary precision integers.
Definition APInt.h:78
static Capacity get(size_t N)
Get the capacity of an array that can hold at least N elements.
Recycle small arrays allocated from a BumpPtrAllocator.
Represent a constant reference to an array (0 or more elements consecutively in memory),...
Definition ArrayRef.h:40
This class is a wrapper over an AAResults, and it is intended to be used only when there are no IR ch...
The address of a basic block.
Definition Constants.h:1071
BlockFrequencyInfo pass uses BlockFrequencyInfoImpl implementation to estimate IR basic block frequen...
A "pseudo-class" with methods for operating on BUILD_VECTORs.
This class represents a function call, abstracting a target machine's calling convention.
ConstantFP - Floating Point Values [float, double].
Definition Constants.h:420
This is the shared class of boolean and integer constants.
Definition Constants.h:87
This is an important base class in LLVM.
Definition Constant.h:43
DWARF expression.
Base class for variables.
A parsed version of the target data layout string in and methods for querying it.
Definition DataLayout.h:64
A debug info location.
Definition DebugLoc.h:123
Implements a dense probed hash-table based set.
Definition DenseSet.h:279
This class describes a reference to an interned FoldingSetNodeID, which can be a useful to store node...
Definition FoldingSet.h:171
This class is used to gather all the unique data bits of a node.
Definition FoldingSet.h:208
This template class is used to instantiate a specialized implementation of the folding set to the nod...
Definition FoldingSet.h:529
FunctionLoweringInfo - This contains information that is global to a function that is used when lower...
Data structure describing the variable locations in a function.
This is an important class for using LLVM in a threaded context.
Definition LLVMContext.h:68
Tracks which library functions to use for a particular subtarget.
This class is used to represent ISD::LOAD nodes.
static LocationSize precise(uint64_t Value)
MCSymbol - Instances of this class represent a symbol name in the MC file, and MCSymbols are created ...
Definition MCSymbol.h:42
Metadata node.
Definition Metadata.h:1080
Abstract base class for all machine specific constantpool value subclasses.
A description of a memory reference used in the backend.
Flags
Flags values. These may be or'd together.
@ MOLoad
The memory access reads data.
@ MOStore
The memory access writes data.
This class contains meta information specific to a module.
An SDNode that represents everything that will be needed to construct a MachineInstr.
The optimization diagnostic interface.
Pass interface - Implemented by all 'passes'.
Definition Pass.h:99
Analysis providing profile information.
RecyclingAllocator - This class wraps an Allocator, adding the functionality of recycling deleted obj...
Wrapper class representing virtual and physical registers.
Definition Register.h:20
Keeps track of dbg_value information through SDISel.
BumpPtrAllocator & getAlloc()
DbgIterator ByvalParmDbgBegin()
DbgIterator DbgEnd()
SDDbgInfo & operator=(const SDDbgInfo &)=delete
SmallVectorImpl< SDDbgLabel * >::iterator DbgLabelIterator
SDDbgInfo()=default
LLVM_ABI void add(SDDbgValue *V, bool isParameter)
bool empty() const
DbgLabelIterator DbgLabelEnd()
DbgIterator ByvalParmDbgEnd()
SmallVectorImpl< SDDbgValue * >::iterator DbgIterator
SDDbgInfo(const SDDbgInfo &)=delete
DbgLabelIterator DbgLabelBegin()
void add(SDDbgLabel *L)
DbgIterator DbgBegin()
LLVM_ABI void erase(const SDNode *Node)
Invalidate all DbgValues attached to the node and remove it from the Node-to-DbgValues map.
ArrayRef< SDDbgValue * > getSDDbgValues(const SDNode *Node) const
Holds the information from a dbg_label node through SDISel.
Holds the information for a single machine location through SDISel; either an SDNode,...
Holds the information from a dbg_value node through SDISel.
Wrapper class for IR location info (IR ordering and DebugLoc) to be passed into SDNode creation funct...
Represents one node in the SelectionDAG.
Represents a use of a SDNode.
SDVTListNode(const FoldingSetNodeIDRef ID, const EVT *VT, unsigned int Num)
SDVTList getSDVTList()
Unlike LLVM values, Selection DAG nodes may return multiple values as the result of a computation.
SDNode * getNode() const
get the SDNode which holds the desired result
EVT getValueType() const
Return the ValueType of the referenced return value.
Targets can subclass this to parameterize the SelectionDAG lowering and instruction selection process...
Help to insert SDNodeFlags automatically in transforming.
FlagInserter(SelectionDAG &SDAG, SDNodeFlags Flags)
FlagInserter(const FlagInserter &)=delete
FlagInserter(SelectionDAG &SDAG, SDNode *N)
FlagInserter & operator=(const FlagInserter &)=delete
This is used to represent a portion of an LLVM function in a low-level Data Dependence DAG representa...
LLVM_ABI SDValue getElementCount(const SDLoc &DL, EVT VT, ElementCount EC)
bool willNotOverflowAdd(bool IsSigned, SDValue N0, SDValue N1) const
Determine if the result of the addition of 2 nodes can never overflow.
static unsigned getOpcode_EXTEND_VECTOR_INREG(unsigned Opcode)
Convert *_EXTEND to *_EXTEND_VECTOR_INREG opcode.
LLVM_ABI Align getReducedAlign(EVT VT, bool UseABI)
In most cases this function returns the ABI alignment for a given type, except for illegal vector typ...
LLVM_ABI SDValue getVPZeroExtendInReg(SDValue Op, SDValue Mask, SDValue EVL, const SDLoc &DL, EVT VT)
Return the expression required to zero extend the Op value assuming it was the smaller SrcTy value.
LLVM_ABI SDValue getShiftAmountOperand(EVT LHSTy, SDValue Op)
Return the specified value casted to the target's desired shift amount type.
LLVM_ABI SDValue getExtLoad(ISD::LoadExtType ExtType, const SDLoc &dl, EVT VT, SDValue Chain, SDValue Ptr, MachinePointerInfo PtrInfo, EVT MemVT, MaybeAlign Alignment=MaybeAlign(), MachineMemOperand::Flags MMOFlags=MachineMemOperand::MONone, const AAMDNodes &AAInfo=AAMDNodes())
LLVM_ABI std::pair< SDValue, SDValue > getMemccpy(SDValue Chain, const SDLoc &dl, SDValue Dst, SDValue Src, SDValue C, SDValue Size, const CallInst *CI)
Lower a memccpy operation into a target library call and return the resulting chain and call result a...
LLVM_ABI bool isKnownNeverLogicalZero(SDValue Op, const APInt &DemandedElts, unsigned Depth=0) const
Test whether the given floating point SDValue (or all elements of it, if it is a vector) is known to ...
LLVM_ABI SDValue getExtLoadVP(ISD::LoadExtType ExtType, const SDLoc &dl, EVT VT, SDValue Chain, SDValue Ptr, SDValue Mask, SDValue EVL, MachinePointerInfo PtrInfo, EVT MemVT, MaybeAlign Alignment, MachineMemOperand::Flags MMOFlags, const AAMDNodes &AAInfo, bool IsExpanding=false)
SDValue getTargetGlobalAddress(const GlobalValue *GV, const SDLoc &DL, EVT VT, int64_t offset=0, unsigned TargetFlags=0)
SDValue getExtOrTrunc(SDValue Op, const SDLoc &DL, EVT VT, unsigned Opcode)
Convert Op, which must be of integer type, to the integer type VT, by either any/sign/zero-extending ...
SDValue getCopyFromReg(SDValue Chain, const SDLoc &dl, Register Reg, EVT VT, SDValue Glue)
SDValue getExtractVectorElt(const SDLoc &DL, EVT VT, SDValue Vec, unsigned Idx)
Extract element at Idx from Vec.
LLVM_ABI SDValue getSplatSourceVector(SDValue V, int &SplatIndex)
If V is a splatted value, return the source vector and its splat index.
LLVM_ABI SDValue getLabelNode(unsigned Opcode, const SDLoc &dl, SDValue Root, MCSymbol *Label)
LLVM_ABI OverflowKind computeOverflowForUnsignedSub(SDValue N0, SDValue N1) const
Determine if the result of the unsigned sub of 2 nodes can overflow.
LLVM_ABI unsigned ComputeMaxSignificantBits(SDValue Op, unsigned Depth=0) const
Get the upper bound on bit size for this Value Op as a signed integer.
const SDValue & getRoot() const
Return the root tag of the SelectionDAG.
LLVM_ABI std::pair< SDValue, SDValue > getStrlen(SDValue Chain, const SDLoc &dl, SDValue Src, const CallInst *CI)
Lower a strlen operation into a target library call and return the resulting chain and call result as...
LLVM_ABI SDValue getMaskedGather(SDVTList VTs, EVT MemVT, const SDLoc &dl, ArrayRef< SDValue > Ops, MachineMemOperand *MMO, ISD::MemIndexType IndexType, ISD::LoadExtType ExtTy)
const RTLIB::RuntimeLibcallsInfo & getRuntimeLibcallInfo() const
bool isKnownNeverSNaN(SDValue Op, unsigned Depth=0) const
LLVM_ABI SDValue getAddrSpaceCast(const SDLoc &dl, EVT VT, SDValue Ptr, unsigned SrcAS, unsigned DestAS)
Return an AddrSpaceCastSDNode.
LLVM_ABI SDValue FoldSetCC(EVT VT, SDValue N1, SDValue N2, ISD::CondCode Cond, const SDLoc &dl, SDNodeFlags Flags={})
Constant fold a setcc to true or false.
bool isKnownNeverSNaN(SDValue Op, const APInt &DemandedElts, unsigned Depth=0) const
LLVM_ABI std::optional< bool > isBoolConstant(SDValue N) const
Check if a value \op N is a constant using the target's BooleanContent for its type.
LLVM_ABI SDValue getStackArgumentTokenFactor(SDValue Chain)
Compute a TokenFactor to force all the incoming stack arguments to be loaded from the stack.
const TargetSubtargetInfo & getSubtarget() const
SDValue getCopyToReg(SDValue Chain, const SDLoc &dl, Register Reg, SDValue N)
const Pass * getPass() const
LLVM_ABI ConstantRange computeConstantRange(SDValue Op, bool ForSigned, unsigned Depth=0) const
Determine the possible constant range of an integer or vector of integers.
LLVM_ABI SDValue getMergeValues(ArrayRef< SDValue > Ops, const SDLoc &dl)
Create a MERGE_VALUES node from the given operands.
LLVM_ABI SDVTList getVTList(EVT VT)
Return an SDVTList that represents the list of values specified.
OptimizationRemarkEmitter & getORE() const
BlockFrequencyInfo * getBFI() const
LLVM_ABI SDValue getShiftAmountConstant(uint64_t Val, EVT VT, const SDLoc &DL)
LLVM_ABI void updateDivergence(SDNode *N)
LLVM_ABI SDValue getSplatValue(SDValue V, bool LegalTypes=false)
If V is a splat vector, return its scalar source operand by extracting that element from the source v...
LLVM_ABI SDValue getAllOnesConstant(const SDLoc &DL, EVT VT, bool IsTarget=false, bool IsOpaque=false)
LLVM_ABI MachineSDNode * getMachineNode(unsigned Opcode, const SDLoc &dl, EVT VT)
These are used for target selectors to create a new node with specified return type(s),...
LLVM_ABI void ExtractVectorElements(SDValue Op, SmallVectorImpl< SDValue > &Args, unsigned Start=0, unsigned Count=0, EVT EltVT=EVT())
Append the extracted elements from Start to Count out of the vector Op in Args.
LLVM_ABI SDValue getAtomicMemset(SDValue Chain, const SDLoc &dl, SDValue Dst, SDValue Value, SDValue Size, Type *SizeTy, unsigned ElemSz, bool isTailCall, MachinePointerInfo DstPtrInfo)
LLVM_ABI SDValue getAtomicLoad(ISD::LoadExtType ExtType, const SDLoc &dl, EVT MemVT, EVT VT, SDValue Chain, SDValue Ptr, MachineMemOperand *MMO)
LLVM_ABI bool LegalizeVectors()
This transforms the SelectionDAG into a SelectionDAG that only uses vector math operations supported ...
LLVM_ABI SDNode * getNodeIfExists(unsigned Opcode, SDVTList VTList, ArrayRef< SDValue > Ops, const SDNodeFlags Flags, bool AllowCommute=false)
Get the specified node if it's already available, or else return NULL.
SDValue getTargetConstantFP(const APFloat &Val, const SDLoc &DL, EVT VT)
LLVM_ABI SDValue getPseudoProbeNode(const SDLoc &Dl, SDValue Chain, uint64_t Guid, uint64_t Index, uint32_t Attr)
Creates a PseudoProbeSDNode with function GUID Guid and the index of the block Index it is probing,...
LLVM_ABI SDValue getFreeze(SDValue V)
Return a freeze using the SDLoc of the value operand.
LLVM_ABI SDNode * SelectNodeTo(SDNode *N, unsigned MachineOpc, EVT VT)
These are used for target selectors to mutate the specified node to have the specified return type,...
LLVM_ABI void init(MachineFunction &NewMF, OptimizationRemarkEmitter &NewORE, Pass *PassPtr, const TargetLibraryInfo *LibraryInfo, const LibcallLoweringInfo *LibcallsInfo, UniformityInfo *UA, ProfileSummaryInfo *PSIin, BlockFrequencyInfo *BFIin, MachineModuleInfo &MMI, FunctionVarLocs const *FnVarLocs)
Prepare this SelectionDAG to process code in the given MachineFunction.
LLVM_ABI SelectionDAG(const TargetMachine &TM, CodeGenOptLevel)
LLVM_ABI SDValue getMemset(SDValue Chain, const SDLoc &dl, SDValue Dst, SDValue Src, SDValue Size, Align Alignment, bool isVol, bool AlwaysInline, const CallInst *CI, MachinePointerInfo DstPtrInfo, const AAMDNodes &AAInfo=AAMDNodes())
LLVM_ABI SDValue getBitcastedSExtOrTrunc(SDValue Op, const SDLoc &DL, EVT VT)
Convert Op, which must be of integer type, to the integer type VT, by first bitcasting (from potentia...
LLVM_ABI SDValue getConstantPool(const Constant *C, EVT VT, MaybeAlign Align=std::nullopt, int Offs=0, bool isT=false, unsigned TargetFlags=0)
LLVM_ABI SDValue getStridedLoadVP(ISD::MemIndexedMode AM, ISD::LoadExtType ExtType, EVT VT, const SDLoc &DL, SDValue Chain, SDValue Ptr, SDValue Offset, SDValue Stride, SDValue Mask, SDValue EVL, EVT MemVT, MachineMemOperand *MMO, bool IsExpanding=false)
SDDbgInfo::DbgIterator ByvalParmDbgEnd() const
LLVM_ABI SDValue getAtomicCmpSwap(unsigned Opcode, const SDLoc &dl, EVT MemVT, SDVTList VTs, SDValue Chain, SDValue Ptr, SDValue Cmp, SDValue Swp, MachineMemOperand *MMO)
Gets a node for an atomic cmpxchg op.
MachineModuleInfo * getMMI() const
LLVM_ABI SDValue makeEquivalentMemoryOrdering(SDValue OldChain, SDValue NewMemOpChain)
If an existing load has uses of its chain, create a token factor node with that chain and the new mem...
LLVM_ABI bool isConstantIntBuildVectorOrConstantInt(SDValue N, bool AllowOpaques=true) const
Test whether the given value is a constant int or similar node.
LLVM_ABI void ReplaceAllUsesOfValuesWith(const SDValue *From, const SDValue *To, unsigned Num)
Like ReplaceAllUsesOfValueWith, but for multiple values at once.
LLVM_ABI SDValue getJumpTableDebugInfo(int JTI, SDValue Chain, const SDLoc &DL)
LLVM_ABI SDValue getSymbolFunctionGlobalAddress(SDValue Op, Function **TargetFunction=nullptr)
Return a GlobalAddress of the function from the current module with name matching the given ExternalS...
bool isSafeToSpeculativelyExecute(unsigned Opcode) const
Some opcodes may create immediate undefined behavior when used with some values (integer division-by-...
void addMMRAMetadata(const SDNode *Node, MDNode *MMRA)
Set MMRAMetadata to be associated with Node.
LLVM_ABI std::optional< unsigned > getValidMaximumShiftAmount(SDValue V, const APInt &DemandedElts, unsigned Depth=0) const
If a SHL/SRA/SRL node V has shift amounts that are all less than the element bit-width of the shift n...
OverflowKind computeOverflowForSub(bool IsSigned, SDValue N0, SDValue N1) const
Determine if the result of the sub of 2 nodes can overflow.
void init(MachineFunction &NewMF, OptimizationRemarkEmitter &NewORE, MachineFunctionAnalysisManager &AM, const TargetLibraryInfo *LibraryInfo, const LibcallLoweringInfo *LibcallsInfo, UniformityInfo *UA, ProfileSummaryInfo *PSIin, BlockFrequencyInfo *BFIin, MachineModuleInfo &MMI, FunctionVarLocs const *FnVarLocs)
LLVM_ABI SDValue UnrollVectorOp(SDNode *N, unsigned ResNE=0)
Utility function used by legalize and lowering to "unroll" a vector operation by splitting out the sc...
SDDbgInfo::DbgIterator ByvalParmDbgBegin() const
LLVM_ABI SDValue getVScale(const SDLoc &DL, EVT VT, APInt MulImm)
Return a node that represents the runtime scaling 'MulImm * RuntimeVL'.
void setFunctionLoweringInfo(FunctionLoweringInfo *FuncInfo)
LLVM_ABI SDValue getConstantFP(double Val, const SDLoc &DL, EVT VT, bool isTarget=false)
Create a ConstantFPSDNode wrapping a constant value.
OverflowKind
Used to represent the possible overflow behavior of an operation.
static LLVM_ABI unsigned getHasPredecessorMaxSteps()
LLVM_ABI bool haveNoCommonBitsSet(SDValue A, SDValue B) const
Return true if A and B have no common bits set.
SDValue getExtractSubvector(const SDLoc &DL, EVT VT, SDValue Vec, unsigned Idx)
Return the VT typed sub-vector of Vec at Idx.
LLVM_ABI bool cannotBeOrderedNegativeFP(SDValue Op) const
Test whether the given float value is known to be positive.
LLVM_ABI SDValue getRegister(Register Reg, EVT VT)
LLVM_ABI bool calculateDivergence(SDNode *N)
LLVM_ABI std::pair< SDValue, SDValue > getStrcmp(SDValue Chain, const SDLoc &dl, SDValue S0, SDValue S1, const CallInst *CI)
Lower a strcmp operation into a target library call and return the resulting chain and call result as...
LLVM_ABI SDValue getGetFPEnv(SDValue Chain, const SDLoc &dl, SDValue Ptr, EVT MemVT, MachineMemOperand *MMO)
LLVM_ABI SDValue getAssertAlign(const SDLoc &DL, SDValue V, Align A)
Return an AssertAlignSDNode.
LLVM_ABI SDNode * mutateStrictFPToFP(SDNode *Node)
Mutate the specified strict FP node to its non-strict equivalent, unlinking the node from its chain a...
LLVM_ABI SDValue getLoad(EVT VT, const SDLoc &dl, SDValue Chain, SDValue Ptr, MachinePointerInfo PtrInfo, MaybeAlign Alignment=MaybeAlign(), MachineMemOperand::Flags MMOFlags=MachineMemOperand::MONone, const AAMDNodes &AAInfo=AAMDNodes(), const MDNode *Ranges=nullptr)
Loads are not normal binary operators: their result type is not determined by their operands,...
LLVM_ABI bool canIgnoreSignBitOfZero(const SDUse &Use) const
Check if a use of a float value is insensitive to signed zeros.
SDValue getGLOBAL_OFFSET_TABLE(EVT VT)
Return a GLOBAL_OFFSET_TABLE node. This does not have a useful SDLoc.
LLVM_ABI bool SignBitIsZeroFP(SDValue Op, unsigned Depth=0) const
Return true if the sign bit of Op is known to be zero, for a floating-point value.
LLVM_ABI SDValue getMemIntrinsicNode(unsigned Opcode, const SDLoc &dl, SDVTList VTList, ArrayRef< SDValue > Ops, EVT MemVT, MachinePointerInfo PtrInfo, Align Alignment, MachineMemOperand::Flags Flags=MachineMemOperand::MOLoad|MachineMemOperand::MOStore, LocationSize Size=LocationSize::precise(0), const AAMDNodes &AAInfo=AAMDNodes())
Creates a MemIntrinsicNode that may produce a result and takes a list of operands.
SDValue getInsertSubvector(const SDLoc &DL, SDValue Vec, SDValue SubVec, unsigned Idx)
Insert SubVec at the Idx element of Vec.
LLVM_ABI SDValue getBitcastedZExtOrTrunc(SDValue Op, const SDLoc &DL, EVT VT)
Convert Op, which must be of integer type, to the integer type VT, by first bitcasting (from potentia...
SelectionDAG(const SelectionDAG &)=delete
LLVM_ABI SDValue getStepVector(const SDLoc &DL, EVT ResVT, const APInt &StepVal)
Returns a vector of type ResVT whose elements contain the linear sequence <0, Step,...
SDValue getSetCC(const SDLoc &DL, EVT VT, SDValue LHS, SDValue RHS, ISD::CondCode Cond, SDValue Chain=SDValue(), bool IsSignaling=false, SDNodeFlags Flags={})
Helper function to make it easier to build SetCC's if you just have an ISD::CondCode instead of an SD...
bool willNotOverflowSub(bool IsSigned, SDValue N0, SDValue N1) const
Determine if the result of the sub of 2 nodes can never overflow.
LLVM_ABI SDValue getAtomic(unsigned Opcode, const SDLoc &dl, EVT MemVT, SDValue Chain, SDValue Ptr, SDValue Val, MachineMemOperand *MMO)
Gets a node for an atomic op, produces result (if relevant) and chain and takes 2 operands.
LLVM_ABI SDValue getMemcpy(SDValue Chain, const SDLoc &dl, SDValue Dst, SDValue Src, SDValue Size, Align Alignment, bool isVol, bool AlwaysInline, const CallInst *CI, std::optional< bool > OverrideTailCall, MachinePointerInfo DstPtrInfo, MachinePointerInfo SrcPtrInfo, const AAMDNodes &AAInfo=AAMDNodes(), BatchAAResults *BatchAA=nullptr)
LLVM_ABI Align getEVTAlign(EVT MemoryVT) const
Compute the default alignment value for the given type.
void addNoMergeSiteInfo(const SDNode *Node, bool NoMerge)
Set NoMergeSiteInfo to be associated with Node if NoMerge is true.
LLVM_ABI bool shouldOptForSize() const
std::pair< SDValue, SDValue > SplitVectorOperand(const SDNode *N, unsigned OpNo)
Split the node's operand with EXTRACT_SUBVECTOR and return the low/high part.
LLVM_ABI SDValue getNOT(const SDLoc &DL, SDValue Val, EVT VT)
Create a bitwise NOT operation as (XOR Val, -1).
LLVM_ABI SDValue getVPZExtOrTrunc(const SDLoc &DL, EVT VT, SDValue Op, SDValue Mask, SDValue EVL)
Convert a vector-predicated Op, which must be an integer vector, to the vector-type VT,...
const STC & getSubtarget() const
SDValue getLoad(ISD::MemIndexedMode AM, ISD::LoadExtType ExtType, EVT VT, const SDLoc &dl, SDValue Chain, SDValue Ptr, SDValue Offset, MachinePointerInfo PtrInfo, EVT MemVT, MaybeAlign Alignment=MaybeAlign(), MachineMemOperand::Flags MMOFlags=MachineMemOperand::MONone, const AAMDNodes &AAInfo=AAMDNodes(), const MDNode *Ranges=nullptr)
const TargetLowering & getTargetLoweringInfo() const
LLVM_ABI bool isEqualTo(SDValue A, SDValue B) const
Test whether two SDValues are known to compare equal.
std::optional< CalledGlobalInfo > getCalledGlobal(const SDNode *Node)
Return CalledGlobal associated with Node, or a nullopt if none exists.
static constexpr unsigned MaxRecursionDepth
LLVM_ABI SDValue getStridedStoreVP(SDValue Chain, const SDLoc &DL, SDValue Val, SDValue Ptr, SDValue Offset, SDValue Stride, SDValue Mask, SDValue EVL, EVT MemVT, MachineMemOperand *MMO, ISD::MemIndexedMode AM, bool IsTruncating=false, bool IsCompressing=false)
bool isGuaranteedNotToBePoison(SDValue Op, unsigned Depth=0) const
Return true if this function can prove that Op is never poison.
LLVM_ABI SDValue getIdentityElement(unsigned Opcode, const SDLoc &DL, EVT VT, SDNodeFlags Flags)
Get the (commutative) identity element for the given opcode, if it exists.
LLVM_ABI SDValue expandVACopy(SDNode *Node)
Expand the specified ISD::VACOPY node as the Legalize pass would.
LLVM_ABI SDValue getIndexedMaskedLoad(SDValue OrigLoad, const SDLoc &dl, SDValue Base, SDValue Offset, ISD::MemIndexedMode AM)
SelectionDAG & operator=(const SelectionDAG &)=delete
SDValue getMemIntrinsicNode(unsigned Opcode, const SDLoc &dl, SDVTList VTList, ArrayRef< SDValue > Ops, EVT MemVT, MachinePointerInfo PtrInfo, MaybeAlign Alignment=std::nullopt, MachineMemOperand::Flags Flags=MachineMemOperand::MOLoad|MachineMemOperand::MOStore, LocationSize Size=LocationSize::precise(0), const AAMDNodes &AAInfo=AAMDNodes())
SDValue getTargetConstant(const APInt &Val, const SDLoc &DL, EVT VT, bool isOpaque=false)
LLVM_ABI APInt computeVectorKnownZeroElements(SDValue Op, const APInt &DemandedElts, unsigned Depth=0) const
For each demanded element of a vector, see if it is known to be zero.
LLVM_ABI void AddDbgValue(SDDbgValue *DB, bool isParameter)
Add a dbg_value SDNode.
bool NewNodesMustHaveLegalTypes
When true, additional steps are taken to ensure that getConstant() and similar functions return DAG n...
LLVM_ABI std::pair< EVT, EVT > GetSplitDestVTs(const EVT &VT) const
Compute the VTs needed for the low/hi parts of a type which is split (or expanded) into two not neces...
MDNode * getHeapAllocSite(const SDNode *Node) const
Return HeapAllocSite associated with Node, or nullptr if none exists.
LLVM_ABI void salvageDebugInfo(SDNode &N)
To be invoked on an SDNode that is slated to be erased.
LLVM_ABI SDNode * MorphNodeTo(SDNode *N, unsigned Opc, SDVTList VTs, ArrayRef< SDValue > Ops)
This mutates the specified node to have the specified return type, opcode, and operands.
SDValue getTargetJumpTable(int JTI, EVT VT, unsigned TargetFlags=0)
MDNode * getMMRAMetadata(const SDNode *Node) const
Return the MMRA MDNode associated with Node, or nullptr if none exists.
SDValue getLoadVP(ISD::MemIndexedMode AM, ISD::LoadExtType ExtType, EVT VT, const SDLoc &dl, SDValue Chain, SDValue Ptr, SDValue Offset, SDValue Mask, SDValue EVL, MachinePointerInfo PtrInfo, EVT MemVT, MaybeAlign Alignment=MaybeAlign(), MachineMemOperand::Flags MMOFlags=MachineMemOperand::MONone, const AAMDNodes &AAInfo=AAMDNodes(), const MDNode *Ranges=nullptr, bool IsExpanding=false)
LLVM_ABI std::pair< SDValue, SDValue > UnrollVectorOverflowOp(SDNode *N, unsigned ResNE=0)
Like UnrollVectorOp(), but for the [US](ADD|SUB|MUL)O family of opcodes.
allnodes_const_iterator allnodes_begin() const
SDValue getUNDEF(EVT VT)
Return an UNDEF node. UNDEF does not have a useful SDLoc.
SDValue getCALLSEQ_END(SDValue Chain, SDValue Op1, SDValue Op2, SDValue InGlue, const SDLoc &DL)
Return a new CALLSEQ_END node, which always must have a glue result (to ensure it's not CSE'd).
LLVM_ABI SDValue getGatherVP(SDVTList VTs, EVT VT, const SDLoc &dl, ArrayRef< SDValue > Ops, MachineMemOperand *MMO, ISD::MemIndexType IndexType)
SDValue getBuildVector(EVT VT, const SDLoc &DL, ArrayRef< SDValue > Ops)
Return an ISD::BUILD_VECTOR node.
LLVM_ABI SDValue getBitcastedAnyExtOrTrunc(SDValue Op, const SDLoc &DL, EVT VT)
Convert Op, which must be of integer type, to the integer type VT, by first bitcasting (from potentia...
allnodes_const_iterator allnodes_end() const
LLVM_ABI bool isSplatValue(SDValue V, const APInt &DemandedElts, APInt &UndefElts, unsigned Depth=0) const
Test whether V has a splatted value for all the demanded elements.
LLVM_ABI void DeleteNode(SDNode *N)
Remove the specified node from the system.
LLVM_ABI SDValue getBitcast(EVT VT, SDValue V)
Return a bitcast using the SDLoc of the value operand, and casting to the provided type.
LLVM_ABI SDDbgValue * getDbgValueList(DIVariable *Var, DIExpression *Expr, ArrayRef< SDDbgOperand > Locs, ArrayRef< SDNode * > Dependencies, bool IsIndirect, const DebugLoc &DL, unsigned O, bool IsVariadic)
Creates a SDDbgValue node from a list of locations.
LLVM_ABI std::pair< SDValue, SDValue > getStrcpy(SDValue Chain, const SDLoc &dl, SDValue Dst, SDValue Src, const CallInst *CI)
Lower a strcpy operation into a target library call and return the resulting chain and call result as...
SDValue getCopyFromReg(SDValue Chain, const SDLoc &dl, Register Reg, EVT VT)
SDValue getSelect(const SDLoc &DL, EVT VT, SDValue Cond, SDValue LHS, SDValue RHS, SDNodeFlags Flags=SDNodeFlags())
Helper function to make it easier to build Select's if you just have operands and don't want to check...
SDDbgInfo::DbgIterator DbgEnd() const
LLVM_ABI SDValue getNegative(SDValue Val, const SDLoc &DL, EVT VT)
Create negative operation as (SUB 0, Val).
LLVM_ABI std::optional< unsigned > getValidShiftAmount(SDValue V, const APInt &DemandedElts, unsigned Depth=0) const
If a SHL/SRA/SRL node V has a uniform shift amount that is less than the element bit-width of the shi...
LLVM_ABI void setNodeMemRefs(MachineSDNode *N, ArrayRef< MachineMemOperand * > NewMemRefs)
Mutate the specified machine node's memory references to the provided list.
LLVM_ABI SDValue simplifySelect(SDValue Cond, SDValue TVal, SDValue FVal)
Try to simplify a select/vselect into 1 of its operands or a constant.
CallSiteInfo getCallSiteInfo(const SDNode *Node)
Return CallSiteInfo associated with Node, or a default if none exists.
LLVM_ABI SDValue getZeroExtendInReg(SDValue Op, const SDLoc &DL, EVT VT)
Return the expression required to zero extend the Op value assuming it was the smaller SrcTy value.
LLVM_ABI bool isConstantFPBuildVectorOrConstantFP(SDValue N) const
Test whether the given value is a constant FP or similar node.
const DataLayout & getDataLayout() const
allnodes_iterator allnodes_begin()
SDValue getPartialReduceMLS(unsigned Opc, const SDLoc &DL, SDValue Acc, SDValue LHS, SDValue RHS)
Get an expression that implements a partial multiply-subtract reduction.
iterator_range< allnodes_const_iterator > allnodes() const
MDNode * getPCSections(const SDNode *Node) const
Return PCSections associated with Node, or nullptr if none exists.
ProfileSummaryInfo * getPSI() const
LLVM_ABI SDValue expandVAArg(SDNode *Node)
Expand the specified ISD::VAARG node as the Legalize pass would.
SDValue getTargetFrameIndex(int FI, EVT VT)
LLVM_ABI void Legalize()
This transforms the SelectionDAG into a SelectionDAG that is compatible with the target instruction s...
LLVM_ABI SDValue getTokenFactor(const SDLoc &DL, SmallVectorImpl< SDValue > &Vals)
Creates a new TokenFactor containing Vals.
LLVM_ABI void setGraphAttrs(const SDNode *N, const char *Attrs)
Set graph attributes for a node. (eg. "color=red".)
SDValue getCopyToReg(SDValue Chain, const SDLoc &dl, SDValue Reg, SDValue N, SDValue Glue)
LLVM_ABI bool LegalizeOp(SDNode *N, SmallSetVector< SDNode *, 16 > &UpdatedNodes)
Transforms a SelectionDAG node and any operands to it into a node that is compatible with the target ...
LLVM_ABI bool doesNodeExist(unsigned Opcode, SDVTList VTList, ArrayRef< SDValue > Ops)
Check if a node exists without modifying its flags.
LLVM_ABI ConstantRange computeConstantRangeIncludingKnownBits(SDValue Op, bool ForSigned, unsigned Depth=0) const
Combine constant ranges from computeConstantRange() and computeKnownBits().
void addHeapAllocSite(const SDNode *Node, MDNode *MD)
Set HeapAllocSite to be associated with Node.
const SelectionDAGTargetInfo & getSelectionDAGInfo() const
LLVM_ABI bool areNonVolatileConsecutiveLoads(LoadSDNode *LD, LoadSDNode *Base, unsigned Bytes, int Dist) const
Return true if loads are next to each other and can be merged.
LLVM_ABI SDValue getMaskedHistogram(SDVTList VTs, EVT MemVT, const SDLoc &dl, ArrayRef< SDValue > Ops, MachineMemOperand *MMO, ISD::MemIndexType IndexType)
LLVM_ABI SDDbgLabel * getDbgLabel(DILabel *Label, const DebugLoc &DL, unsigned O)
Creates a SDDbgLabel node.
SDValue getTargetConstant(const ConstantInt &Val, const SDLoc &DL, EVT VT, bool isOpaque=false)
LLVM_ABI SDValue getStoreVP(SDValue Chain, const SDLoc &dl, SDValue Val, SDValue Ptr, SDValue Offset, SDValue Mask, SDValue EVL, EVT MemVT, MachineMemOperand *MMO, ISD::MemIndexedMode AM, bool IsTruncating=false, bool IsCompressing=false)
std::pair< SDValue, SDValue > SplitVector(const SDValue &N, const SDLoc &DL)
Split the vector with EXTRACT_SUBVECTOR and return the low/high part.
LLVM_ABI OverflowKind computeOverflowForUnsignedMul(SDValue N0, SDValue N1) const
Determine if the result of the unsigned mul of 2 nodes can overflow.
SDValue getCopyToReg(SDValue Chain, const SDLoc &dl, Register Reg, SDValue N, SDValue Glue)
LLVM_ABI void copyExtraInfo(SDNode *From, SDNode *To)
Copy extra info associated with one node to another.
LLVM_ABI SDValue getConstant(uint64_t Val, const SDLoc &DL, EVT VT, bool isTarget=false, bool isOpaque=false)
Create a ConstantSDNode wrapping a constant value.
LLVM_ABI void setGraphColor(const SDNode *N, const char *Color)
Convenience for setting node color attribute.
SDValue getStore(SDValue Chain, const SDLoc &dl, SDValue Val, SDValue Ptr, MachinePointerInfo PtrInfo, MaybeAlign Alignment=MaybeAlign(), MachineMemOperand::Flags MMOFlags=MachineMemOperand::MONone, const AAMDNodes &AAInfo=AAMDNodes())
LLVM_ABI SDValue getMemBasePlusOffset(SDValue Base, TypeSize Offset, const SDLoc &DL, const SDNodeFlags Flags=SDNodeFlags())
Returns sum of the base pointer and offset.
LLVM_ABI SDValue getGlobalAddress(const GlobalValue *GV, const SDLoc &DL, EVT VT, int64_t offset=0, bool isTargetGA=false, unsigned TargetFlags=0)
bool willNotOverflowMul(bool IsSigned, SDValue N0, SDValue N1) const
Determine if the result of the mul of 2 nodes can never overflow.
SDValue getSignedTargetConstant(int64_t Val, const SDLoc &DL, EVT VT, bool isOpaque=false)
LLVM_ABI SDValue getVAArg(EVT VT, const SDLoc &dl, SDValue Chain, SDValue Ptr, SDValue SV, unsigned Align)
VAArg produces a result and token chain, and takes a pointer and a source value as input.
OverflowKind computeOverflowForMul(bool IsSigned, SDValue N0, SDValue N1) const
Determine if the result of the mul of 2 nodes can overflow.
LLVM_ABI SDValue getTruncStore(SDValue Chain, const SDLoc &dl, SDValue Val, SDValue Ptr, MachinePointerInfo PtrInfo, EVT SVT, Align Alignment, MachineMemOperand::Flags MMOFlags=MachineMemOperand::MONone, const AAMDNodes &AAInfo=AAMDNodes())
LLVM_ABI SDValue getLoadFFVP(EVT VT, const SDLoc &DL, SDValue Chain, SDValue Ptr, SDValue Mask, SDValue EVL, MachineMemOperand *MMO)
LLVM_ABI SDValue getTypeSize(const SDLoc &DL, EVT VT, TypeSize TS)
LLVM_ABI SDValue getMDNode(const MDNode *MD)
Return an MDNodeSDNode which holds an MDNode.
LLVM_ABI void clear()
Clear state and free memory necessary to make this SelectionDAG ready to process a new block.
SDValue getCALLSEQ_END(SDValue Chain, uint64_t Size1, uint64_t Size2, SDValue Glue, const SDLoc &DL)
LLVM_ABI std::pair< SDValue, SDValue > getMemcmp(SDValue Chain, const SDLoc &dl, SDValue Dst, SDValue Src, SDValue Size, const CallInst *CI)
Lower a memcmp operation into a target library call and return the resulting chain and call result as...
LLVM_ABI void ReplaceAllUsesWith(SDValue From, SDValue To)
Modify anything using 'From' to use 'To' instead.
LLVM_ABI SDValue getCommutedVectorShuffle(const ShuffleVectorSDNode &SV)
Returns an ISD::VECTOR_SHUFFLE node semantically equivalent to the shuffle node in input but with swa...
LLVM_ABI std::pair< SDValue, SDValue > SplitVector(const SDValue &N, const SDLoc &DL, const EVT &LoVT, const EVT &HiVT)
Split the vector with EXTRACT_SUBVECTOR using the provided VTs and return the low/high part.
LLVM_ABI SDValue makeStateFunctionCall(unsigned LibFunc, SDValue Ptr, SDValue InChain, const SDLoc &DLoc)
Helper used to make a call to a library function that has one argument of pointer type.
LLVM_ABI SDValue getStore(SDValue Chain, const SDLoc &dl, SDValue Val, SDValue Ptr, MachinePointerInfo PtrInfo, Align Alignment, MachineMemOperand::Flags MMOFlags=MachineMemOperand::MONone, const AAMDNodes &AAInfo=AAMDNodes())
Helper function to build ISD::STORE nodes.
LLVM_ABI SDValue getSignedConstant(int64_t Val, const SDLoc &DL, EVT VT, bool isTarget=false, bool isOpaque=false)
LLVM_ABI SDValue getIndexedLoadVP(SDValue OrigLoad, const SDLoc &dl, SDValue Base, SDValue Offset, ISD::MemIndexedMode AM)
LLVM_ABI SDValue getSrcValue(const Value *v)
Construct a node to track a Value* through the backend.
SDValue getSplatVector(EVT VT, const SDLoc &DL, SDValue Op)
LLVM_ABI SDValue getAtomicMemcpy(SDValue Chain, const SDLoc &dl, SDValue Dst, SDValue Src, SDValue Size, Type *SizeTy, unsigned ElemSz, bool isTailCall, MachinePointerInfo DstPtrInfo, MachinePointerInfo SrcPtrInfo)
LLVM_ABI OverflowKind computeOverflowForSignedMul(SDValue N0, SDValue N1) const
Determine if the result of the signed mul of 2 nodes can overflow.
LLVM_ABI MaybeAlign InferPtrAlign(SDValue Ptr) const
Infer alignment of a load / store address.
LLVM_ABI void dump() const
Dump the textual format of this DAG.
FlagInserter * getFlagInserter()
LLVM_ABI bool MaskedValueIsAllOnes(SDValue Op, const APInt &Mask, unsigned Depth=0) const
Return true if '(Op & Mask) == Mask'.
SDValue getCALLSEQ_START(SDValue Chain, uint64_t InSize, uint64_t OutSize, const SDLoc &DL)
Return a new CALLSEQ_START node, that starts new call frame, in which InSize bytes are set up inside ...
bool hasDebugValues() const
Return true if there are any SDDbgValue nodes associated with this SelectionDAG.
LLVM_ABI bool SignBitIsZero(SDValue Op, unsigned Depth=0) const
Return true if the sign bit of Op is known to be zero.
LLVM_ABI void RemoveDeadNodes()
This method deletes all unreachable nodes in the SelectionDAG.
LLVM_ABI void RemoveDeadNode(SDNode *N)
Remove the specified node from the system.
SDValue getBuildVector(EVT VT, const SDLoc &DL, ArrayRef< SDUse > Ops)
Return an ISD::BUILD_VECTOR node.
LLVM_ABI void AddDbgLabel(SDDbgLabel *DB)
Add a dbg_label SDNode.
bool isConstantValueOfAnyType(SDValue N) const
SDDbgInfo::DbgLabelIterator DbgLabelEnd() const
SDValue getTruncStore(SDValue Chain, const SDLoc &dl, SDValue Val, SDValue Ptr, MachinePointerInfo PtrInfo, EVT SVT, MaybeAlign Alignment=MaybeAlign(), MachineMemOperand::Flags MMOFlags=MachineMemOperand::MONone, const AAMDNodes &AAInfo=AAMDNodes())
allnodes_iterator allnodes_end()
SDDbgInfo::DbgLabelIterator DbgLabelBegin() const
LLVM_ABI bool canCreateUndefOrPoison(SDValue Op, const APInt &DemandedElts, UndefPoisonKind Kind=UndefPoisonKind::UndefOrPoison, bool ConsiderFlags=true, unsigned Depth=0) const
Return true if Op can create undef or poison from non-undef & non-poison operands.
SDValue getInsertVectorElt(const SDLoc &DL, SDValue Vec, SDValue Elt, unsigned Idx)
Insert Elt into Vec at offset Idx.
LLVM_ABI SDValue getTargetExtractSubreg(int SRIdx, const SDLoc &DL, EVT VT, SDValue Operand)
A convenience function for creating TargetInstrInfo::EXTRACT_SUBREG nodes.
LLVM_ABI SDValue getBasicBlock(MachineBasicBlock *MBB)
SDValue getSelectCC(const SDLoc &DL, SDValue LHS, SDValue RHS, SDValue True, SDValue False, ISD::CondCode Cond, SDNodeFlags Flags=SDNodeFlags())
Helper function to make it easier to build SelectCC's if you just have an ISD::CondCode instead of an...
MachineFunctionAnalysisManager * getMFAM()
LLVM_ABI SDValue getSExtOrTrunc(SDValue Op, const SDLoc &DL, EVT VT)
Convert Op, which must be of integer type, to the integer type VT, by either sign-extending or trunca...
LLVM_ABI SDDbgValue * getVRegDbgValue(DIVariable *Var, DIExpression *Expr, Register VReg, bool IsIndirect, const DebugLoc &DL, unsigned O)
Creates a VReg SDDbgValue node.
LLVM_ABI KnownFPClass computeKnownFPClass(SDValue Op, FPClassTest InterestedClasses, unsigned Depth=0) const
Determine floating-point class information about Op.
LLVM_ABI bool isIdentityElement(unsigned Opc, SDNodeFlags Flags, SDValue V, unsigned OperandNo, unsigned Depth=0) const
Returns true if V is an identity element of Opc with Flags.
LLVM_ABI SDValue getEHLabel(const SDLoc &dl, SDValue Root, MCSymbol *Label)
LLVM_ABI std::string getGraphAttrs(const SDNode *N) const
Get graph attributes for a node.
LLVM_ABI SDValue getIndexedStoreVP(SDValue OrigStore, const SDLoc &dl, SDValue Base, SDValue Offset, ISD::MemIndexedMode AM)
LLVM_ABI bool isGuaranteedNotToBeUndefOrPoison(SDValue Op, UndefPoisonKind Kind=UndefPoisonKind::UndefOrPoison, unsigned Depth=0) const
Return true if this function can prove that Op is never poison and, Kind can be used to track poison ...
LLVM_ABI bool isKnownNeverZero(SDValue Op, unsigned Depth=0) const
Test whether the given SDValue is known to contain non-zero value(s).
LLVM_ABI SDValue getIndexedStore(SDValue OrigStore, const SDLoc &dl, SDValue Base, SDValue Offset, ISD::MemIndexedMode AM)
LLVM_ABI SDValue FoldConstantArithmetic(unsigned Opcode, const SDLoc &DL, EVT VT, ArrayRef< SDValue > Ops, SDNodeFlags Flags=SDNodeFlags())
LLVM_ABI std::optional< unsigned > getValidMinimumShiftAmount(SDValue V, const APInt &DemandedElts, unsigned Depth=0) const
If a SHL/SRA/SRL node V has shift amounts that are all less than the element bit-width of the shift n...
LLVM_ABI SDValue getSetFPEnv(SDValue Chain, const SDLoc &dl, SDValue Ptr, EVT MemVT, MachineMemOperand *MMO)
LLVM_ABI SDValue getBoolExtOrTrunc(SDValue Op, const SDLoc &SL, EVT VT, EVT OpVT)
Convert Op, which must be of integer type, to the integer type VT, by using an extension appropriate ...
LLVM_ABI SDValue getMaskedStore(SDValue Chain, const SDLoc &dl, SDValue Val, SDValue Base, SDValue Offset, SDValue Mask, EVT MemVT, MachineMemOperand *MMO, ISD::MemIndexedMode AM, bool IsTruncating=false, bool IsCompressing=false)
LLVM_ABI SDValue getExternalSymbol(const char *Sym, EVT VT)
const TargetMachine & getTarget() const
bool getNoMergeSiteInfo(const SDNode *Node) const
Return NoMerge info associated with Node.
LLVM_ABI std::pair< SDValue, SDValue > getStrictFPExtendOrRound(SDValue Op, SDValue Chain, const SDLoc &DL, EVT VT)
Convert Op, which must be a STRICT operation of float type, to the float type VT, by either extending...
SDValue getObjectPtrOffset(const SDLoc &SL, SDValue Ptr, SDValue Offset)
LLVM_ABI std::pair< SDValue, SDValue > SplitEVL(SDValue N, EVT VecVT, const SDLoc &DL)
Split the explicit vector length parameter of a VP operation.
LLVM_ABI SDValue getPtrExtOrTrunc(SDValue Op, const SDLoc &DL, EVT VT)
Convert Op, which must be of integer type, to the integer type VT, by either truncating it or perform...
LLVM_ABI SDValue getVPLogicalNOT(const SDLoc &DL, SDValue Val, SDValue Mask, SDValue EVL, EVT VT)
Create a vector-predicated logical NOT operation as (VP_XOR Val, BooleanOne, Mask,...
LLVM_ABI SDValue getMaskFromElementCount(const SDLoc &DL, EVT VT, ElementCount Len)
Return a vector with the first 'Len' lanes set to true and remaining lanes set to false.
SDDbgInfo::DbgIterator DbgBegin() const
LLVM_ABI SDValue getAnyExtOrTrunc(SDValue Op, const SDLoc &DL, EVT VT)
Convert Op, which must be of integer type, to the integer type VT, by either any-extending or truncat...
iterator_range< allnodes_iterator > allnodes()
OverflowKind computeOverflowForAdd(bool IsSigned, SDValue N0, SDValue N1) const
Determine if the result of the addition of 2 nodes can overflow.
LLVM_ABI SDValue getBlockAddress(const BlockAddress *BA, EVT VT, int64_t Offset=0, bool isTarget=false, unsigned TargetFlags=0)
LLVM_ABI SDValue WidenVector(const SDValue &N, const SDLoc &DL)
Widen the vector up to the next power of two using INSERT_SUBVECTOR.
const LibcallLoweringInfo & getLibcalls() const
LLVM_ABI SDValue getLoadVP(ISD::MemIndexedMode AM, ISD::LoadExtType ExtType, EVT VT, const SDLoc &dl, SDValue Chain, SDValue Ptr, SDValue Offset, SDValue Mask, SDValue EVL, MachinePointerInfo PtrInfo, EVT MemVT, Align Alignment, MachineMemOperand::Flags MMOFlags, const AAMDNodes &AAInfo, const MDNode *Ranges=nullptr, bool IsExpanding=false)
LLVM_ABI SDValue getIntPtrConstant(uint64_t Val, const SDLoc &DL, bool isTarget=false)
LLVM_ABI SDDbgValue * getConstantDbgValue(DIVariable *Var, DIExpression *Expr, const Value *C, const DebugLoc &DL, unsigned O)
Creates a constant SDDbgValue node.
LLVM_ABI SDValue getScatterVP(SDVTList VTs, EVT VT, const SDLoc &dl, ArrayRef< SDValue > Ops, MachineMemOperand *MMO, ISD::MemIndexType IndexType)
LLVM_ABI SDValue getValueType(EVT)
SDValue getTargetConstantFP(double Val, const SDLoc &DL, EVT VT)
LLVM_ABI SDValue getLifetimeNode(bool IsStart, const SDLoc &dl, SDValue Chain, int FrameIndex)
Creates a LifetimeSDNode that starts (IsStart==true) or ends (IsStart==false) the lifetime of the Fra...
ArrayRef< SDDbgValue * > GetDbgValues(const SDNode *SD) const
Get the debug values which reference the given SDNode.
LLVM_ABI SDValue getNode(unsigned Opcode, const SDLoc &DL, EVT VT, ArrayRef< SDUse > Ops)
Gets or creates the specified node.
LLVM_ABI OverflowKind computeOverflowForSignedAdd(SDValue N0, SDValue N1) const
Determine if the result of the signed addition of 2 nodes can overflow.
LLVM_ABI SDValue getFPExtendOrRound(SDValue Op, const SDLoc &DL, EVT VT)
Convert Op, which must be of float type, to the float type VT, by either extending or rounding (by tr...
LLVM_ABI unsigned AssignTopologicalOrder()
Topological-sort the AllNodes list and a assign a unique node id for each node in the DAG based on th...
ilist< SDNode >::size_type allnodes_size() const
LLVM_ABI bool isKnownNeverNaN(SDValue Op, const APInt &DemandedElts, bool SNaN=false, unsigned Depth=0) const
Test whether the given SDValue (or all elements of it, if it is a vector) is known to never be NaN in...
LLVM_ABI SDValue FoldConstantBuildVector(BuildVectorSDNode *BV, const SDLoc &DL, EVT DstEltVT)
Fold BUILD_VECTOR of constants/undefs to the destination type BUILD_VECTOR of constants/undefs elemen...
ilist< SDNode >::const_iterator allnodes_const_iterator
LLVM_ABI SDValue getAtomicMemmove(SDValue Chain, const SDLoc &dl, SDValue Dst, SDValue Src, SDValue Size, Type *SizeTy, unsigned ElemSz, bool isTailCall, MachinePointerInfo DstPtrInfo, MachinePointerInfo SrcPtrInfo)
LLVM_ABI SDValue getIndexedMaskedStore(SDValue OrigStore, const SDLoc &dl, SDValue Base, SDValue Offset, ISD::MemIndexedMode AM)
LLVM_ABI SDValue getTruncStoreVP(SDValue Chain, const SDLoc &dl, SDValue Val, SDValue Ptr, SDValue Mask, SDValue EVL, MachinePointerInfo PtrInfo, EVT SVT, Align Alignment, MachineMemOperand::Flags MMOFlags, const AAMDNodes &AAInfo, bool IsCompressing=false)
SDValue getTargetConstant(uint64_t Val, const SDLoc &DL, EVT VT, bool isOpaque=false)
const TargetLibraryInfo & getLibInfo() const
LLVM_ABI unsigned ComputeNumSignBits(SDValue Op, unsigned Depth=0) const
Return the number of times the sign bit of the register is replicated into the other bits.
void addCalledGlobal(const SDNode *Node, const GlobalValue *GV, unsigned OpFlags)
Set CalledGlobal to be associated with Node.
LLVM_ABI bool MaskedVectorIsZero(SDValue Op, const APInt &DemandedElts, unsigned Depth=0) const
Return true if 'Op' is known to be zero in DemandedElts.
LLVM_ABI SDValue getBoolConstant(bool V, const SDLoc &DL, EVT VT, EVT OpVT)
Create a true or false constant of type VT using the target's BooleanContent for type OpVT.
SDValue getTargetBlockAddress(const BlockAddress *BA, EVT VT, int64_t Offset=0, unsigned TargetFlags=0)
LLVM_ABI SDDbgValue * getFrameIndexDbgValue(DIVariable *Var, DIExpression *Expr, unsigned FI, bool IsIndirect, const DebugLoc &DL, unsigned O)
Creates a FrameIndex SDDbgValue node.
const UniformityInfo * getUniformityInfo() const
LLVM_ABI SDValue getExtStridedLoadVP(ISD::LoadExtType ExtType, const SDLoc &DL, EVT VT, SDValue Chain, SDValue Ptr, SDValue Stride, SDValue Mask, SDValue EVL, EVT MemVT, MachineMemOperand *MMO, bool IsExpanding=false)
CodeGenOptLevel getOptLevel() const
LLVM_ABI SDValue getMemmove(SDValue Chain, const SDLoc &dl, SDValue Dst, SDValue Src, SDValue Size, Align Alignment, bool isVol, const CallInst *CI, std::optional< bool > OverrideTailCall, MachinePointerInfo DstPtrInfo, MachinePointerInfo SrcPtrInfo, const AAMDNodes &AAInfo=AAMDNodes(), BatchAAResults *BatchAA=nullptr)
LLVM_ABI SDValue getJumpTable(int JTI, EVT VT, bool isTarget=false, unsigned TargetFlags=0)
LLVM_ABI bool isBaseWithConstantOffset(SDValue Op) const
Return true if the specified operand is an ISD::ADD with a ConstantSDNode on the right-hand side,...
LLVM_ABI SDValue getVPPtrExtOrTrunc(const SDLoc &DL, EVT VT, SDValue Op, SDValue Mask, SDValue EVL)
Convert a vector-predicated Op, which must be of integer type, to the vector-type integer type VT,...
LLVM_ABI SDValue getVectorIdxConstant(uint64_t Val, const SDLoc &DL, bool isTarget=false)
LLVM_ABI void getTopologicallyOrderedNodes(SmallVectorImpl< const SDNode * > &SortedNodes) const
Get all the nodes in their topological order without modifying any states.
LLVM_ABI void ReplaceAllUsesOfValueWith(SDValue From, SDValue To)
Replace any uses of From with To, leaving uses of other values produced by From.getNode() alone.
MachineFunction & getMachineFunction() const
LLVM_ABI std::pair< SDValue, SDValue > getStrstr(SDValue Chain, const SDLoc &dl, SDValue S0, SDValue S1, const CallInst *CI)
Lower a strstr operation into a target library call and return the resulting chain and call result as...
LLVM_ABI SDValue getPtrExtendInReg(SDValue Op, const SDLoc &DL, EVT VT)
Return the expression required to extend the Op as a pointer value assuming it was the smaller SrcTy ...
LLVM_ABI OverflowKind computeOverflowForUnsignedAdd(SDValue N0, SDValue N1) const
Determine if the result of the unsigned addition of 2 nodes can overflow.
SDValue getPOISON(EVT VT)
Return a POISON node. POISON does not have a useful SDLoc.
void setFlagInserter(FlagInserter *FI)
SDValue getSplatBuildVector(EVT VT, const SDLoc &DL, SDValue Op)
Return a splat ISD::BUILD_VECTOR node, consisting of Op splatted to all elements.
bool isSafeToSpeculativelyExecuteNode(const SDNode *N) const
Check if the provided node is save to speculatively executed given its current arguments.
LLVM_ABI SDValue getFrameIndex(int FI, EVT VT, bool isTarget=false)
LLVM_ABI SDValue getTruncStridedStoreVP(SDValue Chain, const SDLoc &DL, SDValue Val, SDValue Ptr, SDValue Stride, SDValue Mask, SDValue EVL, EVT SVT, MachineMemOperand *MMO, bool IsCompressing=false)
const FunctionVarLocs * getFunctionVarLocs() const
Returns the result of the AssignmentTrackingAnalysis pass if it's available, otherwise return nullptr...
LLVM_ABI void canonicalizeCommutativeBinop(unsigned Opcode, SDValue &N1, SDValue &N2) const
Swap N1 and N2 if Opcode is a commutative binary opcode and the canonical form expects the opposite o...
LLVM_ABI KnownBits computeKnownBits(SDValue Op, unsigned Depth=0) const
Determine which bits of Op are known to be either zero or one and return them in Known.
LLVM_ABI SDValue getRegisterMask(const uint32_t *RegMask)
LLVM_ABI SDValue getZExtOrTrunc(SDValue Op, const SDLoc &DL, EVT VT)
Convert Op, which must be of integer type, to the integer type VT, by either zero-extending or trunca...
LLVM_ABI SDValue getCondCode(ISD::CondCode Cond)
void addCallSiteInfo(const SDNode *Node, CallSiteInfo &&CallInfo)
Set CallSiteInfo to be associated with Node.
SDValue getExtOrTrunc(bool IsSigned, SDValue Op, const SDLoc &DL, EVT VT)
Convert Op, which must be of integer type, to the integer type VT, by either sign/zero-extending (dep...
LLVM_ABI bool MaskedValueIsZero(SDValue Op, const APInt &Mask, unsigned Depth=0) const
Return true if 'Op & Mask' is known to be zero.
LLVM_ABI bool isKnownToBeAPowerOfTwoFP(SDValue Val, unsigned Depth=0) const
Test if the given fp value is known to be an integer power-of-2, either positive or negative.
LLVM_ABI OverflowKind computeOverflowForSignedSub(SDValue N0, SDValue N1) const
Determine if the result of the signed sub of 2 nodes can overflow.
SDValue getObjectPtrOffset(const SDLoc &SL, SDValue Ptr, TypeSize Offset)
Create an add instruction with appropriate flags when used for addressing some offset of an object.
LLVMContext * getContext() const
LLVM_ABI SDValue simplifyFPBinop(unsigned Opcode, SDValue X, SDValue Y, SDNodeFlags Flags)
Try to simplify a floating-point binary operation into 1 of its operands or a constant.
const SDValue & setRoot(SDValue N)
Set the current root tag of the SelectionDAG.
void addPCSections(const SDNode *Node, MDNode *MD)
Set PCSections to be associated with Node.
LLVM_ABI bool isKnownToBeAPowerOfTwo(SDValue Val, bool OrZero=false, unsigned Depth=0) const
Test if the given value is known to have exactly one bit set.
bool isGuaranteedNotToBePoison(SDValue Op, const APInt &DemandedElts, unsigned Depth=0) const
Return true if this function can prove that Op is never poison.
SDValue getTargetConstantPool(MachineConstantPoolValue *C, EVT VT, MaybeAlign Align=std::nullopt, int Offset=0, unsigned TargetFlags=0)
LLVM_ABI SDValue getDeactivationSymbol(const GlobalValue *GV)
LLVM_ABI void clearGraphAttrs()
Clear all previously defined node graph attributes.
LLVM_ABI SDValue getTargetExternalSymbol(const char *Sym, EVT VT, unsigned TargetFlags=0)
LLVM_ABI SDValue getMCSymbol(MCSymbol *Sym, EVT VT)
LLVM_ABI bool isUndef(unsigned Opcode, ArrayRef< SDValue > Ops)
Return true if the result of this operation is always undefined.
SDValue getSetCCVP(const SDLoc &DL, EVT VT, SDValue LHS, SDValue RHS, ISD::CondCode Cond, SDValue Mask, SDValue EVL)
Helper function to make it easier to build VP_SETCCs if you just have an ISD::CondCode instead of an ...
LLVM_ABI SDValue CreateStackTemporary(TypeSize Bytes, Align Alignment)
Create a stack temporary based on the size in bytes and the alignment.
LLVM_ABI SDNode * UpdateNodeOperands(SDNode *N, SDValue Op)
Mutate the specified node in-place to have the specified operands.
LLVM_ABI std::pair< EVT, EVT > GetDependentSplitDestVTs(const EVT &VT, const EVT &EnvVT, bool *HiIsEmpty) const
Compute the VTs needed for the low/hi parts of a type, dependent on an enveloping VT that has been sp...
LLVM_ABI SDValue foldConstantFPMath(unsigned Opcode, const SDLoc &DL, EVT VT, ArrayRef< SDValue > Ops)
Fold floating-point operations when all operands are constants and/or undefined.
SDValue getTargetConstantPool(const Constant *C, EVT VT, MaybeAlign Align=std::nullopt, int Offset=0, unsigned TargetFlags=0)
LLVM_ABI std::optional< ConstantRange > getValidShiftAmountRange(SDValue V, const APInt &DemandedElts, unsigned Depth) const
If a SHL/SRA/SRL node V has shift amounts that are all less than the element bit-width of the shift n...
LLVM_ABI SDValue FoldSymbolOffset(unsigned Opcode, EVT VT, const GlobalAddressSDNode *GA, const SDNode *N2)
void RepositionNode(allnodes_iterator Position, SDNode *N)
Move node N in the AllNodes list to be immediately before the given iterator Position.
LLVM_ABI SDValue getIndexedLoad(SDValue OrigLoad, const SDLoc &dl, SDValue Base, SDValue Offset, ISD::MemIndexedMode AM)
LLVM_ABI SDValue getTargetInsertSubreg(int SRIdx, const SDLoc &DL, EVT VT, SDValue Operand, SDValue Subreg)
A convenience function for creating TargetInstrInfo::INSERT_SUBREG nodes.
SDValue getEntryNode() const
Return the token chain corresponding to the entry of the function.
LLVM_ABI SDDbgValue * getDbgValue(DIVariable *Var, DIExpression *Expr, SDNode *N, unsigned R, bool IsIndirect, const DebugLoc &DL, unsigned O)
Creates a SDDbgValue node.
LLVM_ABI void setSubgraphColor(SDNode *N, const char *Color)
Convenience for setting subgraph color attribute.
LLVM_ABI SDValue getMaskedLoad(EVT VT, const SDLoc &dl, SDValue Chain, SDValue Base, SDValue Offset, SDValue Mask, SDValue Src0, EVT MemVT, MachineMemOperand *MMO, ISD::MemIndexedMode AM, ISD::LoadExtType, bool IsExpanding=false)
SDValue getTargetConstantFP(const ConstantFP &Val, const SDLoc &DL, EVT VT)
DenormalMode getDenormalMode(EVT VT) const
Return the current function's default denormal handling kind for the given floating point type.
SDValue getSplat(EVT VT, const SDLoc &DL, SDValue Op)
Returns a node representing a splat of one value into all lanes of the provided vector type.
LLVM_ABI std::pair< SDValue, SDValue > SplitScalar(const SDValue &N, const SDLoc &DL, const EVT &LoVT, const EVT &HiVT)
Split the scalar node with EXTRACT_ELEMENT using the provided VTs and return the low/high part.
static unsigned getOpcode_EXTEND(unsigned Opcode)
Convert *_EXTEND_VECTOR_INREG to *_EXTEND opcode.
LLVM_ABI SDValue matchBinOpReduction(SDNode *Extract, ISD::NodeType &BinOp, ArrayRef< ISD::NodeType > CandidateBinOps, bool AllowPartials=false)
Match a binop + shuffle pyramid that represents a horizontal reduction over the elements of a vector ...
LLVM_ABI bool isADDLike(SDValue Op, bool NoWrap=false) const
Return true if the specified operand is an ISD::OR or ISD::XOR node that can be treated as an ISD::AD...
LLVM_ABI SDValue getVectorShuffle(EVT VT, const SDLoc &dl, SDValue N1, SDValue N2, ArrayRef< int > Mask)
Return an ISD::VECTOR_SHUFFLE node.
LLVM_DUMP_METHOD void dumpDotGraph(const Twine &FileName, const Twine &Title)
Just dump dot graph to a user-provided path and title.
LLVM_ABI SDValue simplifyShift(SDValue X, SDValue Y)
Try to simplify a shift into 1 of its operands or a constant.
LLVM_ABI void transferDbgValues(SDValue From, SDValue To, unsigned OffsetInBits=0, unsigned SizeInBits=0, bool InvalidateDbg=true)
Transfer debug values from one node to another, while optionally generating fragment expressions for ...
LLVM_ABI SDValue getLogicalNOT(const SDLoc &DL, SDValue Val, EVT VT)
Create a logical NOT operation as (XOR Val, BooleanOne).
LLVM_ABI SDValue getMaskedScatter(SDVTList VTs, EVT MemVT, const SDLoc &dl, ArrayRef< SDValue > Ops, MachineMemOperand *MMO, ISD::MemIndexType IndexType, bool IsTruncating=false)
ilist< SDNode >::iterator allnodes_iterator
LLVM_ABI bool LegalizeTypes()
This transforms the SelectionDAG into a SelectionDAG that only uses types natively supported by the t...
This SDNode is used to implement the code generator support for the llvm IR shufflevector instruction...
A SetVector that performs no allocations if smaller than a certain size.
Definition SetVector.h:339
This class consists of common code factored out of the SmallVector class to reduce code duplication b...
typename SuperClass::iterator iterator
This is a 'vector' (really, a variable-sized array), optimized for the case when the array is small.
StringMap - This is an unconventional map that is specialized for handling keys that are "strings",...
Definition StringMap.h:133
Provides information about what library functions are available for the current target.
This class defines information used to lower LLVM code to legal SelectionDAG operators that the targe...
Primary interface to the complete machine description for the target machine.
TargetSubtargetInfo - Generic base class for all target subtargets.
Twine - A lightweight data structure for efficiently representing the concatenation of temporary valu...
Definition Twine.h:82
The instances of the Type class are immutable: once they are created, they are never changed.
Definition Type.h:46
A Use represents the edge between a Value definition and its users.
Definition Use.h:35
LLVM Value Representation.
Definition Value.h:75
typename base_list_type::const_iterator const_iterator
Definition ilist.h:122
A range adaptor for a pair of iterators.
This file defines classes to implement an intrusive doubly linked list class (i.e.
This provides a very simple, boring adaptor for a begin and end iterator into a range type.
#define llvm_unreachable(msg)
Marks that the current location is not supposed to be reachable.
unsigned ID
LLVM IR allows to use arbitrary numbers as calling convention identifiers.
Definition CallingConv.h:24
@ C
The default llvm calling convention, compatible with C.
Definition CallingConv.h:34
NodeType
ISD::NodeType enum - This enum defines the target-independent operators for a SelectionDAG.
Definition ISDOpcodes.h:41
@ SETCC
SetCC operator - This evaluates to a true value iff the condition is true.
Definition ISDOpcodes.h:819
@ STRICT_FSETCC
STRICT_FSETCC/STRICT_FSETCCS - Constrained versions of SETCC, used for floating-point operands only.
Definition ISDOpcodes.h:511
@ POISON
POISON - A poison node.
Definition ISDOpcodes.h:236
@ INSERT_SUBVECTOR
INSERT_SUBVECTOR(VECTOR1, VECTOR2, IDX) - Returns a vector with VECTOR2 inserted into VECTOR1.
Definition ISDOpcodes.h:600
@ ANY_EXTEND
ANY_EXTEND - Used for integer types. The high bits are undefined.
Definition ISDOpcodes.h:853
@ SIGN_EXTEND_VECTOR_INREG
SIGN_EXTEND_VECTOR_INREG(Vector) - This operator represents an in-register sign-extension of the low ...
Definition ISDOpcodes.h:910
@ SDIVREM
SDIVREM/UDIVREM - Divide two integers and produce both a quotient and remainder result.
Definition ISDOpcodes.h:280
@ SIGN_EXTEND
Conversion operators.
Definition ISDOpcodes.h:844
@ SELECT
Select(COND, TRUEVAL, FALSEVAL).
Definition ISDOpcodes.h:796
@ UNDEF
UNDEF - An undefined node.
Definition ISDOpcodes.h:233
@ SPLAT_VECTOR
SPLAT_VECTOR(VAL) - Returns a vector with the scalar value VAL duplicated in all lanes.
Definition ISDOpcodes.h:672
@ CopyFromReg
CopyFromReg - This node indicates that the input value is a virtual or physical register that is defi...
Definition ISDOpcodes.h:230
@ EXTRACT_SUBVECTOR
EXTRACT_SUBVECTOR(VECTOR, IDX) - Returns a subvector from VECTOR.
Definition ISDOpcodes.h:614
@ EXTRACT_VECTOR_ELT
EXTRACT_VECTOR_ELT(VECTOR, IDX) - Returns a single element from VECTOR identified by the (potentially...
Definition ISDOpcodes.h:576
@ CopyToReg
CopyToReg - This node has three operands: a chain, a register number to set to this value,...
Definition ISDOpcodes.h:224
@ ZERO_EXTEND
ZERO_EXTEND - Used for integer types, zeroing the new bits.
Definition ISDOpcodes.h:850
@ SELECT_CC
Select with condition operator - This selects between a true value and a false value (ops #2 and #3) ...
Definition ISDOpcodes.h:811
@ ANY_EXTEND_VECTOR_INREG
ANY_EXTEND_VECTOR_INREG(Vector) - This operator represents an in-register any-extension of the low la...
Definition ISDOpcodes.h:899
@ GLOBAL_OFFSET_TABLE
The address of the GOT.
Definition ISDOpcodes.h:103
@ VSELECT
Select with a vector condition (op #0) and two vector operands (ops #1 and #2), returning a vector re...
Definition ISDOpcodes.h:805
@ INSERT_VECTOR_ELT
INSERT_VECTOR_ELT(VECTOR, VAL, IDX) - Returns VECTOR with the element at IDX replaced with VAL.
Definition ISDOpcodes.h:565
@ ZERO_EXTEND_VECTOR_INREG
ZERO_EXTEND_VECTOR_INREG(Vector) - This operator represents an in-register zero-extension of the low ...
Definition ISDOpcodes.h:921
@ CALLSEQ_START
CALLSEQ_START/CALLSEQ_END - These operators mark the beginning and end of a call sequence,...
@ BUILD_VECTOR
BUILD_VECTOR(ELT0, ELT1, ELT2, ELT3,...) - Return a fixed-width vector with the specified,...
Definition ISDOpcodes.h:556
MemIndexType
MemIndexType enum - This enum defines how to interpret MGATHER/SCATTER's index parameter when calcula...
MemIndexedMode
MemIndexedMode enum - This enum defines the load / store indexed addressing modes.
CondCode
ISD::CondCode enum - These are ordered carefully to make the bitfields below work out,...
LoadExtType
LoadExtType enum - This enum defines the three variants of LOADEXT (load with extension).
NodeAddr< NodeBase * > Node
Definition RDFGraph.h:381
This is an optimization pass for GlobalISel generic memory operations.
GenericUniformityInfo< SSAContext > UniformityInfo
@ Offset
Definition DWP.cpp:557
GenericSSAContext< Function > SSAContext
iterator_range< T > make_range(T x, T y)
Convenience function for iterating over sub-ranges.
FoldingSetBase::Node FoldingSetNode
Definition FoldingSet.h:404
AnalysisManager< MachineFunction > MachineFunctionAnalysisManager
iplist< T, Options... > ilist
Definition ilist.h:344
LLVM_ABI void checkForCycles(const SelectionDAG *DAG, bool force=false)
FPClassTest
Floating-point class tests, supported by 'is_fpclass' intrinsic.
AlignedCharArrayUnion< AtomicSDNode, TargetIndexSDNode, BlockAddressSDNode, GlobalAddressSDNode, PseudoProbeSDNode > LargestSDNode
A representation of the largest SDNode, for use in sizeof().
FunctionAddr VTableAddr Count
Definition InstrProf.h:139
GlobalAddressSDNode MostAlignedSDNode
The SDNode class with the greatest alignment requirement.
CodeGenOptLevel
Code generation optimization level.
Definition CodeGen.h:82
CombineLevel
Definition DAGCombine.h:15
DWARFExpression::Operation Op
ArrayRef(const T &OneElt) -> ArrayRef< T >
OutputIt move(R &&Range, OutputIt Out)
Provide wrappers to std::move which take ranges instead of having to pass begin/end explicitly.
Definition STLExtras.h:1916
UndefPoisonKind
Enumeration to track whether we are interested in Undef, Poison, or both.
Definition UndefPoison.h:20
BumpPtrAllocatorImpl<> BumpPtrAllocator
The standard BumpPtrAllocator which just uses the default template parameters.
Definition Allocator.h:383
Implement std::hash so that hash_code can be used in STL containers.
Definition BitVector.h:874
#define N
A collection of metadata nodes that might be associated with a memory access used by the alias-analys...
Definition Metadata.h:763
This struct is a compact representation of a valid (non-zero power of two) alignment.
Definition Alignment.h:39
This class provides default implementations for FoldingSetTrait implementations.
Definition FoldingSet.h:116
Represent subnormal handling kind for floating point instruction inputs and outputs.
Extended Value Type.
Definition ValueTypes.h:35
bool isVector() const
Return true if this is a vector value type.
Definition ValueTypes.h:176
bool isScalableVector() const
Return true if this is a vector type where the runtime length is machine dependent.
Definition ValueTypes.h:182
EVT getVectorElementType() const
Given a vector type, return the type of each element.
Definition ValueTypes.h:336
LLVM_ABI const fltSemantics & getFltSemantics() const
Returns an APFloat semantics tag appropriate for the value type.
unsigned getVectorNumElements() const
Given a vector type, return the number of elements it contains.
Definition ValueTypes.h:344
bool bitsLE(EVT VT) const
Return true if this has no more bits than VT.
Definition ValueTypes.h:316
bool isInteger() const
Return true if this is an integer or a vector integer type.
Definition ValueTypes.h:160
static bool Equals(const SDVTListNode &X, const FoldingSetNodeID &ID, unsigned IDHash, FoldingSetNodeID &TempID)
static unsigned ComputeHash(const SDVTListNode &X, FoldingSetNodeID &TempID)
static void Profile(const SDVTListNode &X, FoldingSetNodeID &ID)
This trait class is used to define behavior of how to "profile" (in the FoldingSet parlance) an objec...
Definition FoldingSet.h:146
static nodes_iterator nodes_begin(SelectionDAG *G)
static nodes_iterator nodes_end(SelectionDAG *G)
pointer_iterator< SelectionDAG::allnodes_iterator > nodes_iterator
This class contains a discriminated union of information about pointers in memory operands,...
This struct is a compact representation of a valid (power of two) or undefined (0) alignment.
Definition Alignment.h:106
A simple container for information about the supported runtime calls.
These are IR-level optimization flags that may be propagated to SDNodes.
This represents a list of ValueType's that has been intern'd by a SelectionDAG.
DAGNodeDeletedListener(SelectionDAG &DAG, std::function< void(SDNode *, SDNode *)> Callback)
void NodeDeleted(SDNode *N, SDNode *E) override
The node N that was deleted and, if E is not null, an equivalent node E that replaced it.
std::function< void(SDNode *, SDNode *)> Callback
std::function< void(SDNode *)> Callback
void NodeInserted(SDNode *N) override
The node N that was inserted.
DAGNodeInsertedListener(SelectionDAG &DAG, std::function< void(SDNode *)> Callback)
Clients of various APIs that cause global effects on the DAG can optionally implement this interface.
static void deleteNode(SDNode *)
Use delete by default for iplist and ilist.
Definition ilist.h:41