17 lines
472 B
Python
17 lines
472 B
Python
|
from unicorn import *
|
||
|
from unicorn.mips_const import *
|
||
|
|
||
|
def intr_hook(uc, intno, data):
|
||
|
print 'interrupt=%d, v0=%d, pc=0x%08x' % (intno, uc.reg_read(UC_MIPS_REG_V0), uc.reg_read(UC_MIPS_REG_PC))
|
||
|
|
||
|
addr = 0x40000
|
||
|
code = '0c000000'.decode('hex') # syscall
|
||
|
|
||
|
uc = Uc(UC_ARCH_MIPS, UC_MODE_MIPS32 + UC_MODE_LITTLE_ENDIAN)
|
||
|
uc.mem_map(addr, 0x1000)
|
||
|
uc.mem_write(addr, code)
|
||
|
uc.reg_write(UC_MIPS_REG_V0, 100)
|
||
|
uc.hook_add(UC_HOOK_INTR, intr_hook)
|
||
|
|
||
|
uc.emu_start(addr, len(code))
|