diff options
author | bunnei <bunneidev@gmail.com> | 2017-09-30 14:15:09 -0400 |
---|---|---|
committer | bunnei <bunneidev@gmail.com> | 2017-09-30 14:33:58 -0400 |
commit | 8c92435ded5c9c89290604a03e307c038b4d4117 (patch) | |
tree | 89640df0ae25ef5c78b79c1d8169f5ad6c25d63b /src/core/loader/nso.h | |
parent | fa1c7c7ee18af73f73a1160e48e57abbddcf8b23 (diff) |
nso: Refactor and allocate .bss section.
Diffstat (limited to 'src/core/loader/nso.h')
-rw-r--r-- | src/core/loader/nso.h | 25 |
1 files changed, 24 insertions, 1 deletions
diff --git a/src/core/loader/nso.h b/src/core/loader/nso.h index 39a9bd3d9..2d9e60ad7 100644 --- a/src/core/loader/nso.h +++ b/src/core/loader/nso.h @@ -4,9 +4,11 @@ #pragma once +#include <map> #include <string> #include "common/common_types.h" #include "common/file_util.h" +#include "core/hle/kernel/kernel.h" #include "core/loader/loader.h" namespace Loader { @@ -15,7 +17,8 @@ namespace Loader { class AppLoader_NSO final : public AppLoader { public: AppLoader_NSO(FileUtil::IOFile&& file, std::string filename, std::string filepath) - : AppLoader(std::move(file)), filename(std::move(filename)), filepath(std::move(filepath)) {} + : AppLoader(std::move(file)), filename(std::move(filename)), filepath(std::move(filepath)) { + } /** * Returns the type of the file @@ -31,6 +34,26 @@ public: ResultStatus Load() override; private: + struct Symbol { + Symbol(std::string&& name, u64 value) : name(std::move(name)), value(value) {} + std::string name; + u64 value; + }; + + struct Import { + VAddr ea; + s64 addend; + }; + + void WriteRelocations(const std::vector<Symbol>& symbols, VAddr load_base, + u64 relocation_offset, u64 size, bool is_jump_relocation); + VAddr GetEntryPoint() const; + bool LoadNso(const std::string& path, VAddr load_base); + void Relocate(VAddr load_base, VAddr dynamic_section_addr); + + std::map<std::string, Import> imports; + std::map<std::string, VAddr> exports; + std::string filename; std::string filepath; }; |