ladybird/Userland/Libraries/LibX86/ELFSymbolProvider.h
Daniel Bertalan 15a14d3d21 LibX86: Take load base address into consideration during disassembly
Since our executables are position-independent, the address values
extraced from processes don't correspond to their values within the ELF
file. We have to offset the absolute addresses by the load base address
to get the relative symbol that we need for disassembly.
2021-10-25 12:14:26 +02:00

31 lines
643 B
C++

/*
* Copyright (c) 2020-2021, the SerenityOS developers.
*
* SPDX-License-Identifier: BSD-2-Clause
*/
#pragma once
#include <LibELF/Image.h>
#include <LibX86/Instruction.h>
namespace X86 {
class ELFSymbolProvider final : public SymbolProvider {
public:
ELFSymbolProvider(const ELF::Image& elf, FlatPtr base_address = 0)
: m_elf(elf)
, m_base_address(base_address)
{
}
virtual String symbolicate(FlatPtr address, u32* offset = nullptr) const override
{
return m_elf.symbolicate(address - m_base_address, offset);
}
private:
const ELF::Image& m_elf;
FlatPtr m_base_address;
};
}