From 91b16391658eadd16e88c6bc20c06184e5353734 Mon Sep 17 00:00:00 2001 From: Fabrice Desclaux Date: Mon, 7 Dec 2020 17:57:21 +0100 Subject: Change example names --- example/disasm/dis_binary_lift.py | 39 +++++++++++++++++++++++++++++++++++++++ 1 file changed, 39 insertions(+) create mode 100644 example/disasm/dis_binary_lift.py (limited to 'example/disasm/dis_binary_lift.py') diff --git a/example/disasm/dis_binary_lift.py b/example/disasm/dis_binary_lift.py new file mode 100644 index 00000000..6ad69b05 --- /dev/null +++ b/example/disasm/dis_binary_lift.py @@ -0,0 +1,39 @@ +from __future__ import print_function +import sys +from future.utils import viewvalues +from miasm.analysis.binary import Container +from miasm.analysis.machine import Machine +from miasm.core.locationdb import LocationDB + +##################################### +# Common section from dis_binary.py # +##################################### + +fdesc = open(sys.argv[1], 'rb') +loc_db = LocationDB() + +cont = Container.from_stream(fdesc, loc_db) + +machine = Machine(cont.arch) + +mdis = machine.dis_engine(cont.bin_stream, loc_db=cont.loc_db) + +addr = cont.entry_point +asmcfg = mdis.dis_multiblock(addr) + +##################################### +# End common section # +##################################### + +# Get a Lifter +ir_arch = machine.lifter(mdis.loc_db) + +# Get the IR of the asmcfg +ircfg = ir_arch.new_ircfg_from_asmcfg(asmcfg) + +# Display each IR basic blocks +for irblock in viewvalues(ircfg.blocks): + print(irblock) + +# Output ir control flow graph in a dot file +open('bin_ir_cfg.dot', 'w').write(ircfg.dot()) -- cgit 1.4.1