]> git.siccegge.de Git - frida/frida.git/blobdiff - src/disassembler/llvm/LLVMDisassembler.hxx
Reoganize Function/BasicBlock creation
[frida/frida.git] / src / disassembler / llvm / LLVMDisassembler.hxx
index 95e961fb5656804ef745e4dc073ed496a41fe7ff..d00381b7ed962862c8be6e26008cdf94d06f9da8 100644 (file)
@@ -8,11 +8,9 @@
 #include "include_llvm.hxx"
 
 #include "disassembler/Disassembler.hxx"
 #include "include_llvm.hxx"
 
 #include "disassembler/Disassembler.hxx"
-#include "disassembler/BasicBlock.hxx"
-#include "disassembler/Function.hxx"
-#include "disassembler/llvm/LLVMBasicBlock.hxx"
-#include "disassembler/llvm/LLVMFunction.hxx"
 
 
+class Function;
+class BasicBlock;
 
 Disassembler * createLLVMDisassembler(const std::string& filename, InformationManager* manager);
 
 
 Disassembler * createLLVMDisassembler(const std::string& filename, InformationManager* manager);
 
@@ -28,15 +26,10 @@ public:
        void getSymbols() {}
        uint64_t entryAddress() {return _entryAddress;}
 
        void getSymbols() {}
        uint64_t entryAddress() {return _entryAddress;}
 
-       void forEachFunction(std::function<void (uint64_t, Function*)> callback);
        void printEachInstruction(uint64_t start, uint64_t end,
                                  std::function<void (uint8_t*, size_t, const std::string&,
                                                      const std::string&)> fun);
 
        void printEachInstruction(uint64_t start, uint64_t end,
                                  std::function<void (uint8_t*, size_t, const std::string&,
                                                      const std::string&)> fun);
 
-       BasicBlock * getBasicBlock(uint64_t address) {
-               return blocks[address];
-       }
-
        Function * disassembleFunctionAt(uint64_t address, const std::string& name = "");
 
 protected:
        Function * disassembleFunctionAt(uint64_t address, const std::string& name = "");
 
 protected:
@@ -47,8 +40,8 @@ private:
        typedef llvm::object::ELFFile<ELFT> ELFO;
 
        // http://llvm.org/docs/doxygen/html/MCObjectDisassembler_8cpp_source.html +197
        typedef llvm::object::ELFFile<ELFT> ELFO;
 
        // http://llvm.org/docs/doxygen/html/MCObjectDisassembler_8cpp_source.html +197
-       void disassembleFunction(LLVMFunction* function);
-       void splitBlocks(LLVMFunction* fun);
+       void disassembleFunction(Function* function);
+       void splitBlocks(Function* fun);
        void disassemble();
 
        void readSymbols();
        void disassemble();
 
        void readSymbols();
@@ -56,8 +49,6 @@ private:
        void readDynamicSymbols();
 
        log4cxx::LoggerPtr logger;
        void readDynamicSymbols();
 
        log4cxx::LoggerPtr logger;
-       std::map<uint64_t, LLVMBasicBlock*> blocks;
-       std::map<uint64_t, LLVMFunction*> functions;
 
        llvm::Triple triple;
        std::shared_ptr<llvm::object::Binary> binary;
 
        llvm::Triple triple;
        std::shared_ptr<llvm::object::Binary> binary;