]> Git Repo - qemu.git/blame - target/loongarch/insns.decode
target/loongarch: Add floating point comparison instruction translation
[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
SG
12%sa2p1 15:2 !function=plus_1
13
14#
15# Argument sets
16#
bb79174d 17&i imm
143d6785 18&r_i rd imm
ad08cb3f 19&rr rd rj
8708a04a 20&rr_jk rj rk
143d6785
SG
21&rrr rd rj rk
22&rr_i rd rj imm
bb79174d 23&hint_r_i hint rj imm
143d6785 24&rrr_sa rd rj rk sa
ad08cb3f 25&rr_ms_ls rd rj ms ls
d578ca6c
SG
26&ff fd fj
27&fff fd fj fk
28&ffff fd fj fk fa
9b741076 29&cff_fcond cd fj fk fcond
143d6785
SG
30
31#
32# Formats
33#
bb79174d 34@i15 .... ........ ..... imm:15 &i
ad08cb3f 35@rr .... ........ ..... ..... rj:5 rd:5 &rr
8708a04a 36@rr_jk .... ........ ..... rk:5 rj:5 ..... &rr_jk
143d6785
SG
37@rrr .... ........ ..... rk:5 rj:5 rd:5 &rrr
38@r_i20 .... ... imm:s20 rd:5 &r_i
63cfcd47
SG
39@rr_ui5 .... ........ ..... imm:5 rj:5 rd:5 &rr_i
40@rr_ui6 .... ........ .... imm:6 rj:5 rd:5 &rr_i
143d6785
SG
41@rr_i12 .... ...... imm:s12 rj:5 rd:5 &rr_i
42@rr_ui12 .... ...... imm:12 rj:5 rd:5 &rr_i
bb79174d 43@rr_i14s2 .... .... .............. rj:5 rd:5 &rr_i imm=%i14s2
143d6785 44@rr_i16 .... .. imm:s16 rj:5 rd:5 &rr_i
bb79174d 45@hint_r_i12 .... ...... imm:s12 rj:5 hint:5 &hint_r_i
143d6785 46@rrr_sa2p1 .... ........ ... .. rk:5 rj:5 rd:5 &rrr_sa sa=%sa2p1
ad08cb3f
SG
47@rrr_sa2 .... ........ ... sa:2 rk:5 rj:5 rd:5 &rrr_sa
48@rrr_sa3 .... ........ .. sa:3 rk:5 rj:5 rd:5 &rrr_sa
49@rr_2bw .... ....... ms:5 . ls:5 rj:5 rd:5 &rr_ms_ls
50@rr_2bd .... ...... ms:6 ls:6 rj:5 rd:5 &rr_ms_ls
d578ca6c
SG
51@ff .... ........ ..... ..... fj:5 fd:5 &ff
52@fff .... ........ ..... fk:5 fj:5 fd:5 &fff
53@ffff .... ........ fa:5 fk:5 fj:5 fd:5 &ffff
9b741076 54@cff_fcond .... ........ fcond:5 fk:5 fj:5 .. cd:3 &cff_fcond
143d6785
SG
55
56#
57# Fixed point arithmetic operation instruction
58#
59add_w 0000 00000001 00000 ..... ..... ..... @rrr
60add_d 0000 00000001 00001 ..... ..... ..... @rrr
61sub_w 0000 00000001 00010 ..... ..... ..... @rrr
62sub_d 0000 00000001 00011 ..... ..... ..... @rrr
63slt 0000 00000001 00100 ..... ..... ..... @rrr
64sltu 0000 00000001 00101 ..... ..... ..... @rrr
65slti 0000 001000 ............ ..... ..... @rr_i12
66sltui 0000 001001 ............ ..... ..... @rr_i12
67nor 0000 00000001 01000 ..... ..... ..... @rrr
68and 0000 00000001 01001 ..... ..... ..... @rrr
69or 0000 00000001 01010 ..... ..... ..... @rrr
70xor 0000 00000001 01011 ..... ..... ..... @rrr
71orn 0000 00000001 01100 ..... ..... ..... @rrr
72andn 0000 00000001 01101 ..... ..... ..... @rrr
73mul_w 0000 00000001 11000 ..... ..... ..... @rrr
74mulh_w 0000 00000001 11001 ..... ..... ..... @rrr
75mulh_wu 0000 00000001 11010 ..... ..... ..... @rrr
76mul_d 0000 00000001 11011 ..... ..... ..... @rrr
77mulh_d 0000 00000001 11100 ..... ..... ..... @rrr
78mulh_du 0000 00000001 11101 ..... ..... ..... @rrr
79mulw_d_w 0000 00000001 11110 ..... ..... ..... @rrr
80mulw_d_wu 0000 00000001 11111 ..... ..... ..... @rrr
81div_w 0000 00000010 00000 ..... ..... ..... @rrr
82mod_w 0000 00000010 00001 ..... ..... ..... @rrr
83div_wu 0000 00000010 00010 ..... ..... ..... @rrr
84mod_wu 0000 00000010 00011 ..... ..... ..... @rrr
85div_d 0000 00000010 00100 ..... ..... ..... @rrr
86mod_d 0000 00000010 00101 ..... ..... ..... @rrr
87div_du 0000 00000010 00110 ..... ..... ..... @rrr
88mod_du 0000 00000010 00111 ..... ..... ..... @rrr
89alsl_w 0000 00000000 010 .. ..... ..... ..... @rrr_sa2p1
90alsl_wu 0000 00000000 011 .. ..... ..... ..... @rrr_sa2p1
91alsl_d 0000 00000010 110 .. ..... ..... ..... @rrr_sa2p1
92lu12i_w 0001 010 .................... ..... @r_i20
93lu32i_d 0001 011 .................... ..... @r_i20
94lu52i_d 0000 001100 ............ ..... ..... @rr_i12
95pcaddi 0001 100 .................... ..... @r_i20
96pcalau12i 0001 101 .................... ..... @r_i20
97pcaddu12i 0001 110 .................... ..... @r_i20
98pcaddu18i 0001 111 .................... ..... @r_i20
99addi_w 0000 001010 ............ ..... ..... @rr_i12
100addi_d 0000 001011 ............ ..... ..... @rr_i12
101addu16i_d 0001 00 ................ ..... ..... @rr_i16
102andi 0000 001101 ............ ..... ..... @rr_ui12
103ori 0000 001110 ............ ..... ..... @rr_ui12
104xori 0000 001111 ............ ..... ..... @rr_ui12
63cfcd47
SG
105
106#
107# Fixed point shift operation instruction
108#
109sll_w 0000 00000001 01110 ..... ..... ..... @rrr
110srl_w 0000 00000001 01111 ..... ..... ..... @rrr
111sra_w 0000 00000001 10000 ..... ..... ..... @rrr
112sll_d 0000 00000001 10001 ..... ..... ..... @rrr
113srl_d 0000 00000001 10010 ..... ..... ..... @rrr
114sra_d 0000 00000001 10011 ..... ..... ..... @rrr
115rotr_w 0000 00000001 10110 ..... ..... ..... @rrr
116rotr_d 0000 00000001 10111 ..... ..... ..... @rrr
117slli_w 0000 00000100 00001 ..... ..... ..... @rr_ui5
118slli_d 0000 00000100 0001 ...... ..... ..... @rr_ui6
119srli_w 0000 00000100 01001 ..... ..... ..... @rr_ui5
120srli_d 0000 00000100 0101 ...... ..... ..... @rr_ui6
121srai_w 0000 00000100 10001 ..... ..... ..... @rr_ui5
122srai_d 0000 00000100 1001 ...... ..... ..... @rr_ui6
123rotri_w 0000 00000100 11001 ..... ..... ..... @rr_ui5
124rotri_d 0000 00000100 1101 ...... ..... ..... @rr_ui6
ad08cb3f
SG
125
126#
127# Fixed point bit operation instruction
128#
129ext_w_h 0000 00000000 00000 10110 ..... ..... @rr
130ext_w_b 0000 00000000 00000 10111 ..... ..... @rr
131clo_w 0000 00000000 00000 00100 ..... ..... @rr
132clz_w 0000 00000000 00000 00101 ..... ..... @rr
133cto_w 0000 00000000 00000 00110 ..... ..... @rr
134ctz_w 0000 00000000 00000 00111 ..... ..... @rr
135clo_d 0000 00000000 00000 01000 ..... ..... @rr
136clz_d 0000 00000000 00000 01001 ..... ..... @rr
137cto_d 0000 00000000 00000 01010 ..... ..... @rr
138ctz_d 0000 00000000 00000 01011 ..... ..... @rr
139revb_2h 0000 00000000 00000 01100 ..... ..... @rr
140revb_4h 0000 00000000 00000 01101 ..... ..... @rr
141revb_2w 0000 00000000 00000 01110 ..... ..... @rr
142revb_d 0000 00000000 00000 01111 ..... ..... @rr
143revh_2w 0000 00000000 00000 10000 ..... ..... @rr
144revh_d 0000 00000000 00000 10001 ..... ..... @rr
145bitrev_4b 0000 00000000 00000 10010 ..... ..... @rr
146bitrev_8b 0000 00000000 00000 10011 ..... ..... @rr
147bitrev_w 0000 00000000 00000 10100 ..... ..... @rr
148bitrev_d 0000 00000000 00000 10101 ..... ..... @rr
149bytepick_w 0000 00000000 100 .. ..... ..... ..... @rrr_sa2
150bytepick_d 0000 00000000 11 ... ..... ..... ..... @rrr_sa3
151maskeqz 0000 00000001 00110 ..... ..... ..... @rrr
152masknez 0000 00000001 00111 ..... ..... ..... @rrr
153bstrins_w 0000 0000011 ..... 0 ..... ..... ..... @rr_2bw
154bstrpick_w 0000 0000011 ..... 1 ..... ..... ..... @rr_2bw
155bstrins_d 0000 000010 ...... ...... ..... ..... @rr_2bd
156bstrpick_d 0000 000011 ...... ...... ..... ..... @rr_2bd
bb79174d
SG
157
158#
159# Fixed point load/store instruction
160#
161ld_b 0010 100000 ............ ..... ..... @rr_i12
162ld_h 0010 100001 ............ ..... ..... @rr_i12
163ld_w 0010 100010 ............ ..... ..... @rr_i12
164ld_d 0010 100011 ............ ..... ..... @rr_i12
165st_b 0010 100100 ............ ..... ..... @rr_i12
166st_h 0010 100101 ............ ..... ..... @rr_i12
167st_w 0010 100110 ............ ..... ..... @rr_i12
168st_d 0010 100111 ............ ..... ..... @rr_i12
169ld_bu 0010 101000 ............ ..... ..... @rr_i12
170ld_hu 0010 101001 ............ ..... ..... @rr_i12
171ld_wu 0010 101010 ............ ..... ..... @rr_i12
172ldx_b 0011 10000000 00000 ..... ..... ..... @rrr
173ldx_h 0011 10000000 01000 ..... ..... ..... @rrr
174ldx_w 0011 10000000 10000 ..... ..... ..... @rrr
175ldx_d 0011 10000000 11000 ..... ..... ..... @rrr
176stx_b 0011 10000001 00000 ..... ..... ..... @rrr
177stx_h 0011 10000001 01000 ..... ..... ..... @rrr
178stx_w 0011 10000001 10000 ..... ..... ..... @rrr
179stx_d 0011 10000001 11000 ..... ..... ..... @rrr
180ldx_bu 0011 10000010 00000 ..... ..... ..... @rrr
181ldx_hu 0011 10000010 01000 ..... ..... ..... @rrr
182ldx_wu 0011 10000010 10000 ..... ..... ..... @rrr
183preld 0010 101011 ............ ..... ..... @hint_r_i12
184dbar 0011 10000111 00100 ............... @i15
185ibar 0011 10000111 00101 ............... @i15
186ldptr_w 0010 0100 .............. ..... ..... @rr_i14s2
187stptr_w 0010 0101 .............. ..... ..... @rr_i14s2
188ldptr_d 0010 0110 .............. ..... ..... @rr_i14s2
189stptr_d 0010 0111 .............. ..... ..... @rr_i14s2
190ldgt_b 0011 10000111 10000 ..... ..... ..... @rrr
191ldgt_h 0011 10000111 10001 ..... ..... ..... @rrr
192ldgt_w 0011 10000111 10010 ..... ..... ..... @rrr
193ldgt_d 0011 10000111 10011 ..... ..... ..... @rrr
194ldle_b 0011 10000111 10100 ..... ..... ..... @rrr
195ldle_h 0011 10000111 10101 ..... ..... ..... @rrr
196ldle_w 0011 10000111 10110 ..... ..... ..... @rrr
197ldle_d 0011 10000111 10111 ..... ..... ..... @rrr
198stgt_b 0011 10000111 11000 ..... ..... ..... @rrr
199stgt_h 0011 10000111 11001 ..... ..... ..... @rrr
200stgt_w 0011 10000111 11010 ..... ..... ..... @rrr
201stgt_d 0011 10000111 11011 ..... ..... ..... @rrr
202stle_b 0011 10000111 11100 ..... ..... ..... @rrr
203stle_h 0011 10000111 11101 ..... ..... ..... @rrr
204stle_w 0011 10000111 11110 ..... ..... ..... @rrr
205stle_d 0011 10000111 11111 ..... ..... ..... @rrr
94b02d57
SG
206
207#
208# Fixed point atomic instruction
209#
210ll_w 0010 0000 .............. ..... ..... @rr_i14s2
211sc_w 0010 0001 .............. ..... ..... @rr_i14s2
212ll_d 0010 0010 .............. ..... ..... @rr_i14s2
213sc_d 0010 0011 .............. ..... ..... @rr_i14s2
214amswap_w 0011 10000110 00000 ..... ..... ..... @rrr
215amswap_d 0011 10000110 00001 ..... ..... ..... @rrr
216amadd_w 0011 10000110 00010 ..... ..... ..... @rrr
217amadd_d 0011 10000110 00011 ..... ..... ..... @rrr
218amand_w 0011 10000110 00100 ..... ..... ..... @rrr
219amand_d 0011 10000110 00101 ..... ..... ..... @rrr
220amor_w 0011 10000110 00110 ..... ..... ..... @rrr
221amor_d 0011 10000110 00111 ..... ..... ..... @rrr
222amxor_w 0011 10000110 01000 ..... ..... ..... @rrr
223amxor_d 0011 10000110 01001 ..... ..... ..... @rrr
224ammax_w 0011 10000110 01010 ..... ..... ..... @rrr
225ammax_d 0011 10000110 01011 ..... ..... ..... @rrr
226ammin_w 0011 10000110 01100 ..... ..... ..... @rrr
227ammin_d 0011 10000110 01101 ..... ..... ..... @rrr
228ammax_wu 0011 10000110 01110 ..... ..... ..... @rrr
229ammax_du 0011 10000110 01111 ..... ..... ..... @rrr
230ammin_wu 0011 10000110 10000 ..... ..... ..... @rrr
231ammin_du 0011 10000110 10001 ..... ..... ..... @rrr
232amswap_db_w 0011 10000110 10010 ..... ..... ..... @rrr
233amswap_db_d 0011 10000110 10011 ..... ..... ..... @rrr
234amadd_db_w 0011 10000110 10100 ..... ..... ..... @rrr
235amadd_db_d 0011 10000110 10101 ..... ..... ..... @rrr
236amand_db_w 0011 10000110 10110 ..... ..... ..... @rrr
237amand_db_d 0011 10000110 10111 ..... ..... ..... @rrr
238amor_db_w 0011 10000110 11000 ..... ..... ..... @rrr
239amor_db_d 0011 10000110 11001 ..... ..... ..... @rrr
240amxor_db_w 0011 10000110 11010 ..... ..... ..... @rrr
241amxor_db_d 0011 10000110 11011 ..... ..... ..... @rrr
242ammax_db_w 0011 10000110 11100 ..... ..... ..... @rrr
243ammax_db_d 0011 10000110 11101 ..... ..... ..... @rrr
244ammin_db_w 0011 10000110 11110 ..... ..... ..... @rrr
245ammin_db_d 0011 10000110 11111 ..... ..... ..... @rrr
246ammax_db_wu 0011 10000111 00000 ..... ..... ..... @rrr
247ammax_db_du 0011 10000111 00001 ..... ..... ..... @rrr
248ammin_db_wu 0011 10000111 00010 ..... ..... ..... @rrr
249ammin_db_du 0011 10000111 00011 ..... ..... ..... @rrr
8708a04a
SG
250
251#
252# Fixed point extra instruction
253#
254crc_w_b_w 0000 00000010 01000 ..... ..... ..... @rrr
255crc_w_h_w 0000 00000010 01001 ..... ..... ..... @rrr
256crc_w_w_w 0000 00000010 01010 ..... ..... ..... @rrr
257crc_w_d_w 0000 00000010 01011 ..... ..... ..... @rrr
258crcc_w_b_w 0000 00000010 01100 ..... ..... ..... @rrr
259crcc_w_h_w 0000 00000010 01101 ..... ..... ..... @rrr
260crcc_w_w_w 0000 00000010 01110 ..... ..... ..... @rrr
261crcc_w_d_w 0000 00000010 01111 ..... ..... ..... @rrr
262break 0000 00000010 10100 ............... @i15
263syscall 0000 00000010 10110 ............... @i15
264asrtle_d 0000 00000000 00010 ..... ..... 00000 @rr_jk
265asrtgt_d 0000 00000000 00011 ..... ..... 00000 @rr_jk
266cpucfg 0000 00000000 00000 11011 ..... ..... @rr
d578ca6c
SG
267
268#
269# Floating point arithmetic operation instruction
270#
271fadd_s 0000 00010000 00001 ..... ..... ..... @fff
272fadd_d 0000 00010000 00010 ..... ..... ..... @fff
273fsub_s 0000 00010000 00101 ..... ..... ..... @fff
274fsub_d 0000 00010000 00110 ..... ..... ..... @fff
275fmul_s 0000 00010000 01001 ..... ..... ..... @fff
276fmul_d 0000 00010000 01010 ..... ..... ..... @fff
277fdiv_s 0000 00010000 01101 ..... ..... ..... @fff
278fdiv_d 0000 00010000 01110 ..... ..... ..... @fff
279fmadd_s 0000 10000001 ..... ..... ..... ..... @ffff
280fmadd_d 0000 10000010 ..... ..... ..... ..... @ffff
281fmsub_s 0000 10000101 ..... ..... ..... ..... @ffff
282fmsub_d 0000 10000110 ..... ..... ..... ..... @ffff
283fnmadd_s 0000 10001001 ..... ..... ..... ..... @ffff
284fnmadd_d 0000 10001010 ..... ..... ..... ..... @ffff
285fnmsub_s 0000 10001101 ..... ..... ..... ..... @ffff
286fnmsub_d 0000 10001110 ..... ..... ..... ..... @ffff
287fmax_s 0000 00010000 10001 ..... ..... ..... @fff
288fmax_d 0000 00010000 10010 ..... ..... ..... @fff
289fmin_s 0000 00010000 10101 ..... ..... ..... @fff
290fmin_d 0000 00010000 10110 ..... ..... ..... @fff
291fmaxa_s 0000 00010000 11001 ..... ..... ..... @fff
292fmaxa_d 0000 00010000 11010 ..... ..... ..... @fff
293fmina_s 0000 00010000 11101 ..... ..... ..... @fff
294fmina_d 0000 00010000 11110 ..... ..... ..... @fff
295fabs_s 0000 00010001 01000 00001 ..... ..... @ff
296fabs_d 0000 00010001 01000 00010 ..... ..... @ff
297fneg_s 0000 00010001 01000 00101 ..... ..... @ff
298fneg_d 0000 00010001 01000 00110 ..... ..... @ff
299fsqrt_s 0000 00010001 01000 10001 ..... ..... @ff
300fsqrt_d 0000 00010001 01000 10010 ..... ..... @ff
301frecip_s 0000 00010001 01000 10101 ..... ..... @ff
302frecip_d 0000 00010001 01000 10110 ..... ..... @ff
303frsqrt_s 0000 00010001 01000 11001 ..... ..... @ff
304frsqrt_d 0000 00010001 01000 11010 ..... ..... @ff
305fscaleb_s 0000 00010001 00001 ..... ..... ..... @fff
306fscaleb_d 0000 00010001 00010 ..... ..... ..... @fff
307flogb_s 0000 00010001 01000 01001 ..... ..... @ff
308flogb_d 0000 00010001 01000 01010 ..... ..... @ff
309fcopysign_s 0000 00010001 00101 ..... ..... ..... @fff
310fcopysign_d 0000 00010001 00110 ..... ..... ..... @fff
311fclass_s 0000 00010001 01000 01101 ..... ..... @ff
312fclass_d 0000 00010001 01000 01110 ..... ..... @ff
9b741076
SG
313
314#
315# Floating point compare instruction
316#
317fcmp_cond_s 0000 11000001 ..... ..... ..... 00 ... @cff_fcond
318fcmp_cond_d 0000 11000010 ..... ..... ..... 00 ... @cff_fcond
This page took 0.055812 seconds and 4 git commands to generate.