# SPDX-License-Identifier: GPL-2.0-or-later # # LoongArch instruction decode definitions. # # Copyright (c) 2021 Loongson Technology Corporation Limited # # # Fields # %i14s2 10:s14 !function=shl_2 %sa2p1 15:2 !function=plus_1 # # Argument sets # &i imm &r_i rd imm &rr rd rj &rrr rd rj rk &rr_i rd rj imm &hint_r_i hint rj imm &rrr_sa rd rj rk sa &rr_ms_ls rd rj ms ls # # Formats # @i15 .... ........ ..... imm:15 &i @rr .... ........ ..... ..... rj:5 rd:5 &rr @rrr .... ........ ..... rk:5 rj:5 rd:5 &rrr @r_i20 .... ... imm:s20 rd:5 &r_i @rr_ui5 .... ........ ..... imm:5 rj:5 rd:5 &rr_i @rr_ui6 .... ........ .... imm:6 rj:5 rd:5 &rr_i @rr_i12 .... ...... imm:s12 rj:5 rd:5 &rr_i @rr_ui12 .... ...... imm:12 rj:5 rd:5 &rr_i @rr_i14s2 .... .... .............. rj:5 rd:5 &rr_i imm=%i14s2 @rr_i16 .... .. imm:s16 rj:5 rd:5 &rr_i @hint_r_i12 .... ...... imm:s12 rj:5 hint:5 &hint_r_i @rrr_sa2p1 .... ........ ... .. rk:5 rj:5 rd:5 &rrr_sa sa=%sa2p1 @rrr_sa2 .... ........ ... sa:2 rk:5 rj:5 rd:5 &rrr_sa @rrr_sa3 .... ........ .. sa:3 rk:5 rj:5 rd:5 &rrr_sa @rr_2bw .... ....... ms:5 . ls:5 rj:5 rd:5 &rr_ms_ls @rr_2bd .... ...... ms:6 ls:6 rj:5 rd:5 &rr_ms_ls # # Fixed point arithmetic operation instruction # add_w 0000 00000001 00000 ..... ..... ..... @rrr add_d 0000 00000001 00001 ..... ..... ..... @rrr sub_w 0000 00000001 00010 ..... ..... ..... @rrr sub_d 0000 00000001 00011 ..... ..... ..... @rrr slt 0000 00000001 00100 ..... ..... ..... @rrr sltu 0000 00000001 00101 ..... ..... ..... @rrr slti 0000 001000 ............ ..... ..... @rr_i12 sltui 0000 001001 ............ ..... ..... @rr_i12 nor 0000 00000001 01000 ..... ..... ..... @rrr and 0000 00000001 01001 ..... ..... ..... @rrr or 0000 00000001 01010 ..... ..... ..... @rrr xor 0000 00000001 01011 ..... ..... ..... @rrr orn 0000 00000001 01100 ..... ..... ..... @rrr andn 0000 00000001 01101 ..... ..... ..... @rrr mul_w 0000 00000001 11000 ..... ..... ..... @rrr mulh_w 0000 00000001 11001 ..... ..... ..... @rrr mulh_wu 0000 00000001 11010 ..... ..... ..... @rrr mul_d 0000 00000001 11011 ..... ..... ..... @rrr mulh_d 0000 00000001 11100 ..... ..... ..... @rrr mulh_du 0000 00000001 11101 ..... ..... ..... @rrr mulw_d_w 0000 00000001 11110 ..... ..... ..... @rrr mulw_d_wu 0000 00000001 11111 ..... ..... ..... @rrr div_w 0000 00000010 00000 ..... ..... ..... @rrr mod_w 0000 00000010 00001 ..... ..... ..... @rrr div_wu 0000 00000010 00010 ..... ..... ..... @rrr mod_wu 0000 00000010 00011 ..... ..... ..... @rrr div_d 0000 00000010 00100 ..... ..... ..... @rrr mod_d 0000 00000010 00101 ..... ..... ..... @rrr div_du 0000 00000010 00110 ..... ..... ..... @rrr mod_du 0000 00000010 00111 ..... ..... ..... @rrr alsl_w 0000 00000000 010 .. ..... ..... ..... @rrr_sa2p1 alsl_wu 0000 00000000 011 .. ..... ..... ..... @rrr_sa2p1 alsl_d 0000 00000010 110 .. ..... ..... ..... @rrr_sa2p1 lu12i_w 0001 010 .................... ..... @r_i20 lu32i_d 0001 011 .................... ..... @r_i20 lu52i_d 0000 001100 ............ ..... ..... @rr_i12 pcaddi 0001 100 .................... ..... @r_i20 pcalau12i 0001 101 .................... ..... @r_i20 pcaddu12i 0001 110 .................... ..... @r_i20 pcaddu18i 0001 111 .................... ..... @r_i20 addi_w 0000 001010 ............ ..... ..... @rr_i12 addi_d 0000 001011 ............ ..... ..... @rr_i12 addu16i_d 0001 00 ................ ..... ..... @rr_i16 andi 0000 001101 ............ ..... ..... @rr_ui12 ori 0000 001110 ............ ..... ..... @rr_ui12 xori 0000 001111 ............ ..... ..... @rr_ui12 # # Fixed point shift operation instruction # sll_w 0000 00000001 01110 ..... ..... ..... @rrr srl_w 0000 00000001 01111 ..... ..... ..... @rrr sra_w 0000 00000001 10000 ..... ..... ..... @rrr sll_d 0000 00000001 10001 ..... ..... ..... @rrr srl_d 0000 00000001 10010 ..... ..... ..... @rrr sra_d 0000 00000001 10011 ..... ..... ..... @rrr rotr_w 0000 00000001 10110 ..... ..... ..... @rrr rotr_d 0000 00000001 10111 ..... ..... ..... @rrr slli_w 0000 00000100 00001 ..... ..... ..... @rr_ui5 slli_d 0000 00000100 0001 ...... ..... ..... @rr_ui6 srli_w 0000 00000100 01001 ..... ..... ..... @rr_ui5 srli_d 0000 00000100 0101 ...... ..... ..... @rr_ui6 srai_w 0000 00000100 10001 ..... ..... ..... @rr_ui5 srai_d 0000 00000100 1001 ...... ..... ..... @rr_ui6 rotri_w 0000 00000100 11001 ..... ..... ..... @rr_ui5 rotri_d 0000 00000100 1101 ...... ..... ..... @rr_ui6 # # Fixed point bit operation instruction # ext_w_h 0000 00000000 00000 10110 ..... ..... @rr ext_w_b 0000 00000000 00000 10111 ..... ..... @rr clo_w 0000 00000000 00000 00100 ..... ..... @rr clz_w 0000 00000000 00000 00101 ..... ..... @rr cto_w 0000 00000000 00000 00110 ..... ..... @rr ctz_w 0000 00000000 00000 00111 ..... ..... @rr clo_d 0000 00000000 00000 01000 ..... ..... @rr clz_d 0000 00000000 00000 01001 ..... ..... @rr cto_d 0000 00000000 00000 01010 ..... ..... @rr ctz_d 0000 00000000 00000 01011 ..... ..... @rr revb_2h 0000 00000000 00000 01100 ..... ..... @rr revb_4h 0000 00000000 00000 01101 ..... ..... @rr revb_2w 0000 00000000 00000 01110 ..... ..... @rr revb_d 0000 00000000 00000 01111 ..... ..... @rr revh_2w 0000 00000000 00000 10000 ..... ..... @rr revh_d 0000 00000000 00000 10001 ..... ..... @rr bitrev_4b 0000 00000000 00000 10010 ..... ..... @rr bitrev_8b 0000 00000000 00000 10011 ..... ..... @rr bitrev_w 0000 00000000 00000 10100 ..... ..... @rr bitrev_d 0000 00000000 00000 10101 ..... ..... @rr bytepick_w 0000 00000000 100 .. ..... ..... ..... @rrr_sa2 bytepick_d 0000 00000000 11 ... ..... ..... ..... @rrr_sa3 maskeqz 0000 00000001 00110 ..... ..... ..... @rrr masknez 0000 00000001 00111 ..... ..... ..... @rrr bstrins_w 0000 0000011 ..... 0 ..... ..... ..... @rr_2bw bstrpick_w 0000 0000011 ..... 1 ..... ..... ..... @rr_2bw bstrins_d 0000 000010 ...... ...... ..... ..... @rr_2bd bstrpick_d 0000 000011 ...... ...... ..... ..... @rr_2bd # # Fixed point load/store instruction # ld_b 0010 100000 ............ ..... ..... @rr_i12 ld_h 0010 100001 ............ ..... ..... @rr_i12 ld_w 0010 100010 ............ ..... ..... @rr_i12 ld_d 0010 100011 ............ ..... ..... @rr_i12 st_b 0010 100100 ............ ..... ..... @rr_i12 st_h 0010 100101 ............ ..... ..... @rr_i12 st_w 0010 100110 ............ ..... ..... @rr_i12 st_d 0010 100111 ............ ..... ..... @rr_i12 ld_bu 0010 101000 ............ ..... ..... @rr_i12 ld_hu 0010 101001 ............ ..... ..... @rr_i12 ld_wu 0010 101010 ............ ..... ..... @rr_i12 ldx_b 0011 10000000 00000 ..... ..... ..... @rrr ldx_h 0011 10000000 01000 ..... ..... ..... @rrr ldx_w 0011 10000000 10000 ..... ..... ..... @rrr ldx_d 0011 10000000 11000 ..... ..... ..... @rrr stx_b 0011 10000001 00000 ..... ..... ..... @rrr stx_h 0011 10000001 01000 ..... ..... ..... @rrr stx_w 0011 10000001 10000 ..... ..... ..... @rrr stx_d 0011 10000001 11000 ..... ..... ..... @rrr ldx_bu 0011 10000010 00000 ..... ..... ..... @rrr ldx_hu 0011 10000010 01000 ..... ..... ..... @rrr ldx_wu 0011 10000010 10000 ..... ..... ..... @rrr preld 0010 101011 ............ ..... ..... @hint_r_i12 dbar 0011 10000111 00100 ............... @i15 ibar 0011 10000111 00101 ............... @i15 ldptr_w 0010 0100 .............. ..... ..... @rr_i14s2 stptr_w 0010 0101 .............. ..... ..... @rr_i14s2 ldptr_d 0010 0110 .............. ..... ..... @rr_i14s2 stptr_d 0010 0111 .............. ..... ..... @rr_i14s2 ldgt_b 0011 10000111 10000 ..... ..... ..... @rrr ldgt_h 0011 10000111 10001 ..... ..... ..... @rrr ldgt_w 0011 10000111 10010 ..... ..... ..... @rrr ldgt_d 0011 10000111 10011 ..... ..... ..... @rrr ldle_b 0011 10000111 10100 ..... ..... ..... @rrr ldle_h 0011 10000111 10101 ..... ..... ..... @rrr ldle_w 0011 10000111 10110 ..... ..... ..... @rrr ldle_d 0011 10000111 10111 ..... ..... ..... @rrr stgt_b 0011 10000111 11000 ..... ..... ..... @rrr stgt_h 0011 10000111 11001 ..... ..... ..... @rrr stgt_w 0011 10000111 11010 ..... ..... ..... @rrr stgt_d 0011 10000111 11011 ..... ..... ..... @rrr stle_b 0011 10000111 11100 ..... ..... ..... @rrr stle_h 0011 10000111 11101 ..... ..... ..... @rrr stle_w 0011 10000111 11110 ..... ..... ..... @rrr stle_d 0011 10000111 11111 ..... ..... ..... @rrr # # Fixed point atomic instruction # ll_w 0010 0000 .............. ..... ..... @rr_i14s2 sc_w 0010 0001 .............. ..... ..... @rr_i14s2 ll_d 0010 0010 .............. ..... ..... @rr_i14s2 sc_d 0010 0011 .............. ..... ..... @rr_i14s2 amswap_w 0011 10000110 00000 ..... ..... ..... @rrr amswap_d 0011 10000110 00001 ..... ..... ..... @rrr amadd_w 0011 10000110 00010 ..... ..... ..... @rrr amadd_d 0011 10000110 00011 ..... ..... ..... @rrr amand_w 0011 10000110 00100 ..... ..... ..... @rrr amand_d 0011 10000110 00101 ..... ..... ..... @rrr amor_w 0011 10000110 00110 ..... ..... ..... @rrr amor_d 0011 10000110 00111 ..... ..... ..... @rrr amxor_w 0011 10000110 01000 ..... ..... ..... @rrr amxor_d 0011 10000110 01001 ..... ..... ..... @rrr ammax_w 0011 10000110 01010 ..... ..... ..... @rrr ammax_d 0011 10000110 01011 ..... ..... ..... @rrr ammin_w 0011 10000110 01100 ..... ..... ..... @rrr ammin_d 0011 10000110 01101 ..... ..... ..... @rrr ammax_wu 0011 10000110 01110 ..... ..... ..... @rrr ammax_du 0011 10000110 01111 ..... ..... ..... @rrr ammin_wu 0011 10000110 10000 ..... ..... ..... @rrr ammin_du 0011 10000110 10001 ..... ..... ..... @rrr amswap_db_w 0011 10000110 10010 ..... ..... ..... @rrr amswap_db_d 0011 10000110 10011 ..... ..... ..... @rrr amadd_db_w 0011 10000110 10100 ..... ..... ..... @rrr amadd_db_d 0011 10000110 10101 ..... ..... ..... @rrr amand_db_w 0011 10000110 10110 ..... ..... ..... @rrr amand_db_d 0011 10000110 10111 ..... ..... ..... @rrr amor_db_w 0011 10000110 11000 ..... ..... ..... @rrr amor_db_d 0011 10000110 11001 ..... ..... ..... @rrr amxor_db_w 0011 10000110 11010 ..... ..... ..... @rrr amxor_db_d 0011 10000110 11011 ..... ..... ..... @rrr ammax_db_w 0011 10000110 11100 ..... ..... ..... @rrr ammax_db_d 0011 10000110 11101 ..... ..... ..... @rrr ammin_db_w 0011 10000110 11110 ..... ..... ..... @rrr ammin_db_d 0011 10000110 11111 ..... ..... ..... @rrr ammax_db_wu 0011 10000111 00000 ..... ..... ..... @rrr ammax_db_du 0011 10000111 00001 ..... ..... ..... @rrr ammin_db_wu 0011 10000111 00010 ..... ..... ..... @rrr ammin_db_du 0011 10000111 00011 ..... ..... ..... @rrr