From 85e9768c6a083165ef8376d2924f5d82ce91d118 Mon Sep 17 00:00:00 2001 From: Roland Reichwein Date: Thu, 15 Oct 2020 18:09:12 +0200 Subject: Add Segment structure --- intel.cpp | 82 +++++++++++++++++++++++++++++++++++++++++++++++---------------- 1 file changed, 62 insertions(+), 20 deletions(-) diff --git a/intel.cpp b/intel.cpp index 1de2275..7ef6be3 100644 --- a/intel.cpp +++ b/intel.cpp @@ -155,7 +155,7 @@ namespace { if (sl[1].value == "eax") { // ADD EAX, imm32 return { { std::vector{ 0x05 } +imm32(sl[2].value), {} } }; } else if (sl[1].value == "rax") { // ADD RAX, imm32 - return { { REX("W") + std::vector{ 0x05 } +imm32(sl[2].value), {} } }; + return { { REX("W") + std::vector{ 0x05 } +imm32(sl[2].value), {} } }; } } @@ -231,11 +231,6 @@ namespace { throw std::runtime_error("Unknown command: "s + sl[0].value); }}, - // No Operation - { "nop", [](const std::vector& sl) -> InstructionCodeList { - return {{ std::vector{ 0x90 }, {}}}; - }}, - // Return from procedure { "ret", [](const std::vector& sl) -> InstructionCodeList { return {{ std::vector{ 0xC3 }, {}}}; // near return; TODO: far return is 0xCB @@ -319,13 +314,70 @@ namespace { } // namespace +class Chunk +{ +public: + virtual ~Chunk(){} + virtual std::vector getCode() = 0; + virtual size_t size() = 0; ///< returns size in bytes +}; -class Op +class Label: public Chunk +{ +public: + Label(const std::string& name) : m_name(name) {} + std::string name(){return m_name;} + std::vector getCode() override { return {}; } + size_t size() override { return 0; } + +private: + std::string m_name; +}; + +class Data: public Chunk +{ +public: + Data(std::vector data): m_data(data) {} + virtual ~Data(){} + + std::vector getCode() override + { + return m_data; + } + + size_t size() override + { + return m_data.size(); + } + +protected: + std::vector m_data; +}; + +class Segment: public std::vector> +{ + size_t getAddressOfLabel(const std::string& label) + { + size_t address{0}; + auto i{begin()}; + while (i != end()) { + Chunk& chunk{**i}; + address += chunk.size(); + if (typeid(chunk) == typeid(Label)) { + if (dynamic_cast(chunk).name() == label) { + return address; + } + } + } + + throw std::runtime_error("Bad label: "s + label); + } +}; + +class Op: public Chunk { public: virtual ~Op(){}; - virtual std::vector getMachineCode() = 0; - virtual size_t size() = 0; ///< returns size in bytes virtual bool optimize() = 0; ///< returns true if changed }; @@ -353,7 +405,7 @@ class OpSimple: public Op public: OpSimple(std::vector machine_code): machine_code(machine_code) {} - std::vector getMachineCode() override + std::vector getCode() override { return machine_code; } @@ -372,16 +424,6 @@ protected: std::vector machine_code; }; -class Op_Label: public OpSimple -{ -public: - Op_Label(const std::string& name) : OpSimple({}), m_name(name) {} - std::string name(){return m_name;} - -private: - std::string m_name; -}; - class Op_nop: public OpSimple { public: -- cgit v1.2.3