diff options
| author | Dimitry Andric <dim@FreeBSD.org> | 2021-02-16 20:13:02 +0000 | 
|---|---|---|
| committer | Dimitry Andric <dim@FreeBSD.org> | 2021-02-16 20:13:02 +0000 | 
| commit | b60736ec1405bb0a8dd40989f67ef4c93da068ab (patch) | |
| tree | 5c43fbb7c9fc45f0f87e0e6795a86267dbd12f9d /lldb/source/Plugins/ObjectFile/wasm/ObjectFileWasm.cpp | |
| parent | cfca06d7963fa0909f90483b42a6d7d194d01e08 (diff) | |
Diffstat (limited to 'lldb/source/Plugins/ObjectFile/wasm/ObjectFileWasm.cpp')
| -rw-r--r-- | lldb/source/Plugins/ObjectFile/wasm/ObjectFileWasm.cpp | 61 | 
1 files changed, 38 insertions, 23 deletions
| diff --git a/lldb/source/Plugins/ObjectFile/wasm/ObjectFileWasm.cpp b/lldb/source/Plugins/ObjectFile/wasm/ObjectFileWasm.cpp index 91150fa02ebc..6c29c2326212 100644 --- a/lldb/source/Plugins/ObjectFile/wasm/ObjectFileWasm.cpp +++ b/lldb/source/Plugins/ObjectFile/wasm/ObjectFileWasm.cpp @@ -253,6 +253,43 @@ bool ObjectFileWasm::ParseHeader() {  Symtab *ObjectFileWasm::GetSymtab() { return nullptr; } +static SectionType GetSectionTypeFromName(llvm::StringRef Name) { +  if (Name.consume_front(".debug_") || Name.consume_front(".zdebug_")) { +    return llvm::StringSwitch<SectionType>(Name) +        .Case("abbrev", eSectionTypeDWARFDebugAbbrev) +        .Case("abbrev.dwo", eSectionTypeDWARFDebugAbbrevDwo) +        .Case("addr", eSectionTypeDWARFDebugAddr) +        .Case("aranges", eSectionTypeDWARFDebugAranges) +        .Case("cu_index", eSectionTypeDWARFDebugCuIndex) +        .Case("frame", eSectionTypeDWARFDebugFrame) +        .Case("info", eSectionTypeDWARFDebugInfo) +        .Case("info.dwo", eSectionTypeDWARFDebugInfoDwo) +        .Cases("line", "line.dwo", eSectionTypeDWARFDebugLine) +        .Cases("line_str", "line_str.dwo", eSectionTypeDWARFDebugLineStr) +        .Case("loc", eSectionTypeDWARFDebugLoc) +        .Case("loc.dwo", eSectionTypeDWARFDebugLocDwo) +        .Case("loclists", eSectionTypeDWARFDebugLocLists) +        .Case("loclists.dwo", eSectionTypeDWARFDebugLocListsDwo) +        .Case("macinfo", eSectionTypeDWARFDebugMacInfo) +        .Cases("macro", "macro.dwo", eSectionTypeDWARFDebugMacro) +        .Case("names", eSectionTypeDWARFDebugNames) +        .Case("pubnames", eSectionTypeDWARFDebugPubNames) +        .Case("pubtypes", eSectionTypeDWARFDebugPubTypes) +        .Case("ranges", eSectionTypeDWARFDebugRanges) +        .Case("rnglists", eSectionTypeDWARFDebugRngLists) +        .Case("rnglists.dwo", eSectionTypeDWARFDebugRngListsDwo) +        .Case("str", eSectionTypeDWARFDebugStr) +        .Case("str.dwo", eSectionTypeDWARFDebugStrDwo) +        .Case("str_offsets", eSectionTypeDWARFDebugStrOffsets) +        .Case("str_offsets.dwo", eSectionTypeDWARFDebugStrOffsetsDwo) +        .Case("tu_index", eSectionTypeDWARFDebugTuIndex) +        .Case("types", eSectionTypeDWARFDebugTypes) +        .Case("types.dwo", eSectionTypeDWARFDebugTypesDwo) +        .Default(eSectionTypeOther); +  } +  return eSectionTypeOther; +} +  void ObjectFileWasm::CreateSections(SectionList &unified_section_list) {    if (m_sections_up)      return; @@ -280,29 +317,7 @@ void ObjectFileWasm::CreateSections(SectionList &unified_section_list) {        // Code section.        vm_addr = 0;      } else { -      section_type = -          llvm::StringSwitch<SectionType>(sect_info.name.GetStringRef()) -              .Case(".debug_abbrev", eSectionTypeDWARFDebugAbbrev) -              .Case(".debug_addr", eSectionTypeDWARFDebugAddr) -              .Case(".debug_aranges", eSectionTypeDWARFDebugAranges) -              .Case(".debug_cu_index", eSectionTypeDWARFDebugCuIndex) -              .Case(".debug_frame", eSectionTypeDWARFDebugFrame) -              .Case(".debug_info", eSectionTypeDWARFDebugInfo) -              .Case(".debug_line", eSectionTypeDWARFDebugLine) -              .Case(".debug_line_str", eSectionTypeDWARFDebugLineStr) -              .Case(".debug_loc", eSectionTypeDWARFDebugLoc) -              .Case(".debug_loclists", eSectionTypeDWARFDebugLocLists) -              .Case(".debug_macinfo", eSectionTypeDWARFDebugMacInfo) -              .Case(".debug_macro", eSectionTypeDWARFDebugMacro) -              .Case(".debug_names", eSectionTypeDWARFDebugNames) -              .Case(".debug_pubnames", eSectionTypeDWARFDebugPubNames) -              .Case(".debug_pubtypes", eSectionTypeDWARFDebugPubTypes) -              .Case(".debug_ranges", eSectionTypeDWARFDebugRanges) -              .Case(".debug_rnglists", eSectionTypeDWARFDebugRngLists) -              .Case(".debug_str", eSectionTypeDWARFDebugStr) -              .Case(".debug_str_offsets", eSectionTypeDWARFDebugStrOffsets) -              .Case(".debug_types", eSectionTypeDWARFDebugTypes) -              .Default(eSectionTypeOther); +      section_type = GetSectionTypeFromName(sect_info.name.GetStringRef());        if (section_type == eSectionTypeOther)          continue;        section_name = sect_info.name; | 
