From 22438e4f6ee0067b5ebfad19aa332754dda28f3e Mon Sep 17 00:00:00 2001 From: georgemoralis Date: Tue, 9 Apr 2024 13:39:35 +0300 Subject: [PATCH 1/3] improved linker resolver --- src/core/linker.cpp | 72 ++++++++++++++++++++++++--------------------- 1 file changed, 39 insertions(+), 33 deletions(-) diff --git a/src/core/linker.cpp b/src/core/linker.cpp index ba38d4123..1c23fa6d6 100644 --- a/src/core/linker.cpp +++ b/src/core/linker.cpp @@ -559,44 +559,50 @@ void Linker::Resolve(const std::string& name, Loader::SymbolType sym_type, Modul Loader::SymbolRecord* return_info) { // std::scoped_lock lock{m_mutex}; const auto ids = Common::SplitString(name, '#'); - ASSERT_MSG(ids.size() == 3, "Symbols must be 3 parts name, library, module"); + if (ids.size() == 3) { + const auto* library = FindLibrary(*m, ids.at(1)); + const auto* module = FindModule(*m, ids.at(2)); + ASSERT_MSG(library && module, "Unable to find library and module"); - const auto* library = FindLibrary(*m, ids.at(1)); - const auto* module = FindModule(*m, ids.at(2)); - ASSERT_MSG(library && module, "Unable to find library and module"); + Loader::SymbolResolver sr{}; + sr.name = ids.at(0); + sr.library = library->name; + sr.library_version = library->version; + sr.module = module->name; + sr.module_version_major = module->version_major; + sr.module_version_minor = module->version_minor; + sr.type = sym_type; - Loader::SymbolResolver sr{}; - sr.name = ids.at(0); - sr.library = library->name; - sr.library_version = library->version; - sr.module = module->name; - sr.module_version_major = module->version_major; - sr.module_version_minor = module->version_minor; - sr.type = sym_type; + const Loader::SymbolRecord* rec = nullptr; - const Loader::SymbolRecord* rec = nullptr; - - rec = m_hle_symbols.FindSymbol(sr); - if (rec == nullptr) { - // check if it an export function - if (auto* p = FindExportedModule(*module, *library); - p != nullptr && p->export_sym.GetSize() > 0) { - rec = p->export_sym.FindSymbol(sr); + rec = m_hle_symbols.FindSymbol(sr); + if (rec == nullptr) { + // check if it an export function + if (auto* p = FindExportedModule(*module, *library); + p != nullptr && p->export_sym.GetSize() > 0) { + rec = p->export_sym.FindSymbol(sr); + } + } + if (rec != nullptr) { + *return_info = *rec; + } else { + auto aeronid = AeroLib::FindByNid(sr.name.c_str()); + if (aeronid) { + return_info->name = aeronid->name; + return_info->virtual_address = AeroLib::GetStub(aeronid->nid); + } else { + return_info->virtual_address = AeroLib::GetStub(sr.name.c_str()); + return_info->name = "Unknown !!!"; + } + LOG_ERROR(Core_Linker, "Linker: Stub resolved {} as {} (lib: {}, mod: {})", sr.name, + return_info->name, library->name, module->name); } } - if (rec != nullptr) { - *return_info = *rec; - } else { - auto aeronid = AeroLib::FindByNid(sr.name.c_str()); - if (aeronid) { - return_info->name = aeronid->name; - return_info->virtual_address = AeroLib::GetStub(aeronid->nid); - } else { - return_info->virtual_address = AeroLib::GetStub(sr.name.c_str()); - return_info->name = "Unknown !!!"; - } - LOG_ERROR(Core_Linker, "Linker: Stub resolved {} as {} (lib: {}, mod: {})", sr.name, - return_info->name, library->name, module->name); + else + { + return_info->virtual_address = 0; + return_info->name = name; + LOG_ERROR(Core_Linker, "Not Resolved {}", name); } } From 6a595f18db1942b9884b55a7fbab14bc4dc9cc28 Mon Sep 17 00:00:00 2001 From: georgemoralis Date: Tue, 9 Apr 2024 13:40:03 +0300 Subject: [PATCH 2/3] clang format fix --- src/core/linker.cpp | 4 +--- 1 file changed, 1 insertion(+), 3 deletions(-) diff --git a/src/core/linker.cpp b/src/core/linker.cpp index 1c23fa6d6..5bbf0a6cc 100644 --- a/src/core/linker.cpp +++ b/src/core/linker.cpp @@ -597,9 +597,7 @@ void Linker::Resolve(const std::string& name, Loader::SymbolType sym_type, Modul LOG_ERROR(Core_Linker, "Linker: Stub resolved {} as {} (lib: {}, mod: {})", sr.name, return_info->name, library->name, module->name); } - } - else - { + } else { return_info->virtual_address = 0; return_info->name = name; LOG_ERROR(Core_Linker, "Not Resolved {}", name); From c06346805bb6c78ea5776df40b0c4b0db78be71c Mon Sep 17 00:00:00 2001 From: georgemoralis Date: Tue, 9 Apr 2024 13:49:26 +0300 Subject: [PATCH 3/3] update sdl3 to latest --- externals/sdl3 | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/externals/sdl3 b/externals/sdl3 index 70b0d3310..c8a066019 160000 --- a/externals/sdl3 +++ b/externals/sdl3 @@ -1 +1 @@ -Subproject commit 70b0d33106e98176bf44de5d301855d49587fa50 +Subproject commit c8a066019b686351afc614a44a2111111c42d697