mirror of
https://github.com/RPCSX/llvm.git
synced 2025-01-16 17:38:14 +00:00
It is ok, and convenient, to pass descriptors by value.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@110590 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
e4b9c4f187
commit
8162574aaa
@ -435,14 +435,14 @@ void DwarfDebug::addBlock(DIE *Die, unsigned Attribute, unsigned Form,
|
|||||||
|
|
||||||
/// addSourceLine - Add location information to specified debug information
|
/// addSourceLine - Add location information to specified debug information
|
||||||
/// entry.
|
/// entry.
|
||||||
void DwarfDebug::addSourceLine(DIE *Die, const DIVariable *V) {
|
void DwarfDebug::addSourceLine(DIE *Die, const DIVariable V) {
|
||||||
// Verify variable.
|
// Verify variable.
|
||||||
if (!V->Verify())
|
if (!V.Verify())
|
||||||
return;
|
return;
|
||||||
|
|
||||||
unsigned Line = V->getLineNumber();
|
unsigned Line = V.getLineNumber();
|
||||||
unsigned FileID = GetOrCreateSourceID(V->getContext().getDirectory(),
|
unsigned FileID = GetOrCreateSourceID(V.getContext().getDirectory(),
|
||||||
V->getContext().getFilename());
|
V.getContext().getFilename());
|
||||||
assert(FileID && "Invalid file id");
|
assert(FileID && "Invalid file id");
|
||||||
addUInt(Die, dwarf::DW_AT_decl_file, 0, FileID);
|
addUInt(Die, dwarf::DW_AT_decl_file, 0, FileID);
|
||||||
addUInt(Die, dwarf::DW_AT_decl_line, 0, Line);
|
addUInt(Die, dwarf::DW_AT_decl_line, 0, Line);
|
||||||
@ -450,14 +450,14 @@ void DwarfDebug::addSourceLine(DIE *Die, const DIVariable *V) {
|
|||||||
|
|
||||||
/// addSourceLine - Add location information to specified debug information
|
/// addSourceLine - Add location information to specified debug information
|
||||||
/// entry.
|
/// entry.
|
||||||
void DwarfDebug::addSourceLine(DIE *Die, const DIGlobalVariable *G) {
|
void DwarfDebug::addSourceLine(DIE *Die, const DIGlobalVariable G) {
|
||||||
// Verify global variable.
|
// Verify global variable.
|
||||||
if (!G->Verify())
|
if (!G.Verify())
|
||||||
return;
|
return;
|
||||||
|
|
||||||
unsigned Line = G->getLineNumber();
|
unsigned Line = G.getLineNumber();
|
||||||
unsigned FileID = GetOrCreateSourceID(G->getContext().getDirectory(),
|
unsigned FileID = GetOrCreateSourceID(G.getContext().getDirectory(),
|
||||||
G->getContext().getFilename());
|
G.getContext().getFilename());
|
||||||
assert(FileID && "Invalid file id");
|
assert(FileID && "Invalid file id");
|
||||||
addUInt(Die, dwarf::DW_AT_decl_file, 0, FileID);
|
addUInt(Die, dwarf::DW_AT_decl_file, 0, FileID);
|
||||||
addUInt(Die, dwarf::DW_AT_decl_line, 0, Line);
|
addUInt(Die, dwarf::DW_AT_decl_line, 0, Line);
|
||||||
@ -465,19 +465,19 @@ void DwarfDebug::addSourceLine(DIE *Die, const DIGlobalVariable *G) {
|
|||||||
|
|
||||||
/// addSourceLine - Add location information to specified debug information
|
/// addSourceLine - Add location information to specified debug information
|
||||||
/// entry.
|
/// entry.
|
||||||
void DwarfDebug::addSourceLine(DIE *Die, const DISubprogram *SP) {
|
void DwarfDebug::addSourceLine(DIE *Die, const DISubprogram SP) {
|
||||||
// Verify subprogram.
|
// Verify subprogram.
|
||||||
if (!SP->Verify())
|
if (!SP.Verify())
|
||||||
return;
|
return;
|
||||||
// If the line number is 0, don't add it.
|
// If the line number is 0, don't add it.
|
||||||
if (SP->getLineNumber() == 0)
|
if (SP.getLineNumber() == 0)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
unsigned Line = SP->getLineNumber();
|
unsigned Line = SP.getLineNumber();
|
||||||
if (!SP->getContext().Verify())
|
if (!SP.getContext().Verify())
|
||||||
return;
|
return;
|
||||||
unsigned FileID = GetOrCreateSourceID(SP->getDirectory(),
|
unsigned FileID = GetOrCreateSourceID(SP.getDirectory(),
|
||||||
SP->getFilename());
|
SP.getFilename());
|
||||||
assert(FileID && "Invalid file id");
|
assert(FileID && "Invalid file id");
|
||||||
addUInt(Die, dwarf::DW_AT_decl_file, 0, FileID);
|
addUInt(Die, dwarf::DW_AT_decl_file, 0, FileID);
|
||||||
addUInt(Die, dwarf::DW_AT_decl_line, 0, Line);
|
addUInt(Die, dwarf::DW_AT_decl_line, 0, Line);
|
||||||
@ -485,16 +485,16 @@ void DwarfDebug::addSourceLine(DIE *Die, const DISubprogram *SP) {
|
|||||||
|
|
||||||
/// addSourceLine - Add location information to specified debug information
|
/// addSourceLine - Add location information to specified debug information
|
||||||
/// entry.
|
/// entry.
|
||||||
void DwarfDebug::addSourceLine(DIE *Die, const DIType *Ty) {
|
void DwarfDebug::addSourceLine(DIE *Die, const DIType Ty) {
|
||||||
// Verify type.
|
// Verify type.
|
||||||
if (!Ty->Verify())
|
if (!Ty.Verify())
|
||||||
return;
|
return;
|
||||||
|
|
||||||
unsigned Line = Ty->getLineNumber();
|
unsigned Line = Ty.getLineNumber();
|
||||||
if (!Ty->getContext().Verify())
|
if (!Ty.getContext().Verify())
|
||||||
return;
|
return;
|
||||||
unsigned FileID = GetOrCreateSourceID(Ty->getContext().getDirectory(),
|
unsigned FileID = GetOrCreateSourceID(Ty.getContext().getDirectory(),
|
||||||
Ty->getContext().getFilename());
|
Ty.getContext().getFilename());
|
||||||
assert(FileID && "Invalid file id");
|
assert(FileID && "Invalid file id");
|
||||||
addUInt(Die, dwarf::DW_AT_decl_file, 0, FileID);
|
addUInt(Die, dwarf::DW_AT_decl_file, 0, FileID);
|
||||||
addUInt(Die, dwarf::DW_AT_decl_line, 0, Line);
|
addUInt(Die, dwarf::DW_AT_decl_line, 0, Line);
|
||||||
@ -502,14 +502,14 @@ void DwarfDebug::addSourceLine(DIE *Die, const DIType *Ty) {
|
|||||||
|
|
||||||
/// addSourceLine - Add location information to specified debug information
|
/// addSourceLine - Add location information to specified debug information
|
||||||
/// entry.
|
/// entry.
|
||||||
void DwarfDebug::addSourceLine(DIE *Die, const DINameSpace *NS) {
|
void DwarfDebug::addSourceLine(DIE *Die, const DINameSpace NS) {
|
||||||
// Verify namespace.
|
// Verify namespace.
|
||||||
if (!NS->Verify())
|
if (!NS.Verify())
|
||||||
return;
|
return;
|
||||||
|
|
||||||
unsigned Line = NS->getLineNumber();
|
unsigned Line = NS.getLineNumber();
|
||||||
StringRef FN = NS->getFilename();
|
StringRef FN = NS.getFilename();
|
||||||
StringRef Dir = NS->getDirectory();
|
StringRef Dir = NS.getDirectory();
|
||||||
|
|
||||||
unsigned FileID = GetOrCreateSourceID(Dir, FN);
|
unsigned FileID = GetOrCreateSourceID(Dir, FN);
|
||||||
assert(FileID && "Invalid file id");
|
assert(FileID && "Invalid file id");
|
||||||
@ -966,7 +966,7 @@ void DwarfDebug::constructTypeDIE(DIE &Buffer, DIDerivedType DTy) {
|
|||||||
|
|
||||||
// Add source line info if available and TyDesc is not a forward declaration.
|
// Add source line info if available and TyDesc is not a forward declaration.
|
||||||
if (!DTy.isForwardDecl())
|
if (!DTy.isForwardDecl())
|
||||||
addSourceLine(&Buffer, &DTy);
|
addSourceLine(&Buffer, DTy);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// constructTypeDIE - Construct type DIE from DICompositeType.
|
/// constructTypeDIE - Construct type DIE from DICompositeType.
|
||||||
@ -1040,7 +1040,7 @@ void DwarfDebug::constructTypeDIE(DIE &Buffer, DICompositeType CTy) {
|
|||||||
addType(ElemDie, DV.getType());
|
addType(ElemDie, DV.getType());
|
||||||
addUInt(ElemDie, dwarf::DW_AT_declaration, dwarf::DW_FORM_flag, 1);
|
addUInt(ElemDie, dwarf::DW_AT_declaration, dwarf::DW_FORM_flag, 1);
|
||||||
addUInt(ElemDie, dwarf::DW_AT_external, dwarf::DW_FORM_flag, 1);
|
addUInt(ElemDie, dwarf::DW_AT_external, dwarf::DW_FORM_flag, 1);
|
||||||
addSourceLine(ElemDie, &DV);
|
addSourceLine(ElemDie, DV);
|
||||||
} else if (Element.isDerivedType())
|
} else if (Element.isDerivedType())
|
||||||
ElemDie = createMemberDIE(DIDerivedType(Element));
|
ElemDie = createMemberDIE(DIDerivedType(Element));
|
||||||
else
|
else
|
||||||
@ -1090,7 +1090,7 @@ void DwarfDebug::constructTypeDIE(DIE &Buffer, DICompositeType CTy) {
|
|||||||
|
|
||||||
// Add source line info if available.
|
// Add source line info if available.
|
||||||
if (!CTy.isForwardDecl())
|
if (!CTy.isForwardDecl())
|
||||||
addSourceLine(&Buffer, &CTy);
|
addSourceLine(&Buffer, CTy);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1179,7 +1179,7 @@ DIE *DwarfDebug::createGlobalVariableDIE(const DIGlobalVariable &GV) {
|
|||||||
addType(GVDie, GV.getType());
|
addType(GVDie, GV.getType());
|
||||||
if (!GV.isLocalToUnit())
|
if (!GV.isLocalToUnit())
|
||||||
addUInt(GVDie, dwarf::DW_AT_external, dwarf::DW_FORM_flag, 1);
|
addUInt(GVDie, dwarf::DW_AT_external, dwarf::DW_FORM_flag, 1);
|
||||||
addSourceLine(GVDie, &GV);
|
addSourceLine(GVDie, GV);
|
||||||
|
|
||||||
return GVDie;
|
return GVDie;
|
||||||
}
|
}
|
||||||
@ -1193,7 +1193,7 @@ DIE *DwarfDebug::createMemberDIE(const DIDerivedType &DT) {
|
|||||||
|
|
||||||
addType(MemberDie, DT.getTypeDerivedFrom());
|
addType(MemberDie, DT.getTypeDerivedFrom());
|
||||||
|
|
||||||
addSourceLine(MemberDie, &DT);
|
addSourceLine(MemberDie, DT);
|
||||||
|
|
||||||
DIEBlock *MemLocationDie = new (DIEValueAllocator) DIEBlock();
|
DIEBlock *MemLocationDie = new (DIEValueAllocator) DIEBlock();
|
||||||
addUInt(MemLocationDie, 0, dwarf::DW_FORM_data1, dwarf::DW_OP_plus_uconst);
|
addUInt(MemLocationDie, 0, dwarf::DW_FORM_data1, dwarf::DW_OP_plus_uconst);
|
||||||
@ -1278,7 +1278,7 @@ DIE *DwarfDebug::createSubprogramDIE(const DISubprogram &SP, bool MakeDecl) {
|
|||||||
addString(SPDie, dwarf::DW_AT_MIPS_linkage_name, dwarf::DW_FORM_string,
|
addString(SPDie, dwarf::DW_AT_MIPS_linkage_name, dwarf::DW_FORM_string,
|
||||||
getRealLinkageName(LinkageName));
|
getRealLinkageName(LinkageName));
|
||||||
|
|
||||||
addSourceLine(SPDie, &SP);
|
addSourceLine(SPDie, SP);
|
||||||
|
|
||||||
// Add prototyped tag, if C or ObjC.
|
// Add prototyped tag, if C or ObjC.
|
||||||
unsigned Lang = SP.getCompileUnit().getLanguage();
|
unsigned Lang = SP.getCompileUnit().getLanguage();
|
||||||
@ -1591,7 +1591,7 @@ DIE *DwarfDebug::constructVariableDIE(DbgVariable *DV, DbgScope *Scope) {
|
|||||||
dwarf::DW_FORM_ref4, AbsDIE);
|
dwarf::DW_FORM_ref4, AbsDIE);
|
||||||
else {
|
else {
|
||||||
addString(VariableDie, dwarf::DW_AT_name, dwarf::DW_FORM_string, Name);
|
addString(VariableDie, dwarf::DW_AT_name, dwarf::DW_FORM_string, Name);
|
||||||
addSourceLine(VariableDie, &VD);
|
addSourceLine(VariableDie, VD);
|
||||||
|
|
||||||
// Add variable type.
|
// Add variable type.
|
||||||
// FIXME: isBlockByrefVariable should be reformulated in terms of complex
|
// FIXME: isBlockByrefVariable should be reformulated in terms of complex
|
||||||
@ -1796,7 +1796,7 @@ DIE *DwarfDebug::getOrCreateNameSpace(DINameSpace NS) {
|
|||||||
TheCU->insertDIE(NS, NDie);
|
TheCU->insertDIE(NS, NDie);
|
||||||
if (!NS.getName().empty())
|
if (!NS.getName().empty())
|
||||||
addString(NDie, dwarf::DW_AT_name, dwarf::DW_FORM_string, NS.getName());
|
addString(NDie, dwarf::DW_AT_name, dwarf::DW_FORM_string, NS.getName());
|
||||||
addSourceLine(NDie, &NS);
|
addSourceLine(NDie, NS);
|
||||||
addToContextOwner(NDie, NS.getContext());
|
addToContextOwner(NDie, NS.getContext());
|
||||||
return NDie;
|
return NDie;
|
||||||
}
|
}
|
||||||
|
@ -338,11 +338,11 @@ private:
|
|||||||
|
|
||||||
/// addSourceLine - Add location information to specified debug information
|
/// addSourceLine - Add location information to specified debug information
|
||||||
/// entry.
|
/// entry.
|
||||||
void addSourceLine(DIE *Die, const DIVariable *V);
|
void addSourceLine(DIE *Die, const DIVariable V);
|
||||||
void addSourceLine(DIE *Die, const DIGlobalVariable *G);
|
void addSourceLine(DIE *Die, const DIGlobalVariable G);
|
||||||
void addSourceLine(DIE *Die, const DISubprogram *SP);
|
void addSourceLine(DIE *Die, const DISubprogram SP);
|
||||||
void addSourceLine(DIE *Die, const DIType *Ty);
|
void addSourceLine(DIE *Die, const DIType Ty);
|
||||||
void addSourceLine(DIE *Die, const DINameSpace *NS);
|
void addSourceLine(DIE *Die, const DINameSpace NS);
|
||||||
|
|
||||||
/// addAddress - Add an address attribute to a die based on the location
|
/// addAddress - Add an address attribute to a die based on the location
|
||||||
/// provided.
|
/// provided.
|
||||||
|
Loading…
x
Reference in New Issue
Block a user