diff options
| author | Camille Mougey <commial@gmail.com> | 2018-07-10 16:25:54 +0200 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2018-07-10 16:25:54 +0200 |
| commit | a5221c1b926af7716860fd27039528cfb54d6095 (patch) | |
| tree | 00f29558bdcee14fa475ecf17d7badd45f029de4 /example | |
| parent | 17d48de1951c81fc8b5b4184713a971537747227 (diff) | |
| parent | f08ef523e0a30f89c5e05c894541d180e871fd1c (diff) | |
| download | miasm-a5221c1b926af7716860fd27039528cfb54d6095.tar.gz miasm-a5221c1b926af7716860fd27039528cfb54d6095.zip | |
Merge pull request #793 from serpilliere/clean_rename_ircfg
Clean rename ircfg
Diffstat (limited to 'example')
| -rw-r--r-- | example/disasm/full.py | 16 | ||||
| -rw-r--r-- | example/expression/constant_propagation.py | 9 |
2 files changed, 14 insertions, 11 deletions
diff --git a/example/disasm/full.py b/example/disasm/full.py index fdd220ca..9e1c422d 100644 --- a/example/disasm/full.py +++ b/example/disasm/full.py @@ -7,7 +7,8 @@ from miasm2.core.asmblock import log_asmblock, AsmCFG from miasm2.expression.expression import ExprId from miasm2.core.interval import interval from miasm2.analysis.machine import Machine -from miasm2.analysis.data_flow import dead_simp, DiGraphDefUse, ReachingDefinitions +from miasm2.analysis.data_flow import dead_simp, DiGraphDefUse, \ + ReachingDefinitions, merge_blocks, remove_empty_assignblks from miasm2.expression.simplifications import expr_simp from miasm2.analysis.ssa import SSAPath, SSADiGraph @@ -119,6 +120,7 @@ all_funcs_blocks = {} done_interval = interval() finish = False +entry_points = set() # Main disasm loop while not finish and todo: while not finish and todo: @@ -127,6 +129,7 @@ while not finish and todo: continue done.add(ad) asmcfg = mdis.dis_multiblock(ad) + entry_points.add(mdis.loc_db.get_offset_location(ad)) log.info('func ok %.16x (%d)' % (ad, len(all_funcs))) @@ -229,22 +232,21 @@ if args.gen_ir: open('graph_irflow_raw.dot', 'w').write(out) if args.simplify > 1: + ircfg_a.simplify(expr_simp) modified = True while modified: modified = False modified |= dead_simp(ir_arch_a, ircfg_a) - modified |= ircfg_a.remove_empty_assignblks() - modified |= ircfg_a.remove_jmp_blocks() - modified |= ircfg_a.merge_blocks() + modified |= remove_empty_assignblks(ircfg_a) + modified |= merge_blocks(ircfg_a, entry_points) open('graph_irflow_reduced.dot', 'w').write(ircfg_a.dot()) if args.ssa: - heads = ircfg_a.heads() - if len(heads) != 1: + if len(entry_points) != 1: raise RuntimeError("Your graph should have only one head") - head = list(heads)[0] + head = list(entry_points)[0] ssa = SSADiGraph(ircfg_a) ssa.transform(head) diff --git a/example/expression/constant_propagation.py b/example/expression/constant_propagation.py index d9c5fe65..0798c404 100644 --- a/example/expression/constant_propagation.py +++ b/example/expression/constant_propagation.py @@ -10,7 +10,8 @@ from miasm2.arch.x86.disasm import dis_x86_32 as dis_engine from miasm2.analysis.machine import Machine from miasm2.analysis.binary import Container from miasm2.analysis.cst_propag import propagate_cst_expr -from miasm2.analysis.data_flow import dead_simp +from miasm2.analysis.data_flow import dead_simp, \ + merge_blocks, remove_empty_assignblks from miasm2.expression.simplifications import expr_simp @@ -33,6 +34,7 @@ addr = int(args.address, 0) asmcfg = mdis.dis_multiblock(addr) ircfg = ir_arch.new_ircfg_from_asmcfg(asmcfg) +entry_points = set([mdis.loc_db.get_offset_location(addr)]) init_infos = ir_arch.arch.regs.regs_init cst_propag_link = propagate_cst_expr(ir_arch, ircfg, addr, init_infos) @@ -43,9 +45,8 @@ if args.simplify: while modified: modified = False modified |= dead_simp(ir_arch, ircfg) - modified |= ircfg.remove_empty_assignblks() - modified |= ircfg.remove_jmp_blocks() - modified |= ircfg.merge_blocks() + modified |= remove_empty_assignblks(ircfg) + modified |= merge_blocks(ircfg, entry_points) open("%s.propag.dot" % args.filename, 'w').write(ircfg.dot()) |