alexshap created this revision. Herald added a subscriber: JDevlieghere. A *.dwo file itself can have DW_AT_GNU_dwo_name (but no DW_AT_comp_dir) (clang 4.0 generates such DWOs). In this case there is no need to try to get a new module, and, more over, if we try (below) the method ModuleList::GetSharedModule will return an error + nullptr since the path is ill-formed (because comp_dir is null (since DW_AT_comp_dir is not present)).
Test plan: built a toy example + "br set --name f" + "p LocaVariable" (lld will search recursively for types and will call UpdateExternalModuleListIfNeeded) Repository: rL LLVM https://reviews.llvm.org/D37295 Files: source/Plugins/SymbolFile/DWARF/SymbolFileDWARF.cpp Index: source/Plugins/SymbolFile/DWARF/SymbolFileDWARF.cpp =================================================================== --- source/Plugins/SymbolFile/DWARF/SymbolFileDWARF.cpp +++ source/Plugins/SymbolFile/DWARF/SymbolFileDWARF.cpp @@ -1640,7 +1640,21 @@ } dwo_module_spec.GetArchitecture() = m_obj_file->GetModule()->GetArchitecture(); - // printf ("Loading dwo = '%s'\n", dwo_path); + + // A *.dwo file itself can have DW_AT_GNU_dwo_name (but no + // DW_AT_comp_dir) (clang 4.0 generates such DWOs). In this case + // there is no need to try to get a new module, and, more over, if + // we try (below) the method ModuleList::GetSharedModule will return + // an error + nullptr since the path is ill-formed (because comp_dir + // is null (since DW_AT_comp_dir is not present)). + if (m_obj_file->GetFileSpec() + .GetFileNameExtension() + .GetStringRef() == "dwo" && + llvm::StringRef(m_obj_file->GetFileSpec().GetPath()) + .endswith(dwo_module_spec.GetFileSpec().GetPath())) { + continue; + } + Status error = ModuleList::GetSharedModule( dwo_module_spec, module_sp, NULL, NULL, NULL); if (!module_sp) {
Index: source/Plugins/SymbolFile/DWARF/SymbolFileDWARF.cpp =================================================================== --- source/Plugins/SymbolFile/DWARF/SymbolFileDWARF.cpp +++ source/Plugins/SymbolFile/DWARF/SymbolFileDWARF.cpp @@ -1640,7 +1640,21 @@ } dwo_module_spec.GetArchitecture() = m_obj_file->GetModule()->GetArchitecture(); - // printf ("Loading dwo = '%s'\n", dwo_path); + + // A *.dwo file itself can have DW_AT_GNU_dwo_name (but no + // DW_AT_comp_dir) (clang 4.0 generates such DWOs). In this case + // there is no need to try to get a new module, and, more over, if + // we try (below) the method ModuleList::GetSharedModule will return + // an error + nullptr since the path is ill-formed (because comp_dir + // is null (since DW_AT_comp_dir is not present)). + if (m_obj_file->GetFileSpec() + .GetFileNameExtension() + .GetStringRef() == "dwo" && + llvm::StringRef(m_obj_file->GetFileSpec().GetPath()) + .endswith(dwo_module_spec.GetFileSpec().GetPath())) { + continue; + } + Status error = ModuleList::GetSharedModule( dwo_module_spec, module_sp, NULL, NULL, NULL); if (!module_sp) {
_______________________________________________ lldb-commits mailing list lldb-commits@lists.llvm.org http://lists.llvm.org/cgi-bin/mailman/listinfo/lldb-commits