41 #ifndef __BASE_LOADER_ELF_OBJECT_HH__ 42 #define __BASE_LOADER_ELF_OBJECT_HH__ 66 void determineOpSys();
67 void handleLoadableSegment(GElf_Phdr phdr,
int seg_num);
71 Addr _programHeaderTable = 0;
72 uint16_t _programHeaderSize = 0;
73 uint16_t _programHeaderCount = 0;
99 bool sectionExists(std::string sec);
120 std::string getInterpPath(
const GElf_Phdr &phdr)
const;
125 void updateBias(
Addr bias_addr)
override;
127 bool hasTLS()
override {
return sectionExists(
".tbss"); }
145 #endif // __BASE_LOADER_ELF_OBJECT_HH__ uint16_t programHeaderCount()
std::shared_ptr< ImageFileData > ImageFileDataPtr
Addr programHeaderTable()
void setInterpDir(const std::string &dirname)
This is the interface for setting up a base path for the elf interpreter.
MemoryImage buildImage() const override
Addr bias() const override
Addr mapSize() const override
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
uint16_t programHeaderSize()
bool relocatable() const override
std::set< std::string > sectionNames
ObjectFile * getInterpreter() const override