mirror of
https://github.com/RPCS3/llvm.git
synced 2024-12-19 01:48:34 +00:00
DI: Use a DenseMap
instead of named metadata, NFC
Remove a strange round-trip through named metadata to assign preserved local variables to their subprograms. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@219798 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
b510f8d08c
commit
5c2d60d357
@ -73,6 +73,9 @@ namespace llvm {
|
||||
SmallVector<Value *, 4> AllGVs;
|
||||
SmallVector<TrackingVH<MDNode>, 4> AllImportedModules;
|
||||
|
||||
/// Each subprogram's preserved local variables.
|
||||
DenseMap<MDNode *, std::vector<TrackingVH<MDNode>>> PreservedVariables;
|
||||
|
||||
// Private use for multiple types of template parameters.
|
||||
DITemplateValueParameter
|
||||
createTemplateValueParameter(unsigned Tag, DIDescriptor Scope,
|
||||
|
@ -958,14 +958,6 @@ DISubprogram getDISubprogram(const MDNode *Scope);
|
||||
/// getDICompositeType - Find underlying composite type.
|
||||
DICompositeType getDICompositeType(DIType T);
|
||||
|
||||
/// getOrInsertFnSpecificMDNode - Return a NameMDNode that is suitable
|
||||
/// to hold function specific information.
|
||||
NamedMDNode *getOrInsertFnSpecificMDNode(Module &M, DISubprogram SP);
|
||||
|
||||
/// getFnSpecificMDNode - Return a NameMDNode, if available, that is
|
||||
/// suitable to hold function specific information.
|
||||
NamedMDNode *getFnSpecificMDNode(const Module &M, DISubprogram SP);
|
||||
|
||||
/// createInlinedVariable - Create a new inlined variable based on current
|
||||
/// variable.
|
||||
/// @param DV Current Variable.
|
||||
|
@ -73,13 +73,10 @@ void DIBuilder::finalize() {
|
||||
DIType(TempSubprograms).replaceAllUsesWith(SPs);
|
||||
for (unsigned i = 0, e = SPs.getNumElements(); i != e; ++i) {
|
||||
DISubprogram SP(SPs.getElement(i));
|
||||
SmallVector<Value *, 4> Variables;
|
||||
if (NamedMDNode *NMD = getFnSpecificMDNode(M, SP)) {
|
||||
for (unsigned ii = 0, ee = NMD->getNumOperands(); ii != ee; ++ii)
|
||||
Variables.push_back(NMD->getOperand(ii));
|
||||
NMD->eraseFromParent();
|
||||
}
|
||||
if (MDNode *Temp = SP.getVariablesNodes()) {
|
||||
SmallVector<Value *, 4> Variables;
|
||||
for (Value *V : PreservedVariables.lookup(SP))
|
||||
Variables.push_back(V);
|
||||
DIArray AV = getOrCreateArray(Variables);
|
||||
DIType(Temp).replaceAllUsesWith(AV);
|
||||
}
|
||||
@ -906,8 +903,8 @@ DIVariable DIBuilder::createLocalVariable(unsigned Tag, DIDescriptor Scope,
|
||||
// to preserve variable info in such situation then stash it in a
|
||||
// named mdnode.
|
||||
DISubprogram Fn(getDISubprogram(Scope));
|
||||
NamedMDNode *FnLocals = getOrInsertFnSpecificMDNode(M, Fn);
|
||||
FnLocals->addOperand(Node);
|
||||
assert(Fn && "Missing subprogram for local variable");
|
||||
PreservedVariables[Fn].push_back(Node);
|
||||
}
|
||||
DIVariable RetVar(Node);
|
||||
assert(RetVar.isVariable() &&
|
||||
|
@ -936,47 +936,6 @@ unsigned DILocation::computeNewDiscriminator(LLVMContext &Ctx) {
|
||||
return ++Ctx.pImpl->DiscriminatorTable[Key];
|
||||
}
|
||||
|
||||
/// fixupSubprogramName - Replace contains special characters used
|
||||
/// in a typical Objective-C names with '.' in a given string.
|
||||
static void fixupSubprogramName(DISubprogram Fn, SmallVectorImpl<char> &Out) {
|
||||
StringRef FName =
|
||||
Fn.getFunction() ? Fn.getFunction()->getName() : Fn.getName();
|
||||
FName = Function::getRealLinkageName(FName);
|
||||
|
||||
StringRef Prefix("llvm.dbg.lv.");
|
||||
Out.reserve(FName.size() + Prefix.size());
|
||||
Out.append(Prefix.begin(), Prefix.end());
|
||||
|
||||
bool isObjCLike = false;
|
||||
for (size_t i = 0, e = FName.size(); i < e; ++i) {
|
||||
char C = FName[i];
|
||||
if (C == '[')
|
||||
isObjCLike = true;
|
||||
|
||||
if (isObjCLike && (C == '[' || C == ']' || C == ' ' || C == ':' ||
|
||||
C == '+' || C == '(' || C == ')'))
|
||||
Out.push_back('.');
|
||||
else
|
||||
Out.push_back(C);
|
||||
}
|
||||
}
|
||||
|
||||
/// getFnSpecificMDNode - Return a NameMDNode, if available, that is
|
||||
/// suitable to hold function specific information.
|
||||
NamedMDNode *llvm::getFnSpecificMDNode(const Module &M, DISubprogram Fn) {
|
||||
SmallString<32> Name;
|
||||
fixupSubprogramName(Fn, Name);
|
||||
return M.getNamedMetadata(Name.str());
|
||||
}
|
||||
|
||||
/// getOrInsertFnSpecificMDNode - Return a NameMDNode that is suitable
|
||||
/// to hold function specific information.
|
||||
NamedMDNode *llvm::getOrInsertFnSpecificMDNode(Module &M, DISubprogram Fn) {
|
||||
SmallString<32> Name;
|
||||
fixupSubprogramName(Fn, Name);
|
||||
return M.getOrInsertNamedMetadata(Name.str());
|
||||
}
|
||||
|
||||
/// createInlinedVariable - Create a new inlined variable based on current
|
||||
/// variable.
|
||||
/// @param DV Current Variable.
|
||||
|
Loading…
Reference in New Issue
Block a user