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