]> Git Repo - qemu.git/blob - target/loongarch/insns.decode
target/loongarch: Add LoongArch IOCSR instruction
[qemu.git] / target / loongarch / insns.decode
1 # SPDX-License-Identifier: GPL-2.0-or-later
2 #
3 # LoongArch instruction decode definitions.
4 #
5 # Copyright (c) 2021 Loongson Technology Corporation Limited
6 #
7
8 #
9 # Fields
10 #
11 %i14s2     10:s14       !function=shl_2
12 %sa2p1     15:2         !function=plus_1
13 %offs21    0:s5 10:16   !function=shl_2
14 %offs16    10:s16       !function=shl_2
15 %offs26    0:s10 10:16  !function=shl_2
16
17 #
18 # Argument sets
19 #
20 &i            imm
21 &r_i          rd imm
22 &rr           rd rj
23 &rr_jk        rj rk
24 &rrr          rd rj rk
25 &rr_i         rd rj imm
26 &hint_r_i     hint rj imm
27 &rrr_sa       rd rj rk sa
28 &rr_ms_ls     rd rj ms ls
29 &ff           fd fj
30 &fff          fd fj fk
31 &ffff         fd fj fk fa
32 &cff_fcond    cd fj fk fcond
33 &fffc         fd fj fk ca
34 &fr           fd rj
35 &rf           rd fj
36 &fcsrd_r      fcsrd rj
37 &r_fcsrs      rd fcsrs
38 &cf           cd fj
39 &fc           fd cj
40 &cr           cd rj
41 &rc           rd cj
42 &frr          fd rj rk
43 &fr_i         fd rj imm
44 &r_offs       rj offs
45 &c_offs       cj offs
46 &offs         offs
47 &rr_offs      rj rd offs
48 &r_csr        rd csr
49 &rr_csr       rd rj csr
50
51 #
52 # Formats
53 #
54 @i15                       .... ........ ..... imm:15    &i
55 @rr               .... ........ ..... ..... rj:5 rd:5    &rr
56 @rr_jk            .... ........ ..... rk:5 rj:5 .....    &rr_jk
57 @rrr               .... ........ ..... rk:5 rj:5 rd:5    &rrr
58 @r_i20                          .... ... imm:s20 rd:5    &r_i
59 @rr_ui5           .... ........ ..... imm:5 rj:5 rd:5    &rr_i
60 @rr_ui6            .... ........ .... imm:6 rj:5 rd:5    &rr_i
61 @rr_i12                 .... ...... imm:s12 rj:5 rd:5    &rr_i
62 @rr_ui12                 .... ...... imm:12 rj:5 rd:5    &rr_i
63 @rr_i14s2         .... ....  .............. rj:5 rd:5    &rr_i imm=%i14s2
64 @rr_i16                     .... .. imm:s16 rj:5 rd:5    &rr_i
65 @hint_r_i12           .... ...... imm:s12 rj:5 hint:5    &hint_r_i
66 @rrr_sa2p1        .... ........ ... .. rk:5 rj:5 rd:5    &rrr_sa  sa=%sa2p1
67 @rrr_sa2        .... ........ ... sa:2 rk:5 rj:5 rd:5    &rrr_sa
68 @rrr_sa3         .... ........ .. sa:3 rk:5 rj:5 rd:5    &rrr_sa
69 @rr_2bw            .... ....... ms:5 . ls:5 rj:5 rd:5    &rr_ms_ls
70 @rr_2bd               .... ...... ms:6 ls:6 rj:5 rd:5    &rr_ms_ls
71 @ff               .... ........ ..... ..... fj:5 fd:5    &ff
72 @fff               .... ........ ..... fk:5 fj:5 fd:5    &fff
73 @ffff               .... ........ fa:5 fk:5 fj:5 fd:5    &ffff
74 @cff_fcond    .... ........ fcond:5 fk:5 fj:5 .. cd:3    &cff_fcond
75 @fffc            .... ........ .. ca:3 fk:5 fj:5 fd:5    &fffc
76 @fr               .... ........ ..... ..... rj:5 fd:5    &fr
77 @rf               .... ........ ..... ..... fj:5 rd:5    &rf
78 @fcsrd_r       .... ........ ..... ..... rj:5 fcsrd:5    &fcsrd_r
79 @r_fcsrs       .... ........ ..... ..... fcsrs:5 rd:5    &r_fcsrs
80 @cf            .... ........ ..... ..... fj:5 .. cd:3    &cf
81 @fc            .... ........ ..... ..... .. cj:3 fd:5    &fc
82 @cr            .... ........ ..... ..... rj:5 .. cd:3    &cr
83 @rc            .... ........ ..... ..... .. cj:3 rd:5    &rc
84 @frr               .... ........ ..... rk:5 rj:5 fd:5    &frr
85 @fr_i12                 .... ...... imm:s12 rj:5 fd:5    &fr_i
86 @r_offs21         .... .. ................ rj:5 .....    &r_offs      offs=%offs21
87 @c_offs21      .... .. ................ .. cj:3 .....    &c_offs      offs=%offs21
88 @offs26            .... .. ..........................    &offs        offs=%offs26
89 @rr_offs16         .... .. ................ rj:5 rd:5    &rr_offs     offs=%offs16
90 @r_csr                    .... .... csr:14 ..... rd:5    &r_csr
91 @rr_csr                    .... .... csr:14 rj:5 rd:5    &rr_csr
92
93 #
94 # Fixed point arithmetic operation instruction
95 #
96 add_w           0000 00000001 00000 ..... ..... .....    @rrr
97 add_d           0000 00000001 00001 ..... ..... .....    @rrr
98 sub_w           0000 00000001 00010 ..... ..... .....    @rrr
99 sub_d           0000 00000001 00011 ..... ..... .....    @rrr
100 slt             0000 00000001 00100 ..... ..... .....    @rrr
101 sltu            0000 00000001 00101 ..... ..... .....    @rrr
102 slti            0000 001000 ............ ..... .....     @rr_i12
103 sltui           0000 001001 ............ ..... .....     @rr_i12
104 nor             0000 00000001 01000 ..... ..... .....    @rrr
105 and             0000 00000001 01001 ..... ..... .....    @rrr
106 or              0000 00000001 01010 ..... ..... .....    @rrr
107 xor             0000 00000001 01011 ..... ..... .....    @rrr
108 orn             0000 00000001 01100 ..... ..... .....    @rrr
109 andn            0000 00000001 01101 ..... ..... .....    @rrr
110 mul_w           0000 00000001 11000 ..... ..... .....    @rrr
111 mulh_w          0000 00000001 11001 ..... ..... .....    @rrr
112 mulh_wu         0000 00000001 11010 ..... ..... .....    @rrr
113 mul_d           0000 00000001 11011 ..... ..... .....    @rrr
114 mulh_d          0000 00000001 11100 ..... ..... .....    @rrr
115 mulh_du         0000 00000001 11101 ..... ..... .....    @rrr
116 mulw_d_w        0000 00000001 11110 ..... ..... .....    @rrr
117 mulw_d_wu       0000 00000001 11111 ..... ..... .....    @rrr
118 div_w           0000 00000010 00000 ..... ..... .....    @rrr
119 mod_w           0000 00000010 00001 ..... ..... .....    @rrr
120 div_wu          0000 00000010 00010 ..... ..... .....    @rrr
121 mod_wu          0000 00000010 00011 ..... ..... .....    @rrr
122 div_d           0000 00000010 00100 ..... ..... .....    @rrr
123 mod_d           0000 00000010 00101 ..... ..... .....    @rrr
124 div_du          0000 00000010 00110 ..... ..... .....    @rrr
125 mod_du          0000 00000010 00111 ..... ..... .....    @rrr
126 alsl_w          0000 00000000 010 .. ..... ..... .....   @rrr_sa2p1
127 alsl_wu         0000 00000000 011 .. ..... ..... .....   @rrr_sa2p1
128 alsl_d          0000 00000010 110 .. ..... ..... .....   @rrr_sa2p1
129 lu12i_w         0001 010 .................... .....      @r_i20
130 lu32i_d         0001 011 .................... .....      @r_i20
131 lu52i_d         0000 001100 ............ ..... .....     @rr_i12
132 pcaddi          0001 100 .................... .....      @r_i20
133 pcalau12i       0001 101 .................... .....      @r_i20
134 pcaddu12i       0001 110 .................... .....      @r_i20
135 pcaddu18i       0001 111 .................... .....      @r_i20
136 addi_w          0000 001010 ............ ..... .....     @rr_i12
137 addi_d          0000 001011 ............ ..... .....     @rr_i12
138 addu16i_d       0001 00 ................ ..... .....     @rr_i16
139 andi            0000 001101 ............ ..... .....     @rr_ui12
140 ori             0000 001110 ............ ..... .....     @rr_ui12
141 xori            0000 001111 ............ ..... .....     @rr_ui12
142
143 #
144 # Fixed point shift operation instruction
145 #
146 sll_w           0000 00000001 01110 ..... ..... .....    @rrr
147 srl_w           0000 00000001 01111 ..... ..... .....    @rrr
148 sra_w           0000 00000001 10000 ..... ..... .....    @rrr
149 sll_d           0000 00000001 10001 ..... ..... .....    @rrr
150 srl_d           0000 00000001 10010 ..... ..... .....    @rrr
151 sra_d           0000 00000001 10011 ..... ..... .....    @rrr
152 rotr_w          0000 00000001 10110 ..... ..... .....    @rrr
153 rotr_d          0000 00000001 10111 ..... ..... .....    @rrr
154 slli_w          0000 00000100 00001 ..... ..... .....    @rr_ui5
155 slli_d          0000 00000100 0001 ...... ..... .....    @rr_ui6
156 srli_w          0000 00000100 01001 ..... ..... .....    @rr_ui5
157 srli_d          0000 00000100 0101 ...... ..... .....    @rr_ui6
158 srai_w          0000 00000100 10001 ..... ..... .....    @rr_ui5
159 srai_d          0000 00000100 1001 ...... ..... .....    @rr_ui6
160 rotri_w         0000 00000100 11001 ..... ..... .....    @rr_ui5
161 rotri_d         0000 00000100 1101 ...... ..... .....    @rr_ui6
162
163 #
164 # Fixed point bit operation instruction
165 #
166 ext_w_h         0000 00000000 00000 10110 ..... .....    @rr
167 ext_w_b         0000 00000000 00000 10111 ..... .....    @rr
168 clo_w           0000 00000000 00000 00100 ..... .....    @rr
169 clz_w           0000 00000000 00000 00101 ..... .....    @rr
170 cto_w           0000 00000000 00000 00110 ..... .....    @rr
171 ctz_w           0000 00000000 00000 00111 ..... .....    @rr
172 clo_d           0000 00000000 00000 01000 ..... .....    @rr
173 clz_d           0000 00000000 00000 01001 ..... .....    @rr
174 cto_d           0000 00000000 00000 01010 ..... .....    @rr
175 ctz_d           0000 00000000 00000 01011 ..... .....    @rr
176 revb_2h         0000 00000000 00000 01100 ..... .....    @rr
177 revb_4h         0000 00000000 00000 01101 ..... .....    @rr
178 revb_2w         0000 00000000 00000 01110 ..... .....    @rr
179 revb_d          0000 00000000 00000 01111 ..... .....    @rr
180 revh_2w         0000 00000000 00000 10000 ..... .....    @rr
181 revh_d          0000 00000000 00000 10001 ..... .....    @rr
182 bitrev_4b       0000 00000000 00000 10010 ..... .....    @rr
183 bitrev_8b       0000 00000000 00000 10011 ..... .....    @rr
184 bitrev_w        0000 00000000 00000 10100 ..... .....    @rr
185 bitrev_d        0000 00000000 00000 10101 ..... .....    @rr
186 bytepick_w      0000 00000000 100 .. ..... ..... .....   @rrr_sa2
187 bytepick_d      0000 00000000 11 ... ..... ..... .....   @rrr_sa3
188 maskeqz         0000 00000001 00110 ..... ..... .....    @rrr
189 masknez         0000 00000001 00111 ..... ..... .....    @rrr
190 bstrins_w       0000 0000011 ..... 0 ..... ..... .....   @rr_2bw
191 bstrpick_w      0000 0000011 ..... 1 ..... ..... .....   @rr_2bw
192 bstrins_d       0000 000010 ...... ...... ..... .....    @rr_2bd
193 bstrpick_d      0000 000011 ...... ...... ..... .....    @rr_2bd
194
195 #
196 # Fixed point load/store instruction
197 #
198 ld_b            0010 100000 ............ ..... .....     @rr_i12
199 ld_h            0010 100001 ............ ..... .....     @rr_i12
200 ld_w            0010 100010 ............ ..... .....     @rr_i12
201 ld_d            0010 100011 ............ ..... .....     @rr_i12
202 st_b            0010 100100 ............ ..... .....     @rr_i12
203 st_h            0010 100101 ............ ..... .....     @rr_i12
204 st_w            0010 100110 ............ ..... .....     @rr_i12
205 st_d            0010 100111 ............ ..... .....     @rr_i12
206 ld_bu           0010 101000 ............ ..... .....     @rr_i12
207 ld_hu           0010 101001 ............ ..... .....     @rr_i12
208 ld_wu           0010 101010 ............ ..... .....     @rr_i12
209 ldx_b           0011 10000000 00000 ..... ..... .....    @rrr
210 ldx_h           0011 10000000 01000 ..... ..... .....    @rrr
211 ldx_w           0011 10000000 10000 ..... ..... .....    @rrr
212 ldx_d           0011 10000000 11000 ..... ..... .....    @rrr
213 stx_b           0011 10000001 00000 ..... ..... .....    @rrr
214 stx_h           0011 10000001 01000 ..... ..... .....    @rrr
215 stx_w           0011 10000001 10000 ..... ..... .....    @rrr
216 stx_d           0011 10000001 11000 ..... ..... .....    @rrr
217 ldx_bu          0011 10000010 00000 ..... ..... .....    @rrr
218 ldx_hu          0011 10000010 01000 ..... ..... .....    @rrr
219 ldx_wu          0011 10000010 10000 ..... ..... .....    @rrr
220 preld           0010 101011 ............ ..... .....     @hint_r_i12
221 dbar            0011 10000111 00100 ...............      @i15
222 ibar            0011 10000111 00101 ...............      @i15
223 ldptr_w         0010 0100 .............. ..... .....     @rr_i14s2
224 stptr_w         0010 0101 .............. ..... .....     @rr_i14s2
225 ldptr_d         0010 0110 .............. ..... .....     @rr_i14s2
226 stptr_d         0010 0111 .............. ..... .....     @rr_i14s2
227 ldgt_b          0011 10000111 10000 ..... ..... .....    @rrr
228 ldgt_h          0011 10000111 10001 ..... ..... .....    @rrr
229 ldgt_w          0011 10000111 10010 ..... ..... .....    @rrr
230 ldgt_d          0011 10000111 10011 ..... ..... .....    @rrr
231 ldle_b          0011 10000111 10100 ..... ..... .....    @rrr
232 ldle_h          0011 10000111 10101 ..... ..... .....    @rrr
233 ldle_w          0011 10000111 10110 ..... ..... .....    @rrr
234 ldle_d          0011 10000111 10111 ..... ..... .....    @rrr
235 stgt_b          0011 10000111 11000 ..... ..... .....    @rrr
236 stgt_h          0011 10000111 11001 ..... ..... .....    @rrr
237 stgt_w          0011 10000111 11010 ..... ..... .....    @rrr
238 stgt_d          0011 10000111 11011 ..... ..... .....    @rrr
239 stle_b          0011 10000111 11100 ..... ..... .....    @rrr
240 stle_h          0011 10000111 11101 ..... ..... .....    @rrr
241 stle_w          0011 10000111 11110 ..... ..... .....    @rrr
242 stle_d          0011 10000111 11111 ..... ..... .....    @rrr
243
244 #
245 # Fixed point atomic instruction
246 #
247 ll_w            0010 0000 .............. ..... .....     @rr_i14s2
248 sc_w            0010 0001 .............. ..... .....     @rr_i14s2
249 ll_d            0010 0010 .............. ..... .....     @rr_i14s2
250 sc_d            0010 0011 .............. ..... .....     @rr_i14s2
251 amswap_w        0011 10000110 00000 ..... ..... .....    @rrr
252 amswap_d        0011 10000110 00001 ..... ..... .....    @rrr
253 amadd_w         0011 10000110 00010 ..... ..... .....    @rrr
254 amadd_d         0011 10000110 00011 ..... ..... .....    @rrr
255 amand_w         0011 10000110 00100 ..... ..... .....    @rrr
256 amand_d         0011 10000110 00101 ..... ..... .....    @rrr
257 amor_w          0011 10000110 00110 ..... ..... .....    @rrr
258 amor_d          0011 10000110 00111 ..... ..... .....    @rrr
259 amxor_w         0011 10000110 01000 ..... ..... .....    @rrr
260 amxor_d         0011 10000110 01001 ..... ..... .....    @rrr
261 ammax_w         0011 10000110 01010 ..... ..... .....    @rrr
262 ammax_d         0011 10000110 01011 ..... ..... .....    @rrr
263 ammin_w         0011 10000110 01100 ..... ..... .....    @rrr
264 ammin_d         0011 10000110 01101 ..... ..... .....    @rrr
265 ammax_wu        0011 10000110 01110 ..... ..... .....    @rrr
266 ammax_du        0011 10000110 01111 ..... ..... .....    @rrr
267 ammin_wu        0011 10000110 10000 ..... ..... .....    @rrr
268 ammin_du        0011 10000110 10001 ..... ..... .....    @rrr
269 amswap_db_w     0011 10000110 10010 ..... ..... .....    @rrr
270 amswap_db_d     0011 10000110 10011 ..... ..... .....    @rrr
271 amadd_db_w      0011 10000110 10100 ..... ..... .....    @rrr
272 amadd_db_d      0011 10000110 10101 ..... ..... .....    @rrr
273 amand_db_w      0011 10000110 10110 ..... ..... .....    @rrr
274 amand_db_d      0011 10000110 10111 ..... ..... .....    @rrr
275 amor_db_w       0011 10000110 11000 ..... ..... .....    @rrr
276 amor_db_d       0011 10000110 11001 ..... ..... .....    @rrr
277 amxor_db_w      0011 10000110 11010 ..... ..... .....    @rrr
278 amxor_db_d      0011 10000110 11011 ..... ..... .....    @rrr
279 ammax_db_w      0011 10000110 11100 ..... ..... .....    @rrr
280 ammax_db_d      0011 10000110 11101 ..... ..... .....    @rrr
281 ammin_db_w      0011 10000110 11110 ..... ..... .....    @rrr
282 ammin_db_d      0011 10000110 11111 ..... ..... .....    @rrr
283 ammax_db_wu     0011 10000111 00000 ..... ..... .....    @rrr
284 ammax_db_du     0011 10000111 00001 ..... ..... .....    @rrr
285 ammin_db_wu     0011 10000111 00010 ..... ..... .....    @rrr
286 ammin_db_du     0011 10000111 00011 ..... ..... .....    @rrr
287
288 #
289 # Fixed point extra instruction
290 #
291 crc_w_b_w       0000 00000010 01000 ..... ..... .....    @rrr
292 crc_w_h_w       0000 00000010 01001 ..... ..... .....    @rrr
293 crc_w_w_w       0000 00000010 01010 ..... ..... .....    @rrr
294 crc_w_d_w       0000 00000010 01011 ..... ..... .....    @rrr
295 crcc_w_b_w      0000 00000010 01100 ..... ..... .....    @rrr
296 crcc_w_h_w      0000 00000010 01101 ..... ..... .....    @rrr
297 crcc_w_w_w      0000 00000010 01110 ..... ..... .....    @rrr
298 crcc_w_d_w      0000 00000010 01111 ..... ..... .....    @rrr
299 break           0000 00000010 10100 ...............      @i15
300 syscall         0000 00000010 10110 ...............      @i15
301 asrtle_d        0000 00000000 00010 ..... ..... 00000    @rr_jk
302 asrtgt_d        0000 00000000 00011 ..... ..... 00000    @rr_jk
303 cpucfg          0000 00000000 00000 11011 ..... .....    @rr
304
305 #
306 # Floating point arithmetic operation instruction
307 #
308 fadd_s          0000 00010000 00001 ..... ..... .....    @fff
309 fadd_d          0000 00010000 00010 ..... ..... .....    @fff
310 fsub_s          0000 00010000 00101 ..... ..... .....    @fff
311 fsub_d          0000 00010000 00110 ..... ..... .....    @fff
312 fmul_s          0000 00010000 01001 ..... ..... .....    @fff
313 fmul_d          0000 00010000 01010 ..... ..... .....    @fff
314 fdiv_s          0000 00010000 01101 ..... ..... .....    @fff
315 fdiv_d          0000 00010000 01110 ..... ..... .....    @fff
316 fmadd_s         0000 10000001 ..... ..... ..... .....    @ffff
317 fmadd_d         0000 10000010 ..... ..... ..... .....    @ffff
318 fmsub_s         0000 10000101 ..... ..... ..... .....    @ffff
319 fmsub_d         0000 10000110 ..... ..... ..... .....    @ffff
320 fnmadd_s        0000 10001001 ..... ..... ..... .....    @ffff
321 fnmadd_d        0000 10001010 ..... ..... ..... .....    @ffff
322 fnmsub_s        0000 10001101 ..... ..... ..... .....    @ffff
323 fnmsub_d        0000 10001110 ..... ..... ..... .....    @ffff
324 fmax_s          0000 00010000 10001 ..... ..... .....    @fff
325 fmax_d          0000 00010000 10010 ..... ..... .....    @fff
326 fmin_s          0000 00010000 10101 ..... ..... .....    @fff
327 fmin_d          0000 00010000 10110 ..... ..... .....    @fff
328 fmaxa_s         0000 00010000 11001 ..... ..... .....    @fff
329 fmaxa_d         0000 00010000 11010 ..... ..... .....    @fff
330 fmina_s         0000 00010000 11101 ..... ..... .....    @fff
331 fmina_d         0000 00010000 11110 ..... ..... .....    @fff
332 fabs_s          0000 00010001 01000 00001 ..... .....    @ff
333 fabs_d          0000 00010001 01000 00010 ..... .....    @ff
334 fneg_s          0000 00010001 01000 00101 ..... .....    @ff
335 fneg_d          0000 00010001 01000 00110 ..... .....    @ff
336 fsqrt_s         0000 00010001 01000 10001 ..... .....    @ff
337 fsqrt_d         0000 00010001 01000 10010 ..... .....    @ff
338 frecip_s        0000 00010001 01000 10101 ..... .....    @ff
339 frecip_d        0000 00010001 01000 10110 ..... .....    @ff
340 frsqrt_s        0000 00010001 01000 11001 ..... .....    @ff
341 frsqrt_d        0000 00010001 01000 11010 ..... .....    @ff
342 fscaleb_s       0000 00010001 00001 ..... ..... .....    @fff
343 fscaleb_d       0000 00010001 00010 ..... ..... .....    @fff
344 flogb_s         0000 00010001 01000 01001 ..... .....    @ff
345 flogb_d         0000 00010001 01000 01010 ..... .....    @ff
346 fcopysign_s     0000 00010001 00101 ..... ..... .....    @fff
347 fcopysign_d     0000 00010001 00110 ..... ..... .....    @fff
348 fclass_s        0000 00010001 01000 01101 ..... .....    @ff
349 fclass_d        0000 00010001 01000 01110 ..... .....    @ff
350
351 #
352 # Floating point compare instruction
353 #
354 fcmp_cond_s     0000 11000001 ..... ..... ..... 00 ...   @cff_fcond
355 fcmp_cond_d     0000 11000010 ..... ..... ..... 00 ...   @cff_fcond
356
357 #
358 # Floating point conversion instruction
359 #
360 fcvt_s_d        0000 00010001 10010 00110 ..... .....    @ff
361 fcvt_d_s        0000 00010001 10010 01001 ..... .....    @ff
362 ftintrm_w_s     0000 00010001 10100 00001 ..... .....    @ff
363 ftintrm_w_d     0000 00010001 10100 00010 ..... .....    @ff
364 ftintrm_l_s     0000 00010001 10100 01001 ..... .....    @ff
365 ftintrm_l_d     0000 00010001 10100 01010 ..... .....    @ff
366 ftintrp_w_s     0000 00010001 10100 10001 ..... .....    @ff
367 ftintrp_w_d     0000 00010001 10100 10010 ..... .....    @ff
368 ftintrp_l_s     0000 00010001 10100 11001 ..... .....    @ff
369 ftintrp_l_d     0000 00010001 10100 11010 ..... .....    @ff
370 ftintrz_w_s     0000 00010001 10101 00001 ..... .....    @ff
371 ftintrz_w_d     0000 00010001 10101 00010 ..... .....    @ff
372 ftintrz_l_s     0000 00010001 10101 01001 ..... .....    @ff
373 ftintrz_l_d     0000 00010001 10101 01010 ..... .....    @ff
374 ftintrne_w_s    0000 00010001 10101 10001 ..... .....    @ff
375 ftintrne_w_d    0000 00010001 10101 10010 ..... .....    @ff
376 ftintrne_l_s    0000 00010001 10101 11001 ..... .....    @ff
377 ftintrne_l_d    0000 00010001 10101 11010 ..... .....    @ff
378 ftint_w_s       0000 00010001 10110 00001 ..... .....    @ff
379 ftint_w_d       0000 00010001 10110 00010 ..... .....    @ff
380 ftint_l_s       0000 00010001 10110 01001 ..... .....    @ff
381 ftint_l_d       0000 00010001 10110 01010 ..... .....    @ff
382 ffint_s_w       0000 00010001 11010 00100 ..... .....    @ff
383 ffint_s_l       0000 00010001 11010 00110 ..... .....    @ff
384 ffint_d_w       0000 00010001 11010 01000 ..... .....    @ff
385 ffint_d_l       0000 00010001 11010 01010 ..... .....    @ff
386 frint_s         0000 00010001 11100 10001 ..... .....    @ff
387 frint_d         0000 00010001 11100 10010 ..... .....    @ff
388
389 #
390 # Floating point move instruction
391 #
392 fmov_s          0000 00010001 01001 00101 ..... .....    @ff
393 fmov_d          0000 00010001 01001 00110 ..... .....    @ff
394 fsel            0000 11010000 00 ... ..... ..... .....   @fffc
395 movgr2fr_w      0000 00010001 01001 01001 ..... .....    @fr
396 movgr2fr_d      0000 00010001 01001 01010 ..... .....    @fr
397 movgr2frh_w     0000 00010001 01001 01011 ..... .....    @fr
398 movfr2gr_s      0000 00010001 01001 01101 ..... .....    @rf
399 movfr2gr_d      0000 00010001 01001 01110 ..... .....    @rf
400 movfrh2gr_s     0000 00010001 01001 01111 ..... .....    @rf
401 movgr2fcsr      0000 00010001 01001 10000 ..... .....    @fcsrd_r
402 movfcsr2gr      0000 00010001 01001 10010 ..... .....    @r_fcsrs
403 movfr2cf        0000 00010001 01001 10100 ..... 00 ...   @cf
404 movcf2fr        0000 00010001 01001 10101 00 ... .....   @fc
405 movgr2cf        0000 00010001 01001 10110 ..... 00 ...   @cr
406 movcf2gr        0000 00010001 01001 10111 00 ... .....   @rc
407
408 #
409 # Floating point load/store instruction
410 #
411 fld_s           0010 101100 ............ ..... .....     @fr_i12
412 fst_s           0010 101101 ............ ..... .....     @fr_i12
413 fld_d           0010 101110 ............ ..... .....     @fr_i12
414 fst_d           0010 101111 ............ ..... .....     @fr_i12
415 fldx_s          0011 10000011 00000 ..... ..... .....    @frr
416 fldx_d          0011 10000011 01000 ..... ..... .....    @frr
417 fstx_s          0011 10000011 10000 ..... ..... .....    @frr
418 fstx_d          0011 10000011 11000 ..... ..... .....    @frr
419 fldgt_s         0011 10000111 01000 ..... ..... .....    @frr
420 fldgt_d         0011 10000111 01001 ..... ..... .....    @frr
421 fldle_s         0011 10000111 01010 ..... ..... .....    @frr
422 fldle_d         0011 10000111 01011 ..... ..... .....    @frr
423 fstgt_s         0011 10000111 01100 ..... ..... .....    @frr
424 fstgt_d         0011 10000111 01101 ..... ..... .....    @frr
425 fstle_s         0011 10000111 01110 ..... ..... .....    @frr
426 fstle_d         0011 10000111 01111 ..... ..... .....    @frr
427
428 #
429 # Branch instructions
430 #
431 beqz            0100 00 ................ ..... .....     @r_offs21
432 bnez            0100 01 ................ ..... .....     @r_offs21
433 bceqz           0100 10 ................ 00 ... .....    @c_offs21
434 bcnez           0100 10 ................ 01 ... .....    @c_offs21
435 jirl            0100 11 ................ ..... .....     @rr_offs16
436 b               0101 00 ..........................       @offs26
437 bl              0101 01 ..........................       @offs26
438 beq             0101 10 ................ ..... .....     @rr_offs16
439 bne             0101 11 ................ ..... .....     @rr_offs16
440 blt             0110 00 ................ ..... .....     @rr_offs16
441 bge             0110 01 ................ ..... .....     @rr_offs16
442 bltu            0110 10 ................ ..... .....     @rr_offs16
443 bgeu            0110 11 ................ ..... .....     @rr_offs16
444
445 #
446 # Core instructions
447 #
448 {
449   csrrd             0000 0100 .............. 00000 .....     @r_csr
450   csrwr             0000 0100 .............. 00001 .....     @r_csr
451   csrxchg           0000 0100 .............. ..... .....     @rr_csr
452 }
453
454 iocsrrd_b        0000 01100100 10000 00000 ..... .....    @rr
455 iocsrrd_h        0000 01100100 10000 00001 ..... .....    @rr
456 iocsrrd_w        0000 01100100 10000 00010 ..... .....    @rr
457 iocsrrd_d        0000 01100100 10000 00011 ..... .....    @rr
458 iocsrwr_b        0000 01100100 10000 00100 ..... .....    @rr
459 iocsrwr_h        0000 01100100 10000 00101 ..... .....    @rr
460 iocsrwr_w        0000 01100100 10000 00110 ..... .....    @rr
461 iocsrwr_d        0000 01100100 10000 00111 ..... .....    @rr
This page took 0.050146 seconds and 4 git commands to generate.