/src/capstonenext/arch/AArch64/AArch64Mapping.h
Line | Count | Source (jump to first uncovered line) |
1 | | /* Capstone Disassembly Engine */ |
2 | | /* By Nguyen Anh Quynh <aquynh@gmail.com>, 2013-2019 */ |
3 | | |
4 | | #ifndef CS_AARCH64_MAP_H |
5 | | #define CS_AARCH64_MAP_H |
6 | | |
7 | | #include "capstone/capstone.h" |
8 | | #include "../../MCInst.h" |
9 | | #include "../../SStream.h" |
10 | | |
11 | | typedef enum { |
12 | | #include "AArch64GenCSOpGroup.inc" |
13 | | } aarch64_op_group; |
14 | | |
15 | | // return name of register in friendly string |
16 | | const char *AArch64_reg_name(csh handle, unsigned int reg); |
17 | | |
18 | | // given internal insn id, return public instruction info |
19 | | void AArch64_get_insn_id(cs_struct *h, cs_insn *insn, unsigned int id); |
20 | | |
21 | | const char *AArch64_insn_name(csh handle, unsigned int id); |
22 | | |
23 | | const char *AArch64_group_name(csh handle, unsigned int id); |
24 | | |
25 | | void AArch64_reg_access(const cs_insn *insn, cs_regs regs_read, |
26 | | uint8_t *regs_read_count, cs_regs regs_write, |
27 | | uint8_t *regs_write_count); |
28 | | |
29 | | void AArch64_add_cs_detail(MCInst *MI, int /* aarch64_op_group */ op_group, |
30 | | va_list args); |
31 | | |
32 | | static inline void add_cs_detail(MCInst *MI, |
33 | | int /* aarch64_op_group */ op_group, ...) |
34 | 1.08M | { |
35 | 1.08M | if (!MI->flat_insn->detail) |
36 | 0 | return; |
37 | 1.08M | va_list args; |
38 | 1.08M | va_start(args, op_group); |
39 | 1.08M | AArch64_add_cs_detail(MI, op_group, args); |
40 | 1.08M | va_end(args); |
41 | 1.08M | } Unexecuted instantiation: AArch64Module.c:add_cs_detail Unexecuted instantiation: AArch64Mapping.c:add_cs_detail Unexecuted instantiation: AArch64Disassembler.c:add_cs_detail AArch64InstPrinter.c:add_cs_detail Line | Count | Source | 34 | 1.08M | { | 35 | 1.08M | if (!MI->flat_insn->detail) | 36 | 0 | return; | 37 | 1.08M | va_list args; | 38 | 1.08M | va_start(args, op_group); | 39 | 1.08M | AArch64_add_cs_detail(MI, op_group, args); | 40 | 1.08M | va_end(args); | 41 | 1.08M | } |
|
42 | | |
43 | | void AArch64_init_mri(MCRegisterInfo *MRI); |
44 | | |
45 | | void AArch64_init_cs_detail(MCInst *MI); |
46 | | |
47 | | void AArch64_set_instr_map_data(MCInst *MI); |
48 | | |
49 | | bool AArch64_getInstruction(csh handle, const uint8_t *code, size_t code_len, |
50 | | MCInst *instr, uint16_t *size, uint64_t address, |
51 | | void *info); |
52 | | |
53 | | void AArch64_printer(MCInst *MI, SStream *O, void * /* MCRegisterInfo* */ info); |
54 | | |
55 | | void AArch64_set_detail_op_reg(MCInst *MI, unsigned OpNum, aarch64_reg Reg); |
56 | | void AArch64_set_detail_op_imm(MCInst *MI, unsigned OpNum, |
57 | | aarch64_op_type ImmType, int64_t Imm); |
58 | | void AArch64_set_detail_op_imm_range(MCInst *MI, unsigned OpNum, |
59 | | int64_t FirstImm, int64_t offset); |
60 | | void AArch64_set_detail_op_mem(MCInst *MI, unsigned OpNum, uint64_t Val); |
61 | | void AArch64_set_detail_op_mem_offset(MCInst *MI, unsigned OpNum, uint64_t Val); |
62 | | void AArch64_set_detail_shift_ext(MCInst *MI, unsigned OpNum, bool SignExtend, |
63 | | bool DoShift, unsigned ExtWidth, |
64 | | char SrcRegKind); |
65 | | void AArch64_set_detail_op_float(MCInst *MI, unsigned OpNum, float Val); |
66 | | void AArch64_set_detail_op_sys(MCInst *MI, unsigned OpNum, aarch64_sysop sys_op, |
67 | | aarch64_op_type type); |
68 | | void AArch64_set_detail_op_sme(MCInst *MI, unsigned OpNum, |
69 | | aarch64_sme_op_part part, |
70 | | AArch64Layout_VectorLayout vas, ...); |
71 | | void AArch64_set_detail_op_pred(MCInst *MI, unsigned OpNum); |
72 | | void AArch64_insert_detail_op_reg_at(MCInst *MI, unsigned index, |
73 | | aarch64_reg Reg, cs_ac_type access); |
74 | | void AArch64_insert_detail_op_float_at(MCInst *MI, unsigned index, double val, |
75 | | cs_ac_type access); |
76 | | void AArch64_insert_detail_op_imm_at(MCInst *MI, unsigned index, int64_t Imm); |
77 | | void AArch64_insert_detail_op_sys(MCInst *MI, unsigned index, aarch64_sysop sys_op, |
78 | | aarch64_op_type type); |
79 | | void AArch64_insert_detail_op_sme(MCInst *MI, unsigned index, aarch64_op_sme sme_op); |
80 | | void AArch64_add_vas(MCInst *MI, const SStream *OS); |
81 | | |
82 | | #endif |