1
0
Fork 0
mirror of https://github.com/jakcron/nstool.git synced 2025-01-10 11:45:28 +00:00

Port ElfSymbolParser to libtoolchain.

This commit is contained in:
jakcron 2021-09-30 19:42:15 +08:00
parent 0c6efad603
commit 258173915c
2 changed files with 14 additions and 13 deletions

View file

@ -1,8 +1,9 @@
#include "ElfSymbolParser.h" #include "ElfSymbolParser.h"
nstool::ElfSymbolParser::ElfSymbolParser() nstool::ElfSymbolParser::ElfSymbolParser() :
mModuleName("nstool::ElfSymbolParser"),
mSymbolList()
{ {
mSymbolList.clear();
} }
void nstool::ElfSymbolParser::operator=(const ElfSymbolParser& other) void nstool::ElfSymbolParser::operator=(const ElfSymbolParser& other)
@ -22,7 +23,7 @@ bool nstool::ElfSymbolParser::operator!=(const ElfSymbolParser& other) const
void nstool::ElfSymbolParser::parseData(const byte_t *dyn_sym, size_t dyn_sym_size, const byte_t *dyn_str, size_t dyn_str_size, bool is64Bit) void nstool::ElfSymbolParser::parseData(const byte_t *dyn_sym, size_t dyn_sym_size, const byte_t *dyn_str, size_t dyn_str_size, bool is64Bit)
{ {
size_t dynSymSize = is64Bit ? sizeof(fnd::Elf64_Sym) : sizeof(fnd::Elf32_Sym); size_t dynSymSize = is64Bit ? sizeof(Elf64_Sym) : sizeof(Elf32_Sym);
sElfSymbol symbol; sElfSymbol symbol;
for (size_t i = 0; i < dyn_sym_size; i += dynSymSize) for (size_t i = 0; i < dyn_sym_size; i += dynSymSize)
@ -31,22 +32,22 @@ void nstool::ElfSymbolParser::parseData(const byte_t *dyn_sym, size_t dyn_sym_si
if (is64Bit) if (is64Bit)
{ {
name_pos = le_word(((fnd::Elf64_Sym*)(dyn_sym + i))->st_name); name_pos = tc::bn::detail::__le_uint32(((Elf64_Sym*)(dyn_sym + i))->st_name);
symbol.shn_index = le_hword(((fnd::Elf64_Sym*)(dyn_sym + i))->st_shndx); symbol.shn_index = tc::bn::detail::__le_uint16(((Elf64_Sym*)(dyn_sym + i))->st_shndx);
symbol.symbol_type = fnd::elf::get_elf_st_type(((fnd::Elf64_Sym*)(dyn_sym + i))->st_info); symbol.symbol_type = elf::get_elf_st_type(((Elf64_Sym*)(dyn_sym + i))->st_info);
symbol.symbol_binding = fnd::elf::get_elf_st_bind(((fnd::Elf64_Sym*)(dyn_sym + i))->st_info); symbol.symbol_binding = elf::get_elf_st_bind(((Elf64_Sym*)(dyn_sym + i))->st_info);
} }
else else
{ {
name_pos = le_word(((fnd::Elf32_Sym*)(dyn_sym + i))->st_name); name_pos = tc::bn::detail::__le_uint32(((Elf32_Sym*)(dyn_sym + i))->st_name);
symbol.shn_index = le_hword(((fnd::Elf32_Sym*)(dyn_sym + i))->st_shndx); symbol.shn_index = tc::bn::detail::__le_uint16(((Elf32_Sym*)(dyn_sym + i))->st_shndx);
symbol.symbol_type = fnd::elf::get_elf_st_type(((fnd::Elf32_Sym*)(dyn_sym + i))->st_info); symbol.symbol_type = elf::get_elf_st_type(((Elf32_Sym*)(dyn_sym + i))->st_info);
symbol.symbol_binding = fnd::elf::get_elf_st_bind(((fnd::Elf32_Sym*)(dyn_sym + i))->st_info); symbol.symbol_binding = elf::get_elf_st_bind(((Elf32_Sym*)(dyn_sym + i))->st_info);
} }
if (name_pos >= dyn_str_size) if (name_pos >= dyn_str_size)
{ {
throw tc::Exception(kModuleName, "Out of bounds symbol name offset"); throw tc::Exception(mModuleName, "Out of bounds symbol name offset");
} }
//for (; dyn_str[name_pos] == 0x00 && name_pos < dyn_str_size; name_pos++); //for (; dyn_str[name_pos] == 0x00 && name_pos < dyn_str_size; name_pos++);

View file

@ -43,7 +43,7 @@ public:
const std::vector<sElfSymbol>& getSymbolList() const; const std::vector<sElfSymbol>& getSymbolList() const;
private: private:
const std::string kModuleName = "ElfSymbolParser"; std::string mModuleName;
// data // data
std::vector<sElfSymbol> mSymbolList; std::vector<sElfSymbol> mSymbolList;