mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-10-25 10:27:04 +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:
		| @@ -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"; | ||||
|   | ||||
		Reference in New Issue
	
	Block a user