]> Git Repo - qemu.git/blame - target/loongarch/insns.decode
target/loongarch: Add fixed point extra 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
143d6785
SG
26
27#
28# Formats
29#
bb79174d 30@i15 .... ........ ..... imm:15 &i
ad08cb3f 31@rr .... ........ ..... ..... rj:5 rd:5 &rr
8708a04a 32@rr_jk .... ........ ..... rk:5 rj:5 ..... &rr_jk
143d6785
SG
33@rrr .... ........ ..... rk:5 rj:5 rd:5 &rrr
34@r_i20 .... ... imm:s20 rd:5 &r_i
63cfcd47
SG
35@rr_ui5 .... ........ ..... imm:5 rj:5 rd:5 &rr_i
36@rr_ui6 .... ........ .... imm:6 rj:5 rd:5 &rr_i
143d6785
SG
37@rr_i12 .... ...... imm:s12 rj:5 rd:5 &rr_i
38@rr_ui12 .... ...... imm:12 rj:5 rd:5 &rr_i
bb79174d 39@rr_i14s2 .... .... .............. rj:5 rd:5 &rr_i imm=%i14s2
143d6785 40@rr_i16 .... .. imm:s16 rj:5 rd:5 &rr_i
bb79174d 41@hint_r_i12 .... ...... imm:s12 rj:5 hint:5 &hint_r_i
143d6785 42@rrr_sa2p1 .... ........ ... .. rk:5 rj:5 rd:5 &rrr_sa sa=%sa2p1
ad08cb3f
SG
43@rrr_sa2 .... ........ ... sa:2 rk:5 rj:5 rd:5 &rrr_sa
44@rrr_sa3 .... ........ .. sa:3 rk:5 rj:5 rd:5 &rrr_sa
45@rr_2bw .... ....... ms:5 . ls:5 rj:5 rd:5 &rr_ms_ls
46@rr_2bd .... ...... ms:6 ls:6 rj:5 rd:5 &rr_ms_ls
143d6785
SG
47
48#
49# Fixed point arithmetic operation instruction
50#
51add_w 0000 00000001 00000 ..... ..... ..... @rrr
52add_d 0000 00000001 00001 ..... ..... ..... @rrr
53sub_w 0000 00000001 00010 ..... ..... ..... @rrr
54sub_d 0000 00000001 00011 ..... ..... ..... @rrr
55slt 0000 00000001 00100 ..... ..... ..... @rrr
56sltu 0000 00000001 00101 ..... ..... ..... @rrr
57slti 0000 001000 ............ ..... ..... @rr_i12
58sltui 0000 001001 ............ ..... ..... @rr_i12
59nor 0000 00000001 01000 ..... ..... ..... @rrr
60and 0000 00000001 01001 ..... ..... ..... @rrr
61or 0000 00000001 01010 ..... ..... ..... @rrr
62xor 0000 00000001 01011 ..... ..... ..... @rrr
63orn 0000 00000001 01100 ..... ..... ..... @rrr
64andn 0000 00000001 01101 ..... ..... ..... @rrr
65mul_w 0000 00000001 11000 ..... ..... ..... @rrr
66mulh_w 0000 00000001 11001 ..... ..... ..... @rrr
67mulh_wu 0000 00000001 11010 ..... ..... ..... @rrr
68mul_d 0000 00000001 11011 ..... ..... ..... @rrr
69mulh_d 0000 00000001 11100 ..... ..... ..... @rrr
70mulh_du 0000 00000001 11101 ..... ..... ..... @rrr
71mulw_d_w 0000 00000001 11110 ..... ..... ..... @rrr
72mulw_d_wu 0000 00000001 11111 ..... ..... ..... @rrr
73div_w 0000 00000010 00000 ..... ..... ..... @rrr
74mod_w 0000 00000010 00001 ..... ..... ..... @rrr
75div_wu 0000 00000010 00010 ..... ..... ..... @rrr
76mod_wu 0000 00000010 00011 ..... ..... ..... @rrr
77div_d 0000 00000010 00100 ..... ..... ..... @rrr
78mod_d 0000 00000010 00101 ..... ..... ..... @rrr
79div_du 0000 00000010 00110 ..... ..... ..... @rrr
80mod_du 0000 00000010 00111 ..... ..... ..... @rrr
81alsl_w 0000 00000000 010 .. ..... ..... ..... @rrr_sa2p1
82alsl_wu 0000 00000000 011 .. ..... ..... ..... @rrr_sa2p1
83alsl_d 0000 00000010 110 .. ..... ..... ..... @rrr_sa2p1
84lu12i_w 0001 010 .................... ..... @r_i20
85lu32i_d 0001 011 .................... ..... @r_i20
86lu52i_d 0000 001100 ............ ..... ..... @rr_i12
87pcaddi 0001 100 .................... ..... @r_i20
88pcalau12i 0001 101 .................... ..... @r_i20
89pcaddu12i 0001 110 .................... ..... @r_i20
90pcaddu18i 0001 111 .................... ..... @r_i20
91addi_w 0000 001010 ............ ..... ..... @rr_i12
92addi_d 0000 001011 ............ ..... ..... @rr_i12
93addu16i_d 0001 00 ................ ..... ..... @rr_i16
94andi 0000 001101 ............ ..... ..... @rr_ui12
95ori 0000 001110 ............ ..... ..... @rr_ui12
96xori 0000 001111 ............ ..... ..... @rr_ui12
63cfcd47
SG
97
98#
99# Fixed point shift operation instruction
100#
101sll_w 0000 00000001 01110 ..... ..... ..... @rrr
102srl_w 0000 00000001 01111 ..... ..... ..... @rrr
103sra_w 0000 00000001 10000 ..... ..... ..... @rrr
104sll_d 0000 00000001 10001 ..... ..... ..... @rrr
105srl_d 0000 00000001 10010 ..... ..... ..... @rrr
106sra_d 0000 00000001 10011 ..... ..... ..... @rrr
107rotr_w 0000 00000001 10110 ..... ..... ..... @rrr
108rotr_d 0000 00000001 10111 ..... ..... ..... @rrr
109slli_w 0000 00000100 00001 ..... ..... ..... @rr_ui5
110slli_d 0000 00000100 0001 ...... ..... ..... @rr_ui6
111srli_w 0000 00000100 01001 ..... ..... ..... @rr_ui5
112srli_d 0000 00000100 0101 ...... ..... ..... @rr_ui6
113srai_w 0000 00000100 10001 ..... ..... ..... @rr_ui5
114srai_d 0000 00000100 1001 ...... ..... ..... @rr_ui6
115rotri_w 0000 00000100 11001 ..... ..... ..... @rr_ui5
116rotri_d 0000 00000100 1101 ...... ..... ..... @rr_ui6
ad08cb3f
SG
117
118#
119# Fixed point bit operation instruction
120#
121ext_w_h 0000 00000000 00000 10110 ..... ..... @rr
122ext_w_b 0000 00000000 00000 10111 ..... ..... @rr
123clo_w 0000 00000000 00000 00100 ..... ..... @rr
124clz_w 0000 00000000 00000 00101 ..... ..... @rr
125cto_w 0000 00000000 00000 00110 ..... ..... @rr
126ctz_w 0000 00000000 00000 00111 ..... ..... @rr
127clo_d 0000 00000000 00000 01000 ..... ..... @rr
128clz_d 0000 00000000 00000 01001 ..... ..... @rr
129cto_d 0000 00000000 00000 01010 ..... ..... @rr
130ctz_d 0000 00000000 00000 01011 ..... ..... @rr
131revb_2h 0000 00000000 00000 01100 ..... ..... @rr
132revb_4h 0000 00000000 00000 01101 ..... ..... @rr
133revb_2w 0000 00000000 00000 01110 ..... ..... @rr
134revb_d 0000 00000000 00000 01111 ..... ..... @rr
135revh_2w 0000 00000000 00000 10000 ..... ..... @rr
136revh_d 0000 00000000 00000 10001 ..... ..... @rr
137bitrev_4b 0000 00000000 00000 10010 ..... ..... @rr
138bitrev_8b 0000 00000000 00000 10011 ..... ..... @rr
139bitrev_w 0000 00000000 00000 10100 ..... ..... @rr
140bitrev_d 0000 00000000 00000 10101 ..... ..... @rr
141bytepick_w 0000 00000000 100 .. ..... ..... ..... @rrr_sa2
142bytepick_d 0000 00000000 11 ... ..... ..... ..... @rrr_sa3
143maskeqz 0000 00000001 00110 ..... ..... ..... @rrr
144masknez 0000 00000001 00111 ..... ..... ..... @rrr
145bstrins_w 0000 0000011 ..... 0 ..... ..... ..... @rr_2bw
146bstrpick_w 0000 0000011 ..... 1 ..... ..... ..... @rr_2bw
147bstrins_d 0000 000010 ...... ...... ..... ..... @rr_2bd
148bstrpick_d 0000 000011 ...... ...... ..... ..... @rr_2bd
bb79174d
SG
149
150#
151# Fixed point load/store instruction
152#
153ld_b 0010 100000 ............ ..... ..... @rr_i12
154ld_h 0010 100001 ............ ..... ..... @rr_i12
155ld_w 0010 100010 ............ ..... ..... @rr_i12
156ld_d 0010 100011 ............ ..... ..... @rr_i12
157st_b 0010 100100 ............ ..... ..... @rr_i12
158st_h 0010 100101 ............ ..... ..... @rr_i12
159st_w 0010 100110 ............ ..... ..... @rr_i12
160st_d 0010 100111 ............ ..... ..... @rr_i12
161ld_bu 0010 101000 ............ ..... ..... @rr_i12
162ld_hu 0010 101001 ............ ..... ..... @rr_i12
163ld_wu 0010 101010 ............ ..... ..... @rr_i12
164ldx_b 0011 10000000 00000 ..... ..... ..... @rrr
165ldx_h 0011 10000000 01000 ..... ..... ..... @rrr
166ldx_w 0011 10000000 10000 ..... ..... ..... @rrr
167ldx_d 0011 10000000 11000 ..... ..... ..... @rrr
168stx_b 0011 10000001 00000 ..... ..... ..... @rrr
169stx_h 0011 10000001 01000 ..... ..... ..... @rrr
170stx_w 0011 10000001 10000 ..... ..... ..... @rrr
171stx_d 0011 10000001 11000 ..... ..... ..... @rrr
172ldx_bu 0011 10000010 00000 ..... ..... ..... @rrr
173ldx_hu 0011 10000010 01000 ..... ..... ..... @rrr
174ldx_wu 0011 10000010 10000 ..... ..... ..... @rrr
175preld 0010 101011 ............ ..... ..... @hint_r_i12
176dbar 0011 10000111 00100 ............... @i15
177ibar 0011 10000111 00101 ............... @i15
178ldptr_w 0010 0100 .............. ..... ..... @rr_i14s2
179stptr_w 0010 0101 .............. ..... ..... @rr_i14s2
180ldptr_d 0010 0110 .............. ..... ..... @rr_i14s2
181stptr_d 0010 0111 .............. ..... ..... @rr_i14s2
182ldgt_b 0011 10000111 10000 ..... ..... ..... @rrr
183ldgt_h 0011 10000111 10001 ..... ..... ..... @rrr
184ldgt_w 0011 10000111 10010 ..... ..... ..... @rrr
185ldgt_d 0011 10000111 10011 ..... ..... ..... @rrr
186ldle_b 0011 10000111 10100 ..... ..... ..... @rrr
187ldle_h 0011 10000111 10101 ..... ..... ..... @rrr
188ldle_w 0011 10000111 10110 ..... ..... ..... @rrr
189ldle_d 0011 10000111 10111 ..... ..... ..... @rrr
190stgt_b 0011 10000111 11000 ..... ..... ..... @rrr
191stgt_h 0011 10000111 11001 ..... ..... ..... @rrr
192stgt_w 0011 10000111 11010 ..... ..... ..... @rrr
193stgt_d 0011 10000111 11011 ..... ..... ..... @rrr
194stle_b 0011 10000111 11100 ..... ..... ..... @rrr
195stle_h 0011 10000111 11101 ..... ..... ..... @rrr
196stle_w 0011 10000111 11110 ..... ..... ..... @rrr
197stle_d 0011 10000111 11111 ..... ..... ..... @rrr
94b02d57
SG
198
199#
200# Fixed point atomic instruction
201#
202ll_w 0010 0000 .............. ..... ..... @rr_i14s2
203sc_w 0010 0001 .............. ..... ..... @rr_i14s2
204ll_d 0010 0010 .............. ..... ..... @rr_i14s2
205sc_d 0010 0011 .............. ..... ..... @rr_i14s2
206amswap_w 0011 10000110 00000 ..... ..... ..... @rrr
207amswap_d 0011 10000110 00001 ..... ..... ..... @rrr
208amadd_w 0011 10000110 00010 ..... ..... ..... @rrr
209amadd_d 0011 10000110 00011 ..... ..... ..... @rrr
210amand_w 0011 10000110 00100 ..... ..... ..... @rrr
211amand_d 0011 10000110 00101 ..... ..... ..... @rrr
212amor_w 0011 10000110 00110 ..... ..... ..... @rrr
213amor_d 0011 10000110 00111 ..... ..... ..... @rrr
214amxor_w 0011 10000110 01000 ..... ..... ..... @rrr
215amxor_d 0011 10000110 01001 ..... ..... ..... @rrr
216ammax_w 0011 10000110 01010 ..... ..... ..... @rrr
217ammax_d 0011 10000110 01011 ..... ..... ..... @rrr
218ammin_w 0011 10000110 01100 ..... ..... ..... @rrr
219ammin_d 0011 10000110 01101 ..... ..... ..... @rrr
220ammax_wu 0011 10000110 01110 ..... ..... ..... @rrr
221ammax_du 0011 10000110 01111 ..... ..... ..... @rrr
222ammin_wu 0011 10000110 10000 ..... ..... ..... @rrr
223ammin_du 0011 10000110 10001 ..... ..... ..... @rrr
224amswap_db_w 0011 10000110 10010 ..... ..... ..... @rrr
225amswap_db_d 0011 10000110 10011 ..... ..... ..... @rrr
226amadd_db_w 0011 10000110 10100 ..... ..... ..... @rrr
227amadd_db_d 0011 10000110 10101 ..... ..... ..... @rrr
228amand_db_w 0011 10000110 10110 ..... ..... ..... @rrr
229amand_db_d 0011 10000110 10111 ..... ..... ..... @rrr
230amor_db_w 0011 10000110 11000 ..... ..... ..... @rrr
231amor_db_d 0011 10000110 11001 ..... ..... ..... @rrr
232amxor_db_w 0011 10000110 11010 ..... ..... ..... @rrr
233amxor_db_d 0011 10000110 11011 ..... ..... ..... @rrr
234ammax_db_w 0011 10000110 11100 ..... ..... ..... @rrr
235ammax_db_d 0011 10000110 11101 ..... ..... ..... @rrr
236ammin_db_w 0011 10000110 11110 ..... ..... ..... @rrr
237ammin_db_d 0011 10000110 11111 ..... ..... ..... @rrr
238ammax_db_wu 0011 10000111 00000 ..... ..... ..... @rrr
239ammax_db_du 0011 10000111 00001 ..... ..... ..... @rrr
240ammin_db_wu 0011 10000111 00010 ..... ..... ..... @rrr
241ammin_db_du 0011 10000111 00011 ..... ..... ..... @rrr
8708a04a
SG
242
243#
244# Fixed point extra instruction
245#
246crc_w_b_w 0000 00000010 01000 ..... ..... ..... @rrr
247crc_w_h_w 0000 00000010 01001 ..... ..... ..... @rrr
248crc_w_w_w 0000 00000010 01010 ..... ..... ..... @rrr
249crc_w_d_w 0000 00000010 01011 ..... ..... ..... @rrr
250crcc_w_b_w 0000 00000010 01100 ..... ..... ..... @rrr
251crcc_w_h_w 0000 00000010 01101 ..... ..... ..... @rrr
252crcc_w_w_w 0000 00000010 01110 ..... ..... ..... @rrr
253crcc_w_d_w 0000 00000010 01111 ..... ..... ..... @rrr
254break 0000 00000010 10100 ............... @i15
255syscall 0000 00000010 10110 ............... @i15
256asrtle_d 0000 00000000 00010 ..... ..... 00000 @rr_jk
257asrtgt_d 0000 00000000 00011 ..... ..... 00000 @rr_jk
258cpucfg 0000 00000000 00000 11011 ..... ..... @rr
This page took 0.049961 seconds and 4 git commands to generate.