mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-23 11:13:28 +01:00
Fix the assembly and dissassembly of DW_FORM_sec_offset. Found this by
changing both the string of the dwo_name to be correct and the type of the statement list. Testcases all around. llvm-svn: 172699
This commit is contained in:
parent
7c06c5fb2b
commit
bd3c66b31a
@ -254,6 +254,7 @@ void DIELabel::EmitValue(AsmPrinter *AP, unsigned Form) const {
|
||||
///
|
||||
unsigned DIELabel::SizeOf(AsmPrinter *AP, unsigned Form) const {
|
||||
if (Form == dwarf::DW_FORM_data4) return 4;
|
||||
if (Form == dwarf::DW_FORM_sec_offset) return 4;
|
||||
if (Form == dwarf::DW_FORM_strp) return 4;
|
||||
return AP->getDataLayout().getPointerSize();
|
||||
}
|
||||
|
@ -2433,14 +2433,16 @@ void DwarfDebug::emitDebugInlineInfo() {
|
||||
// DW_AT_low_pc and DW_AT_high_pc are not used, and vice versa.
|
||||
CompileUnit *DwarfDebug::constructSkeletonCU(const MDNode *N) {
|
||||
DICompileUnit DIUnit(N);
|
||||
StringRef FN = DIUnit.getFilename();
|
||||
CompilationDir = DIUnit.getDirectory();
|
||||
|
||||
DIE *Die = new DIE(dwarf::DW_TAG_compile_unit);
|
||||
CompileUnit *NewCU = new CompileUnit(GlobalCUIndexCount++,
|
||||
DIUnit.getLanguage(), Die, Asm,
|
||||
this, &SkeletonHolder);
|
||||
// FIXME: This should be the .dwo file.
|
||||
|
||||
SmallString<16> T(DIUnit.getFilename());
|
||||
sys::path::replace_extension(T, ".dwo");
|
||||
StringRef FN = sys::path::filename(T);
|
||||
NewCU->addLocalString(Die, dwarf::DW_AT_GNU_dwo_name, FN);
|
||||
|
||||
// FIXME: We also need DW_AT_dwo_id.
|
||||
@ -2456,10 +2458,10 @@ CompileUnit *DwarfDebug::constructSkeletonCU(const MDNode *N) {
|
||||
// DW_AT_stmt_list is a offset of line number information for this
|
||||
// compile unit in debug_line section.
|
||||
if (Asm->MAI->doesDwarfUseRelocationsAcrossSections())
|
||||
NewCU->addLabel(Die, dwarf::DW_AT_stmt_list, dwarf::DW_FORM_data4,
|
||||
NewCU->addLabel(Die, dwarf::DW_AT_stmt_list, dwarf::DW_FORM_sec_offset,
|
||||
Asm->GetTempSymbol("section_line"));
|
||||
else
|
||||
NewCU->addUInt(Die, dwarf::DW_AT_stmt_list, dwarf::DW_FORM_data4, 0);
|
||||
NewCU->addUInt(Die, dwarf::DW_AT_stmt_list, dwarf::DW_FORM_sec_offset, 0);
|
||||
|
||||
if (!CompilationDir.empty())
|
||||
NewCU->addLocalString(Die, dwarf::DW_AT_comp_dir, CompilationDir);
|
||||
|
@ -203,11 +203,9 @@ bool DWARFDebugInfoEntryMinimal::extractFast(const DWARFCompileUnit *cu,
|
||||
form = debug_info_data.getULEB128(&offset);
|
||||
break;
|
||||
|
||||
// FIXME: 64-bit for DWARF64
|
||||
case DW_FORM_sec_offset:
|
||||
if (cu->getAddressByteSize() == 4)
|
||||
debug_info_data.getU32(offset_ptr);
|
||||
else
|
||||
debug_info_data.getU64(offset_ptr);
|
||||
debug_info_data.getU32(offset_ptr);
|
||||
break;
|
||||
|
||||
default:
|
||||
@ -344,11 +342,9 @@ DWARFDebugInfoEntryMinimal::extract(const DWARFCompileUnit *cu,
|
||||
form_is_indirect = true;
|
||||
break;
|
||||
|
||||
// FIXME: 64-bit for DWARF64.
|
||||
case DW_FORM_sec_offset:
|
||||
if (cu->getAddressByteSize() == 4)
|
||||
debug_info_data.getU32(offset_ptr);
|
||||
else
|
||||
debug_info_data.getU64(offset_ptr);
|
||||
debug_info_data.getU32(offset_ptr);
|
||||
break;
|
||||
|
||||
default:
|
||||
|
@ -72,7 +72,7 @@ static const uint8_t form_sizes_addr8[] = {
|
||||
8, // 0x14 DW_FORM_ref8
|
||||
0, // 0x15 DW_FORM_ref_udata
|
||||
0, // 0x16 DW_FORM_indirect
|
||||
8, // 0x17 DW_FORM_sec_offset
|
||||
4, // 0x17 DW_FORM_sec_offset
|
||||
0, // 0x18 DW_FORM_exprloc
|
||||
0, // 0x19 DW_FORM_flag_present
|
||||
8, // 0x20 DW_FORM_ref_sig8
|
||||
@ -299,12 +299,9 @@ DWARFFormValue::skipValue(uint16_t form, DataExtractor debug_info_data,
|
||||
form = debug_info_data.getULEB128(offset_ptr);
|
||||
break;
|
||||
|
||||
// 4 for DWARF32, 8 for DWARF64.
|
||||
// FIXME: 4 for DWARF32, 8 for DWARF64.
|
||||
case DW_FORM_sec_offset:
|
||||
if (cu->getAddressByteSize() == 4)
|
||||
*offset_ptr += 4;
|
||||
else
|
||||
*offset_ptr += 8;
|
||||
*offset_ptr += 4;
|
||||
return true;
|
||||
|
||||
default:
|
||||
@ -427,11 +424,9 @@ DWARFFormValue::dump(raw_ostream &OS, const DWARFCompileUnit *cu) const {
|
||||
OS << "DW_FORM_indirect";
|
||||
break;
|
||||
|
||||
// Should be formatted to 64-bit for DWARF64.
|
||||
case DW_FORM_sec_offset:
|
||||
if (cu->getAddressByteSize() == 4)
|
||||
OS << format("0x%08x", (uint32_t)uvalue);
|
||||
else
|
||||
OS << format("0x%016" PRIx64, uvalue);
|
||||
OS << format("0x%08x", (uint32_t)uvalue);
|
||||
break;
|
||||
|
||||
default:
|
||||
|
@ -21,11 +21,15 @@
|
||||
|
||||
; CHECK: .debug_info contents:
|
||||
; CHECK: DW_TAG_compile_unit
|
||||
; CHECK: DW_AT_GNU_dwo_name [DW_FORM_strp] ( .debug_str[0x00000000] = "baz.c")
|
||||
; CHECK: DW_AT_GNU_addr_base [DW_FORM_sec_offset] (0x0000000000000000)
|
||||
; CHECK: DW_AT_GNU_dwo_name [DW_FORM_strp] ( .debug_str[0x00000000] = "baz.dwo")
|
||||
; CHECK: DW_AT_GNU_addr_base [DW_FORM_sec_offset] (0x00000000)
|
||||
; CHECK: DW_AT_low_pc [DW_FORM_addr] (0x0000000000000000)
|
||||
; CHECK: DW_AT_stmt_list [DW_FORM_data4] (0x00000000)
|
||||
; CHECK: DW_AT_comp_dir [DW_FORM_strp] ( .debug_str[0x00000006] = "/usr/local/google/home/echristo/tmp")
|
||||
; CHECK: DW_AT_stmt_list [DW_FORM_sec_offset] (0x00000000)
|
||||
; CHECK: DW_AT_comp_dir [DW_FORM_strp] ( .debug_str[0x00000008] = "/usr/local/google/home/echristo/tmp")
|
||||
|
||||
; CHECK: .debug_str contents:
|
||||
; CHECK: 0x00000000: "baz.dwo"
|
||||
; CHECK: 0x00000008: "/usr/local/google/home/echristo/tmp"
|
||||
|
||||
; Check that we're using the right forms.
|
||||
; CHECK: .debug_abbrev.dwo contents:
|
||||
|
Loading…
Reference in New Issue
Block a user