blob: 1929961f43ef513a53d796886433951d4c18cedb (
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
32
33
34
35
36
37
|
from pdb import pm
from pprint import pprint
from miasm2.arch.x86.arch import mn_x86
from miasm2.core import parse_asm, asmbloc
import miasm2.expression.expression as m2_expr
from miasm2.core import asmbloc
# Assemble code
blocs, symbol_pool = parse_asm.parse_txt(mn_x86, 32, '''
main:
MOV EAX, 1
MOV EBX, 2
MOV ECX, 2
MOV DX, 2
loop:
INC EBX
CMOVZ EAX, EBX
ADD EAX, ECX
JZ loop
RET
''')
# Set 'main' label's offset
symbol_pool.set_offset(symbol_pool.getby_name("main"), 0x0)
# Spread information and resolve instructions offset
patches = asmbloc.asm_resolve_final(mn_x86, blocs[0], symbol_pool)
# Show resolved blocs
for bloc in blocs[0]:
print bloc
# Print offset -> bytes
pprint(patches)
|