1139749Simp/* LoongArch opcode support. 253553Stanimura Copyright (C) 2021-2022 Free Software Foundation, Inc. 353553Stanimura Contributed by Loongson Ltd. 453553Stanimura 553553Stanimura This file is part of the GNU opcodes library. 653553Stanimura 753553Stanimura This library is free software; you can redistribute it and/or modify 853553Stanimura it under the terms of the GNU General Public License as published by 953553Stanimura the Free Software Foundation; either version 3, or (at your option) 1053553Stanimura any later version. 1153553Stanimura 1253553Stanimura It is distributed in the hope that it will be useful, but WITHOUT 1353553Stanimura ANY WARRANTY; without even the implied warranty of MERCHANTABILITY 1453553Stanimura or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public 1553553Stanimura License for more details. 1653553Stanimura 1753553Stanimura You should have received a copy of the GNU General Public License 1853553Stanimura along with this program; see the file COPYING3. If not, 1953553Stanimura see <http://www.gnu.org/licenses/>. */ 2053553Stanimura 2153553Stanimura#include <stddef.h> 2253553Stanimura#include "opcode/loongarch.h" 2353553Stanimura#include "libiberty.h" 2453553Stanimura 2553553Stanimurastruct loongarch_ASEs_option LARCH_opts; 2653553Stanimura 27193640Sariffsize_t 28193640Sariffloongarch_insn_length (insn_t insn ATTRIBUTE_UNUSED) 29193640Sariff{ 30193640Sariff return 4; 3153553Stanimura} 3254462Scg 3362483Scgconst char *const loongarch_r_normal_name[32] = 3453553Stanimura{ 35110499Snyan "$r0", "$r1", "$r2", "$r3", "$r4", "$r5", "$r6", "$r7", 36110499Snyan "$r8", "$r9", "$r10", "$r11", "$r12", "$r13", "$r14", "$r15", 3782180Scg "$r16", "$r17", "$r18", "$r19", "$r20", "$r21", "$r22", "$r23", 3882180Scg "$r24", "$r25", "$r26", "$r27", "$r28", "$r29", "$r30", "$r31", 3954824Scg}; 4054824Scg 4154824Scgconst char *const loongarch_r_lp64_name[32] = 4254824Scg{ 4354824Scg "$zero", "$ra", "$tp", "$sp", "$a0", "$a1", "$a2", "$a3", 4474763Scg "$a4", "$a5", "$a6", "$a7", "$t0", "$t1", "$t2", "$t3", 4574763Scg "$t4", "$t5", "$t6", "$t7", "$t8", "$x", "$fp", "$s0", 4654824Scg "$s1", "$s2", "$s3", "$s4", "$s5", "$s6", "$s7", "$s8", 4754824Scg}; 4854824Scg 4974763Scgconst char *const loongarch_r_lp64_name1[32] = 5054824Scg{ 5154824Scg "", "", "", "", "$v0", "$v1", "", "", "", "", "", "", "", "", "", "", 5253553Stanimura "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", 5353553Stanimura}; 5453553Stanimura 5574395Scgconst char *const loongarch_f_normal_name[32] = 5654462Scg{ 5754824Scg "$f0", "$f1", "$f2", "$f3", "$f4", "$f5", "$f6", "$f7", 5854824Scg "$f8", "$f9", "$f10", "$f11", "$f12", "$f13", "$f14", "$f15", 5954824Scg "$f16", "$f17", "$f18", "$f19", "$f20", "$f21", "$f22", "$f23", 6054462Scg "$f24", "$f25", "$f26", "$f27", "$f28", "$f29", "$f30", "$f31", 6154824Scg}; 6254824Scg 6354824Scgconst char *const loongarch_f_lp64_name[32] = 6454462Scg{ 6554824Scg "$fa0", "$fa1", "$fa2", "$fa3", "$fa4", "$fa5", "$fa6", "$fa7", 6654824Scg "$ft0", "$ft1", "$ft2", "$ft3", "$ft4", "$ft5", "$ft6", "$ft7", 6754824Scg "$ft8", "$ft9", "$ft10", "$ft11", "$ft12", "$ft13", "$ft14", "$ft15", 6854462Scg "$fs0", "$fs1", "$fs2", "$fs3", "$fs4", "$fs5", "$fs6", "$fs7", 6954824Scg}; 7054824Scg 7165644Scgconst char *const loongarch_f_lp64_name1[32] = 7254824Scg{ 73107285Scg "$fv0", "$fv1", "", "", "", "", "", "", "", "", "", "", "", "", "", "", 7474763Scg "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", 7554462Scg}; 7653553Stanimura 7753553Stanimuraconst char *const loongarch_c_normal_name[8] = 7853553Stanimura{ 7953553Stanimura "$fcc0", "$fcc1", "$fcc2", "$fcc3", "$fcc4", "$fcc5", "$fcc6", "$fcc7", 8054824Scg}; 8154824Scg 8253553Stanimuraconst char *const loongarch_cr_normal_name[4] = 8354462Scg{ 8453553Stanimura "$scr0", 8554462Scg "$scr1", 8654824Scg "$scr2", 87166918Sariff "$scr3", 88166918Sariff}; 89166918Sariff 90166918Sariffconst char *const loongarch_v_normal_name[32] = 91166918Sariff{ 92166901Spiso "$vr0", "$vr1", "$vr2", "$vr3", "$vr4", "$vr5", "$vr6", "$vr7", 9354824Scg "$vr8", "$vr9", "$vr10", "$vr11", "$vr12", "$vr13", "$vr14", "$vr15", 9454824Scg "$vr16", "$vr17", "$vr18", "$vr19", "$vr20", "$vr21", "$vr22", "$vr23", 9553553Stanimura "$vr24", "$vr25", "$vr26", "$vr27", "$vr28", "$vr29", "$vr30", "$vr31", 9654462Scg}; 9754462Scg 9853553Stanimuraconst char *const loongarch_x_normal_name[32] = 9953553Stanimura{ 10053553Stanimura "$xr0", "$xr1", "$xr2", "$xr3", "$xr4", "$xr5", "$xr6", "$xr7", 10154462Scg "$xr8", "$xr9", "$xr10", "$xr11", "$xr12", "$xr13", "$xr14", "$xr15", 10254462Scg "$xr16", "$xr17", "$xr18", "$xr19", "$xr20", "$xr21", "$xr22", "$xr23", 10360711Snyan "$xr24", "$xr25", "$xr26", "$xr27", "$xr28", "$xr29", "$xr30", "$xr31", 10460711Snyan}; 10560711Snyan 10660711Snyanstatic struct loongarch_opcode loongarch_macro_opcodes[] = 10760711Snyan{ 10860711Snyan /* match, mask, name, format, macro, include, exclude, pinfo. */ 10960711Snyan { 0, 0, "li.w", "r,sc", "%f", 0, 0, 0}, 11060711Snyan { 0, 0, "li.d", "r,sc", "%f", 0, 0, 0}, 11160711Snyan { 0, 0, "la", "r,la", "la.global %1,%2", 0, 0, 0 }, 11260711Snyan 11360711Snyan { 0, 0, "la.global", "r,la", "la.pcrel %1,%2", 11460711Snyan &LARCH_opts.ase_gpcr, 0, 0 }, 11560711Snyan { 0, 0, "la.global", "r,r,la", "la.pcrel %1,%2,%3", 11660711Snyan &LARCH_opts.ase_gpcr, 0, 0 }, 11754462Scg { 0, 0, "la.global", "r,la", "la.abs %1,%2", 11854462Scg &LARCH_opts.ase_gabs, 0, 0 }, 11954462Scg { 0, 0, "la.global", "r,r,la", "la.abs %1,%3", 12054462Scg &LARCH_opts.ase_gabs, 0, 0 }, 12154462Scg { 0, 0, "la.global", "r,l", "la.got %1,%2", 0, 0, 0 }, 12254462Scg { 0, 0, "la.global", "r,r,l", "la.got %1,%2,%3", 0, 0, 0 }, 12354462Scg 12474763Scg { 0, 0, "la.local", "r,la", "la.abs %1,%2", 12574763Scg &LARCH_opts.ase_labs, 0, 0 }, 12674763Scg { 0, 0, "la.local", "r,r,la", "la.abs %1,%3", 127167608Sariff &LARCH_opts.ase_labs, 0, 0 }, 128167608Sariff { 0, 0, "la.local", "r,la", "la.pcrel %1,%2", 0, 0, 0 }, 12974763Scg { 0, 0, "la.local", "r,r,la", "la.pcrel %1,%2,%3", 0, 0, 0 }, 13074763Scg 13174763Scg { 0, 0, "la.abs", "r,la", 13274763Scg "lu12i.w %1,%%abs(%2)>>12;" 13374763Scg "ori %1,%1,%%abs(%2)&0xfff;", 13474763Scg &LARCH_opts.ase_ilp32, &LARCH_opts.ase_lp64, 0 }, 13574763Scg { 0, 0, "la.abs", "r,la", 13674763Scg "lu12i.w %1,%%abs(%2)<<32>>44;" 13774763Scg "ori %1,%1,%%abs(%2)&0xfff;" 13874763Scg "lu32i.d %1,%%abs(%2)<<12>>44;" 13974763Scg "lu52i.d %1,%1,%%abs(%2)>>52;", 14074763Scg &LARCH_opts.ase_lp64, 0, 0 }, 14174763Scg 14274763Scg { 0, 0, "la.pcrel", "r,la", 14374763Scg "pcaddu12i %1,%%pcrel(%2+0x800)<<32>>44;" 144129180Struckman "addi.w %1,%1,%%pcrel(%2+4)-(%%pcrel(%2+4+0x800)>>12<<12);", 145129180Struckman &LARCH_opts.ase_ilp32, &LARCH_opts.ase_lp64, 0 }, 146129180Struckman 147129180Struckman { 0, 0, "la.pcrel", "r,la", 148129180Struckman "pcaddu12i %1,%%pcrel(%2+0x800)>>12;" 149129180Struckman "addi.d %1,%1,%%pcrel(%2+4)-(%%pcrel(%2+4+0x800)>>12<<12);", 15074763Scg &LARCH_opts.ase_lp64, 0, 0 }, 15174763Scg { 0, 0, "la.pcrel", "r,r,la", 15274763Scg "pcaddu12i %1,(%%pcrel(%3)-(%%pcrel(%3+0x80000000)>>32<<32))<<32>>44;" 15374763Scg "ori %2,$r0,(%%pcrel(%3+4)-(%%pcrel(%3+4+0x80000000)>>32<<32))&0xfff;" 15474763Scg "lu32i.d %2,%%pcrel(%3+8+0x80000000)<<12>>44;" 15554462Scg "lu52i.d %2,%2,%%pcrel(%3+12+0x80000000)>>52;" 15654462Scg "add.d %1,%1,%2;", 15754462Scg &LARCH_opts.ase_lp64, 0, 0 }, 15854462Scg 15954462Scg { 0, 0, "la.got", "r,l", 16054462Scg "pcaddu12i %1,(%%pcrel(_GLOBAL_OFFSET_TABLE_+0x800)+%%gprel(%2))<<32>>44;" 16154462Scg "ld.w " 16254462Scg "%1,%1,%%pcrel(_GLOBAL_OFFSET_TABLE_+4)+%%gprel(%2)-((%%pcrel(_GLOBAL_" 16354462Scg "OFFSET_TABLE_+4+0x800)+%%gprel(%2))>>12<<12);", 16454462Scg &LARCH_opts.ase_ilp32, &LARCH_opts.ase_lp64, 0 }, 16554462Scg 166108064Ssemenu { 0, 0, "la.got", "r,l", 167108064Ssemenu "pcaddu12i %1,(%%pcrel(_GLOBAL_OFFSET_TABLE_+0x800)+%%gprel(%2))>>12;" 168108064Ssemenu "ld.d " 16954462Scg "%1,%1,%%pcrel(_GLOBAL_OFFSET_TABLE_+4)+%%gprel(%2)-((%%pcrel(_GLOBAL_" 17054462Scg "OFFSET_TABLE_+4+0x800)+%%gprel(%2))>>12<<12);", 17154462Scg &LARCH_opts.ase_lp64, 0, 0 }, 17254462Scg { 0, 0, "la.got", "r,r,l", 17354462Scg "pcaddu12i " 17454462Scg "%1,(%%pcrel(_GLOBAL_OFFSET_TABLE_)+%%gprel(%3)-((%%pcrel(_GLOBAL_OFFSET_" 17554462Scg "TABLE_+0x80000000)+%%gprel(%3))>>32<<32))<<32>>44;" 17654462Scg "ori " 17754462Scg "%2,$r0,(%%pcrel(_GLOBAL_OFFSET_TABLE_+4)+%%gprel(%3)-((%%pcrel(_GLOBAL_" 17854462Scg "OFFSET_TABLE_+4+0x80000000)+%%gprel(%3))>>32<<32))&0xfff;" 17954462Scg "lu32i.d " 18054462Scg "%2,(%%pcrel(_GLOBAL_OFFSET_TABLE_+8+0x80000000)+%%gprel(%3))<<12>>44;" 18154462Scg "lu52i.d " 18254462Scg "%2,%2,(%%pcrel(_GLOBAL_OFFSET_TABLE_+12+0x80000000)+%%gprel(%3))>>52;" 18354462Scg "ldx.d %1,%1,%2;", 18454462Scg &LARCH_opts.ase_lp64, 0, 0 }, 18554462Scg 18654462Scg { 0, 0, "la.tls.le", "r,la", 18754462Scg "lu12i.w %1,%%tprel(%2)>>12;" 18854462Scg "ori %1,%1,%%tprel(%2)&0xfff", 18954462Scg &LARCH_opts.ase_ilp32, &LARCH_opts.ase_lp64, 0 }, 19054462Scg /* { 0, 0, "la.tls.le", "r,la", 19154462Scg * "lu12i.w %1,%%tprel(%2)>>12;" 19254462Scg * "ori %1,%1,%%tprel(%2)&0xfff" 19354462Scg * , &LARCH_opts.addrwidth_is_64, 0, 0}, */ 19454462Scg { 0, 0, "la.tls.le", "r,la", 19554462Scg "lu12i.w %1,%%tprel(%2)<<32>>44;" 19654462Scg "ori %1,%1,%%tprel(%2)&0xfff;" 19754462Scg "lu32i.d %1,%%tprel(%2)<<12>>44;" 19854462Scg "lu52i.d %1,%1,%%tprel(%2)>>52;", 19954462Scg &LARCH_opts.ase_lp64, 0, 0 }, 20054462Scg 20154462Scg { 0, 0, "la.tls.ie", "r,l", 20254462Scg "pcaddu12i %1,(%%pcrel(_GLOBAL_OFFSET_TABLE_+0x800)+%%tlsgot(%2))<<32>>44;" 20354462Scg "ld.w " 20454462Scg "%1,%1,%%pcrel(_GLOBAL_OFFSET_TABLE_+4)+%%tlsgot(%2)-((%%pcrel(_GLOBAL_" 20554462Scg "OFFSET_TABLE_+4+0x800)+%%tlsgot(%2))>>12<<12);", 20654462Scg &LARCH_opts.ase_ilp32, &LARCH_opts.ase_lp64, 0 }, 20754462Scg 20854462Scg { 0, 0, "la.tls.ie", "r,l", 20954462Scg "pcaddu12i %1,(%%pcrel(_GLOBAL_OFFSET_TABLE_+0x800)+%%tlsgot(%2))>>12;" 21054462Scg "ld.d " 21154462Scg "%1,%1,%%pcrel(_GLOBAL_OFFSET_TABLE_+4)+%%tlsgot(%2)-((%%pcrel(_GLOBAL_" 21254462Scg "OFFSET_TABLE_+4+0x800)+%%tlsgot(%2))>>12<<12);", 21354462Scg &LARCH_opts.ase_lp64, 0, 0 }, 21454462Scg { 0, 0, "la.tls.ie", "r,r,l", 21554462Scg "pcaddu12i " 21654462Scg "%1,(%%pcrel(_GLOBAL_OFFSET_TABLE_)+%%tlsgot(%3)-((%%pcrel(_GLOBAL_OFFSET_" 21754462Scg "TABLE_+0x80000000)+%%tlsgot(%3))>>32<<32))<<32>>44;" 21854462Scg "ori " 21954462Scg "%2,$r0,(%%pcrel(_GLOBAL_OFFSET_TABLE_+4)+%%tlsgot(%3)-((%%pcrel(_GLOBAL_" 22054462Scg "OFFSET_TABLE_+4+0x80000000)+%%tlsgot(%3))>>32<<32))&0xfff;" 22154462Scg "lu32i.d " 22254462Scg "%2,(%%pcrel(_GLOBAL_OFFSET_TABLE_+8+0x80000000)+%%tlsgot(%3))<<12>>44;" 22354462Scg "lu52i.d " 22454462Scg "%2,%2,(%%pcrel(_GLOBAL_OFFSET_TABLE_+12+0x80000000)+%%tlsgot(%3))>>52;" 22554462Scg "ldx.d %1,%1,%2;", 22654462Scg &LARCH_opts.ase_lp64, 0, 0 }, 22754462Scg 22854462Scg { 0, 0, "la.tls.ld", "r,l", "la.tls.gd %1,%2", 0, 0, 0 }, 22954462Scg { 0, 0, "la.tls.ld", "r,r,l", "la.tls.gd %1,%2,%3", 23054462Scg &LARCH_opts.ase_lp64, 0, 0 }, 23154462Scg 23254462Scg { 0, 0, "la.tls.gd", "r,l", 23354462Scg "pcaddu12i %1,(%%pcrel(_GLOBAL_OFFSET_TABLE_+0x800)+%%tlsgd(%2))<<32>>44;" 23454462Scg "addi.w " 23554462Scg "%1,%1,%%pcrel(_GLOBAL_OFFSET_TABLE_+4)+%%tlsgd(%2)-((%%pcrel(_GLOBAL_" 23654462Scg "OFFSET_TABLE_+4+0x800)+%%tlsgd(%2))>>12<<12);", 23754462Scg &LARCH_opts.ase_ilp32, &LARCH_opts.ase_lp64, 0 }, 23854462Scg 23954462Scg { 0, 0, "la.tls.gd", "r,l", 24054462Scg "pcaddu12i %1,(%%pcrel(_GLOBAL_OFFSET_TABLE_+0x800)+%%tlsgd(%2))>>12;" 24154462Scg "addi.d " 24254462Scg "%1,%1,%%pcrel(_GLOBAL_OFFSET_TABLE_+4)+%%tlsgd(%2)-((%%pcrel(_GLOBAL_" 24354462Scg "OFFSET_TABLE_+4+0x800)+%%tlsgd(%2))>>12<<12);", 24454462Scg &LARCH_opts.ase_lp64, 0, 0 }, 24554462Scg { 0, 0, "la.tls.gd", "r,r,l", 24654462Scg "pcaddu12i " 24754462Scg "%1,(%%pcrel(_GLOBAL_OFFSET_TABLE_)+%%tlsgd(%3)-((%%pcrel(_GLOBAL_OFFSET_" 24854462Scg "TABLE_+0x80000000)+%%tlsgd(%3))>>32<<32))<<32>>44;" 24954462Scg "ori " 25054462Scg "%2,$r0,(%%pcrel(_GLOBAL_OFFSET_TABLE_+4)+%%tlsgd(%3)-((%%pcrel(_GLOBAL_" 25154462Scg "OFFSET_TABLE_+4+0x80000000)+%%tlsgd(%3))>>32<<32))&0xfff;" 25254462Scg "lu32i.d " 25354462Scg "%2,(%%pcrel(_GLOBAL_OFFSET_TABLE_+8+0x80000000)+%%tlsgd(%3))<<12>>44;" 25454462Scg "lu52i.d " 25554118Stanimura "%2,%2,(%%pcrel(_GLOBAL_OFFSET_TABLE_+12+0x80000000)+%%tlsgd(%3))>>52;" 25654961Speter "add.d %1,%1,%2;", 25754961Speter &LARCH_opts.ase_lp64, 0, 0 }, 25854961Speter 25954961Speter { 0 } /* Terminate the list. */ 26054961Speter}; 26154961Speter 26254961Speterstatic struct loongarch_opcode loongarch_fix_opcodes[] = 26384134Sgreid{ 26454462Scg /* match, mask, name, format, macro, include, exclude, pinfo. */ 26558385Scg { 0x00001000, 0xfffffc00, "clo.w", "r0:5,r5:5", 0, 0, 0, 0 }, 26654961Speter { 0x00001400, 0xfffffc00, "clz.w", "r0:5,r5:5", 0, 0, 0, 0 }, 26758385Scg { 0x00001800, 0xfffffc00, "cto.w", "r0:5,r5:5", 0, 0, 0, 0 }, 26854462Scg { 0x00001c00, 0xfffffc00, "ctz.w", "r0:5,r5:5", 0, 0, 0, 0 }, 26970668Simp { 0x00002000, 0xfffffc00, "clo.d", "r0:5,r5:5", 0, 0, 0, 0 }, 27056721Sgallatin { 0x00002400, 0xfffffc00, "clz.d", "r0:5,r5:5", 0, 0, 0, 0 }, 271148597Snetchild { 0x00002800, 0xfffffc00, "cto.d", "r0:5,r5:5", 0, 0, 0, 0 }, 27254961Speter { 0x00002c00, 0xfffffc00, "ctz.d", "r0:5,r5:5", 0, 0, 0, 0 }, 27361061Skuriyama { 0x00003000, 0xfffffc00, "revb.2h", "r0:5,r5:5", 0, 0, 0, 0 }, 27454961Speter { 0x00003400, 0xfffffc00, "revb.4h", "r0:5,r5:5", 0, 0, 0, 0 }, 27561569Sbrian { 0x00003800, 0xfffffc00, "revb.2w", "r0:5,r5:5", 0, 0, 0, 0 }, 27654961Speter { 0x00003c00, 0xfffffc00, "revb.d", "r0:5,r5:5", 0, 0, 0, 0 }, 27755848Sdeischen { 0x00004000, 0xfffffc00, "revh.2w", "r0:5,r5:5", 0, 0, 0, 0 }, 27854961Speter { 0x00004400, 0xfffffc00, "revh.d", "r0:5,r5:5", 0, 0, 0, 0 }, 27954961Speter { 0x00004800, 0xfffffc00, "bitrev.4b", "r0:5,r5:5", 0, 0, 0, 0 }, 28054961Speter { 0x00004c00, 0xfffffc00, "bitrev.8b", "r0:5,r5:5", 0, 0, 0, 0 }, 28164845Scg { 0x00005000, 0xfffffc00, "bitrev.w", "r0:5,r5:5", 0, 0, 0, 0 }, 28254118Stanimura { 0x00005400, 0xfffffc00, "bitrev.d", "r0:5,r5:5", 0, 0, 0, 0 }, 28354118Stanimura { 0x00005800, 0xfffffc00, "ext.w.h", "r0:5,r5:5", 0, 0, 0, 0 }, 28454118Stanimura { 0x00005c00, 0xfffffc00, "ext.w.b", "r0:5,r5:5", 0, 0, 0, 0 }, 28553553Stanimura /* or %1,%2,$r0 */ 28653553Stanimura { 0x00150000, 0xfffffc00, "move", "r0:5,r5:5", 0, 0, 0, 0 }, 28753553Stanimura { 0x00006000, 0xfffffc00, "rdtimel.w", "r0:5,r5:5", 0, 0, 0, 0 }, 28854462Scg { 0x00006400, 0xfffffc00, "rdtimeh.w", "r0:5,r5:5", 0, 0, 0, 0 }, 28956774Scg { 0x00006800, 0xfffffc00, "rdtime.d", "r0:5,r5:5", 0, 0, 0, 0 }, 29056774Scg { 0x00006c00, 0xfffffc00, "cpucfg", "r0:5,r5:5", 0, 0, 0, 0 }, 29156774Scg { 0x00010000, 0xffff801f, "asrtle.d", "r5:5,r10:5", 0, 0, 0, 0 }, 29256774Scg { 0x00018000, 0xffff801f, "asrtgt.d", "r5:5,r10:5", 0, 0, 0, 0 }, 29356774Scg { 0x00040000, 0xfffe0000, "alsl.w", "r0:5,r5:5,r10:5,u15:2+1", 0, 0, 0, 0 }, 29456774Scg { 0x00060000, 0xfffe0000, "alsl.wu", "r0:5,r5:5,r10:5,u15:2+1", 0, 0, 0, 0 }, 29556774Scg { 0x00080000, 0xfffe0000, "bytepick.w", "r0:5,r5:5,r10:5,u15:2", 0, 0, 0, 0 }, 29654462Scg { 0x000c0000, 0xfffc0000, "bytepick.d", "r0:5,r5:5,r10:5,u15:3", 0, 0, 0, 0 }, 29754462Scg { 0x00100000, 0xffff8000, "add.w", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 29854462Scg { 0x00108000, 0xffff8000, "add.d", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 29954462Scg { 0x00110000, 0xffff8000, "sub.w", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 30054462Scg { 0x00118000, 0xffff8000, "sub.d", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 30153553Stanimura { 0x00120000, 0xffff8000, "slt", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 30260711Snyan { 0x00128000, 0xffff8000, "sltu", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 30360711Snyan { 0x00130000, 0xffff8000, "maskeqz", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 30460711Snyan { 0x00138000, 0xffff8000, "masknez", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 30560711Snyan { 0x00140000, 0xffff8000, "nor", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 30654462Scg { 0x00148000, 0xffff8000, "and", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 30754462Scg { 0x00150000, 0xffff8000, "or", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 30860711Snyan { 0x00158000, 0xffff8000, "xor", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 30954462Scg { 0x00160000, 0xffff8000, "orn", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 31060711Snyan { 0x00168000, 0xffff8000, "andn", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 31160711Snyan { 0x00170000, 0xffff8000, "sll.w", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 31260711Snyan { 0x00178000, 0xffff8000, "srl.w", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 31354462Scg { 0x00180000, 0xffff8000, "sra.w", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 31454462Scg { 0x00188000, 0xffff8000, "sll.d", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 31554462Scg { 0x00190000, 0xffff8000, "srl.d", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 31654462Scg { 0x00198000, 0xffff8000, "sra.d", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 31754462Scg { 0x001b0000, 0xffff8000, "rotr.w", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 31867651Scg { 0x001b8000, 0xffff8000, "rotr.d", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 31967651Scg { 0x001c0000, 0xffff8000, "mul.w", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 32067651Scg { 0x001c8000, 0xffff8000, "mulh.w", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 32167651Scg { 0x001d0000, 0xffff8000, "mulh.wu", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 32254462Scg { 0x001d8000, 0xffff8000, "mul.d", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 32367651Scg { 0x001e0000, 0xffff8000, "mulh.d", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 32454462Scg { 0x001e8000, 0xffff8000, "mulh.du", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 32554462Scg { 0x001f0000, 0xffff8000, "mulw.d.w", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 32654462Scg { 0x001f8000, 0xffff8000, "mulw.d.wu", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 32767651Scg { 0x00200000, 0xffff8000, "div.w", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 32854462Scg { 0x00208000, 0xffff8000, "mod.w", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 32954462Scg { 0x00210000, 0xffff8000, "div.wu", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 33054462Scg { 0x00218000, 0xffff8000, "mod.wu", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 33167651Scg { 0x00220000, 0xffff8000, "div.d", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 33254462Scg { 0x00228000, 0xffff8000, "mod.d", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 33354462Scg { 0x00230000, 0xffff8000, "div.du", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 33454462Scg { 0x00238000, 0xffff8000, "mod.du", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 33554462Scg { 0x00240000, 0xffff8000, "crc.w.b.w", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 33654462Scg { 0x00248000, 0xffff8000, "crc.w.h.w", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 33754462Scg { 0x00250000, 0xffff8000, "crc.w.w.w", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 33854462Scg { 0x00258000, 0xffff8000, "crc.w.d.w", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 33954462Scg { 0x00260000, 0xffff8000, "crcc.w.b.w", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 34054462Scg { 0x00268000, 0xffff8000, "crcc.w.h.w", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 34154462Scg { 0x00270000, 0xffff8000, "crcc.w.w.w", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 34253553Stanimura { 0x00278000, 0xffff8000, "crcc.w.d.w", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 34353553Stanimura { 0x002a0000, 0xffff8000, "break", "u0:15", 0, 0, 0, 0 }, 34453553Stanimura { 0x002a8000, 0xffff8000, "dbcl", "u0:15", 0, 0, 0, 0 }, 34553553Stanimura { 0x002b0000, 0xffff8000, "syscall", "u0:15", 0, 0, 0, 0 }, 34653553Stanimura { 0x002c0000, 0xfffe0000, "alsl.d", "r0:5,r5:5,r10:5,u15:2+1", 0, 0, 0, 0 }, 34754791Scg { 0x00408000, 0xffff8000, "slli.w", "r0:5,r5:5,u10:5", 0, 0, 0, 0 }, 34854462Scg { 0x00410000, 0xffff0000, "slli.d", "r0:5,r5:5,u10:6", 0, 0, 0, 0 }, 34954462Scg { 0x00448000, 0xffff8000, "srli.w", "r0:5,r5:5,u10:5", 0, 0, 0, 0 }, 35054462Scg { 0x00450000, 0xffff0000, "srli.d", "r0:5,r5:5,u10:6", 0, 0, 0, 0 }, 35154462Scg { 0x00488000, 0xffff8000, "srai.w", "r0:5,r5:5,u10:5", 0, 0, 0, 0 }, 35254824Scg { 0x00490000, 0xffff0000, "srai.d", "r0:5,r5:5,u10:6", 0, 0, 0, 0 }, 35353553Stanimura { 0x004c8000, 0xffff8000, "rotri.w", "r0:5,r5:5,u10:5", 0, 0, 0, 0 }, 35454462Scg { 0x004d0000, 0xffff0000, "rotri.d", "r0:5,r5:5,u10:6", 0, 0, 0, 0 }, 35554462Scg { 0x00600000, 0xffe08000, "bstrins.w", "r0:5,r5:5,u16:5,u10:5", 0, 0, 0, 0 }, 35654462Scg { 0x00608000, 0xffe08000, "bstrpick.w", "r0:5,r5:5,u16:5,u10:5", 0, 0, 0, 0 }, 35754462Scg { 0x00800000, 0xffc00000, "bstrins.d", "r0:5,r5:5,u16:6,u10:6", 0, 0, 0, 0 }, 35854462Scg { 0x00c00000, 0xffc00000, "bstrpick.d", "r0:5,r5:5,u16:6,u10:6", 0, 0, 0, 0 }, 35953553Stanimura { 0 } /* Terminate the list. */ 36053553Stanimura}; 36154462Scg 36274763Scgstatic struct loongarch_opcode loongarch_single_float_opcodes[] = 36354791Scg{ 36454462Scg /* match, mask, name, format, macro, include, exclude, pinfo. */ 36553553Stanimura { 0x01008000, 0xffff8000, "fadd.s", "f0:5,f5:5,f10:5", 0, 0, 0, 0 }, 36654791Scg { 0x01028000, 0xffff8000, "fsub.s", "f0:5,f5:5,f10:5", 0, 0, 0, 0 }, 36754462Scg { 0x01048000, 0xffff8000, "fmul.s", "f0:5,f5:5,f10:5", 0, 0, 0, 0 }, 36854791Scg { 0x01068000, 0xffff8000, "fdiv.s", "f0:5,f5:5,f10:5", 0, 0, 0, 0 }, 36954462Scg { 0x01088000, 0xffff8000, "fmax.s", "f0:5,f5:5,f10:5", 0, 0, 0, 0 }, 37054462Scg { 0x010a8000, 0xffff8000, "fmin.s", "f0:5,f5:5,f10:5", 0, 0, 0, 0 }, 37154791Scg { 0x010c8000, 0xffff8000, "fmaxa.s", "f0:5,f5:5,f10:5", 0, 0, 0, 0 }, 37258385Scg { 0x010e8000, 0xffff8000, "fmina.s", "f0:5,f5:5,f10:5", 0, 0, 0, 0 }, 37354462Scg { 0x01108000, 0xffff8000, "fscaleb.s", "f0:5,f5:5,f10:5", 0, 0, 0, 0 }, 37454462Scg { 0x01128000, 0xffff8000, "fcopysign.s", "f0:5,f5:5,f10:5", 0, 0, 0, 0 }, 37554462Scg { 0x01140400, 0xfffffc00, "fabs.s", "f0:5,f5:5", 0, 0, 0, 0 }, 37654462Scg { 0x01141400, 0xfffffc00, "fneg.s", "f0:5,f5:5", 0, 0, 0, 0 }, 37754462Scg { 0x01142400, 0xfffffc00, "flogb.s", "f0:5,f5:5", 0, 0, 0, 0 }, 37854462Scg { 0x01143400, 0xfffffc00, "fclass.s", "f0:5,f5:5", 0, 0, 0, 0 }, 37954462Scg { 0x01144400, 0xfffffc00, "fsqrt.s", "f0:5,f5:5", 0, 0, 0, 0 }, 38054462Scg { 0x01145400, 0xfffffc00, "frecip.s", "f0:5,f5:5", 0, 0, 0, 0 }, 38154462Scg { 0x01146400, 0xfffffc00, "frsqrt.s", "f0:5,f5:5", 0, 0, 0, 0 }, 38254462Scg { 0x01149400, 0xfffffc00, "fmov.s", "f0:5,f5:5", 0, 0, 0, 0 }, 38354462Scg { 0x0114a400, 0xfffffc00, "movgr2fr.w", "f0:5,r5:5", 0, 0, 0, 0 }, 38454462Scg { 0x0114ac00, 0xfffffc00, "movgr2frh.w", "f0:5,r5:5", 0, 0, 0, 0 }, 38554462Scg { 0x0114b400, 0xfffffc00, "movfr2gr.s", "r0:5,f5:5", 0, 0, 0, 0 }, 38654462Scg { 0x0114bc00, 0xfffffc00, "movfrh2gr.s", "r0:5,f5:5", 0, 0, 0, 0 }, 38754462Scg { 0x0114c000, 0xfffffc00, "movgr2fcsr", "r0:5,r5:5", 0, 0, 0, 0 }, 38854462Scg { 0x0114c800, 0xfffffc00, "movfcsr2gr", "r0:5,r5:5", 0, 0, 0, 0 }, 38954462Scg { 0x0114d000, 0xfffffc18, "movfr2cf", "c0:3,f5:5", 0, 0, 0, 0 }, 39054462Scg { 0x0114d400, 0xffffff00, "movcf2fr", "f0:5,c5:3", 0, 0, 0, 0 }, 39154791Scg { 0x0114d800, 0xfffffc18, "movgr2cf", "c0:3,r5:5", 0, 0, 0, 0 }, 39254462Scg { 0x0114dc00, 0xffffff00, "movcf2gr", "r0:5,c5:3", 0, 0, 0, 0 }, 39354846Scg { 0x011a0400, 0xfffffc00, "ftintrm.w.s", "f0:5,f5:5", 0, 0, 0, 0 }, 39454846Scg { 0x011a2400, 0xfffffc00, "ftintrm.l.s", "f0:5,f5:5", 0, 0, 0, 0 }, 39554846Scg { 0x011a4400, 0xfffffc00, "ftintrp.w.s", "f0:5,f5:5", 0, 0, 0, 0 }, 39654846Scg { 0x011a6400, 0xfffffc00, "ftintrp.l.s", "f0:5,f5:5", 0, 0, 0, 0 }, 39754846Scg { 0x011a8400, 0xfffffc00, "ftintrz.w.s", "f0:5,f5:5", 0, 0, 0, 0 }, 39854846Scg { 0x011aa400, 0xfffffc00, "ftintrz.l.s", "f0:5,f5:5", 0, 0, 0, 0 }, 39954846Scg { 0x011ac400, 0xfffffc00, "ftintrne.w.s", "f0:5,f5:5", 0, 0, 0, 0 }, 40054462Scg { 0x011ae400, 0xfffffc00, "ftintrne.l.s", "f0:5,f5:5", 0, 0, 0, 0 }, 40154791Scg { 0x011b0400, 0xfffffc00, "ftint.w.s", "f0:5,f5:5", 0, 0, 0, 0 }, 40254791Scg { 0x011b2400, 0xfffffc00, "ftint.l.s", "f0:5,f5:5", 0, 0, 0, 0 }, 40354824Scg { 0x011d1000, 0xfffffc00, "ffint.s.w", "f0:5,f5:5", 0, 0, 0, 0 }, 40460711Snyan { 0x011d1800, 0xfffffc00, "ffint.s.l", "f0:5,f5:5", 0, 0, 0, 0 }, 40560711Snyan { 0x011e4400, 0xfffffc00, "frint.s", "f0:5,f5:5", 0, 0, 0, 0 }, 40660711Snyan { 0 } /* Terminate the list. */ 40760711Snyan}; 40860711Snyanstatic struct loongarch_opcode loongarch_double_float_opcodes[] = 40960711Snyan{ 41060711Snyan /* match, mask, name, format, macro, include, exclude, pinfo. */ 41160711Snyan { 0x01010000, 0xffff8000, "fadd.d", "f0:5,f5:5,f10:5", 0, 0, 0, 0 }, 41260711Snyan { 0x01030000, 0xffff8000, "fsub.d", "f0:5,f5:5,f10:5", 0, 0, 0, 0 }, 41360711Snyan { 0x01050000, 0xffff8000, "fmul.d", "f0:5,f5:5,f10:5", 0, 0, 0, 0 }, 41460711Snyan { 0x01070000, 0xffff8000, "fdiv.d", "f0:5,f5:5,f10:5", 0, 0, 0, 0 }, 41560711Snyan { 0x01090000, 0xffff8000, "fmax.d", "f0:5,f5:5,f10:5", 0, 0, 0, 0 }, 41660711Snyan { 0x010b0000, 0xffff8000, "fmin.d", "f0:5,f5:5,f10:5", 0, 0, 0, 0 }, 41760711Snyan { 0x010d0000, 0xffff8000, "fmaxa.d", "f0:5,f5:5,f10:5", 0, 0, 0, 0 }, 41854791Scg { 0x010f0000, 0xffff8000, "fmina.d", "f0:5,f5:5,f10:5", 0, 0, 0, 0 }, 41954791Scg { 0x01110000, 0xffff8000, "fscaleb.d", "f0:5,f5:5,f10:5", 0, 0, 0, 0 }, 42054791Scg { 0x01130000, 0xffff8000, "fcopysign.d", "f0:5,f5:5,f10:5", 0, 0, 0, 0 }, 42154791Scg { 0x01140800, 0xfffffc00, "fabs.d", "f0:5,f5:5", 0, 0, 0, 0 }, 42254791Scg { 0x01141800, 0xfffffc00, "fneg.d", "f0:5,f5:5", 0, 0, 0, 0 }, 42354791Scg { 0x01142800, 0xfffffc00, "flogb.d", "f0:5,f5:5", 0, 0, 0, 0 }, 42454791Scg { 0x01143800, 0xfffffc00, "fclass.d", "f0:5,f5:5", 0, 0, 0, 0 }, 42554791Scg { 0x01144800, 0xfffffc00, "fsqrt.d", "f0:5,f5:5", 0, 0, 0, 0 }, 42654791Scg { 0x01145800, 0xfffffc00, "frecip.d", "f0:5,f5:5", 0, 0, 0, 0 }, 42754791Scg { 0x01146800, 0xfffffc00, "frsqrt.d", "f0:5,f5:5", 0, 0, 0, 0 }, 42860711Snyan { 0x01149800, 0xfffffc00, "fmov.d", "f0:5,f5:5", 0, 0, 0, 0 }, 42965644Scg { 0x0114a800, 0xfffffc00, "movgr2fr.d", "f0:5,r5:5", 0, 0, 0, 0 }, 43065644Scg { 0x0114b800, 0xfffffc00, "movfr2gr.d", "r0:5,f5:5", 0, 0, 0, 0 }, 43165644Scg { 0x01191800, 0xfffffc00, "fcvt.s.d", "f0:5,f5:5", 0, 0, 0, 0 }, 43265644Scg { 0x01192400, 0xfffffc00, "fcvt.d.s", "f0:5,f5:5", 0, 0, 0, 0 }, 43365644Scg { 0x011a0800, 0xfffffc00, "ftintrm.w.d", "f0:5,f5:5", 0, 0, 0, 0 }, 43454462Scg { 0x011a2800, 0xfffffc00, "ftintrm.l.d", "f0:5,f5:5", 0, 0, 0, 0 }, 43554462Scg { 0x011a4800, 0xfffffc00, "ftintrp.w.d", "f0:5,f5:5", 0, 0, 0, 0 }, 43654462Scg { 0x011a6800, 0xfffffc00, "ftintrp.l.d", "f0:5,f5:5", 0, 0, 0, 0 }, 43754462Scg { 0x011a8800, 0xfffffc00, "ftintrz.w.d", "f0:5,f5:5", 0, 0, 0, 0 }, 43854961Speter { 0x011aa800, 0xfffffc00, "ftintrz.l.d", "f0:5,f5:5", 0, 0, 0, 0 }, 43958385Scg { 0x011ac800, 0xfffffc00, "ftintrne.w.d", "f0:5,f5:5", 0, 0, 0, 0 }, 44058385Scg { 0x011ae800, 0xfffffc00, "ftintrne.l.d", "f0:5,f5:5", 0, 0, 0, 0 }, 44154462Scg { 0x011b0800, 0xfffffc00, "ftint.w.d", "f0:5,f5:5", 0, 0, 0, 0 }, 44254462Scg { 0x011b2800, 0xfffffc00, "ftint.l.d", "f0:5,f5:5", 0, 0, 0, 0 }, 44353553Stanimura { 0x011d2000, 0xfffffc00, "ffint.d.w", "f0:5,f5:5", 0, 0, 0, 0 }, 44454462Scg { 0x011d2800, 0xfffffc00, "ffint.d.l", "f0:5,f5:5", 0, 0, 0, 0 }, 44553553Stanimura { 0x011e4800, 0xfffffc00, "frint.d", "f0:5,f5:5", 0, 0, 0, 0 }, 44654824Scg { 0 } /* Terminate the list. */ 44754824Scg}; 44874763Scg 449128232Sgreenstatic struct loongarch_opcode loongarch_imm_opcodes[] = 45054824Scg{ 45154824Scg /* match, mask, name, format, macro, include, exclude, pinfo. */ 45254824Scg { 0x02000000, 0xffc00000, "slti", "r0:5,r5:5,s10:12", 0, 0, 0, 0 }, 45354118Stanimura { 0x02400000, 0xffc00000, "sltui", "r0:5,r5:5,s10:12", 0, 0, 0, 0 }, 45478564Sgreid { 0x02800000, 0xffc00000, "addi.w", "r0:5,r5:5,s10:12", 0, 0, 0, 0 }, 45554462Scg { 0x02c00000, 0xffc00000, "addi.d", "r0:5,r5:5,s10:12", 0, 0, 0, 0 }, 45654118Stanimura { 0x03000000, 0xffc00000, "lu52i.d", "r0:5,r5:5,s10:12", 0, 0, 0, 0 }, 45774395Scg { 0x0, 0x0, "nop", "", "andi $r0,$r0,0", 0, 0, 0 }, 45874395Scg { 0x03400000, 0xffc00000, "andi", "r0:5,r5:5,u10:12", 0, 0, 0, 0 }, 45954118Stanimura { 0x03800000, 0xffc00000, "ori", "r0:5,r5:5,u10:12", 0, 0, 0, 0 }, 46054118Stanimura { 0x03c00000, 0xffc00000, "xori", "r0:5,r5:5,u10:12", 0, 0, 0, 0 }, 46178564Sgreid { 0x10000000, 0xfc000000, "addu16i.d", "r0:5,r5:5,s10:16", 0, 0, 0, 0 }, 46254462Scg { 0x14000000, 0xfe000000, "lu12i.w", "r0:5,s5:20", 0, 0, 0, 0 }, 46354118Stanimura { 0x16000000, 0xfe000000, "lu32i.d", "r0:5,s5:20", 0, 0, 0, 0 }, 46474395Scg { 0x18000000, 0xfe000000, "pcaddi", "r0:5,s5:20", 0, 0, 0, 0 }, 46574395Scg { 0x1a000000, 0xfe000000, "pcalau12i", "r0:5,s5:20", 0, 0, 0, 0 }, 46654118Stanimura { 0x1c000000, 0xfe000000, "pcaddu12i", "r0:5,s5:20", 0, 0, 0, 0 }, 46754118Stanimura { 0x1e000000, 0xfe000000, "pcaddu18i", "r0:5,s5:20", 0, 0, 0, 0 }, 46878564Sgreid { 0 } /* Terminate the list. */ 46954462Scg}; 47054118Stanimura 47174395Scgstatic struct loongarch_opcode loongarch_privilege_opcodes[] = 47274395Scg{ 47354118Stanimura /* match, mask, name, format, macro, include, exclude, pinfo. */ 47454462Scg { 0x04000000, 0xff0003e0, "csrrd", "r0:5,u10:14", 0, 0, 0, 0 }, 47553553Stanimura { 0x04000020, 0xff0003e0, "csrwr", "r0:5,u10:14", 0, 0, 0, 0 }, 47653553Stanimura { 0x04000000, 0xff000000, "csrxchg", "r0:5,r5:5,u10:14", 0, 0, 0, 0 }, 47753553Stanimura { 0x06000000, 0xffc00000, "cacop", "u0:5,r5:5,s10:12", 0, 0, 0, 0 }, 47854462Scg { 0x06400000, 0xfffc0000, "lddir", "r0:5,r5:5,u10:8", 0, 0, 0, 0 }, 47954791Scg { 0x06440000, 0xfffc001f, "ldpte", "r5:5,u10:8", 0, 0, 0, 0 }, 48054791Scg { 0x06480000, 0xfffffc00, "iocsrrd.b", "r0:5,r5:5", 0, 0, 0, 0 }, 48154462Scg { 0x06480400, 0xfffffc00, "iocsrrd.h", "r0:5,r5:5", 0, 0, 0, 0 }, 48253553Stanimura { 0x06480800, 0xfffffc00, "iocsrrd.w", "r0:5,r5:5", 0, 0, 0, 0 }, 48353553Stanimura { 0x06480c00, 0xfffffc00, "iocsrrd.d", "r0:5,r5:5", 0, 0, 0, 0 }, 48465644Scg { 0x06481000, 0xfffffc00, "iocsrwr.b", "r0:5,r5:5", 0, 0, 0, 0 }, 48565644Scg { 0x06481400, 0xfffffc00, "iocsrwr.h", "r0:5,r5:5", 0, 0, 0, 0 }, 48665644Scg { 0x06481800, 0xfffffc00, "iocsrwr.w", "r0:5,r5:5", 0, 0, 0, 0 }, 48765644Scg { 0x06481c00, 0xfffffc00, "iocsrwr.d", "r0:5,r5:5", 0, 0, 0, 0 }, 48865644Scg { 0x06482000, 0xffffffff, "tlbclr", "", 0, 0, 0, 0 }, 48974763Scg { 0x06482400, 0xffffffff, "tlbflush", "", 0, 0, 0, 0 }, 49074395Scg { 0x06482800, 0xffffffff, "tlbsrch", "", 0, 0, 0, 0 }, 49174395Scg { 0x06482c00, 0xffffffff, "tlbrd", "", 0, 0, 0, 0 }, 49274395Scg { 0x06483000, 0xffffffff, "tlbwr", "", 0, 0, 0, 0 }, 49365644Scg { 0x06483400, 0xffffffff, "tlbfill", "", 0, 0, 0, 0 }, 49474763Scg { 0x06483800, 0xffffffff, "ertn", "", 0, 0, 0, 0 }, 49565644Scg { 0x06488000, 0xffff8000, "idle", "u0:15", 0, 0, 0, 0 }, 49665644Scg { 0x06498000, 0xffff8000, "invtlb", "u0:5,r5:5,r10:5", 0, 0, 0, 0 }, 49765644Scg { 0 } /* Terminate the list. */ 49854824Scg}; 49954824Scg 50054824Scgstatic struct loongarch_opcode loongarch_4opt_single_float_opcodes[] = 50154824Scg{ 50254824Scg /* match, mask, name, format, macro, include, exclude, pinfo. */ 50354824Scg { 0x08100000, 0xfff00000, "fmadd.s", "f0:5,f5:5,f10:5,f15:5", 0, 0, 0, 0 }, 50474763Scg { 0x08500000, 0xfff00000, "fmsub.s", "f0:5,f5:5,f10:5,f15:5", 0, 0, 0, 0 }, 50554824Scg { 0x08900000, 0xfff00000, "fnmadd.s", "f0:5,f5:5,f10:5,f15:5", 0, 0, 0, 0 }, 50654824Scg { 0x08d00000, 0xfff00000, "fnmsub.s", "f0:5,f5:5,f10:5,f15:5", 0, 0, 0, 0 }, 50754824Scg { 0x0c100000, 0xffff8018, "fcmp.caf.s", "c0:3,f5:5,f10:5", 0, 0, 0, 0 }, 50854824Scg { 0x0c108000, 0xffff8018, "fcmp.saf.s", "c0:3,f5:5,f10:5", 0, 0, 0, 0 }, 50954824Scg { 0x0c110000, 0xffff8018, "fcmp.clt.s", "c0:3,f5:5,f10:5", 0, 0, 0, 0 }, 51074763Scg { 0x0c118000, 0xffff8018, "fcmp.slt.s", "c0:3,f5:5,f10:5", 0, 0, 0, 0 }, 51154824Scg { 0x0c118000, 0xffff8018, "fcmp.sgt.s", "c0:3,f10:5,f5:5", 0, 0, 0, 0 }, 51254824Scg { 0x0c120000, 0xffff8018, "fcmp.ceq.s", "c0:3,f5:5,f10:5", 0, 0, 0, 0 }, 51354824Scg { 0x0c128000, 0xffff8018, "fcmp.seq.s", "c0:3,f5:5,f10:5", 0, 0, 0, 0 }, 514166918Sariff { 0x0c130000, 0xffff8018, "fcmp.cle.s", "c0:3,f5:5,f10:5", 0, 0, 0, 0 }, 515166918Sariff { 0x0c138000, 0xffff8018, "fcmp.sle.s", "c0:3,f5:5,f10:5", 0, 0, 0, 0 }, 516166918Sariff { 0x0c138000, 0xffff8018, "fcmp.sge.s", "c0:3,f10:5,f5:5", 0, 0, 0, 0 }, 517166918Sariff { 0x0c140000, 0xffff8018, "fcmp.cun.s", "c0:3,f5:5,f10:5", 0, 0, 0, 0 }, 518166918Sariff { 0x0c148000, 0xffff8018, "fcmp.sun.s", "c0:3,f5:5,f10:5", 0, 0, 0, 0 }, 519166901Spiso { 0x0c150000, 0xffff8018, "fcmp.cult.s", "c0:3,f5:5,f10:5", 0, 0, 0, 0 }, 52054824Scg { 0x0c150000, 0xffff8018, "fcmp.cugt.s", "c0:3,f10:5,f5:5", 0, 0, 0, 0 }, 52154824Scg { 0x0c158000, 0xffff8018, "fcmp.sult.s", "c0:3,f5:5,f10:5", 0, 0, 0, 0 }, 52254824Scg { 0x0c160000, 0xffff8018, "fcmp.cueq.s", "c0:3,f5:5,f10:5", 0, 0, 0, 0 }, 52374763Scg { 0x0c168000, 0xffff8018, "fcmp.sueq.s", "c0:3,f5:5,f10:5", 0, 0, 0, 0 }, 52454824Scg { 0x0c170000, 0xffff8018, "fcmp.cule.s", "c0:3,f5:5,f10:5", 0, 0, 0, 0 }, 525166918Sariff { 0x0c170000, 0xffff8018, "fcmp.cuge.s", "c0:3,f10:5,f5:5", 0, 0, 0, 0 }, 526166901Spiso { 0x0c178000, 0xffff8018, "fcmp.sule.s", "c0:3,f5:5,f10:5", 0, 0, 0, 0 }, 527166901Spiso { 0x0c180000, 0xffff8018, "fcmp.cne.s", "c0:3,f5:5,f10:5", 0, 0, 0, 0 }, 528166901Spiso { 0x0c188000, 0xffff8018, "fcmp.sne.s", "c0:3,f5:5,f10:5", 0, 0, 0, 0 }, 529166901Spiso { 0x0c1a0000, 0xffff8018, "fcmp.cor.s", "c0:3,f5:5,f10:5", 0, 0, 0, 0 }, 530166918Sariff { 0x0c1a8000, 0xffff8018, "fcmp.sor.s", "c0:3,f5:5,f10:5", 0, 0, 0, 0 }, 53174763Scg { 0x0c1c0000, 0xffff8018, "fcmp.cune.s", "c0:3,f5:5,f10:5", 0, 0, 0, 0 }, 53254824Scg { 0x0c1c8000, 0xffff8018, "fcmp.sune.s", "c0:3,f5:5,f10:5", 0, 0, 0, 0 }, 53354824Scg { 0x0d000000, 0xfffc0000, "fsel", "f0:5,f5:5,f10:5,c15:3", 0, 0, 0, 0 }, 53454824Scg { 0 } /* Terminate the list. */ 53554824Scg}; 53654824Scg 53774763Scgstatic struct loongarch_opcode loongarch_4opt_double_float_opcodes[] = 53874763Scg{ 53954824Scg /* match, mask, name, format, macro, include, exclude, pinfo. */ 54074763Scg { 0x08200000, 0xfff00000, "fmadd.d", "f0:5,f5:5,f10:5,f15:5", 0, 0, 0, 0 }, 54154824Scg { 0x08600000, 0xfff00000, "fmsub.d", "f0:5,f5:5,f10:5,f15:5", 0, 0, 0, 0 }, 54254824Scg { 0x08a00000, 0xfff00000, "fnmadd.d", "f0:5,f5:5,f10:5,f15:5", 0, 0, 0, 0 }, 54354824Scg { 0x08e00000, 0xfff00000, "fnmsub.d", "f0:5,f5:5,f10:5,f15:5", 0, 0, 0, 0 }, 54454824Scg { 0x0c200000, 0xffff8018, "fcmp.caf.d", "c0:3,f5:5,f10:5", 0, 0, 0, 0 }, 54574763Scg { 0x0c208000, 0xffff8018, "fcmp.saf.d", "c0:3,f5:5,f10:5", 0, 0, 0, 0 }, 54654824Scg { 0x0c210000, 0xffff8018, "fcmp.clt.d", "c0:3,f5:5,f10:5", 0, 0, 0, 0 }, 54754824Scg { 0x0c218000, 0xffff8018, "fcmp.slt.d", "c0:3,f5:5,f10:5", 0, 0, 0, 0 }, 54874763Scg { 0x0c218000, 0xffff8018, "fcmp.sgt.d", "c0:3,f10:5,f5:5", 0, 0, 0, 0 }, 54974763Scg { 0x0c220000, 0xffff8018, "fcmp.ceq.d", "c0:3,f5:5,f10:5", 0, 0, 0, 0 }, 55054824Scg { 0x0c228000, 0xffff8018, "fcmp.seq.d", "c0:3,f5:5,f10:5", 0, 0, 0, 0 }, 55154824Scg { 0x0c230000, 0xffff8018, "fcmp.cle.d", "c0:3,f5:5,f10:5", 0, 0, 0, 0 }, 55254824Scg { 0x0c238000, 0xffff8018, "fcmp.sle.d", "c0:3,f5:5,f10:5", 0, 0, 0, 0 }, 55354824Scg { 0x0c238000, 0xffff8018, "fcmp.sge.d", "c0:3,f10:5,f5:5", 0, 0, 0, 0 }, 55454824Scg { 0x0c240000, 0xffff8018, "fcmp.cun.d", "c0:3,f5:5,f10:5", 0, 0, 0, 0 }, 55554824Scg { 0x0c248000, 0xffff8018, "fcmp.sun.d", "c0:3,f5:5,f10:5", 0, 0, 0, 0 }, 55654824Scg { 0x0c250000, 0xffff8018, "fcmp.cult.d", "c0:3,f5:5,f10:5", 0, 0, 0, 0 }, 55754824Scg { 0x0c250000, 0xffff8018, "fcmp.cugt.d", "c0:3,f10:5,f5:5", 0, 0, 0, 0 }, 55874763Scg { 0x0c258000, 0xffff8018, "fcmp.sult.d", "c0:3,f5:5,f10:5", 0, 0, 0, 0 }, 55954824Scg { 0x0c260000, 0xffff8018, "fcmp.cueq.d", "c0:3,f5:5,f10:5", 0, 0, 0, 0 }, 56074763Scg { 0x0c268000, 0xffff8018, "fcmp.sueq.d", "c0:3,f5:5,f10:5", 0, 0, 0, 0 }, 56154824Scg { 0x0c270000, 0xffff8018, "fcmp.cule.d", "c0:3,f5:5,f10:5", 0, 0, 0, 0 }, 56254824Scg { 0x0c270000, 0xffff8018, "fcmp.cuge.d", "c0:3,f10:5,f5:5", 0, 0, 0, 0 }, 56354824Scg { 0x0c278000, 0xffff8018, "fcmp.sule.d", "c0:3,f5:5,f10:5", 0, 0, 0, 0 }, 56454824Scg { 0x0c280000, 0xffff8018, "fcmp.cne.d", "c0:3,f5:5,f10:5", 0, 0, 0, 0 }, 56554824Scg { 0x0c288000, 0xffff8018, "fcmp.sne.d", "c0:3,f5:5,f10:5", 0, 0, 0, 0 }, 56674763Scg { 0x0c2a0000, 0xffff8018, "fcmp.cor.d", "c0:3,f5:5,f10:5", 0, 0, 0, 0 }, 56774763Scg { 0x0c2a8000, 0xffff8018, "fcmp.sor.d", "c0:3,f5:5,f10:5", 0, 0, 0, 0 }, 56854824Scg { 0x0c2c0000, 0xffff8018, "fcmp.cune.d", "c0:3,f5:5,f10:5", 0, 0, 0, 0 }, 56974763Scg { 0x0c2c8000, 0xffff8018, "fcmp.sune.d", "c0:3,f5:5,f10:5", 0, 0, 0, 0 }, 57054824Scg { 0 } /* Terminate the list. */ 57154824Scg}; 57254824Scg 57354824Scgstatic struct loongarch_opcode loongarch_load_store_opcodes[] = 57454824Scg{ 57554824Scg /* match, mask, name, format, macro, include, exclude, pinfo. */ 57674763Scg { 0x20000000, 0xff000000, "ll.w", "r0:5,r5:5,s10:14<<2", 0, 0, 0, 0 }, 57774763Scg { 0x21000000, 0xff000000, "sc.w", "r0:5,r5:5,s10:14<<2", 0, 0, 0, 0 }, 57854824Scg { 0x22000000, 0xff000000, "ll.d", "r0:5,r5:5,s10:14<<2", 0, 0, 0, 0 }, 57954824Scg { 0x23000000, 0xff000000, "sc.d", "r0:5,r5:5,s10:14<<2", 0, 0, 0, 0 }, 58053553Stanimura { 0x24000000, 0xff000000, "ldptr.w", "r0:5,r5:5,s10:14<<2", 0, 0, 0, 0 }, 58153553Stanimura { 0x25000000, 0xff000000, "stptr.w", "r0:5,r5:5,s10:14<<2", 0, 0, 0, 0 }, 58253553Stanimura { 0x26000000, 0xff000000, "ldptr.d", "r0:5,r5:5,s10:14<<2", 0, 0, 0, 0 }, 58353553Stanimura { 0x27000000, 0xff000000, "stptr.d", "r0:5,r5:5,s10:14<<2", 0, 0, 0, 0 }, 58454462Scg { 0x28000000, 0xffc00000, "ld.b", "r0:5,r5:5,s10:12", 0, 0, 0, 0 }, 58553553Stanimura { 0x28400000, 0xffc00000, "ld.h", "r0:5,r5:5,s10:12", 0, 0, 0, 0 }, 58653553Stanimura { 0x28800000, 0xffc00000, "ld.w", "r0:5,r5:5,s10:12", 0, 0, 0, 0 }, 58760711Snyan { 0x28c00000, 0xffc00000, "ld.d", "r0:5,r5:5,s10:12", 0, 0, 0, 0 }, 58860711Snyan { 0x29000000, 0xffc00000, "st.b", "r0:5,r5:5,s10:12", 0, 0, 0, 0 }, 58960711Snyan { 0x29400000, 0xffc00000, "st.h", "r0:5,r5:5,s10:12", 0, 0, 0, 0 }, 59053553Stanimura { 0x29800000, 0xffc00000, "st.w", "r0:5,r5:5,s10:12", 0, 0, 0, 0 }, 59153553Stanimura { 0x29c00000, 0xffc00000, "st.d", "r0:5,r5:5,s10:12", 0, 0, 0, 0 }, 59253553Stanimura { 0x2a000000, 0xffc00000, "ld.bu", "r0:5,r5:5,s10:12", 0, 0, 0, 0 }, 59353553Stanimura { 0x2a400000, 0xffc00000, "ld.hu", "r0:5,r5:5,s10:12", 0, 0, 0, 0 }, 59453553Stanimura { 0x2a800000, 0xffc00000, "ld.wu", "r0:5,r5:5,s10:12", 0, 0, 0, 0 }, 59553553Stanimura { 0x2ac00000, 0xffc00000, "preld", "u0:5,r5:5,s10:12", 0, 0, 0, 0 }, 59660711Snyan { 0x38000000, 0xffff8000, "ldx.b", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 59760711Snyan { 0x38040000, 0xffff8000, "ldx.h", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 59860711Snyan { 0x38080000, 0xffff8000, "ldx.w", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 59960711Snyan { 0x380c0000, 0xffff8000, "ldx.d", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 60060711Snyan { 0x38100000, 0xffff8000, "stx.b", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 60154824Scg { 0x38140000, 0xffff8000, "stx.h", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 60260711Snyan { 0x38180000, 0xffff8000, "stx.w", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 60353553Stanimura { 0x381c0000, 0xffff8000, "stx.d", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 60453553Stanimura { 0x38200000, 0xffff8000, "ldx.bu", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 60554462Scg { 0x38240000, 0xffff8000, "ldx.hu", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 60654462Scg { 0x38280000, 0xffff8000, "ldx.wu", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 60754462Scg { 0x382c0000, 0xffff8000, "preldx", "u0:5,r5:5,r10:5", 0, 0, 0, 0 }, 60854824Scg { 0x0, 0x0, "amswap.w", "r,r,r,u0:0", "amswap.w %1,%2,%3", 0, 0, 0 }, 60954462Scg { 0x38600000, 0xffff8000, "amswap.w", "r0:5,r10:5,r5:5", 0, 0, 0, 0 }, 61054462Scg { 0x0, 0x0, "amswap.d", "r,r,r,u0:0", "amswap.d %1,%2,%3", 0, 0, 0 }, 61153553Stanimura { 0x38608000, 0xffff8000, "amswap.d", "r0:5,r10:5,r5:5", 0, 0, 0, 0 }, 61254824Scg { 0x0, 0x0, "amadd.w", "r,r,r,u0:0", "amadd.w %1,%2,%3", 0, 0, 0 }, 61354824Scg { 0x38610000, 0xffff8000, "amadd.w", "r0:5,r10:5,r5:5", 0, 0, 0, 0 }, 61454824Scg { 0x0, 0x0, "amadd.d", "r,r,r,u0:0", "amadd.d %1,%2,%3", 0, 0, 0 }, 61554824Scg { 0x38618000, 0xffff8000, "amadd.d", "r0:5,r10:5,r5:5", 0, 0, 0, 0 }, 61653553Stanimura { 0x0, 0x0, "amand.w", "r,r,r,u0:0", "amand.w %1,%2,%3", 0, 0, 0 }, 61753553Stanimura { 0x38620000, 0xffff8000, "amand.w", "r0:5,r10:5,r5:5", 0, 0, 0, 0 }, 61853553Stanimura { 0x0, 0x0, "amand.d", "r,r,r,u0:0", "amand.d %1,%2,%3", 0, 0, 0 }, 61953553Stanimura { 0x38628000, 0xffff8000, "amand.d", "r0:5,r10:5,r5:5", 0, 0, 0, 0 }, 62053553Stanimura { 0x0, 0x0, "amor.w", "r,r,r,u0:0", "amor.w %1,%2,%3", 0, 0, 0 }, 62153553Stanimura { 0x38630000, 0xffff8000, "amor.w", "r0:5,r10:5,r5:5", 0, 0, 0, 0 }, 62253553Stanimura { 0x0, 0x0, "amor.d", "r,r,r,u0:0", "amor.d %1,%2,%3", 0, 0, 0 }, 62353553Stanimura { 0x38638000, 0xffff8000, "amor.d", "r0:5,r10:5,r5:5", 0, 0, 0, 0 }, 62453553Stanimura { 0x0, 0x0, "amxor.w", "r,r,r,u0:0", "amxor.w %1,%2,%3", 0, 0, 0 }, 62554961Speter { 0x38640000, 0xffff8000, "amxor.w", "r0:5,r10:5,r5:5", 0, 0, 0, 0 }, 62653553Stanimura { 0x0, 0x0, "amxor.d", "r,r,r,u0:0", "amxor.d %1,%2,%3", 0, 0, 0 }, 62753553Stanimura { 0x38648000, 0xffff8000, "amxor.d", "r0:5,r10:5,r5:5", 0, 0, 0, 0 }, 62853553Stanimura { 0x0, 0x0, "ammax.w", "r,r,r,u0:0", "ammax.w %1,%2,%3", 0, 0, 0 }, 62953553Stanimura { 0x38650000, 0xffff8000, "ammax.w", "r0:5,r10:5,r5:5", 0, 0, 0, 0 }, 63053553Stanimura { 0x0, 0x0, "ammax.d", "r,r,r,u0:0", "ammax.d %1,%2,%3", 0, 0, 0 }, 63153553Stanimura { 0x38658000, 0xffff8000, "ammax.d", "r0:5,r10:5,r5:5", 0, 0, 0, 0 }, 63254462Scg { 0x0, 0x0, "ammin.w", "r,r,r,u0:0", "ammin.w %1,%2,%3", 0, 0, 0 }, 63353553Stanimura { 0x38660000, 0xffff8000, "ammin.w", "r0:5,r10:5,r5:5", 0, 0, 0, 0 }, 63453553Stanimura { 0x0, 0x0, "ammin.d", "r,r,r,u0:0", "ammin.d %1,%2,%3", 0, 0, 0 }, 63553553Stanimura { 0x38668000, 0xffff8000, "ammin.d", "r0:5,r10:5,r5:5", 0, 0, 0, 0 }, 63653553Stanimura { 0x0, 0x0, "ammax.wu", "r,r,r,u0:0", "ammax.wu %1,%2,%3", 0, 0, 0 }, 63753553Stanimura { 0x38670000, 0xffff8000, "ammax.wu", "r0:5,r10:5,r5:5", 0, 0, 0, 0 }, 63853553Stanimura { 0x0, 0x0, "ammax.du", "r,r,r,u0:0", "ammax.du %1,%2,%3", 0, 0, 0 }, 63954824Scg { 0x38678000, 0xffff8000, "ammax.du", "r0:5,r10:5,r5:5", 0, 0, 0, 0 }, 64053553Stanimura { 0x0, 0x0, "ammin.wu", "r,r,r,u0:0", "ammin.wu %1,%2,%3", 0, 0, 0 }, 64154462Scg { 0x38680000, 0xffff8000, "ammin.wu", "r0:5,r10:5,r5:5", 0, 0, 0, 0 }, 64254462Scg { 0x0, 0x0, "ammin.du", "r,r,r,u0:0", "ammin.du %1,%2,%3", 0, 0, 0 }, 64354824Scg { 0x38688000, 0xffff8000, "ammin.du", "r0:5,r10:5,r5:5", 0, 0, 0, 0 }, 64454462Scg { 0x0, 0x0, "amswap_db.w", "r,r,r,u0:0", "amswap_db.w %1,%2,%3", 0, 0, 0 }, 64553553Stanimura { 0x38690000, 0xffff8000, "amswap_db.w", "r0:5,r10:5,r5:5", 0, 0, 0, 0 }, 64654824Scg { 0x0, 0x0, "amswap_db.d", "r,r,r,u0:0", "amswap_db.d %1,%2,%3", 0, 0, 0 }, 64754824Scg { 0x38698000, 0xffff8000, "amswap_db.d", "r0:5,r10:5,r5:5", 0, 0, 0, 0 }, 64853553Stanimura { 0x0, 0x0, "amadd_db.w", "r,r,r,u0:0", "amadd_db.w %1,%2,%3", 0, 0, 0 }, 64953553Stanimura { 0x386a0000, 0xffff8000, "amadd_db.w", "r0:5,r10:5,r5:5", 0, 0, 0, 0 }, 65053553Stanimura { 0x0, 0x0, "amadd_db.d", "r,r,r,u0:0", "amadd_db.d %1,%2,%3", 0, 0, 0 }, 65153553Stanimura { 0x386a8000, 0xffff8000, "amadd_db.d", "r0:5,r10:5,r5:5", 0, 0, 0, 0 }, 65253553Stanimura { 0x0, 0x0, "amand_db.w", "r,r,r,u0:0", "amand_db.w %1,%2,%3", 0, 0, 0 }, 65353553Stanimura { 0x386b0000, 0xffff8000, "amand_db.w", "r0:5,r10:5,r5:5", 0, 0, 0, 0 }, 65453553Stanimura { 0x0, 0x0, "amand_db.d", "r,r,r,u0:0", "amand_db.d %1,%2,%3", 0, 0, 0 }, 65553553Stanimura { 0x386b8000, 0xffff8000, "amand_db.d", "r0:5,r10:5,r5:5", 0, 0, 0, 0 }, 65653553Stanimura { 0x0, 0x0, "amor_db.w", "r,r,r,u0:0", "amor_db.w %1,%2,%3", 0, 0, 0 }, 65753553Stanimura { 0x386c0000, 0xffff8000, "amor_db.w", "r0:5,r10:5,r5:5", 0, 0, 0, 0 }, 65853553Stanimura { 0x0, 0x0, "amor_db.d", "r,r,r,u0:0", "amor_db.d %1,%2,%3", 0, 0, 0 }, 65953553Stanimura { 0x386c8000, 0xffff8000, "amor_db.d", "r0:5,r10:5,r5:5", 0, 0, 0, 0 }, 66053553Stanimura { 0x0, 0x0, "amxor_db.w", "r,r,r,u0:0", "amxor_db.w %1,%2,%3", 0, 0, 0 }, 66154462Scg { 0x386d0000, 0xffff8000, "amxor_db.w", "r0:5,r10:5,r5:5", 0, 0, 0, 0 }, 66253553Stanimura { 0x0, 0x0, "amxor_db.d", "r,r,r,u0:0", "amxor_db.d %1,%2,%3", 0, 0, 0 }, 66354462Scg { 0x386d8000, 0xffff8000, "amxor_db.d", "r0:5,r10:5,r5:5", 0, 0, 0, 0 }, 66454462Scg { 0x0, 0x0, "ammax_db.w", "r,r,r,u0:0", "ammax_db.w %1,%2,%3", 0, 0, 0 }, 66554462Scg { 0x386e0000, 0xffff8000, "ammax_db.w", "r0:5,r10:5,r5:5", 0, 0, 0, 0 }, 66654462Scg { 0x0, 0x0, "ammax_db.d", "r,r,r,u0:0", "ammax_db.d %1,%2,%3", 0, 0, 0 }, 66754462Scg { 0x386e8000, 0xffff8000, "ammax_db.d", "r0:5,r10:5,r5:5", 0, 0, 0, 0 }, 66854462Scg { 0x0, 0x0, "ammin_db.w", "r,r,r,u0:0", "ammin_db.w %1,%2,%3", 0, 0, 0 }, 66954462Scg { 0x386f0000, 0xffff8000, "ammin_db.w", "r0:5,r10:5,r5:5", 0, 0, 0, 0 }, 67054462Scg { 0x0, 0x0, "ammin_db.d", "r,r,r,u0:0", "ammin_db.d %1,%2,%3", 0, 0, 0 }, 67154462Scg { 0x386f8000, 0xffff8000, "ammin_db.d", "r0:5,r10:5,r5:5", 0, 0, 0, 0 }, 67254462Scg { 0x0, 0x0, "ammax_db.wu", "r,r,r,u0:0", "ammax_db.wu %1,%2,%3", 0, 0, 0 }, 67354462Scg { 0x38700000, 0xffff8000, "ammax_db.wu", "r0:5,r10:5,r5:5", 0, 0, 0, 0 }, 67454462Scg { 0x0, 0x0, "ammax_db.du", "r,r,r,u0:0", "ammax_db.du %1,%2,%3", 0, 0, 0 }, 67554462Scg { 0x38708000, 0xffff8000, "ammax_db.du", "r0:5,r10:5,r5:5", 0, 0, 0, 0 }, 67654462Scg { 0x0, 0x0, "ammin_db.wu", "r,r,r,u0:0", "ammin_db.wu %1,%2,%3", 0, 0, 0 }, 67754462Scg { 0x38710000, 0xffff8000, "ammin_db.wu", "r0:5,r10:5,r5:5", 0, 0, 0, 0 }, 67854462Scg { 0x0, 0x0, "ammin_db.du", "r,r,r,u0:0", "ammin_db.du %1,%2,%3", 0, 0, 0 }, 67954462Scg { 0x38718000, 0xffff8000, "ammin_db.du", "r0:5,r10:5,r5:5", 0, 0, 0, 0 }, 68054462Scg { 0x38720000, 0xffff8000, "dbar", "u0:15", 0, 0, 0, 0 }, 68154462Scg { 0x38728000, 0xffff8000, "ibar", "u0:15", 0, 0, 0, 0 }, 68254462Scg { 0x38780000, 0xffff8000, "ldgt.b", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 68354462Scg { 0x38788000, 0xffff8000, "ldgt.h", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 68454462Scg { 0x38790000, 0xffff8000, "ldgt.w", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 68554462Scg { 0x38798000, 0xffff8000, "ldgt.d", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 68654462Scg { 0x387a0000, 0xffff8000, "ldle.b", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 68754462Scg { 0x387a8000, 0xffff8000, "ldle.h", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 68854462Scg { 0x387b0000, 0xffff8000, "ldle.w", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 68954462Scg { 0x387b8000, 0xffff8000, "ldle.d", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 69054462Scg { 0x387c0000, 0xffff8000, "stgt.b", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 69154462Scg { 0x387c8000, 0xffff8000, "stgt.h", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 69254462Scg { 0x387d0000, 0xffff8000, "stgt.w", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 69354462Scg { 0x387d8000, 0xffff8000, "stgt.d", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 69454462Scg { 0x387e0000, 0xffff8000, "stle.b", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 69554462Scg { 0x387e8000, 0xffff8000, "stle.h", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 69654462Scg { 0x387f0000, 0xffff8000, "stle.w", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 69754462Scg { 0x387f8000, 0xffff8000, "stle.d", "r0:5,r5:5,r10:5", 0, 0, 0, 0 }, 69854462Scg { 0 } /* Terminate the list. */ 69953553Stanimura}; 70053553Stanimura 70154824Scgstatic struct loongarch_opcode loongarch_single_float_load_store_opcodes[] = 70253553Stanimura{ 70360711Snyan /* match, mask, name, format, macro, include, exclude, pinfo. */ 70460711Snyan { 0x2b000000, 0xffc00000, "fld.s", "f0:5,r5:5,s10:12", 0, 0, 0, 0 }, 70560711Snyan { 0x2b400000, 0xffc00000, "fst.s", "f0:5,r5:5,s10:12", 0, 0, 0, 0 }, 70660711Snyan { 0x38300000, 0xffff8000, "fldx.s", "f0:5,r5:5,r10:5", 0, &LARCH_opts.ase_lp64, 0, 0 }, 70760711Snyan { 0x38380000, 0xffff8000, "fstx.s", "f0:5,r5:5,r10:5", 0, &LARCH_opts.ase_lp64, 0, 0 }, 70860711Snyan { 0x38740000, 0xffff8000, "fldgt.s", "f0:5,r5:5,r10:5", 0, &LARCH_opts.ase_lp64, 0, 0 }, 70960711Snyan { 0x38750000, 0xffff8000, "fldle.s", "f0:5,r5:5,r10:5", 0, &LARCH_opts.ase_lp64, 0, 0 }, 71060711Snyan { 0x38760000, 0xffff8000, "fstgt.s", "f0:5,r5:5,r10:5", 0, &LARCH_opts.ase_lp64, 0, 0 }, 71160711Snyan { 0x38770000, 0xffff8000, "fstle.s", "f0:5,r5:5,r10:5", 0, &LARCH_opts.ase_lp64, 0, 0 }, 71260711Snyan { 0 } /* Terminate the list. */ 71360711Snyan}; 71460711Snyan 71560711Snyanstatic struct loongarch_opcode loongarch_double_float_load_store_opcodes[] = 71653553Stanimura{ 71753553Stanimura /* match, mask, name, format, macro, include, exclude, pinfo. */ 71853553Stanimura { 0x2b800000, 0xffc00000, "fld.d", "f0:5,r5:5,s10:12", 0, 0, 0, 0 }, 71960711Snyan { 0x2bc00000, 0xffc00000, "fst.d", "f0:5,r5:5,s10:12", 0, 0, 0, 0 }, 72054462Scg { 0x38340000, 0xffff8000, "fldx.d", "f0:5,r5:5,r10:5", 0, &LARCH_opts.ase_lp64, 0, 0 }, 72153553Stanimura { 0x383c0000, 0xffff8000, "fstx.d", "f0:5,r5:5,r10:5", 0, &LARCH_opts.ase_lp64, 0, 0 }, 72253553Stanimura { 0x38748000, 0xffff8000, "fldgt.d", "f0:5,r5:5,r10:5", 0, &LARCH_opts.ase_lp64, 0, 0 }, 72353553Stanimura { 0x38758000, 0xffff8000, "fldle.d", "f0:5,r5:5,r10:5", 0, &LARCH_opts.ase_lp64, 0, 0 }, 72453553Stanimura { 0x38768000, 0xffff8000, "fstgt.d", "f0:5,r5:5,r10:5", 0, &LARCH_opts.ase_lp64, 0, 0 }, 72554824Scg { 0x38778000, 0xffff8000, "fstle.d", "f0:5,r5:5,r10:5", 0, &LARCH_opts.ase_lp64, 0, 0 }, 72653553Stanimura { 0 } /* Terminate the list. */ 72753553Stanimura}; 728127135Snjl 729127135Snjlstatic struct loongarch_opcode loongarch_float_jmp_opcodes[] = 730127135Snjl{ 731127135Snjl { 0x0, 0x0, "bceqz", "c,la", "bceqz %1,%%pcrel(%2)", 0, 0, 0 }, 73254462Scg { 0x48000000, 0xfc000300, "bceqz", "c5:3,sb0:5|10:16<<2", 0, 0, 0, 0 }, 73353553Stanimura { 0x0, 0x0, "bcnez", "c,la", "bcnez %1,%%pcrel(%2)", 0, 0, 0 }, 73453553Stanimura { 0x48000100, 0xfc000300, "bcnez", "c5:3,sb0:5|10:16<<2", 0, 0, 0, 0 }, 73553553Stanimura { 0 } /* Terminate the list. */ 73653553Stanimura}; 73754824Scg 73865644Scgstatic struct loongarch_opcode loongarch_jmp_opcodes[] = 73954824Scg{ 740127135Snjl /* match, mask, name, format, macro, include, exclude, pinfo. */ 741127135Snjl { 0x0, 0x0, "bltz", "r,la", "bltz %1,%%pcrel(%2)", 0, 0, 0 }, 742127135Snjl { 0x60000000, 0xfc00001f, "bltz", "r5:5,sb10:16<<2", 0, 0, 0, 0 }, 743127135Snjl { 0x0, 0x0, "bgtz", "r,la", "bgtz %1,%%pcrel(%2)", 0, 0, 0 }, 74454824Scg { 0x60000000, 0xfc0003e0, "bgtz", "r0:5,sb10:16<<2", 0, 0, 0, 0 }, 74554824Scg { 0x0, 0x0, "bgez", "r,la", "bgez %1,%%pcrel(%2)", 0, 0, 0 }, 74654824Scg { 0x64000000, 0xfc00001f, "bgez", "r5:5,sb10:16<<2", 0, 0, 0, 0 }, 74754824Scg { 0x0, 0x0, "blez", "r,la", "blez %1,%%pcrel(%2)", 0, 0, 0 }, 74854462Scg { 0x64000000, 0xfc0003e0, "blez", "r0:5,sb10:16<<2", 0, 0, 0, 0 }, 74953553Stanimura { 0x0, 0x0, "beqz", "r,la", "beqz %1,%%pcrel(%2)", 0, 0, 0 }, 75053553Stanimura { 0x40000000, 0xfc000000, "beqz", "r5:5,sb0:5|10:16<<2", 0, 0, 0, 0 }, 75153553Stanimura { 0x0, 0x0, "bnez", "r,la", "bnez %1,%%pcrel(%2)", 0, 0, 0 }, 75253553Stanimura { 0x44000000, 0xfc000000, "bnez", "r5:5,sb0:5|10:16<<2", 0, 0, 0, 0 }, 75354462Scg { 0x0, 0x0, "jr", "r", "jirl $r0,%1,0", 0, 0, 0 }, 75453553Stanimura { 0x50000000, 0xfc000000, "b", "sb0:10|10:16<<2", 0, 0, 0, 0 }, 75553553Stanimura { 0x0, 0x0, "b", "la", "b %%pcrel(%1)", 0, 0, 0 }, 75653553Stanimura { 0x4c000000, 0xfc000000, "jirl", "r0:5,r5:5,s10:16<<2", 0, 0, 0, 0 }, 75754824Scg { 0x0, 0x0, "bl", "la", "bl %%pcrel(%1)", 0, 0, 0 }, 75853553Stanimura { 0x54000000, 0xfc000000, "bl", "sb0:10|10:16<<2", 0, 0, 0, 0 }, 75953553Stanimura { 0x0, 0x0, "beq", "r,r,la", "beq %1,%2,%%pcrel(%3)", 0, 0, 0 }, 76053553Stanimura { 0x58000000, 0xfc000000, "beq", "r5:5,r0:5,sb10:16<<2", 0, 0, 0, 0 }, 76153553Stanimura { 0x0, 0x0, "bne", "r,r,la", "bne %1,%2,%%pcrel(%3)", 0, 0, 0 }, 76253553Stanimura { 0x5c000000, 0xfc000000, "bne", "r5:5,r0:5,sb10:16<<2", 0, 0, 0, 0 }, 76354824Scg { 0x0, 0x0, "blt", "r,r,la", "blt %1,%2,%%pcrel(%3)", 0, 0, 0 }, 76453553Stanimura { 0x60000000, 0xfc000000, "blt", "r5:5,r0:5,sb10:16<<2", 0, 0, 0, 0 }, 76553553Stanimura { 0x0, 0x0, "bgt", "r,r,la", "bgt %1,%2,%%pcrel(%3)", 0, 0, 0 }, 76653553Stanimura { 0x60000000, 0xfc000000, "bgt", "r0:5,r5:5,sb10:16<<2", 0, 0, 0, 0 }, 76753553Stanimura { 0x0, 0x0, "bge", "r,r,la", "bge %1,%2,%%pcrel(%3)", 0, 0, 0 }, 76853553Stanimura { 0x64000000, 0xfc000000, "bge", "r5:5,r0:5,sb10:16<<2", 0, 0, 0, 0 }, 76954824Scg { 0x0, 0x0, "ble", "r,r,la", "ble %1,%2,%%pcrel(%3)", 0, 0, 0 }, 77054824Scg { 0x64000000, 0xfc000000, "ble", "r0:5,r5:5,sb10:16<<2", 0, 0, 0, 0 }, 77165644Scg { 0x0, 0x0, "bltu", "r,r,la", "bltu %1,%2,%%pcrel(%3)", 0, 0, 0 }, 77265644Scg { 0x68000000, 0xfc000000, "bltu", "r5:5,r0:5,sb10:16<<2", 0, 0, 0, 0 }, 77365644Scg { 0x0, 0x0, "bgtu", "r,r,la", "bgtu %1,%2,%%pcrel(%3)", 0, 0, 0 }, 77454824Scg { 0x68000000, 0xfc000000, "bgtu", "r0:5,r5:5,sb10:16<<2", 0, 0, 0, 0 }, 77554824Scg { 0x0, 0x0, "bgeu", "r,r,la", "bgeu %1,%2,%%pcrel(%3)", 0, 0, 0 }, 77654824Scg { 0x6c000000, 0xfc000000, "bgeu", "r5:5,r0:5,sb10:16<<2", 0, 0, 0, 0 }, 77754824Scg { 0x0, 0x0, "bleu", "r,r,la", "bleu %1,%2,%%pcrel(%3)", 0, 0, 0 }, 77853553Stanimura { 0x6c000000, 0xfc000000, "bleu", "r0:5,r5:5,sb10:16<<2", 0, 0, 0, 0 }, 77953553Stanimura { 0 } /* Terminate the list. */ 78053553Stanimura}; 78153553Stanimura 78253553Stanimurastruct loongarch_ase loongarch_ASEs[] = 78353553Stanimura{ 78453553Stanimura { &LARCH_opts.ase_ilp32, loongarch_macro_opcodes, 0, 0, { 0 }, 0, 0 }, 78565644Scg { &LARCH_opts.ase_ilp32, loongarch_imm_opcodes, 0, 0, { 0 }, 0, 0 }, 78653553Stanimura { &LARCH_opts.ase_ilp32, loongarch_privilege_opcodes, 0, 0, { 0 }, 0, 0 }, 78753553Stanimura { &LARCH_opts.ase_ilp32, loongarch_load_store_opcodes, 0, 0, { 0 }, 0, 0 }, 78853553Stanimura { &LARCH_opts.ase_ilp32, loongarch_fix_opcodes, 0, 0, { 0 }, 0, 0 }, 78953553Stanimura { &LARCH_opts.ase_ilp32, loongarch_jmp_opcodes, 0, 0, { 0 }, 0, 0 }, 79053553Stanimura { &LARCH_opts.ase_sf, loongarch_float_jmp_opcodes, 0, 0, { 0 }, 0, 0 }, 79154462Scg { &LARCH_opts.ase_sf, loongarch_single_float_opcodes, 0, 0, { 0 }, 0, 0 }, 79254462Scg { &LARCH_opts.ase_df, loongarch_double_float_opcodes, 0, 0, { 0 }, 0, 0 }, 79353553Stanimura { &LARCH_opts.ase_sf, loongarch_4opt_single_float_opcodes, 0, 0, { 0 }, 0, 0 }, 79453553Stanimura { &LARCH_opts.ase_df, loongarch_4opt_double_float_opcodes, 0, 0, { 0 }, 0, 0 }, 79553553Stanimura { &LARCH_opts.ase_sf, loongarch_single_float_load_store_opcodes, 0, 0, { 0 }, 0, 0 }, 79653553Stanimura { &LARCH_opts.ase_df, loongarch_double_float_load_store_opcodes, 0, 0, { 0 }, 0, 0 }, 79754824Scg { 0 }, 79854824Scg}; 79953553Stanimura