ROSE 0.11.145.192
|
Loader for ELF files.
Definition at line 11 of file BinaryLoaderElf.h.
#include <Rose/BinaryAnalysis/BinaryLoaderElf.h>
Classes | |
class | SymbolMap |
A mapping from symbol name (with optional version in parentheses) to SymbolMapEntry. More... | |
struct | SymbolMapEntry |
An entry for a SymbolMap. More... | |
class | SymverResolver |
class | VersionedSymbol |
Symbol from .dynsym combined with additional information. More... | |
Public Types | |
enum | { VER_FLG_BASE =0x1 , VER_FLG_WEAK =0x2 , VERSYM_HIDDEN =0x8000 } |
Flags for version definitions and requirements. More... | |
using | Ptr = BinaryLoaderElfPtr |
Reference counting pointer to BinaryLoaderElf. | |
Public Types inherited from Rose::BinaryAnalysis::BinaryLoader | |
enum | MappingContribution { CONTRIBUTE_NONE , CONTRIBUTE_ADD , CONTRIBUTE_SUB } |
Describes how a section contributes to the overall memory map. More... | |
enum | ConflictResolution { RESOLVE_THROW , RESOLVE_OVERMAP , RESOLVE_REMAP , RESOLVE_REMAP_ABOVE } |
Describes how conflicts are resolved when mapping a section. More... | |
using | Ptr = BinaryLoaderPtr |
Referenc counting pointer to BinaryLoader. | |
typedef std::vector< Exception > | FixupErrors |
Public Member Functions | |
virtual BinaryLoaderPtr | clone () const override |
Copy constructor. | |
virtual bool | canLoad (SgAsmGenericHeader *) const override |
Capability query. | |
void | addLibDefaults (SgAsmGenericHeader *header=NULL) |
Sets up library search paths and preloads from the environment. | |
virtual void | fixup (SgAsmInterpretation *interp, FixupErrors *errors=NULL) override |
Performs relocation fixups on the specified interpretation. | |
virtual SgAsmGenericSection * | findSectionByPreferredVa (SgAsmGenericHeader *, rose_addr_t va) |
Find the section containing the specified virtual address. | |
virtual rose_addr_t | rebase (const MemoryMap::Ptr &, SgAsmGenericHeader *, const SgAsmGenericSectionPtrList &) override |
Returns a new, temporary base address which is greater than everything that's been mapped already. | |
Public Member Functions inherited from Rose::BinaryAnalysis::BinaryLoader | |
void | appendDirectories (const std::vector< std::string > &dirnames) |
Appends directories to the list of directories searched for libraries. | |
virtual std::string | findSoFile (const std::string &libname) const |
Convert name to fully qualified name. | |
virtual void | load (SgAsmInterpretation *) |
Top-level method to do everything. | |
virtual void | link (SgAsmInterpretation *interp) |
Finds and parses all shared objects needed by an interpretation. | |
virtual void | remap (SgAsmInterpretation *interp) |
Maps sections of the interpretation into the virtual address space. | |
virtual std::vector< std::string > | dependencies (SgAsmGenericHeader *) |
Finds shared object dependencies of a single binary header. | |
virtual void | remap (Rose::BinaryAnalysis::MemoryMap::Ptr &, SgAsmGenericHeader *) |
Remaps the sections for a particular header. | |
rose_addr_t | bialign (rose_addr_t val1, rose_addr_t align1, rose_addr_t val2, rose_addr_t align2) |
Calculate adjustment to cause two values to be aligned to two different alignments. | |
virtual void | addSectionsForRemap (SgAsmGenericHeader *header, SgAsmGenericSectionPtrList &allSections) |
Selects loadable sections. | |
virtual unsigned | mappingPermissions (SgAsmGenericSection *) const |
MemoryMap permissions. | |
bool | performingDynamicLinking () const |
Property: Whether this loader will perform the linking step. | |
void | performingDynamicLinking (bool b) |
Property: Whether this loader will perform the linking step. | |
bool | performingRemap () const |
Property: Whether this loader will perform the mapping step. | |
void | performingRemap (bool b) |
Property: Whether this loader will perform the mapping step. | |
bool | performingRelocations () const |
Property: Whether this loader will perform the relocation step. | |
void | performingRelocations (bool b) |
Property: Whether this loader will perform the relocation step. | |
const std::vector< std::string > & | preloads () const |
Property: List of libraries that will be pre-loaded. | |
std::vector< std::string > & | preloads () |
Property: List of libraries that will be pre-loaded. | |
void | preloads (const std::vector< std::string > &v) |
Property: List of libraries that will be pre-loaded. | |
const std::vector< std::string > & | directories () const |
Property: List of directories searched for libraries. | |
std::vector< std::string > & | directories () |
Property: List of directories searched for libraries. | |
void | directories (const std::vector< std::string > &v) |
Property: List of directories searched for libraries. | |
virtual bool | isLinked (SgBinaryComposite *composite, const std::string &filename) |
Returns true if the specified file name is already linked into the AST. | |
virtual bool | isLinked (SgAsmInterpretation *interp, const std::string &filename) |
Returns true if the specified file name is already linked into the AST. | |
Public Member Functions inherited from Sawyer::SharedObject | |
SharedObject () | |
Default constructor. | |
SharedObject (const SharedObject &) | |
Copy constructor. | |
virtual | ~SharedObject () |
Virtual destructor. | |
SharedObject & | operator= (const SharedObject &) |
Assignment. | |
Static Public Member Functions | |
static Ptr | instance () |
Allocating constructor. | |
static void | getDynamicVars (SgAsmGenericHeader *, std::string &rpath, std::string &runpath) |
Returns the strings associated with certain variables in the ".dynamic" section. | |
Static Public Member Functions inherited from Rose::BinaryAnalysis::BinaryLoader | |
static Ptr | instance () |
Allocating constructor. | |
static void | initDiagnostics () |
Initialize diagnostic streams for binary loaders. | |
static void | registerSubclass (const Ptr &) |
Register a loader instance. | |
static Ptr | lookup (SgAsmGenericHeader *) |
Finds a suitable loader. | |
static Ptr | lookup (SgAsmInterpretation *) |
Finds a suitable loader. | |
static void | load (SgBinaryComposite *composite, bool read_executable_file_format_only=false) |
Top-level method to do everything. | |
static SgAsmGenericFile * | createAsmAST (SgBinaryComposite *composite, std::string filePath) |
Parses a single binary file. | |
static int64_t | gcd (int64_t a, int64_t b, int64_t *x=NULL, int64_t *y=NULL) |
Extended Euclid Algorithm. | |
static SgAsmGenericHeaderPtrList | findSimilarHeaders (SgAsmGenericHeader *matchHeader, SgAsmGenericHeaderPtrList &candidateHeaders) |
Find headers similar to given header. | |
static bool | isHeaderSimilar (SgAsmGenericHeader *, SgAsmGenericHeader *) |
Determines whether two headers are similar. | |
Protected Member Functions | |
BinaryLoaderElf (const BinaryLoaderElf &other) | |
virtual SgAsmGenericSectionPtrList | getRemapSections (SgAsmGenericHeader *) override |
Returns mappable sections in a particular order. | |
virtual MappingContribution | alignValues (SgAsmGenericSection *, const MemoryMap::Ptr &, rose_addr_t *malign_lo, rose_addr_t *malign_hi, rose_addr_t *va, rose_addr_t *mem_size, rose_addr_t *offset, rose_addr_t *file_size, bool *map_private, rose_addr_t *va_offset, bool *anon_lo, bool *anon_hi, ConflictResolution *resolve) override |
Linux-specific ELF Segment and Section alignment. | |
void | buildMasterSymbolTable (SgAsmInterpretation *) |
Builds the master symbol table. | |
SgAsmElfSymbol * | fixupInfoRelocSymbol (SgAsmElfRelocEntry *, const SymverResolver &) |
Returns the defining symbol for a relocation, if any. | |
rose_addr_t | fixupInfoTargetVa (SgAsmElfRelocEntry *, SgAsmGenericSection **section_p=NULL, rose_addr_t *adj_p=NULL) |
Returns the virtual address where a relocation should be supplied. | |
rose_addr_t | fixupInfoSymbolVa (SgAsmElfSymbol *, SgAsmGenericSection **section_p=NULL, rose_addr_t *adj_p=NULL) |
Returns the virtual address of a symbol adjusted for remapping. | |
rose_addr_t | fixupInfoAddend (SgAsmElfRelocEntry *, rose_addr_t target_va, const MemoryMap::Ptr &, size_t nbytes=0) |
Returns the addend associated with a relocation. | |
rose_addr_t | fixupInfoExpr (const std::string &expression, SgAsmElfRelocEntry *reloc, const SymverResolver &resolver, const MemoryMap::Ptr &memmap, rose_addr_t *target_va_p=NULL) |
Evaluates a simple postfix expression and returns the result. | |
void | fixupApply (rose_addr_t value, SgAsmElfRelocEntry *, const MemoryMap::Ptr &, rose_addr_t target_va=0, size_t nbytes=0) |
Writes a value into memory at the relocation target. | |
void | fixupApplySymbolCopy (SgAsmElfRelocEntry *, const SymverResolver &, const MemoryMap::Ptr &) |
Copies symbol memory to the relocation target. | |
void | performRelocation (SgAsmElfRelocEntry *, const SymverResolver &, const MemoryMap::Ptr &) |
void | performRelocations (SgAsmElfFileHeader *, const MemoryMap::Ptr &) |
Protected Member Functions inherited from Rose::BinaryAnalysis::BinaryLoader | |
BinaryLoader (const BinaryLoader &other) | |
Copy constructor. | |
Protected Attributes | |
SymbolMap | symbols_ |
Symbol table for an entire interpretation. | |
Additional Inherited Members | |
Static Public Attributes inherited from Rose::BinaryAnalysis::BinaryLoader | |
static Sawyer::Message::Facility | mlog |
Logging facility initialized by initDiagnostics(). | |
Reference counting pointer to BinaryLoaderElf.
Definition at line 14 of file BinaryLoaderElf.h.
anonymous enum |
Flags for version definitions and requirements.
Definition at line 19 of file BinaryLoaderElf.h.
|
inlineprotected |
Definition at line 210 of file BinaryLoaderElf.h.
|
inlineprotected |
Definition at line 212 of file BinaryLoaderElf.h.
|
inlinevirtual |
Definition at line 222 of file BinaryLoaderElf.h.
|
inlinestatic |
Allocating constructor.
Definition at line 218 of file BinaryLoaderElf.h.
|
inlineoverridevirtual |
Copy constructor.
See super class.
Reimplemented from Rose::BinaryAnalysis::BinaryLoader.
Reimplemented in Rose::BinaryAnalysis::BinaryLoaderElfObj.
Definition at line 225 of file BinaryLoaderElf.h.
|
overridevirtual |
Capability query.
See super class.
Reimplemented from Rose::BinaryAnalysis::BinaryLoader.
Reimplemented in Rose::BinaryAnalysis::BinaryLoaderElfObj.
void Rose::BinaryAnalysis::BinaryLoaderElf::addLibDefaults | ( | SgAsmGenericHeader * | header = NULL | ) |
Sets up library search paths and preloads from the environment.
The search paths and preloads are added to the end of the lists. If an ELF file header is provided, then the DT_RPATH and DT_RUNPATH from the ".dynamic" section are also used.
Caveats:
|
overridevirtual |
Performs relocation fixups on the specified interpretation.
This should be called after sections are mapped into memory by remap(). If an error occurs, then this function either throws the error (BinaryLoader::Exception) or appends it to the errors
container (if errors
is non-null).
Reimplemented from Rose::BinaryAnalysis::BinaryLoader.
|
virtual |
Find the section containing the specified virtual address.
Only ELF Sections of the specified header are searched, and we search based on the preferred mapping location of the section (not the actual mapping location). The null pointer is returned if no suitable section can be found.
|
overrideprotectedvirtual |
Returns mappable sections in a particular order.
Returns ELF Segments in the order they are defined in the segment table, followed by ELF Sections in the order they are defined in the section table but excluding those sections that were already added to the list as ELF Segments.
Reimplemented from Rose::BinaryAnalysis::BinaryLoader.
Reimplemented in Rose::BinaryAnalysis::BinaryLoaderElfObj.
|
overridevirtual |
Returns a new, temporary base address which is greater than everything that's been mapped already.
Reimplemented from Rose::BinaryAnalysis::BinaryLoader.
|
overrideprotectedvirtual |
Linux-specific ELF Segment and Section alignment.
Reimplemented from Rose::BinaryAnalysis::BinaryLoader.
Reimplemented in Rose::BinaryAnalysis::BinaryLoaderElfObj.
|
protected |
Builds the master symbol table.
This table is built just before relocations are fixed up and contains information about all the symbols that might be necessary during that process. The symbol table describes one entire interpretation.
|
protected |
Returns the defining symbol for a relocation, if any.
The relocation optionally points to a symbol under the same file header as the relocation. We then consult the supplied resolver
to find a defining symbol under a possibly different file header of the same interpretation. The defining symbol is returned.
If the relocation does not refer to a symbol, or the symbol is weak with no definition then a null pointer is returned. Otherwise, if a defining symbol cannot be located via the resolver, then an Exception is thrown.
Debugging information is conditionally output and indented four spaces.
|
protected |
Returns the virtual address where a relocation should be supplied.
The relocation address is computed by treating the relocation offset as a virtual address, finding the section that would have contained that virtual address had all sections of the relocation's header been mapped at their preferred addresses, and returning the sum of the relocation offset with the difference between the section's actual and preferred mapping addresses. The section and adjustment are optionally returned through the section_p
and adj_p
pointer arguments.
If no section can be found for the relocation offset then an Exception is thrown.
Debugging information is conditionally output and indented four spaces.
|
protected |
Returns the virtual address of a symbol adjusted for remapping.
The return value is computed by treating the symbol value as a virtual address, finding the section that would have contained that virtual address had all sections of the symbol's header been mapped at their preferred addresses, and returning the sum of the symbol value with the difference between the section's actual and preferred mapping addresses. The section and adjustment are optionally returned through the section_p
and adj_p
pointer arguments.
If no section can be found for the relocation offset then an Exception is thrown.
Debugging information is conditionally output and indented four spaces.
|
protected |
Returns the addend associated with a relocation.
If the relocation appears in a RELA relocation section then the addend is that which is specified in the relocation entry itself. Otherwise the supplied relocation target virtual address and memory map are used to read the addend from specimen memory.
The nbytes
arguments indicates how many bytes are read from the specimen's memory if the relocation is not of the RELA variety. If the size is zero (the default) then it is obtained from the relocation's file header. The byte sex is always obtained from information in the relocation's file header.
An Exception is thrown if an attempt is made to read from memory which is not mapped or not readable.
|
protected |
Evaluates a simple postfix expression and returns the result.
The expression consists of terms, operators, and settings each consisting of a single character. They are defined as follows, and for the most part match various linker documentation from Sun Microsystems "Linker and Libraries Guide", April 2008, page 239:
In addition to the primary return value, these additional values are returned through pointers when the pointer is non-null:
target_va_t
is the virtual address where the relocation should be applied. See fixup_info_target_va(). Debugging information is conditionally emitted and indented four spaces. Most debugging information comes from the underlying fixup_info_* methods that are called.
Exceptions are thrown when something goes wrong. Most exceptions come from the underlying fixup_info_* methods.
|
protected |
Writes a value into memory at the relocation target.
The target virtual address is either specified by a non-zero value for the target_va
argument, or (re)computed from the supplied relocation entry. This method is usually called by the othe fixup_apply_* methods. The value is truncated and/or byte-swapped if necessary according to the file header containing the relocation entry. If nbytes
is zero (the default) then the size will be determined from the relocation's file header.
Debugging information is conditionally emitted and indented four spaces.
An Exception is thrown if the value cannot be written to the specimen memory due to memory not being mapped or not being writable.
|
protected |
Copies symbol memory to the relocation target.
This is usually used to copy initialized library data (initialized by the loader calling a constructor) into a common location in the executable's .bss.
|
protected |
Symbol table for an entire interpretation.
This symbol table is created by the fixup() method via build_master_symbol_table() and used by various relocation fixups.
Definition at line 207 of file BinaryLoaderElf.h.