]> Git Repo - qemu.git/blame - target/loongarch/insns.decode
target/loongarch: Add timer related instructions support.
[qemu.git] / target / loongarch / insns.decode
CommitLineData
143d6785
SG
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#
bb79174d 11%i14s2 10:s14 !function=shl_2
143d6785 12%sa2p1 15:2 !function=plus_1
ee86bd58
SG
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
143d6785
SG
16
17#
18# Argument sets
19#
bb79174d 20&i imm
143d6785 21&r_i rd imm
ad08cb3f 22&rr rd rj
8708a04a 23&rr_jk rj rk
143d6785
SG
24&rrr rd rj rk
25&rr_i rd rj imm
bb79174d 26&hint_r_i hint rj imm
143d6785 27&rrr_sa rd rj rk sa
ad08cb3f 28&rr_ms_ls rd rj ms ls
d578ca6c
SG
29&ff fd fj
30&fff fd fj fk
31&ffff fd fj fk fa
9b741076 32&cff_fcond cd fj fk fcond
b7dabd56
SG
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
e616bdfd
SG
42&frr fd rj rk
43&fr_i fd rj imm
ee86bd58
SG
44&r_offs rj offs
45&c_offs cj offs
46&offs offs
47&rr_offs rj rd offs
5b1dedfe
XY
48&r_csr rd csr
49&rr_csr rd rj csr
fcbbeb8e
XY
50&empty
51&i_rr imm rj rk
d2cba6f7
XY
52&cop_r_i cop rj imm
53&j_i rj imm
143d6785
SG
54
55#
56# Formats
57#
bb79174d 58@i15 .... ........ ..... imm:15 &i
ad08cb3f 59@rr .... ........ ..... ..... rj:5 rd:5 &rr
8708a04a 60@rr_jk .... ........ ..... rk:5 rj:5 ..... &rr_jk
143d6785
SG
61@rrr .... ........ ..... rk:5 rj:5 rd:5 &rrr
62@r_i20 .... ... imm:s20 rd:5 &r_i
63cfcd47
SG
63@rr_ui5 .... ........ ..... imm:5 rj:5 rd:5 &rr_i
64@rr_ui6 .... ........ .... imm:6 rj:5 rd:5 &rr_i
d2cba6f7 65@rr_ui8 .. ........ .... imm:8 rj:5 rd:5 &rr_i
143d6785
SG
66@rr_i12 .... ...... imm:s12 rj:5 rd:5 &rr_i
67@rr_ui12 .... ...... imm:12 rj:5 rd:5 &rr_i
bb79174d 68@rr_i14s2 .... .... .............. rj:5 rd:5 &rr_i imm=%i14s2
143d6785 69@rr_i16 .... .. imm:s16 rj:5 rd:5 &rr_i
bb79174d 70@hint_r_i12 .... ...... imm:s12 rj:5 hint:5 &hint_r_i
143d6785 71@rrr_sa2p1 .... ........ ... .. rk:5 rj:5 rd:5 &rrr_sa sa=%sa2p1
ad08cb3f
SG
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
d578ca6c
SG
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
9b741076 79@cff_fcond .... ........ fcond:5 fk:5 fj:5 .. cd:3 &cff_fcond
b7dabd56
SG
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
e616bdfd
SG
89@frr .... ........ ..... rk:5 rj:5 fd:5 &frr
90@fr_i12 .... ...... imm:s12 rj:5 fd:5 &fr_i
ee86bd58
SG
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
5b1dedfe
XY
95@r_csr .... .... csr:14 ..... rd:5 &r_csr
96@rr_csr .... .... csr:14 rj:5 rd:5 &rr_csr
fcbbeb8e
XY
97@empty .... ........ ..... ..... ..... ..... &empty
98@i_rr ...... ...... ..... rk:5 rj:5 imm:5 &i_rr
d2cba6f7
XY
99@cop_r_i .... ...... imm:s12 rj:5 cop:5 &cop_r_i
100@j_i .... ........ .. imm:8 rj:5 ..... &j_i
143d6785
SG
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
63cfcd47
SG
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
ad08cb3f
SG
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
bb79174d
SG
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
94b02d57
SG
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
8708a04a
SG
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
f9bf5074
XY
312rdtimel_w 0000 00000000 00000 11000 ..... ..... @rr
313rdtimeh_w 0000 00000000 00000 11001 ..... ..... @rr
314rdtime_d 0000 00000000 00000 11010 ..... ..... @rr
8708a04a 315cpucfg 0000 00000000 00000 11011 ..... ..... @rr
d578ca6c
SG
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
9b741076
SG
362
363#
364# Floating point compare instruction
365#
366fcmp_cond_s 0000 11000001 ..... ..... ..... 00 ... @cff_fcond
367fcmp_cond_d 0000 11000010 ..... ..... ..... 00 ... @cff_fcond
7c1f8870
SG
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
b7dabd56
SG
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
e616bdfd
SG
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
ee86bd58
SG
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
5b1dedfe
XY
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}
f84a2aac
XY
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
fcbbeb8e
XY
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
d2cba6f7
XY
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
This page took 0.077171 seconds and 4 git commands to generate.