Debug Info: add a newly-created DIE to a parent in the same function.

With this commit, all DIEs created in CompileUnit will be added to parents
inside the same function. Also make getOrCreateTemplateType|Value functions
private.

No functionality change.


git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@193002 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Manman Ren 2013-10-18 21:14:19 +00:00
parent 57a964bc63
commit 630c3264a6
2 changed files with 29 additions and 24 deletions

View File

@ -782,11 +782,11 @@ void CompileUnit::addTemplateParams(DIE &Buffer, DIArray TParams) {
for (unsigned i = 0, e = TParams.getNumElements(); i != e; ++i) { for (unsigned i = 0, e = TParams.getNumElements(); i != e; ++i) {
DIDescriptor Element = TParams.getElement(i); DIDescriptor Element = TParams.getElement(i);
if (Element.isTemplateTypeParameter()) if (Element.isTemplateTypeParameter())
Buffer.addChild(getOrCreateTemplateTypeParameterDIE( getOrCreateTemplateTypeParameterDIE(
DITemplateTypeParameter(Element))); DITemplateTypeParameter(Element), Buffer);
else if (Element.isTemplateValueParameter()) else if (Element.isTemplateValueParameter())
Buffer.addChild(getOrCreateTemplateValueParameterDIE( getOrCreateTemplateValueParameterDIE(
DITemplateValueParameter(Element))); DITemplateValueParameter(Element), Buffer);
} }
} }
@ -1084,10 +1084,8 @@ void CompileUnit::constructTypeDIE(DIE &Buffer, DICompositeType CTy) {
for (unsigned i = 0, N = Elements.getNumElements(); i < N; ++i) { for (unsigned i = 0, N = Elements.getNumElements(); i < N; ++i) {
DIE *ElemDie = NULL; DIE *ElemDie = NULL;
DIDescriptor Enum(Elements.getElement(i)); DIDescriptor Enum(Elements.getElement(i));
if (Enum.isEnumerator()) { if (Enum.isEnumerator())
ElemDie = constructEnumTypeDIE(DIEnumerator(Enum)); ElemDie = constructEnumTypeDIE(DIEnumerator(Enum), Buffer);
Buffer.addChild(ElemDie);
}
} }
DIType DTy = resolve(CTy.getTypeDerivedFrom()); DIType DTy = resolve(CTy.getTypeDerivedFrom());
if (DTy) { if (DTy) {
@ -1161,8 +1159,7 @@ void CompileUnit::constructTypeDIE(DIE &Buffer, DICompositeType CTy) {
} else if (DDTy.isStaticMember()) { } else if (DDTy.isStaticMember()) {
ElemDie = getOrCreateStaticMemberDIE(DDTy); ElemDie = getOrCreateStaticMemberDIE(DDTy);
} else { } else {
ElemDie = createMemberDIE(DDTy); ElemDie = createMemberDIE(DDTy, Buffer);
Buffer.addChild(ElemDie);
} }
} else if (Element.isObjCProperty()) { } else if (Element.isObjCProperty()) {
DIObjCProperty Property(Element); DIObjCProperty Property(Element);
@ -1267,12 +1264,14 @@ void CompileUnit::constructTypeDIE(DIE &Buffer, DICompositeType CTy) {
/// getOrCreateTemplateTypeParameterDIE - Find existing DIE or create new DIE /// getOrCreateTemplateTypeParameterDIE - Find existing DIE or create new DIE
/// for the given DITemplateTypeParameter. /// for the given DITemplateTypeParameter.
DIE * DIE *
CompileUnit::getOrCreateTemplateTypeParameterDIE(DITemplateTypeParameter TP) { CompileUnit::getOrCreateTemplateTypeParameterDIE(DITemplateTypeParameter TP,
DIE &Buffer) {
DIE *ParamDIE = getDIE(TP); DIE *ParamDIE = getDIE(TP);
if (ParamDIE) if (ParamDIE)
return ParamDIE; return ParamDIE;
ParamDIE = new DIE(dwarf::DW_TAG_template_type_parameter); ParamDIE = new DIE(dwarf::DW_TAG_template_type_parameter);
Buffer.addChild(ParamDIE);
// Add the type if it exists, it could be void and therefore no type. // Add the type if it exists, it could be void and therefore no type.
if (TP.getType()) if (TP.getType())
addType(ParamDIE, resolve(TP.getType())); addType(ParamDIE, resolve(TP.getType()));
@ -1284,12 +1283,14 @@ CompileUnit::getOrCreateTemplateTypeParameterDIE(DITemplateTypeParameter TP) {
/// getOrCreateTemplateValueParameterDIE - Find existing DIE or create new DIE /// getOrCreateTemplateValueParameterDIE - Find existing DIE or create new DIE
/// for the given DITemplateValueParameter. /// for the given DITemplateValueParameter.
DIE * DIE *
CompileUnit::getOrCreateTemplateValueParameterDIE(DITemplateValueParameter VP) { CompileUnit::getOrCreateTemplateValueParameterDIE(DITemplateValueParameter VP,
DIE &Buffer) {
DIE *ParamDIE = getDIE(VP); DIE *ParamDIE = getDIE(VP);
if (ParamDIE) if (ParamDIE)
return ParamDIE; return ParamDIE;
ParamDIE = new DIE(VP.getTag()); ParamDIE = new DIE(VP.getTag());
Buffer.addChild(ParamDIE);
// Add the type if there is one, template template and template parameter // Add the type if there is one, template template and template parameter
// packs will not have a type. // packs will not have a type.
@ -1681,8 +1682,9 @@ void CompileUnit::constructArrayTypeDIE(DIE &Buffer,
} }
/// constructEnumTypeDIE - Construct enum type DIE from DIEnumerator. /// constructEnumTypeDIE - Construct enum type DIE from DIEnumerator.
DIE *CompileUnit::constructEnumTypeDIE(DIEnumerator ETy) { DIE *CompileUnit::constructEnumTypeDIE(DIEnumerator ETy, DIE &Buffer) {
DIE *Enumerator = new DIE(dwarf::DW_TAG_enumerator); DIE *Enumerator = new DIE(dwarf::DW_TAG_enumerator);
Buffer.addChild(Enumerator);
StringRef Name = ETy.getName(); StringRef Name = ETy.getName();
addString(Enumerator, dwarf::DW_AT_name, Name); addString(Enumerator, dwarf::DW_AT_name, Name);
int64_t Value = ETy.getEnumValue(); int64_t Value = ETy.getEnumValue();
@ -1779,8 +1781,9 @@ DIE *CompileUnit::constructVariableDIE(DbgVariable *DV,
} }
/// createMemberDIE - Create new member DIE. /// createMemberDIE - Create new member DIE.
DIE *CompileUnit::createMemberDIE(DIDerivedType DT) { DIE *CompileUnit::createMemberDIE(DIDerivedType DT, DIE &Buffer) {
DIE *MemberDie = new DIE(DT.getTag()); DIE *MemberDie = new DIE(DT.getTag());
Buffer.addChild(MemberDie);
StringRef Name = DT.getName(); StringRef Name = DT.getName();
if (!Name.empty()) if (!Name.empty())
addString(MemberDie, dwarf::DW_AT_name, Name); addString(MemberDie, dwarf::DW_AT_name, Name);

View File

@ -290,14 +290,6 @@ public:
/// given DIType. /// given DIType.
DIE *getOrCreateTypeDIE(const MDNode *N); DIE *getOrCreateTypeDIE(const MDNode *N);
/// getOrCreateTemplateTypeParameterDIE - Find existing DIE or create new DIE
/// for the given DITemplateTypeParameter.
DIE *getOrCreateTemplateTypeParameterDIE(DITemplateTypeParameter TP);
/// getOrCreateTemplateValueParameterDIE - Find existing DIE or create
/// new DIE for the given DITemplateValueParameter.
DIE *getOrCreateTemplateValueParameterDIE(DITemplateValueParameter TVP);
/// getOrCreateContextDIE - Get context owner's DIE. /// getOrCreateContextDIE - Get context owner's DIE.
DIE *getOrCreateContextDIE(DIScope Context); DIE *getOrCreateContextDIE(DIScope Context);
@ -328,10 +320,20 @@ private:
void constructArrayTypeDIE(DIE &Buffer, DICompositeType *CTy); void constructArrayTypeDIE(DIE &Buffer, DICompositeType *CTy);
/// constructEnumTypeDIE - Construct enum type DIE from DIEnumerator. /// constructEnumTypeDIE - Construct enum type DIE from DIEnumerator.
DIE *constructEnumTypeDIE(DIEnumerator ETy); DIE *constructEnumTypeDIE(DIEnumerator ETy, DIE &Buffer);
/// createMemberDIE - Create new member DIE. /// createMemberDIE - Create new member DIE.
DIE *createMemberDIE(DIDerivedType DT); DIE *createMemberDIE(DIDerivedType DT, DIE &Buffer);
/// getOrCreateTemplateTypeParameterDIE - Find existing DIE or create new DIE
/// for the given DITemplateTypeParameter.
DIE *getOrCreateTemplateTypeParameterDIE(DITemplateTypeParameter TP,
DIE &Buffer);
/// getOrCreateTemplateValueParameterDIE - Find existing DIE or create
/// new DIE for the given DITemplateValueParameter.
DIE *getOrCreateTemplateValueParameterDIE(DITemplateValueParameter TVP,
DIE &Buffer);
/// getOrCreateStaticMemberDIE - Create new static data member DIE. /// getOrCreateStaticMemberDIE - Create new static data member DIE.
DIE *getOrCreateStaticMemberDIE(DIDerivedType DT); DIE *getOrCreateStaticMemberDIE(DIDerivedType DT);