14#ifndef LLVM_ADT_POINTERINTPAIR_H
15#define LLVM_ADT_POINTERINTPAIR_H
29 static_assert(
sizeof(
Ptr) ==
sizeof(intptr_t),
"");
33 static_assert(std::is_trivially_destructible<Ptr>::value,
"");
34 static_assert(std::is_trivially_copy_constructible<Ptr>::value,
"");
35 static_assert(std::is_trivially_move_constructible<Ptr>::value,
"");
39 constexpr intptr_t
asInt()
const {
41 std::memcpy(&R, Data,
sizeof(R));
45 constexpr operator intptr_t()
const {
return asInt(); }
48 std::memcpy(Data, &V,
sizeof(Data));
60template <
typename T,
typename Enable>
struct DenseMapInfo;
61template <
typename Po
interT,
unsigned IntBits,
typename PtrTraits>
62struct PointerIntPairInfo;
78 typename PtrTraits = PointerLikeTypeTraits<PointerTy>,
79 typename Info = PointerIntPairInfo<PointerTy, IntBits, PtrTraits>>
96 IntType
getInt()
const {
return (IntType)Info::getInt(Value); }
99 Value = Info::updatePointer(Value, PtrVal);
103 Value = Info::updateInt(Value,
static_cast<intptr_t
>(IntVal));
107 Value = Info::updatePointer(0, PtrVal);
111 Value = Info::updateInt(Info::updatePointer(0, PtrVal),
112 static_cast<intptr_t
>(IntVal));
121 "Can only return the address if IntBits is cleared and "
122 "PtrTraits doesn't change the pointer");
123 return Value.getPointerAddress();
127 return reinterpret_cast<void *
>(Value.asInt());
131 Value =
reinterpret_cast<intptr_t
>(Val);
136 P.setFromOpaqueValue(V);
143 (void)PtrTraits::getFromVoidPointer(V);
148 return Value ==
RHS.Value;
152 return Value !=
RHS.Value;
159 return Value <=
RHS.Value;
163 return Value >=
RHS.Value;
167template <
typename Po
interT,
unsigned IntBits,
typename PtrTraits>
169 static_assert(PtrTraits::NumLowBitsAvailable <
170 std::numeric_limits<uintptr_t>::digits,
171 "cannot use a pointer type that has all bits free");
172 static_assert(IntBits <= PtrTraits::NumLowBitsAvailable,
173 "PointerIntPair with integer size too large for pointer");
180 IntShift = (uintptr_t)PtrTraits::NumLowBitsAvailable - IntBits,
190 return PtrTraits::getFromVoidPointer(
200 reinterpret_cast<intptr_t
>(PtrTraits::getAsVoidPointer(
Ptr));
202 "Pointer is not sufficiently aligned");
216template <
typename Po
interTy,
unsigned IntBits,
typename IntType>
221 uintptr_t Val =
static_cast<uintptr_t
>(-1);
222 Val <<= PointerLikeTypeTraits<Ty>::NumLowBitsAvailable;
227 uintptr_t Val =
static_cast<uintptr_t
>(-2);
228 Val <<= PointerLikeTypeTraits<PointerTy>::NumLowBitsAvailable;
233 uintptr_t
IV =
reinterpret_cast<uintptr_t
>(V.getOpaqueValue());
241template <
typename PointerTy,
unsigned IntBits,
typename IntType,
247 return P.getOpaqueValue();
261 PtrTraits::NumLowBitsAvailable - IntBits;
265template <std::size_t
I,
typename PointerTy,
unsigned IntBits,
typename IntType,
266 typename PtrTraits,
typename Info>
269 static_assert(
I < 2);
270 if constexpr (
I == 0)
279template <
typename PointerTy,
unsigned IntBits,
typename IntType,
280 typename PtrTraits,
typename Info>
282 llvm::PointerIntPair<PointerTy, IntBits, IntType, PtrTraits, Info>>
283 : std::integral_constant<std::size_t, 2> {};
285template <std::size_t
I,
typename PointerTy,
unsigned IntBits,
typename IntType,
286 typename PtrTraits,
typename Info>
288 I,
llvm::PointerIntPair<PointerTy, IntBits, IntType, PtrTraits, Info>>
289 : std::conditional<I == 0, PointerTy, IntType> {};
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
Analysis containing CSE Info
static const uint32_t IV[8]
PointerIntPair - This class implements a pair of a pointer and small integer.
bool operator<(const PointerIntPair &RHS) const
void setPointer(PointerTy PtrVal) &
PointerIntPair(PointerTy PtrVal)
bool operator!=(const PointerIntPair &RHS) const
static PointerIntPair getFromOpaqueValue(const void *V)
bool operator==(const PointerIntPair &RHS) const
PointerIntPair(PointerTy PtrVal, IntType IntVal)
void initWithPointer(PointerTy PtrVal) &
bool operator<=(const PointerIntPair &RHS) const
void setInt(IntType IntVal) &
void setPointerAndInt(PointerTy PtrVal, IntType IntVal) &
void * getOpaqueValue() const
constexpr PointerIntPair()=default
bool operator>=(const PointerIntPair &RHS) const
static PointerIntPair getFromOpaqueValue(void *V)
PointerTy * getAddrOfPointer()
bool operator>(const PointerIntPair &RHS) const
PointerTy const * getAddrOfPointer() const
PointerTy getPointer() const
void setFromOpaqueValue(void *Val) &
LLVM Value Representation.
These are wrappers over isa* function that allow them to be used in generic algorithms such as llvm:a...
This is an optimization pass for GlobalISel generic memory operations.
decltype(auto) get(const PointerIntPair< PointerTy, IntBits, IntType, PtrTraits, Info > &Pair)
FunctionAddr VTableAddr uintptr_t uintptr_t Data
Implement std::hash so that hash_code can be used in STL containers.
static unsigned getHashValue(Ty V)
static Ty getTombstoneKey()
PointerIntPair< PointerTy, IntBits, IntType > Ty
static bool isEqual(const Ty &LHS, const Ty &RHS)
An information struct used to provide DenseMap with the various necessary components for a given valu...
static PointerT getPointer(intptr_t Value)
static intptr_t updateInt(intptr_t OrigValue, intptr_t Int)
static intptr_t getInt(intptr_t Value)
@ IntShift
IntShift - The number of low bits that we reserve for other uses, and keep zero.
@ PointerBitMask
PointerBitMask - The bits that come from the pointer.
@ IntMask
IntMask - This is the unshifted mask for valid bits of the int type.
static intptr_t updatePointer(intptr_t OrigValue, PointerT Ptr)
static void * getAsVoidPointer(const PointerIntPair< PointerTy, IntBits, IntType > &P)
static PointerIntPair< PointerTy, IntBits, IntType > getFromVoidPointer(void *P)
static PointerIntPair< PointerTy, IntBits, IntType > getFromVoidPointer(const void *P)
static constexpr int NumLowBitsAvailable
A traits type that is used to handle pointer types and things that are just wrappers for pointers as ...
constexpr intptr_t asInt() const
constexpr PunnedPointer(intptr_t i=0)
const Ptr * getPointerAddress() const
Ptr * getPointerAddress()
constexpr PunnedPointer & operator=(intptr_t V)