diff options
author | Gabe Black <gabeblack@google.com> | 2019-10-01 21:15:06 -0700 |
---|---|---|
committer | Gabe Black <gabeblack@google.com> | 2019-10-12 04:10:59 +0000 |
commit | 6ee86bf497ea87a585fe8e4651760e71244fa2fb (patch) | |
tree | b2038b4d87285261ce57d29e82ad9e67baf99676 /src/base/loader/raw_object.hh | |
parent | 211869ea950f3cc3116655f06b1d46d3fa39fb3a (diff) | |
download | gem5-6ee86bf497ea87a585fe8e4651760e71244fa2fb.tar.xz |
arch,base: Separate the idea of a memory image and object file.
A memory image can be described by an object file, but an object file
is more than a memory image. Also, it makes sense to manipulate a
memory image to, for instance, change how it's loaded into memory. That
takes on larger implications (relocations, the entry point, symbols,
etc.) when talking about the whole object file, and also modifies
aspects which may not need to change. For instance if an image needs
to be loaded into memory at addresses different from what's in the
object file, but other things like symbols need to stay unmodified.
Change-Id: Ia360405ffb2c1c48e0cc201ac0a0764357996a54
Reviewed-on: https://gem5-review.googlesource.com/c/public/gem5/+/21466
Tested-by: kokoro <noreply+kokoro@google.com>
Reviewed-by: Brandon Potter <Brandon.Potter@amd.com>
Maintainer: Gabe Black <gabeblack@google.com>
Diffstat (limited to 'src/base/loader/raw_object.hh')
-rw-r--r-- | src/base/loader/raw_object.hh | 17 |
1 files changed, 8 insertions, 9 deletions
diff --git a/src/base/loader/raw_object.hh b/src/base/loader/raw_object.hh index 9eb929107..6dc54c7aa 100644 --- a/src/base/loader/raw_object.hh +++ b/src/base/loader/raw_object.hh @@ -39,18 +39,17 @@ class RawObject: public ObjectFile RawObject(const std::string &_filename, size_t _len, uint8_t *_data, Arch _arch, OpSys _opSys); - Segment *data; - public: virtual ~RawObject() {} - virtual bool loadAllSymbols(SymbolTable *symtab, Addr base = 0, - Addr offset = 0, Addr addr_mask = maxAddr); - virtual bool loadGlobalSymbols(SymbolTable *symtab, Addr base = 0, - Addr offset = 0, - Addr addr_mask = maxAddr); - virtual bool loadLocalSymbols(SymbolTable *symtab, Addr base = 0, - Addr offset = 0, Addr addr_mask = maxAddr); + MemoryImage buildImage() const override; + + bool loadAllSymbols(SymbolTable *symtab, Addr base=0, + Addr offset=0, Addr addr_mask=MaxAddr) override; + bool loadGlobalSymbols(SymbolTable *symtab, Addr base=0, + Addr offset=0, Addr addr_mask=MaxAddr) override; + bool loadLocalSymbols(SymbolTable *symtab, Addr base=0, + Addr offset=0, Addr addr_mask=MaxAddr) override; static ObjectFile *tryFile(const std::string &fname, size_t len, uint8_t *data); |