xref: /aosp_15_r20/external/capstone/arch/Sparc/SparcMapping.h (revision 9a0e4156d50a75a99ec4f1653a0e9602a5d45c18)
1*9a0e4156SSadaf Ebrahimi /* Capstone Disassembly Engine */
2*9a0e4156SSadaf Ebrahimi /* By Nguyen Anh Quynh <[email protected]>, 2013-2015 */
3*9a0e4156SSadaf Ebrahimi 
4*9a0e4156SSadaf Ebrahimi #ifndef CS_SPARC_MAP_H
5*9a0e4156SSadaf Ebrahimi #define CS_SPARC_MAP_H
6*9a0e4156SSadaf Ebrahimi 
7*9a0e4156SSadaf Ebrahimi #include "capstone/capstone.h"
8*9a0e4156SSadaf Ebrahimi 
9*9a0e4156SSadaf Ebrahimi // return name of regiser in friendly string
10*9a0e4156SSadaf Ebrahimi const char *Sparc_reg_name(csh handle, unsigned int reg);
11*9a0e4156SSadaf Ebrahimi 
12*9a0e4156SSadaf Ebrahimi // given internal insn id, return public instruction info
13*9a0e4156SSadaf Ebrahimi void Sparc_get_insn_id(cs_struct *h, cs_insn *insn, unsigned int id);
14*9a0e4156SSadaf Ebrahimi 
15*9a0e4156SSadaf Ebrahimi const char *Sparc_insn_name(csh handle, unsigned int id);
16*9a0e4156SSadaf Ebrahimi 
17*9a0e4156SSadaf Ebrahimi const char *Sparc_group_name(csh handle, unsigned int id);
18*9a0e4156SSadaf Ebrahimi 
19*9a0e4156SSadaf Ebrahimi // map internal raw register to 'public' register
20*9a0e4156SSadaf Ebrahimi sparc_reg Sparc_map_register(unsigned int r);
21*9a0e4156SSadaf Ebrahimi 
22*9a0e4156SSadaf Ebrahimi // map instruction name to instruction ID (public)
23*9a0e4156SSadaf Ebrahimi // this is for alias instructions only
24*9a0e4156SSadaf Ebrahimi sparc_reg Sparc_map_insn(const char *name);
25*9a0e4156SSadaf Ebrahimi 
26*9a0e4156SSadaf Ebrahimi // map CC string to CC id
27*9a0e4156SSadaf Ebrahimi sparc_cc Sparc_map_ICC(const char *name);
28*9a0e4156SSadaf Ebrahimi 
29*9a0e4156SSadaf Ebrahimi sparc_cc Sparc_map_FCC(const char *name);
30*9a0e4156SSadaf Ebrahimi 
31*9a0e4156SSadaf Ebrahimi sparc_hint Sparc_map_hint(const char *name);
32*9a0e4156SSadaf Ebrahimi 
33*9a0e4156SSadaf Ebrahimi #endif
34*9a0e4156SSadaf Ebrahimi 
35