LLVM 22.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"
44#include <cassert>
45#include <cstdint>
46#include <functional>
47#include <map>
48#include <set>
49#include <string>
50#include <tuple>
51#include <utility>
52#include <vector>
53
54namespace llvm {
55
56class DIExpression;
57class DILabel;
58class DIVariable;
59class Function;
60class Pass;
61class Type;
62template <class GraphType> struct GraphTraits;
63template <typename T, unsigned int N> class SmallSetVector;
64template <typename T, typename Enable> struct FoldingSetTrait;
65class BatchAAResults;
66class BlockAddress;
67class BlockFrequencyInfo;
68class Constant;
69class ConstantFP;
70class ConstantInt;
71class DataLayout;
72struct fltSemantics;
73class FunctionLoweringInfo;
74class FunctionVarLocs;
75class GlobalValue;
76struct KnownBits;
77class LLVMContext;
78class MachineBasicBlock;
79class MachineConstantPoolValue;
80class MachineModuleInfo;
81class MCSymbol;
82class OptimizationRemarkEmitter;
83class ProfileSummaryInfo;
84class SDDbgValue;
85class SDDbgOperand;
86class SDDbgLabel;
87class SelectionDAG;
88class SelectionDAGTargetInfo;
89class TargetLibraryInfo;
90class TargetLowering;
91class TargetMachine;
92class TargetSubtargetInfo;
93class Value;
94
95template <typename T> class GenericSSAContext;
96using SSAContext = GenericSSAContext<Function>;
97template <typename T> class GenericUniformityInfo;
98using UniformityInfo = GenericUniformityInfo<SSAContext>;
99
101 friend struct FoldingSetTrait<SDVTListNode>;
102
103 /// A reference to an Interned FoldingSetNodeID for this node.
104 /// The Allocator in SelectionDAG holds the data.
105 /// SDVTList contains all types which are frequently accessed in SelectionDAG.
106 /// The size of this list is not expected to be big so it won't introduce
107 /// a memory penalty.
108 FoldingSetNodeIDRef FastID;
109 const EVT *VTs;
110 unsigned int NumVTs;
111 /// The hash value for SDVTList is fixed, so cache it to avoid
112 /// hash calculation.
113 unsigned HashValue;
114
115public:
116 SDVTListNode(const FoldingSetNodeIDRef ID, const EVT *VT, unsigned int Num) :
117 FastID(ID), VTs(VT), NumVTs(Num) {
118 HashValue = ID.ComputeHash();
119 }
120
122 SDVTList result = {VTs, NumVTs};
123 return result;
124 }
125};
126
127/// Specialize FoldingSetTrait for SDVTListNode
128/// to avoid computing temp FoldingSetNodeID and hash value.
129template<> struct FoldingSetTrait<SDVTListNode> : DefaultFoldingSetTrait<SDVTListNode> {
130 static void Profile(const SDVTListNode &X, FoldingSetNodeID& ID) {
131 ID = X.FastID;
132 }
133
134 static bool Equals(const SDVTListNode &X, const FoldingSetNodeID &ID,
135 unsigned IDHash, FoldingSetNodeID &TempID) {
136 if (X.HashValue != IDHash)
137 return false;
138 return ID == X.FastID;
139 }
140
141 static unsigned ComputeHash(const SDVTListNode &X, FoldingSetNodeID &TempID) {
142 return X.HashValue;
143 }
144};
145
146template <> struct ilist_alloc_traits<SDNode> {
147 static void deleteNode(SDNode *) {
148 llvm_unreachable("ilist_traits<SDNode> shouldn't see a deleteNode call!");
149 }
150};
151
152/// Keeps track of dbg_value information through SDISel. We do
153/// not build SDNodes for these so as not to perturb the generated code;
154/// instead the info is kept off to the side in this structure. Each SDNode may
155/// have one or more associated dbg_value entries. This information is kept in
156/// DbgValMap.
157/// Byval parameters are handled separately because they don't use alloca's,
158/// which busts the normal mechanism. There is good reason for handling all
159/// parameters separately: they may not have code generated for them, they
160/// should always go at the beginning of the function regardless of other code
161/// motion, and debug info for them is potentially useful even if the parameter
162/// is unused. Right now only byval parameters are handled separately.
164 BumpPtrAllocator Alloc;
166 SmallVector<SDDbgValue*, 32> ByvalParmDbgValues;
169 DbgValMapType DbgValMap;
170
171public:
172 SDDbgInfo() = default;
173 SDDbgInfo(const SDDbgInfo &) = delete;
174 SDDbgInfo &operator=(const SDDbgInfo &) = delete;
175
176 LLVM_ABI void add(SDDbgValue *V, bool isParameter);
177
178 void add(SDDbgLabel *L) { DbgLabels.push_back(L); }
179
180 /// Invalidate all DbgValues attached to the node and remove
181 /// it from the Node-to-DbgValues map.
182 LLVM_ABI void erase(const SDNode *Node);
183
184 void clear() {
185 DbgValMap.clear();
186 DbgValues.clear();
187 ByvalParmDbgValues.clear();
188 DbgLabels.clear();
189 Alloc.Reset();
190 }
191
192 BumpPtrAllocator &getAlloc() { return Alloc; }
193
194 bool empty() const {
195 return DbgValues.empty() && ByvalParmDbgValues.empty() && DbgLabels.empty();
196 }
197
199 auto I = DbgValMap.find(Node);
200 if (I != DbgValMap.end())
201 return I->second;
202 return ArrayRef<SDDbgValue*>();
203 }
204
207
208 DbgIterator DbgBegin() { return DbgValues.begin(); }
209 DbgIterator DbgEnd() { return DbgValues.end(); }
210 DbgIterator ByvalParmDbgBegin() { return ByvalParmDbgValues.begin(); }
211 DbgIterator ByvalParmDbgEnd() { return ByvalParmDbgValues.end(); }
212 DbgLabelIterator DbgLabelBegin() { return DbgLabels.begin(); }
213 DbgLabelIterator DbgLabelEnd() { return DbgLabels.end(); }
214};
215
216LLVM_ABI void checkForCycles(const SelectionDAG *DAG, bool force = false);
217
218/// This is used to represent a portion of an LLVM function in a low-level
219/// Data Dependence DAG representation suitable for instruction selection.
220/// This DAG is constructed as the first step of instruction selection in order
221/// to allow implementation of machine specific optimizations
222/// and code simplifications.
223///
224/// The representation used by the SelectionDAG is a target-independent
225/// representation, which has some similarities to the GCC RTL representation,
226/// but is significantly more simple, powerful, and is a graph form instead of a
227/// linear form.
228///
230 const TargetMachine &TM;
231 const SelectionDAGTargetInfo *TSI = nullptr;
232 const TargetLowering *TLI = nullptr;
233 const TargetLibraryInfo *LibInfo = nullptr;
234 const FunctionVarLocs *FnVarLocs = nullptr;
235 MachineFunction *MF;
236 MachineFunctionAnalysisManager *MFAM = nullptr;
237 Pass *SDAGISelPass = nullptr;
238 LLVMContext *Context;
239 CodeGenOptLevel OptLevel;
240
241 UniformityInfo *UA = nullptr;
242 FunctionLoweringInfo * FLI = nullptr;
243
244 /// The function-level optimization remark emitter. Used to emit remarks
245 /// whenever manipulating the DAG.
247
248 ProfileSummaryInfo *PSI = nullptr;
249 BlockFrequencyInfo *BFI = nullptr;
250 MachineModuleInfo *MMI = nullptr;
251
252 /// Extended EVTs used for single value VTLists.
253 std::set<EVT, EVT::compareRawBits> EVTs;
254
255 /// List of non-single value types.
256 FoldingSet<SDVTListNode> VTListMap;
257
258 /// Pool allocation for misc. objects that are created once per SelectionDAG.
259 BumpPtrAllocator Allocator;
260
261 /// The starting token.
262 SDNode EntryNode;
263
264 /// The root of the entire DAG.
265 SDValue Root;
266
267 /// A linked list of nodes in the current DAG.
268 ilist<SDNode> AllNodes;
269
270 /// The AllocatorType for allocating SDNodes. We use
271 /// pool allocation with recycling.
273 sizeof(LargestSDNode),
274 alignof(MostAlignedSDNode)>;
275
276 /// Pool allocation for nodes.
277 NodeAllocatorType NodeAllocator;
278
279 /// This structure is used to memoize nodes, automatically performing
280 /// CSE with existing nodes when a duplicate is requested.
281 FoldingSet<SDNode> CSEMap;
282
283 /// Pool allocation for machine-opcode SDNode operands.
284 BumpPtrAllocator OperandAllocator;
285 ArrayRecycler<SDUse> OperandRecycler;
286
287 /// Tracks dbg_value and dbg_label information through SDISel.
288 SDDbgInfo *DbgInfo;
289
292
293 struct NodeExtraInfo {
294 CallSiteInfo CSInfo;
295 MDNode *HeapAllocSite = nullptr;
296 MDNode *PCSections = nullptr;
297 MDNode *MMRA = nullptr;
298 CalledGlobalInfo CalledGlobal{};
299 bool NoMerge = false;
300 };
301 /// Out-of-line extra information for SDNodes.
303
304 /// PersistentId counter to be used when inserting the next
305 /// SDNode to this SelectionDAG. We do not place that under
306 /// `#if LLVM_ENABLE_ABI_BREAKING_CHECKS` intentionally because
307 /// it adds unneeded complexity without noticeable
308 /// benefits (see discussion with @thakis in D120714).
309 uint16_t NextPersistentId = 0;
310
311public:
312 /// Clients of various APIs that cause global effects on
313 /// the DAG can optionally implement this interface. This allows the clients
314 /// to handle the various sorts of updates that happen.
315 ///
316 /// A DAGUpdateListener automatically registers itself with DAG when it is
317 /// constructed, and removes itself when destroyed in RAII fashion.
321
323 : Next(D.UpdateListeners), DAG(D) {
324 DAG.UpdateListeners = this;
325 }
326
328 assert(DAG.UpdateListeners == this &&
329 "DAGUpdateListeners must be destroyed in LIFO order");
330 DAG.UpdateListeners = Next;
331 }
332
333 /// The node N that was deleted and, if E is not null, an
334 /// equivalent node E that replaced it.
335 virtual void NodeDeleted(SDNode *N, SDNode *E);
336
337 /// The node N that was updated.
338 virtual void NodeUpdated(SDNode *N);
339
340 /// The node N that was inserted.
341 virtual void NodeInserted(SDNode *N);
342 };
343
345 std::function<void(SDNode *, SDNode *)> Callback;
346
348 std::function<void(SDNode *, SDNode *)> Callback)
349 : DAGUpdateListener(DAG), Callback(std::move(Callback)) {}
350
351 void NodeDeleted(SDNode *N, SDNode *E) override { Callback(N, E); }
352
353 private:
354 virtual void anchor();
355 };
356
358 std::function<void(SDNode *)> Callback;
359
361 std::function<void(SDNode *)> Callback)
362 : DAGUpdateListener(DAG), Callback(std::move(Callback)) {}
363
364 void NodeInserted(SDNode *N) override { Callback(N); }
365
366 private:
367 virtual void anchor();
368 };
369
370 /// Help to insert SDNodeFlags automatically in transforming. Use
371 /// RAII to save and resume flags in current scope.
373 SelectionDAG &DAG;
374 SDNodeFlags Flags;
375 FlagInserter *LastInserter;
376
377 public:
379 : DAG(SDAG), Flags(Flags),
380 LastInserter(SDAG.getFlagInserter()) {
381 SDAG.setFlagInserter(this);
382 }
384 : FlagInserter(SDAG, N->getFlags()) {}
385
386 FlagInserter(const FlagInserter &) = delete;
388 ~FlagInserter() { DAG.setFlagInserter(LastInserter); }
389
390 SDNodeFlags getFlags() const { return Flags; }
391 };
392
393 /// When true, additional steps are taken to
394 /// ensure that getConstant() and similar functions return DAG nodes that
395 /// have legal types. This is important after type legalization since
396 /// any illegally typed nodes generated after this point will not experience
397 /// type legalization.
399
400private:
401 /// DAGUpdateListener is a friend so it can manipulate the listener stack.
402 friend struct DAGUpdateListener;
403
404 /// Linked list of registered DAGUpdateListener instances.
405 /// This stack is maintained by DAGUpdateListener RAII.
406 DAGUpdateListener *UpdateListeners = nullptr;
407
408 /// Implementation of setSubgraphColor.
409 /// Return whether we had to truncate the search.
410 bool setSubgraphColorHelper(SDNode *N, const char *Color,
411 DenseSet<SDNode *> &visited,
412 int level, bool &printed);
413
414 template <typename SDNodeT, typename... ArgTypes>
415 SDNodeT *newSDNode(ArgTypes &&... Args) {
416 return new (NodeAllocator.template Allocate<SDNodeT>())
417 SDNodeT(std::forward<ArgTypes>(Args)...);
418 }
419
420 /// Build a synthetic SDNodeT with the given args and extract its subclass
421 /// data as an integer (e.g. for use in a folding set).
422 ///
423 /// The args to this function are the same as the args to SDNodeT's
424 /// constructor, except the second arg (assumed to be a const DebugLoc&) is
425 /// omitted.
426 template <typename SDNodeT, typename... ArgTypes>
427 static uint16_t getSyntheticNodeSubclassData(unsigned IROrder,
428 ArgTypes &&... Args) {
429 // The compiler can reduce this expression to a constant iff we pass an
430 // empty DebugLoc. Thankfully, the debug location doesn't have any bearing
431 // on the subclass data.
432 return SDNodeT(IROrder, DebugLoc(), std::forward<ArgTypes>(Args)...)
433 .getRawSubclassData();
434 }
435
436 template <typename SDNodeTy>
437 static uint16_t getSyntheticNodeSubclassData(unsigned Opc, unsigned Order,
438 SDVTList VTs, EVT MemoryVT,
439 MachineMemOperand *MMO) {
440 return SDNodeTy(Opc, Order, DebugLoc(), VTs, MemoryVT, MMO)
441 .getRawSubclassData();
442 }
443
444 void createOperands(SDNode *Node, ArrayRef<SDValue> Vals);
445
446 void removeOperands(SDNode *Node) {
447 if (!Node->OperandList)
448 return;
449 OperandRecycler.deallocate(
451 Node->OperandList);
452 Node->NumOperands = 0;
453 Node->OperandList = nullptr;
454 }
455 void CreateTopologicalOrder(std::vector<SDNode*>& Order);
456
457public:
458 // Maximum depth for recursive analysis such as computeKnownBits, etc.
459 static constexpr unsigned MaxRecursionDepth = 6;
460
461 // Returns the maximum steps for SDNode->hasPredecessor() like searches.
462 LLVM_ABI static unsigned getHasPredecessorMaxSteps();
463
465 SelectionDAG(const SelectionDAG &) = delete;
468
469 /// Prepare this SelectionDAG to process code in the given MachineFunction.
471 Pass *PassPtr, const TargetLibraryInfo *LibraryInfo,
474 FunctionVarLocs const *FnVarLocs);
475
478 const TargetLibraryInfo *LibraryInfo, UniformityInfo *UA,
480 MachineModuleInfo &MMI, FunctionVarLocs const *FnVarLocs) {
481 init(NewMF, NewORE, nullptr, LibraryInfo, UA, PSIin, BFIin, MMI, FnVarLocs);
482 MFAM = &AM;
483 }
484
486 FLI = FuncInfo;
487 }
488
489 /// Clear state and free memory necessary to make this
490 /// SelectionDAG ready to process a new block.
491 LLVM_ABI void clear();
492
493 MachineFunction &getMachineFunction() const { return *MF; }
494 const Pass *getPass() const { return SDAGISelPass; }
496
497 CodeGenOptLevel getOptLevel() const { return OptLevel; }
498 const DataLayout &getDataLayout() const { return MF->getDataLayout(); }
499 const TargetMachine &getTarget() const { return TM; }
500 const TargetSubtargetInfo &getSubtarget() const { return MF->getSubtarget(); }
501 template <typename STC> const STC &getSubtarget() const {
502 return MF->getSubtarget<STC>();
503 }
504 const TargetLowering &getTargetLoweringInfo() const { return *TLI; }
505 const TargetLibraryInfo &getLibInfo() const { return *LibInfo; }
506 const SelectionDAGTargetInfo &getSelectionDAGInfo() const { return *TSI; }
507 const UniformityInfo *getUniformityInfo() const { return UA; }
508 /// Returns the result of the AssignmentTrackingAnalysis pass if it's
509 /// available, otherwise return nullptr.
510 const FunctionVarLocs *getFunctionVarLocs() const { return FnVarLocs; }
511 LLVMContext *getContext() const { return Context; }
512 OptimizationRemarkEmitter &getORE() const { return *ORE; }
513 ProfileSummaryInfo *getPSI() const { return PSI; }
514 BlockFrequencyInfo *getBFI() const { return BFI; }
515 MachineModuleInfo *getMMI() const { return MMI; }
516
517 FlagInserter *getFlagInserter() { return Inserter; }
518 void setFlagInserter(FlagInserter *FI) { Inserter = FI; }
519
520 /// Just dump dot graph to a user-provided path and title.
521 /// This doesn't open the dot viewer program and
522 /// helps visualization when outside debugging session.
523 /// FileName expects absolute path. If provided
524 /// without any path separators then the file
525 /// will be created in the current directory.
526 /// Error will be emitted if the path is insane.
527#if !defined(NDEBUG) || defined(LLVM_ENABLE_DUMP)
528 LLVM_DUMP_METHOD void dumpDotGraph(const Twine &FileName, const Twine &Title);
529#endif
530
531 /// Pop up a GraphViz/gv window with the DAG rendered using 'dot'.
532 LLVM_ABI void viewGraph(const std::string &Title);
533 LLVM_ABI void viewGraph();
534
535#if LLVM_ENABLE_ABI_BREAKING_CHECKS
536 std::map<const SDNode *, std::string> NodeGraphAttrs;
537#endif
538
539 /// Clear all previously defined node graph attributes.
540 /// Intended to be used from a debugging tool (eg. gdb).
542
543 /// Set graph attributes for a node. (eg. "color=red".)
544 LLVM_ABI void setGraphAttrs(const SDNode *N, const char *Attrs);
545
546 /// Get graph attributes for a node. (eg. "color=red".)
547 /// Used from getNodeAttributes.
548 LLVM_ABI std::string getGraphAttrs(const SDNode *N) const;
549
550 /// Convenience for setting node color attribute.
551 LLVM_ABI void setGraphColor(const SDNode *N, const char *Color);
552
553 /// Convenience for setting subgraph color attribute.
554 LLVM_ABI void setSubgraphColor(SDNode *N, const char *Color);
555
557
558 allnodes_const_iterator allnodes_begin() const { return AllNodes.begin(); }
559 allnodes_const_iterator allnodes_end() const { return AllNodes.end(); }
560
562
563 allnodes_iterator allnodes_begin() { return AllNodes.begin(); }
564 allnodes_iterator allnodes_end() { return AllNodes.end(); }
565
567 return AllNodes.size();
568 }
569
572 }
575 }
576
577 /// Return the root tag of the SelectionDAG.
578 const SDValue &getRoot() const { return Root; }
579
580 /// Return the token chain corresponding to the entry of the function.
582 return SDValue(const_cast<SDNode *>(&EntryNode), 0);
583 }
584
585 /// Set the current root tag of the SelectionDAG.
586 ///
588 assert((!N.getNode() || N.getValueType() == MVT::Other) &&
589 "DAG root value is not a chain!");
590 if (N.getNode())
591 checkForCycles(N.getNode(), this);
592 Root = N;
593 if (N.getNode())
594 checkForCycles(this);
595 return Root;
596 }
597
598#if !defined(NDEBUG) && LLVM_ENABLE_ABI_BREAKING_CHECKS
599 void VerifyDAGDivergence();
600#endif
601
602 /// This iterates over the nodes in the SelectionDAG, folding
603 /// certain types of nodes together, or eliminating superfluous nodes. The
604 /// Level argument controls whether Combine is allowed to produce nodes and
605 /// types that are illegal on the target.
606 LLVM_ABI void Combine(CombineLevel Level, BatchAAResults *BatchAA,
607 CodeGenOptLevel OptLevel);
608
609 /// This transforms the SelectionDAG into a SelectionDAG that
610 /// only uses types natively supported by the target.
611 /// Returns "true" if it made any changes.
612 ///
613 /// Note that this is an involved process that may invalidate pointers into
614 /// the graph.
615 LLVM_ABI bool LegalizeTypes();
616
617 /// This transforms the SelectionDAG into a SelectionDAG that is
618 /// compatible with the target instruction selector, as indicated by the
619 /// TargetLowering object.
620 ///
621 /// Note that this is an involved process that may invalidate pointers into
622 /// the graph.
623 LLVM_ABI void Legalize();
624
625 /// Transforms a SelectionDAG node and any operands to it into a node
626 /// that is compatible with the target instruction selector, as indicated by
627 /// the TargetLowering object.
628 ///
629 /// \returns true if \c N is a valid, legal node after calling this.
630 ///
631 /// This essentially runs a single recursive walk of the \c Legalize process
632 /// over the given node (and its operands). This can be used to incrementally
633 /// legalize the DAG. All of the nodes which are directly replaced,
634 /// potentially including N, are added to the output parameter \c
635 /// UpdatedNodes so that the delta to the DAG can be understood by the
636 /// caller.
637 ///
638 /// When this returns false, N has been legalized in a way that make the
639 /// pointer passed in no longer valid. It may have even been deleted from the
640 /// DAG, and so it shouldn't be used further. When this returns true, the
641 /// N passed in is a legal node, and can be immediately processed as such.
642 /// This may still have done some work on the DAG, and will still populate
643 /// UpdatedNodes with any new nodes replacing those originally in the DAG.
645 SmallSetVector<SDNode *, 16> &UpdatedNodes);
646
647 /// This transforms the SelectionDAG into a SelectionDAG
648 /// that only uses vector math operations supported by the target. This is
649 /// necessary as a separate step from Legalize because unrolling a vector
650 /// operation can introduce illegal types, which requires running
651 /// LegalizeTypes again.
652 ///
653 /// This returns true if it made any changes; in that case, LegalizeTypes
654 /// is called again before Legalize.
655 ///
656 /// Note that this is an involved process that may invalidate pointers into
657 /// the graph.
659
660 /// This method deletes all unreachable nodes in the SelectionDAG.
662
663 /// Remove the specified node from the system. This node must
664 /// have no referrers.
666
667 /// Return an SDVTList that represents the list of values specified.
670 LLVM_ABI SDVTList getVTList(EVT VT1, EVT VT2, EVT VT3);
671 LLVM_ABI SDVTList getVTList(EVT VT1, EVT VT2, EVT VT3, EVT VT4);
673
674 //===--------------------------------------------------------------------===//
675 // Node creation methods.
676
677 /// Create a ConstantSDNode wrapping a constant value.
678 /// If VT is a vector type, the constant is splatted into a BUILD_VECTOR.
679 ///
680 /// If only legal types can be produced, this does the necessary
681 /// transformations (e.g., if the vector element type is illegal).
682 /// @{
684 bool isTarget = false, bool isOpaque = false);
685 LLVM_ABI SDValue getConstant(const APInt &Val, const SDLoc &DL, EVT VT,
686 bool isTarget = false, bool isOpaque = false);
687
688 LLVM_ABI SDValue getSignedConstant(int64_t Val, const SDLoc &DL, EVT VT,
689 bool isTarget = false,
690 bool isOpaque = false);
691
693 bool IsTarget = false,
694 bool IsOpaque = false);
695
696 LLVM_ABI SDValue getConstant(const ConstantInt &Val, const SDLoc &DL, EVT VT,
697 bool isTarget = false, bool isOpaque = false);
699 bool isTarget = false);
701 const SDLoc &DL);
703 const SDLoc &DL);
705 bool isTarget = false);
706
708 bool isOpaque = false) {
709 return getConstant(Val, DL, VT, true, isOpaque);
710 }
711 SDValue getTargetConstant(const APInt &Val, const SDLoc &DL, EVT VT,
712 bool isOpaque = false) {
713 return getConstant(Val, DL, VT, true, isOpaque);
714 }
716 bool isOpaque = false) {
717 return getConstant(Val, DL, VT, true, isOpaque);
718 }
719 SDValue getSignedTargetConstant(int64_t Val, const SDLoc &DL, EVT VT,
720 bool isOpaque = false) {
721 return getSignedConstant(Val, DL, VT, true, isOpaque);
722 }
723
724 /// Create a true or false constant of type \p VT using the target's
725 /// BooleanContent for type \p OpVT.
726 LLVM_ABI SDValue getBoolConstant(bool V, const SDLoc &DL, EVT VT, EVT OpVT);
727 /// @}
728
729 /// Create a ConstantFPSDNode wrapping a constant value.
730 /// If VT is a vector type, the constant is splatted into a BUILD_VECTOR.
731 ///
732 /// If only legal types can be produced, this does the necessary
733 /// transformations (e.g., if the vector element type is illegal).
734 /// The forms that take a double should only be used for simple constants
735 /// that can be exactly represented in VT. No checks are made.
736 /// @{
737 LLVM_ABI SDValue getConstantFP(double Val, const SDLoc &DL, EVT VT,
738 bool isTarget = false);
739 LLVM_ABI SDValue getConstantFP(const APFloat &Val, const SDLoc &DL, EVT VT,
740 bool isTarget = false);
741 LLVM_ABI SDValue getConstantFP(const ConstantFP &V, const SDLoc &DL, EVT VT,
742 bool isTarget = false);
743 SDValue getTargetConstantFP(double Val, const SDLoc &DL, EVT VT) {
744 return getConstantFP(Val, DL, VT, true);
745 }
746 SDValue getTargetConstantFP(const APFloat &Val, const SDLoc &DL, EVT VT) {
747 return getConstantFP(Val, DL, VT, true);
748 }
750 return getConstantFP(Val, DL, VT, true);
751 }
752 /// @}
753
755 EVT VT, int64_t offset = 0,
756 bool isTargetGA = false,
757 unsigned TargetFlags = 0);
759 int64_t offset = 0, unsigned TargetFlags = 0) {
760 return getGlobalAddress(GV, DL, VT, offset, true, TargetFlags);
761 }
762 LLVM_ABI SDValue getFrameIndex(int FI, EVT VT, bool isTarget = false);
764 return getFrameIndex(FI, VT, true);
765 }
766 LLVM_ABI SDValue getJumpTable(int JTI, EVT VT, bool isTarget = false,
767 unsigned TargetFlags = 0);
768 SDValue getTargetJumpTable(int JTI, EVT VT, unsigned TargetFlags = 0) {
769 return getJumpTable(JTI, VT, true, TargetFlags);
770 }
772 const SDLoc &DL);
774 MaybeAlign Align = std::nullopt,
775 int Offs = 0, bool isT = false,
776 unsigned TargetFlags = 0);
778 MaybeAlign Align = std::nullopt, int Offset = 0,
779 unsigned TargetFlags = 0) {
780 return getConstantPool(C, VT, Align, Offset, true, TargetFlags);
781 }
783 MaybeAlign Align = std::nullopt,
784 int Offs = 0, bool isT = false,
785 unsigned TargetFlags = 0);
787 MaybeAlign Align = std::nullopt, int Offset = 0,
788 unsigned TargetFlags = 0) {
789 return getConstantPool(C, VT, Align, Offset, true, TargetFlags);
790 }
791 // When generating a branch to a BB, we don't in general know enough
792 // to provide debug info for the BB at that time, so keep this one around.
794 LLVM_ABI SDValue getExternalSymbol(const char *Sym, EVT VT);
796 unsigned TargetFlags = 0);
798
802 LLVM_ABI SDValue getEHLabel(const SDLoc &dl, SDValue Root, MCSymbol *Label);
803 LLVM_ABI SDValue getLabelNode(unsigned Opcode, const SDLoc &dl, SDValue Root,
804 MCSymbol *Label);
806 int64_t Offset = 0, bool isTarget = false,
807 unsigned TargetFlags = 0);
809 int64_t Offset = 0, unsigned TargetFlags = 0) {
810 return getBlockAddress(BA, VT, Offset, true, TargetFlags);
811 }
812
814 SDValue N) {
815 return getNode(ISD::CopyToReg, dl, MVT::Other, Chain,
816 getRegister(Reg, N.getValueType()), N);
817 }
818
819 // This version of the getCopyToReg method takes an extra operand, which
820 // indicates that there is potentially an incoming glue value (if Glue is not
821 // null) and that there should be a glue result.
823 SDValue Glue) {
824 SDVTList VTs = getVTList(MVT::Other, MVT::Glue);
825 SDValue Ops[] = { Chain, getRegister(Reg, N.getValueType()), N, Glue };
826 return getNode(ISD::CopyToReg, dl, VTs,
827 ArrayRef(Ops, Glue.getNode() ? 4 : 3));
828 }
829
830 // Similar to last getCopyToReg() except parameter Reg is a SDValue
832 SDValue Glue) {
833 SDVTList VTs = getVTList(MVT::Other, MVT::Glue);
834 SDValue Ops[] = { Chain, Reg, N, Glue };
835 return getNode(ISD::CopyToReg, dl, VTs,
836 ArrayRef(Ops, Glue.getNode() ? 4 : 3));
837 }
838
840 SDVTList VTs = getVTList(VT, MVT::Other);
841 SDValue Ops[] = { Chain, getRegister(Reg, VT) };
842 return getNode(ISD::CopyFromReg, dl, VTs, Ops);
843 }
844
845 // This version of the getCopyFromReg method takes an extra operand, which
846 // indicates that there is potentially an incoming glue value (if Glue is not
847 // null) and that there should be a glue result.
849 SDValue Glue) {
850 SDVTList VTs = getVTList(VT, MVT::Other, MVT::Glue);
851 SDValue Ops[] = { Chain, getRegister(Reg, VT), Glue };
852 return getNode(ISD::CopyFromReg, dl, VTs,
853 ArrayRef(Ops, Glue.getNode() ? 3 : 2));
854 }
855
857
858 /// Return an ISD::VECTOR_SHUFFLE node. The number of elements in VT,
859 /// which must be a vector type, must match the number of mask elements
860 /// NumElts. An integer mask element equal to -1 is treated as undefined.
862 SDValue N2, ArrayRef<int> Mask);
863
864 /// Return an ISD::BUILD_VECTOR node. The number of elements in VT,
865 /// which must be a vector type, must match the number of operands in Ops.
866 /// The operands must have the same type as (or, for integers, a type wider
867 /// than) VT's element type.
869 // VerifySDNode (via InsertNode) checks BUILD_VECTOR later.
870 return getNode(ISD::BUILD_VECTOR, DL, VT, Ops);
871 }
872
873 /// Return an ISD::BUILD_VECTOR node. The number of elements in VT,
874 /// which must be a vector type, must match the number of operands in Ops.
875 /// The operands must have the same type as (or, for integers, a type wider
876 /// than) VT's element type.
878 // VerifySDNode (via InsertNode) checks BUILD_VECTOR later.
879 return getNode(ISD::BUILD_VECTOR, DL, VT, Ops);
880 }
881
882 /// Return a splat ISD::BUILD_VECTOR node, consisting of Op splatted to all
883 /// elements. VT must be a vector type. Op's type must be the same as (or,
884 /// for integers, a type wider than) VT's element type.
886 // VerifySDNode (via InsertNode) checks BUILD_VECTOR later.
887 if (Op.isUndef()) {
888 assert((VT.getVectorElementType() == Op.getValueType() ||
889 (VT.isInteger() &&
890 VT.getVectorElementType().bitsLE(Op.getValueType()))) &&
891 "A splatted value must have a width equal or (for integers) "
892 "greater than the vector element type!");
893 return getNode(ISD::UNDEF, SDLoc(), VT);
894 }
895
897 return getNode(ISD::BUILD_VECTOR, DL, VT, Ops);
898 }
899
900 // Return a splat ISD::SPLAT_VECTOR node, consisting of Op splatted to all
901 // elements.
903 if (Op.isUndef()) {
904 assert((VT.getVectorElementType() == Op.getValueType() ||
905 (VT.isInteger() &&
906 VT.getVectorElementType().bitsLE(Op.getValueType()))) &&
907 "A splatted value must have a width equal or (for integers) "
908 "greater than the vector element type!");
909 return getNode(ISD::UNDEF, SDLoc(), VT);
910 }
911 return getNode(ISD::SPLAT_VECTOR, DL, VT, Op);
912 }
913
914 /// Returns a node representing a splat of one value into all lanes
915 /// of the provided vector type. This is a utility which returns
916 /// either a BUILD_VECTOR or SPLAT_VECTOR depending on the
917 /// scalability of the desired vector type.
919 assert(VT.isVector() && "Can't splat to non-vector type");
920 return VT.isScalableVector() ?
922 }
923
924 /// Returns a vector of type ResVT whose elements contain the linear sequence
925 /// <0, Step, Step * 2, Step * 3, ...>
927 const APInt &StepVal);
928
929 /// Returns a vector of type ResVT whose elements contain the linear sequence
930 /// <0, 1, 2, 3, ...>
931 LLVM_ABI SDValue getStepVector(const SDLoc &DL, EVT ResVT);
932
933 /// Returns an ISD::VECTOR_SHUFFLE node semantically equivalent to
934 /// the shuffle node in input but with swapped operands.
935 ///
936 /// Example: shuffle A, B, <0,5,2,7> -> shuffle B, A, <4,1,6,3>
938
939 /// Extract element at \p Idx from \p Vec. See EXTRACT_VECTOR_ELT
940 /// description for result type handling.
942 unsigned Idx) {
943 return getNode(ISD::EXTRACT_VECTOR_ELT, DL, VT, Vec,
945 }
946
947 /// Insert \p Elt into \p Vec at offset \p Idx. See INSERT_VECTOR_ELT
948 /// description for element type handling.
950 unsigned Idx) {
951 return getNode(ISD::INSERT_VECTOR_ELT, DL, Vec.getValueType(), Vec, Elt,
953 }
954
955 /// Insert \p SubVec at the \p Idx element of \p Vec.
957 unsigned Idx) {
958 return getNode(ISD::INSERT_SUBVECTOR, DL, Vec.getValueType(), Vec, SubVec,
960 }
961
962 /// Return the \p VT typed sub-vector of \p Vec at \p Idx
964 unsigned Idx) {
965 return getNode(ISD::EXTRACT_SUBVECTOR, DL, VT, Vec,
967 }
968
969 /// Convert Op, which must be of float type, to the
970 /// float type VT, by either extending or rounding (by truncation).
972
973 /// Convert Op, which must be a STRICT operation of float type, to the
974 /// float type VT, by either extending or rounding (by truncation).
975 LLVM_ABI std::pair<SDValue, SDValue>
977
978 /// Convert *_EXTEND_VECTOR_INREG to *_EXTEND opcode.
979 static unsigned getOpcode_EXTEND(unsigned Opcode) {
980 switch (Opcode) {
981 case ISD::ANY_EXTEND:
983 return ISD::ANY_EXTEND;
984 case ISD::ZERO_EXTEND:
986 return ISD::ZERO_EXTEND;
987 case ISD::SIGN_EXTEND:
989 return ISD::SIGN_EXTEND;
990 }
991 llvm_unreachable("Unknown opcode");
992 }
993
994 /// Convert *_EXTEND to *_EXTEND_VECTOR_INREG opcode.
995 static unsigned getOpcode_EXTEND_VECTOR_INREG(unsigned Opcode) {
996 switch (Opcode) {
997 case ISD::ANY_EXTEND:
1000 case ISD::ZERO_EXTEND:
1003 case ISD::SIGN_EXTEND:
1006 }
1007 llvm_unreachable("Unknown opcode");
1008 }
1009
1010 /// Convert Op, which must be of integer type, to the
1011 /// integer type VT, by either any-extending or truncating it.
1013
1014 /// Convert Op, which must be of integer type, to the
1015 /// integer type VT, by either sign-extending or truncating it.
1017
1018 /// Convert Op, which must be of integer type, to the
1019 /// integer type VT, by either zero-extending or truncating it.
1021
1022 /// Convert Op, which must be of integer type, to the
1023 /// integer type VT, by either any/sign/zero-extending (depending on IsAny /
1024 /// IsSigned) or truncating it.
1026 EVT VT, unsigned Opcode) {
1027 switch(Opcode) {
1028 case ISD::ANY_EXTEND:
1029 return getAnyExtOrTrunc(Op, DL, VT);
1030 case ISD::ZERO_EXTEND:
1031 return getZExtOrTrunc(Op, DL, VT);
1032 case ISD::SIGN_EXTEND:
1033 return getSExtOrTrunc(Op, DL, VT);
1034 }
1035 llvm_unreachable("Unsupported opcode");
1036 }
1037
1038 /// Convert Op, which must be of integer type, to the
1039 /// integer type VT, by either sign/zero-extending (depending on IsSigned) or
1040 /// truncating it.
1041 SDValue getExtOrTrunc(bool IsSigned, SDValue Op, const SDLoc &DL, EVT VT) {
1042 return IsSigned ? getSExtOrTrunc(Op, DL, VT) : getZExtOrTrunc(Op, DL, VT);
1043 }
1044
1045 /// Convert Op, which must be of integer type, to the
1046 /// integer type VT, by first bitcasting (from potential vector) to
1047 /// corresponding scalar type then either any-extending or truncating it.
1049 EVT VT);
1050
1051 /// Convert Op, which must be of integer type, to the
1052 /// integer type VT, by first bitcasting (from potential vector) to
1053 /// corresponding scalar type then either sign-extending or truncating it.
1055
1056 /// Convert Op, which must be of integer type, to the
1057 /// integer type VT, by first bitcasting (from potential vector) to
1058 /// corresponding scalar type then either zero-extending or truncating it.
1060
1061 /// Return the expression required to zero extend the Op
1062 /// value assuming it was the smaller SrcTy value.
1064
1065 /// Return the expression required to zero extend the Op
1066 /// value assuming it was the smaller SrcTy value.
1068 const SDLoc &DL, EVT VT);
1069
1070 /// Convert Op, which must be of integer type, to the integer type VT, by
1071 /// either truncating it or performing either zero or sign extension as
1072 /// appropriate extension for the pointer's semantics.
1074
1075 /// Return the expression required to extend the Op as a pointer value
1076 /// assuming it was the smaller SrcTy value. This may be either a zero extend
1077 /// or a sign extend.
1079
1080 /// Convert Op, which must be of integer type, to the integer type VT,
1081 /// by using an extension appropriate for the target's
1082 /// BooleanContent for type OpVT or truncating it.
1084 EVT OpVT);
1085
1086 /// Create negative operation as (SUB 0, Val).
1087 LLVM_ABI SDValue getNegative(SDValue Val, const SDLoc &DL, EVT VT);
1088
1089 /// Create a bitwise NOT operation as (XOR Val, -1).
1090 LLVM_ABI SDValue getNOT(const SDLoc &DL, SDValue Val, EVT VT);
1091
1092 /// Create a logical NOT operation as (XOR Val, BooleanOne).
1093 LLVM_ABI SDValue getLogicalNOT(const SDLoc &DL, SDValue Val, EVT VT);
1094
1095 /// Create a vector-predicated logical NOT operation as (VP_XOR Val,
1096 /// BooleanOne, Mask, EVL).
1098 SDValue EVL, EVT VT);
1099
1100 /// Convert a vector-predicated Op, which must be an integer vector, to the
1101 /// vector-type VT, by performing either vector-predicated zext or truncating
1102 /// it. The Op will be returned as-is if Op and VT are vectors containing
1103 /// integer with same width.
1105 SDValue Mask, SDValue EVL);
1106
1107 /// Convert a vector-predicated Op, which must be of integer type, to the
1108 /// vector-type integer type VT, by either truncating it or performing either
1109 /// vector-predicated zero or sign extension as appropriate extension for the
1110 /// pointer's semantics. This function just redirects to getVPZExtOrTrunc
1111 /// right now.
1113 SDValue Mask, SDValue EVL);
1114
1115 /// Returns sum of the base pointer and offset.
1116 /// Unlike getObjectPtrOffset this does not set NoUnsignedWrap by default.
1119 const SDNodeFlags Flags = SDNodeFlags());
1122 const SDNodeFlags Flags = SDNodeFlags());
1123
1124 /// Create an add instruction with appropriate flags when used for
1125 /// addressing some offset of an object. i.e. if a load is split into multiple
1126 /// components, create an add nuw from the base pointer to the offset.
1129 }
1130
1132 // The object itself can't wrap around the address space, so it shouldn't be
1133 // possible for the adds of the offsets to the split parts to overflow.
1135 }
1136
1137 /// Return a new CALLSEQ_START node, that starts new call frame, in which
1138 /// InSize bytes are set up inside CALLSEQ_START..CALLSEQ_END sequence and
1139 /// OutSize specifies part of the frame set up prior to the sequence.
1141 const SDLoc &DL) {
1142 SDVTList VTs = getVTList(MVT::Other, MVT::Glue);
1143 SDValue Ops[] = { Chain,
1144 getIntPtrConstant(InSize, DL, true),
1145 getIntPtrConstant(OutSize, DL, true) };
1146 return getNode(ISD::CALLSEQ_START, DL, VTs, Ops);
1147 }
1148
1149 /// Return a new CALLSEQ_END node, which always must have a
1150 /// glue result (to ensure it's not CSE'd).
1151 /// CALLSEQ_END does not have a useful SDLoc.
1153 SDValue InGlue, const SDLoc &DL) {
1154 SDVTList NodeTys = getVTList(MVT::Other, MVT::Glue);
1156 Ops.push_back(Chain);
1157 Ops.push_back(Op1);
1158 Ops.push_back(Op2);
1159 if (InGlue.getNode())
1160 Ops.push_back(InGlue);
1161 return getNode(ISD::CALLSEQ_END, DL, NodeTys, Ops);
1162 }
1163
1165 SDValue Glue, const SDLoc &DL) {
1166 return getCALLSEQ_END(
1167 Chain, getIntPtrConstant(Size1, DL, /*isTarget=*/true),
1168 getIntPtrConstant(Size2, DL, /*isTarget=*/true), Glue, DL);
1169 }
1170
1171 /// Return true if the result of this operation is always undefined.
1172 LLVM_ABI bool isUndef(unsigned Opcode, ArrayRef<SDValue> Ops);
1173
1174 /// Return an UNDEF node. UNDEF does not have a useful SDLoc.
1176 return getNode(ISD::UNDEF, SDLoc(), VT);
1177 }
1178
1179 /// Return a POISON node. POISON does not have a useful SDLoc.
1181
1182 /// Return a node that represents the runtime scaling 'MulImm * RuntimeVL'.
1183 LLVM_ABI SDValue getVScale(const SDLoc &DL, EVT VT, APInt MulImm,
1184 bool ConstantFold = true);
1185
1187 bool ConstantFold = true);
1188
1189 /// Return a GLOBAL_OFFSET_TABLE node. This does not have a useful SDLoc.
1191 return getNode(ISD::GLOBAL_OFFSET_TABLE, SDLoc(), VT);
1192 }
1193
1194 /// Gets or creates the specified node.
1195 ///
1196 LLVM_ABI SDValue getNode(unsigned Opcode, const SDLoc &DL, EVT VT,
1197 ArrayRef<SDUse> Ops);
1198 LLVM_ABI SDValue getNode(unsigned Opcode, const SDLoc &DL, EVT VT,
1199 ArrayRef<SDValue> Ops, const SDNodeFlags Flags);
1200 LLVM_ABI SDValue getNode(unsigned Opcode, const SDLoc &DL,
1201 ArrayRef<EVT> ResultTys, ArrayRef<SDValue> Ops,
1202 const SDNodeFlags Flags);
1203 LLVM_ABI SDValue getNode(unsigned Opcode, const SDLoc &DL, SDVTList VTList,
1204 ArrayRef<SDValue> Ops, const SDNodeFlags Flags);
1205
1206 // Use flags from current flag inserter.
1207 LLVM_ABI SDValue getNode(unsigned Opcode, const SDLoc &DL, EVT VT,
1208 ArrayRef<SDValue> Ops);
1209 LLVM_ABI SDValue getNode(unsigned Opcode, const SDLoc &DL,
1210 ArrayRef<EVT> ResultTys, ArrayRef<SDValue> Ops);
1211 LLVM_ABI SDValue getNode(unsigned Opcode, const SDLoc &DL, SDVTList VTList,
1212 ArrayRef<SDValue> Ops);
1213 LLVM_ABI SDValue getNode(unsigned Opcode, const SDLoc &DL, EVT VT,
1214 SDValue Operand);
1215 LLVM_ABI SDValue getNode(unsigned Opcode, const SDLoc &DL, EVT VT, SDValue N1,
1216 SDValue N2);
1217 LLVM_ABI SDValue getNode(unsigned Opcode, const SDLoc &DL, EVT VT, SDValue N1,
1218 SDValue N2, SDValue N3);
1219
1220 // Specialize based on number of operands.
1221 LLVM_ABI SDValue getNode(unsigned Opcode, const SDLoc &DL, EVT VT);
1222 LLVM_ABI SDValue getNode(unsigned Opcode, const SDLoc &DL, EVT VT,
1223 SDValue Operand, const SDNodeFlags Flags);
1224 LLVM_ABI SDValue getNode(unsigned Opcode, const SDLoc &DL, EVT VT, SDValue N1,
1225 SDValue N2, const SDNodeFlags Flags);
1226 LLVM_ABI SDValue getNode(unsigned Opcode, const SDLoc &DL, EVT VT, SDValue N1,
1227 SDValue N2, SDValue N3, const SDNodeFlags Flags);
1228 LLVM_ABI SDValue getNode(unsigned Opcode, const SDLoc &DL, EVT VT, SDValue N1,
1229 SDValue N2, SDValue N3, SDValue N4);
1230 LLVM_ABI SDValue getNode(unsigned Opcode, const SDLoc &DL, EVT VT, SDValue N1,
1231 SDValue N2, SDValue N3, SDValue N4,
1232 const SDNodeFlags Flags);
1233 LLVM_ABI SDValue getNode(unsigned Opcode, const SDLoc &DL, EVT VT, SDValue N1,
1234 SDValue N2, SDValue N3, SDValue N4, SDValue N5);
1235 LLVM_ABI SDValue getNode(unsigned Opcode, const SDLoc &DL, EVT VT, SDValue N1,
1236 SDValue N2, SDValue N3, SDValue N4, SDValue N5,
1237 const SDNodeFlags Flags);
1238
1239 // Specialize again based on number of operands for nodes with a VTList
1240 // rather than a single VT.
1241 LLVM_ABI SDValue getNode(unsigned Opcode, const SDLoc &DL, SDVTList VTList);
1242 LLVM_ABI SDValue getNode(unsigned Opcode, const SDLoc &DL, SDVTList VTList,
1243 SDValue N);
1244 LLVM_ABI SDValue getNode(unsigned Opcode, const SDLoc &DL, SDVTList VTList,
1245 SDValue N1, SDValue N2);
1246 LLVM_ABI SDValue getNode(unsigned Opcode, const SDLoc &DL, SDVTList VTList,
1247 SDValue N1, SDValue N2, SDValue N3);
1248 LLVM_ABI SDValue getNode(unsigned Opcode, const SDLoc &DL, SDVTList VTList,
1249 SDValue N1, SDValue N2, SDValue N3, SDValue N4);
1250 LLVM_ABI SDValue getNode(unsigned Opcode, const SDLoc &DL, SDVTList VTList,
1251 SDValue N1, SDValue N2, SDValue N3, SDValue N4,
1252 SDValue N5);
1253
1254 /// Compute a TokenFactor to force all the incoming stack arguments to be
1255 /// loaded from the stack. This is used in tail call lowering to protect
1256 /// stack arguments from being clobbered.
1258
1259 std::pair<SDValue, SDValue> getMemcmp(SDValue Chain, const SDLoc &dl,
1260 SDValue Dst, SDValue Src, SDValue Size,
1261 const CallInst *CI);
1262 /* \p CI if not null is the memset call being lowered.
1263 * \p OverrideTailCall is an optional parameter that can be used to override
1264 * the tail call optimization decision. */
1265 LLVM_ABI SDValue getMemcpy(SDValue Chain, const SDLoc &dl, SDValue Dst,
1266 SDValue Src, SDValue Size, Align Alignment,
1267 bool isVol, bool AlwaysInline, const CallInst *CI,
1268 std::optional<bool> OverrideTailCall,
1269 MachinePointerInfo DstPtrInfo,
1270 MachinePointerInfo SrcPtrInfo,
1271 const AAMDNodes &AAInfo = AAMDNodes(),
1272 BatchAAResults *BatchAA = nullptr);
1273
1274 /* \p CI if not null is the memset call being lowered.
1275 * \p OverrideTailCall is an optional parameter that can be used to override
1276 * the tail call optimization decision. */
1277 LLVM_ABI SDValue getMemmove(SDValue Chain, const SDLoc &dl, SDValue Dst,
1278 SDValue Src, SDValue Size, Align Alignment,
1279 bool isVol, const CallInst *CI,
1280 std::optional<bool> OverrideTailCall,
1281 MachinePointerInfo DstPtrInfo,
1282 MachinePointerInfo SrcPtrInfo,
1283 const AAMDNodes &AAInfo = AAMDNodes(),
1284 BatchAAResults *BatchAA = nullptr);
1285
1286 LLVM_ABI SDValue getMemset(SDValue Chain, const SDLoc &dl, SDValue Dst,
1287 SDValue Src, SDValue Size, Align Alignment,
1288 bool isVol, bool AlwaysInline, const CallInst *CI,
1289 MachinePointerInfo DstPtrInfo,
1290 const AAMDNodes &AAInfo = AAMDNodes());
1291
1292 LLVM_ABI SDValue getAtomicMemcpy(SDValue Chain, const SDLoc &dl, SDValue Dst,
1293 SDValue Src, SDValue Size, Type *SizeTy,
1294 unsigned ElemSz, bool isTailCall,
1295 MachinePointerInfo DstPtrInfo,
1296 MachinePointerInfo SrcPtrInfo);
1297
1298 LLVM_ABI SDValue getAtomicMemmove(SDValue Chain, const SDLoc &dl, SDValue Dst,
1299 SDValue Src, SDValue Size, Type *SizeTy,
1300 unsigned ElemSz, bool isTailCall,
1301 MachinePointerInfo DstPtrInfo,
1302 MachinePointerInfo SrcPtrInfo);
1303
1304 LLVM_ABI SDValue getAtomicMemset(SDValue Chain, const SDLoc &dl, SDValue Dst,
1305 SDValue Value, SDValue Size, Type *SizeTy,
1306 unsigned ElemSz, bool isTailCall,
1307 MachinePointerInfo DstPtrInfo);
1308
1309 /// Helper function to make it easier to build SetCC's if you just have an
1310 /// ISD::CondCode instead of an SDValue.
1312 ISD::CondCode Cond, SDValue Chain = SDValue(),
1313 bool IsSignaling = false) {
1314 assert(LHS.getValueType().isVector() == RHS.getValueType().isVector() &&
1315 "Vector/scalar operand type mismatch for setcc");
1316 assert(LHS.getValueType().isVector() == VT.isVector() &&
1317 "Vector/scalar result type mismatch for setcc");
1319 "Cannot create a setCC of an invalid node.");
1320 if (Chain)
1321 return getNode(IsSignaling ? ISD::STRICT_FSETCCS : ISD::STRICT_FSETCC, DL,
1322 {VT, MVT::Other}, {Chain, LHS, RHS, getCondCode(Cond)});
1323 return getNode(ISD::SETCC, DL, VT, LHS, RHS, getCondCode(Cond));
1324 }
1325
1326 /// Helper function to make it easier to build VP_SETCCs if you just have an
1327 /// ISD::CondCode instead of an SDValue.
1329 ISD::CondCode Cond, SDValue Mask, SDValue EVL) {
1330 assert(LHS.getValueType().isVector() && RHS.getValueType().isVector() &&
1331 "Cannot compare scalars");
1333 "Cannot create a setCC of an invalid node.");
1334 return getNode(ISD::VP_SETCC, DL, VT, LHS, RHS, getCondCode(Cond), Mask,
1335 EVL);
1336 }
1337
1338 /// Helper function to make it easier to build Select's if you just have
1339 /// operands and don't want to check for vector.
1341 SDValue RHS, SDNodeFlags Flags = SDNodeFlags()) {
1342 assert(LHS.getValueType() == VT && RHS.getValueType() == VT &&
1343 "Cannot use select on differing types");
1344 auto Opcode = Cond.getValueType().isVector() ? ISD::VSELECT : ISD::SELECT;
1345 return getNode(Opcode, DL, VT, Cond, LHS, RHS, Flags);
1346 }
1347
1348 /// Helper function to make it easier to build SelectCC's if you just have an
1349 /// ISD::CondCode instead of an SDValue.
1351 SDValue False, ISD::CondCode Cond,
1352 SDNodeFlags Flags = SDNodeFlags()) {
1353 return getNode(ISD::SELECT_CC, DL, True.getValueType(), LHS, RHS, True,
1354 False, getCondCode(Cond), Flags);
1355 }
1356
1357 /// Try to simplify a select/vselect into 1 of its operands or a constant.
1359
1360 /// Try to simplify a shift into 1 of its operands or a constant.
1362
1363 /// Try to simplify a floating-point binary operation into 1 of its operands
1364 /// or a constant.
1365 LLVM_ABI SDValue simplifyFPBinop(unsigned Opcode, SDValue X, SDValue Y,
1366 SDNodeFlags Flags);
1367
1368 /// VAArg produces a result and token chain, and takes a pointer
1369 /// and a source value as input.
1370 LLVM_ABI SDValue getVAArg(EVT VT, const SDLoc &dl, SDValue Chain, SDValue Ptr,
1371 SDValue SV, unsigned Align);
1372
1373 /// Gets a node for an atomic cmpxchg op. There are two
1374 /// valid Opcodes. ISD::ATOMIC_CMO_SWAP produces the value loaded and a
1375 /// chain result. ISD::ATOMIC_CMP_SWAP_WITH_SUCCESS produces the value loaded,
1376 /// a success flag (initially i1), and a chain.
1377 LLVM_ABI SDValue getAtomicCmpSwap(unsigned Opcode, const SDLoc &dl, EVT MemVT,
1378 SDVTList VTs, SDValue Chain, SDValue Ptr,
1379 SDValue Cmp, SDValue Swp,
1380 MachineMemOperand *MMO);
1381
1382 /// Gets a node for an atomic op, produces result (if relevant)
1383 /// and chain and takes 2 operands.
1384 LLVM_ABI SDValue getAtomic(unsigned Opcode, const SDLoc &dl, EVT MemVT,
1385 SDValue Chain, SDValue Ptr, SDValue Val,
1386 MachineMemOperand *MMO);
1387
1388 /// Gets a node for an atomic op, produces result and chain and takes N
1389 /// operands.
1390 LLVM_ABI SDValue getAtomic(unsigned Opcode, const SDLoc &dl, EVT MemVT,
1391 SDVTList VTList, ArrayRef<SDValue> Ops,
1392 MachineMemOperand *MMO,
1394
1396 EVT MemVT, EVT VT, SDValue Chain, SDValue Ptr,
1397 MachineMemOperand *MMO);
1398
1399 /// Creates a MemIntrinsicNode that may produce a
1400 /// result and takes a list of operands. Opcode may be INTRINSIC_VOID,
1401 /// INTRINSIC_W_CHAIN, or a target-specific memory-referencing opcode
1402 // (see `SelectionDAGTargetInfo::isTargetMemoryOpcode`).
1404 unsigned Opcode, const SDLoc &dl, SDVTList VTList, ArrayRef<SDValue> Ops,
1405 EVT MemVT, MachinePointerInfo PtrInfo, Align Alignment,
1409 const AAMDNodes &AAInfo = AAMDNodes());
1410
1412 unsigned Opcode, const SDLoc &dl, SDVTList VTList, ArrayRef<SDValue> Ops,
1413 EVT MemVT, MachinePointerInfo PtrInfo,
1414 MaybeAlign Alignment = std::nullopt,
1418 const AAMDNodes &AAInfo = AAMDNodes()) {
1419 // Ensure that codegen never sees alignment 0
1420 return getMemIntrinsicNode(Opcode, dl, VTList, Ops, MemVT, PtrInfo,
1421 Alignment.value_or(getEVTAlign(MemVT)), Flags,
1422 Size, AAInfo);
1423 }
1424
1425 LLVM_ABI SDValue getMemIntrinsicNode(unsigned Opcode, const SDLoc &dl,
1426 SDVTList VTList, ArrayRef<SDValue> Ops,
1427 EVT MemVT, MachineMemOperand *MMO);
1428
1429 /// Creates a LifetimeSDNode that starts (`IsStart==true`) or ends
1430 /// (`IsStart==false`) the lifetime of the `FrameIndex`.
1431 LLVM_ABI SDValue getLifetimeNode(bool IsStart, const SDLoc &dl, SDValue Chain,
1432 int FrameIndex);
1433
1434 /// Creates a PseudoProbeSDNode with function GUID `Guid` and
1435 /// the index of the block `Index` it is probing, as well as the attributes
1436 /// `attr` of the probe.
1439 uint32_t Attr);
1440
1441 /// Create a MERGE_VALUES node from the given operands.
1443
1444 /// Loads are not normal binary operators: their result type is not
1445 /// determined by their operands, and they produce a value AND a token chain.
1446 ///
1447 /// This function will set the MOLoad flag on MMOFlags, but you can set it if
1448 /// you want. The MOStore flag must not be set.
1450 EVT VT, const SDLoc &dl, SDValue Chain, SDValue Ptr,
1451 MachinePointerInfo PtrInfo, MaybeAlign Alignment = MaybeAlign(),
1453 const AAMDNodes &AAInfo = AAMDNodes(), const MDNode *Ranges = nullptr);
1454 LLVM_ABI SDValue getLoad(EVT VT, const SDLoc &dl, SDValue Chain, SDValue Ptr,
1455 MachineMemOperand *MMO);
1457 getExtLoad(ISD::LoadExtType ExtType, const SDLoc &dl, EVT VT, SDValue Chain,
1458 SDValue Ptr, MachinePointerInfo PtrInfo, EVT MemVT,
1459 MaybeAlign Alignment = MaybeAlign(),
1461 const AAMDNodes &AAInfo = AAMDNodes());
1462 LLVM_ABI SDValue getExtLoad(ISD::LoadExtType ExtType, const SDLoc &dl, EVT VT,
1463 SDValue Chain, SDValue Ptr, EVT MemVT,
1464 MachineMemOperand *MMO);
1465 LLVM_ABI SDValue getIndexedLoad(SDValue OrigLoad, const SDLoc &dl,
1469 ISD::MemIndexedMode AM, ISD::LoadExtType ExtType, EVT VT, const SDLoc &dl,
1471 EVT MemVT, Align Alignment,
1473 const AAMDNodes &AAInfo = AAMDNodes(), const MDNode *Ranges = nullptr);
1475 ISD::MemIndexedMode AM, ISD::LoadExtType ExtType, EVT VT, const SDLoc &dl,
1477 EVT MemVT, MaybeAlign Alignment = MaybeAlign(),
1479 const AAMDNodes &AAInfo = AAMDNodes(), const MDNode *Ranges = nullptr) {
1480 // Ensures that codegen never sees a None Alignment.
1481 return getLoad(AM, ExtType, VT, dl, Chain, Ptr, Offset, PtrInfo, MemVT,
1482 Alignment.value_or(getEVTAlign(MemVT)), MMOFlags, AAInfo,
1483 Ranges);
1484 }
1486 EVT VT, const SDLoc &dl, SDValue Chain, SDValue Ptr,
1487 SDValue Offset, EVT MemVT, MachineMemOperand *MMO);
1488
1489 /// Helper function to build ISD::STORE nodes.
1490 ///
1491 /// This function will set the MOStore flag on MMOFlags, but you can set it if
1492 /// you want. The MOLoad and MOInvariant flags must not be set.
1493
1495 getStore(SDValue Chain, const SDLoc &dl, SDValue Val, SDValue Ptr,
1496 MachinePointerInfo PtrInfo, Align Alignment,
1498 const AAMDNodes &AAInfo = AAMDNodes());
1499 inline SDValue
1500 getStore(SDValue Chain, const SDLoc &dl, SDValue Val, SDValue Ptr,
1501 MachinePointerInfo PtrInfo, MaybeAlign Alignment = MaybeAlign(),
1503 const AAMDNodes &AAInfo = AAMDNodes()) {
1504 return getStore(Chain, dl, Val, Ptr, PtrInfo,
1505 Alignment.value_or(getEVTAlign(Val.getValueType())),
1506 MMOFlags, AAInfo);
1507 }
1508 LLVM_ABI SDValue getStore(SDValue Chain, const SDLoc &dl, SDValue Val,
1511 getTruncStore(SDValue Chain, const SDLoc &dl, SDValue Val, SDValue Ptr,
1512 MachinePointerInfo PtrInfo, EVT SVT, Align Alignment,
1514 const AAMDNodes &AAInfo = AAMDNodes());
1515 inline SDValue
1517 MachinePointerInfo PtrInfo, EVT SVT,
1518 MaybeAlign Alignment = MaybeAlign(),
1520 const AAMDNodes &AAInfo = AAMDNodes()) {
1521 return getTruncStore(Chain, dl, Val, Ptr, PtrInfo, SVT,
1522 Alignment.value_or(getEVTAlign(SVT)), MMOFlags,
1523 AAInfo);
1524 }
1525 LLVM_ABI SDValue getTruncStore(SDValue Chain, const SDLoc &dl, SDValue Val,
1526 SDValue Ptr, EVT SVT, MachineMemOperand *MMO);
1527 LLVM_ABI SDValue getIndexedStore(SDValue OrigStore, const SDLoc &dl,
1530 LLVM_ABI SDValue getStore(SDValue Chain, const SDLoc &dl, SDValue Val,
1533 bool IsTruncating = false);
1534
1536 EVT VT, const SDLoc &dl, SDValue Chain,
1538 SDValue EVL, MachinePointerInfo PtrInfo, EVT MemVT,
1539 Align Alignment, MachineMemOperand::Flags MMOFlags,
1540 const AAMDNodes &AAInfo,
1541 const MDNode *Ranges = nullptr,
1542 bool IsExpanding = false);
1543 inline SDValue
1545 const SDLoc &dl, SDValue Chain, SDValue Ptr, SDValue Offset,
1546 SDValue Mask, SDValue EVL, MachinePointerInfo PtrInfo, EVT MemVT,
1547 MaybeAlign Alignment = MaybeAlign(),
1549 const AAMDNodes &AAInfo = AAMDNodes(),
1550 const MDNode *Ranges = nullptr, bool IsExpanding = false) {
1551 // Ensures that codegen never sees a None Alignment.
1552 return getLoadVP(AM, ExtType, VT, dl, Chain, Ptr, Offset, Mask, EVL,
1553 PtrInfo, MemVT, Alignment.value_or(getEVTAlign(MemVT)),
1554 MMOFlags, AAInfo, Ranges, IsExpanding);
1555 }
1557 EVT VT, const SDLoc &dl, SDValue Chain,
1559 SDValue EVL, EVT MemVT, MachineMemOperand *MMO,
1560 bool IsExpanding = false);
1561 LLVM_ABI SDValue getLoadVP(EVT VT, const SDLoc &dl, SDValue Chain,
1562 SDValue Ptr, SDValue Mask, SDValue EVL,
1563 MachinePointerInfo PtrInfo, MaybeAlign Alignment,
1564 MachineMemOperand::Flags MMOFlags,
1565 const AAMDNodes &AAInfo,
1566 const MDNode *Ranges = nullptr,
1567 bool IsExpanding = false);
1568 LLVM_ABI SDValue getLoadVP(EVT VT, const SDLoc &dl, SDValue Chain,
1569 SDValue Ptr, SDValue Mask, SDValue EVL,
1570 MachineMemOperand *MMO, bool IsExpanding = false);
1572 ISD::LoadExtType ExtType, const SDLoc &dl, EVT VT, SDValue Chain,
1573 SDValue Ptr, SDValue Mask, SDValue EVL, MachinePointerInfo PtrInfo,
1574 EVT MemVT, MaybeAlign Alignment, MachineMemOperand::Flags MMOFlags,
1575 const AAMDNodes &AAInfo, bool IsExpanding = false);
1577 EVT VT, SDValue Chain, SDValue Ptr,
1578 SDValue Mask, SDValue EVL, EVT MemVT,
1579 MachineMemOperand *MMO,
1580 bool IsExpanding = false);
1581 LLVM_ABI SDValue getIndexedLoadVP(SDValue OrigLoad, const SDLoc &dl,
1584 LLVM_ABI SDValue getStoreVP(SDValue Chain, const SDLoc &dl, SDValue Val,
1586 SDValue EVL, EVT MemVT, MachineMemOperand *MMO,
1587 ISD::MemIndexedMode AM, bool IsTruncating = false,
1588 bool IsCompressing = false);
1589 LLVM_ABI SDValue getTruncStoreVP(SDValue Chain, const SDLoc &dl, SDValue Val,
1590 SDValue Ptr, SDValue Mask, SDValue EVL,
1591 MachinePointerInfo PtrInfo, EVT SVT,
1592 Align Alignment,
1593 MachineMemOperand::Flags MMOFlags,
1594 const AAMDNodes &AAInfo,
1595 bool IsCompressing = false);
1596 LLVM_ABI SDValue getTruncStoreVP(SDValue Chain, const SDLoc &dl, SDValue Val,
1597 SDValue Ptr, SDValue Mask, SDValue EVL,
1598 EVT SVT, MachineMemOperand *MMO,
1599 bool IsCompressing = false);
1600 LLVM_ABI SDValue getIndexedStoreVP(SDValue OrigStore, const SDLoc &dl,
1603
1605 ISD::MemIndexedMode AM, ISD::LoadExtType ExtType, EVT VT, const SDLoc &DL,
1606 SDValue Chain, SDValue Ptr, SDValue Offset, SDValue Stride, SDValue Mask,
1607 SDValue EVL, EVT MemVT, MachineMemOperand *MMO, bool IsExpanding = false);
1609 SDValue Ptr, SDValue Stride, SDValue Mask,
1610 SDValue EVL, MachineMemOperand *MMO,
1611 bool IsExpanding = false);
1613 const SDLoc &DL, EVT VT, SDValue Chain,
1614 SDValue Ptr, SDValue Stride,
1615 SDValue Mask, SDValue EVL, EVT MemVT,
1616 MachineMemOperand *MMO,
1617 bool IsExpanding = false);
1620 SDValue Stride, SDValue Mask, SDValue EVL,
1621 EVT MemVT, MachineMemOperand *MMO,
1623 bool IsTruncating = false,
1624 bool IsCompressing = false);
1626 SDValue Val, SDValue Ptr,
1627 SDValue Stride, SDValue Mask,
1628 SDValue EVL, EVT SVT,
1629 MachineMemOperand *MMO,
1630 bool IsCompressing = false);
1631
1632 LLVM_ABI SDValue getGatherVP(SDVTList VTs, EVT VT, const SDLoc &dl,
1634 ISD::MemIndexType IndexType);
1635 LLVM_ABI SDValue getScatterVP(SDVTList VTs, EVT VT, const SDLoc &dl,
1637 ISD::MemIndexType IndexType);
1638
1639 LLVM_ABI SDValue getMaskedLoad(EVT VT, const SDLoc &dl, SDValue Chain,
1641 SDValue Src0, EVT MemVT,
1643 ISD::LoadExtType, bool IsExpanding = false);
1647 LLVM_ABI SDValue getMaskedStore(SDValue Chain, const SDLoc &dl, SDValue Val,
1649 EVT MemVT, MachineMemOperand *MMO,
1651 bool IsTruncating = false,
1652 bool IsCompressing = false);
1653 LLVM_ABI SDValue getIndexedMaskedStore(SDValue OrigStore, const SDLoc &dl,
1656 LLVM_ABI SDValue getMaskedGather(SDVTList VTs, EVT MemVT, const SDLoc &dl,
1658 MachineMemOperand *MMO,
1659 ISD::MemIndexType IndexType,
1660 ISD::LoadExtType ExtTy);
1661 LLVM_ABI SDValue getMaskedScatter(SDVTList VTs, EVT MemVT, const SDLoc &dl,
1663 MachineMemOperand *MMO,
1664 ISD::MemIndexType IndexType,
1665 bool IsTruncating = false);
1666 LLVM_ABI SDValue getMaskedHistogram(SDVTList VTs, EVT MemVT, const SDLoc &dl,
1668 MachineMemOperand *MMO,
1669 ISD::MemIndexType IndexType);
1670 LLVM_ABI SDValue getLoadFFVP(EVT VT, const SDLoc &DL, SDValue Chain,
1671 SDValue Ptr, SDValue Mask, SDValue EVL,
1672 MachineMemOperand *MMO);
1673
1675 EVT MemVT, MachineMemOperand *MMO);
1677 EVT MemVT, MachineMemOperand *MMO);
1678
1679 /// Construct a node to track a Value* through the backend.
1681
1682 /// Return an MDNodeSDNode which holds an MDNode.
1683 LLVM_ABI SDValue getMDNode(const MDNode *MD);
1684
1685 /// Return a bitcast using the SDLoc of the value operand, and casting to the
1686 /// provided type. Use getNode to set a custom SDLoc.
1688
1689 /// Return an AddrSpaceCastSDNode.
1691 unsigned SrcAS, unsigned DestAS);
1692
1693 /// Return a freeze using the SDLoc of the value operand.
1695
1696 /// Return an AssertAlignSDNode.
1698
1699 /// Swap N1 and N2 if Opcode is a commutative binary opcode
1700 /// and the canonical form expects the opposite order.
1701 LLVM_ABI void canonicalizeCommutativeBinop(unsigned Opcode, SDValue &N1,
1702 SDValue &N2) const;
1703
1704 /// Return the specified value casted to
1705 /// the target's desired shift amount type.
1707
1708 /// Expands a node with multiple results to an FP or vector libcall. The
1709 /// libcall is expected to take all the operands of the \p Node followed by
1710 /// output pointers for each of the results. \p CallRetResNo can be optionally
1711 /// set to indicate that one of the results comes from the libcall's return
1712 /// value.
1713 LLVM_ABI bool
1714 expandMultipleResultFPLibCall(RTLIB::Libcall LC, SDNode *Node,
1716 std::optional<unsigned> CallRetResNo = {});
1717
1718 /// Expand the specified \c ISD::VAARG node as the Legalize pass would.
1719 LLVM_ABI SDValue expandVAArg(SDNode *Node);
1720
1721 /// Expand the specified \c ISD::VACOPY node as the Legalize pass would.
1722 LLVM_ABI SDValue expandVACopy(SDNode *Node);
1723
1724 /// Return a GlobalAddress of the function from the current module with
1725 /// name matching the given ExternalSymbol. Additionally can provide the
1726 /// matched function.
1727 /// Panic if the function doesn't exist.
1729 SDValue Op, Function **TargetFunction = nullptr);
1730
1731 /// *Mutate* the specified node in-place to have the
1732 /// specified operands. If the resultant node already exists in the DAG,
1733 /// this does not modify the specified node, instead it returns the node that
1734 /// already exists. If the resultant node does not exist in the DAG, the
1735 /// input node is returned. As a degenerate case, if you specify the same
1736 /// input operands as the node already has, the input node is returned.
1737 LLVM_ABI SDNode *UpdateNodeOperands(SDNode *N, SDValue Op);
1738 LLVM_ABI SDNode *UpdateNodeOperands(SDNode *N, SDValue Op1, SDValue Op2);
1739 LLVM_ABI SDNode *UpdateNodeOperands(SDNode *N, SDValue Op1, SDValue Op2,
1740 SDValue Op3);
1741 LLVM_ABI SDNode *UpdateNodeOperands(SDNode *N, SDValue Op1, SDValue Op2,
1742 SDValue Op3, SDValue Op4);
1743 LLVM_ABI SDNode *UpdateNodeOperands(SDNode *N, SDValue Op1, SDValue Op2,
1744 SDValue Op3, SDValue Op4, SDValue Op5);
1745 LLVM_ABI SDNode *UpdateNodeOperands(SDNode *N, ArrayRef<SDValue> Ops);
1746
1747 /// Creates a new TokenFactor containing \p Vals. If \p Vals contains 64k
1748 /// values or more, move values into new TokenFactors in 64k-1 blocks, until
1749 /// the final TokenFactor has less than 64k operands.
1750 LLVM_ABI SDValue getTokenFactor(const SDLoc &DL,
1751 SmallVectorImpl<SDValue> &Vals);
1752
1753 /// *Mutate* the specified machine node's memory references to the provided
1754 /// list.
1755 LLVM_ABI void setNodeMemRefs(MachineSDNode *N,
1756 ArrayRef<MachineMemOperand *> NewMemRefs);
1757
1758 // Calculate divergence of node \p N based on its operands.
1759 LLVM_ABI bool calculateDivergence(SDNode *N);
1760
1761 // Propagates the change in divergence to users
1762 LLVM_ABI void updateDivergence(SDNode *N);
1763
1764 /// These are used for target selectors to *mutate* the
1765 /// specified node to have the specified return type, Target opcode, and
1766 /// operands. Note that target opcodes are stored as
1767 /// ~TargetOpcode in the node opcode field. The resultant node is returned.
1768 LLVM_ABI SDNode *SelectNodeTo(SDNode *N, unsigned MachineOpc, EVT VT);
1769 LLVM_ABI SDNode *SelectNodeTo(SDNode *N, unsigned MachineOpc, EVT VT,
1770 SDValue Op1);
1771 LLVM_ABI SDNode *SelectNodeTo(SDNode *N, unsigned MachineOpc, EVT VT,
1772 SDValue Op1, SDValue Op2);
1773 LLVM_ABI SDNode *SelectNodeTo(SDNode *N, unsigned MachineOpc, EVT VT,
1774 SDValue Op1, SDValue Op2, SDValue Op3);
1775 LLVM_ABI SDNode *SelectNodeTo(SDNode *N, unsigned MachineOpc, EVT VT,
1776 ArrayRef<SDValue> Ops);
1777 LLVM_ABI SDNode *SelectNodeTo(SDNode *N, unsigned MachineOpc, EVT VT1,
1778 EVT VT2);
1779 LLVM_ABI SDNode *SelectNodeTo(SDNode *N, unsigned MachineOpc, EVT VT1,
1780 EVT VT2, ArrayRef<SDValue> Ops);
1781 LLVM_ABI SDNode *SelectNodeTo(SDNode *N, unsigned MachineOpc, EVT VT1,
1782 EVT VT2, EVT VT3, ArrayRef<SDValue> Ops);
1783 LLVM_ABI SDNode *SelectNodeTo(SDNode *N, unsigned MachineOpc, EVT VT1,
1784 EVT VT2, SDValue Op1, SDValue Op2);
1785 LLVM_ABI SDNode *SelectNodeTo(SDNode *N, unsigned MachineOpc, SDVTList VTs,
1786 ArrayRef<SDValue> Ops);
1787
1788 /// This *mutates* the specified node to have the specified
1789 /// return type, opcode, and operands.
1790 LLVM_ABI SDNode *MorphNodeTo(SDNode *N, unsigned Opc, SDVTList VTs,
1791 ArrayRef<SDValue> Ops);
1792
1793 /// Mutate the specified strict FP node to its non-strict equivalent,
1794 /// unlinking the node from its chain and dropping the metadata arguments.
1795 /// The node must be a strict FP node.
1796 LLVM_ABI SDNode *mutateStrictFPToFP(SDNode *Node);
1797
1798 /// These are used for target selectors to create a new node
1799 /// with specified return type(s), MachineInstr opcode, and operands.
1800 ///
1801 /// Note that getMachineNode returns the resultant node. If there is already
1802 /// a node of the specified opcode and operands, it returns that node instead
1803 /// of the current one.
1804 LLVM_ABI MachineSDNode *getMachineNode(unsigned Opcode, const SDLoc &dl,
1805 EVT VT);
1806 LLVM_ABI MachineSDNode *getMachineNode(unsigned Opcode, const SDLoc &dl,
1807 EVT VT, SDValue Op1);
1808 LLVM_ABI MachineSDNode *getMachineNode(unsigned Opcode, const SDLoc &dl,
1809 EVT VT, SDValue Op1, SDValue Op2);
1810 LLVM_ABI MachineSDNode *getMachineNode(unsigned Opcode, const SDLoc &dl,
1811 EVT VT, SDValue Op1, SDValue Op2,
1812 SDValue Op3);
1813 LLVM_ABI MachineSDNode *getMachineNode(unsigned Opcode, const SDLoc &dl,
1814 EVT VT, ArrayRef<SDValue> Ops);
1815 LLVM_ABI MachineSDNode *getMachineNode(unsigned Opcode, const SDLoc &dl,
1816 EVT VT1, EVT VT2, SDValue Op1,
1817 SDValue Op2);
1818 LLVM_ABI MachineSDNode *getMachineNode(unsigned Opcode, const SDLoc &dl,
1819 EVT VT1, EVT VT2, SDValue Op1,
1820 SDValue Op2, SDValue Op3);
1821 LLVM_ABI MachineSDNode *getMachineNode(unsigned Opcode, const SDLoc &dl,
1822 EVT VT1, EVT VT2,
1823 ArrayRef<SDValue> Ops);
1824 LLVM_ABI MachineSDNode *getMachineNode(unsigned Opcode, const SDLoc &dl,
1825 EVT VT1, EVT VT2, EVT VT3, SDValue Op1,
1826 SDValue Op2);
1827 LLVM_ABI MachineSDNode *getMachineNode(unsigned Opcode, const SDLoc &dl,
1828 EVT VT1, EVT VT2, EVT VT3, SDValue Op1,
1829 SDValue Op2, SDValue Op3);
1830 LLVM_ABI MachineSDNode *getMachineNode(unsigned Opcode, const SDLoc &dl,
1831 EVT VT1, EVT VT2, EVT VT3,
1832 ArrayRef<SDValue> Ops);
1833 LLVM_ABI MachineSDNode *getMachineNode(unsigned Opcode, const SDLoc &dl,
1834 ArrayRef<EVT> ResultTys,
1835 ArrayRef<SDValue> Ops);
1836 LLVM_ABI MachineSDNode *getMachineNode(unsigned Opcode, const SDLoc &dl,
1837 SDVTList VTs, ArrayRef<SDValue> Ops);
1838
1839 /// A convenience function for creating TargetInstrInfo::EXTRACT_SUBREG nodes.
1840 LLVM_ABI SDValue getTargetExtractSubreg(int SRIdx, const SDLoc &DL, EVT VT,
1841 SDValue Operand);
1842
1843 /// A convenience function for creating TargetInstrInfo::INSERT_SUBREG nodes.
1844 LLVM_ABI SDValue getTargetInsertSubreg(int SRIdx, const SDLoc &DL, EVT VT,
1845 SDValue Operand, SDValue Subreg);
1846
1847 /// Get the specified node if it's already available, or else return NULL.
1848 LLVM_ABI SDNode *getNodeIfExists(unsigned Opcode, SDVTList VTList,
1849 ArrayRef<SDValue> Ops,
1850 const SDNodeFlags Flags);
1851 LLVM_ABI SDNode *getNodeIfExists(unsigned Opcode, SDVTList VTList,
1852 ArrayRef<SDValue> Ops);
1853
1854 /// Check if a node exists without modifying its flags.
1855 LLVM_ABI bool doesNodeExist(unsigned Opcode, SDVTList VTList,
1856 ArrayRef<SDValue> Ops);
1857
1858 /// Creates a SDDbgValue node.
1859 LLVM_ABI SDDbgValue *getDbgValue(DIVariable *Var, DIExpression *Expr,
1860 SDNode *N, unsigned R, bool IsIndirect,
1861 const DebugLoc &DL, unsigned O);
1862
1863 /// Creates a constant SDDbgValue node.
1864 LLVM_ABI SDDbgValue *getConstantDbgValue(DIVariable *Var, DIExpression *Expr,
1865 const Value *C, const DebugLoc &DL,
1866 unsigned O);
1867
1868 /// Creates a FrameIndex SDDbgValue node.
1869 LLVM_ABI SDDbgValue *getFrameIndexDbgValue(DIVariable *Var,
1870 DIExpression *Expr, unsigned FI,
1871 bool IsIndirect,
1872 const DebugLoc &DL, unsigned O);
1873
1874 /// Creates a FrameIndex SDDbgValue node.
1875 LLVM_ABI SDDbgValue *getFrameIndexDbgValue(DIVariable *Var,
1876 DIExpression *Expr, unsigned FI,
1877 ArrayRef<SDNode *> Dependencies,
1878 bool IsIndirect,
1879 const DebugLoc &DL, unsigned O);
1880
1881 /// Creates a VReg SDDbgValue node.
1882 LLVM_ABI SDDbgValue *getVRegDbgValue(DIVariable *Var, DIExpression *Expr,
1883 Register VReg, bool IsIndirect,
1884 const DebugLoc &DL, unsigned O);
1885
1886 /// Creates a SDDbgValue node from a list of locations.
1887 LLVM_ABI SDDbgValue *getDbgValueList(DIVariable *Var, DIExpression *Expr,
1888 ArrayRef<SDDbgOperand> Locs,
1889 ArrayRef<SDNode *> Dependencies,
1890 bool IsIndirect, const DebugLoc &DL,
1891 unsigned O, bool IsVariadic);
1892
1893 /// Creates a SDDbgLabel node.
1894 LLVM_ABI SDDbgLabel *getDbgLabel(DILabel *Label, const DebugLoc &DL,
1895 unsigned O);
1896
1897 /// Transfer debug values from one node to another, while optionally
1898 /// generating fragment expressions for split-up values. If \p InvalidateDbg
1899 /// is set, debug values are invalidated after they are transferred.
1900 LLVM_ABI void transferDbgValues(SDValue From, SDValue To,
1901 unsigned OffsetInBits = 0,
1902 unsigned SizeInBits = 0,
1903 bool InvalidateDbg = true);
1904
1905 /// Remove the specified node from the system. If any of its
1906 /// operands then becomes dead, remove them as well. Inform UpdateListener
1907 /// for each node deleted.
1908 LLVM_ABI void RemoveDeadNode(SDNode *N);
1909
1910 /// This method deletes the unreachable nodes in the
1911 /// given list, and any nodes that become unreachable as a result.
1912 LLVM_ABI void RemoveDeadNodes(SmallVectorImpl<SDNode *> &DeadNodes);
1913
1914 /// Modify anything using 'From' to use 'To' instead.
1915 /// This can cause recursive merging of nodes in the DAG. Use the first
1916 /// version if 'From' is known to have a single result, use the second
1917 /// if you have two nodes with identical results (or if 'To' has a superset
1918 /// of the results of 'From'), use the third otherwise.
1919 ///
1920 /// These methods all take an optional UpdateListener, which (if not null) is
1921 /// informed about nodes that are deleted and modified due to recursive
1922 /// changes in the dag.
1923 ///
1924 /// These functions only replace all existing uses. It's possible that as
1925 /// these replacements are being performed, CSE may cause the From node
1926 /// to be given new uses. These new uses of From are left in place, and
1927 /// not automatically transferred to To.
1928 ///
1929 LLVM_ABI void ReplaceAllUsesWith(SDValue From, SDValue To);
1930 LLVM_ABI void ReplaceAllUsesWith(SDNode *From, SDNode *To);
1931 LLVM_ABI void ReplaceAllUsesWith(SDNode *From, const SDValue *To);
1932
1933 /// Replace any uses of From with To, leaving
1934 /// uses of other values produced by From.getNode() alone.
1935 LLVM_ABI void ReplaceAllUsesOfValueWith(SDValue From, SDValue To);
1936
1937 /// Like ReplaceAllUsesOfValueWith, but for multiple values at once.
1938 /// This correctly handles the case where
1939 /// there is an overlap between the From values and the To values.
1940 LLVM_ABI void ReplaceAllUsesOfValuesWith(const SDValue *From,
1941 const SDValue *To, unsigned Num);
1942
1943 /// If an existing load has uses of its chain, create a token factor node with
1944 /// that chain and the new memory node's chain and update users of the old
1945 /// chain to the token factor. This ensures that the new memory node will have
1946 /// the same relative memory dependency position as the old load. Returns the
1947 /// new merged load chain.
1948 LLVM_ABI SDValue makeEquivalentMemoryOrdering(SDValue OldChain,
1949 SDValue NewMemOpChain);
1950
1951 /// If an existing load has uses of its chain, create a token factor node with
1952 /// that chain and the new memory node's chain and update users of the old
1953 /// chain to the token factor. This ensures that the new memory node will have
1954 /// the same relative memory dependency position as the old load. Returns the
1955 /// new merged load chain.
1956 LLVM_ABI SDValue makeEquivalentMemoryOrdering(LoadSDNode *OldLoad,
1957 SDValue NewMemOp);
1958
1959 /// Topological-sort the AllNodes list and a
1960 /// assign a unique node id for each node in the DAG based on their
1961 /// topological order. Returns the number of nodes.
1963
1964 /// Move node N in the AllNodes list to be immediately
1965 /// before the given iterator Position. This may be used to update the
1966 /// topological ordering when the list of nodes is modified.
1968 AllNodes.insert(Position, AllNodes.remove(N));
1969 }
1970
1971 /// Add a dbg_value SDNode. If SD is non-null that means the
1972 /// value is produced by SD.
1973 LLVM_ABI void AddDbgValue(SDDbgValue *DB, bool isParameter);
1974
1975 /// Add a dbg_label SDNode.
1977
1978 /// Get the debug values which reference the given SDNode.
1980 return DbgInfo->getSDDbgValues(SD);
1981 }
1982
1983public:
1984 /// Return true if there are any SDDbgValue nodes associated
1985 /// with this SelectionDAG.
1986 bool hasDebugValues() const { return !DbgInfo->empty(); }
1987
1988 SDDbgInfo::DbgIterator DbgBegin() const { return DbgInfo->DbgBegin(); }
1989 SDDbgInfo::DbgIterator DbgEnd() const { return DbgInfo->DbgEnd(); }
1990
1992 return DbgInfo->ByvalParmDbgBegin();
1993 }
1995 return DbgInfo->ByvalParmDbgEnd();
1996 }
1997
1999 return DbgInfo->DbgLabelBegin();
2000 }
2002 return DbgInfo->DbgLabelEnd();
2003 }
2004
2005 /// To be invoked on an SDNode that is slated to be erased. This
2006 /// function mirrors \c llvm::salvageDebugInfo.
2008
2009 LLVM_ABI void dump() const;
2010
2011 /// In most cases this function returns the ABI alignment for a given type,
2012 /// except for illegal vector types where the alignment exceeds that of the
2013 /// stack. In such cases we attempt to break the vector down to a legal type
2014 /// and return the ABI alignment for that instead.
2015 LLVM_ABI Align getReducedAlign(EVT VT, bool UseABI);
2016
2017 /// Create a stack temporary based on the size in bytes and the alignment
2019
2020 /// Create a stack temporary, suitable for holding the specified value type.
2021 /// If minAlign is specified, the slot size will have at least that alignment.
2022 LLVM_ABI SDValue CreateStackTemporary(EVT VT, unsigned minAlign = 1);
2023
2024 /// Create a stack temporary suitable for holding either of the specified
2025 /// value types.
2027
2028 LLVM_ABI SDValue FoldSymbolOffset(unsigned Opcode, EVT VT,
2029 const GlobalAddressSDNode *GA,
2030 const SDNode *N2);
2031
2032 LLVM_ABI SDValue FoldConstantArithmetic(unsigned Opcode, const SDLoc &DL,
2033 EVT VT, ArrayRef<SDValue> Ops,
2034 SDNodeFlags Flags = SDNodeFlags());
2035
2036 /// Fold floating-point operations when all operands are constants and/or
2037 /// undefined.
2038 LLVM_ABI SDValue foldConstantFPMath(unsigned Opcode, const SDLoc &DL, EVT VT,
2039 ArrayRef<SDValue> Ops);
2040
2041 /// Fold BUILD_VECTOR of constants/undefs to the destination type
2042 /// BUILD_VECTOR of constants/undefs elements.
2044 const SDLoc &DL, EVT DstEltVT);
2045
2046 /// Constant fold a setcc to true or false.
2048 const SDLoc &dl);
2049
2050 /// Return true if the sign bit of Op is known to be zero.
2051 /// We use this predicate to simplify operations downstream.
2052 LLVM_ABI bool SignBitIsZero(SDValue Op, unsigned Depth = 0) const;
2053
2054 /// Return true if 'Op & Mask' is known to be zero. We
2055 /// use this predicate to simplify operations downstream. Op and Mask are
2056 /// known to be the same type.
2057 LLVM_ABI bool MaskedValueIsZero(SDValue Op, const APInt &Mask,
2058 unsigned Depth = 0) const;
2059
2060 /// Return true if 'Op & Mask' is known to be zero in DemandedElts. We
2061 /// use this predicate to simplify operations downstream. Op and Mask are
2062 /// known to be the same type.
2063 LLVM_ABI bool MaskedValueIsZero(SDValue Op, const APInt &Mask,
2064 const APInt &DemandedElts,
2065 unsigned Depth = 0) const;
2066
2067 /// Return true if 'Op' is known to be zero in DemandedElts. We
2068 /// use this predicate to simplify operations downstream.
2069 LLVM_ABI bool MaskedVectorIsZero(SDValue Op, const APInt &DemandedElts,
2070 unsigned Depth = 0) const;
2071
2072 /// Return true if '(Op & Mask) == Mask'.
2073 /// Op and Mask are known to be the same type.
2074 LLVM_ABI bool MaskedValueIsAllOnes(SDValue Op, const APInt &Mask,
2075 unsigned Depth = 0) const;
2076
2077 /// For each demanded element of a vector, see if it is known to be zero.
2079 const APInt &DemandedElts,
2080 unsigned Depth = 0) const;
2081
2082 /// Determine which bits of Op are known to be either zero or one and return
2083 /// them in Known. For vectors, the known bits are those that are shared by
2084 /// every vector element.
2085 /// Targets can implement the computeKnownBitsForTargetNode method in the
2086 /// TargetLowering class to allow target nodes to be understood.
2087 LLVM_ABI KnownBits computeKnownBits(SDValue Op, unsigned Depth = 0) const;
2088
2089 /// Determine which bits of Op are known to be either zero or one and return
2090 /// them in Known. The DemandedElts argument allows us to only collect the
2091 /// known bits that are shared by the requested vector elements.
2092 /// Targets can implement the computeKnownBitsForTargetNode method in the
2093 /// TargetLowering class to allow target nodes to be understood.
2094 LLVM_ABI KnownBits computeKnownBits(SDValue Op, const APInt &DemandedElts,
2095 unsigned Depth = 0) const;
2096
2097 /// Used to represent the possible overflow behavior of an operation.
2098 /// Never: the operation cannot overflow.
2099 /// Always: the operation will always overflow.
2100 /// Sometime: the operation may or may not overflow.
2105 };
2106
2107 /// Determine if the result of the signed addition of 2 nodes can overflow.
2109 SDValue N1) const;
2110
2111 /// Determine if the result of the unsigned addition of 2 nodes can overflow.
2113 SDValue N1) const;
2114
2115 /// Determine if the result of the addition of 2 nodes can overflow.
2117 SDValue N1) const {
2118 return IsSigned ? computeOverflowForSignedAdd(N0, N1)
2120 }
2121
2122 /// Determine if the result of the addition of 2 nodes can never overflow.
2123 bool willNotOverflowAdd(bool IsSigned, SDValue N0, SDValue N1) const {
2124 return computeOverflowForAdd(IsSigned, N0, N1) == OFK_Never;
2125 }
2126
2127 /// Determine if the result of the signed sub of 2 nodes can overflow.
2129 SDValue N1) const;
2130
2131 /// Determine if the result of the unsigned sub of 2 nodes can overflow.
2133 SDValue N1) const;
2134
2135 /// Determine if the result of the sub of 2 nodes can overflow.
2137 SDValue N1) const {
2138 return IsSigned ? computeOverflowForSignedSub(N0, N1)
2140 }
2141
2142 /// Determine if the result of the sub of 2 nodes can never overflow.
2143 bool willNotOverflowSub(bool IsSigned, SDValue N0, SDValue N1) const {
2144 return computeOverflowForSub(IsSigned, N0, N1) == OFK_Never;
2145 }
2146
2147 /// Determine if the result of the signed mul of 2 nodes can overflow.
2149 SDValue N1) const;
2150
2151 /// Determine if the result of the unsigned mul of 2 nodes can overflow.
2153 SDValue N1) const;
2154
2155 /// Determine if the result of the mul of 2 nodes can overflow.
2157 SDValue N1) const {
2158 return IsSigned ? computeOverflowForSignedMul(N0, N1)
2160 }
2161
2162 /// Determine if the result of the mul of 2 nodes can never overflow.
2163 bool willNotOverflowMul(bool IsSigned, SDValue N0, SDValue N1) const {
2164 return computeOverflowForMul(IsSigned, N0, N1) == OFK_Never;
2165 }
2166
2167 /// Test if the given value is known to have exactly one bit set. This differs
2168 /// from computeKnownBits in that it doesn't necessarily determine which bit
2169 /// is set.
2170 LLVM_ABI bool isKnownToBeAPowerOfTwo(SDValue Val, unsigned Depth = 0) const;
2171
2172 /// Test if the given _fp_ value is known to be an integer power-of-2, either
2173 /// positive or negative.
2174 LLVM_ABI bool isKnownToBeAPowerOfTwoFP(SDValue Val, unsigned Depth = 0) const;
2175
2176 /// Return the number of times the sign bit of the register is replicated into
2177 /// the other bits. We know that at least 1 bit is always equal to the sign
2178 /// bit (itself), but other cases can give us information. For example,
2179 /// immediately after an "SRA X, 2", we know that the top 3 bits are all equal
2180 /// to each other, so we return 3. Targets can implement the
2181 /// ComputeNumSignBitsForTarget method in the TargetLowering class to allow
2182 /// target nodes to be understood.
2183 LLVM_ABI unsigned ComputeNumSignBits(SDValue Op, unsigned Depth = 0) const;
2184
2185 /// Return the number of times the sign bit of the register is replicated into
2186 /// the other bits. We know that at least 1 bit is always equal to the sign
2187 /// bit (itself), but other cases can give us information. For example,
2188 /// immediately after an "SRA X, 2", we know that the top 3 bits are all equal
2189 /// to each other, so we return 3. The DemandedElts argument allows
2190 /// us to only collect the minimum sign bits of the requested vector elements.
2191 /// Targets can implement the ComputeNumSignBitsForTarget method in the
2192 /// TargetLowering class to allow target nodes to be understood.
2193 LLVM_ABI unsigned ComputeNumSignBits(SDValue Op, const APInt &DemandedElts,
2194 unsigned Depth = 0) const;
2195
2196 /// Get the upper bound on bit size for this Value \p Op as a signed integer.
2197 /// i.e. x == sext(trunc(x to MaxSignedBits) to bitwidth(x)).
2198 /// Similar to the APInt::getSignificantBits function.
2199 /// Helper wrapper to ComputeNumSignBits.
2201 unsigned Depth = 0) const;
2202
2203 /// Get the upper bound on bit size for this Value \p Op as a signed integer.
2204 /// i.e. x == sext(trunc(x to MaxSignedBits) to bitwidth(x)).
2205 /// Similar to the APInt::getSignificantBits function.
2206 /// Helper wrapper to ComputeNumSignBits.
2208 const APInt &DemandedElts,
2209 unsigned Depth = 0) const;
2210
2211 /// Return true if this function can prove that \p Op is never poison
2212 /// and, if \p PoisonOnly is false, does not have undef bits.
2214 bool PoisonOnly = false,
2215 unsigned Depth = 0) const;
2216
2217 /// Return true if this function can prove that \p Op is never poison
2218 /// and, if \p PoisonOnly is false, does not have undef bits. The DemandedElts
2219 /// argument limits the check to the requested vector elements.
2221 const APInt &DemandedElts,
2222 bool PoisonOnly = false,
2223 unsigned Depth = 0) const;
2224
2225 /// Return true if this function can prove that \p Op is never poison.
2226 bool isGuaranteedNotToBePoison(SDValue Op, unsigned Depth = 0) const {
2227 return isGuaranteedNotToBeUndefOrPoison(Op, /*PoisonOnly*/ true, Depth);
2228 }
2229
2230 /// Return true if this function can prove that \p Op is never poison. The
2231 /// DemandedElts argument limits the check to the requested vector elements.
2232 bool isGuaranteedNotToBePoison(SDValue Op, const APInt &DemandedElts,
2233 unsigned Depth = 0) const {
2234 return isGuaranteedNotToBeUndefOrPoison(Op, DemandedElts,
2235 /*PoisonOnly*/ true, Depth);
2236 }
2237
2238 /// Return true if Op can create undef or poison from non-undef & non-poison
2239 /// operands. The DemandedElts argument limits the check to the requested
2240 /// vector elements.
2241 ///
2242 /// \p ConsiderFlags controls whether poison producing flags on the
2243 /// instruction are considered. This can be used to see if the instruction
2244 /// could still introduce undef or poison even without poison generating flags
2245 /// which might be on the instruction. (i.e. could the result of
2246 /// Op->dropPoisonGeneratingFlags() still create poison or undef)
2247 LLVM_ABI bool canCreateUndefOrPoison(SDValue Op, const APInt &DemandedElts,
2248 bool PoisonOnly = false,
2249 bool ConsiderFlags = true,
2250 unsigned Depth = 0) const;
2251
2252 /// Return true if Op can create undef or poison from non-undef & non-poison
2253 /// operands.
2254 ///
2255 /// \p ConsiderFlags controls whether poison producing flags on the
2256 /// instruction are considered. This can be used to see if the instruction
2257 /// could still introduce undef or poison even without poison generating flags
2258 /// which might be on the instruction. (i.e. could the result of
2259 /// Op->dropPoisonGeneratingFlags() still create poison or undef)
2261 bool ConsiderFlags = true,
2262 unsigned Depth = 0) const;
2263
2264 /// Return true if the specified operand is an ISD::OR or ISD::XOR node
2265 /// that can be treated as an ISD::ADD node.
2266 /// or(x,y) == add(x,y) iff haveNoCommonBitsSet(x,y)
2267 /// xor(x,y) == add(x,y) iff isMinSignedConstant(y) && !NoWrap
2268 /// If \p NoWrap is true, this will not match ISD::XOR.
2269 LLVM_ABI bool isADDLike(SDValue Op, bool NoWrap = false) const;
2270
2271 /// Return true if the specified operand is an ISD::ADD with a ConstantSDNode
2272 /// on the right-hand side, or if it is an ISD::OR with a ConstantSDNode that
2273 /// is guaranteed to have the same semantics as an ADD. This handles the
2274 /// equivalence:
2275 /// X|Cst == X+Cst iff X&Cst = 0.
2277
2278 /// Test whether the given SDValue (or all elements of it, if it is a
2279 /// vector) is known to never be NaN in \p DemandedElts. If \p SNaN is true,
2280 /// returns if \p Op is known to never be a signaling NaN (it may still be a
2281 /// qNaN).
2282 LLVM_ABI bool isKnownNeverNaN(SDValue Op, const APInt &DemandedElts,
2283 bool SNaN = false, unsigned Depth = 0) const;
2284
2285 /// Test whether the given SDValue (or all elements of it, if it is a
2286 /// vector) is known to never be NaN. If \p SNaN is true, returns if \p Op is
2287 /// known to never be a signaling NaN (it may still be a qNaN).
2288 LLVM_ABI bool isKnownNeverNaN(SDValue Op, bool SNaN = false,
2289 unsigned Depth = 0) const;
2290
2291 /// \returns true if \p Op is known to never be a signaling NaN in \p
2292 /// DemandedElts.
2293 bool isKnownNeverSNaN(SDValue Op, const APInt &DemandedElts,
2294 unsigned Depth = 0) const {
2295 return isKnownNeverNaN(Op, DemandedElts, true, Depth);
2296 }
2297
2298 /// \returns true if \p Op is known to never be a signaling NaN.
2299 bool isKnownNeverSNaN(SDValue Op, unsigned Depth = 0) const {
2300 return isKnownNeverNaN(Op, true, Depth);
2301 }
2302
2303 /// Test whether the given floating point SDValue is known to never be
2304 /// positive or negative zero.
2306
2307 /// Test whether the given SDValue is known to contain non-zero value(s).
2308 LLVM_ABI bool isKnownNeverZero(SDValue Op, unsigned Depth = 0) const;
2309
2310 /// Test whether the given float value is known to be positive. +0.0, +inf and
2311 /// +nan are considered positive, -0.0, -inf and -nan are not.
2313
2314 /// Test whether two SDValues are known to compare equal. This
2315 /// is true if they are the same value, or if one is negative zero and the
2316 /// other positive zero.
2317 LLVM_ABI bool isEqualTo(SDValue A, SDValue B) const;
2318
2319 /// Return true if A and B have no common bits set. As an example, this can
2320 /// allow an 'add' to be transformed into an 'or'.
2322
2323 /// Test whether \p V has a splatted value for all the demanded elements.
2324 ///
2325 /// On success \p UndefElts will indicate the elements that have UNDEF
2326 /// values instead of the splat value, this is only guaranteed to be correct
2327 /// for \p DemandedElts.
2328 ///
2329 /// NOTE: The function will return true for a demanded splat of UNDEF values.
2330 LLVM_ABI bool isSplatValue(SDValue V, const APInt &DemandedElts,
2331 APInt &UndefElts, unsigned Depth = 0) const;
2332
2333 /// Test whether \p V has a splatted value.
2334 LLVM_ABI bool isSplatValue(SDValue V, bool AllowUndefs = false) const;
2335
2336 /// If V is a splatted value, return the source vector and its splat index.
2337 LLVM_ABI SDValue getSplatSourceVector(SDValue V, int &SplatIndex);
2338
2339 /// If V is a splat vector, return its scalar source operand by extracting
2340 /// that element from the source vector. If LegalTypes is true, this method
2341 /// may only return a legally-typed splat value. If it cannot legalize the
2342 /// splatted value it will return SDValue().
2343 LLVM_ABI SDValue getSplatValue(SDValue V, bool LegalTypes = false);
2344
2345 /// If a SHL/SRA/SRL node \p V has shift amounts that are all less than the
2346 /// element bit-width of the shift node, return the valid constant range.
2347 LLVM_ABI std::optional<ConstantRange>
2348 getValidShiftAmountRange(SDValue V, const APInt &DemandedElts,
2349 unsigned Depth) const;
2350
2351 /// If a SHL/SRA/SRL node \p V has a uniform shift amount
2352 /// that is less than the element bit-width of the shift node, return it.
2353 LLVM_ABI std::optional<uint64_t>
2354 getValidShiftAmount(SDValue V, const APInt &DemandedElts,
2355 unsigned Depth = 0) const;
2356
2357 /// If a SHL/SRA/SRL node \p V has a uniform shift amount
2358 /// that is less than the element bit-width of the shift node, return it.
2359 LLVM_ABI std::optional<uint64_t>
2360 getValidShiftAmount(SDValue V, unsigned Depth = 0) const;
2361
2362 /// If a SHL/SRA/SRL node \p V has shift amounts that are all less than the
2363 /// element bit-width of the shift node, return the minimum possible value.
2364 LLVM_ABI std::optional<uint64_t>
2365 getValidMinimumShiftAmount(SDValue V, const APInt &DemandedElts,
2366 unsigned Depth = 0) const;
2367
2368 /// If a SHL/SRA/SRL node \p V has shift amounts that are all less than the
2369 /// element bit-width of the shift node, return the minimum possible value.
2370 LLVM_ABI std::optional<uint64_t>
2371 getValidMinimumShiftAmount(SDValue V, unsigned Depth = 0) const;
2372
2373 /// If a SHL/SRA/SRL node \p V has shift amounts that are all less than the
2374 /// element bit-width of the shift node, return the maximum possible value.
2375 LLVM_ABI std::optional<uint64_t>
2376 getValidMaximumShiftAmount(SDValue V, const APInt &DemandedElts,
2377 unsigned Depth = 0) const;
2378
2379 /// If a SHL/SRA/SRL node \p V has shift amounts that are all less than the
2380 /// element bit-width of the shift node, return the maximum possible value.
2381 LLVM_ABI std::optional<uint64_t>
2382 getValidMaximumShiftAmount(SDValue V, unsigned Depth = 0) const;
2383
2384 /// Match a binop + shuffle pyramid that represents a horizontal reduction
2385 /// over the elements of a vector starting from the EXTRACT_VECTOR_ELT node /p
2386 /// Extract. The reduction must use one of the opcodes listed in /p
2387 /// CandidateBinOps and on success /p BinOp will contain the matching opcode.
2388 /// Returns the vector that is being reduced on, or SDValue() if a reduction
2389 /// was not matched. If \p AllowPartials is set then in the case of a
2390 /// reduction pattern that only matches the first few stages, the extracted
2391 /// subvector of the start of the reduction is returned.
2393 ArrayRef<ISD::NodeType> CandidateBinOps,
2394 bool AllowPartials = false);
2395
2396 /// Utility function used by legalize and lowering to
2397 /// "unroll" a vector operation by splitting out the scalars and operating
2398 /// on each element individually. If the ResNE is 0, fully unroll the vector
2399 /// op. If ResNE is less than the width of the vector op, unroll up to ResNE.
2400 /// If the ResNE is greater than the width of the vector op, unroll the
2401 /// vector op and fill the end of the resulting vector with UNDEFS.
2402 LLVM_ABI SDValue UnrollVectorOp(SDNode *N, unsigned ResNE = 0);
2403
2404 /// Like UnrollVectorOp(), but for the [US](ADD|SUB|MUL)O family of opcodes.
2405 /// This is a separate function because those opcodes have two results.
2406 LLVM_ABI std::pair<SDValue, SDValue>
2407 UnrollVectorOverflowOp(SDNode *N, unsigned ResNE = 0);
2408
2409 /// Return true if loads are next to each other and can be
2410 /// merged. Check that both are nonvolatile and if LD is loading
2411 /// 'Bytes' bytes from a location that is 'Dist' units away from the
2412 /// location that the 'Base' load is loading from.
2414 unsigned Bytes, int Dist) const;
2415
2416 /// Infer alignment of a load / store address. Return std::nullopt if it
2417 /// cannot be inferred.
2419
2420 /// Split the scalar node with EXTRACT_ELEMENT using the provided VTs and
2421 /// return the low/high part.
2422 LLVM_ABI std::pair<SDValue, SDValue> SplitScalar(const SDValue &N,
2423 const SDLoc &DL,
2424 const EVT &LoVT,
2425 const EVT &HiVT);
2426
2427 /// Compute the VTs needed for the low/hi parts of a type
2428 /// which is split (or expanded) into two not necessarily identical pieces.
2429 LLVM_ABI std::pair<EVT, EVT> GetSplitDestVTs(const EVT &VT) const;
2430
2431 /// Compute the VTs needed for the low/hi parts of a type, dependent on an
2432 /// enveloping VT that has been split into two identical pieces. Sets the
2433 /// HisIsEmpty flag when hi type has zero storage size.
2434 LLVM_ABI std::pair<EVT, EVT> GetDependentSplitDestVTs(const EVT &VT,
2435 const EVT &EnvVT,
2436 bool *HiIsEmpty) const;
2437
2438 /// Split the vector with EXTRACT_SUBVECTOR using the provided
2439 /// VTs and return the low/high part.
2440 LLVM_ABI std::pair<SDValue, SDValue> SplitVector(const SDValue &N,
2441 const SDLoc &DL,
2442 const EVT &LoVT,
2443 const EVT &HiVT);
2444
2445 /// Split the vector with EXTRACT_SUBVECTOR and return the low/high part.
2446 std::pair<SDValue, SDValue> SplitVector(const SDValue &N, const SDLoc &DL) {
2447 EVT LoVT, HiVT;
2448 std::tie(LoVT, HiVT) = GetSplitDestVTs(N.getValueType());
2449 return SplitVector(N, DL, LoVT, HiVT);
2450 }
2451
2452 /// Split the explicit vector length parameter of a VP operation.
2453 LLVM_ABI std::pair<SDValue, SDValue> SplitEVL(SDValue N, EVT VecVT,
2454 const SDLoc &DL);
2455
2456 /// Split the node's operand with EXTRACT_SUBVECTOR and
2457 /// return the low/high part.
2458 std::pair<SDValue, SDValue> SplitVectorOperand(const SDNode *N, unsigned OpNo)
2459 {
2460 return SplitVector(N->getOperand(OpNo), SDLoc(N));
2461 }
2462
2463 /// Widen the vector up to the next power of two using INSERT_SUBVECTOR.
2464 LLVM_ABI SDValue WidenVector(const SDValue &N, const SDLoc &DL);
2465
2466 /// Append the extracted elements from Start to Count out of the vector Op in
2467 /// Args. If Count is 0, all of the elements will be extracted. The extracted
2468 /// elements will have type EVT if it is provided, and otherwise their type
2469 /// will be Op's element type.
2472 unsigned Start = 0, unsigned Count = 0,
2473 EVT EltVT = EVT());
2474
2475 /// Compute the default alignment value for the given type.
2476 LLVM_ABI Align getEVTAlign(EVT MemoryVT) const;
2477
2478 /// Test whether the given value is a constant int or similar node.
2479 LLVM_ABI bool
2481 bool AllowOpaques = true) const;
2482
2483 /// Test whether the given value is a constant FP or similar node.
2485
2486 /// \returns true if \p N is any kind of constant or build_vector of
2487 /// constants, int or float. If a vector, it may not necessarily be a splat.
2491 }
2492
2493 /// Check if a value \op N is a constant using the target's BooleanContent for
2494 /// its type.
2495 LLVM_ABI std::optional<bool> isBoolConstant(SDValue N) const;
2496
2497 /// Set CallSiteInfo to be associated with Node.
2499 SDEI[Node].CSInfo = std::move(CallInfo);
2500 }
2501 /// Return CallSiteInfo associated with Node, or a default if none exists.
2503 auto I = SDEI.find(Node);
2504 return I != SDEI.end() ? std::move(I->second).CSInfo : CallSiteInfo();
2505 }
2506 /// Set HeapAllocSite to be associated with Node.
2508 SDEI[Node].HeapAllocSite = MD;
2509 }
2510 /// Return HeapAllocSite associated with Node, or nullptr if none exists.
2512 auto I = SDEI.find(Node);
2513 return I != SDEI.end() ? I->second.HeapAllocSite : nullptr;
2514 }
2515 /// Set PCSections to be associated with Node.
2516 void addPCSections(const SDNode *Node, MDNode *MD) {
2517 SDEI[Node].PCSections = MD;
2518 }
2519 /// Set MMRAMetadata to be associated with Node.
2520 void addMMRAMetadata(const SDNode *Node, MDNode *MMRA) {
2521 SDEI[Node].MMRA = MMRA;
2522 }
2523 /// Return PCSections associated with Node, or nullptr if none exists.
2525 auto It = SDEI.find(Node);
2526 return It != SDEI.end() ? It->second.PCSections : nullptr;
2527 }
2528 /// Return the MMRA MDNode associated with Node, or nullptr if none
2529 /// exists.
2531 auto It = SDEI.find(Node);
2532 return It != SDEI.end() ? It->second.MMRA : nullptr;
2533 }
2534 /// Set CalledGlobal to be associated with Node.
2535 void addCalledGlobal(const SDNode *Node, const GlobalValue *GV,
2536 unsigned OpFlags) {
2537 SDEI[Node].CalledGlobal = {GV, OpFlags};
2538 }
2539 /// Return CalledGlobal associated with Node, or a nullopt if none exists.
2540 std::optional<CalledGlobalInfo> getCalledGlobal(const SDNode *Node) {
2541 auto I = SDEI.find(Node);
2542 return I != SDEI.end()
2543 ? std::make_optional(std::move(I->second).CalledGlobal)
2544 : std::nullopt;
2545 }
2546 /// Set NoMergeSiteInfo to be associated with Node if NoMerge is true.
2547 void addNoMergeSiteInfo(const SDNode *Node, bool NoMerge) {
2548 if (NoMerge)
2549 SDEI[Node].NoMerge = NoMerge;
2550 }
2551 /// Return NoMerge info associated with Node.
2552 bool getNoMergeSiteInfo(const SDNode *Node) const {
2553 auto I = SDEI.find(Node);
2554 return I != SDEI.end() ? I->second.NoMerge : false;
2555 }
2556
2557 /// Copy extra info associated with one node to another.
2559
2560 /// Return the current function's default denormal handling kind for the given
2561 /// floating point type.
2563 return MF->getDenormalMode(VT.getFltSemantics());
2564 }
2565
2566 LLVM_ABI bool shouldOptForSize() const;
2567
2568 /// Get the (commutative) neutral element for the given opcode, if it exists.
2569 LLVM_ABI SDValue getNeutralElement(unsigned Opcode, const SDLoc &DL, EVT VT,
2570 SDNodeFlags Flags);
2571
2572 /// Some opcodes may create immediate undefined behavior when used with some
2573 /// values (integer division-by-zero for example). Therefore, these operations
2574 /// are not generally safe to move around or change.
2575 bool isSafeToSpeculativelyExecute(unsigned Opcode) const {
2576 switch (Opcode) {
2577 case ISD::SDIV:
2578 case ISD::SREM:
2579 case ISD::SDIVREM:
2580 case ISD::UDIV:
2581 case ISD::UREM:
2582 case ISD::UDIVREM:
2583 return false;
2584 default:
2585 return true;
2586 }
2587 }
2588
2589 /// Check if the provided node is save to speculatively executed given its
2590 /// current arguments. So, while `udiv` the opcode is not safe to
2591 /// speculatively execute, a given `udiv` node may be if the denominator is
2592 /// known nonzero.
2594 switch (N->getOpcode()) {
2595 case ISD::UDIV:
2596 return isKnownNeverZero(N->getOperand(1));
2597 default:
2598 return isSafeToSpeculativelyExecute(N->getOpcode());
2599 }
2600 }
2601
2603 SDValue InChain, const SDLoc &DLoc);
2604
2605private:
2606#ifndef NDEBUG
2607 void verifyNode(SDNode *N) const;
2608#endif
2609 void InsertNode(SDNode *N);
2610 bool RemoveNodeFromCSEMaps(SDNode *N);
2611 void AddModifiedNodeToCSEMaps(SDNode *N);
2612 SDNode *FindModifiedNodeSlot(SDNode *N, SDValue Op, void *&InsertPos);
2613 SDNode *FindModifiedNodeSlot(SDNode *N, SDValue Op1, SDValue Op2,
2614 void *&InsertPos);
2615 SDNode *FindModifiedNodeSlot(SDNode *N, ArrayRef<SDValue> Ops,
2616 void *&InsertPos);
2617 SDNode *UpdateSDLocOnMergeSDNode(SDNode *N, const SDLoc &loc);
2618
2619 void DeleteNodeNotInCSEMaps(SDNode *N);
2620 void DeallocateNode(SDNode *N);
2621
2622 void allnodes_clear();
2623
2624 /// Look up the node specified by ID in CSEMap. If it exists, return it. If
2625 /// not, return the insertion token that will make insertion faster. This
2626 /// overload is for nodes other than Constant or ConstantFP, use the other one
2627 /// for those.
2628 SDNode *FindNodeOrInsertPos(const FoldingSetNodeID &ID, void *&InsertPos);
2629
2630 /// Look up the node specified by ID in CSEMap. If it exists, return it. If
2631 /// not, return the insertion token that will make insertion faster. Performs
2632 /// additional processing for constant nodes.
2633 SDNode *FindNodeOrInsertPos(const FoldingSetNodeID &ID, const SDLoc &DL,
2634 void *&InsertPos);
2635
2636 /// Maps to auto-CSE operations.
2637 std::vector<CondCodeSDNode*> CondCodeNodes;
2638
2639 std::vector<SDNode*> ValueTypeNodes;
2640 std::map<EVT, SDNode*, EVT::compareRawBits> ExtendedValueTypeNodes;
2641 StringMap<SDNode*> ExternalSymbols;
2642
2643 std::map<std::pair<std::string, unsigned>, SDNode *> TargetExternalSymbols;
2645
2646 FlagInserter *Inserter = nullptr;
2647};
2648
2649template <> struct GraphTraits<SelectionDAG*> : public GraphTraits<SDNode*> {
2651
2653 return nodes_iterator(G->allnodes_begin());
2654 }
2655
2657 return nodes_iterator(G->allnodes_end());
2658 }
2659};
2660
2661} // end namespace llvm
2662
2663#endif // LLVM_CODEGEN_SELECTIONDAG_H
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
This file defines the StringMap class.
MachineBasicBlock & MBB
MachineBasicBlock MachineBasicBlock::iterator DebugLoc DL
Function Alias Analysis Results
This file defines the BumpPtrAllocator interface.
BlockVerifier::State From
static GCRegistry::Add< OcamlGC > B("ocaml", "ocaml 3.10-compatible GC")
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")
RelocType Type
Definition: COFFYAML.cpp:410
#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:638
Returns the sub type a function will return at a given Idx Should correspond to the result type of an ExtractValue instruction executed with just that one unsigned Idx
This file defines the DenseMap class.
This file defines the DenseSet and SmallDenseSet classes.
uint32_t Index
uint64_t Size
Symbol * Sym
Definition: ELF_riscv.cpp:479
static GCMetadataPrinterRegistry::Add< ErlangGCPrinter > X("erlang", "erlang-compatible garbage collector")
This file defines a hash set that can be used to remove duplication of nodes in a graph.
Hexagon Vector Combine
#define I(x, y, z)
Definition: MD5.cpp:58
#define G(x, y, z)
Definition: MD5.cpp:56
Register Reg
Promote Memory to Register
Definition: Mem2Reg.cpp:110
This file contains the declarations for metadata subclasses.
static GCMetadataPrinterRegistry::Add< OcamlGCMetadataPrinter > Y("ocaml", "ocaml 3.10-compatible collector")
const SmallVectorImpl< MachineOperand > & Cond
Shrink Wrap Pass
Definition: ShrinkWrap.cpp:301
This file defines the SmallVector class.
static void removeOperands(MachineInstr &MI, unsigned i)
Value * RHS
Value * LHS
Class for arbitrary precision integers.
Definition: APInt.h:78
A container for analyses that lazily runs them and caches their results.
Definition: PassManager.h:255
static Capacity get(size_t N)
Get the capacity of an array that can hold at least N elements.
Definition: ArrayRecycler.h:79
Recycle small arrays allocated from a BumpPtrAllocator.
Definition: ArrayRecycler.h:28
void deallocate(Capacity Cap, T *Ptr)
Deallocate an array with the specified Capacity.
ArrayRef - Represent a constant reference to an array (0 or more elements consecutively in memory),...
Definition: ArrayRef.h:41
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:899
BlockFrequencyInfo pass uses BlockFrequencyInfoImpl implementation to estimate IR basic block frequen...
A "pseudo-class" with methods for operating on BUILD_VECTORs.
Allocate memory in an ever growing pool, as if by bump-pointer.
Definition: Allocator.h:67
This class represents a function call, abstracting a target machine's calling convention.
ConstantFP - Floating Point Values [float, double].
Definition: Constants.h:277
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
This class represents an Operation in the Expression.
A parsed version of the target data layout string in and methods for querying it.
Definition: DataLayout.h:63
A debug info location.
Definition: DebugLoc.h:124
iterator find(const_arg_type_t< KeyT > Val)
Definition: DenseMap.h:177
iterator end()
Definition: DenseMap.h:87
Implements a dense probed hash-table based set.
Definition: DenseSet.h:263
Node - This class is used to maintain the singly linked bucket list in a folding set.
Definition: FoldingSet.h:139
FoldingSetNodeIDRef - This class describes a reference to an interned FoldingSetNodeID,...
Definition: FoldingSet.h:293
FoldingSetNodeID - This class is used to gather all the unique data bits of a node.
Definition: FoldingSet.h:330
FoldingSet - This template class is used to instantiate a specialized implementation of the folding s...
Definition: FoldingSet.h:539
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
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:1077
Abstract base class for all machine specific constantpool value subclasses.
const TargetSubtargetInfo & getSubtarget() const
getSubtarget - Return the subtarget for which this machine code is being compiled.
DenormalMode getDenormalMode(const fltSemantics &FPType) const
Returns the denormal handling type for the default rounding mode of the function.
const DataLayout & getDataLayout() const
Return the DataLayout attached to the Module associated to this MF.
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.
The optimization diagnostic interface.
Pass interface - Implemented by all 'passes'.
Definition: Pass.h:99
Analysis providing profile information.
Wrapper class representing virtual and physical registers.
Definition: Register.h:19
Keeps track of dbg_value information through SDISel.
Definition: SelectionDAG.h:163
BumpPtrAllocator & getAlloc()
Definition: SelectionDAG.h:192
DbgIterator ByvalParmDbgBegin()
Definition: SelectionDAG.h:210
DbgIterator DbgEnd()
Definition: SelectionDAG.h:209
SDDbgInfo & operator=(const SDDbgInfo &)=delete
SmallVectorImpl< SDDbgLabel * >::iterator DbgLabelIterator
Definition: SelectionDAG.h:206
SDDbgInfo()=default
LLVM_ABI void add(SDDbgValue *V, bool isParameter)
bool empty() const
Definition: SelectionDAG.h:194
DbgLabelIterator DbgLabelEnd()
Definition: SelectionDAG.h:213
DbgIterator ByvalParmDbgEnd()
Definition: SelectionDAG.h:211
SmallVectorImpl< SDDbgValue * >::iterator DbgIterator
Definition: SelectionDAG.h:205
SDDbgInfo(const SDDbgInfo &)=delete
DbgLabelIterator DbgLabelBegin()
Definition: SelectionDAG.h:212
void add(SDDbgLabel *L)
Definition: SelectionDAG.h:178
DbgIterator DbgBegin()
Definition: SelectionDAG.h:208
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
Definition: SelectionDAG.h:198
Holds the information from a dbg_label node through SDISel.
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.
SDVTListNode(const FoldingSetNodeIDRef ID, const EVT *VT, unsigned int Num)
Definition: SelectionDAG.h:116
SDVTList getSDVTList()
Definition: SelectionDAG.h:121
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.
Definition: SelectionDAG.h:372
SDNodeFlags getFlags() const
Definition: SelectionDAG.h:390
FlagInserter(SelectionDAG &SDAG, SDNodeFlags Flags)
Definition: SelectionDAG.h:378
FlagInserter(const FlagInserter &)=delete
FlagInserter(SelectionDAG &SDAG, SDNode *N)
Definition: SelectionDAG.h:383
FlagInserter & operator=(const FlagInserter &)=delete
This is used to represent a portion of an LLVM function in a low-level Data Dependence DAG representa...
Definition: SelectionDAG.h:229
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.
Definition: SelectionDAG.h:995
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 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)
Definition: SelectionDAG.h:758
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)
Definition: SelectionDAG.h:848
SDValue getExtractVectorElt(const SDLoc &DL, EVT VT, SDValue Vec, unsigned Idx)
Extract element at Idx from Vec.
Definition: SelectionDAG.h:941
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.
Definition: SelectionDAG.h:578
LLVM_ABI SDValue getMaskedGather(SDVTList VTs, EVT MemVT, const SDLoc &dl, ArrayRef< SDValue > Ops, MachineMemOperand *MMO, ISD::MemIndexType IndexType, ISD::LoadExtType ExtTy)
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.
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
Definition: SelectionDAG.h:500
SDValue getCopyToReg(SDValue Chain, const SDLoc &dl, Register Reg, SDValue N)
Definition: SelectionDAG.h:813
const Pass * getPass() const
Definition: SelectionDAG.h:494
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
Definition: SelectionDAG.h:512
BlockFrequencyInfo * getBFI() const
Definition: SelectionDAG.h:514
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 FoldSetCC(EVT VT, SDValue N1, SDValue N2, ISD::CondCode Cond, const SDLoc &dl)
Constant fold a setcc to true or false.
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 getNeutralElement(unsigned Opcode, const SDLoc &DL, EVT VT, SDNodeFlags Flags)
Get the (commutative) neutral element for the given opcode, if it exists.
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 ...
SDValue getTargetConstantFP(const APFloat &Val, const SDLoc &DL, EVT VT)
Definition: SelectionDAG.h:746
LLVM_ABI SDValue getVScale(const SDLoc &DL, EVT VT, APInt MulImm, bool ConstantFold=true)
Return a node that represents the runtime scaling 'MulImm * RuntimeVL'.
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 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
Definition: SelectionDAG.h:515
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)
SDValue getSetCC(const SDLoc &DL, EVT VT, SDValue LHS, SDValue RHS, ISD::CondCode Cond, SDValue Chain=SDValue(), bool IsSignaling=false)
Helper function to make it easier to build SetCC's if you just have an ISD::CondCode instead of an SD...
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.
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, UniformityInfo *UA, ProfileSummaryInfo *PSIin, BlockFrequencyInfo *BFIin, MachineModuleInfo &MMI, FunctionVarLocs const *FnVarLocs)
Definition: SelectionDAG.h:476
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
void setFunctionLoweringInfo(FunctionLoweringInfo *FuncInfo)
Definition: SelectionDAG.h:485
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.
Definition: SelectionDAG.h:963
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 SDValue getElementCount(const SDLoc &DL, EVT VT, ElementCount EC, bool ConstantFold=true)
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,...
SDValue getGLOBAL_OFFSET_TABLE(EVT VT)
Return a GLOBAL_OFFSET_TABLE node. This does not have a useful SDLoc.
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.
Definition: SelectionDAG.h:956
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,...
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 std::optional< uint64_t > 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 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
Definition: SelectionDAG.h:501
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
Definition: SelectionDAG.h:504
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
Definition: SelectionDAG.h:459
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 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)
Definition: SelectionDAG.h:711
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...
Definition: SelectionDAG.h:398
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)
Definition: SelectionDAG.h:768
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
Definition: SelectionDAG.h:558
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.
Definition: SelectionDAG.h:868
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
Definition: SelectionDAG.h:559
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.
SDValue getCopyFromReg(SDValue Chain, const SDLoc &dl, Register Reg, EVT VT)
Definition: SelectionDAG.h:839
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 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
Definition: SelectionDAG.h:498
allnodes_iterator allnodes_begin()
Definition: SelectionDAG.h:563
iterator_range< allnodes_const_iterator > allnodes() const
Definition: SelectionDAG.h:573
MDNode * getPCSections(const SDNode *Node) const
Return PCSections associated with Node, or nullptr if none exists.
ProfileSummaryInfo * getPSI() const
Definition: SelectionDAG.h:513
LLVM_ABI SDValue expandVAArg(SDNode *Node)
Expand the specified ISD::VAARG node as the Legalize pass would.
SDValue getTargetFrameIndex(int FI, EVT VT)
Definition: SelectionDAG.h:763
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)
Definition: SelectionDAG.h:831
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.
void addHeapAllocSite(const SDNode *Node, MDNode *MD)
Set HeapAllocSite to be associated with Node.
const SelectionDAGTargetInfo & getSelectionDAGInfo() const
Definition: SelectionDAG.h:506
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)
Definition: SelectionDAG.h:715
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)
Definition: SelectionDAG.h:822
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)
Definition: SelectionDAG.h:719
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 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)
std::pair< SDValue, SDValue > getMemcmp(SDValue Chain, const SDLoc &dl, SDValue Dst, SDValue Src, SDValue Size, const CallInst *CI)
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 bool isGuaranteedNotToBeUndefOrPoison(SDValue Op, bool PoisonOnly=false, unsigned Depth=0) const
Return true if this function can prove that Op is never poison and, if PoisonOnly is false,...
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)
Definition: SelectionDAG.h:902
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
FlagInserter * getFlagInserter()
Definition: SelectionDAG.h:517
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.
Definition: SelectionDAG.h:877
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()
Definition: SelectionDAG.h:564
SDDbgInfo::DbgLabelIterator DbgLabelBegin() const
SDValue getInsertVectorElt(const SDLoc &DL, SDValue Vec, SDValue Elt, unsigned Idx)
Insert Elt into Vec at offset Idx.
Definition: SelectionDAG.h:949
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()
Definition: SelectionDAG.h:495
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 bool isKnownToBeAPowerOfTwo(SDValue Val, unsigned Depth=0) const
Test if the given value is known to have exactly one bit set.
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 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 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
Definition: SelectionDAG.h:499
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,...
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()
Definition: SelectionDAG.h:570
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 bool isKnownNeverZeroFloat(SDValue Op) const
Test whether the given floating point SDValue is known to never be positive or negative zero.
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)
Definition: SelectionDAG.h:743
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
Definition: SelectionDAG.h:566
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
Definition: SelectionDAG.h:556
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)
Definition: SelectionDAG.h:707
const TargetLibraryInfo & getLibInfo() const
Definition: SelectionDAG.h:505
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)
Definition: SelectionDAG.h:808
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
Definition: SelectionDAG.h:507
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
Definition: SelectionDAG.h:497
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 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
Definition: SelectionDAG.h:493
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 bool canCreateUndefOrPoison(SDValue Op, const APInt &DemandedElts, bool PoisonOnly=false, bool ConsiderFlags=true, unsigned Depth=0) const
Return true if Op can create undef or poison from non-undef & non-poison operands.
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)
Definition: SelectionDAG.h:518
LLVM_ABI std::optional< uint64_t > 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...
SDValue getSplatBuildVector(EVT VT, const SDLoc &DL, SDValue Op)
Return a splat ISD::BUILD_VECTOR node, consisting of Op splatted to all elements.
Definition: SelectionDAG.h:885
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...
Definition: SelectionDAG.h:510
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.
LLVM_ABI bool expandMultipleResultFPLibCall(RTLIB::Libcall LC, SDNode *Node, SmallVectorImpl< SDValue > &Results, std::optional< unsigned > CallRetResNo={})
Expands a node with multiple results to an FP or vector libcall.
LLVM_ABI std::optional< uint64_t > 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...
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.
LLVM_ABI ~SelectionDAG()
LLVMContext * getContext() const
Definition: SelectionDAG.h:511
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.
Definition: SelectionDAG.h:587
void addPCSections(const SDNode *Node, MDNode *MD)
Set PCSections to be associated with Node.
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)
Definition: SelectionDAG.h:786
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.
LLVM_ABI SDNode * getNodeIfExists(unsigned Opcode, SDVTList VTList, ArrayRef< SDValue > Ops, const SDNodeFlags Flags)
Get the specified node if it's already available, or else return NULL.
SDValue getTargetConstantPool(const Constant *C, EVT VT, MaybeAlign Align=std::nullopt, int Offset=0, unsigned TargetFlags=0)
Definition: SelectionDAG.h:777
LLVM_ABI void init(MachineFunction &NewMF, OptimizationRemarkEmitter &NewORE, Pass *PassPtr, const TargetLibraryInfo *LibraryInfo, UniformityInfo *UA, ProfileSummaryInfo *PSIin, BlockFrequencyInfo *BFIin, MachineModuleInfo &MMI, FunctionVarLocs const *FnVarLocs)
Prepare this SelectionDAG to process code in the given MachineFunction.
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.
Definition: SelectionDAG.h:581
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)
Definition: SelectionDAG.h:749
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.
Definition: SelectionDAG.h:918
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.
Definition: SelectionDAG.h:979
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
Definition: SelectionDAG.h:561
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:356
bool empty() const
Definition: SmallVector.h:82
This class consists of common code factored out of the SmallVector class to reduce code duplication b...
Definition: SmallVector.h:574
typename SuperClass::iterator iterator
Definition: SmallVector.h:578
void push_back(const T &Elt)
Definition: SmallVector.h:414
This is a 'vector' (really, a variable-sized array), optimized for the case when the array is small.
Definition: SmallVector.h:1197
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.
Definition: TargetMachine.h:83
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:45
LLVM Value Representation.
Definition: Value.h:75
pointer remove(iterator &IT)
Definition: ilist.h:188
iterator insert(iterator where, pointer New)
Definition: ilist.h:165
An intrusive list with ownership and callbacks specified/controlled by ilist_traits,...
Definition: ilist.h:328
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.
@ 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:801
@ STRICT_FSETCC
STRICT_FSETCC/STRICT_FSETCCS - Constrained versions of SETCC, used for floating-point operands only.
Definition: ISDOpcodes.h:504
@ POISON
POISON - A poison node.
Definition: ISDOpcodes.h:231
@ INSERT_SUBVECTOR
INSERT_SUBVECTOR(VECTOR1, VECTOR2, IDX) - Returns a vector with VECTOR2 inserted into VECTOR1.
Definition: ISDOpcodes.h:587
@ ConstantFP
Definition: ISDOpcodes.h:87
@ ANY_EXTEND
ANY_EXTEND - Used for integer types. The high bits are undefined.
Definition: ISDOpcodes.h:835
@ SIGN_EXTEND_VECTOR_INREG
SIGN_EXTEND_VECTOR_INREG(Vector) - This operator represents an in-register sign-extension of the low ...
Definition: ISDOpcodes.h:892
@ SDIVREM
SDIVREM/UDIVREM - Divide two integers and produce both a quotient and remainder result.
Definition: ISDOpcodes.h:275
@ STRICT_FSETCCS
Definition: ISDOpcodes.h:505
@ SIGN_EXTEND
Conversion operators.
Definition: ISDOpcodes.h:826
@ SELECT
Select(COND, TRUEVAL, FALSEVAL).
Definition: ISDOpcodes.h:778
@ UNDEF
UNDEF - An undefined node.
Definition: ISDOpcodes.h:228
@ SPLAT_VECTOR
SPLAT_VECTOR(VAL) - Returns a vector with the scalar value VAL duplicated in all lanes.
Definition: ISDOpcodes.h:663
@ CopyFromReg
CopyFromReg - This node indicates that the input value is a virtual or physical register that is defi...
Definition: ISDOpcodes.h:225
@ EXTRACT_SUBVECTOR
EXTRACT_SUBVECTOR(VECTOR, IDX) - Returns a subvector from VECTOR.
Definition: ISDOpcodes.h:601
@ EXTRACT_VECTOR_ELT
EXTRACT_VECTOR_ELT(VECTOR, IDX) - Returns a single element from VECTOR identified by the (potentially...
Definition: ISDOpcodes.h:563
@ CopyToReg
CopyToReg - This node has three operands: a chain, a register number to set to this value,...
Definition: ISDOpcodes.h:219
@ ZERO_EXTEND
ZERO_EXTEND - Used for integer types, zeroing the new bits.
Definition: ISDOpcodes.h:832
@ SELECT_CC
Select with condition operator - This selects between a true value and a false value (ops #2 and #3) ...
Definition: ISDOpcodes.h:793
@ ANY_EXTEND_VECTOR_INREG
ANY_EXTEND_VECTOR_INREG(Vector) - This operator represents an in-register any-extension of the low la...
Definition: ISDOpcodes.h:881
@ 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:787
@ INSERT_VECTOR_ELT
INSERT_VECTOR_ELT(VECTOR, VAL, IDX) - Returns VECTOR with the element at IDX replaced with VAL.
Definition: ISDOpcodes.h:552
@ ZERO_EXTEND_VECTOR_INREG
ZERO_EXTEND_VECTOR_INREG(Vector) - This operator represents an in-register zero-extension of the low ...
Definition: ISDOpcodes.h:903
@ BlockAddress
Definition: ISDOpcodes.h:94
@ CALLSEQ_START
CALLSEQ_START/CALLSEQ_END - These operators mark the beginning and end of a call sequence,...
Definition: ISDOpcodes.h:1250
@ BUILD_VECTOR
BUILD_VECTOR(ELT0, ELT1, ELT2, ELT3,...) - Return a fixed-width vector with the specified,...
Definition: ISDOpcodes.h:543
MemIndexType
MemIndexType enum - This enum defines how to interpret MGATHER/SCATTER's index parameter when calcula...
Definition: ISDOpcodes.h:1647
MemIndexedMode
MemIndexedMode enum - This enum defines the load / store indexed addressing modes.
Definition: ISDOpcodes.h:1634
CondCode
ISD::CondCode enum - These are ordered carefully to make the bitfields below work out,...
Definition: ISDOpcodes.h:1685
LoadExtType
LoadExtType enum - This enum defines the three variants of LOADEXT (load with extension).
Definition: ISDOpcodes.h:1665
This is an optimization pass for GlobalISel generic memory operations.
Definition: AddressRanges.h:18
@ Offset
Definition: DWP.cpp:477
AlignedCharArrayUnion< AtomicSDNode, TargetIndexSDNode, BlockAddressSDNode, GlobalAddressSDNode, PseudoProbeSDNode > LargestSDNode
A representation of the largest SDNode, for use in sizeof().
GenericSSAContext< Function > SSAContext
iterator_range< T > make_range(T x, T y)
Convenience function for iterating over sub-ranges.
LLVM_ABI void checkForCycles(const SelectionDAG *DAG, bool force=false)
BumpPtrAllocatorImpl BumpPtrAllocator
The standard BumpPtrAllocator which just uses the default template parameters.
Definition: Allocator.h:383
CodeGenOptLevel
Code generation optimization level.
Definition: CodeGen.h:82
GenericUniformityInfo< SSAContext > UniformityInfo
CombineLevel
Definition: DAGCombine.h:15
DWARFExpression::Operation Op
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:1886
Implement std::hash so that hash_code can be used in STL containers.
Definition: BitVector.h:856
#define N
A collection of metadata nodes that might be associated with a memory access used by the alias-analys...
Definition: Metadata.h:760
This struct is a compact representation of a valid (non-zero power of two) alignment.
Definition: Alignment.h:39
DefaultFoldingSetTrait - This class provides default implementations for FoldingSetTrait implementati...
Definition: FoldingSet.h:236
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:168
bool isScalableVector() const
Return true if this is a vector type where the runtime length is machine dependent.
Definition: ValueTypes.h:174
EVT getVectorElementType() const
Given a vector type, return the type of each element.
Definition: ValueTypes.h:323
LLVM_ABI const fltSemantics & getFltSemantics() const
Returns an APFloat semantics tag appropriate for the value type.
Definition: ValueTypes.cpp:330
unsigned getVectorNumElements() const
Given a vector type, return the number of elements it contains.
Definition: ValueTypes.h:331
bool bitsLE(EVT VT) const
Return true if this has no more bits than VT.
Definition: ValueTypes.h:303
bool isInteger() const
Return true if this is an integer or a vector integer type.
Definition: ValueTypes.h:152
static bool Equals(const SDVTListNode &X, const FoldingSetNodeID &ID, unsigned IDHash, FoldingSetNodeID &TempID)
Definition: SelectionDAG.h:134
static unsigned ComputeHash(const SDVTListNode &X, FoldingSetNodeID &TempID)
Definition: SelectionDAG.h:141
static void Profile(const SDVTListNode &X, FoldingSetNodeID &ID)
Definition: SelectionDAG.h:130
FoldingSetTrait - This trait class is used to define behavior of how to "profile" (in the FoldingSet ...
Definition: FoldingSet.h:266
static nodes_iterator nodes_begin(SelectionDAG *G)
static nodes_iterator nodes_end(SelectionDAG *G)
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:117
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)
Definition: SelectionDAG.h:347
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.
Definition: SelectionDAG.h:351
std::function< void(SDNode *, SDNode *)> Callback
Definition: SelectionDAG.h:345
std::function< void(SDNode *)> Callback
Definition: SelectionDAG.h:358
void NodeInserted(SDNode *N) override
The node N that was inserted.
Definition: SelectionDAG.h:364
DAGNodeInsertedListener(SelectionDAG &DAG, std::function< void(SDNode *)> Callback)
Definition: SelectionDAG.h:360
Clients of various APIs that cause global effects on the DAG can optionally implement this interface.
Definition: SelectionDAG.h:318
DAGUpdateListener *const Next
Definition: SelectionDAG.h:319
static void deleteNode(SDNode *)
Definition: SelectionDAG.h:147
Use delete by default for iplist and ilist.
Definition: ilist.h:41