diff options
author | Roland Reichwein <mail@reichwein.it> | 2020-10-17 14:16:46 +0200 |
---|---|---|
committer | Roland Reichwein <mail@reichwein.it> | 2020-10-17 14:16:46 +0200 |
commit | f86999e137f43372236f2dccd1fe3572a85c0dcd (patch) | |
tree | fedfeec810d22dde57073c5b51ecf1a4253a9c61 /intel.cpp | |
parent | 85e9768c6a083165ef8376d2924f5d82ce91d118 (diff) |
Separate-out assembler
Diffstat (limited to 'intel.cpp')
-rw-r--r-- | intel.cpp | 136 |
1 files changed, 0 insertions, 136 deletions
@@ -314,142 +314,6 @@ namespace { } // namespace -class Chunk -{ -public: - virtual ~Chunk(){} - virtual std::vector<uint8_t> getCode() = 0; - virtual size_t size() = 0; ///< returns size in bytes -}; - -class Label: public Chunk -{ -public: - Label(const std::string& name) : m_name(name) {} - std::string name(){return m_name;} - std::vector<uint8_t> getCode() override { return {}; } - size_t size() override { return 0; } - -private: - std::string m_name; -}; - -class Data: public Chunk -{ -public: - Data(std::vector<uint8_t> data): m_data(data) {} - virtual ~Data(){} - - std::vector<uint8_t> getCode() override - { - return m_data; - } - - size_t size() override - { - return m_data.size(); - } - -protected: - std::vector<uint8_t> m_data; -}; - -class Segment: public std::vector<std::shared_ptr<Chunk>> -{ - 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<Label&>(chunk).name() == label) { - return address; - } - } - } - - throw std::runtime_error("Bad label: "s + label); - } -}; - -class Op: public Chunk -{ -public: - virtual ~Op(){}; - virtual bool optimize() = 0; ///< returns true if changed -}; - -using AsmArgs = std::vector<std::any>; // 0th element is mnemonic -using FactoryFunction = std::function<std::shared_ptr<Op>(AsmArgs&)>; - -std::unordered_map<std::string, FactoryFunction> ops; - -bool registerOp(const std::string& mnemonic, FactoryFunction f) -{ - if (ops.contains(mnemonic)) { - std::cout << "Warning: mnemonic |" << mnemonic << "| already registered." << std::endl; - return false; - } - - std::cout << "Registering mnemonic |" << mnemonic << "|." << std::endl; - - ops[mnemonic] = f; - - return true; -} - -class OpSimple: public Op -{ -public: - OpSimple(std::vector<uint8_t> machine_code): machine_code(machine_code) {} - - std::vector<uint8_t> getCode() override - { - return machine_code; - } - - size_t size() override - { - return machine_code.size(); - } - - bool optimize() override ///< returns true if changed - { - return false; - } - -protected: - std::vector<uint8_t> machine_code; -}; - -class Op_nop: public OpSimple -{ -public: - Op_nop() : OpSimple({ 0x90 }) {} - -}; - -template<typename T> -std::string mangleNameOne(const std::string& s) -{ - return s + "_" + typeid(T).name(); -} - -template<typename T, typename... Targs> -std::string mangleName(const std::string& s) -{ - if constexpr (sizeof...(Targs) == 0) - return mangleNameOne<T>(s); - else - return mangleName<Targs...>(s + "_" + typeid(T).name()); -} - -bool registered { registerOp("nop", [](AsmArgs& args) -> std::shared_ptr<Op>{ - return std::make_shared<Op_nop>(); - }) }; - class Assembler { std::unordered_map<std::string, size_t> labels; ///< labels with their positions in instruction list |