blob: 7ab403f4a0287f17cf50bf6ef4730b9db2bf28ff (
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
|
from pdb import pm
from pprint import pprint
from miasm2.arch.x86.arch import mn_x86
from miasm2.core import parse_asm, asmbloc
# Assemble code
blocks, 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, blocks, symbol_pool)
# Show resolved blocks
for block in blocks:
print block
# Print offset -> bytes
pprint(patches)
|