diff --git a/regress/mips_except.py b/regress/mips_except.py index f24b5b85..28c8001e 100755 --- a/regress/mips_except.py +++ b/regress/mips_except.py @@ -6,24 +6,33 @@ def hook_intr(uc, intno, _): print 'interrupt', intno CODE = 0x400000 -asm = '0000a48f'.decode('hex') +asm = '0000a48f'.decode('hex') # lw $a0, ($sp) uc = Uc(UC_ARCH_MIPS, UC_MODE_MIPS32 + UC_MODE_LITTLE_ENDIAN) uc.hook_add(UC_HOOK_INTR, hook_intr) uc.mem_map(CODE, 0x1000) uc.mem_write(CODE, asm) -print 'unaligned access (exc 12)' -uc.reg_write(UC_MIPS_REG_SP, 0x01) -uc.emu_start(CODE, CODE + len(asm), 300) -print +try: + print 'unaligned access (exc 12)' + uc.reg_write(UC_MIPS_REG_SP, 0x400001) + uc.emu_start(CODE, CODE + len(asm), 300) + print +except UcError as e: + print("ERROR: %s" % e) -print 'dunno (exc 26)' -uc.reg_write(UC_MIPS_REG_SP, 0xFFFFFFF0) -uc.emu_start(CODE, CODE + len(asm), 200) -print +try: + print 'dunno (exc 26)' + uc.reg_write(UC_MIPS_REG_SP, 0xFFFFFFF0) + uc.emu_start(CODE, CODE + len(asm), 200) + print +except UcError as e: + print("ERROR: %s" % e) -print 'unassigned access (exc 28)' -uc.reg_write(UC_MIPS_REG_SP, 0x80000000) -uc.emu_start(CODE, CODE + len(asm), 100) -print +try: + print 'unassigned access (exc 28)' + uc.reg_write(UC_MIPS_REG_SP, 0x80000000) + uc.emu_start(CODE, CODE + len(asm), 100) + print +except UcError as e: + print("ERROR: %s" % e)