about summary refs log tree commit diff stats
path: root/example/expression/get_read_write.py
blob: 9e3b5caf540db53a735a38db5f62ad50c688f6b3 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
from miasm2.arch.x86.arch import mn_x86
from miasm2.expression.expression import get_rw
from miasm2.arch.x86.ira import ir_a_x86_32
from miasm2.core.asmblock import AsmSymbolPool

symbol_pool = AsmSymbolPool()


print """
Simple expression manipulation demo.
Get read/written registers for a given instruction
"""

arch = mn_x86
ir_arch = ir_a_x86_32()

l = arch.fromstring('LODSB', symbol_pool, 32)
l.offset, l.l = 0, 15
ir_arch.add_instr(l)

print '*' * 80
for lbl, irblock in ir_arch.blocks.iteritems():
    print irblock
    for assignblk in irblock:
        rw = assignblk.get_rw()
        for dst, reads in rw.iteritems():
            print 'read:   ', [str(x) for x in reads]
            print 'written:', dst
            print

open('graph_instr.dot', 'w').write(ir_arch.graph.dot())