Move emission of the debug string table to early in the debug

info finalization to greatly reduce the number of fixups that the
assembler has to handle in order to improve compile time.

llvm-svn: 191119
This commit is contained in:
Eric Christopher 2013-09-20 23:22:52 +00:00
parent 6e35094bbf
commit 9cd26af8b6
6 changed files with 59 additions and 35 deletions

View File

@ -843,6 +843,34 @@ void CompileUnit::addType(DIE *Entity, DIType Ty, uint16_t Attribute) {
addGlobalType(Ty); addGlobalType(Ty);
} }
// Accelerator table mutators - add each name along with its companion
// DIE to the proper table while ensuring that the name that we're going
// to reference is in the string table. We do this since the names we
// add may not only be identical to the names in the DIE.
void CompileUnit::addAccelName(StringRef Name, DIE *Die) {
DU->getStringPoolEntry(Name);
std::vector<DIE*> &DIEs = AccelNames[Name];
DIEs.push_back(Die);
}
void CompileUnit::addAccelObjC(StringRef Name, DIE *Die) {
DU->getStringPoolEntry(Name);
std::vector<DIE*> &DIEs = AccelObjC[Name];
DIEs.push_back(Die);
}
void CompileUnit::addAccelNamespace(StringRef Name, DIE *Die) {
DU->getStringPoolEntry(Name);
std::vector<DIE*> &DIEs = AccelNamespace[Name];
DIEs.push_back(Die);
}
void CompileUnit::addAccelType(StringRef Name, std::pair<DIE *, unsigned> Die) {
DU->getStringPoolEntry(Name);
std::vector<std::pair<DIE *, unsigned> > &DIEs = AccelTypes[Name];
DIEs.push_back(Die);
}
/// addGlobalName - Add a new global name to the compile unit. /// addGlobalName - Add a new global name to the compile unit.
void CompileUnit::addGlobalName(StringRef Name, DIE *Die) { void CompileUnit::addGlobalName(StringRef Name, DIE *Die) {
GlobalNames[Name] = Die; GlobalNames[Name] = Die;

View File

@ -136,22 +136,16 @@ public:
void addGlobalType(DIType Ty); void addGlobalType(DIType Ty);
/// addAccelName - Add a new name to the name accelerator table. /// addAccelName - Add a new name to the name accelerator table.
void addAccelName(StringRef Name, DIE *Die) { void addAccelName(StringRef Name, DIE *Die);
std::vector<DIE*> &DIEs = AccelNames[Name];
DIEs.push_back(Die); /// addAccelObjC - Add a new name to the ObjC accelerator table.
} void addAccelObjC(StringRef Name, DIE *Die);
void addAccelObjC(StringRef Name, DIE *Die) {
std::vector<DIE*> &DIEs = AccelObjC[Name]; /// addAccelNamespace - Add a new name to the namespace accelerator table.
DIEs.push_back(Die); void addAccelNamespace(StringRef Name, DIE *Die);
}
void addAccelNamespace(StringRef Name, DIE *Die) { /// addAccelType - Add a new type to the type accelerator table.
std::vector<DIE*> &DIEs = AccelNamespace[Name]; void addAccelType(StringRef Name, std::pair<DIE *, unsigned> Die);
DIEs.push_back(Die);
}
void addAccelType(StringRef Name, std::pair<DIE *, unsigned> Die) {
std::vector<std::pair<DIE *, unsigned> > &DIEs = AccelTypes[Name];
DIEs.push_back(Die);
}
/// getDIE - Returns the debug information entry map slot for the /// getDIE - Returns the debug information entry map slot for the
/// specified debug variable. /// specified debug variable.

View File

@ -313,10 +313,12 @@ static StringRef getObjCMethodName(StringRef In) {
} }
// Add the various names to the Dwarf accelerator table names. // Add the various names to the Dwarf accelerator table names.
// TODO: Determine whether or not we should add names for programs
// that do not have a DW_AT_name or DW_AT_linkage_name field - this
// is only slightly different than the lookup of non-standard ObjC names.
static void addSubprogramNames(CompileUnit *TheCU, DISubprogram SP, static void addSubprogramNames(CompileUnit *TheCU, DISubprogram SP,
DIE* Die) { DIE* Die) {
if (!SP.isDefinition()) return; if (!SP.isDefinition()) return;
TheCU->addAccelName(SP.getName(), Die); TheCU->addAccelName(SP.getName(), Die);
// If the linkage name is different than the name, go ahead and output // If the linkage name is different than the name, go ahead and output
@ -1126,6 +1128,8 @@ void DwarfDebug::endModule() {
finalizeModuleInfo(); finalizeModuleInfo();
if (!useSplitDwarf()) { if (!useSplitDwarf()) {
emitDebugStr();
// Emit all the DIEs into a debug info section. // Emit all the DIEs into a debug info section.
emitDebugInfo(); emitDebugInfo();
@ -1147,6 +1151,9 @@ void DwarfDebug::endModule() {
} else { } else {
// TODO: Fill this in for separated debug sections and separate // TODO: Fill this in for separated debug sections and separate
// out information into new sections. // out information into new sections.
emitDebugStr();
if (useSplitDwarf())
emitDebugStrDWO();
// Emit the debug info section and compile units. // Emit the debug info section and compile units.
emitDebugInfo(); emitDebugInfo();
@ -1187,11 +1194,6 @@ void DwarfDebug::endModule() {
emitDebugPubTypes(GenerateGnuPubSections); emitDebugPubTypes(GenerateGnuPubSections);
} }
// Finally emit string information into a string table.
emitDebugStr();
if (useSplitDwarf())
emitDebugStrDWO();
// clean up. // clean up.
SPMap.clear(); SPMap.clear();
for (DenseMap<const MDNode *, CompileUnit *>::iterator I = CUMap.begin(), for (DenseMap<const MDNode *, CompileUnit *>::iterator I = CUMap.begin(),

View File

@ -23,7 +23,10 @@
; CHECK: add x29, sp, #416 ; CHECK: add x29, sp, #416
; CHECK: add {{x[0-9]+}}, sp, #4 ; CHECK: add {{x[0-9]+}}, sp, #4
; Now check the debugging information reflects this: ; CHECK: .Linfo_string7:
; CHECK-NEXT: main_arr
; Now check the debugging information reflects this:
; CHECK: DW_TAG_variable ; CHECK: DW_TAG_variable
; CHECK-NEXT: .word .Linfo_string7 ; CHECK-NEXT: .word .Linfo_string7
@ -32,8 +35,6 @@
; CHECK-NEXT: .byte 145 ; CHECK-NEXT: .byte 145
; CHECK-NEXT: .ascii "\344|" ; CHECK-NEXT: .ascii "\344|"
; CHECK: .Linfo_string7:
; CHECK-NEXT: main_arr
target datalayout = "e-p:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-i128:128:128-f32:32:32-f64:64:64-f128:128:128-n32:64-S128" target datalayout = "e-p:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-i128:128:128-f32:32:32-f64:64:64-f128:128:128-n32:64-S128"

View File

@ -11,6 +11,9 @@
; CHECK: la %r2, 164(%r11) ; CHECK: la %r2, 164(%r11)
; CHECK: brasl %r14, populate_array@PLT ; CHECK: brasl %r14, populate_array@PLT
; ;
; CHECK: .Linfo_string7:
; CHECK-NEXT: main_arr
;
; Now check that the debugging information reflects this: ; Now check that the debugging information reflects this:
; CHECK: DW_TAG_variable ; CHECK: DW_TAG_variable
; CHECK-NEXT: .long .Linfo_string7 ; CHECK-NEXT: .long .Linfo_string7
@ -21,8 +24,6 @@
; CHECK-NEXT: .byte 145 ; CHECK-NEXT: .byte 145
; CHECK-NEXT: .ascii "\244\001" ; CHECK-NEXT: .ascii "\244\001"
; ;
; CHECK: .Linfo_string7:
; CHECK-NEXT: main_arr
@.str = private unnamed_addr constant [13 x i8] c"Total is %d\0A\00", align 2 @.str = private unnamed_addr constant [13 x i8] c"Total is %d\0A\00", align 2

View File

@ -16,6 +16,12 @@
!7 = metadata !{i32 720932, null, null, metadata !"int", i32 0, i64 32, i64 32, i64 0, i32 0, i32 5} ; [ DW_TAG_base_type ] !7 = metadata !{i32 720932, null, null, metadata !"int", i32 0, i64 32, i64 32, i64 0, i32 0, i32 5} ; [ DW_TAG_base_type ]
!8 = metadata !{metadata !"z.c", metadata !"/home/nicholas"} !8 = metadata !{metadata !"z.c", metadata !"/home/nicholas"}
; Verify that "yyyy" ended up in the stringpool.
; LINUX: .section .debug_str,"MS",@progbits,1
; LINUX: yyyy
; DARWIN: .section __DWARF,__debug_str,regular,debug
; DARWIN: yyyy
; Verify that we refer to 'yyyy' with a relocation. ; Verify that we refer to 'yyyy' with a relocation.
; LINUX: .long .Linfo_string3 # DW_AT_name ; LINUX: .long .Linfo_string3 # DW_AT_name
; LINUX-NEXT: .long 38 # DW_AT_type ; LINUX-NEXT: .long 38 # DW_AT_type
@ -36,11 +42,3 @@
; DARWIN-NEXT: .byte 9 ## DW_AT_location ; DARWIN-NEXT: .byte 9 ## DW_AT_location
; DARWIN-NEXT: .byte 3 ; DARWIN-NEXT: .byte 3
; DARWIN-NEXT: .quad _yyyy ; DARWIN-NEXT: .quad _yyyy
; Verify that "yyyy" ended up in the stringpool.
; LINUX: .section .debug_str,"MS",@progbits,1
; LINUX-NOT: .section
; LINUX: yyyy
; DARWIN: .section __DWARF,__debug_str,regular,debug
; DARWIN-NOT: .section
; DARWIN: yyyy