Coverage Report

Created: 2026-05-30 06:22

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/capstonenext/arch/RISCV/RISCVDisassemblerExtension.c
Line
Count
Source
1
#include "RISCVDisassemblerExtension.h"
2
3
#define GET_SUBTARGETINFO_ENUM
4
#include "RISCVGenSubtargetInfo.inc"
5
6
bool RISCV_getFeatureBits(unsigned int mode, unsigned int feature)
7
1.07M
{
8
1.07M
  if (feature == RISCV_FeatureNoRVCHints) {
9
15.3k
    return false;
10
15.3k
  }
11
12
1.06M
  switch (feature) {
13
0
  case RISCV_Feature32Bit:
14
0
    return mode & CS_MODE_RISCV32;
15
16
126k
  case RISCV_Feature64Bit:
17
126k
    return mode & CS_MODE_RISCV64;
18
19
106
  case RISCV_FeatureStdExtF:
20
247
  case RISCV_FeatureStdExtD:
21
247
    return mode & CS_MODE_RISCV_FD;
22
23
0
  case RISCV_FeatureStdExtV:
24
0
    return mode & CS_MODE_RISCV_V;
25
26
17.7k
  case RISCV_FeatureStdExtZfinx:
27
35.5k
  case RISCV_FeatureStdExtZdinx:
28
35.5k
  case RISCV_FeatureStdExtZhinx:
29
35.5k
  case RISCV_FeatureStdExtZhinxmin:
30
35.5k
    return mode & CS_MODE_RISCV_ZFINX;
31
32
126k
  case RISCV_FeatureStdExtC:
33
126k
    return mode & CS_MODE_RISCV_C;
34
35
36.8k
  case RISCV_FeatureStdExtZcmp:
36
73.7k
  case RISCV_FeatureStdExtZcmt:
37
73.7k
  case RISCV_FeatureStdExtZce:
38
73.7k
    return mode & CS_MODE_RISCV_ZCMP_ZCMT_ZCE;
39
40
37.0k
  case RISCV_FeatureStdExtZicfiss:
41
37.0k
    return mode & CS_MODE_RISCV_ZICFISS;
42
43
45.9k
  case RISCV_FeatureRVE:
44
45.9k
    return mode & CS_MODE_RISCV_E;
45
46
5
  case RISCV_FeatureStdExtA:
47
5
    return mode & CS_MODE_RISCV_A;
48
49
17.6k
  case RISCV_FeatureVendorXCVelw:
50
17.6k
    return mode & CS_MODE_RISCV_COREV;
51
52
17.7k
  case RISCV_FeatureVendorXSfvcp:
53
35.5k
  case RISCV_FeatureVendorXSfvfnrclipxfqf:
54
53.2k
  case RISCV_FeatureVendorXSfvfwmaccqqq:
55
71.0k
  case RISCV_FeatureVendorXSfvqmaccdod:
56
88.7k
  case RISCV_FeatureVendorXSfvqmaccqoq:
57
88.7k
    return mode & CS_MODE_RISCV_SIFIVE;
58
59
17.7k
  case RISCV_FeatureVendorXTHeadBa:
60
35.5k
  case RISCV_FeatureVendorXTHeadBb:
61
53.2k
  case RISCV_FeatureVendorXTHeadBs:
62
71.0k
  case RISCV_FeatureVendorXTHeadCmo:
63
88.7k
  case RISCV_FeatureVendorXTHeadCondMov:
64
106k
  case RISCV_FeatureVendorXTHeadFMemIdx:
65
124k
  case RISCV_FeatureVendorXTHeadMac:
66
142k
  case RISCV_FeatureVendorXTHeadMemIdx:
67
159k
  case RISCV_FeatureVendorXTHeadMemPair:
68
177k
  case RISCV_FeatureVendorXTHeadSync:
69
195k
  case RISCV_FeatureVendorXTHeadVdot:
70
195k
    return mode & CS_MODE_RISCV_THEAD;
71
72
17.7k
  case RISCV_FeatureVendorXVentanaCondOps:
73
17.7k
    return mode & CS_MODE_RISCV_VENTANA;
74
75
2
  case RISCV_FeatureStdExtZba:
76
2
    return mode & CS_MODE_RISCV_ZBA;
77
3
  case RISCV_FeatureStdExtZbb:
78
3
    return mode & CS_MODE_RISCV_ZBB;
79
1
  case RISCV_FeatureStdExtZbc:
80
1
    return mode & CS_MODE_RISCV_ZBC;
81
5
  case RISCV_FeatureStdExtZbkb:
82
5
    return mode & CS_MODE_RISCV_ZBKB;
83
0
  case RISCV_FeatureStdExtZbkc:
84
0
    return mode & CS_MODE_RISCV_ZBKC;
85
1
  case RISCV_FeatureStdExtZbkx:
86
1
    return mode & CS_MODE_RISCV_ZBKX;
87
1
  case RISCV_FeatureStdExtZbs:
88
1
    return mode & CS_MODE_RISCV_ZBS;
89
298k
  default:
90
    // support everything by default
91
    return true;
92
1.06M
  }
93
1.06M
}