/src/binutils-gdb/include/opcode/riscv.h
Line | Count | Source (jump to first uncovered line) |
1 | | /* riscv.h. RISC-V opcode list for GDB, the GNU debugger. |
2 | | Copyright (C) 2011-2025 Free Software Foundation, Inc. |
3 | | Contributed by Andrew Waterman |
4 | | |
5 | | This file is part of GDB, GAS, and the GNU binutils. |
6 | | |
7 | | GDB, GAS, and the GNU binutils are free software; you can redistribute |
8 | | them and/or modify them under the terms of the GNU General Public |
9 | | License as published by the Free Software Foundation; either version |
10 | | 3, or (at your option) any later version. |
11 | | |
12 | | GDB, GAS, and the GNU binutils are distributed in the hope that they |
13 | | will be useful, but WITHOUT ANY WARRANTY; without even the implied |
14 | | warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See |
15 | | the GNU General Public License for more details. |
16 | | |
17 | | You should have received a copy of the GNU General Public License |
18 | | along with this program; see the file COPYING3. If not, |
19 | | see <http://www.gnu.org/licenses/>. */ |
20 | | |
21 | | #ifndef _RISCV_H_ |
22 | | #define _RISCV_H_ |
23 | | |
24 | | #include "riscv-opc.h" |
25 | | #include <stdlib.h> |
26 | | #include <stdint.h> |
27 | | |
28 | | typedef uint64_t insn_t; |
29 | | |
30 | | static inline unsigned int riscv_insn_length (insn_t insn) |
31 | 4.13M | { |
32 | 4.13M | if ((insn & 0x3) != 0x3) /* RVC instructions. */ |
33 | 3.21M | return 2; |
34 | 917k | if ((insn & 0x1f) != 0x1f) /* 32-bit instructions. */ |
35 | 590k | return 4; |
36 | 326k | if ((insn & 0x3f) == 0x1f) /* 48-bit instructions. */ |
37 | 30.8k | return 6; |
38 | 295k | if ((insn & 0x7f) == 0x3f) /* 64-bit instructions. */ |
39 | 18.5k | return 8; |
40 | | /* 80- ... 176-bit instructions. */ |
41 | 277k | if ((insn & 0x7f) == 0x7f && (insn & 0x7000) != 0x7000) |
42 | 65.4k | return 10 + ((insn >> 11) & 0xe); |
43 | | /* Maximum value returned by this function. */ |
44 | 211k | #define RISCV_MAX_INSN_LEN 22 |
45 | | /* Longer instructions not supported at the moment. */ |
46 | 211k | return 2; |
47 | 277k | } Unexecuted instantiation: elf32-riscv.c:riscv_insn_length Unexecuted instantiation: elf64-riscv.c:riscv_insn_length Unexecuted instantiation: elfxx-riscv.c:riscv_insn_length riscv-dis.c:riscv_insn_length Line | Count | Source | 31 | 4.13M | { | 32 | 4.13M | if ((insn & 0x3) != 0x3) /* RVC instructions. */ | 33 | 3.21M | return 2; | 34 | 917k | if ((insn & 0x1f) != 0x1f) /* 32-bit instructions. */ | 35 | 590k | return 4; | 36 | 326k | if ((insn & 0x3f) == 0x1f) /* 48-bit instructions. */ | 37 | 30.8k | return 6; | 38 | 295k | if ((insn & 0x7f) == 0x3f) /* 64-bit instructions. */ | 39 | 18.5k | return 8; | 40 | | /* 80- ... 176-bit instructions. */ | 41 | 277k | if ((insn & 0x7f) == 0x7f && (insn & 0x7000) != 0x7000) | 42 | 65.4k | return 10 + ((insn >> 11) & 0xe); | 43 | | /* Maximum value returned by this function. */ | 44 | 211k | #define RISCV_MAX_INSN_LEN 22 | 45 | | /* Longer instructions not supported at the moment. */ | 46 | 211k | return 2; | 47 | 277k | } |
Unexecuted instantiation: riscv-opc.c:riscv_insn_length |
48 | | |
49 | | #define RVC_JUMP_BITS 11 |
50 | | #define RVC_JUMP_REACH ((1ULL << RVC_JUMP_BITS) * RISCV_JUMP_ALIGN) |
51 | | |
52 | | #define RVC_BRANCH_BITS 8 |
53 | | #define RVC_BRANCH_REACH ((1ULL << RVC_BRANCH_BITS) * RISCV_BRANCH_ALIGN) |
54 | | |
55 | 3.42M | #define RV_X(x, s, n) (((x) >> (s)) & ((1 << (n)) - 1)) |
56 | 91.7k | #define RV_IMM_SIGN(x) (-(((x) >> 31) & 1)) |
57 | 0 | #define RV_X_SIGNED(x, s, n) (RV_X(x, s, n) | ((-(RV_X(x, (s + n - 1), 1))) << (n))) |
58 | 0 | #define RV_IMM_SIGN_N(x, s, n) (-(((x) >> ((s) + (n) - 1)) & 1)) |
59 | | |
60 | | #define EXTRACT_ITYPE_IMM(x) \ |
61 | 41.7k | (RV_X(x, 20, 12) | (RV_IMM_SIGN(x) << 12)) |
62 | | #define EXTRACT_STYPE_IMM(x) \ |
63 | 12.5k | (RV_X(x, 7, 5) | (RV_X(x, 25, 7) << 5) | (RV_IMM_SIGN(x) << 12)) |
64 | | #define EXTRACT_BTYPE_IMM(x) \ |
65 | 5.50k | ((RV_X(x, 8, 4) << 1) | (RV_X(x, 25, 6) << 5) | (RV_X(x, 7, 1) << 11) | (RV_IMM_SIGN(x) << 12)) |
66 | | #define EXTRACT_UTYPE_IMM(x) \ |
67 | 23.9k | ((RV_X(x, 12, 20) << 12) | (RV_IMM_SIGN(x) << 32)) |
68 | | #define EXTRACT_JTYPE_IMM(x) \ |
69 | 8.04k | ((RV_X(x, 21, 10) << 1) | (RV_X(x, 20, 1) << 11) | (RV_X(x, 12, 8) << 12) | (RV_IMM_SIGN(x) << 20)) |
70 | | #define EXTRACT_CITYPE_IMM(x) \ |
71 | 399k | (RV_X(x, 2, 5) | (-RV_X(x, 12, 1) << 5)) |
72 | | #define EXTRACT_CITYPE_LUI_IMM(x) \ |
73 | 63.9k | (EXTRACT_CITYPE_IMM (x) << RISCV_IMM_BITS) |
74 | | #define EXTRACT_CITYPE_ADDI16SP_IMM(x) \ |
75 | 11.3k | ((RV_X(x, 6, 1) << 4) | (RV_X(x, 2, 1) << 5) | (RV_X(x, 5, 1) << 6) | (RV_X(x, 3, 2) << 7) | (-RV_X(x, 12, 1) << 9)) |
76 | | #define EXTRACT_CITYPE_LWSP_IMM(x) \ |
77 | 30.9k | ((RV_X(x, 4, 3) << 2) | (RV_X(x, 12, 1) << 5) | (RV_X(x, 2, 2) << 6)) |
78 | | #define EXTRACT_CITYPE_LDSP_IMM(x) \ |
79 | 52.2k | ((RV_X(x, 5, 2) << 3) | (RV_X(x, 12, 1) << 5) | (RV_X(x, 2, 3) << 6)) |
80 | | #define EXTRACT_CSSTYPE_IMM(x) \ |
81 | | (RV_X(x, 7, 6) << 0) |
82 | | #define EXTRACT_CSSTYPE_SWSP_IMM(x) \ |
83 | 27.9k | ((RV_X(x, 9, 4) << 2) | (RV_X(x, 7, 2) << 6)) |
84 | | #define EXTRACT_CSSTYPE_SDSP_IMM(x) \ |
85 | 35.0k | ((RV_X(x, 10, 3) << 3) | (RV_X(x, 7, 3) << 6)) |
86 | | #define EXTRACT_CIWTYPE_IMM(x) \ |
87 | | (RV_X(x, 5, 8)) |
88 | | #define EXTRACT_CIWTYPE_ADDI4SPN_IMM(x) \ |
89 | 271k | ((RV_X(x, 6, 1) << 2) | (RV_X(x, 5, 1) << 3) | (RV_X(x, 11, 2) << 4) | (RV_X(x, 7, 4) << 6)) |
90 | | #define EXTRACT_CLTYPE_IMM(x) \ |
91 | | ((RV_X(x, 5, 2) << 0) | (RV_X(x, 10, 3) << 2)) |
92 | | #define EXTRACT_CLTYPE_LW_IMM(x) \ |
93 | 81.5k | ((RV_X(x, 6, 1) << 2) | (RV_X(x, 10, 3) << 3) | (RV_X(x, 5, 1) << 6)) |
94 | | #define EXTRACT_CLTYPE_LD_IMM(x) \ |
95 | 142k | ((RV_X(x, 10, 3) << 3) | (RV_X(x, 5, 2) << 6)) |
96 | | #define EXTRACT_CBTYPE_IMM(x) \ |
97 | 46.3k | ((RV_X(x, 3, 2) << 1) | (RV_X(x, 10, 2) << 3) | (RV_X(x, 2, 1) << 5) | (RV_X(x, 5, 2) << 6) | (-RV_X(x, 12, 1) << 8)) |
98 | | #define EXTRACT_CJTYPE_IMM(x) \ |
99 | 27.3k | ((RV_X(x, 3, 3) << 1) | (RV_X(x, 11, 1) << 4) | (RV_X(x, 2, 1) << 5) | (RV_X(x, 7, 1) << 6) | (RV_X(x, 6, 1) << 7) | (RV_X(x, 9, 2) << 8) | (RV_X(x, 8, 1) << 10) | (-RV_X(x, 12, 1) << 11)) |
100 | | #define EXTRACT_RVV_VI_IMM(x) \ |
101 | 0 | (RV_X(x, 15, 5) | (-RV_X(x, 19, 1) << 5)) |
102 | | #define EXTRACT_RVV_VI_UIMM(x) \ |
103 | 0 | (RV_X(x, 15, 5)) |
104 | | #define EXTRACT_RVV_VI_UIMM6(x) \ |
105 | 0 | (RV_X(x, 15, 5) | (RV_X(x, 26, 1) << 5)) |
106 | | #define EXTRACT_RVV_OFFSET(x) \ |
107 | 0 | (RV_X(x, 29, 3)) |
108 | | #define EXTRACT_RVV_VB_IMM(x) \ |
109 | 0 | (RV_X(x, 20, 10)) |
110 | | #define EXTRACT_RVV_VC_IMM(x) \ |
111 | 0 | (RV_X(x, 20, 11)) |
112 | | #define EXTRACT_ZCB_BYTE_UIMM(x) \ |
113 | 0 | (RV_X(x, 6, 1) | (RV_X(x, 5, 1) << 1)) |
114 | | #define EXTRACT_ZCB_HALFWORD_UIMM(x) \ |
115 | 0 | (RV_X(x, 5, 1) << 1) |
116 | | #define EXTRACT_ZCMP_SPIMM(x) \ |
117 | 0 | (RV_X(x, 2, 2) << 4) |
118 | | #define EXTRACT_ZCMT_INDEX(x) \ |
119 | 0 | (RV_X(x, 2, 8)) |
120 | | /* Vendor-specific (CORE-V) extract macros. */ |
121 | | #define EXTRACT_CV_IS2_UIMM5(x) \ |
122 | 0 | (RV_X(x, 20, 5)) |
123 | | #define EXTRACT_CV_IS3_UIMM5(x) \ |
124 | 0 | (RV_X(x, 25, 5)) |
125 | | #define EXTRACT_CV_BI_IMM5(x) \ |
126 | 0 | (RV_X(x, 20, 5) | (RV_IMM_SIGN_N(x, 20, 5) << 5)) |
127 | | #define EXTRACT_CV_BITMANIP_UIMM5(x) \ |
128 | 0 | (RV_X(x, 25, 5)) |
129 | | #define EXTRACT_CV_BITMANIP_UIMM2(x) \ |
130 | 0 | (RV_X(x, 25, 2)) |
131 | | #define EXTRACT_CV_SIMD_IMM6(x) \ |
132 | 0 | ((RV_X(x, 25, 1)) | (RV_X(x, 20, 5) << 1) | (RV_IMM_SIGN_N(x, 20, 5) << 5)) |
133 | | #define EXTRACT_CV_SIMD_UIMM6(x) \ |
134 | 0 | ((RV_X(x, 25, 1)) | (RV_X(x, 20, 5) << 1)) |
135 | | /* Vendor-specific (MIPS) extract macros. */ |
136 | | #define EXTRACT_MIPS_LWP_IMM(x) \ |
137 | 0 | (RV_X(x, 22, 5) << 2) |
138 | | #define EXTRACT_MIPS_LDP_IMM(x) \ |
139 | 0 | (RV_X(x, 23, 4) << 3) |
140 | | #define EXTRACT_MIPS_SWP_IMM(x) \ |
141 | 0 | ((RV_X(x, 25, 2) << 5) | (RV_X(x, 9, 3) << 2)) |
142 | | #define EXTRACT_MIPS_SDP_IMM(x) \ |
143 | 0 | ((RV_X(x, 25, 2) << 5) | (RV_X(x, 10, 2) << 3)) |
144 | | |
145 | | #define ENCODE_ITYPE_IMM(x) \ |
146 | 0 | (RV_X(x, 0, 12) << 20) |
147 | | #define ENCODE_STYPE_IMM(x) \ |
148 | 0 | ((RV_X(x, 0, 5) << 7) | (RV_X(x, 5, 7) << 25)) |
149 | | #define ENCODE_BTYPE_IMM(x) \ |
150 | 0 | ((RV_X(x, 1, 4) << 8) | (RV_X(x, 5, 6) << 25) | (RV_X(x, 11, 1) << 7) | (RV_X(x, 12, 1) << 31)) |
151 | | #define ENCODE_UTYPE_IMM(x) \ |
152 | 0 | (RV_X(x, 12, 20) << 12) |
153 | | #define ENCODE_JTYPE_IMM(x) \ |
154 | 0 | ((RV_X(x, 1, 10) << 21) | (RV_X(x, 11, 1) << 20) | (RV_X(x, 12, 8) << 12) | (RV_X(x, 20, 1) << 31)) |
155 | | #define ENCODE_CITYPE_IMM(x) \ |
156 | 0 | ((RV_X(x, 0, 5) << 2) | (RV_X(x, 5, 1) << 12)) |
157 | | #define ENCODE_CITYPE_LUI_IMM(x) \ |
158 | 0 | ENCODE_CITYPE_IMM ((x) >> RISCV_IMM_BITS) |
159 | | #define ENCODE_CITYPE_ADDI16SP_IMM(x) \ |
160 | | ((RV_X(x, 4, 1) << 6) | (RV_X(x, 5, 1) << 2) | (RV_X(x, 6, 1) << 5) | (RV_X(x, 7, 2) << 3) | (RV_X(x, 9, 1) << 12)) |
161 | | #define ENCODE_CITYPE_LWSP_IMM(x) \ |
162 | | ((RV_X(x, 2, 3) << 4) | (RV_X(x, 5, 1) << 12) | (RV_X(x, 6, 2) << 2)) |
163 | | #define ENCODE_CITYPE_LDSP_IMM(x) \ |
164 | | ((RV_X(x, 3, 2) << 5) | (RV_X(x, 5, 1) << 12) | (RV_X(x, 6, 3) << 2)) |
165 | | #define ENCODE_CSSTYPE_IMM(x) \ |
166 | | (RV_X(x, 0, 6) << 7) |
167 | | #define ENCODE_CSSTYPE_SWSP_IMM(x) \ |
168 | | ((RV_X(x, 2, 4) << 9) | (RV_X(x, 6, 2) << 7)) |
169 | | #define ENCODE_CSSTYPE_SDSP_IMM(x) \ |
170 | | ((RV_X(x, 3, 3) << 10) | (RV_X(x, 6, 3) << 7)) |
171 | | #define ENCODE_CIWTYPE_IMM(x) \ |
172 | | (RV_X(x, 0, 8) << 5) |
173 | | #define ENCODE_CIWTYPE_ADDI4SPN_IMM(x) \ |
174 | | ((RV_X(x, 2, 1) << 6) | (RV_X(x, 3, 1) << 5) | (RV_X(x, 4, 2) << 11) | (RV_X(x, 6, 4) << 7)) |
175 | | #define ENCODE_CLTYPE_IMM(x) \ |
176 | | ((RV_X(x, 0, 2) << 5) | (RV_X(x, 2, 3) << 10)) |
177 | | #define ENCODE_CLTYPE_LW_IMM(x) \ |
178 | | ((RV_X(x, 2, 1) << 6) | (RV_X(x, 3, 3) << 10) | (RV_X(x, 6, 1) << 5)) |
179 | | #define ENCODE_CLTYPE_LD_IMM(x) \ |
180 | | ((RV_X(x, 3, 3) << 10) | (RV_X(x, 6, 2) << 5)) |
181 | | #define ENCODE_CBTYPE_IMM(x) \ |
182 | 0 | ((RV_X(x, 1, 2) << 3) | (RV_X(x, 3, 2) << 10) | (RV_X(x, 5, 1) << 2) | (RV_X(x, 6, 2) << 5) | (RV_X(x, 8, 1) << 12)) |
183 | | #define ENCODE_CJTYPE_IMM(x) \ |
184 | 0 | ((RV_X(x, 1, 3) << 3) | (RV_X(x, 4, 1) << 11) | (RV_X(x, 5, 1) << 2) | (RV_X(x, 6, 1) << 7) | (RV_X(x, 7, 1) << 6) | (RV_X(x, 8, 2) << 9) | (RV_X(x, 10, 1) << 8) | (RV_X(x, 11, 1) << 12)) |
185 | | #define ENCODE_RVV_VB_IMM(x) \ |
186 | | (RV_X(x, 0, 10) << 20) |
187 | | #define ENCODE_RVV_VC_IMM(x) \ |
188 | | (RV_X(x, 0, 11) << 20) |
189 | | #define ENCODE_RVV_VI_UIMM6(x) \ |
190 | | (RV_X(x, 0, 5) << 15 | RV_X(x, 5, 1) << 26) |
191 | | #define ENCODE_ZCB_BYTE_UIMM(x) \ |
192 | | ((RV_X(x, 0, 1) << 6) | (RV_X(x, 1, 1) << 5)) |
193 | | #define ENCODE_ZCB_HALFWORD_UIMM(x) \ |
194 | | (RV_X(x, 1, 1) << 5) |
195 | | #define ENCODE_ZCMP_SPIMM(x) \ |
196 | | (RV_X(x, 4, 2) << 2) |
197 | | #define ENCODE_ZCMT_INDEX(x) \ |
198 | | (RV_X(x, 0, 8) << 2) |
199 | | /* Vendor-specific (CORE-V) encode macros. */ |
200 | | #define ENCODE_CV_IS2_UIMM5(x) \ |
201 | | (RV_X(x, 0, 5) << 20) |
202 | | #define ENCODE_CV_IS3_UIMM5(x) \ |
203 | | (RV_X(x, 0, 5) << 25) |
204 | | #define ENCODE_CV_BITMANIP_UIMM5(x) \ |
205 | | (RV_X(x, 0, 5) << 25) |
206 | | #define ENCODE_CV_BITMANIP_UIMM2(x) \ |
207 | | (RV_X(x, 0, 2) << 25) |
208 | | #define ENCODE_CV_SIMD_IMM6(x) \ |
209 | | ((RV_X(x, 0, 1) << 25) | (RV_X(x, 1, 5) << 20)) |
210 | | #define ENCODE_CV_SIMD_UIMM6(x) \ |
211 | | ((RV_X(x, 0, 1) << 25) | (RV_X(x, 1, 5) << 20)) |
212 | | /* Vendor-specific (MIPS) encode macros. */ |
213 | | #define ENCODE_MIPS_LWP_IMM(x) \ |
214 | | (RV_X(x, 2, 5) << 22) |
215 | | #define ENCODE_MIPS_LDP_IMM(x) \ |
216 | | (RV_X(x, 3, 4) << 23) |
217 | | #define ENCODE_MIPS_SWP_IMM(x) \ |
218 | | ((RV_X(x, 5, 2) << 25) | (RV_X(x, 2, 3) << 9)) |
219 | | #define ENCODE_MIPS_SDP_IMM(x) \ |
220 | | ((RV_X(x, 5, 2) << 25) | (RV_X(x, 3, 2) << 10)) |
221 | | |
222 | 0 | #define VALID_ITYPE_IMM(x) (EXTRACT_ITYPE_IMM(ENCODE_ITYPE_IMM(x)) == (x)) |
223 | | #define VALID_STYPE_IMM(x) (EXTRACT_STYPE_IMM(ENCODE_STYPE_IMM(x)) == (x)) |
224 | 0 | #define VALID_BTYPE_IMM(x) (EXTRACT_BTYPE_IMM(ENCODE_BTYPE_IMM(x)) == (x)) |
225 | 0 | #define VALID_UTYPE_IMM(x) (EXTRACT_UTYPE_IMM(ENCODE_UTYPE_IMM(x)) == (x)) |
226 | 0 | #define VALID_JTYPE_IMM(x) (EXTRACT_JTYPE_IMM(ENCODE_JTYPE_IMM(x)) == (x)) |
227 | | #define VALID_CITYPE_IMM(x) (EXTRACT_CITYPE_IMM(ENCODE_CITYPE_IMM(x)) == (x)) |
228 | 0 | #define VALID_CITYPE_LUI_IMM(x) (ENCODE_CITYPE_LUI_IMM(x) != 0 \ |
229 | 0 | && EXTRACT_CITYPE_LUI_IMM(ENCODE_CITYPE_LUI_IMM(x)) == (x)) |
230 | | #define VALID_CITYPE_ADDI16SP_IMM(x) (ENCODE_CITYPE_ADDI16SP_IMM(x) != 0 \ |
231 | | && EXTRACT_CITYPE_ADDI16SP_IMM(ENCODE_CITYPE_ADDI16SP_IMM(x)) == (x)) |
232 | | #define VALID_CITYPE_LWSP_IMM(x) (EXTRACT_CITYPE_LWSP_IMM(ENCODE_CITYPE_LWSP_IMM(x)) == (x)) |
233 | | #define VALID_CITYPE_LDSP_IMM(x) (EXTRACT_CITYPE_LDSP_IMM(ENCODE_CITYPE_LDSP_IMM(x)) == (x)) |
234 | | #define VALID_CSSTYPE_IMM(x) (EXTRACT_CSSTYPE_IMM(ENCODE_CSSTYPE_IMM(x)) == (x)) |
235 | | #define VALID_CSSTYPE_SWSP_IMM(x) (EXTRACT_CSSTYPE_SWSP_IMM(ENCODE_CSSTYPE_SWSP_IMM(x)) == (x)) |
236 | | #define VALID_CSSTYPE_SDSP_IMM(x) (EXTRACT_CSSTYPE_SDSP_IMM(ENCODE_CSSTYPE_SDSP_IMM(x)) == (x)) |
237 | | #define VALID_CIWTYPE_IMM(x) (EXTRACT_CIWTYPE_IMM(ENCODE_CIWTYPE_IMM(x)) == (x)) |
238 | | #define VALID_CIWTYPE_ADDI4SPN_IMM(x) (EXTRACT_CIWTYPE_ADDI4SPN_IMM(ENCODE_CIWTYPE_ADDI4SPN_IMM(x)) == (x)) |
239 | | #define VALID_CLTYPE_IMM(x) (EXTRACT_CLTYPE_IMM(ENCODE_CLTYPE_IMM(x)) == (x)) |
240 | | #define VALID_CLTYPE_LW_IMM(x) (EXTRACT_CLTYPE_LW_IMM(ENCODE_CLTYPE_LW_IMM(x)) == (x)) |
241 | | #define VALID_CLTYPE_LD_IMM(x) (EXTRACT_CLTYPE_LD_IMM(ENCODE_CLTYPE_LD_IMM(x)) == (x)) |
242 | 0 | #define VALID_CBTYPE_IMM(x) (EXTRACT_CBTYPE_IMM(ENCODE_CBTYPE_IMM(x)) == (x)) |
243 | 0 | #define VALID_CJTYPE_IMM(x) (EXTRACT_CJTYPE_IMM(ENCODE_CJTYPE_IMM(x)) == (x)) |
244 | | #define VALID_RVV_VB_IMM(x) (EXTRACT_RVV_VB_IMM(ENCODE_RVV_VB_IMM(x)) == (x)) |
245 | | #define VALID_RVV_VC_IMM(x) (EXTRACT_RVV_VC_IMM(ENCODE_RVV_VC_IMM(x)) == (x)) |
246 | | #define VALID_ZCB_BYTE_UIMM(x) (EXTRACT_ZCB_BYTE_UIMM(ENCODE_ZCB_BYTE_UIMM(x)) == (x)) |
247 | | #define VALID_ZCB_HALFWORD_UIMM(x) (EXTRACT_ZCB_HALFWORD_UIMM(ENCODE_ZCB_HALFWORD_UIMM(x)) == (x)) |
248 | | #define VALID_ZCMP_SPIMM(x) (EXTRACT_ZCMP_SPIMM(ENCODE_ZCMP_SPIMM(x)) == (x)) |
249 | | |
250 | | #define RISCV_RTYPE(insn, rd, rs1, rs2) \ |
251 | 0 | ((MATCH_ ## insn) | ((rd) << OP_SH_RD) | ((rs1) << OP_SH_RS1) | ((rs2) << OP_SH_RS2)) |
252 | | #define RISCV_ITYPE(insn, rd, rs1, imm) \ |
253 | 0 | ((MATCH_ ## insn) | ((rd) << OP_SH_RD) | ((rs1) << OP_SH_RS1) | ENCODE_ITYPE_IMM(imm)) |
254 | | #define RISCV_STYPE(insn, rs1, rs2, imm) \ |
255 | | ((MATCH_ ## insn) | ((rs1) << OP_SH_RS1) | ((rs2) << OP_SH_RS2) | ENCODE_STYPE_IMM(imm)) |
256 | | #define RISCV_BTYPE(insn, rs1, rs2, target) \ |
257 | | ((MATCH_ ## insn) | ((rs1) << OP_SH_RS1) | ((rs2) << OP_SH_RS2) | ENCODE_BTYPE_IMM(target)) |
258 | | #define RISCV_UTYPE(insn, rd, bigimm) \ |
259 | 0 | ((MATCH_ ## insn) | ((rd) << OP_SH_RD) | ENCODE_UTYPE_IMM(bigimm)) |
260 | | #define RISCV_JTYPE(insn, rd, target) \ |
261 | | ((MATCH_ ## insn) | ((rd) << OP_SH_RD) | ENCODE_JTYPE_IMM(target)) |
262 | | |
263 | 0 | #define RISCV_NOP RISCV_ITYPE(ADDI, 0, 0, 0) |
264 | 0 | #define RVC_NOP MATCH_C_ADDI |
265 | | |
266 | | #define RISCV_CONST_HIGH_PART(VALUE) \ |
267 | 0 | (((VALUE) + (RISCV_IMM_REACH/2)) & ~(RISCV_IMM_REACH-1)) |
268 | 0 | #define RISCV_CONST_LOW_PART(VALUE) ((VALUE) - RISCV_CONST_HIGH_PART (VALUE)) |
269 | 0 | #define RISCV_PCREL_HIGH_PART(VALUE, PC) RISCV_CONST_HIGH_PART((VALUE) - (PC)) |
270 | 0 | #define RISCV_PCREL_LOW_PART(VALUE, PC) RISCV_CONST_LOW_PART((VALUE) - (PC)) |
271 | | |
272 | | #define RISCV_JUMP_BITS RISCV_BIGIMM_BITS |
273 | | #define RISCV_JUMP_ALIGN_BITS 1 |
274 | | #define RISCV_JUMP_ALIGN (1 << RISCV_JUMP_ALIGN_BITS) |
275 | | #define RISCV_JUMP_REACH ((1ULL << RISCV_JUMP_BITS) * RISCV_JUMP_ALIGN) |
276 | | |
277 | 106k | #define RISCV_IMM_BITS 12 |
278 | 30.7k | #define RISCV_BIGIMM_BITS (32 - RISCV_IMM_BITS) |
279 | 0 | #define RISCV_IMM_REACH (1LL << RISCV_IMM_BITS) |
280 | 30.7k | #define RISCV_BIGIMM_REACH (1LL << RISCV_BIGIMM_BITS) |
281 | | #define RISCV_RVC_IMM_REACH (1LL << 6) |
282 | | #define RISCV_BRANCH_BITS RISCV_IMM_BITS |
283 | | #define RISCV_BRANCH_ALIGN_BITS RISCV_JUMP_ALIGN_BITS |
284 | | #define RISCV_BRANCH_ALIGN (1 << RISCV_BRANCH_ALIGN_BITS) |
285 | | #define RISCV_BRANCH_REACH (RISCV_IMM_REACH * RISCV_BRANCH_ALIGN) |
286 | | |
287 | | /* RV fields. */ |
288 | | |
289 | 238k | #define OP_MASK_OP 0x7f |
290 | | #define OP_SH_OP 0 |
291 | 8.17M | #define OP_MASK_RS2 0x1f |
292 | 16.3M | #define OP_SH_RS2 20 |
293 | 9.12M | #define OP_MASK_RS1 0x1f |
294 | 17.1M | #define OP_SH_RS1 15 |
295 | | #define OP_MASK_RS3 0x1fU |
296 | | #define OP_SH_RS3 27 |
297 | 9.82M | #define OP_MASK_RD 0x1f |
298 | 18.2M | #define OP_SH_RD 7 |
299 | | #define OP_MASK_SHAMT 0x3f |
300 | | #define OP_SH_SHAMT 20 |
301 | | #define OP_MASK_SHAMTW 0x1f |
302 | | #define OP_SH_SHAMTW 20 |
303 | | #define OP_MASK_RM 0x7 |
304 | | #define OP_SH_RM 12 |
305 | | #define OP_MASK_PRED 0xf |
306 | | #define OP_SH_PRED 24 |
307 | | #define OP_MASK_SUCC 0xf |
308 | | #define OP_SH_SUCC 20 |
309 | | #define OP_MASK_AQ 0x1 |
310 | | #define OP_SH_AQ 26 |
311 | | #define OP_MASK_RL 0x1 |
312 | | #define OP_SH_RL 25 |
313 | | |
314 | | #define OP_MASK_CSR 0xfffU |
315 | | #define OP_SH_CSR 20 |
316 | | |
317 | | #define OP_MASK_FUNCT3 0x7 |
318 | | #define OP_SH_FUNCT3 12 |
319 | | #define OP_MASK_FUNCT7 0x7fU |
320 | | #define OP_SH_FUNCT7 25 |
321 | | #define OP_MASK_FUNCT2 0x3 |
322 | | #define OP_SH_FUNCT2 25 |
323 | | |
324 | | /* RVC fields. */ |
325 | | |
326 | | #define OP_MASK_OP2 0x3 |
327 | | #define OP_SH_OP2 0 |
328 | | |
329 | 612k | #define OP_MASK_CRS2 0x1f |
330 | 1.20M | #define OP_SH_CRS2 2 |
331 | | #define OP_MASK_CRS1S 0x7 |
332 | | #define OP_SH_CRS1S 7 |
333 | 1.23M | #define OP_MASK_CRS2S 0x7 |
334 | 2.46M | #define OP_SH_CRS2S 2 |
335 | | |
336 | | #define OP_MASK_CFUNCT6 0x3f |
337 | | #define OP_SH_CFUNCT6 10 |
338 | | #define OP_MASK_CFUNCT4 0xf |
339 | | #define OP_SH_CFUNCT4 12 |
340 | | #define OP_MASK_CFUNCT3 0x7 |
341 | | #define OP_SH_CFUNCT3 13 |
342 | | #define OP_MASK_CFUNCT2 0x3 |
343 | | #define OP_SH_CFUNCT2 5 |
344 | | |
345 | | /* Scalar crypto fields. */ |
346 | | |
347 | | #define OP_SH_BS 30 |
348 | | #define OP_MASK_BS 3 |
349 | | #define OP_SH_RNUM 20 |
350 | | #define OP_MASK_RNUM 0xf |
351 | | |
352 | | /* RVV fields. */ |
353 | | |
354 | 892k | #define OP_MASK_VD 0x1f |
355 | 1.78M | #define OP_SH_VD 7 |
356 | 3.54M | #define OP_MASK_VS1 0x1f |
357 | 7.09M | #define OP_SH_VS1 15 |
358 | 3.54M | #define OP_MASK_VS2 0x1f |
359 | 7.09M | #define OP_SH_VS2 20 |
360 | | #define OP_MASK_VIMM 0x1f |
361 | | #define OP_SH_VIMM 15 |
362 | | #define OP_MASK_VMASK 0x1 |
363 | | #define OP_SH_VMASK 25 |
364 | | #define OP_MASK_VFUNCT6 0x3f |
365 | | #define OP_SH_VFUNCT6 26 |
366 | | #define OP_MASK_VLMUL 0x7 |
367 | | #define OP_SH_VLMUL 0 |
368 | | #define OP_MASK_VSEW 0x7 |
369 | | #define OP_SH_VSEW 3 |
370 | | #define OP_MASK_VTA 0x1 |
371 | | #define OP_SH_VTA 6 |
372 | | #define OP_MASK_VMA 0x1 |
373 | | #define OP_SH_VMA 7 |
374 | | #define OP_MASK_VWD 0x1 |
375 | | #define OP_SH_VWD 26 |
376 | | |
377 | | #define OP_MASK_XTHEADVLMUL 0x3 |
378 | | #define OP_SH_XTHEADVLMUL 0 |
379 | | #define OP_MASK_XTHEADVSEW 0x7 |
380 | | #define OP_SH_XTHEADVSEW 2 |
381 | | #define OP_MASK_XTHEADVEDIV 0x3 |
382 | | #define OP_SH_XTHEADVEDIV 5 |
383 | | #define OP_MASK_XTHEADVTYPE_RES 0xf |
384 | | #define OP_SH_XTHEADVTYPE_RES 7 |
385 | | |
386 | | /* Zc fields. */ |
387 | | #define OP_MASK_REG_LIST 0xf |
388 | | #define OP_SH_REG_LIST 4 |
389 | 0 | #define ZCMP_SP_ALIGNMENT 16 |
390 | | #define OP_MASK_SREG1 0x7 |
391 | | #define OP_SH_SREG1 7 |
392 | | #define OP_MASK_SREG2 0x7 |
393 | | #define OP_SH_SREG2 2 |
394 | | |
395 | | #define NVECR 32 |
396 | | #define NVECM 1 |
397 | | |
398 | | /* SiFive fields. */ |
399 | | #define OP_MASK_XSO2 0x3 |
400 | | #define OP_SH_XSO2 26 |
401 | | #define OP_MASK_XSO1 0x1 |
402 | | #define OP_SH_XSO1 26 |
403 | | |
404 | | /* MIPS fields. */ |
405 | | #define OP_MASK_MIPS_IMM9 0x1ff |
406 | | #define OP_SH_MIPS_IMM9 20 |
407 | | #define OP_MASK_MIPS_HINT 0x1f |
408 | | #define OP_SH_MIPS_HINT 7 |
409 | | #define OP_MASK_MIPS_LWP_OFFSET 0x1f |
410 | | #define OP_SH_MIPS_LWP_OFFSET 22 |
411 | | #define OP_MASK_MIPS_LDP_OFFSET 0xf |
412 | | #define OP_SH_MIPS_LDP_OFFSET 23 |
413 | | #define OP_MASK_MIPS_SWP_OFFSET9 0x7 |
414 | | #define OP_SH_MIPS_SWP_OFFSET9 9 |
415 | | #define OP_MASK_MIPS_SWP_OFFSET25 0x3 |
416 | | #define OP_SH_MIPS_SWP_OFFSET25 25 |
417 | | #define OP_MASK_MIPS_SDP_OFFSET10 0x3 |
418 | | #define OP_SH_MIPS_SDP_OFFSET10 10 |
419 | | #define OP_MASK_MIPS_SDP_OFFSET25 0x3 |
420 | | #define OP_SH_MIPS_SDP_OFFSET25 25 |
421 | | |
422 | | /* ABI names for selected x-registers. */ |
423 | | |
424 | 0 | #define X_RA 1 |
425 | 285k | #define X_SP 2 |
426 | 132k | #define X_GP 3 |
427 | 132k | #define X_TP 4 |
428 | | #define X_T0 5 |
429 | | #define X_T1 6 |
430 | | #define X_T2 7 |
431 | 0 | #define X_S0 8 |
432 | 0 | #define X_S1 9 |
433 | | #define X_A0 10 |
434 | | #define X_A1 11 |
435 | 0 | #define X_S2 18 |
436 | | #define X_S7 23 |
437 | | #define X_S10 26 |
438 | 0 | #define X_S11 27 |
439 | | #define X_T3 28 |
440 | | |
441 | | #define NGPR 32 |
442 | | #define NFPR 32 |
443 | | |
444 | | /* These fake label defines are use by both the assembler, and |
445 | | libopcodes. The assembler uses this when it needs to generate a fake |
446 | | label, and libopcodes uses it to hide the fake labels in its output. */ |
447 | 0 | #define RISCV_FAKE_LABEL_NAME ".L0 " |
448 | | #define RISCV_FAKE_LABEL_CHAR ' ' |
449 | | |
450 | | /* Replace bits MASK << SHIFT of STRUCT with the equivalent bits in |
451 | | VALUE << SHIFT. VALUE is evaluated exactly once. */ |
452 | | #define INSERT_BITS(STRUCT, VALUE, MASK, SHIFT) \ |
453 | | (STRUCT) = (((STRUCT) & ~((insn_t)(MASK) << (SHIFT))) \ |
454 | | | ((insn_t)((VALUE) & (MASK)) << (SHIFT))) |
455 | | |
456 | | /* Extract bits MASK << SHIFT from STRUCT and shift them right |
457 | | SHIFT places. */ |
458 | | #define EXTRACT_BITS(STRUCT, MASK, SHIFT) \ |
459 | 797k | (((STRUCT) >> (SHIFT)) & (MASK)) |
460 | | |
461 | | /* Extract the operand given by FIELD from integer INSN. */ |
462 | | #define EXTRACT_OPERAND(FIELD, INSN) \ |
463 | 797k | ((unsigned int) EXTRACT_BITS ((INSN), OP_MASK_##FIELD, OP_SH_##FIELD)) |
464 | | |
465 | | /* Extract an unsigned immediate operand on position s with n bits. */ |
466 | | #define EXTRACT_U_IMM(n, s, l) \ |
467 | 0 | RV_X (l, s, n) |
468 | | |
469 | | /* Extract an signed immediate operand on position s with n bits. */ |
470 | | #define EXTRACT_S_IMM(n, s, l) \ |
471 | 0 | RV_X_SIGNED (l, s, n) |
472 | | |
473 | | /* Validate that unsigned n-bit immediate is within bounds. */ |
474 | | #define VALIDATE_U_IMM(v, n) \ |
475 | | ((unsigned long) v < (1UL << n)) |
476 | | |
477 | | /* Validate that signed n-bit immediate is within bounds. */ |
478 | | #define VALIDATE_S_IMM(v, n) \ |
479 | | (v < (long) (1UL << (n-1)) && v >= -(offsetT) (1UL << (n-1))) |
480 | | |
481 | | /* The maximal number of subset can be required. */ |
482 | | #define MAX_SUBSET_NUM 4 |
483 | | |
484 | | /* The range of sregs. */ |
485 | | #define RISCV_SREG_0_7(REGNO) \ |
486 | | ((REGNO == X_S0 || REGNO == X_S1) \ |
487 | | || (REGNO >= X_S2 && REGNO <= X_S7)) |
488 | | |
489 | | /* All RISC-V instructions belong to at least one of these classes. */ |
490 | | enum riscv_insn_class |
491 | | { |
492 | | INSN_CLASS_NONE, |
493 | | |
494 | | INSN_CLASS_I, |
495 | | INSN_CLASS_C, |
496 | | INSN_CLASS_M, |
497 | | INSN_CLASS_F, |
498 | | INSN_CLASS_D, |
499 | | INSN_CLASS_Q, |
500 | | INSN_CLASS_F_AND_C, |
501 | | INSN_CLASS_D_AND_C, |
502 | | INSN_CLASS_ZICOND, |
503 | | INSN_CLASS_ZICSR, |
504 | | INSN_CLASS_ZIFENCEI, |
505 | | INSN_CLASS_ZIHINTNTL, |
506 | | INSN_CLASS_ZIHINTNTL_AND_C, |
507 | | INSN_CLASS_ZIHINTPAUSE, |
508 | | INSN_CLASS_ZIMOP, |
509 | | INSN_CLASS_ZMMUL, |
510 | | INSN_CLASS_ZAAMO, |
511 | | INSN_CLASS_ZALRSC, |
512 | | INSN_CLASS_ZAWRS, |
513 | | INSN_CLASS_F_INX, |
514 | | INSN_CLASS_D_INX, |
515 | | INSN_CLASS_Q_INX, |
516 | | INSN_CLASS_ZFH_INX, |
517 | | INSN_CLASS_ZFHMIN, |
518 | | INSN_CLASS_ZFHMIN_INX, |
519 | | INSN_CLASS_ZFHMIN_AND_D_INX, |
520 | | INSN_CLASS_ZFHMIN_AND_Q_INX, |
521 | | INSN_CLASS_ZFBFMIN, |
522 | | INSN_CLASS_ZFA, |
523 | | INSN_CLASS_D_AND_ZFA, |
524 | | INSN_CLASS_Q_AND_ZFA, |
525 | | INSN_CLASS_ZFH_AND_ZFA, |
526 | | INSN_CLASS_ZFH_OR_ZVFH_AND_ZFA, |
527 | | INSN_CLASS_ZBA, |
528 | | INSN_CLASS_ZBB, |
529 | | INSN_CLASS_ZBC, |
530 | | INSN_CLASS_ZBS, |
531 | | INSN_CLASS_ZBKB, |
532 | | INSN_CLASS_ZBKC, |
533 | | INSN_CLASS_ZBKX, |
534 | | INSN_CLASS_ZKND, |
535 | | INSN_CLASS_ZKNE, |
536 | | INSN_CLASS_ZKNH, |
537 | | INSN_CLASS_ZKSED, |
538 | | INSN_CLASS_ZKSH, |
539 | | INSN_CLASS_ZBB_OR_ZBKB, |
540 | | INSN_CLASS_ZBC_OR_ZBKC, |
541 | | INSN_CLASS_ZKND_OR_ZKNE, |
542 | | INSN_CLASS_V, |
543 | | INSN_CLASS_ZVEF, |
544 | | INSN_CLASS_ZVBB, |
545 | | INSN_CLASS_ZVBC, |
546 | | INSN_CLASS_ZVFBFMIN, |
547 | | INSN_CLASS_ZVFBFWMA, |
548 | | INSN_CLASS_ZVKB, |
549 | | INSN_CLASS_ZVKG, |
550 | | INSN_CLASS_ZVKNED, |
551 | | INSN_CLASS_ZVKNHA_OR_ZVKNHB, |
552 | | INSN_CLASS_ZVKSED, |
553 | | INSN_CLASS_ZVKSH, |
554 | | INSN_CLASS_ZICFISS, |
555 | | INSN_CLASS_ZICFISS_AND_ZCMOP, |
556 | | INSN_CLASS_ZICFILP, |
557 | | INSN_CLASS_ZCB, |
558 | | INSN_CLASS_ZCB_AND_ZBA, |
559 | | INSN_CLASS_ZCB_AND_ZBB, |
560 | | INSN_CLASS_ZCB_AND_ZMMUL, |
561 | | INSN_CLASS_ZCMOP, |
562 | | INSN_CLASS_ZCMP, |
563 | | INSN_CLASS_ZCMT, |
564 | | INSN_CLASS_SMCTR_OR_SSCTR, |
565 | | INSN_CLASS_ZILSD, |
566 | | INSN_CLASS_ZCLSD, |
567 | | INSN_CLASS_SMRNMI, |
568 | | INSN_CLASS_SVINVAL, |
569 | | INSN_CLASS_ZICBOM, |
570 | | INSN_CLASS_ZICBOP, |
571 | | INSN_CLASS_ZICBOZ, |
572 | | INSN_CLASS_ZABHA, |
573 | | INSN_CLASS_ZACAS, |
574 | | INSN_CLASS_ZABHA_AND_ZACAS, |
575 | | INSN_CLASS_H, |
576 | | INSN_CLASS_XCVALU, |
577 | | INSN_CLASS_XCVBI, |
578 | | INSN_CLASS_XCVBITMANIP, |
579 | | INSN_CLASS_XCVELW, |
580 | | INSN_CLASS_XCVMAC, |
581 | | INSN_CLASS_XCVMEM, |
582 | | INSN_CLASS_XCVSIMD, |
583 | | INSN_CLASS_XTHEADBA, |
584 | | INSN_CLASS_XTHEADBB, |
585 | | INSN_CLASS_XTHEADBS, |
586 | | INSN_CLASS_XTHEADCMO, |
587 | | INSN_CLASS_XTHEADCONDMOV, |
588 | | INSN_CLASS_XTHEADFMEMIDX, |
589 | | INSN_CLASS_XTHEADFMV, |
590 | | INSN_CLASS_XTHEADINT, |
591 | | INSN_CLASS_XTHEADMAC, |
592 | | INSN_CLASS_XTHEADMEMIDX, |
593 | | INSN_CLASS_XTHEADMEMPAIR, |
594 | | INSN_CLASS_XTHEADSYNC, |
595 | | INSN_CLASS_XTHEADVECTOR, |
596 | | INSN_CLASS_XTHEADVDOT, |
597 | | INSN_CLASS_XTHEADZVAMO, |
598 | | INSN_CLASS_XVENTANACONDOPS, |
599 | | INSN_CLASS_XSFVCP, |
600 | | INSN_CLASS_XSFCEASE, |
601 | | INSN_CLASS_XSFVQMACCQOQ, |
602 | | INSN_CLASS_XSFVQMACCDOD, |
603 | | INSN_CLASS_XSFVFNRCLIPXFQF, |
604 | | INSN_CLASS_XMIPSCBOP, |
605 | | INSN_CLASS_XMIPSCMOV, |
606 | | INSN_CLASS_XMIPSEXECTL, |
607 | | INSN_CLASS_XMIPSLSP, |
608 | | }; |
609 | | |
610 | | /* This structure holds information for a particular instruction. */ |
611 | | struct riscv_opcode |
612 | | { |
613 | | /* The name of the instruction. */ |
614 | | const char *name; |
615 | | |
616 | | /* The requirement of xlen for the instruction, 0 if no requirement. */ |
617 | | unsigned xlen_requirement; |
618 | | |
619 | | /* Class to which this instruction belongs. Used to decide whether or |
620 | | not this instruction is legal in the current -march context. */ |
621 | | enum riscv_insn_class insn_class; |
622 | | |
623 | | /* A string describing the arguments for this instruction. */ |
624 | | const char *args; |
625 | | |
626 | | /* The basic opcode for the instruction. When assembling, this |
627 | | opcode is modified by the arguments to produce the actual opcode |
628 | | that is used. If pinfo is INSN_MACRO, then this is 0. */ |
629 | | insn_t match; |
630 | | |
631 | | /* If pinfo is not INSN_MACRO, then this is a bit mask for the |
632 | | relevant portions of the opcode when disassembling. If the |
633 | | actual opcode anded with the match field equals the opcode field, |
634 | | then we have found the correct instruction. If pinfo is |
635 | | INSN_MACRO, then this field is the macro identifier. */ |
636 | | insn_t mask; |
637 | | |
638 | | /* A function to determine if a word corresponds to this instruction. |
639 | | Usually, this computes ((word & mask) == match). */ |
640 | | int (*match_func) (const struct riscv_opcode *op, insn_t word); |
641 | | |
642 | | /* For a macro, this is INSN_MACRO. Otherwise, it is a collection |
643 | | of bits describing the instruction, notably any relevant hazard |
644 | | information. */ |
645 | | unsigned long pinfo; |
646 | | }; |
647 | | |
648 | | /* Instruction is a simple alias (e.g. "mv" for "addi"). */ |
649 | 0 | #define INSN_ALIAS 0x00000001 |
650 | | |
651 | | /* These are for setting insn_info fields. |
652 | | |
653 | | Nonbranch is the default. Noninsn is used only if there is no match. |
654 | | There are no condjsr or dref2 instructions. So that leaves condbranch, |
655 | | branch, jsr, and dref that we need to handle here, encoded in 3 bits. */ |
656 | 1.09M | #define INSN_TYPE 0x0000000e |
657 | | |
658 | | /* Instruction is an unconditional branch. */ |
659 | 21.5k | #define INSN_BRANCH 0x00000002 |
660 | | /* Instruction is a conditional branch. */ |
661 | 51.8k | #define INSN_CONDBRANCH 0x00000004 |
662 | | /* Instruction is a jump to subroutine. */ |
663 | 16.3k | #define INSN_JSR 0x00000006 |
664 | | /* Instruction is a data reference. */ |
665 | 391k | #define INSN_DREF 0x00000008 |
666 | | /* Instruction is allowed when eew >= 64. */ |
667 | | #define INSN_V_EEW64 0x10000000 |
668 | | |
669 | | /* We have 5 data reference sizes, which we can encode in 3 bits. */ |
670 | 1.49M | #define INSN_DATA_SIZE 0x00000070 |
671 | 391k | #define INSN_DATA_SIZE_SHIFT 4 |
672 | | #define INSN_1_BYTE 0x00000010 |
673 | | #define INSN_2_BYTE 0x00000020 |
674 | | #define INSN_4_BYTE 0x00000030 |
675 | | #define INSN_8_BYTE 0x00000040 |
676 | | #define INSN_16_BYTE 0x00000050 |
677 | | |
678 | | /* Instruction is actually a macro. It should be ignored by the |
679 | | disassembler, and requires special treatment by the assembler. */ |
680 | 811M | #define INSN_MACRO 0xffffffff |
681 | | |
682 | | /* This is a list of macro expanded instructions. */ |
683 | | enum |
684 | | { |
685 | | M_LA, |
686 | | M_LLA, |
687 | | M_LGA, |
688 | | M_LA_TLS_GD, |
689 | | M_LA_TLS_IE, |
690 | | M_Lx, |
691 | | M_FLx, |
692 | | M_Sx_FSx, |
693 | | M_CALL, |
694 | | M_LI, |
695 | | M_EXTH, |
696 | | M_ZEXTW, |
697 | | M_SEXTB, |
698 | | M_VMSGE, |
699 | | M_NUM_MACROS |
700 | | }; |
701 | | |
702 | | /* The mapping symbol states. */ |
703 | | enum riscv_seg_mstate |
704 | | { |
705 | | MAP_NONE = 0, /* Must be zero, for seginfo in new sections. */ |
706 | | MAP_DATA, /* Data. */ |
707 | | MAP_INSN, /* Instructions. */ |
708 | | }; |
709 | | |
710 | | #define NRC (4 + 1) /* Max characters in register names, incl nul. */ |
711 | | |
712 | | extern const char riscv_gpr_names_numeric[NGPR][NRC]; |
713 | | extern const char riscv_gpr_names_abi[NGPR][NRC]; |
714 | | extern const char riscv_fpr_names_numeric[NFPR][NRC]; |
715 | | extern const char riscv_fpr_names_abi[NFPR][NRC]; |
716 | | extern const char * const riscv_rm[8]; |
717 | | extern const char * const riscv_pred_succ[16]; |
718 | | extern const char riscv_vecr_names_numeric[NVECR][NRC]; |
719 | | extern const char riscv_vecm_names_numeric[NVECM][NRC]; |
720 | | extern const char * const riscv_vsew[8]; |
721 | | extern const char * const riscv_vlmul[8]; |
722 | | extern const char * const riscv_vta[2]; |
723 | | extern const char * const riscv_vma[2]; |
724 | | extern const char * const riscv_th_vlen[4]; |
725 | | extern const char * const riscv_th_vediv[4]; |
726 | | extern const char * const riscv_fli_symval[32]; |
727 | | extern const float riscv_fli_numval[32]; |
728 | | |
729 | | extern const struct riscv_opcode riscv_opcodes[]; |
730 | | extern const struct riscv_opcode riscv_insn_types[]; |
731 | | |
732 | | extern unsigned int riscv_get_sp_base (insn_t, unsigned int); |
733 | | |
734 | | #endif /* _RISCV_H_ */ |