16#ifndef LLVM_ADT_FOLDINGSET_H
17#define LLVM_ADT_FOLDINGSET_H
145template <
typename T,
typename Enable =
void>
149template<
typename T,
typename Ctx>
152 X.Profile(
ID, Context);
172 const unsigned *Data =
nullptr;
189 reinterpret_cast<const uint8_t *
>(Data),
sizeof(
unsigned) * Size));
200 const unsigned *
getData()
const {
return Data; }
213 template <
typename T>
void AddIntegerImpl(
T I) {
214 static_assert(std::is_integral_v<T> &&
sizeof(
T) <=
sizeof(
unsigned) * 2,
215 "T must be an integer type no wider than 64 bits");
217 if constexpr (
sizeof(
unsigned) <
sizeof(
T))
218 Bits.push_back(
static_cast<unsigned long long>(
I) >> 32);
233 static_assert(
sizeof(uintptr_t) <=
sizeof(
unsigned long long),
234 "unexpected pointer size");
247 template <
typename T>
252 inline void clear() { Bits.clear(); }
316 void *NextInFoldingSetBucket =
nullptr;
371 void GrowBucketCount(
unsigned NewBucketCount,
const FoldingSetInfo &Info);
424template<
typename T,
typename Ctx>
434template<
typename T,
typename Ctx>
492 return static_cast<T *
>(
500 ID, InsertPos, Derived::getFoldingSetInfo()));
515 assert(Inserted ==
N &&
"Node already inserted!");
537 T *TN =
static_cast<T *
>(
N);
546 T *TN =
static_cast<T *
>(
N);
554 T *TN =
static_cast<T *
>(
N);
560 GetNodeProfile, NodeEquals, ComputeNodeHash};
566 explicit FoldingSet(
unsigned Log2InitSize = 6) : Super(Log2InitSize) {}
579template <
class T,
class Ctx>
600 T *TN =
static_cast<T *
>(
N);
607 T *TN =
static_cast<T *
>(
N);
614 T *TN =
static_cast<T *
>(
N);
621 GetNodeProfile, NodeEquals, ComputeNodeHash};
628 : Super(Log2InitSize), Context(Context) {}
638template <
class T,
class VectorT = SmallVector<T*, 8>>
657 void clear() { Set.clear(); Vector.clear(); }
662 return Set.FindNodeOrInsertPos(
ID, InsertPos);
668 T *Result = Set.GetOrInsertNode(
N);
669 if (Result ==
N) Vector.push_back(
N);
677 Set.InsertNode(
N, InsertPos);
689 unsigned size()
const {
return Set.size(); }
692 bool empty()
const {
return Set.empty(); }
749 uintptr_t x =
reinterpret_cast<uintptr_t
>(Probe) & ~0x1;
750 Ptr =
reinterpret_cast<void*
>(x);
791 template <
typename... Ts>
793 : data(
std::forward<Ts>(Args)...) {}
800 operator T&() {
return data; }
801 operator const T&()
const {
return data; }
828template <
typename T1,
typename T2>
830 static inline void Profile(
const std::pair<T1, T2> &
P,
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
This file defines the BumpPtrAllocator interface.
static GCRegistry::Add< StatepointGC > D("statepoint-example", "an example strategy for statepoint")
static GCRegistry::Add< OcamlGC > B("ocaml", "ocaml 3.10-compatible GC")
This file contains library features backported from future STL versions.
This file defines the SmallVector class.
static unsigned getSize(unsigned Kind)
ContextualFoldingSet(Ctx Context, unsigned Log2InitSize=6)
FastFoldingSetNode(const FoldingSetNodeID &ID)
void Profile(FoldingSetNodeID &ID) const
This class is used to maintain the singly linked bucket list in a folding set.
void * getNextInBucket() const
void SetNextInBucket(void *N)
Implements the folding set functionality.
LLVM_ABI FoldingSetBase(unsigned Log2InitSize=6)
void ** Buckets
Array of bucket chains.
unsigned size() const
Returns the number of nodes in the folding set.
LLVM_ABI void reserve(unsigned EltCount, const FoldingSetInfo &Info)
Increase the number of buckets such that adding the EltCount th node won't cause a rebucket operation...
LLVM_ABI bool RemoveNode(Node *N)
Remove a node from the folding set, returning true if one was removed or false if the node was not in...
LLVM_ABI FoldingSetBase & operator=(FoldingSetBase &&RHS)
LLVM_ABI ~FoldingSetBase()
unsigned NumBuckets
Length of the Buckets array. Always a power of 2.
unsigned NumNodes
Number of nodes in the folding set.
unsigned capacity()
Returns the number of nodes permitted in the folding set before a rebucket operation is performed.
LLVM_ABI Node * GetOrInsertNode(Node *N, const FoldingSetInfo &Info)
If there is an existing simple Node exactly equal to the node N, return it.
bool empty() const
Returns true if there are no nodes in the folding set.
LLVM_ABI void InsertNode(Node *N, void *InsertPos, const FoldingSetInfo &Info)
Insert the specified node into the folding set, knowing that it is not already in the folding set.
LLVM_ABI void clear()
Remove all nodes from the folding set.
LLVM_ABI Node * FindNodeOrInsertPos(const FoldingSetNodeID &ID, void *&InsertPos, const FoldingSetInfo &Info)
Look up the node specified by ID.
LLVM_ABI FoldingSetBucketIteratorImpl(void **Bucket)
FoldingSetBucketIteratorImpl(void **Bucket, bool)
bool operator!=(const FoldingSetBucketIteratorImpl &RHS) const
bool operator==(const FoldingSetBucketIteratorImpl &RHS) const
FoldingSetBucketIterator(void **Bucket, bool)
FoldingSetBucketIterator(void **Bucket)
FoldingSetBucketIterator operator++(int)
FoldingSetBucketIterator & operator++()
void reserve(unsigned EltCount)
Increase the number of buckets such that adding the EltCount th node won't cause a rebucket operation...
FoldingSetIterator< T > iterator
const_iterator end() const
bucket_iterator bucket_begin(unsigned hash)
bool RemoveNode(T *N)
Remove a node from the folding set, returning true if one was removed or false if the node was not in...
~FoldingSetImpl()=default
FoldingSetImpl(FoldingSetImpl &&Arg)=default
FoldingSetBucketIterator< T > bucket_iterator
void InsertNode(T *N)
Insert the specified node into the folding set, knowing that it is not already in the folding set.
void InsertNode(T *N, void *InsertPos)
Insert the specified node into the folding set, knowing that it is not already in the folding set.
T * FindNodeOrInsertPos(const FoldingSetNodeID &ID, void *&InsertPos)
Look up the node specified by ID.
const_iterator begin() const
FoldingSetIterator< const T > const_iterator
FoldingSetImpl & operator=(FoldingSetImpl &&RHS)=default
T * GetOrInsertNode(T *N)
If there is an existing simple Node exactly equal to the specified node, return it.
FoldingSetImpl(unsigned Log2InitSize)
bucket_iterator bucket_end(unsigned hash)
LLVM_ABI FoldingSetIteratorImpl(void **Bucket)
bool operator==(const FoldingSetIteratorImpl &RHS) const
bool operator!=(const FoldingSetIteratorImpl &RHS) const
FoldingSetIterator(void **Bucket)
FoldingSetIterator operator++(int)
FoldingSetIterator & operator++()
This class describes a reference to an interned FoldingSetNodeID, which can be a useful to store node...
unsigned computeStableHash() const
LLVM_ABI bool operator==(FoldingSetNodeIDRef) const
FoldingSetNodeIDRef(const unsigned *D, size_t S)
LLVM_ABI bool operator<(FoldingSetNodeIDRef) const
Used to compare the "ordering" of two nodes as defined by the profiled bits and their ordering define...
bool operator!=(FoldingSetNodeIDRef RHS) const
unsigned ComputeHash() const
FoldingSetNodeIDRef()=default
const unsigned * getData() const
This class is used to gather all the unique data bits of a node.
LLVM_ABI FoldingSetNodeIDRef Intern(BumpPtrAllocator &Allocator) const
Copy this node's data to a memory region allocated from the given allocator and return a FoldingSetNo...
void AddInteger(signed I)
void AddInteger(unsigned long I)
FoldingSetNodeID(FoldingSetNodeIDRef Ref)
unsigned computeStableHash() const
void AddPointer(const void *Ptr)
Add* - Add various data types to Bit data.
bool operator!=(const FoldingSetNodeIDRef RHS) const
void clear()
Clear the accumulated profile, allowing this FoldingSetNodeID object to be used to compute a new prof...
void AddInteger(unsigned I)
FoldingSetNodeID()=default
LLVM_ABI bool operator==(const FoldingSetNodeID &RHS) const
operator== - Used to compare two nodes to each other.
bool operator!=(const FoldingSetNodeID &RHS) const
void AddInteger(unsigned long long I)
void AddInteger(long long I)
unsigned ComputeHash() const
LLVM_ABI bool operator<(const FoldingSetNodeID &RHS) const
Used to compare the "ordering" of two nodes as defined by the profiled bits and their ordering define...
LLVM_ABI void AddNodeID(const FoldingSetNodeID &ID)
LLVM_ABI void AddString(StringRef String)
Add* - Add various data types to Bit data.
FoldingSetNodeWrapper(Ts &&... Args)
const T & getValue() const
void Profile(FoldingSetNodeID &ID)
T * GetOrInsertNode(T *N)
If there is an existing simple Node exactly equal to the specified node, return it.
const_iterator end() const
void InsertNode(T *N)
Insert the specified node into the folding set, knowing that it is not already in the folding set.
T * FindNodeOrInsertPos(const FoldingSetNodeID &ID, void *&InsertPos)
Look up the node specified by ID.
unsigned size() const
Returns the number of nodes in the folding set.
pointee_iterator< typename VectorT::const_iterator > const_iterator
pointee_iterator< typename VectorT::iterator > iterator
void clear()
Remove all nodes from the folding set.
bool empty() const
Returns true if there are no nodes in the folding set.
FoldingSetVector(unsigned Log2InitSize=6)
void InsertNode(T *N, void *InsertPos)
Insert the specified node into the folding set, knowing that it is not already in the folding set.
const_iterator begin() const
This template class is used to instantiate a specialized implementation of the folding set to the nod...
FoldingSet(FoldingSet &&Arg)=default
FoldingSet(unsigned Log2InitSize=6)
FoldingSet & operator=(FoldingSet &&RHS)=default
void push_back(const T &Elt)
This is a 'vector' (really, a variable-sized array), optimized for the case when the array is small.
Represent a constant reference to a string, i.e.
unsigned ID
LLVM IR allows to use arbitrary numbers as calling convention identifiers.
This is an optimization pass for GlobalISel generic memory operations.
uint64_t xxh3_64bits(ArrayRef< uint8_t > data)
Inline ArrayRef overloads of the xxhash entry points declared out-of-line in llvm/Support/xxhash....
FoldingSetBase::Node FoldingSetNode
constexpr std::underlying_type_t< Enum > to_underlying(Enum E)
Returns underlying integer value of an enum.
@ Ref
The access may reference the value stored in memory.
BumpPtrAllocatorImpl<> BumpPtrAllocator
The standard BumpPtrAllocator which just uses the default template parameters.
hash_code hash_combine_range(InputIteratorT first, InputIteratorT last)
Compute a hash_code for a sequence of values.
Implement std::hash so that hash_code can be used in STL containers.
Like FoldingSetTrait, but for ContextualFoldingSets.
Like DefaultFoldingSetTrait, but for ContextualFoldingSets.
static bool Equals(T &X, const FoldingSetNodeID &ID, unsigned IDHash, FoldingSetNodeID &TempID, Ctx Context)
static void Profile(T &X, FoldingSetNodeID &ID, Ctx Context)
static unsigned ComputeHash(T &X, FoldingSetNodeID &TempID, Ctx Context)
This class provides default implementations for FoldingSetTrait implementations.
static void Profile(const T &X, FoldingSetNodeID &ID)
static unsigned ComputeHash(T &X, FoldingSetNodeID &TempID)
static bool Equals(T &X, const FoldingSetNodeID &ID, unsigned IDHash, FoldingSetNodeID &TempID)
static void Profile(T &X, FoldingSetNodeID &ID)
Functions provided by the derived class to compute folding properties.
unsigned(* ComputeNodeHash)(const FoldingSetBase *Self, Node *N, FoldingSetNodeID &TempID)
Instantiations of the FoldingSet template implement this function to compute a hash value for the giv...
bool(* NodeEquals)(const FoldingSetBase *Self, Node *N, const FoldingSetNodeID &ID, unsigned IDHash, FoldingSetNodeID &TempID)
Instantiations of the FoldingSet template implement this function to compare the given node with the ...
void(* GetNodeProfile)(const FoldingSetBase *Self, Node *N, FoldingSetNodeID &ID)
Instantiations of the FoldingSet template implement this function to gather data bits for the given n...
static void Profile(const T &X, FoldingSetNodeID &ID)
static void Profile(T *X, FoldingSetNodeID &ID)
static void Profile(const std::pair< T1, T2 > &P, FoldingSetNodeID &ID)
This trait class is used to define behavior of how to "profile" (in the FoldingSet parlance) an objec...
An iterator type that allows iterating over the pointees via some other iterator.