diff options
author | Trygve Laugstøl <trygvis@inamo.no> | 2016-07-16 22:59:28 +0200 |
---|---|---|
committer | Trygve Laugstøl <trygvis@inamo.no> | 2016-07-16 22:59:28 +0200 |
commit | 62e8183d33ae159b9e984d2ef5b4a83656d56a16 (patch) | |
tree | 49eda06698ad2a11ad661386e6b1524a4ec11aba /includes/trygvis/elfinfo | |
parent | 4675ec55f6bdb8f826cc94a9585ff9229c277983 (diff) | |
download | elfinfo-62e8183d33ae159b9e984d2ef5b4a83656d56a16.tar.gz elfinfo-62e8183d33ae159b9e984d2ef5b4a83656d56a16.tar.bz2 elfinfo-62e8183d33ae159b9e984d2ef5b4a83656d56a16.tar.xz elfinfo-62e8183d33ae159b9e984d2ef5b4a83656d56a16.zip |
o Working version that can take the data from the LD script. Only tested with the Intel Quark D2000 LD script.
lexer: Allowing capital X in hex numbers too.
Diffstat (limited to 'includes/trygvis/elfinfo')
-rw-r--r-- | includes/trygvis/elfinfo/Ld.h | 70 |
1 files changed, 70 insertions, 0 deletions
diff --git a/includes/trygvis/elfinfo/Ld.h b/includes/trygvis/elfinfo/Ld.h new file mode 100644 index 0000000..cab466d --- /dev/null +++ b/includes/trygvis/elfinfo/Ld.h @@ -0,0 +1,70 @@ +#pragma once + +#include <string> +#include <set> +#include <vector> +#include <sstream> + +namespace trygvis { +namespace elfinfo { + +enum class MemoryAttribute { + R, W, X +}; + +static char to_str(const MemoryAttribute &type) { + switch (type) { + case MemoryAttribute::R: + return 'r'; + case MemoryAttribute::W: + return 'w'; + case MemoryAttribute::X: + return 'x'; + } +} + +struct Section { + std::string name; +}; + +struct MemoryArea { + std::string name; + uint64_t origin; + uint64_t length; + std::set<MemoryAttribute> attributes; + + bool contains(uint64_t address, uint64_t size) const { + return contains(address) && contains(address + size); + } + + bool contains(uint64_t address) const { + return origin <= address && address < origin + length; + } + + std::string attributes_string() const { + char buf[4]; + buf[0] = attributes.find(MemoryAttribute::R) == attributes.end() ? '-' : 'r'; + buf[1] = attributes.find(MemoryAttribute::W) == attributes.end() ? '-' : 'w'; + buf[2] = attributes.find(MemoryAttribute::X) == attributes.end() ? '-' : 'x'; + buf[3] = '\0'; + return std::string(buf); + } +}; + +struct LdScript { + std::vector<MemoryArea> memoryAreas; +}; + +class LdScriptLoader { +public: + LdScriptLoader(); + + LdScript load(std::string path); + + void setDebug(bool debug); +private: + bool debug_; +}; + +} // namespace elfinfo +} // namespace trygvis |