Coverage Report

Created: 2024-08-21 06:24

/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