xref: /aosp_15_r20/external/capstone/bindings/python/test_sparc.py (revision 9a0e4156d50a75a99ec4f1653a0e9602a5d45c18)
1*9a0e4156SSadaf Ebrahimi#!/usr/bin/env python
2*9a0e4156SSadaf Ebrahimi
3*9a0e4156SSadaf Ebrahimi# Capstone Python bindings, by Nguyen Anh Quynnh <[email protected]>
4*9a0e4156SSadaf Ebrahimi
5*9a0e4156SSadaf Ebrahimifrom __future__ import print_function
6*9a0e4156SSadaf Ebrahimifrom capstone import *
7*9a0e4156SSadaf Ebrahimifrom capstone.sparc import *
8*9a0e4156SSadaf Ebrahimifrom xprint import to_hex, to_x_32
9*9a0e4156SSadaf Ebrahimi
10*9a0e4156SSadaf Ebrahimi
11*9a0e4156SSadaf EbrahimiSPARC_CODE = b"\x80\xa0\x40\x02\x85\xc2\x60\x08\x85\xe8\x20\x01\x81\xe8\x00\x00\x90\x10\x20\x01\xd5\xf6\x10\x16\x21\x00\x00\x0a\x86\x00\x40\x02\x01\x00\x00\x00\x12\xbf\xff\xff\x10\xbf\xff\xff\xa0\x02\x00\x09\x0d\xbf\xff\xff\xd4\x20\x60\x00\xd4\x4e\x00\x16\x2a\xc2\x80\x03"
12*9a0e4156SSadaf EbrahimiSPARCV9_CODE = b"\x81\xa8\x0a\x24\x89\xa0\x10\x20\x89\xa0\x1a\x60\x89\xa0\x00\xe0"
13*9a0e4156SSadaf Ebrahimi
14*9a0e4156SSadaf Ebrahimiall_tests = (
15*9a0e4156SSadaf Ebrahimi        (CS_ARCH_SPARC, CS_MODE_BIG_ENDIAN, SPARC_CODE, "Sparc"),
16*9a0e4156SSadaf Ebrahimi        (CS_ARCH_SPARC, CS_MODE_BIG_ENDIAN+CS_MODE_V9, SPARCV9_CODE, "SparcV9"),
17*9a0e4156SSadaf Ebrahimi)
18*9a0e4156SSadaf Ebrahimi
19*9a0e4156SSadaf Ebrahimi
20*9a0e4156SSadaf Ebrahimidef print_insn_detail(insn):
21*9a0e4156SSadaf Ebrahimi    # print address, mnemonic and operands
22*9a0e4156SSadaf Ebrahimi    print("0x%x:\t%s\t%s" % (insn.address, insn.mnemonic, insn.op_str))
23*9a0e4156SSadaf Ebrahimi
24*9a0e4156SSadaf Ebrahimi    # "data" instruction generated by SKIPDATA option has no detail
25*9a0e4156SSadaf Ebrahimi    if insn.id == 0:
26*9a0e4156SSadaf Ebrahimi        return
27*9a0e4156SSadaf Ebrahimi
28*9a0e4156SSadaf Ebrahimi    if len(insn.operands) > 0:
29*9a0e4156SSadaf Ebrahimi        print("\top_count: %u" % len(insn.operands))
30*9a0e4156SSadaf Ebrahimi        c = 0
31*9a0e4156SSadaf Ebrahimi        for i in insn.operands:
32*9a0e4156SSadaf Ebrahimi            if i.type == SPARC_OP_REG:
33*9a0e4156SSadaf Ebrahimi                print("\t\toperands[%u].type: REG = %s" % (c, insn.reg_name(i.reg)))
34*9a0e4156SSadaf Ebrahimi            if i.type == SPARC_OP_IMM:
35*9a0e4156SSadaf Ebrahimi                print("\t\toperands[%u].type: IMM = 0x%s" % (c, to_x_32(i.imm)))
36*9a0e4156SSadaf Ebrahimi            if i.type == SPARC_OP_MEM:
37*9a0e4156SSadaf Ebrahimi                print("\t\toperands[%u].type: MEM" % c)
38*9a0e4156SSadaf Ebrahimi                if i.mem.base != 0:
39*9a0e4156SSadaf Ebrahimi                    print("\t\t\toperands[%u].mem.base: REG = %s" \
40*9a0e4156SSadaf Ebrahimi                        % (c, insn.reg_name(i.mem.base)))
41*9a0e4156SSadaf Ebrahimi                if i.mem.index != 0:
42*9a0e4156SSadaf Ebrahimi                    print("\t\t\toperands[%u].mem.index: REG = %s" \
43*9a0e4156SSadaf Ebrahimi                        % (c, insn.reg_name(i.mem.index)))
44*9a0e4156SSadaf Ebrahimi                if i.mem.disp != 0:
45*9a0e4156SSadaf Ebrahimi                    print("\t\t\toperands[%u].mem.disp: 0x%s" \
46*9a0e4156SSadaf Ebrahimi                        % (c, to_x_32(i.mem.disp)))
47*9a0e4156SSadaf Ebrahimi            c += 1
48*9a0e4156SSadaf Ebrahimi
49*9a0e4156SSadaf Ebrahimi    if insn.cc:
50*9a0e4156SSadaf Ebrahimi        print("\tCode condition: %u" % insn.cc)
51*9a0e4156SSadaf Ebrahimi    if insn.hint:
52*9a0e4156SSadaf Ebrahimi        print("\tHint code: %u" % insn.hint)
53*9a0e4156SSadaf Ebrahimi
54*9a0e4156SSadaf Ebrahimi
55*9a0e4156SSadaf Ebrahimi# ## Test class Cs
56*9a0e4156SSadaf Ebrahimidef test_class():
57*9a0e4156SSadaf Ebrahimi    for (arch, mode, code, comment) in all_tests:
58*9a0e4156SSadaf Ebrahimi        print("*" * 16)
59*9a0e4156SSadaf Ebrahimi        print("Platform: %s" % comment)
60*9a0e4156SSadaf Ebrahimi        print("Code: %s" % to_hex(code))
61*9a0e4156SSadaf Ebrahimi        print("Disasm:")
62*9a0e4156SSadaf Ebrahimi
63*9a0e4156SSadaf Ebrahimi        try:
64*9a0e4156SSadaf Ebrahimi            md = Cs(arch, mode)
65*9a0e4156SSadaf Ebrahimi            md.detail = True
66*9a0e4156SSadaf Ebrahimi            for insn in md.disasm(code, 0x1000):
67*9a0e4156SSadaf Ebrahimi                print_insn_detail(insn)
68*9a0e4156SSadaf Ebrahimi                print ()
69*9a0e4156SSadaf Ebrahimi            print("0x%x:\n" % (insn.address + insn.size))
70*9a0e4156SSadaf Ebrahimi        except CsError as e:
71*9a0e4156SSadaf Ebrahimi            print("ERROR: %s" %e)
72*9a0e4156SSadaf Ebrahimi
73*9a0e4156SSadaf Ebrahimi
74*9a0e4156SSadaf Ebrahimiif __name__ == '__main__':
75*9a0e4156SSadaf Ebrahimi    test_class()
76