1*9a0e4156SSadaf Ebrahimi#!/usr/bin/env python 2*9a0e4156SSadaf Ebrahimi 3*9a0e4156SSadaf Ebrahimi# Capstone Python bindings, by Fotis Loukos <[email protected]> 4*9a0e4156SSadaf Ebrahimi 5*9a0e4156SSadaf Ebrahimifrom __future__ import print_function 6*9a0e4156SSadaf Ebrahimifrom capstone import * 7*9a0e4156SSadaf Ebrahimifrom capstone.tms320c64x import * 8*9a0e4156SSadaf Ebrahimifrom xprint import to_x, to_hex, to_x_32 9*9a0e4156SSadaf Ebrahimi 10*9a0e4156SSadaf Ebrahimi 11*9a0e4156SSadaf EbrahimiTMS320C64X_CODE = b"\x01\xac\x88\x40\x81\xac\x88\x43\x00\x00\x00\x00\x02\x90\x32\x96\x02\x80\x46\x9e\x05\x3c\x83\xe6\x0b\x0c\x8b\x24" 12*9a0e4156SSadaf Ebrahimi 13*9a0e4156SSadaf Ebrahimiall_tests = ( 14*9a0e4156SSadaf Ebrahimi (CS_ARCH_TMS320C64X, 0, TMS320C64X_CODE, "TMS320C64x"), 15*9a0e4156SSadaf Ebrahimi) 16*9a0e4156SSadaf Ebrahimi 17*9a0e4156SSadaf Ebrahimi 18*9a0e4156SSadaf Ebrahimidef print_insn_detail(insn): 19*9a0e4156SSadaf Ebrahimi # print address, mnemonic and operands 20*9a0e4156SSadaf Ebrahimi print("0x%x:\t%s\t%s" % (insn.address, insn.mnemonic, insn.op_str)) 21*9a0e4156SSadaf Ebrahimi 22*9a0e4156SSadaf Ebrahimi # "data" instruction generated by SKIPDATA option has no detail 23*9a0e4156SSadaf Ebrahimi if insn.id == 0: 24*9a0e4156SSadaf Ebrahimi return 25*9a0e4156SSadaf Ebrahimi 26*9a0e4156SSadaf Ebrahimi if len(insn.operands) > 0: 27*9a0e4156SSadaf Ebrahimi print("\top_count: %u" % len(insn.operands)) 28*9a0e4156SSadaf Ebrahimi c = 0 29*9a0e4156SSadaf Ebrahimi for i in insn.operands: 30*9a0e4156SSadaf Ebrahimi if i.type == TMS320C64X_OP_REG: 31*9a0e4156SSadaf Ebrahimi print("\t\toperands[%u].type: REG = %s" % (c, insn.reg_name(i.reg))) 32*9a0e4156SSadaf Ebrahimi if i.type == TMS320C64X_OP_IMM: 33*9a0e4156SSadaf Ebrahimi print("\t\toperands[%u].type: IMM = 0x%s" % (c, to_x(i.imm))) 34*9a0e4156SSadaf Ebrahimi if i.type == TMS320C64X_OP_MEM: 35*9a0e4156SSadaf Ebrahimi print("\t\toperands[%u].type: MEM" % c) 36*9a0e4156SSadaf Ebrahimi if i.mem.base != 0: 37*9a0e4156SSadaf Ebrahimi print("\t\t\toperands[%u].mem.base: REG = %s" \ 38*9a0e4156SSadaf Ebrahimi % (c, insn.reg_name(i.mem.base))) 39*9a0e4156SSadaf Ebrahimi if i.mem.disptype == TMS320C64X_MEM_DISP_INVALID: 40*9a0e4156SSadaf Ebrahimi print("\t\t\toperands[%u].mem.disptype: Invalid" % (c)) 41*9a0e4156SSadaf Ebrahimi print("\t\t\toperands[%u].mem.disp: 0x%s" \ 42*9a0e4156SSadaf Ebrahimi % (c, to_x(i.mem.disp))) 43*9a0e4156SSadaf Ebrahimi if i.mem.disptype == TMS320C64X_MEM_DISP_CONSTANT: 44*9a0e4156SSadaf Ebrahimi print("\t\t\toperands[%u].mem.disptype: Constant" % (c)) 45*9a0e4156SSadaf Ebrahimi print("\t\t\toperands[%u].mem.disp: 0x%s" \ 46*9a0e4156SSadaf Ebrahimi % (c, to_x(i.mem.disp))) 47*9a0e4156SSadaf Ebrahimi if i.mem.disptype == TMS320C64X_MEM_DISP_REGISTER: 48*9a0e4156SSadaf Ebrahimi print("\t\t\toperands[%u].mem.disptype: Register" % (c)) 49*9a0e4156SSadaf Ebrahimi print("\t\t\toperands[%u].mem.disp: %s" \ 50*9a0e4156SSadaf Ebrahimi % (c, insn.reg_name(i.mem.disp))) 51*9a0e4156SSadaf Ebrahimi print("\t\t\toperands[%u].mem.unit: %u" % (c, i.mem.unit)) 52*9a0e4156SSadaf Ebrahimi if i.mem.direction == TMS320C64X_MEM_DIR_INVALID: 53*9a0e4156SSadaf Ebrahimi print("\t\t\toperands[%u].mem.direction: Invalid" % (c)) 54*9a0e4156SSadaf Ebrahimi if i.mem.direction == TMS320C64X_MEM_DIR_FW: 55*9a0e4156SSadaf Ebrahimi print("\t\t\toperands[%u].mem.direction: Forward" % (c)) 56*9a0e4156SSadaf Ebrahimi if i.mem.direction == TMS320C64X_MEM_DIR_BW: 57*9a0e4156SSadaf Ebrahimi print("\t\t\toperands[%u].mem.direction: Backward" % (c)) 58*9a0e4156SSadaf Ebrahimi if i.mem.modify == TMS320C64X_MEM_MOD_INVALID: 59*9a0e4156SSadaf Ebrahimi print("\t\t\toperands[%u].mem.modify: Invalid" % (c)) 60*9a0e4156SSadaf Ebrahimi if i.mem.modify == TMS320C64X_MEM_MOD_NO: 61*9a0e4156SSadaf Ebrahimi print("\t\t\toperands[%u].mem.modify: No" % (c)) 62*9a0e4156SSadaf Ebrahimi if i.mem.modify == TMS320C64X_MEM_MOD_PRE: 63*9a0e4156SSadaf Ebrahimi print("\t\t\toperands[%u].mem.modify: Pre" % (c)) 64*9a0e4156SSadaf Ebrahimi if i.mem.modify == TMS320C64X_MEM_MOD_POST: 65*9a0e4156SSadaf Ebrahimi print("\t\t\toperands[%u].mem.modify: Post" % (c)) 66*9a0e4156SSadaf Ebrahimi print("\t\t\toperands[%u].mem.scaled: %u" % (c, i.mem.scaled)) 67*9a0e4156SSadaf Ebrahimi if i.type == TMS320C64X_OP_REGPAIR: 68*9a0e4156SSadaf Ebrahimi print("\t\toperands[%u].type: REGPAIR = %s:%s" % (c, insn.reg_name(i.reg + 1), insn.reg_name(i.reg))) 69*9a0e4156SSadaf Ebrahimi c += 1 70*9a0e4156SSadaf Ebrahimi 71*9a0e4156SSadaf Ebrahimi 72*9a0e4156SSadaf Ebrahimi# ## Test class Cs 73*9a0e4156SSadaf Ebrahimidef test_class(): 74*9a0e4156SSadaf Ebrahimi 75*9a0e4156SSadaf Ebrahimi for (arch, mode, code, comment) in all_tests: 76*9a0e4156SSadaf Ebrahimi print("*" * 16) 77*9a0e4156SSadaf Ebrahimi print("Platform: %s" %comment) 78*9a0e4156SSadaf Ebrahimi print("Code: %s" % to_hex(code)) 79*9a0e4156SSadaf Ebrahimi print("Disasm:") 80*9a0e4156SSadaf Ebrahimi 81*9a0e4156SSadaf Ebrahimi try: 82*9a0e4156SSadaf Ebrahimi md = Cs(arch, mode) 83*9a0e4156SSadaf Ebrahimi md.detail = True 84*9a0e4156SSadaf Ebrahimi for insn in md.disasm(code, 0x1000): 85*9a0e4156SSadaf Ebrahimi print_insn_detail(insn) 86*9a0e4156SSadaf Ebrahimi print () 87*9a0e4156SSadaf Ebrahimi print("0x%x:\n" % (insn.address + insn.size)) 88*9a0e4156SSadaf Ebrahimi except CsError as e: 89*9a0e4156SSadaf Ebrahimi print("ERROR: %s" %e) 90*9a0e4156SSadaf Ebrahimi 91*9a0e4156SSadaf Ebrahimi 92*9a0e4156SSadaf Ebrahimiif __name__ == '__main__': 93*9a0e4156SSadaf Ebrahimi test_class() 94