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