mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-15 23:31:37 +00:00
PR9214: Convert Metadata API to use ArrayRef.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@129932 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
ae5fbeec23
commit
ec9186bcf9
@ -111,30 +111,25 @@ class MDNode : public Value, public FoldingSetNode {
|
||||
void replaceOperand(MDNodeOperand *Op, Value *NewVal);
|
||||
~MDNode();
|
||||
|
||||
MDNode(LLVMContext &C, Value *const *Vals, unsigned NumVals,
|
||||
bool isFunctionLocal);
|
||||
MDNode(LLVMContext &C, ArrayRef<Value*> Vals, bool isFunctionLocal);
|
||||
|
||||
static MDNode *getMDNode(LLVMContext &C, Value *const *Vals, unsigned NumVals,
|
||||
static MDNode *getMDNode(LLVMContext &C, ArrayRef<Value*> Vals,
|
||||
FunctionLocalness FL, bool Insert = true);
|
||||
public:
|
||||
// Constructors and destructors.
|
||||
static MDNode *get(LLVMContext &Context, ArrayRef<Value*> V);
|
||||
// FIXME: Eliminate this constructor form.
|
||||
static MDNode *get(LLVMContext &Context, Value *const *Vals,
|
||||
unsigned NumVals);
|
||||
static MDNode *get(LLVMContext &Context, ArrayRef<Value*> Vals);
|
||||
// getWhenValsUnresolved - Construct MDNode determining function-localness
|
||||
// from isFunctionLocal argument, not by analyzing Vals.
|
||||
static MDNode *getWhenValsUnresolved(LLVMContext &Context, Value *const *Vals,
|
||||
unsigned NumVals, bool isFunctionLocal);
|
||||
static MDNode *getWhenValsUnresolved(LLVMContext &Context,
|
||||
ArrayRef<Value*> Vals,
|
||||
bool isFunctionLocal);
|
||||
|
||||
static MDNode *getIfExists(LLVMContext &Context, Value *const *Vals,
|
||||
unsigned NumVals);
|
||||
static MDNode *getIfExists(LLVMContext &Context, ArrayRef<Value*> Vals);
|
||||
|
||||
/// getTemporary - Return a temporary MDNode, for use in constructing
|
||||
/// cyclic MDNode structures. A temporary MDNode is not uniqued,
|
||||
/// may be RAUW'd, and must be manually deleted with deleteTemporary.
|
||||
static MDNode *getTemporary(LLVMContext &Context, Value *const *Vals,
|
||||
unsigned NumVals);
|
||||
static MDNode *getTemporary(LLVMContext &Context, ArrayRef<Value*> Vals);
|
||||
|
||||
/// deleteTemporary - Deallocate a node created by getTemporary. The
|
||||
/// node must not have any users.
|
||||
|
@ -518,7 +518,7 @@ DIType DIBuilder::createTemporaryType() {
|
||||
// Give the temporary MDNode a tag. It doesn't matter what tag we
|
||||
// use here as long as DIType accepts it.
|
||||
Value *Elts[] = { GetTagConstant(VMContext, DW_TAG_base_type) };
|
||||
MDNode *Node = MDNode::getTemporary(VMContext, Elts, 1);
|
||||
MDNode *Node = MDNode::getTemporary(VMContext, Elts);
|
||||
return DIType(Node);
|
||||
}
|
||||
|
||||
@ -532,17 +532,19 @@ DIType DIBuilder::createTemporaryType(DIFile F) {
|
||||
NULL,
|
||||
F
|
||||
};
|
||||
MDNode *Node = MDNode::getTemporary(VMContext, Elts, array_lengthof(Elts));
|
||||
MDNode *Node = MDNode::getTemporary(VMContext, Elts);
|
||||
return DIType(Node);
|
||||
}
|
||||
|
||||
/// getOrCreateArray - Get a DIArray, create one if required.
|
||||
DIArray DIBuilder::getOrCreateArray(Value *const *Elements, unsigned NumElements) {
|
||||
DIArray DIBuilder::getOrCreateArray(Value *const *Elements,
|
||||
unsigned NumElements) {
|
||||
if (NumElements == 0) {
|
||||
Value *Null = llvm::Constant::getNullValue(Type::getInt32Ty(VMContext));
|
||||
return DIArray(MDNode::get(VMContext, &Null, 1));
|
||||
return DIArray(MDNode::get(VMContext, Null));
|
||||
}
|
||||
return DIArray(MDNode::get(VMContext, Elements, NumElements));
|
||||
return DIArray(MDNode::get(VMContext,
|
||||
ArrayRef<Value*>(Elements, NumElements)));
|
||||
}
|
||||
|
||||
/// getOrCreateSubrange - Create a descriptor for a value range. This
|
||||
@ -778,7 +780,7 @@ Instruction *DIBuilder::insertDeclare(Value *Storage, DIVariable VarInfo,
|
||||
if (!DeclareFn)
|
||||
DeclareFn = Intrinsic::getDeclaration(&M, Intrinsic::dbg_declare);
|
||||
|
||||
Value *Args[] = { MDNode::get(Storage->getContext(), &Storage, 1), VarInfo };
|
||||
Value *Args[] = { MDNode::get(Storage->getContext(), Storage), VarInfo };
|
||||
return CallInst::Create(DeclareFn, Args, Args+2, "", InsertBefore);
|
||||
}
|
||||
|
||||
@ -790,7 +792,7 @@ Instruction *DIBuilder::insertDeclare(Value *Storage, DIVariable VarInfo,
|
||||
if (!DeclareFn)
|
||||
DeclareFn = Intrinsic::getDeclaration(&M, Intrinsic::dbg_declare);
|
||||
|
||||
Value *Args[] = { MDNode::get(Storage->getContext(), &Storage, 1), VarInfo };
|
||||
Value *Args[] = { MDNode::get(Storage->getContext(), Storage), VarInfo };
|
||||
|
||||
// If this block already has a terminator then insert this intrinsic
|
||||
// before the terminator.
|
||||
@ -809,7 +811,7 @@ Instruction *DIBuilder::insertDbgValueIntrinsic(Value *V, uint64_t Offset,
|
||||
if (!ValueFn)
|
||||
ValueFn = Intrinsic::getDeclaration(&M, Intrinsic::dbg_value);
|
||||
|
||||
Value *Args[] = { MDNode::get(V->getContext(), &V, 1),
|
||||
Value *Args[] = { MDNode::get(V->getContext(), V),
|
||||
ConstantInt::get(Type::getInt64Ty(V->getContext()), Offset),
|
||||
VarInfo };
|
||||
return CallInst::Create(ValueFn, Args, Args+3, "", InsertBefore);
|
||||
@ -824,7 +826,7 @@ Instruction *DIBuilder::insertDbgValueIntrinsic(Value *V, uint64_t Offset,
|
||||
if (!ValueFn)
|
||||
ValueFn = Intrinsic::getDeclaration(&M, Intrinsic::dbg_value);
|
||||
|
||||
Value *Args[] = { MDNode::get(V->getContext(), &V, 1),
|
||||
Value *Args[] = { MDNode::get(V->getContext(), V),
|
||||
ConstantInt::get(Type::getInt64Ty(V->getContext()), Offset),
|
||||
VarInfo };
|
||||
return CallInst::Create(ValueFn, Args, Args+3, "", InsertAtEnd);
|
||||
|
@ -514,7 +514,7 @@ bool LLParser::ParseMDNodeID(MDNode *&Result) {
|
||||
if (Result) return false;
|
||||
|
||||
// Otherwise, create MDNode forward reference.
|
||||
MDNode *FwdNode = MDNode::getTemporary(Context, 0, 0);
|
||||
MDNode *FwdNode = MDNode::getTemporary(Context, ArrayRef<Value*>());
|
||||
ForwardRefMDNodes[MID] = std::make_pair(FwdNode, Lex.getLoc());
|
||||
|
||||
if (NumberedMetadata.size() <= MID)
|
||||
@ -572,7 +572,7 @@ bool LLParser::ParseStandaloneMetadata() {
|
||||
ParseToken(lltok::rbrace, "expected end of metadata node"))
|
||||
return true;
|
||||
|
||||
MDNode *Init = MDNode::get(Context, Elts.data(), Elts.size());
|
||||
MDNode *Init = MDNode::get(Context, Elts);
|
||||
|
||||
// See if this was forward referenced, if so, handle it.
|
||||
std::map<unsigned, std::pair<TrackingVH<MDNode>, LocTy> >::iterator
|
||||
@ -2498,7 +2498,7 @@ bool LLParser::ParseMetadataListValue(ValID &ID, PerFunctionState *PFS) {
|
||||
ParseToken(lltok::rbrace, "expected end of metadata node"))
|
||||
return true;
|
||||
|
||||
ID.MDNodeVal = MDNode::get(Context, Elts.data(), Elts.size());
|
||||
ID.MDNodeVal = MDNode::get(Context, Elts);
|
||||
ID.Kind = ValID::t_MDNode;
|
||||
return false;
|
||||
}
|
||||
|
@ -349,7 +349,7 @@ Value *BitcodeReaderMDValueList::getValueFwdRef(unsigned Idx) {
|
||||
}
|
||||
|
||||
// Create and return a placeholder, which will later be RAUW'd.
|
||||
Value *V = MDNode::getTemporary(Context, 0, 0);
|
||||
Value *V = MDNode::getTemporary(Context, ArrayRef<Value*>());
|
||||
MDValuePtrs[Idx] = V;
|
||||
return V;
|
||||
}
|
||||
@ -843,9 +843,7 @@ bool BitcodeReader::ParseMetadata() {
|
||||
else
|
||||
Elts.push_back(NULL);
|
||||
}
|
||||
Value *V = MDNode::getWhenValsUnresolved(Context,
|
||||
Elts.data(), Elts.size(),
|
||||
IsFunctionLocal);
|
||||
Value *V = MDNode::getWhenValsUnresolved(Context, Elts, IsFunctionLocal);
|
||||
IsFunctionLocal = false;
|
||||
MDValueList.AssignValue(V, NextMDValueNo++);
|
||||
break;
|
||||
|
@ -104,7 +104,7 @@ bool llvm::isAllocaPromotable(const AllocaInst *AI) {
|
||||
/// FindAllocaDbgDeclare - Finds the llvm.dbg.declare intrinsic describing the
|
||||
/// alloca 'V', if any.
|
||||
static DbgDeclareInst *FindAllocaDbgDeclare(Value *V) {
|
||||
if (MDNode *DebugNode = MDNode::getIfExists(V->getContext(), &V, 1))
|
||||
if (MDNode *DebugNode = MDNode::getIfExists(V->getContext(), V))
|
||||
for (Value::use_iterator UI = DebugNode->use_begin(),
|
||||
E = DebugNode->use_end(); UI != E; ++UI)
|
||||
if (DbgDeclareInst *DDI = dyn_cast<DbgDeclareInst>(*UI))
|
||||
|
@ -39,7 +39,7 @@ Value *llvm::MapValue(const Value *V, ValueToValueMapTy &VM,
|
||||
return VM[V] = const_cast<Value*>(V);
|
||||
|
||||
// Create a dummy node in case we have a metadata cycle.
|
||||
MDNode *Dummy = MDNode::getTemporary(V->getContext(), 0, 0);
|
||||
MDNode *Dummy = MDNode::getTemporary(V->getContext(), ArrayRef<Value*>());
|
||||
VM[V] = Dummy;
|
||||
|
||||
// Check all operands to see if any need to be remapped.
|
||||
@ -54,7 +54,7 @@ Value *llvm::MapValue(const Value *V, ValueToValueMapTy &VM,
|
||||
Value *Op = MD->getOperand(i);
|
||||
Elts.push_back(Op ? MapValue(Op, VM, Flags) : 0);
|
||||
}
|
||||
MDNode *NewMD = MDNode::get(V->getContext(), Elts.data(), Elts.size());
|
||||
MDNode *NewMD = MDNode::get(V->getContext(), Elts);
|
||||
Dummy->replaceAllUsesWith(NewMD);
|
||||
VM[V] = NewMD;
|
||||
MDNode::deleteTemporary(Dummy);
|
||||
|
@ -543,7 +543,8 @@ LLVMValueRef LLVMMDString(const char *Str, unsigned SLen) {
|
||||
|
||||
LLVMValueRef LLVMMDNodeInContext(LLVMContextRef C, LLVMValueRef *Vals,
|
||||
unsigned Count) {
|
||||
return wrap(MDNode::get(*unwrap(C), unwrap<Value>(Vals, Count), Count));
|
||||
return wrap(MDNode::get(*unwrap(C),
|
||||
ArrayRef<Value*>(unwrap<Value>(Vals, Count), Count)));
|
||||
}
|
||||
|
||||
LLVMValueRef LLVMMDNode(LLVMValueRef *Vals, unsigned Count) {
|
||||
|
@ -109,7 +109,7 @@ MDNode *DebugLoc::getAsMDNode(const LLVMContext &Ctx) const {
|
||||
ConstantInt::get(Int32, getLine()), ConstantInt::get(Int32, getCol()),
|
||||
Scope, IA
|
||||
};
|
||||
return MDNode::get(Ctx2, &Elts[0], 4);
|
||||
return MDNode::get(Ctx2, Elts);
|
||||
}
|
||||
|
||||
/// getFromDILocation - Translate the DILocation quad into a DebugLoc.
|
||||
|
@ -84,18 +84,18 @@ static MDNodeOperand *getOperandPtr(MDNode *N, unsigned Op) {
|
||||
return reinterpret_cast<MDNodeOperand*>(N+1)+Op;
|
||||
}
|
||||
|
||||
MDNode::MDNode(LLVMContext &C, Value *const *Vals, unsigned NumVals,
|
||||
bool isFunctionLocal)
|
||||
MDNode::MDNode(LLVMContext &C, ArrayRef<Value*> Vals, bool isFunctionLocal)
|
||||
: Value(Type::getMetadataTy(C), Value::MDNodeVal) {
|
||||
NumOperands = NumVals;
|
||||
NumOperands = Vals.size();
|
||||
|
||||
if (isFunctionLocal)
|
||||
setValueSubclassData(getSubclassDataFromValue() | FunctionLocalBit);
|
||||
|
||||
// Initialize the operand list, which is co-allocated on the end of the node.
|
||||
unsigned i = 0;
|
||||
for (MDNodeOperand *Op = getOperandPtr(this, 0), *E = Op+NumOperands;
|
||||
Op != E; ++Op, ++Vals)
|
||||
new (Op) MDNodeOperand(*Vals, this);
|
||||
Op != E; ++Op, ++i)
|
||||
new (Op) MDNodeOperand(Vals[i], this);
|
||||
}
|
||||
|
||||
|
||||
@ -183,9 +183,8 @@ static bool isFunctionLocalValue(Value *V) {
|
||||
(isa<MDNode>(V) && cast<MDNode>(V)->isFunctionLocal());
|
||||
}
|
||||
|
||||
MDNode *MDNode::getMDNode(LLVMContext &Context, Value *const *Vals,
|
||||
unsigned NumVals, FunctionLocalness FL,
|
||||
bool Insert) {
|
||||
MDNode *MDNode::getMDNode(LLVMContext &Context, ArrayRef<Value*> Vals,
|
||||
FunctionLocalness FL, bool Insert) {
|
||||
LLVMContextImpl *pImpl = Context.pImpl;
|
||||
|
||||
// Add all the operand pointers. Note that we don't have to add the
|
||||
@ -193,7 +192,7 @@ MDNode *MDNode::getMDNode(LLVMContext &Context, Value *const *Vals,
|
||||
// Note that if the operands are later nulled out, the node will be
|
||||
// removed from the uniquing map.
|
||||
FoldingSetNodeID ID;
|
||||
for (unsigned i = 0; i != NumVals; ++i)
|
||||
for (unsigned i = 0; i != Vals.size(); ++i)
|
||||
ID.AddPointer(Vals[i]);
|
||||
|
||||
void *InsertPoint;
|
||||
@ -205,7 +204,7 @@ MDNode *MDNode::getMDNode(LLVMContext &Context, Value *const *Vals,
|
||||
bool isFunctionLocal = false;
|
||||
switch (FL) {
|
||||
case FL_Unknown:
|
||||
for (unsigned i = 0; i != NumVals; ++i) {
|
||||
for (unsigned i = 0; i != Vals.size(); ++i) {
|
||||
Value *V = Vals[i];
|
||||
if (!V) continue;
|
||||
if (isFunctionLocalValue(V)) {
|
||||
@ -223,8 +222,8 @@ MDNode *MDNode::getMDNode(LLVMContext &Context, Value *const *Vals,
|
||||
}
|
||||
|
||||
// Coallocate space for the node and Operands together, then placement new.
|
||||
void *Ptr = malloc(sizeof(MDNode)+NumVals*sizeof(MDNodeOperand));
|
||||
N = new (Ptr) MDNode(Context, Vals, NumVals, isFunctionLocal);
|
||||
void *Ptr = malloc(sizeof(MDNode)+Vals.size()*sizeof(MDNodeOperand));
|
||||
N = new (Ptr) MDNode(Context, Vals, isFunctionLocal);
|
||||
|
||||
// InsertPoint will have been set by the FindNodeOrInsertPos call.
|
||||
pImpl->MDNodeSet.InsertNode(N, InsertPoint);
|
||||
@ -233,26 +232,23 @@ MDNode *MDNode::getMDNode(LLVMContext &Context, Value *const *Vals,
|
||||
}
|
||||
|
||||
MDNode *MDNode::get(LLVMContext &Context, ArrayRef<Value*> Vals) {
|
||||
return getMDNode(Context, Vals.data(), Vals.size(), FL_Unknown);
|
||||
}
|
||||
MDNode *MDNode::get(LLVMContext &Context, Value*const* Vals, unsigned NumVals) {
|
||||
return getMDNode(Context, Vals, NumVals, FL_Unknown);
|
||||
return getMDNode(Context, Vals, FL_Unknown);
|
||||
}
|
||||
|
||||
MDNode *MDNode::getWhenValsUnresolved(LLVMContext &Context, Value *const *Vals,
|
||||
unsigned NumVals, bool isFunctionLocal) {
|
||||
return getMDNode(Context, Vals, NumVals, isFunctionLocal ? FL_Yes : FL_No);
|
||||
MDNode *MDNode::getWhenValsUnresolved(LLVMContext &Context,
|
||||
ArrayRef<Value*> Vals,
|
||||
bool isFunctionLocal) {
|
||||
return getMDNode(Context, Vals, isFunctionLocal ? FL_Yes : FL_No);
|
||||
}
|
||||
|
||||
MDNode *MDNode::getIfExists(LLVMContext &Context, Value *const *Vals,
|
||||
unsigned NumVals) {
|
||||
return getMDNode(Context, Vals, NumVals, FL_Unknown, false);
|
||||
MDNode *MDNode::getIfExists(LLVMContext &Context, ArrayRef<Value*> Vals) {
|
||||
return getMDNode(Context, Vals, FL_Unknown, false);
|
||||
}
|
||||
|
||||
MDNode *MDNode::getTemporary(LLVMContext &Context, Value *const *Vals,
|
||||
unsigned NumVals) {
|
||||
MDNode *N = (MDNode *)malloc(sizeof(MDNode)+NumVals*sizeof(MDNodeOperand));
|
||||
N = new (N) MDNode(Context, Vals, NumVals, FL_No);
|
||||
MDNode *MDNode::getTemporary(LLVMContext &Context, ArrayRef<Value*> Vals) {
|
||||
MDNode *N =
|
||||
(MDNode *)malloc(sizeof(MDNode)+Vals.size()*sizeof(MDNodeOperand));
|
||||
N = new (N) MDNode(Context, Vals, FL_No);
|
||||
N->setValueSubclassData(N->getSubclassDataFromValue() |
|
||||
NotUniquedBit);
|
||||
LeakDetector::addGarbageObject(N);
|
||||
|
@ -87,10 +87,10 @@ TEST_F(MDNodeTest, Simple) {
|
||||
V.push_back(CI);
|
||||
V.push_back(s2);
|
||||
|
||||
MDNode *n1 = MDNode::get(Context, &V[0], 3);
|
||||
MDNode *n1 = MDNode::get(Context, V);
|
||||
Value *const c1 = n1;
|
||||
MDNode *n2 = MDNode::get(Context, &c1, 1);
|
||||
MDNode *n3 = MDNode::get(Context, &V[0], 3);
|
||||
MDNode *n2 = MDNode::get(Context, c1);
|
||||
MDNode *n3 = MDNode::get(Context, V);
|
||||
EXPECT_NE(n1, n2);
|
||||
#ifdef ENABLE_MDNODE_UNIQUING
|
||||
EXPECT_EQ(n1, n3);
|
||||
@ -112,7 +112,7 @@ TEST_F(MDNodeTest, Delete) {
|
||||
Instruction *I = new BitCastInst(C, Type::getInt32Ty(getGlobalContext()));
|
||||
|
||||
Value *const V = I;
|
||||
MDNode *n = MDNode::get(Context, &V, 1);
|
||||
MDNode *n = MDNode::get(Context, V);
|
||||
WeakVH wvh = n;
|
||||
|
||||
EXPECT_EQ(n, wvh);
|
||||
@ -127,8 +127,8 @@ TEST(NamedMDNodeTest, Search) {
|
||||
|
||||
Value *const V = C;
|
||||
Value *const V2 = C2;
|
||||
MDNode *n = MDNode::get(Context, &V, 1);
|
||||
MDNode *n2 = MDNode::get(Context, &V2, 1);
|
||||
MDNode *n = MDNode::get(Context, V);
|
||||
MDNode *n2 = MDNode::get(Context, V2);
|
||||
|
||||
Module M("MyModule", Context);
|
||||
const char *Name = "llvm.NMD1";
|
||||
|
Loading…
x
Reference in New Issue
Block a user