X-Git-Url: https://git.siccegge.de//index.cgi?p=frida%2Ffrida.git;a=blobdiff_plain;f=src%2Fdisassembler%2Fllvm%2FLLVMDisassembler.cxx;h=8dd548332bf4f1f01106cd2020db3b137e13b626;hp=9ab28440f7f96451ef8fb5cc0e4e4b1c604ab613;hb=879c174dd56331b6c7b3254edd115e46a0b5e78c;hpb=1b95144814ee74e611fd8a3806e54f064b120460 diff --git a/src/disassembler/llvm/LLVMDisassembler.cxx b/src/disassembler/llvm/LLVMDisassembler.cxx index 9ab2844..8dd5483 100644 --- a/src/disassembler/llvm/LLVMDisassembler.cxx +++ b/src/disassembler/llvm/LLVMDisassembler.cxx @@ -13,26 +13,25 @@ using std::error_code; * */ Disassembler * createLLVMDisassembler(const std::string& filename, InformationManager* manager) { + if (filename == "") + return NULL; + std::unique_ptr o; o.reset(createBinary(filename).get()); - const Binary * op = o.get(); + Binary * op = o.release(); // ELFType - if (const ELF32LEObjectFile * _ = dyn_cast(op)) { -#pragma unused(_) - return new LLVMDisassembler>(filename, manager); + if (ELF32LEObjectFile * object = dyn_cast(op)) { + return new LLVMDisassembler>(filename, manager, object); } - if (const ELF64LEObjectFile * _ = dyn_cast(op)) { -#pragma unused(_) - return new LLVMDisassembler>(filename, manager); + if (ELF64LEObjectFile * object = dyn_cast(op)) { + return new LLVMDisassembler>(filename, manager, object); } - if (const ELF32BEObjectFile * _ = dyn_cast(op)) { -#pragma unused(_) - return new LLVMDisassembler>(filename, manager); + if (ELF32BEObjectFile * object = dyn_cast(op)) { + return new LLVMDisassembler>(filename, manager, object); } - if (const ELF64BEObjectFile * _ = dyn_cast(op)) { -#pragma unused(_) - return new LLVMDisassembler>(filename, manager); + if (ELF64BEObjectFile * object = dyn_cast(op)) { + return new LLVMDisassembler>(filename, manager, object); } return NULL; @@ -45,25 +44,32 @@ Disassembler * createLLVMDisassembler(const std::string& filename, InformationMa */ template LLVMDisassembler::LLVMDisassembler(const std::string& filename, - InformationManager* manager) + InformationManager* manager, + ELFObjectFile* file) : Disassembler(filename, manager) , logger(log4cxx::Logger::getLogger("LLVMDisassembler")) , triple("unknown-unknown-unknown") , manager(manager) { LOG4CXX_DEBUG(logger, "Handling file" << filename); - auto result = createBinary(filename); - error_code ec; - if ((ec = result.getError())) { - LOG4CXX_ERROR(logger, "Failed to load Binary" << ec.message()); - binary = NULL; - return; - } + if (!file) { + auto result = createBinary(filename); - binary.reset(result.get()); + error_code ec; + if ((ec = result.getError())) { + LOG4CXX_ERROR(logger, "Failed to load Binary" << ec.message()); + binary = NULL; + return; + } + + binary.reset(result.get()); - o = dyn_cast(binary.get()); + o = dyn_cast>(binary.get()); + } else { + o = file; + binary.reset(file); + } triple.setArch(Triple::ArchType(o->getArch())); std::string tripleName(triple.getTriple());