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