mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-07-19 02:25:01 +00:00
Add MDNode::getIfExists(), an efficient way to determine if a value is used by metadata (since metadata does not appear in a value's use list)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@94492 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@@ -112,7 +112,7 @@ protected:
|
|||||||
bool isFunctionLocal);
|
bool isFunctionLocal);
|
||||||
|
|
||||||
static MDNode *getMDNode(LLVMContext &C, Value *const *Vals, unsigned NumVals,
|
static MDNode *getMDNode(LLVMContext &C, Value *const *Vals, unsigned NumVals,
|
||||||
FunctionLocalness FL);
|
FunctionLocalness FL, bool Insert = true);
|
||||||
public:
|
public:
|
||||||
// Constructors and destructors.
|
// Constructors and destructors.
|
||||||
static MDNode *get(LLVMContext &Context, Value *const *Vals,
|
static MDNode *get(LLVMContext &Context, Value *const *Vals,
|
||||||
@@ -122,6 +122,9 @@ public:
|
|||||||
static MDNode *getWhenValsUnresolved(LLVMContext &Context, Value *const *Vals,
|
static MDNode *getWhenValsUnresolved(LLVMContext &Context, Value *const *Vals,
|
||||||
unsigned NumVals, bool isFunctionLocal);
|
unsigned NumVals, bool isFunctionLocal);
|
||||||
|
|
||||||
|
static MDNode *getIfExists(LLVMContext &Context, Value *const *Vals,
|
||||||
|
unsigned NumVals);
|
||||||
|
|
||||||
/// getOperand - Return specified operand.
|
/// getOperand - Return specified operand.
|
||||||
Value *getOperand(unsigned i) const;
|
Value *getOperand(unsigned i) const;
|
||||||
|
|
||||||
|
@@ -186,15 +186,22 @@ void MDNode::destroy() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
MDNode *MDNode::getMDNode(LLVMContext &Context, Value *const *Vals,
|
MDNode *MDNode::getMDNode(LLVMContext &Context, Value *const *Vals,
|
||||||
unsigned NumVals, FunctionLocalness FL) {
|
unsigned NumVals, FunctionLocalness FL,
|
||||||
|
bool Insert) {
|
||||||
LLVMContextImpl *pImpl = Context.pImpl;
|
LLVMContextImpl *pImpl = Context.pImpl;
|
||||||
FoldingSetNodeID ID;
|
FoldingSetNodeID ID;
|
||||||
for (unsigned i = 0; i != NumVals; ++i)
|
for (unsigned i = 0; i != NumVals; ++i)
|
||||||
ID.AddPointer(Vals[i]);
|
ID.AddPointer(Vals[i]);
|
||||||
|
|
||||||
void *InsertPoint;
|
void *InsertPoint;
|
||||||
MDNode *N = pImpl->MDNodeSet.FindNodeOrInsertPos(ID, InsertPoint);
|
MDNode *N = NULL;
|
||||||
if (!N) {
|
|
||||||
|
if ((N = pImpl->MDNodeSet.FindNodeOrInsertPos(ID, InsertPoint)))
|
||||||
|
return N;
|
||||||
|
|
||||||
|
if (!Insert)
|
||||||
|
return NULL;
|
||||||
|
|
||||||
bool isFunctionLocal = false;
|
bool isFunctionLocal = false;
|
||||||
switch (FL) {
|
switch (FL) {
|
||||||
case FL_Unknown:
|
case FL_Unknown:
|
||||||
@@ -222,7 +229,7 @@ MDNode *MDNode::getMDNode(LLVMContext &Context, Value *const *Vals,
|
|||||||
|
|
||||||
// InsertPoint will have been set by the FindNodeOrInsertPos call.
|
// InsertPoint will have been set by the FindNodeOrInsertPos call.
|
||||||
pImpl->MDNodeSet.InsertNode(N, InsertPoint);
|
pImpl->MDNodeSet.InsertNode(N, InsertPoint);
|
||||||
}
|
|
||||||
return N;
|
return N;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -235,6 +242,11 @@ MDNode *MDNode::getWhenValsUnresolved(LLVMContext &Context, Value*const* Vals,
|
|||||||
return getMDNode(Context, Vals, NumVals, isFunctionLocal ? FL_Yes : FL_No);
|
return getMDNode(Context, Vals, NumVals, isFunctionLocal ? FL_Yes : FL_No);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
MDNode *MDNode::getIfExists(LLVMContext &Context, Value *const *Vals,
|
||||||
|
unsigned NumVals) {
|
||||||
|
return getMDNode(Context, Vals, NumVals, FL_Unknown, false);
|
||||||
|
}
|
||||||
|
|
||||||
/// getOperand - Return specified operand.
|
/// getOperand - Return specified operand.
|
||||||
Value *MDNode::getOperand(unsigned i) const {
|
Value *MDNode::getOperand(unsigned i) const {
|
||||||
return *getOperandPtr(const_cast<MDNode*>(this), i);
|
return *getOperandPtr(const_cast<MDNode*>(this), i);
|
||||||
|
Reference in New Issue
Block a user