diff options
| author | Ajax <commial@gmail.com> | 2015-11-09 14:20:36 +0100 |
|---|---|---|
| committer | Ajax <commial@gmail.com> | 2015-11-09 14:20:36 +0100 |
| commit | 1ae7dfe4130c8ea023addd8993241f26efc04f54 (patch) | |
| tree | 17fa65294898773007765cba48bc1c08aed1ef28 /example/disasm/callback.py | |
| parent | f6dcdced5bfdb1ae32613df194890d70a03da4b8 (diff) | |
| download | focaccia-miasm-1ae7dfe4130c8ea023addd8993241f26efc04f54.tar.gz focaccia-miasm-1ae7dfe4130c8ea023addd8993241f26efc04f54.zip | |
Disasm/x86: move `pushpop` callback to an example `callback.py`
Diffstat (limited to 'example/disasm/callback.py')
| -rw-r--r-- | example/disasm/callback.py | 60 |
1 files changed, 60 insertions, 0 deletions
diff --git a/example/disasm/callback.py b/example/disasm/callback.py new file mode 100644 index 00000000..9c443e17 --- /dev/null +++ b/example/disasm/callback.py @@ -0,0 +1,60 @@ +from miasm2.core.bin_stream import bin_stream_str +from miasm2.core.asmbloc import asm_constraint, asm_label +from miasm2.expression.expression import ExprId +from miasm2.arch.x86.disasm import dis_x86_32, cb_x86_funcs + + +def cb_x86_callpop(cur_bloc, symbol_pool, *args, **kwargs): + """ + 1000: call 1005 + 1005: pop + + Will give: + + 1000: push 1005 + 1005: pop + + """ + if len(cur_bloc.lines) < 1: + return + l = cur_bloc.lines[-1] + if l.name != 'CALL': + return + dst = l.args[0] + if not (isinstance(dst, ExprId) and isinstance(dst.name, asm_label)): + return + if dst.name.offset != l.offset + l.l: + return + l.name = 'PUSH' + cur_bloc.bto.clear() + cur_bloc.add_cst(dst.name.offset, asm_constraint.c_next, symbol_pool) + + +# Prepare a tiny shellcode +shellcode = ''.join(["\xe8\x00\x00\x00\x00", # CALL $ + "X", # POP EAX + "\xc3", # RET + ]) +bin_stream = bin_stream_str(shellcode) +mdis = dis_x86_32(bin_stream) + +print "Without callback:\n" +blocks = mdis.dis_multibloc(0) +print "\n".join(str(block) for block in blocks) + +# Enable callback +cb_x86_funcs.append(cb_x86_callpop) +## Other method: +## mdis.dis_bloc_callback = cb_x86_callpop + +# Clean disassembly cache +mdis.job_done.clear() + +print "=" * 40 +print "With callback:\n" +blocks_after = mdis.dis_multibloc(0) +print "\n".join(str(block) for block in blocks_after) + +# Ensure the callback has been called +assert blocks[0].lines[0].name == "CALL" +assert blocks_after[0].lines[0].name == "PUSH" |