Files
llvm-project/lldb/source/Plugins/ObjectFile/ELF/ObjectFileELF.h
T

365 lines
12 KiB
C++
Raw Normal View History

2010-07-13 23:07:23 +00:00
//===-- ObjectFileELF.h --------------------------------------- -*- C++ -*-===//
//
// The LLVM Compiler Infrastructure
//
// This file is distributed under the University of Illinois Open Source
// License. See LICENSE.TXT for details.
//
//===----------------------------------------------------------------------===//
#ifndef liblldb_ObjectFileELF_h_
#define liblldb_ObjectFileELF_h_
#include <stdint.h>
#include <vector>
#include "lldb/lldb-private.h"
#include "lldb/Host/FileSpec.h"
#include "lldb/Symbol/ObjectFile.h"
#include "lldb/Core/UUID.h"
2010-07-13 23:07:23 +00:00
#include "ELFHeader.h"
struct ELFNote
{
elf::elf_word n_namesz;
elf::elf_word n_descsz;
elf::elf_word n_type;
std::string n_name;
ELFNote() : n_namesz(0), n_descsz(0), n_type(0)
{
}
/// Parse an ELFNote entry from the given DataExtractor starting at position
/// \p offset.
///
/// @param[in] data
/// The DataExtractor to read from.
///
/// @param[in,out] offset
/// Pointer to an offset in the data. On return the offset will be
/// advanced by the number of bytes read.
///
/// @return
/// True if the ELFRel entry was successfully read and false otherwise.
bool
Parse(const lldb_private::DataExtractor &data, lldb::offset_t *offset);
};
2010-07-13 23:07:23 +00:00
//------------------------------------------------------------------------------
/// @class ObjectFileELF
/// @brief Generic ELF object file reader.
///
/// This class provides a generic ELF (32/64 bit) reader plugin implementing the
/// ObjectFile protocol.
class ObjectFileELF :
public lldb_private::ObjectFile
{
public:
//------------------------------------------------------------------
// Static Functions
//------------------------------------------------------------------
static void
Initialize();
static void
Terminate();
2013-05-10 21:47:16 +00:00
static lldb_private::ConstString
GetPluginNameStatic();
static const char *
GetPluginDescriptionStatic();
static lldb_private::ObjectFile *
2012-02-24 01:59:29 +00:00
CreateInstance(const lldb::ModuleSP &module_sp,
2013-02-06 17:22:03 +00:00
lldb::DataBufferSP& data_sp,
lldb::offset_t data_offset,
const lldb_private::FileSpec* file,
2013-02-06 17:22:03 +00:00
lldb::offset_t file_offset,
lldb::offset_t length);
2012-02-05 02:38:54 +00:00
static lldb_private::ObjectFile *
2012-02-24 01:59:29 +00:00
CreateMemoryInstance (const lldb::ModuleSP &module_sp,
2012-02-05 02:38:54 +00:00
lldb::DataBufferSP& data_sp,
const lldb::ProcessSP &process_sp,
lldb::addr_t header_addr);
static size_t
GetModuleSpecifications (const lldb_private::FileSpec& file,
lldb::DataBufferSP& data_sp,
lldb::offset_t data_offset,
lldb::offset_t file_offset,
lldb::offset_t length,
lldb_private::ModuleSpecList &specs);
static bool
MagicBytesMatch (lldb::DataBufferSP& data_sp,
lldb::addr_t offset,
lldb::addr_t length);
//------------------------------------------------------------------
// PluginInterface protocol
//------------------------------------------------------------------
2013-05-10 21:47:16 +00:00
virtual lldb_private::ConstString
GetPluginName();
virtual uint32_t
GetPluginVersion();
2010-07-13 23:07:23 +00:00
//------------------------------------------------------------------
// ObjectFile Protocol.
//------------------------------------------------------------------
virtual
~ObjectFileELF();
2010-07-13 23:07:23 +00:00
virtual bool
ParseHeader();
2010-07-13 23:07:23 +00:00
virtual lldb::ByteOrder
GetByteOrder() const;
virtual bool
IsExecutable () const;
2013-01-25 18:06:21 +00:00
virtual uint32_t
2010-07-13 23:07:23 +00:00
GetAddressByteSize() const;
virtual lldb_private::Symtab *
GetSymtab();
2010-07-13 23:07:23 +00:00
virtual lldb_private::Symbol *
ResolveSymbolForAddress(const lldb_private::Address& so_addr, bool verify_unique);
virtual bool
IsStripped ();
virtual void
CreateSections (lldb_private::SectionList &unified_section_list);
2010-07-13 23:07:23 +00:00
virtual void
Dump(lldb_private::Stream *s);
virtual bool
GetArchitecture (lldb_private::ArchSpec &arch);
2010-07-13 23:07:23 +00:00
virtual bool
GetUUID(lldb_private::UUID* uuid);
2013-07-01 19:45:50 +00:00
virtual lldb_private::FileSpecList
GetDebugSymbolFilePaths();
2010-07-13 23:07:23 +00:00
virtual uint32_t
GetDependentModules(lldb_private::FileSpecList& files);
virtual lldb_private::Address
GetImageInfoAddress(lldb_private::Target *target);
virtual lldb_private::Address
GetEntryPointAddress ();
virtual ObjectFile::Type
CalculateType();
virtual ObjectFile::Strata
CalculateStrata();
// Returns number of program headers found in the ELF file.
size_t
GetProgramHeaderCount();
// Returns the program header with the given index.
const elf::ELFProgramHeader *
GetProgramHeaderByIndex(lldb::user_id_t id);
// Returns segment data for the given index.
lldb_private::DataExtractor
GetSegmentDataByIndex(lldb::user_id_t id);
2010-07-13 23:07:23 +00:00
private:
2012-02-24 01:59:29 +00:00
ObjectFileELF(const lldb::ModuleSP &module_sp,
2013-02-06 17:22:03 +00:00
lldb::DataBufferSP& data_sp,
lldb::offset_t data_offset,
2010-07-13 23:07:23 +00:00
const lldb_private::FileSpec* file,
2013-02-06 17:22:03 +00:00
lldb::offset_t offset,
lldb::offset_t length);
2010-07-13 23:07:23 +00:00
typedef std::vector<elf::ELFProgramHeader> ProgramHeaderColl;
typedef ProgramHeaderColl::iterator ProgramHeaderCollIter;
typedef ProgramHeaderColl::const_iterator ProgramHeaderCollConstIter;
2013-07-01 19:45:50 +00:00
struct ELFSectionHeaderInfo : public elf::ELFSectionHeader
{
lldb_private::ConstString section_name;
};
typedef std::vector<ELFSectionHeaderInfo> SectionHeaderColl;
typedef SectionHeaderColl::iterator SectionHeaderCollIter;
typedef SectionHeaderColl::const_iterator SectionHeaderCollConstIter;
2011-03-30 16:07:05 +00:00
typedef std::vector<elf::ELFDynamic> DynamicSymbolColl;
typedef DynamicSymbolColl::iterator DynamicSymbolCollIter;
typedef DynamicSymbolColl::const_iterator DynamicSymbolCollConstIter;
2010-07-13 23:07:23 +00:00
/// Version of this reader common to all plugins based on this class.
static const uint32_t m_plugin_version = 1;
/// ELF file header.
elf::ELFHeader m_header;
2013-07-01 19:45:50 +00:00
/// ELF build ID.
lldb_private::UUID m_uuid;
2013-07-01 19:45:50 +00:00
/// ELF .gnu_debuglink file and crc data if available.
std::string m_gnu_debuglink_file;
uint32_t m_gnu_debuglink_crc;
2010-07-13 23:07:23 +00:00
/// Collection of program headers.
ProgramHeaderColl m_program_headers;
2010-07-13 23:07:23 +00:00
/// Collection of section headers.
SectionHeaderColl m_section_headers;
2010-07-13 23:07:23 +00:00
2011-03-30 16:07:05 +00:00
/// Collection of symbols from the dynamic table.
DynamicSymbolColl m_dynamic_symbols;
2010-07-13 23:07:23 +00:00
/// List of file specifications corresponding to the modules (shared
/// libraries) on which this object file depends.
mutable std::unique_ptr<lldb_private::FileSpecList> m_filespec_ap;
2010-07-13 23:07:23 +00:00
/// Cached value of the entry point for this module.
lldb_private::Address m_entry_point_address;
2011-03-30 16:07:05 +00:00
2010-07-13 23:07:23 +00:00
/// Returns a 1 based index of the given section header.
2013-01-25 18:06:21 +00:00
size_t
2010-07-13 23:07:23 +00:00
SectionIndex(const SectionHeaderCollIter &I);
/// Returns a 1 based index of the given section header.
2013-01-25 18:06:21 +00:00
size_t
2010-07-13 23:07:23 +00:00
SectionIndex(const SectionHeaderCollConstIter &I) const;
/// Parses all section headers present in this object file and populates
/// m_program_headers. This method will compute the header list only once.
/// Returns the number of headers parsed.
size_t
2010-07-13 23:07:23 +00:00
ParseProgramHeaders();
2010-07-13 23:07:23 +00:00
/// Parses all section headers present in this object file and populates
/// m_section_headers. This method will compute the header list only once.
/// Returns the number of headers parsed.
size_t
2010-07-13 23:07:23 +00:00
ParseSectionHeaders();
2013-07-01 19:45:50 +00:00
/// Parses the elf section headers and returns the uuid, debug link name, crc.
static size_t
GetSectionHeaderInfo(SectionHeaderColl &section_headers,
lldb_private::DataExtractor &data,
const elf::ELFHeader &header,
lldb_private::UUID &uuid,
std::string &gnu_debuglink_file,
uint32_t &gnu_debuglink_crc);
2010-07-13 23:07:23 +00:00
/// Scans the dynamic section and locates all dependent modules (shared
/// libraries) populating m_filespec_ap. This method will compute the
2010-07-13 23:07:23 +00:00
/// dependent module list only once. Returns the number of dependent
/// modules parsed.
size_t
ParseDependentModules();
2011-03-30 16:07:05 +00:00
/// Parses the dynamic symbol table and populates m_dynamic_symbols. The
/// vector retains the order as found in the object file. Returns the
/// number of dynamic symbols parsed.
size_t
ParseDynamicSymbols();
2010-07-13 23:07:23 +00:00
/// Populates m_symtab_ap will all non-dynamic linker symbols. This method
/// will parse the symbols only once. Returns the number of symbols parsed.
2011-03-30 16:07:05 +00:00
unsigned
2010-07-13 23:07:23 +00:00
ParseSymbolTable(lldb_private::Symtab *symbol_table,
2011-03-30 16:07:05 +00:00
lldb::user_id_t start_id,
lldb_private::Section *symtab);
2010-07-13 23:07:23 +00:00
2013-07-01 19:45:50 +00:00
/// Helper routine for ParseSymbolTable().
unsigned
ParseSymbols(lldb_private::Symtab *symbol_table,
lldb::user_id_t start_id,
lldb_private::SectionList *section_list,
const size_t num_symbols,
2013-07-01 19:45:50 +00:00
const lldb_private::DataExtractor &symtab_data,
const lldb_private::DataExtractor &strtab_data);
2011-03-30 16:07:05 +00:00
/// Scans the relocation entries and adds a set of artificial symbols to the
/// given symbol table for each PLT slot. Returns the number of symbols
/// added.
unsigned
ParseTrampolineSymbols(lldb_private::Symtab *symbol_table,
lldb::user_id_t start_id,
2013-07-01 19:45:50 +00:00
const ELFSectionHeaderInfo *rela_hdr,
2011-03-30 16:07:05 +00:00
lldb::user_id_t section_id);
/// Returns the section header with the given id or NULL.
2013-07-01 19:45:50 +00:00
const ELFSectionHeaderInfo *
2011-03-30 16:07:05 +00:00
GetSectionHeaderByIndex(lldb::user_id_t id);
2010-07-13 23:07:23 +00:00
/// @name ELF header dump routines
//@{
static void
DumpELFHeader(lldb_private::Stream *s, const elf::ELFHeader& header);
static void
2010-07-13 23:07:23 +00:00
DumpELFHeader_e_ident_EI_DATA(lldb_private::Stream *s,
unsigned char ei_data);
static void
2010-07-13 23:07:23 +00:00
DumpELFHeader_e_type(lldb_private::Stream *s, elf::elf_half e_type);
//@}
2010-07-13 23:07:23 +00:00
/// @name ELF program header dump routines
//@{
void
2010-07-13 23:07:23 +00:00
DumpELFProgramHeaders(lldb_private::Stream *s);
static void
2010-07-13 23:07:23 +00:00
DumpELFProgramHeader(lldb_private::Stream *s,
const elf::ELFProgramHeader &ph);
static void
2010-07-13 23:07:23 +00:00
DumpELFProgramHeader_p_type(lldb_private::Stream *s, elf::elf_word p_type);
static void
2010-07-13 23:07:23 +00:00
DumpELFProgramHeader_p_flags(lldb_private::Stream *s,
elf::elf_word p_flags);
//@}
2010-07-13 23:07:23 +00:00
/// @name ELF section header dump routines
//@{
void
DumpELFSectionHeaders(lldb_private::Stream *s);
2010-07-13 23:07:23 +00:00
static void
DumpELFSectionHeader(lldb_private::Stream *s,
2013-07-01 19:45:50 +00:00
const ELFSectionHeaderInfo& sh);
2010-07-13 23:07:23 +00:00
static void
DumpELFSectionHeader_sh_type(lldb_private::Stream *s,
elf::elf_word sh_type);
static void
DumpELFSectionHeader_sh_flags(lldb_private::Stream *s,
2013-01-25 18:06:21 +00:00
elf::elf_xword sh_flags);
2010-07-13 23:07:23 +00:00
//@}
/// ELF dependent module dump routine.
void
DumpDependentModules(lldb_private::Stream *s);
2011-03-30 16:07:05 +00:00
const elf::ELFDynamic *
FindDynamicSymbol(unsigned tag);
unsigned
PLTRelocationType();
};
#endif // #ifndef liblldb_ObjectFileELF_h_